/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKKA0020502TPMA
*	ソースファイル名：JEKKA0020502TPMA.java
*	作成者			：富士通
*	日付			：2013年02月14日
*＜機能概要＞
*	宅内機器一意照会（６）から契約Ｓ宅内情報処理を呼び出すための独自部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v4.00.00	2013/02/14	FJ)古内		【ST1-2013-0000311】宅内エラー対応
*	v32.00.00   2017/05/26  FJ)河邊     【OM-2017-0000488】オープンカーソルエラー
*
********************************************************************************/
package eo.ejb.cbs.mainproc;

import java.sql.Connection;
import java.util.ArrayList;
import java.util.Hashtable;

import com.fujitsu.futurity.model.base.CAANConnectionMgr;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.ejb.common.JSYejbConnection;
import com.fujitsu.futurity.model.ejb.common.StatusCodes;
import com.fujitsu.futurity.model.ejb.common.fw.AgentDispatchContext;
import com.fujitsu.futurity.model.ejb.common.fw.TemplateMainHandler;

import eo.ejb.cbs.cbsmsg.EKKA0020502CBSMsg;
import eo.ejb.cbs.cbsmsg.EKKA0020502CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKKA0020502CBSMsg2List;
import eo.ejb.common.JCCModelCommon;
import eo.ejb.common.JKKCtrlTnInfo;
import eo.ejb.common.JWCCtrlTnInfo;

public class JEKKA0020502TPMA implements TemplateMainHandler {

	/**
	 * 結果コード
	 */
	private static final String CMD_RESULT_CD = "CMD_RESULT_CD";
	
	// コマンド実行部品用
	@SuppressWarnings("unchecked")
	public static void ctrlTnInfo(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		Hashtable<String, Object > serviceMap = new Hashtable<String, Object>();
		
		ArrayList<Hashtable<String,  Object>>list = new ArrayList<Hashtable<String, Object>>();
		
		CAANMsg[] listCaan = inCBSMsg.getCAANMsgList(EKKA0020502CBSMsg.EKKA0020502CBSMSG1LIST);
		
		Hashtable<String, Object > serviceMapList_head = new Hashtable<String, Object>();

		//operatorID
		String operatorId = inCBSMsg.getString(EKKA0020502CBSMsg.OPERATORID);
		if(operatorId != null)
		{
			serviceMapList_head.put(JWCCtrlTnInfo.OPERATORID, operatorId);
		}
		else
		{
			serviceMapList_head.put(JWCCtrlTnInfo.OPERATORID, "");
		}
		
		//operatorDateTime
		String operatoDateTime = inCBSMsg.getString(EKKA0020502CBSMsg.OPERATEDATETIME);
		if(operatoDateTime != null)
		{
			serviceMapList_head.put(JWCCtrlTnInfo.OPERATEDATETIME, operatoDateTime);
		}
		else
		{
			serviceMapList_head.put(JWCCtrlTnInfo.OPERATEDATETIME, "");
		}
		list.add(serviceMapList_head);
		// 
		for(int i = 0 ; i < listCaan.length ; i++)
		{
			Hashtable<String, Object > serviceMapList = new Hashtable<String, Object>();
			//ＫＥＹ＿MACアドレス
			String key_mac_ad  =  listCaan[i].getString(EKKA0020502CBSMsg1List.KEY_MAC_AD);
			if(key_mac_ad != null)
			{
				serviceMapList.put(EKKA0020502CBSMsg1List.KEY_MAC_AD, key_mac_ad);
			}
			else 
			{
				serviceMapList.put(EKKA0020502CBSMsg1List.KEY_MAC_AD, "");
			}
			
			list.add(serviceMapList);
		}

		serviceMap.put(EKKA0020502CBSMsg.EKKA0020502CBSMSG1LIST, list);

		// スタブ用インスタンス
		int str_flag = Integer.parseInt(JCCModelCommon.getApplicationConst("TN_CONNECTION_MODE"));
		JKKCtrlTnInfo instance = JKKCtrlTnInfo.getInstance(str_flag);
		
		// テーブルのコネクションを取得して、部品に受け渡しを行う。
		Connection con = JSYejbConnection.getConnection("TK_T_TK");
		instance.setConnection(con);
		instance.setInContext(inContext);
		
		try
		{
			Hashtable ret = instance.ctrlTnInfo_KKA0007(serviceMap);
			
			CAANMsg[] l_ekka0020502csvmsg2list = null;

			String error_level = (String)ret.get("errorLevel");
			if(error_level != null)
			{
				inCBSMsg.set(EKKA0020502CBSMsg.ERROR_LEVEL, error_level);
			}
			else
			{
				inCBSMsg.set(EKKA0020502CBSMsg.ERROR_LEVEL, "");
			}
			

			String return_cd = (String)ret.get("returnCode");
			if(return_cd != null)
			{
				inCBSMsg.set(EKKA0020502CBSMsg.RETURN_CD, return_cd);
				if(("1000").equals(return_cd) || 
						("1050").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020502CBSMsg.STATUS, StatusCodes.SINGLEDATA_ERR);
				}
				else if(("1100").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020502CBSMsg.STATUS, StatusCodes.ITEM_RELATION_ERR);
				}
				else if(("1200").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020502CBSMsg.STATUS, StatusCodes.RELATION_ERR);
				}
				else if (("0500".equals(return_cd)))
				{
					inCBSMsg.set(EKKA0020502CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
					return;
				}
			}
			else
			{
				inCBSMsg.set(EKKA0020502CBSMsg.RETURN_CD, "");
			}

			String return_message = (String)ret.get("returnMessage");
			if(return_message != null)
			{
				inCBSMsg.set(EKKA0020502CBSMsg.RETURN_MESSAGE, return_message);
			}
			else
			{
				inCBSMsg.set(EKKA0020502CBSMsg.RETURN_MESSAGE, "");
			}
			
			//結果コードが"1"なら処理を終了する。
			if(ret.get(CMD_RESULT_CD) != null && ret.get(CMD_RESULT_CD).equals("1"))
			{
				inCBSMsg.set(EKKA0020502CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
				return;
			}	
			
			// 取得した戻り値を元に、inCBSMsgのアウト項目に値を設定して返す
			ArrayList<Hashtable<String, Object>> retlist = (ArrayList<Hashtable<String, Object>>)ret.get(EKKA0020502CBSMsg.EKKA0020502CBSMSG2LIST);

			//入力キーのエラー処理
			String[][] keyList = {
					{EKKA0020502CBSMsg1List.KEY_MAC_AD_ERR, EKKA0020502CBSMsg1List.KEY_MAC_AD.substring(4) + "_ERR"}
					};
			int cnt =0;
			String str ="";
			if(retlist != null && !retlist.isEmpty())
			{
				for(int i = 0 ; i < retlist.size() ; i ++)
				{
					Hashtable data = retlist.get(i);
	
					for (int j = 0; j < keyList.length; j++)
					{
						if (data.containsKey(keyList[j][1]))
						{

							listCaan[i].set(keyList[j][0], (String)data.get(keyList[j][1]));
							//EKKA0020502CBSMSG1LIST_ERRには最初のエラーを設定する。
							if(cnt == 0){
								str = (String)data.get(keyList[j][1]);
								cnt++;
							}
						}
					}
					
				}
			}
			if(cnt > 0){
				inCBSMsg.set(EKKA0020502CBSMsg.EKKA0020502CBSMSG1LIST_ERR, str);
			}
			
			
			if(retlist != null && !retlist.isEmpty())
			{
				// うまくいけば戻りの電文を設定して終了する。
				l_ekka0020502csvmsg2list =  new CAANMsg[retlist.size()];


				for(int i = 0 ; i < retlist.size() ; i ++)
				{
					Hashtable data = retlist.get(i);
					CAANMsg msg = new CAANMsg("eo.ejb.cbs.cbsmsg.EKKA0020502CBSMsg2List");
					
					l_ekka0020502csvmsg2list[i] = msg;
					//機器製造番号
					msg.set(EKKA0020502CBSMsg2List.KK_SEIZO_NO, (String)data.get(EKKA0020502CBSMsg2List.KK_SEIZO_NO));
					//MACアドレス
					msg.set(EKKA0020502CBSMsg2List.MAC_AD, (String)data.get(EKKA0020502CBSMsg2List.MAC_AD));
					//宅内機器ステータス
					msg.set(EKKA0020502CBSMsg2List.TK_STAT, (String)data.get(EKKA0020502CBSMsg2List.TK_STAT));
					//宅内機器基本Ｔ更新日付
					msg.set(EKKA0020502CBSMsg2List.KIHON_UPD_DTTM, (String)data.get(EKKA0020502CBSMsg2List.KIHON_UPD_DTTM));
					
					// ***** エラーチェック *****
					if (data.containsKey(EKKA0020502CBSMsg1List.KEY_MAC_AD.substring(4) + "_ERR"))
					{
						listCaan[i].set(EKKA0020502CBSMsg1List.KEY_MAC_AD_ERR, data.get(EKKA0020502CBSMsg1List.KEY_MAC_AD.substring(4) + "_ERR"));
					}
				}

				inCBSMsg.set(EKKA0020502CBSMsg.EKKA0020502CBSMSG2LIST, l_ekka0020502csvmsg2list);
				
			}
		}
		catch(Exception e)
		{
			e.printStackTrace();
			inCBSMsg.set(EKKA0020502CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
		}
// OM-2017-0000488 2017/05/26 ADD START
		finally
		{
			// 資源の解放
			if (con != null)
			{
				CAANConnectionMgr.getInstance().close(con);
			}
		}
// OM-2017-0000488 2017/05/26 ADD END
	}
}
