/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom, 2011
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JKKGetSvkeiStat
*   ソースファイル名：JKKGetSvkeiStat.java
*   作成者          ：富士通
*   日付            ：2012年 1月23日
*＜機能概要＞
*   サービス契約履歴一覧照会S-IF呼出し用アクセッサ部品
*＜修正履歴＞
*   バージョン  修正日       修正者      修正内容
*   v1.00.00    2012/ 1/23   FJ）        新規作成
*
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.fujitsu.futurity.bp.custom.constant.JKKGetSvkeiStatConstCC;
import com.fujitsu.futurity.bp.custom.constant.JKKSvcConst;
import com.fujitsu.futurity.bp.x21.bpm.ServiceComponentRequestInvoker;
import com.fujitsu.futurity.bp.x21.bpm.db.SessionHandle;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadOnly;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadWrite;
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.common.constant.JPCModelConstant;
import eo.ejb.cbs.cbsmsg.EKK0081B024CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081B024CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0161B011CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161B011CBSMsg1List;




/**
 * サービス契約履歴一覧照会S-IF呼出し用アクセッサ部品
 * 
 * @author FJ
 * @since 2012-01-23
 */
public class JKKGetSvkeiStat
{

	/**
	 * テンプレートID：EKK0081B024 サービス契約履歴一覧照会
	 */
	public static final String TID_EKK0081B024 = "EKK0081B024";

	// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
	/**
	 * テンプレートID：EKK0161B011 サービス契約内訳履歴一覧照会
	 */
	public static final String TID_EKK0161B011 = "EKK0161B011";
	// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END

	/** チェックエラー時のメッセージ */
	private static final String ERR_MSG = "INVALID_RETURN_MESSAGE";

	// ST2-2012-0001742 2012/10/01 ADD START
	/** 異動区分：光電話・番号回復 */
	private static final String IDO_DIV_00044 = "00044";
	// ST2-2012-0001742 2012/10/01 ADD END
	
	// 20121217 IT1-2012-0002387 ADD START
	/** 異動区分：光電話・番号解約 */
	private static final String IDO_DIV_00043 = "00043";
	// 20121217 IT1-2012-0002387 ADD END


	/**
	 * 現在のサービス契約ステータスの一世代前の値を取得<br/>
	 * <pre>
	 * 一世代前のサービス契約ステータスは、リクエストパラメータ param から次の要領で取得する。
	 * 		Map parentMap = (Map)param.getData(mapNm);
	 * 		String last_svc_kei_stat = (String)parentMap.get(JKKGetSvkeiStatConstCC.LAST_KK0081_STAT);
	 * </pre>
	 * @param handle セッションハンドル
	 * @param param0 リクエストパラメータ
	 * @param mapNm マップ名
	 * @return リクエストパラメータ
	 * @throws Throwable 任意の例外
	 */
	@SuppressWarnings("unchecked")
	protected static IRequestParameterReadWrite getLastSvcKeiStat(
			SessionHandle handle, IRequestParameterReadWrite param0, String mapNm) throws Throwable
	{
		// ST2-2012-0001742 2012/10/01 ADD START
		// 異動区分を先にとりだす。
		HashMap inMap = null;
		inMap = (HashMap)param0.getData(mapNm);
		
		String ido_div=(String)inMap.get(JKKGetSvkeiStatConstCC.IDO_DIV);
		// ST2-2012-0001742 2012/10/01 ADD END
		
		//サービス契約履歴一覧照会S-IF呼出し
		IRequestParameterReadWrite param1 = JKKGetSvkeiStat.execEKK0081B024(handle, param0, mapNm);
		
		String last_kk0081_stat = null;
		String last_gene_add_dtm = null;
		// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
		String last_kk0161_stat = null;
		// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END

		// 20121217 IT1-2012-0002387 申込明細番号を追加 ADD START
		// サービス契約を解約・キャンセル・番号解約した時点のサービス契約の申込明細番号
		String dslCnclMskmDtlNo = null;
		// 20121217 IT1-2012-0002387 申込明細番号を追加 ADD END
		
		HashMap<String, Object> parentMap = (HashMap<String, Object>) param1.getData(mapNm);
		List<?> kk0081RkList = (List<?>) parentMap.get(JKKGetSvkeiStatConstCC.EKK0081B024CBSMSG1LIST);
		if (null != kk0081RkList && 0 < kk0081RkList.size())
		{
			int i = 0;
			//現在のサービス契約ステータス
			String svc_kei_stat = (String) ((Map<?, ?>) kk0081RkList.get(i++)).get(JKKGetSvkeiStatConstCC.SVC_KEI_STAT);
	
			//一世代前のサービス契約ステータスを取得
			while (i < kk0081RkList.size())
			{
				// 20121217 IT1-2012-0002387 処理中の１世代のレコード ADD START
				int j = i - 1;
				Map<?, ?> childMap2 = (Map<?, ?>) kk0081RkList.get(j);
				// 20121217 IT1-2012-0002387 処理中の１世代のレコード ADD END
				Map<?, ?> childMap = (Map<?, ?>) kk0081RkList.get(i++);
				// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
//				last_kk0081_stat = (String) childMap.get(JKKGetSvkeiStatConstCC.SVC_KEI_STAT);
				// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END
				// ST2-2012-0001742 2012/10/01 MOD START
				// 光電話・番号回復時にはサービス契約ステータスは変わらないため
				// そのまま1世代前の情報を返却する。
				if (!IDO_DIV_00044.equals(ido_div))
				{
					// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
					last_kk0081_stat = (String) childMap.get(JKKGetSvkeiStatConstCC.SVC_KEI_STAT);
					// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END

					if (!last_kk0081_stat.equals(svc_kei_stat))
					{
						last_gene_add_dtm = (String) childMap.get(JKKGetSvkeiStatConstCC.GENE_ADD_DTM);
						// 20121217 IT1-2012-0002387 解約・キャンセル時点の申込明細番号を設定 ADD START
						dslCnclMskmDtlNo =  (String) childMap2.get(JKKGetSvkeiStatConstCC.MSKM_DTL_NO);
						// 20121217 IT1-2012-00023877 解約・キャンセル時点の申込明細番号を設定 ADD END
						break;
					}
				}
				else
				{
					// 20121217 IT1-2012-0002387 申込明細番号を追加 MOD START
//					last_gene_add_dtm = (String) childMap.get(JKKGetSvkeiStatConstCC.GENE_ADD_DTM);
//					break;
					if(last_gene_add_dtm == null)
					{
						// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
						// カレントの情報を1世代前として取得する
						last_gene_add_dtm = (String) childMap2.get(JKKGetSvkeiStatConstCC.GENE_ADD_DTM);
						last_kk0081_stat = (String) childMap2.get(JKKGetSvkeiStatConstCC.SVC_KEI_STAT);
						break;
						// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END
					}
					// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
					// 番号解約時にコース変更予約が取り消された場合、サービス契約に番号解約のレコードがなく、
					// 申込明細番号を取得できていない。後続処理でサービス契約内訳から取得するため削除
//					if(IDO_DIV_00043.equals((String) childMap2.get(JKKGetSvkeiStatConstCC.IDO_DIV))){
//						// 光電話・番号解約した時点の申込明細番号を設定する
//						dslCnclMskmDtlNo =  (String) childMap2.get(JKKGetSvkeiStatConstCC.MSKM_DTL_NO);
//						break;
//					}
					// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END
					// 20121217 IT1-2012-0002387 申込明細番号を追加 MOD END
				}
				// ST2-2012-0001742 2012/10/01 MOD END
			}
		}

		// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
		// KT1-2013-0000766 休止・中断中に利用停止できない 2013/08/08 START
		String svcKeiUcwkNo = (String)inMap.get(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_UCWK_NO);
		// 異動区分が光電話・番号回復、利用停止解除の場合
//		if (IDO_DIV_00044.equals(ido_div))
		if (null != svcKeiUcwkNo && !svcKeiUcwkNo.isEmpty() && (IDO_DIV_00044.equals(ido_div) || JKKSvcConst.IDO_DIV_USESTPRLS.equals(ido_div)))
		// KT1-2013-0000766 休止・中断中に利用停止できない 2013/08/08 END
		{
			// 申込明細番号、サービス契約内訳ステータスを取得する
			// サービス契約内訳履歴一覧照会S-IF呼出し
			IRequestParameterReadWrite paramUcwk = JKKGetSvkeiStat.execEKK0161B011(handle, param0, mapNm);
			HashMap<String, Object> parentMapUcwk = (HashMap<String, Object>) paramUcwk.getData(mapNm);
			List<?> kk0161RkList = (List<?>) parentMapUcwk.get(JKKGetSvkeiStatConstCC.EKK0161B011CBSMSG1LIST);
			if (null != kk0161RkList && 0 < kk0161RkList.size())
			{
				int i = 0;
				// 現在のサービス契約内訳ステータス
				String svc_kei_ucwk_stat = (String) ((Map<?, ?>) kk0161RkList.get(i++)).get(JKKGetSvkeiStatConstCC.SVC_KEI_UCWK_STAT);

				// 一世代前のサービス契約内訳ステータス、申込明細番号を取得
				while (i < kk0161RkList.size())
				{
					int j = i - 1;
					Map<?, ?> childMap2 = (Map<?, ?>) kk0161RkList.get(j);
					Map<?, ?> childMap = (Map<?, ?>) kk0161RkList.get(i++);
					last_kk0161_stat = (String) childMap.get(JKKGetSvkeiStatConstCC.SVC_KEI_UCWK_STAT);
					if (!last_kk0161_stat.equals(svc_kei_ucwk_stat))
					{
						// 光電話・番号解約した時点の申込明細番号を設定する
						dslCnclMskmDtlNo =  (String) childMap2.get(JKKGetSvkeiStatConstCC.MSKM_DTL_NO);
						break;
					}
				}
			}
		}
		// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END

		// 返却用、一世代前のサービス契約ステータス
		parentMap.put(JKKGetSvkeiStatConstCC.LAST_KK0081_STAT, last_kk0081_stat);
		// 返却用、一世代前のサービス契約ステータスにあたる世代登録年月日時分秒
		parentMap.put(JKKGetSvkeiStatConstCC.LAST_GENE_ADD_DTM, last_gene_add_dtm);
		// 20121217 IT1-2012-0002387 申込明細番号を追加 ADD START
		parentMap.put(JKKGetSvkeiStatConstCC.DSL_CNCL_MSKM_DTL_NO, dslCnclMskmDtlNo);
		// 20121217 IT1-2012-0002387 申込明細番号を追加 ADD END
		// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
		// 返却用、一世代前のサービス契約内訳ステータス
		parentMap.put(JKKGetSvkeiStatConstCC.LAST_KK0161_STAT, last_kk0161_stat);
		// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END
		
		return param1;
	}


	/**
	 * 登録から現在までのサービス契約ステータスの値を取得<br>
	 * <br>
	 * @param	handle		セッションハンドル
	 * @param	param0		リクエストパラメータ
	 * @param	mapNm		マップ名
	 * @return				リクエストパラメータ
	 * @throws	Throwable	任意の例外
	 */
	@SuppressWarnings("unchecked")
	protected static IRequestParameterReadWrite getSvcKeiStatRireki(
			SessionHandle handle,
			IRequestParameterReadWrite param0,
			String mapNm
	) throws Throwable
	{
		// サービス契約ステータス履歴リスト
		ArrayList<String> kk0081_stat_rireki = new ArrayList<String>();

		// サービス契約履歴一覧照会S-IF呼出し（世代登録年月日時分秒　降順）
		IRequestParameterReadWrite param1 = JKKGetSvkeiStat.execEKK0081B024(handle, param0, mapNm);

		HashMap<String, Object> parentMap = (HashMap<String, Object>) param1.getData(mapNm);
		List<?> kk0081RkList = (List<?>) parentMap.get(JKKGetSvkeiStatConstCC.EKK0081B024CBSMSG1LIST);

		// １レコード前のサービス契約ステータス
		String bf_svc_kei_stat = null;

		for (int i = 0; i < kk0081RkList.size(); i++)
		{
			HashMap<?, ?> kk0081RkInfo = (HashMap<?, ?>)kk0081RkList.get(i);

			// サービス契約ステータス
			String svc_kei_stat = (String)kk0081RkInfo.get(JKKGetSvkeiStatConstCC.SVC_KEI_STAT);

			if (bf_svc_kei_stat == null)
			{
				// リストに格納
				kk0081_stat_rireki.add(svc_kei_stat);
			}
			else
			{
				// サービス契約ステータスが異なる場合
				if (! bf_svc_kei_stat.equals(svc_kei_stat))
				{
					// リストに格納
					kk0081_stat_rireki.add(svc_kei_stat);
				}
			}

			// サービス契約ステータスを保持
			bf_svc_kei_stat = svc_kei_stat;
		}

		// サービス契約ステータスの履歴情報
		parentMap.put(JKKGetSvkeiStatConstCC.KK0081_STAT_RIREKI, kk0081_stat_rireki);

		return param1;
	}


	/**
	 * EKK0081B024 サービス契約一覧照会S-IFの呼出処理
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param mapNm マップ名
	 * @return リクエストパラメータ
	 * @throws Throwable 任意の例外
	 */
	protected static IRequestParameterReadWrite execEKK0081B024(
			SessionHandle handle, IRequestParameterReadWrite param, String mapNm) throws Throwable
	{
		// 上りマッピング
		HashMap<String, Object> paramMap = editInMsgEKK0081B024(param, mapNm);
		
		//サービスＩ／Ｆ呼出
		Map<?, ?> result = (new ServiceComponentRequestInvoker()).run(paramMap, handle);

		// 下りマッピング
		IRequestParameterReadWrite ret = editResultRPEKK0081B024(result, param, mapNm);

		// エラーチェック処理
		errChk(result);

		return ret;
	}





	/**
	 * エラーチェック処理
	 * 
	 * @param msgList サービスインタフェース実行結果
	 * @throws SCCallException 
	 */
	private static void errChk(Map<?, ?> msgList) 
	throws SCCallException
	{
		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg template = templates[0];

		// リターンコード取得
		int returnCode = (Integer)msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// ステータス
		int templateStatus = template.getInt(JCMConstants.STATUS_INT_KEY);
		
		if ((0 != returnCode) || (0 != templateStatus))
		{
			throw new SCCallException(ERR_MSG, String.valueOf(returnCode), templateStatus);
		}
	}


	/**
	 *<DL>
	 *<DT>処理概要:
	 *<DD>サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param param (I) 業務データ取得用I/F
	 * @return サービスコンポーネント実行用CAANMsg
	 */
	@SuppressWarnings("unchecked")
	private static HashMap<String, Object> editInMsgEKK0081B024(IRequestParameterReadOnly param, String mapNm) throws Throwable
	{

		HashMap<String, Object> paramMap = new HashMap<String, Object>();

		/* SCインプット共通データ */
		// **********************************************
		// 【取得元：電文ヘッダ(ヘッダ)】
		// **********************************************
		// 電文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));

		CAANMsg template = new CAANMsg(EKK0081B024CBSMsg.class.getName());

		HashMap inMap = null;

		// テンプレートID
		template.set(EKK0081B024CBSMsg.TEMPLATEID, TID_EKK0081B024);

		// 機能コード（デフォルト：１）
		template.set(EKK0081B024CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);

		// オペレータID
		Object operatorId = param.getControlMapData(SCControlMapKeys.OPERATOR_ID);
		template.set(JCMConstants.OPERATOR_ID_KEY, operatorId);

		// 運用日付
		Object operateDate = param.getControlMapData(SCControlMapKeys.OPE_DATE);
		template.set(JCMConstants.OPERATE_DATE_KEY, operateDate);

		// 運用日時
		Object operateDateTime = param.getControlMapData(SCControlMapKeys.OPE_TIME);
		template.set(JCMConstants.OPERATE_DATETIME_KEY, operateDateTime);

		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData(mapNm);


		// サービス契約履歴一覧照会マップ.ＫＥＹ＿サービス契約番号 → ＫＥＹ＿サービス契約番号
		if (inMap == null || inMap.get(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_NO) == null || "".equals(inMap.get(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_NO))) {
			template.setNull(EKK0081B024CBSMsg.KEY_SVC_KEI_NO);
		} else {
			template.set(EKK0081B024CBSMsg.KEY_SVC_KEI_NO, (String) inMap.get(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_NO));
		}
			

		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}


	/**
	 *<DL>
	 *<DT>処理概要:
	 *<DD>サービスコンポーネント実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param param (I) 業務データ取得・書込用I/F
	 * @param templates (I) CAANMsgクラス配列
	 * @param returnCode (I) リターンコード
	 * @return 業務データ取得・書込用I/F
	 */
	@SuppressWarnings("unchecked")
	private static IRequestParameterReadWrite editErrorInfoEKK0081B024(
			IRequestParameterReadWrite param, CAANMsg[] templates, int returnCode, String mapNm) throws Throwable
	{
		CAANMsg template = templates[0];
		int templateStatus = template.getInt(EKK0081B024CBSMsg.STATUS);
		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 inMap = null;
		
		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData(mapNm);
		if (inMap == null) {
			inMap = new HashMap();
			param.setData(mapNm, inMap);
		}

		// サービス契約履歴一覧照会マップ.ＫＥＹ＿サービス契約番号 → ＫＥＹ＿サービス契約番号 のエラー情報返却
		if (!template.isNull(EKK0081B024CBSMsg.KEY_SVC_KEI_NO_ERR)) {
			if (!inMap.containsKey(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_NO_ERR)) {
				inMap.put(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_NO_ERR, template.getString(EKK0081B024CBSMsg.KEY_SVC_KEI_NO_ERR));
			}
		}
		return param;
	}

	/**
	 *<DL>
	 *<DT>処理概要:
	 *<DD>サービスコンポーネント実行後に、IRequestParameterReadWriteに必要なデータをマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param msgList (I) CAANMsgクラス 
	 * @param param (I) 業務データ取得・書込用I/F
	 * @return 業務データ取得・書込用I/F
	 */
	@SuppressWarnings("unchecked")
	private static IRequestParameterReadWrite editResultRPEKK0081B024(
			Map<?, ?> msgList,
			IRequestParameterReadWrite param,
			String mapNm) throws Throwable
	{

		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[]) msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];
		CAANMsg[] templateArray = null;

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		
		// 結果を詰めるマップを取得。
		HashMap dataMap = null;
		ArrayList dataList = null;

		/* 業務データ設定 */
		dataMap = (HashMap)param.getData(mapNm);
		if (dataMap == null) {
			dataMap = new HashMap();
			param.setData(mapNm, dataMap);
		}
		templateArray = parentTemplate.getCAANMsgList(EKK0081B024CBSMsg.EKK0081B024CBSMSG1LIST);
		dataList = (ArrayList)dataMap.get(JKKGetSvkeiStatConstCC.EKK0081B024CBSMSG1LIST);
		  
		if (dataList == null) {
			dataList = new ArrayList();
		}

		if (templateArray != null) {
			for (int i = 0; i < templateArray.length; i++) {
				CAANMsg childTemplate = templateArray[i];
				if ( i >= dataList.size()) {
					dataList.add(new HashMap());
				}
				HashMap childMap = (HashMap)dataList.get(i);

				// サービス契約履歴一覧照会マップ.サービス契約履歴一覧照会明細.世代登録年月日時分秒 ← サービス契約履歴一覧照会明細.世代登録年月日時分秒
				if (childTemplate.isNull(EKK0081B024CBSMsg1List.GENE_ADD_DTM)) {
					childMap.put(JKKGetSvkeiStatConstCC.GENE_ADD_DTM, new String());
				} else {
					childMap.put(JKKGetSvkeiStatConstCC.GENE_ADD_DTM, childTemplate.getString(EKK0081B024CBSMsg1List.GENE_ADD_DTM));
				}

				// サービス契約履歴一覧照会マップ.サービス契約履歴一覧照会明細.サービス契約ステータス ← サービス契約履歴一覧照会明細.サービス契約ステータス
				if (childTemplate.isNull(EKK0081B024CBSMsg1List.SVC_KEI_STAT)) {
					childMap.put(JKKGetSvkeiStatConstCC.SVC_KEI_STAT, new String());
				} else {
					childMap.put(JKKGetSvkeiStatConstCC.SVC_KEI_STAT, childTemplate.getString(EKK0081B024CBSMsg1List.SVC_KEI_STAT));
				}

				// サービス契約履歴一覧照会マップ.サービス契約履歴一覧照会明細.申込明細番号 ← サービス契約履歴一覧照会明細.申込明細番号
				if (childTemplate.isNull(EKK0081B024CBSMsg1List.MSKM_DTL_NO)) {
					childMap.put(JKKGetSvkeiStatConstCC.MSKM_DTL_NO, new String());
				} else {
					childMap.put(JKKGetSvkeiStatConstCC.MSKM_DTL_NO, childTemplate.getString(EKK0081B024CBSMsg1List.MSKM_DTL_NO));
				}

				// サービス契約履歴一覧照会マップ.サービス契約履歴一覧照会明細.異動区分 ← サービス契約履歴一覧照会明細.異動区分
				if (childTemplate.isNull(EKK0081B024CBSMsg1List.IDO_DIV)) {
					childMap.put(JKKGetSvkeiStatConstCC.IDO_DIV, new String());
				} else {
					childMap.put(JKKGetSvkeiStatConstCC.IDO_DIV, childTemplate.getString(EKK0081B024CBSMsg1List.IDO_DIV));
				}

			}
		}
		dataMap.put(JKKGetSvkeiStatConstCC.EKK0081B024CBSMSG1LIST, dataList);

        
        // エラー情報の設定
        param = editErrorInfoEKK0081B024(param, templates, (Integer)return_code, mapNm);

		//エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>)param.getControlMapData(SCControlMapKeys.ERROR_INFO);
		if(errList == null){
			errList = new ArrayList<Object>();
		}
		// コントロールマップに設定
		param.setControlMapData(SCControlMapKeys.ERROR_INFO, TemplateErrorUtil.getErrorInfo(msgList, errList));
        

		return param;
	}

	// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 START
	/**
	 * EKK0161B011 サービス契約内訳履歴一覧照会S-IFの呼出処理
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param mapNm マップ名
	 * @return リクエストパラメータ
	 * @throws Throwable 任意の例外
	 */
	protected static IRequestParameterReadWrite execEKK0161B011(
			SessionHandle handle, IRequestParameterReadWrite param, String mapNm) throws Throwable
	{
		// 上りマッピング
		HashMap<String, Object> paramMap = editInMsgEKK0161B011(param, mapNm);
		
		//サービスＩ／Ｆ呼出
		Map<?, ?> result = (new ServiceComponentRequestInvoker()).run(paramMap, handle);

		// 下りマッピング
		IRequestParameterReadWrite ret = editResultRPEKK0161B011(result, param, mapNm);

		// エラーチェック処理
		errChk(result);

		return ret;
	}

	/**
	 *<DL>
	 *<DT>処理概要:
	 *<DD>サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param param (I) 業務データ取得用I/F
	 * @return サービスコンポーネント実行用CAANMsg
	 */
	@SuppressWarnings("unchecked")
	private static HashMap<String, Object> editInMsgEKK0161B011(IRequestParameterReadOnly param, String mapNm) throws Throwable
	{

		HashMap<String, Object> paramMap = new HashMap<String, Object>();

		/* SCインプット共通データ */
		// **********************************************
		// 【取得元：電文ヘッダ(ヘッダ)】
		// **********************************************
		// 電文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));

		CAANMsg template = new CAANMsg(EKK0161B011CBSMsg.class.getName());

		HashMap inMap = null;

		// テンプレートID
		template.set(EKK0161B011CBSMsg.TEMPLATEID, TID_EKK0161B011);

		// 機能コード（デフォルト：１）
		template.set(EKK0161B011CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);

		// オペレータID
		Object operatorId = param.getControlMapData(SCControlMapKeys.OPERATOR_ID);
		template.set(JCMConstants.OPERATOR_ID_KEY, operatorId);

		// 運用日付
		Object operateDate = param.getControlMapData(SCControlMapKeys.OPE_DATE);
		template.set(JCMConstants.OPERATE_DATE_KEY, operateDate);

		// 運用日時
		Object operateDateTime = param.getControlMapData(SCControlMapKeys.OPE_TIME);
		template.set(JCMConstants.OPERATE_DATETIME_KEY, operateDateTime);

		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData(mapNm);


		// サービス契約内訳履歴一覧照会マップ.ＫＥＹ＿サービス契約内訳番号 → ＫＥＹ＿サービス契約内訳番号
		if (inMap == null || inMap.get(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_UCWK_NO) == null || "".equals(inMap.get(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_UCWK_NO))) {
			template.setNull(EKK0161B011CBSMsg.KEY_SVC_KEI_UCWK_NO);
		} else {
			template.set(EKK0161B011CBSMsg.KEY_SVC_KEI_UCWK_NO, (String) inMap.get(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_UCWK_NO));
		}
			

		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}


	/**
	 *<DL>
	 *<DT>処理概要:
	 *<DD>サービスコンポーネント実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param param (I) 業務データ取得・書込用I/F
	 * @param templates (I) CAANMsgクラス配列
	 * @param returnCode (I) リターンコード
	 * @return 業務データ取得・書込用I/F
	 */
	@SuppressWarnings("unchecked")
	private static IRequestParameterReadWrite editErrorInfoEKK0161B011(
			IRequestParameterReadWrite param, CAANMsg[] templates, int returnCode, String mapNm) throws Throwable
	{
		CAANMsg template = templates[0];
		int templateStatus = template.getInt(EKK0161B011CBSMsg.STATUS);
		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 inMap = null;
		
		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData(mapNm);
		if (inMap == null) {
			inMap = new HashMap();
			param.setData(mapNm, inMap);
		}

		// サービス契約内訳履歴一覧照会マップ.ＫＥＹ＿サービス契約内訳番号 → ＫＥＹ＿サービス契約内訳番号 のエラー情報返却
		if (!template.isNull(EKK0161B011CBSMsg.KEY_SVC_KEI_UCWK_NO_ERR)) {
			if (!inMap.containsKey(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_UCWK_NO_ERR)) {
				inMap.put(JKKGetSvkeiStatConstCC.KEY_SVC_KEI_UCWK_NO_ERR, template.getString(EKK0161B011CBSMsg.KEY_SVC_KEI_UCWK_NO_ERR));
			}
		}
		return param;
	}

	/**
	 *<DL>
	 *<DT>処理概要:
	 *<DD>サービスコンポーネント実行後に、IRequestParameterReadWriteに必要なデータをマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param msgList (I) CAANMsgクラス 
	 * @param param (I) 業務データ取得・書込用I/F
	 * @return 業務データ取得・書込用I/F
	 */
	@SuppressWarnings("unchecked")
	private static IRequestParameterReadWrite editResultRPEKK0161B011(
			Map<?, ?> msgList,
			IRequestParameterReadWrite param,
			String mapNm) throws Throwable
	{

		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[]) msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];
		CAANMsg[] templateArray = null;

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		
		// 結果を詰めるマップを取得。
		HashMap dataMap = null;
		ArrayList dataList = null;

		/* 業務データ設定 */
		dataMap = (HashMap)param.getData(mapNm);
		if (dataMap == null) {
			dataMap = new HashMap();
			param.setData(mapNm, dataMap);
		}
		templateArray = parentTemplate.getCAANMsgList(EKK0161B011CBSMsg.EKK0161B011CBSMSG1LIST);
		dataList = (ArrayList)dataMap.get(JKKGetSvkeiStatConstCC.EKK0161B011CBSMSG1LIST);
		  
		if (dataList == null) {
			dataList = new ArrayList();
		}

		if (templateArray != null) {
			for (int i = 0; i < templateArray.length; i++) {
				CAANMsg childTemplate = templateArray[i];
				if ( i >= dataList.size()) {
					dataList.add(new HashMap());
				}
				HashMap childMap = (HashMap)dataList.get(i);

				// サービス契約内訳履歴一覧照会マップ.サービス契約内訳履歴一覧照会明細.世代登録年月日時分秒 ← サービス契約内訳履歴一覧照会明細.世代登録年月日時分秒
				if (childTemplate.isNull(EKK0161B011CBSMsg1List.GENE_ADD_DTM)) {
					childMap.put(JKKGetSvkeiStatConstCC.GENE_ADD_DTM, new String());
				} else {
					childMap.put(JKKGetSvkeiStatConstCC.GENE_ADD_DTM, childTemplate.getString(EKK0161B011CBSMsg1List.GENE_ADD_DTM));
				}

				// サービス契約内訳履歴一覧照会マップ.サービス契約内訳履歴一覧照会明細.サービス契約内訳ステータス ← サービス契約内訳履歴一覧照会明細.サービス契約内訳ステータス
				if (childTemplate.isNull(EKK0161B011CBSMsg1List.SVC_KEI_UCWK_STAT)) {
					childMap.put(JKKGetSvkeiStatConstCC.SVC_KEI_UCWK_STAT, new String());
				} else {
					childMap.put(JKKGetSvkeiStatConstCC.SVC_KEI_UCWK_STAT, childTemplate.getString(EKK0161B011CBSMsg1List.SVC_KEI_UCWK_STAT));
				}

				// サービス契約内訳履歴一覧照会マップ.サービス契約内訳履歴一覧照会明細.申込明細番号 ← サービス契約内訳履歴一覧照会明細.申込明細番号
				if (childTemplate.isNull(EKK0161B011CBSMsg1List.MSKM_DTL_NO)) {
					childMap.put(JKKGetSvkeiStatConstCC.MSKM_DTL_NO, new String());
				} else {
					childMap.put(JKKGetSvkeiStatConstCC.MSKM_DTL_NO, childTemplate.getString(EKK0161B011CBSMsg1List.MSKM_DTL_NO));
				}

			}
		}
		dataMap.put(JKKGetSvkeiStatConstCC.EKK0161B011CBSMSG1LIST, dataList);

        
        // エラー情報の設定
        param = editErrorInfoEKK0161B011(param, templates, (Integer)return_code, mapNm);

		//エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>)param.getControlMapData(SCControlMapKeys.ERROR_INFO);
		if(errList == null){
			errList = new ArrayList<Object>();
		}
		// コントロールマップに設定
		param.setControlMapData(SCControlMapKeys.ERROR_INFO, TemplateErrorUtil.getErrorInfo(msgList, errList));
        

		return param;
	}
	// IT1-2013-0001202 番号回復時に排他エラー 2013/05/17 END

}
