/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKKA0020503TPMA
*	ソースファイル名：JEKKA0020503TPMA.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.EKKA0020503CBSMsg;
import eo.ejb.cbs.cbsmsg.EKKA0020503CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKKA0020503CBSMsg2List;
import eo.ejb.common.JCCModelCommon;
import eo.ejb.common.JKKCtrlTnInfo;
import eo.ejb.common.JWCCtrlTnInfo;

public class JEKKA0020503TPMA 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(EKKA0020503CBSMsg.EKKA0020503CBSMSG1LIST);
		
		Hashtable<String, Object > serviceMapList_head = new Hashtable<String, Object>();

		//operatorID
		String operatorId = inCBSMsg.getString(EKKA0020503CBSMsg.OPERATORID);
		if(operatorId != null)
		{
			serviceMapList_head.put(JWCCtrlTnInfo.OPERATORID, operatorId);
		}
		else
		{
			serviceMapList_head.put(JWCCtrlTnInfo.OPERATORID, "");
		}
		
		//operatorDateTime
		String operatoDateTime = inCBSMsg.getString(EKKA0020503CBSMsg.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>();
			//ＫＥＹ＿管理場所識別コード
			String key_knri_plc_skbt_cd  =  listCaan[i].getString(EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SKBT_CD);
			if(key_knri_plc_skbt_cd != null)
			{
				serviceMapList.put(EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SKBT_CD, key_knri_plc_skbt_cd);
			}
			else 
			{
				serviceMapList.put(EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SKBT_CD, "");
			}
			
			//ＫＥＹ＿管理場所棚コード
			String key_knri_plc_slf_cd  =  listCaan[i].getString(EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SLF_CD);
			
			if(key_knri_plc_slf_cd != null)
			{
				serviceMapList.put(EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SLF_CD, key_knri_plc_slf_cd);
			}
			else 
			{
				serviceMapList.put(EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SLF_CD, "");
			}
			
			//ＫＥＹ＿宅内機器型式コード
			String key_tk_mdl_cd  =  listCaan[i].getString(EKKA0020503CBSMsg1List.KEY_TK_MDL_CD);
			
			if(key_tk_mdl_cd != null)
			{
				serviceMapList.put(EKKA0020503CBSMsg1List.KEY_TK_MDL_CD, key_tk_mdl_cd);
			}
			else 
			{
				serviceMapList.put(EKKA0020503CBSMsg1List.KEY_TK_MDL_CD, "");
			}
			
			list.add(serviceMapList);
		}

		serviceMap.put(EKKA0020503CBSMsg.EKKA0020503CBSMSG1LIST, 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_KKA0008(serviceMap);
			
			CAANMsg[] l_ekka0020503csvmsg2list = null;

			String error_level = (String)ret.get("errorLevel");
			if(error_level != null)
			{
				inCBSMsg.set(EKKA0020503CBSMsg.ERROR_LEVEL, error_level);
			}
			else
			{
				inCBSMsg.set(EKKA0020503CBSMsg.ERROR_LEVEL, "");
			}
			

			String return_cd = (String)ret.get("returnCode");
			if(return_cd != null)
			{
				inCBSMsg.set(EKKA0020503CBSMsg.RETURN_CD, return_cd);
				if(("1000").equals(return_cd) || 
						("1050").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020503CBSMsg.STATUS, StatusCodes.SINGLEDATA_ERR);
				}
				else if(("1100").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020503CBSMsg.STATUS, StatusCodes.ITEM_RELATION_ERR);
				}
				else if(("1200").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020503CBSMsg.STATUS, StatusCodes.RELATION_ERR);
				}
				else if (("0500".equals(return_cd)))
				{
					inCBSMsg.set(EKKA0020503CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
					return;
				}
			}
			else
			{
				inCBSMsg.set(EKKA0020503CBSMsg.RETURN_CD, "");
			}

			String return_message = (String)ret.get("returnMessage");
			if(return_message != null)
			{
				inCBSMsg.set(EKKA0020503CBSMsg.RETURN_MESSAGE, return_message);
			}
			else
			{
				inCBSMsg.set(EKKA0020503CBSMsg.RETURN_MESSAGE, "");
			}
			
			//結果コードが"1"なら処理を終了する。
			if(ret.get(CMD_RESULT_CD) != null && ret.get(CMD_RESULT_CD).equals("1"))
			{
				inCBSMsg.set(EKKA0020503CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
				return;
			}	
			
			// 取得した戻り値を元に、inCBSMsgのアウト項目に値を設定して返す
			ArrayList<Hashtable<String, Object>> retlist = (ArrayList<Hashtable<String, Object>>)ret.get(EKKA0020503CBSMsg.EKKA0020503CBSMSG2LIST);
			
			//入力キーのエラー処理
			//**************リクエスト条件は１つだけが前提**********
			String[][] keyList = {
					{EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SKBT_CD_ERR, EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SKBT_CD.substring(4) + "_ERR"},
					{EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SLF_CD_ERR, EKKA0020503CBSMsg1List.KEY_KNRI_PLC_SLF_CD.substring(4) + "_ERR"},
					{EKKA0020503CBSMsg1List.KEY_TK_MDL_CD_ERR, EKKA0020503CBSMsg1List.KEY_TK_MDL_CD.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]));
							//EKKA0020503CBSMSG1LIST_ERRには最初のエラーを設定する。
							if(cnt == 0){
								str = (String)data.get(keyList[j][1]);
								cnt++;
							}
						}
					}
					
				}
			}
			if(cnt > 0){
				inCBSMsg.set(EKKA0020503CBSMsg.EKKA0020503CBSMSG1LIST_ERR, str);
			}
			
			if(retlist != null && !retlist.isEmpty())
			{
				// うまくいけば戻りの電文を設定して終了する。
				l_ekka0020503csvmsg2list =  new CAANMsg[retlist.size()];

				int cnt2 =0;
				String str2 ="";
				for(int i = 0 ; i < retlist.size() ; i ++)
				{
					Hashtable data = retlist.get(i);
					CAANMsg msg = new CAANMsg("eo.ejb.cbs.cbsmsg.EKKA0020503CBSMsg2List");
					
					l_ekka0020503csvmsg2list[i] = msg;
					//管理場所識別コード
					msg.set(EKKA0020503CBSMsg2List.KNRI_PLC_SKBT_CD, (String)data.get(EKKA0020503CBSMsg2List.KNRI_PLC_SKBT_CD));
					
					//管理場所棚コード
					msg.set(EKKA0020503CBSMsg2List.KNRI_PLC_SLF_CD, (String)data.get(EKKA0020503CBSMsg2List.KNRI_PLC_SLF_CD));
					
					//宅内機器型式コード
					msg.set(EKKA0020503CBSMsg2List.TK_MDL_CD, (String)data.get(EKKA0020503CBSMsg2List.TK_MDL_CD));
					
					//管理場所コード
					msg.set(EKKA0020503CBSMsg2List.KNRI_PLC_CD, (String)data.get(EKKA0020503CBSMsg2List.KNRI_PLC_CD));
					
					//宅内機器物流在庫T更新日時
					msg.set(EKKA0020503CBSMsg2List.BRZIKO_UPD_DTTM, (String)data.get(EKKA0020503CBSMsg2List.BRZIKO_UPD_DTTM));
					
					//戻り値のエラー処理、個別項目のエラーは設定されないため最初に見つかったエラーをセットする。
					if(cnt2 == 0 ){
						if(data.containsKey(EKKA0020503CBSMsg2List.KNRI_PLC_SKBT_CD + "_ERR")){
							str2 = (String)data.get(EKKA0020503CBSMsg2List.KNRI_PLC_SKBT_CD + "_ERR");
							cnt2++;
						}else if(data.containsKey(EKKA0020503CBSMsg2List.KNRI_PLC_SLF_CD + "_ERR")){
							str2 = (String)data.get(EKKA0020503CBSMsg2List.KNRI_PLC_SLF_CD + "_ERR");
							cnt2++;
						}else if(data.containsKey(EKKA0020503CBSMsg2List.TK_MDL_CD + "_ERR")){
							str2 = (String)data.get(EKKA0020503CBSMsg2List.TK_MDL_CD + "_ERR");
							cnt2++;
						}else if(data.containsKey(EKKA0020503CBSMsg2List.KNRI_PLC_CD + "_ERR")){
							str2 = (String)data.get(EKKA0020503CBSMsg2List.KNRI_PLC_CD + "_ERR");
							cnt2++;
						}else if(data.containsKey(EKKA0020503CBSMsg2List.BRZIKO_UPD_DTTM + "_ERR")){
							str2 = (String)data.get(EKKA0020503CBSMsg2List.BRZIKO_UPD_DTTM + "_ERR");
							cnt2++;
						}
					
					}
				}

				inCBSMsg.set(EKKA0020503CBSMsg.EKKA0020503CBSMSG2LIST, l_ekka0020503csvmsg2list);
				//個別項目のエラーは設定されない
				if(cnt2 > 0){
					inCBSMsg.set(EKKA0020503CBSMsg.EKKA0020503CBSMSG2LIST_ERR, str2);
				}
			}
		}
		catch(Exception e)
		{
			e.printStackTrace();
			inCBSMsg.set(EKKA0020503CBSMsg.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
	}
}
