/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom						 *
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKGetKaisenUcwkUpDtmCC
*	ソースファイル名：JKKGetKaisenUcwkUpDtmCC.java
*	作成者			：FAP)古田
*	日付			：2012年06月05日
*＜機能概要＞
*	最終更新年月日自分秒取得の共通コンポーネント
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v4.00.00	2012/06/05	FAP)古田		新規作成
*	v4.01.00	2013/01/22	FAP)鳩本		サービス契約一意照会取得結果を一部HashMap格納
*	v5.00.00	2013/10/29	FAP)中井	【OM-2013-0003800】解約済サービス契約更新日時取得
*	v7.00.00	2013/10/21	FAP)田原	【ANK-1578-00-00】対応
*   v7.00.01	2014/01/13	 FJ) 中井	【IT2-2014-0000034】対応
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

import com.fujitsu.futurity.bp.x21.bpm.ServiceComponentRequestInvoker;
import com.fujitsu.futurity.bp.x21.bpm.db.SessionHandle;
import com.fujitsu.futurity.bp.x21.bpm.exception.RequestParameterException;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadWrite;
import com.fujitsu.futurity.bp.x21.cc.AbstractCommonComponent;
import com.fujitsu.futurity.bp.x21.cc.exception.SCCallException;
import com.fujitsu.futurity.common.JCMConstants;
import com.fujitsu.futurity.common.x01.sc.SCControlMapKeys;
import com.fujitsu.futurity.mapping.bp.common.TemplateErrorUtil;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.common.JCMAPLConstMgr;

import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0241B002CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0251A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0251A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0251B003CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0251B003CBSMsg1List;


/**
 * サービス契約回線内訳番号に紐づくサービス契約の最大の最終更新年月日自分秒と
 * サービス契約に紐づく最終更新タイムスタンプを取得します。<p>
 * <BR>
 * @author 富士通
 */
public class JKKGetKaisenUcwkUpDtmCC extends AbstractCommonComponent
{
	/** サービス契約回線内訳一覧照会（現在利用中） */
	private static final String TEMPLATE_ID_EKK0251B003 = "EKK0251B003";
	/** 回線利用中サービス契約一覧照会 */
//	private static final String TEMPLATE_ID_EKK0081B007 = "EKK0081B007";
	/** サービス契約一意照会 */
	private static final String TEMPLATE_ID_EKK0081A010 = "EKK0081A010";
	/* ++++++++++ v5.00.00 追加開始 ++++++++++ */
	/** 回線対象サービス契約一意照会 */
	private static final String TEMPLATE_ID_EKK0251A010 = "EKK0251A010";
	/* ++++++++++ v5.00.00 追加終了 ++++++++++ */
	
	/**
	 * 
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return IRequestParameterReadWrite
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite getKaisenMaxUpdDtm(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
		String dataMapKey = fixedText;
		
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		/* ++++++++++ v7.00.01 追加開始 ++++++++++ */
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		/* ++++++++++ v7.00.01 追加終了 ++++++++++ */
		
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		// ***** EKK0081A010（サービス契約一意照会）*****
		Object[][] ekk0081a010IN_sv = {
				{EKK0081A010CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK0081A010},
				{EKK0081A010CBSMsg.FUNC_CODE,        "2"},
				{EKK0081A010CBSMsg.KEY_SVC_KEI_NO,   (String)ccMsg.get("svc_kei_no")},
				{EKK0081A010CBSMsg.KEY_GENE_ADD_DTM, ""},
				{EKK0081A010CBSMsg.KEY_RSV_APLY_YMD, (String)ccMsg.get("stdardymd")}
		};
		
		CAANMsg ekk0081a010cbsMsg_sv 
						= callSC(handle, scCall, param, dataMapKey, ekk0081a010IN_sv).getCAANMsgList(EKK0081A010CBSMsg.EKK0081A010CBSMSG1LIST)[0];

		ccMsg.put("last_upd_dtm_svc_kei", ekk0081a010cbsMsg_sv.getString(EKK0081A010CBSMsg1List.LAST_UPD_DTM));
		/* ++++++++++ v7.00.00 追加開始 ++++++++++ */
		ccMsg.put("svc_cd", ekk0081a010cbsMsg_sv.getString(EKK0081A010CBSMsg1List.SVC_CD));
		/* ++++++++++ v7.00.00 追加終了 ++++++++++ */
		/* ++++++++++ v4.01.00 追加開始 ++++++++++ */
		if (ekk0081a010cbsMsg_sv != null)
		{
			ccMsg.put("svc_kei_stat",  ekk0081a010cbsMsg_sv.getString(EKK0081A010CBSMsg1List.SVC_KEI_STAT));
			ccMsg.put("svc_sta_ymd",  ekk0081a010cbsMsg_sv.getString(EKK0081A010CBSMsg1List.SVC_STA_YMD));
		}
		else
		{
			ccMsg.put("svc_kei_stat", "");
			ccMsg.put("svc_sta_ymd", "");
		}
		/* ++++++++++ v4.01.00 追加完了 ++++++++++ */
		
		
		// サービス契約回線内訳番号取得処理
		// ***** EKK0251B003（サービス契約回線内訳一覧照会（現在利用中））*****
		Object[][] ekk0251b003IN = {
			{EKK0251B003CBSMsg.TEMPLATEID,     TEMPLATE_ID_EKK0251B003},
			{EKK0251B003CBSMsg.FUNC_CODE,      "1"},
			{EKK0251B003CBSMsg.KEY_SVC_KEI_NO, (String)ccMsg.get("svc_kei_no")}
		};
		
		CAANMsg[] ekk0251b003cbsMsg1list 
						= callSC(handle, scCall, param, dataMapKey, ekk0251b003IN).getCAANMsgList(EKK0251B003CBSMsg.EKK0251B003CBSMSG1LIST);
		
		if(ekk0251b003cbsMsg1list == null || ekk0251b003cbsMsg1list.length ==0)
		{
			return param;
		}
		
		/* ++++++++++ v5.00.00 修正開始 ++++++++++ */
//		// サービス契約内訳番号に紐づくサービス契約番号を取得
//		// ***** EKK0081B007（回線利用中サービス契約一覧照会）*****
//		Object[][] ekk0081b007IN = {
//			{EKK0081B007CBSMsg.TEMPLATEID,     TEMPLATE_ID_EKK0081B007},
//			{EKK0081B007CBSMsg.FUNC_CODE,      "1"},
//			{EKK0081B007CBSMsg.KEY_SVC_KEI_KAISEN_UCWK_NO, ekk0251b003cbsMsg1list[0].getString(EKK0251B003CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO)},
//			{EKK0081B007CBSMsg.KEY_OPE_YMD, (String)ccMsg.get("stdardymd")}
//		};
//		
//		CAANMsg[] ekk0081B007cbsMsg1list 
//						= callSC(handle, scCall, param, dataMapKey, ekk0081b007IN).getCAANMsgList(EKK0081B007CBSMsg.EKK0081B007CBSMSG1LIST);
		// サービス契約内訳番号に紐づくサービス契約番号を取得
		// ***** EKK0241B002（回線対象サービス契約一覧照会）*****
		Object[][] ekk0251a010IN = {
			{EKK0251A010CBSMsg.TEMPLATEID,     TEMPLATE_ID_EKK0251A010},
			{EKK0251A010CBSMsg.FUNC_CODE,      "2"},
			{EKK0251A010CBSMsg.KEY_SVC_KEI_KAISEN_UCWK_NO, ekk0251b003cbsMsg1list[0].getString(EKK0251B003CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO)},
		};
		
		CAANMsg[] ekk0251a010cbsMsg1list 
						= callSC(handle, scCall, param, dataMapKey, ekk0251a010IN).getCAANMsgList(EKK0251A010CBSMsg.EKK0251A010CBSMSG1LIST);
		
//		if(ekk0081B007cbsMsg1list == null || ekk0081B007cbsMsg1list.length ==0)
		if(ekk0251a010cbsMsg1list == null || ekk0251a010cbsMsg1list.length ==0)
		{
			return param;
		}
		else
		{
			ccMsg.put("last_upd_dtm_kaisen", ekk0251a010cbsMsg1list[0].getString(EKK0251A010CBSMsg1List.LAST_UPD_DTM));
		}
		/* ++++++++++ v5.00.00 修正終了 ++++++++++ */
		
//		/* ++++++++++ v5.00.00 削除開始 ++++++++++ */
//		// 最終更新年月日時分秒格納変数
//		ArrayList<String> updateList = new ArrayList<String>();
//		
//		// サービス契約の最終更新年月日時分秒を取得
//		for(int i=0;i<ekk0081B007cbsMsg1list.length;i++)
///		{
//			// ***** EKK0081A010（サービス契約一意照会）*****
//			Object[][] ekk0081a010IN = {
//				{EKK0081A010CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK0081A010},
//				{EKK0081A010CBSMsg.FUNC_CODE,        "2"},
//				{EKK0081A010CBSMsg.KEY_SVC_KEI_NO,   ekk0241b002cbsMsg1list[i].getString(EKK0241B002CBSMsg1List.SVC_KEI_NO)},
//				{EKK0081A010CBSMsg.KEY_GENE_ADD_DTM, ""},
//				{EKK0081A010CBSMsg.KEY_RSV_APLY_YMD, (String)ccMsg.get("stdardymd")}
//			};
//			
//			CAANMsg ekk0081a010cbsMsg 
//							= callSC(handle, scCall, param, dataMapKey, ekk0081a010IN).getCAANMsgList(EKK0081A010CBSMsg.EKK0081A010CBSMSG1LIST)[0];
//			
//			updateList.add(ekk0081a010cbsMsg.getString(EKK0081A010CBSMsg1List.LAST_UPD_DTM));
//		}
//		
//		if(updateList.size() >= 1)
//		{
//			// 処理対象のリストをソートし、昇順になったソート順を降順に逆転させる（JKKejbExclusiveProcCommonの排他処理参照）
//			Collections.sort(updateList);
//			Collections.reverse(updateList);
//			
//			ccMsg.put("last_upd_dtm_kaisen", updateList.get(0));
//		}
		/* ++++++++++ v5.00.00 削除終了 ++++++++++ */

		
		/* ++++++++++ v7.00.01 追加開始 ++++++++++ */
		if(workMap.get("work_svc_kei_no_tekkyo") != null && !"".equals(workMap.get("work_svc_kei_no_tekkyo")))
		{
			// ***** EKK0081A010（サービス契約一意照会）*****
			Object[][] ekk0081a010IN2_sv = {
					{EKK0081A010CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK0081A010},
					{EKK0081A010CBSMsg.FUNC_CODE,        "2"},
					{EKK0081A010CBSMsg.KEY_SVC_KEI_NO,   (String)workMap.get("work_svc_kei_no_tekkyo")},
					{EKK0081A010CBSMsg.KEY_GENE_ADD_DTM, ""},
					{EKK0081A010CBSMsg.KEY_RSV_APLY_YMD, (String)ccMsg.get("stdardymd")}
			};
			
			ekk0081a010cbsMsg_sv 
							= callSC(handle, scCall, param, dataMapKey, ekk0081a010IN2_sv).getCAANMsgList(EKK0081A010CBSMsg.EKK0081A010CBSMSG1LIST)[0];
	
			ccMsg.put("last_upd_dtm_svc_kei", ekk0081a010cbsMsg_sv.getString(EKK0081A010CBSMsg1List.LAST_UPD_DTM));
			ccMsg.put("svc_cd", ekk0081a010cbsMsg_sv.getString(EKK0081A010CBSMsg1List.SVC_CD));
			if (ekk0081a010cbsMsg_sv != null)
			{
				ccMsg.put("svc_kei_stat",  ekk0081a010cbsMsg_sv.getString(EKK0081A010CBSMsg1List.SVC_KEI_STAT));
				ccMsg.put("svc_sta_ymd",  ekk0081a010cbsMsg_sv.getString(EKK0081A010CBSMsg1List.SVC_STA_YMD));
			}
			else
			{
				ccMsg.put("svc_kei_stat", "");
				ccMsg.put("svc_sta_ymd", "");
			}
			
			
			// サービス契約回線内訳番号取得処理
			// ***** EKK0251B003（サービス契約回線内訳一覧照会（現在利用中））*****
			Object[][] ekk0251b003IN2 = {
				{EKK0251B003CBSMsg.TEMPLATEID,     TEMPLATE_ID_EKK0251B003},
				{EKK0251B003CBSMsg.FUNC_CODE,      "1"},
				{EKK0251B003CBSMsg.KEY_SVC_KEI_NO, (String)ccMsg.get("svc_kei_no")}
			};
			
			ekk0251b003cbsMsg1list 
							= callSC(handle, scCall, param, dataMapKey, ekk0251b003IN2).getCAANMsgList(EKK0251B003CBSMsg.EKK0251B003CBSMSG1LIST);
			
			if(ekk0251b003cbsMsg1list == null || ekk0251b003cbsMsg1list.length ==0)
			{
				return param;
			}
			// サービス契約内訳番号に紐づくサービス契約番号を取得
			// ***** EKK0241B002（回線対象サービス契約一覧照会）*****
			Object[][] ekk0251a010IN2 = {
				{EKK0251A010CBSMsg.TEMPLATEID,     TEMPLATE_ID_EKK0251A010},
				{EKK0251A010CBSMsg.FUNC_CODE,      "2"},
				{EKK0251A010CBSMsg.KEY_SVC_KEI_KAISEN_UCWK_NO, ekk0251b003cbsMsg1list[0].getString(EKK0251B003CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO)},
			};
			
			ekk0251a010cbsMsg1list 
							= callSC(handle, scCall, param, dataMapKey, ekk0251a010IN2).getCAANMsgList(EKK0251A010CBSMsg.EKK0251A010CBSMSG1LIST);
			
			if(ekk0251a010cbsMsg1list == null || ekk0251a010cbsMsg1list.length ==0)
			{
				return param;
			}
			else
			{
				ccMsg.put("last_upd_dtm_tekkyo_kaisen", ekk0251a010cbsMsg1list[0].getString(EKK0251A010CBSMsg1List.LAST_UPD_DTM));
			}
		}
		/* ++++++++++ v7.00.01 追加終了 ++++++++++ */
		return param;
		
	}
	
	/**
	 * SC(サービスインターフェイス）を呼び出す。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param dataMapKey
	 * @param mappingData
	 * @return CAANMsg
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private CAANMsg callSC(SessionHandle handle, 
							ServiceComponentRequestInvoker scCall, 
							IRequestParameterReadWrite param, 
							String dataMapKey,
							Object[][] mappingData) throws Exception
	{
		HashMap<String, Object> paramMap = editInMsg(param, mappingData);
		
		Map<?, ?> result = scCall.run(paramMap, handle);
		
		CAANMsg[] templates = (CAANMsg[])result.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg msg = templates[0];
		
		// リターンコード取得
		Object return_code = result.get(JCMConstants.RET_CD_INT_KEY);
		Integer status = msg.getInt(JCMConstants.STATUS_INT_KEY);
		
		editErrorInfoCom(param, templates, (Integer)return_code, dataMapKey, mappingData);
		
		//エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>)param.getControlMapData(SCControlMapKeys.ERROR_INFO);
		if (errList == null)
		{
			errList = new ArrayList<Object>();
		}
		
		// コントロールマップに設定
		param.setControlMapData(SCControlMapKeys.ERROR_INFO, TemplateErrorUtil.getErrorInfo(result, errList));
		
		// 異常の場合、SCCallExceptionを生成してスローする
		if(!("0".equals(return_code.toString()) && 0 == status))
		{
			throw new SCCallException("戻り値不正", return_code.toString(), status);
		}
		return msg;
	}
	
	/**
	 * @param param
	 * @param mappingData
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	private HashMap<String, Object> editInMsg(IRequestParameterReadWrite param,
												Object[][] mappingData) throws RequestParameterException
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();

		// 【取得元：電文ヘッダ(ヘッダ)】
		// 電文ID
		paramMap.put(JCMConstants.TRANZACTION_ID_KEY, param.getTelegramID());
		// ユースケースID
		paramMap.put(JCMConstants.USECASE_ID_KEY, param.getUsecaseID());
		// オペレーションID
		paramMap.put(JCMConstants.OPERATION_ID_KEY, param.getOperationID());
		// サービス呼び出し区分
		paramMap.put(JCMConstants.CALL_TYPE_KEY, param.getCallType());

		// 【取得元：ユーザエリア(コントロールマップ)】
		// 依頼先ホスト名
		paramMap.put(JCMConstants.CLIENT_HOST_NAME_KEY, param.getControlMapData(SCControlMapKeys.REQ_HOSTNAME));
		// 依頼元IPアドレス
		paramMap.put(JCMConstants.CLIENT_IP_ADDRESS_KEY, param.getControlMapData(SCControlMapKeys.REQ_HOSTIP));
		// 依頼元画面ID
		paramMap.put(JCMConstants.INVOKE_GAMEN_ID_KEY, param.getControlMapData(SCControlMapKeys.REQ_VIEWID));
		// オペレータID
		paramMap.put(JCMConstants.OPERATOR_ID_KEY, param.getControlMapData(SCControlMapKeys.OPERATOR_ID));
		
		String svcIf = (String)mappingData[0][1];
		
		CAANMsg template = new CAANMsg(String.format("eo.ejb.cbs.cbsmsg.%sCBSMsg", svcIf));

		// オペレータID
		template.set(JCMConstants.OPERATOR_ID_KEY, param.getControlMapData(SCControlMapKeys.OPERATOR_ID));
		// 運用日付
		template.set(JCMConstants.OPERATE_DATE_KEY, param.getControlMapData(SCControlMapKeys.OPE_DATE));
		// 運用日時
		template.set(JCMConstants.OPERATE_DATETIME_KEY, param.getControlMapData(SCControlMapKeys.OPE_TIME));
		
		for (int i = 0; i < mappingData.length; i++)
		{
			if ("".equals(mappingData[i][1]))
			{
				template.setNull((String)mappingData[i][0]);
			}
			else
			{
				template.set((String)mappingData[i][0], mappingData[i][1]);
			}
		}
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	/**
	 * 
	 * @param param
	 * @param templates
	 * @param returnCode
	 * @param dataMapKey
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editErrorInfoCom(IRequestParameterReadWrite param,
														CAANMsg[] templates, 
														int returnCode,
														String dataMapKey,
														Object[][] mappingData) throws RequestParameterException
	{
		// 本来はサービスインターフェイス分の処理が必要
		CAANMsg template = templates[0];
		int templateStatus = template.getInt(JCMConstants.STATUS_INT_KEY);

		if (returnCode != 0)
		{
			templateStatus = 9000;
		}

		if (JCMAPLConstMgr.getString("RETURN_MESSAGE_" + String.format("%1$04d", templateStatus)) == null)
		{
			templateStatus = 0;
		}

		int bpStatus = 0;
		Object obj = param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if (obj == null)
		{
			bpStatus = -1;
		}
		else
		{
			bpStatus = Integer.parseInt((String)param.getControlMapData(SCControlMapKeys.RETURN_CODE));
		}

		if (templateStatus > bpStatus)
		{
			// BPにサービスコンポーネントのステータスを設定する。
			String formatStatus = String.format("%1$04d", templateStatus);
			String message = JCMAPLConstMgr.getString("RETURN_MESSAGE_" + formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, message);
		}

		HashMap<String, String> inMap = null;

		// ユーザデータ情報
		inMap = (HashMap<String, String>)param.getData(dataMapKey);
		
		for (int i = 0; i < mappingData.length; i++)
		{
			if (((String)mappingData[i][0]).startsWith("key_"))
			{
				if (!template.isNull(mappingData[i][0] + "_err"))
				{
					if (!inMap.containsKey(mappingData[i][0] + "_err"))
					{
						inMap.put(mappingData[i][0] + "_err", template.getString(mappingData[i][0] + "_err"));
					}
				}
			}
		}
		return param;
	}
	

}
