/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKKA0020005TPMA
*	ソースファイル名：JEKKA0020005TPMA.java
*	作成者			：EK911023
*	日付			：2013年02月15日
*＜機能概要＞
*	宅内機器物流在庫一意照会独自処理部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	ｖ1.00.00
*   v 5.00.00    2013/06/28   FJ) 大山    LT-2013-0000080
*
********************************************************************************/
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.common.constant.JWCStrConst;
import eo.ejb.cbs.cbsmsg.EKKA0020005CBSMsg;
import eo.ejb.cbs.cbsmsg.EKKA0020005CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKKA0020005CBSMsg2List;
import eo.ejb.common.JCCModelCommon;
import eo.ejb.common.JKKCtrlTnInfo;
import eo.ejb.common.JWCCtrlTnInfo;

public class JEKKA0020005TPMA implements TemplateMainHandler {

	/**
	 * 結果コード
	 */
	private static final String CMD_RESULT_CD = "CMD_RESULT_CD";
	

	// コマンド実行部品用
	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[] list2 = inCBSMsg.getCAANMsgList(EKKA0020005CBSMsg.EKKA0020005CBSMSG1LIST);
		
		Hashtable<String, Object > serviceMapList_head = new Hashtable<String, Object>();

		//operatorID
		String operatorId = inCBSMsg.getString(EKKA0020005CBSMsg.OPERATORID);
		if(operatorId != null)
		{
			serviceMapList_head.put(JWCCtrlTnInfo.OPERATORID, operatorId);
		}
		else
		{
			serviceMapList_head.put(JWCCtrlTnInfo.OPERATORID, "");
		}
		
		//operatorDateTime
		String operatoDateTime = inCBSMsg.getString(EKKA0020005CBSMsg.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 < list2.length ; i++)
		{
			Hashtable<String, Object > serviceMapList = new Hashtable<String, Object>();
			//ＫＥＹ＿管理場所識別コード
			String key_knri_plc_skbt_cd =  list2[i].getString(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_SKBT_CD);
			if(key_knri_plc_skbt_cd != null)
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_SKBT_CD, key_knri_plc_skbt_cd);
			}
			else
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_SKBT_CD, "");
			}
			//ＫＥＹ＿管理場所コード
			String key_knri_plc_cd = list2[i].getString(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_CD);
			if(key_knri_plc_cd != null)
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_CD, key_knri_plc_cd);
			}
			else
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_CD, "");
			}
			//ＫＥＹ＿管理場所棚コード
			String key_knri_plc_slf_cd = list2[i].getString(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_SLF_CD);
			if(key_knri_plc_slf_cd != null)
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_SLF_CD, key_knri_plc_slf_cd);
			}
			else
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_KNRI_PLC_SLF_CD, "");
			}
			//ＫＥＹ＿宅内機器型式コード
			String key_tk_mdl_cd = list2[i].getString(EKKA0020005CBSMsg1List.KEY_TK_MDL_CD);
			if(key_tk_mdl_cd != null)
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_TK_MDL_CD, key_tk_mdl_cd);
			}
			else
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_TK_MDL_CD, "");
			}

			//ＫＥＹ＿商品場外コード
			String key_gds_stat_cd = list2[i].getString(EKKA0020005CBSMsg1List.KEY_GDS_STAT_CD);

			if(key_gds_stat_cd != null)
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_GDS_STAT_CD, key_gds_stat_cd);
			}
			else
			{
				serviceMapList.put(EKKA0020005CBSMsg1List.KEY_GDS_STAT_CD, "-");
			}

			
			list.add(serviceMapList);
		}
		
		serviceMap.put(EKKA0020005CBSMsg.EKKA0020005CBSMSG1LIST, list);

		// 宅内機器コマンド発行部品のスタブ用、
		int str_flag = Integer.parseInt(JCCModelCommon.getApplicationConst(JWCStrConst.TN_FLAG));
		JKKCtrlTnInfo instance = JKKCtrlTnInfo.getInstance(str_flag);
		
		// テーブルのコネクションを取得するして、部品に受け渡しを行う。
		Connection con = JSYejbConnection.getConnection("TK_T_TK");
		instance.setConnection(con);
		
		try
		{
			Hashtable ret = instance.ctrlTnInfo_KKA0005(serviceMap, con);

			CAANMsg[] l_ekka002005csvmsg2list = null;

			// 取得した戻り値を元に、inCBSMsgのアウト項目に値を設定して返す
			ArrayList<Hashtable<String, Object>> retlist = (ArrayList<Hashtable<String, Object>>)ret.get(EKKA0020005CBSMsg.EKKA0020005CBSMSG2LIST);

			String error_level = (String)ret.get(EKKA0020005CBSMsg.ERROR_LEVEL);
			if(error_level != null)
			{
				inCBSMsg.set(EKKA0020005CBSMsg.ERROR_LEVEL, error_level);
			}
			else
			{
				inCBSMsg.set(EKKA0020005CBSMsg.ERROR_LEVEL, "");
			}
			

			String return_cd = (String)ret.get(EKKA0020005CBSMsg.RETURN_CD);
			if(return_cd != null)
			{
				inCBSMsg.set(EKKA0020005CBSMsg.RETURN_CD, return_cd);
			}
			else
			{
				inCBSMsg.set(EKKA0020005CBSMsg.RETURN_CD, "");
			}

			String return_message = (String)ret.get(EKKA0020005CBSMsg.RETURN_MESSAGE);
			if(return_message != null)
			{
				inCBSMsg.set(EKKA0020005CBSMsg.RETURN_MESSAGE, return_message);
			}
			else
			{
				inCBSMsg.set(EKKA0020005CBSMsg.RETURN_MESSAGE, "");
			}
			
			//結果コードが"1"なら処理を終了する。
			if(ret.get(CMD_RESULT_CD) != null && ret.get(CMD_RESULT_CD).equals("1"))
			{
				inCBSMsg.set(EKKA0020005CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
				return;
			}
			//エラーレベルが000より大きければ処理を終了する。
			if(ret.get("errorLevel") != null && !((String)ret.get("errorLevel")).equals("000")) {
				inCBSMsg.set(EKKA0020005CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
				return;
			}
			
			if(retlist != null && !retlist.isEmpty())
			{
				
				// うまくいけば戻りの電文を設定して終了する。
				l_ekka002005csvmsg2list =  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.EKKA0020005CBSMsg2List");
					
					l_ekka002005csvmsg2list[i] = msg;
					
					//管理場所識別コード
					msg.set(EKKA0020005CBSMsg2List.KNRI_PLC_SKBT_CD, (String)data.get(EKKA0020005CBSMsg2List.KNRI_PLC_SKBT_CD));
					//管理場所コード
					msg.set(EKKA0020005CBSMsg2List.KNRI_PLC_CD, (String)data.get(EKKA0020005CBSMsg2List.KNRI_PLC_CD));
					//管理場所棚コード
					msg.set(EKKA0020005CBSMsg2List.KNRI_PLC_SLF_CD, (String)data.get(EKKA0020005CBSMsg2List.KNRI_PLC_SLF_CD));
					//宅内機器型式コード
					msg.set(EKKA0020005CBSMsg2List.TK_MDL_CD, (String)data.get(EKKA0020005CBSMsg2List.TK_MDL_CD));
					//商品状態コード
					msg.set(EKKA0020005CBSMsg2List.GDS_STAT_CD, (String)data.get(EKKA0020005CBSMsg2List.GDS_STAT_CD));
					//実在庫数
					msg.set(EKKA0020005CBSMsg2List.JZAIKO_CNT, (String)data.get(EKKA0020005CBSMsg2List.JZAIKO_CNT));
					//配送受付（受注）数
					msg.set(EKKA0020005CBSMsg2List.HAISO_UK_JUCHU_CNT, (String)data.get(EKKA0020005CBSMsg2List.HAISO_UK_JUCHU_CNT));
					//配送出荷指示数
					msg.set(EKKA0020005CBSMsg2List.HAISO_SHKA_SJI_CNT, (String)data.get(EKKA0020005CBSMsg2List.HAISO_SHKA_SJI_CNT));
					//予備機器配送指示数
					msg.set(EKKA0020005CBSMsg2List.YBKIKI_HAISO_SJI_CNT, (String)data.get(EKKA0020005CBSMsg2List.YBKIKI_HAISO_SJI_CNT));
					//棚移動指示数
					msg.set(EKKA0020005CBSMsg2List.SHELF_MV_SJI_CNT, (String)data.get(EKKA0020005CBSMsg2List.SHELF_MV_SJI_CNT));
					//予備機器配送中数
					msg.set(EKKA0020005CBSMsg2List.YBKIKI_HAISO_CHU_CNT, (String)data.get(EKKA0020005CBSMsg2List.YBKIKI_HAISO_CHU_CNT));
					//当日入荷数
					msg.set(EKKA0020005CBSMsg2List.TJITU_NYUKA_CNT, (String)data.get(EKKA0020005CBSMsg2List.TJITU_NYUKA_CNT));
					//当日配送出荷数
					msg.set(EKKA0020005CBSMsg2List.TJITU_HAISO_SHKA_CNT, (String)data.get(EKKA0020005CBSMsg2List.TJITU_HAISO_SHKA_CNT));
					//当日解約撤去返品数
					msg.set(EKKA0020005CBSMsg2List.TJITU_DSL_TEKKYO_HMPIN_CNT, (String)data.get(EKKA0020005CBSMsg2List.TJITU_DSL_TEKKYO_HMPIN_CNT));
					//当日故障交換返品数
					msg.set(EKKA0020005CBSMsg2List.TJITU_TRB_KOKAN_HMPIN_CNT, (String)data.get(EKKA0020005CBSMsg2List.TJITU_TRB_KOKAN_HMPIN_CNT));
					//棚移動入荷完了数
					msg.set(EKKA0020005CBSMsg2List.SHELF_MV_NYUKA_FIN_CNT, (String)data.get(EKKA0020005CBSMsg2List.SHELF_MV_NYUKA_FIN_CNT));
					//棚移動出荷完了数
					msg.set(EKKA0020005CBSMsg2List.SHELF_MV_SHKA_FIN_CNT, (String)data.get(EKKA0020005CBSMsg2List.SHELF_MV_SHKA_FIN_CNT));
					//予備機器出荷完了数
					msg.set(EKKA0020005CBSMsg2List.YBKIKI_SHKA_FIN_CNT, (String)data.get(EKKA0020005CBSMsg2List.YBKIKI_SHKA_FIN_CNT));
					//計画外入荷数
					msg.set(EKKA0020005CBSMsg2List.PLAN_GAI_NYUKA_CNT, (String)data.get(EKKA0020005CBSMsg2List.PLAN_GAI_NYUKA_CNT));
					//計画外出荷数
					msg.set(EKKA0020005CBSMsg2List.PLAN_GAI_SHKA_CNT, (String)data.get(EKKA0020005CBSMsg2List.PLAN_GAI_SHKA_CNT));

				}

				inCBSMsg.set(EKKA0020005CBSMsg.EKKA0020005CBSMSG2LIST, l_ekka002005csvmsg2list);
			}
		}
		catch(Exception e)
		{
			e.printStackTrace();
			inCBSMsg.set(EKKA0020005CBSMsg.STATUS, StatusCodes.EXTERNAL_IF_ERR1);
		} finally {
			if(con != null)
			{
				CAANConnectionMgr.getInstance().close(con);
			}
		}
	}

}
