/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKKA0020501TPMA
*	ソースファイル名：JEKKA0020501TPMA.java
*	作成者			：富士通
*	日付			：2012年4月9日
*＜機能概要＞
*	上位機器製造番号更新から契約Ｓ宅内情報処理を呼び出すための独自部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2012/4/9	富士通		新規作成
*	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.EKKA0020501CBSMsg;
import eo.ejb.cbs.cbsmsg.EKKA0020501CBSMsg1List;
import eo.ejb.common.JCCModelCommon;
import eo.ejb.common.JKKCtrlTnInfo;

public class JEKKA0020501TPMA 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(EKKA0020501CBSMsg.EKKA0020501CBSMSG1LIST);
		
		Hashtable<String, Object > serviceMapList_head = new Hashtable<String, Object>();
		
		//operatorID
		String operatorId = inCBSMsg.getString(EKKA0020501CBSMsg.OPERATORID);
		if(operatorId != null)
		{
			serviceMapList_head.put(JKKCtrlTnInfo.OPERATORID, operatorId);
		}
		else
		{
			serviceMapList_head.put(JKKCtrlTnInfo.OPERATORID, "");
		}
		
		//operatorDateTime
		String operatoDateTime = inCBSMsg.getString(EKKA0020501CBSMsg.OPERATEDATETIME);
		if(operatoDateTime != null)
		{
			serviceMapList_head.put(JKKCtrlTnInfo.OPERATEDATETIME, operatoDateTime);
		}
		else
		{
			serviceMapList_head.put(JKKCtrlTnInfo.OPERATEDATETIME, "");
		}
		list.add(serviceMapList_head);
		// 
		for(int i = 0 ; i < listCaan.length ; i++)
		{
			Hashtable<String, Object > serviceMapList = new Hashtable<String, Object>();
			//ＫＥＹ＿宅内機器型式コード
			String key_tk_mdl_cd  =  listCaan[i].getString(EKKA0020501CBSMsg1List.KEY_TK_MDL_CD);
			if(key_tk_mdl_cd != null)
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.KEY_TK_MDL_CD, key_tk_mdl_cd);
			}
			else 
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.KEY_TK_MDL_CD, "");
			}
			
			//ＫＥＹ＿機器製造番号
			String key_kk_seizo_no  =  listCaan[i].getString(EKKA0020501CBSMsg1List.KEY_KK_SEIZO_NO);
			if(key_kk_seizo_no != null)
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.KEY_KK_SEIZO_NO, key_kk_seizo_no);
			}
			else 
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.KEY_KK_SEIZO_NO, "");
			}

			//ＫＥＹ＿宅内機器基本Ｔ更新日付
			String key_kihon_upd_dttm  =  listCaan[i].getString(EKKA0020501CBSMsg1List.KEY_KIHON_UPD_DTTM);
			if(key_kihon_upd_dttm != null)
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.KEY_KIHON_UPD_DTTM, key_kihon_upd_dttm);
			}
			else 
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.KEY_KIHON_UPD_DTTM, "");
			}
			
			//上位宅内機器型式コード
			String joi_tk_mdl_cd  =  listCaan[i].getString(EKKA0020501CBSMsg1List.JOI_TK_MDL_CD);
			if(joi_tk_mdl_cd != null)
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.JOI_TK_MDL_CD, joi_tk_mdl_cd);
			}
			else 
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.JOI_TK_MDL_CD, "");
			}

			//上位機器製造番号
			String joi_kk_seizo_no  =  listCaan[i].getString(EKKA0020501CBSMsg1List.JOI_KK_SEIZO_NO);
			if(joi_kk_seizo_no != null)
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.JOI_KK_SEIZO_NO, joi_kk_seizo_no);
			}
			else 
			{
				serviceMapList.put(EKKA0020501CBSMsg1List.JOI_KK_SEIZO_NO, "");
			}
			
			list.add(serviceMapList);
		}
		
		serviceMap.put(EKKA0020501CBSMsg.EKKA0020501CBSMSG1LIST, 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_KKA0006(serviceMap);
			
			// エラーレベル
			String error_level = (String)ret.get("errorLevel");
			if(error_level != null)
			{
				inCBSMsg.set(EKKA0020501CBSMsg.ERROR_LEVEL, error_level);
			}
			else
			{
				inCBSMsg.set(EKKA0020501CBSMsg.ERROR_LEVEL, "");
			}
			
			// リターンコード
			String return_cd = (String)ret.get("returnCode");
			if(return_cd != null)
			{
				inCBSMsg.set(EKKA0020501CBSMsg.RETURN_CD, return_cd);
				if(("1000").equals(return_cd) || 
						("1050").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020501CBSMsg.STATUS, StatusCodes.SINGLEDATA_ERR);
				}
				else if(("1100").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020501CBSMsg.STATUS, StatusCodes.ITEM_RELATION_ERR);
				}
				else if(("1200").equals(return_cd))
				{
					inCBSMsg.set(EKKA0020501CBSMsg.STATUS, StatusCodes.RELATION_ERR);
				}
				else if (("0500".equals(return_cd)))
				{
					inCBSMsg.set(EKKA0020501CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
					return;
				}
			}
			else
			{
				inCBSMsg.set(EKKA0020501CBSMsg.RETURN_CD, "");
			}
			
			// メッセージ
			String return_message = (String)ret.get("returnMessage");
			if(return_message != null)
			{
				inCBSMsg.set(EKKA0020501CBSMsg.RETURN_MESSAGE, return_message);
			}
			else
			{
				inCBSMsg.set(EKKA0020501CBSMsg.RETURN_MESSAGE, "");
			}
			
			//結果コードが"1"なら処理を終了する。
			if(ret.get(CMD_RESULT_CD) != null && ret.get(CMD_RESULT_CD).equals("1"))
			{
				inCBSMsg.set(EKKA0020501CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
				return;
			}	
			
			//エラーのリスト
			ArrayList<Hashtable<String, Object>> retErrlist = (ArrayList<Hashtable<String, Object>>)ret.get(EKKA0020501CBSMsg.EKKA0020501CBSMSG1LIST);
			
			//入力キーのエラー処理
			String[][] keyList = {
					{EKKA0020501CBSMsg1List.KEY_TK_MDL_CD_ERR, EKKA0020501CBSMsg1List.KEY_TK_MDL_CD.substring(4) + "_ERR"},
					{EKKA0020501CBSMsg1List.KEY_KK_SEIZO_NO_ERR, EKKA0020501CBSMsg1List.KEY_KK_SEIZO_NO.substring(4) + "_ERR"},
					{EKKA0020501CBSMsg1List.KEY_KIHON_UPD_DTTM_ERR, EKKA0020501CBSMsg1List.KEY_KIHON_UPD_DTTM.substring(4) + "_ERR"},
					{EKKA0020501CBSMsg1List.JOI_TK_MDL_CD_ERR, EKKA0020501CBSMsg1List.JOI_TK_MDL_CD + "_ERR"},
					{EKKA0020501CBSMsg1List.JOI_KK_SEIZO_NO_ERR, EKKA0020501CBSMsg1List.JOI_KK_SEIZO_NO + "_ERR"}
					};
				
			int cnt =0;
			if(retErrlist != null && !retErrlist.isEmpty())
			{
				for(int i = 0 ; i < retErrlist.size() ; i++)
				{
					Hashtable data = retErrlist.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]));
							cnt++;
						}
					}
				}
			}
			
			// ***** 宅内からのエラー情報（RETURN_CD）の読み替え処理 *****
			if(cnt == 0 && "1250".equals(return_cd)){
				// 悲観ロックエラー時はエラー項目が設定されないため、リストにエラーを設定する。
				inCBSMsg.set(EKKA0020501CBSMsg.EKKA0020501CBSMSG1LIST_ERR, "EA");
				// RETURN_CDの読み替え
				inCBSMsg.set(EKKA0020501CBSMsg.STATUS, StatusCodes.RELATION_ERR);
			}
			if(cnt == 0 && "1200".equals(return_cd)){
				// 楽観ロックエラー時はRETURN_CDを読み替える。
				inCBSMsg.set(EKKA0020501CBSMsg.STATUS, StatusCodes.RELATION_ERR);
			}
		}
		catch(Exception e)
		{
			e.printStackTrace();
			inCBSMsg.set(EKKA0020501CBSMsg.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
	}
}
