/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JKKCourseRkSvKeiUcwkDslCC
*   ソースファイル名：JKKCourseRkSvKeiUcwkDslCC.java
*   作成者          ：FJ
*   日付            ：2012年03月15日
*＜機能概要＞
*   コース変更予約取消の共通コンポーネント（サービス契約内訳コース履歴一覧照会の予約レコード解約）
*＜修正履歴＞
*＜修正履歴＞
*   バージョン  修正日       修正者      修正内容
*   v1.00.00    2012/03/21   FJ)団       新規作成
*   v4.00.00    2012/12/04   FJ)馬場     IT1-2012-0002185対応（元JKKCourseRkSkuCrSearchCC）
*   v5.00.00	2013/09/12	 FJ)辛		【OM-2013-0001808】対応
*   v6.00.00	2014/01/08	 FJ)辛		【OM-2014-0000097】対応
 * v23.00.00	2016/03/31	FJ)星野     【OM-2016-0000849】対応
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
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.common.constant.JKKStrConst;
import eo.ejb.cbs.cbsmsg.EKK0161A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0161B002CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161B002CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0161C160CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161C180CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161C190CBSMsg;

public class JKKCourseRkSvKeiUcwkDslCC extends AbstractCommonComponent
{
	/** サービス契約内訳コース履歴一覧照会 */
	private static final String TEMPLATE_ID_EKK0161B002 = "EKK0161B002";
	/** サービス契約内訳一意照会 */
	private static final String TEMPLATE_ID_EKK0161A010 = "EKK0161A010";
	/** サービス契約内訳キャンセル */
	private static final String TEMPLATE_ID_EKK0161C160 = "EKK0161C160";
	/** サービス契約内訳解約 */
	private static final String TEMPLATE_ID_EKK0161C180 = "EKK0161C180";
	/** サービス契約内訳解約確定 */
	private static final String TEMPLATE_ID_EKK0161C190 = "EKK0161C190";
	/** プラン終了種別コード(2：解約による終了) */
	private static final String PLAN_END_SBT_CD_2 = "2";

	/**
	 * サービス契約内訳コース履歴一覧照会情報を取得し、解約キャンセルを行う。
	 * 
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return IRequestParameterReadWrite
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite executeSvKeiUcwkDsl(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(fixedText);
		ArrayList<HashMap<String, Object>> dataList = new ArrayList<HashMap<String, Object>>();
		int count = 0;
		String courseChgMskmDtlNo = (String)ccMsg.get("mskm_dtl_no");
		
		/* ++++++++++ v6.00.00 追加開始 ++++++++++ */
		String param_ido_div = (String)ccMsg.get("ido_div");
		boolean fromScrn = false;
		String course_chg_flg = (String)ccMsg.get("course_chg_flg");
		String course_chg_ido_div = (String)ccMsg.get("course_chg_ido_div");
		
		if(course_chg_flg != null && course_chg_flg != "")
		{
			if("1".equals(course_chg_flg))
			{
				fromScrn = true;
			}
		}
		/* ++++++++++ v6.00.00 追加終了 ++++++++++ */
		
		// 同一サービス契約内訳に対して２回以上処理を行わない判定をするためのリスト
		ArrayList<String> svcKeiUcwkNoList = new ArrayList<String>();
		
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		// ***** EKK0161B002（サービス契約内訳コース履歴一覧照会）*****
		Object[][] ekk0161b002IN = {
				{EKK0161B002CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK0161B002},
				{EKK0161B002CBSMsg.FUNC_CODE,        "1"},
				{EKK0161B002CBSMsg.KEY_SVC_KEI_NO,   (String)ccMsg.get("key_svc_kei_no")},
			};
		CAANMsg[] ekk0161b002CBSMsg1List = callSC(handle, scCall, param, fixedText, ekk0161b002IN).getCAANMsgList(EKK0161B002CBSMsg.EKK0161B002CBSMSG1LIST);
		
		for (int i = 0; i < ekk0161b002CBSMsg1List.length; i++)
		{
			CAANMsg childTemplate = ekk0161b002CBSMsg1List[i];
			
			// サービス契約内訳一意照会
			Object[][] ekk0161a010INGENE = {
					{EKK0161A010CBSMsg.TEMPLATEID,            TEMPLATE_ID_EKK0161A010},
					{EKK0161A010CBSMsg.FUNC_CODE,             "1"},
					{EKK0161A010CBSMsg.KEY_SVC_KEI_UCWK_NO,   childTemplate.getString(EKK0161B002CBSMsg1List.SVC_KEI_UCWK_NO)},
					{EKK0161A010CBSMsg.KEY_GENE_ADD_DTM,      childTemplate.getString(EKK0161B002CBSMsg1List.GENE_ADD_DTM)},
					{EKK0161A010CBSMsg.KEY_RSV_APLY_YMD,      ""},
				};
			CAANMsg[] ekk0161a010CBSMsg1List = callSC(handle, scCall, param, fixedText, ekk0161a010INGENE).getCAANMsgList(EKK0161A010CBSMsg.EKK0161A010CBSMSG1LIST);
			
			String curMskmDtlNo = ekk0161a010CBSMsg1List[0].getString(EKK0161A010CBSMsg1List.MSKM_DTL_NO);
			// コース変更時の申込明細番号と異なるレコードは処理しない
			if(!courseChgMskmDtlNo.equals(curMskmDtlNo))
			{
				continue;
			}
			
			/* ++++++++++ v6.00.00 追加開始 ++++++++++ */
			String idoDiv = ekk0161a010CBSMsg1List[0].getString(EKK0161A010CBSMsg1List.IDO_DIV);
			//コース変更予約取消画面からの予約取消
			if(fromScrn)
			{
				if(!course_chg_ido_div.equals(idoDiv))
				{
					continue;
				}
			}
			//住所変更登録画面のコース変更予約取消処理からの予約取消
			else
			{
				if(!param_ido_div.equals(idoDiv))
				{
					continue;
				}
			}
			/* ++++++++++ v6.00.00 追加終了 ++++++++++ */
			String curSvcKeiUcwkNo = ekk0161a010CBSMsg1List[0].getString(EKK0161A010CBSMsg1List.SVC_KEI_UCWK_NO);
			
			/* ++++++++++ v23.00.00 ADD START ++++++++++ */
			// サービス契約内訳一意照会（カレント）
			Object[][] ekk0161a010INCUR = {
					{EKK0161A010CBSMsg.TEMPLATEID,            TEMPLATE_ID_EKK0161A010},
					{EKK0161A010CBSMsg.FUNC_CODE,             "2"},
					{EKK0161A010CBSMsg.KEY_SVC_KEI_UCWK_NO,   curSvcKeiUcwkNo},
					{EKK0161A010CBSMsg.KEY_GENE_ADD_DTM,      ""},
					{EKK0161A010CBSMsg.KEY_RSV_APLY_YMD,      JPCBPCommon.getOpeDate(null)},
				};
			CAANMsg[] ekk0161a010CBSMsg1ListCur = callSC(handle, scCall, param, fixedText, ekk0161a010INCUR).getCAANMsgList(EKK0161A010CBSMsg.EKK0161A010CBSMSG1LIST);
			
			// 解約済・キャンセル済の内訳は処理しない
			String svcKeiUcwkStat = ekk0161a010CBSMsg1ListCur[0].getString(EKK0161A010CBSMsg1List.SVC_KEI_UCWK_STAT);
			if( JKKStrConst.CD00037_DSL_ZM.equals(svcKeiUcwkStat) || JKKStrConst.CD00037_CANCEL_ZM.equals(svcKeiUcwkStat)){
				continue;
			}
			/* ++++++++++ v23.00.00 ADD END   ++++++++++ */

			// リストにすでに同一番号のサービス契約内訳情報が格納されている場合は処理しない
			if(svcKeiUcwkNoList.contains(curSvcKeiUcwkNo))
			{
				continue;
			}
			svcKeiUcwkNoList.add(curSvcKeiUcwkNo);
			
			// コース変更の未来レコード（予約）を対象データとしてセットする
			if (count >= dataList.size())
			{
				dataList.add(new HashMap<String, Object>());
			}
			HashMap<String, Object> childMap = dataList.get(count);
			
			// 取得情報ここから
			// サービス契約内訳コース履歴一覧照会.サービス契約内訳番号
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.SVC_KEI_UCWK_NO)) 
			{
				childMap.put("svc_kei_ucwk_no", "");
				ccMsg.put("svc_kei_ucwk_no", "");
			} 
			else 
			{
				childMap.put("svc_kei_ucwk_no", childTemplate.getString(EKK0161B002CBSMsg1List.SVC_KEI_UCWK_NO));
				ccMsg.put("svc_kei_ucwk_no", childTemplate.getString(EKK0161B002CBSMsg1List.SVC_KEI_UCWK_NO));
			}
			// サービス契約内訳コース履歴一覧照会.世代登録年月日時分秒
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.GENE_ADD_DTM)) 
			{
				childMap.put("gene_add_dtm", "");
				ccMsg.put("gene_add_dtm", "");
			} 
			else 
			{
				childMap.put("gene_add_dtm", childTemplate.getString(EKK0161B002CBSMsg1List.GENE_ADD_DTM));
				ccMsg.put("gene_add_dtm", childTemplate.getString(EKK0161B002CBSMsg1List.GENE_ADD_DTM));
			}
			// サービス契約内訳コース履歴一覧照会.予約適用年月日
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.RSV_APLY_YMD)) 
			{
				childMap.put("rsv_aply_ymd", "");
			} 
			else 
			{
				childMap.put("rsv_aply_ymd", childTemplate.getString(EKK0161B002CBSMsg1List.RSV_APLY_YMD));
			}
			// サービス契約内訳コース履歴一覧照会.予約適用コード
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.RSV_APLY_CD)) 
			{
				childMap.put("rsv_aply_cd", "");
			} 
			else 
			{
				childMap.put("rsv_aply_cd", childTemplate.getString(EKK0161B002CBSMsg1List.RSV_APLY_CD));
			}
			// サービス契約内訳コース履歴一覧照会.プラン開始年月日
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.PLAN_STAYMD)) 
			{
				childMap.put("plan_staymd", "");
			} 
			else 
			{
				childMap.put("plan_staymd", childTemplate.getString(EKK0161B002CBSMsg1List.PLAN_STAYMD));
			}
			// サービス契約内訳コース履歴一覧照会.料金コースコード
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.PCRS_CD)) 
			{
				childMap.put("pcrs_cd", "");
			} 
			else 
			{
				childMap.put("pcrs_cd", childTemplate.getString(EKK0161B002CBSMsg1List.PCRS_CD));
			}
			// サービス契約内訳コース履歴一覧照会.更新年月日時分秒
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.UPD_DTM)) 
			{
				childMap.put("upd_dtm", "");
			} 
			else 
			{
				childMap.put("upd_dtm", childTemplate.getString(EKK0161B002CBSMsg1List.UPD_DTM));
			}
			// サービス契約内訳コース履歴一覧照会.提供方式契約番号
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.TK_HOSHIKI_KEI_NO)) 
			{
				childMap.put("tk_hoshiki_kei_no", "");
			} 
			else 
			{
				childMap.put("tk_hoshiki_kei_no", childTemplate.getString(EKK0161B002CBSMsg1List.TK_HOSHIKI_KEI_NO));
			}
			// サービス契約内訳コース履歴一覧照会.マンション名
			if (childTemplate.isNull(EKK0161B002CBSMsg1List.MANSION_NM)) 
			{
				childMap.put("mansion_nm", "");
			} 
			else 
			{
				childMap.put("mansion_nm", childTemplate.getString(EKK0161B002CBSMsg1List.MANSION_NM));
			}
			// サービス契約内訳一意照会.サービス契約内訳ステータス
			if (ekk0161a010CBSMsg1List[0].isNull(EKK0161A010CBSMsg1List.SVC_KEI_UCWK_STAT)) 
			{
				childMap.put("svc_kei_ucwk_stat", "");
				ccMsg.put("svc_kei_ucwk_stat", "");
			} 
			else 
			{
				childMap.put("svc_kei_ucwk_stat", ekk0161a010CBSMsg1List[0].getString(EKK0161A010CBSMsg1List.SVC_KEI_UCWK_STAT));
				ccMsg.put("svc_kei_ucwk_stat", ekk0161a010CBSMsg1List[0].getString(EKK0161A010CBSMsg1List.SVC_KEI_UCWK_STAT));
			}
			
			count++;
		}
		ccMsg.put("EKK0161B002CBSMsg1List", dataList);
		
		
		// 予約レコードがある場合、解約キャンセル処理を行う
		if (0 < count)
		{
			ccMsg.put("plan_chg_flg", "1");
			
			// 作業領域の取得
			Map workMap = (Map)param.getMappingWorkArea();
			
			String mskmDtlNo = (String)workMap.get("mskm_dtl_no");
			String updDtm = (String)workMap.get("upd_dtm");
			
			// 予約レコード分、解約キャンセルを行う
			for(int i = 0; i < dataList.size(); i++)
			{
				HashMap<String, Object> childMap = dataList.get(i);
				
				String svcKeiUcwkStat = (String)childMap.get("svc_kei_ucwk_stat");
				
				// サービス契約内訳ステータスにより処理を分岐する
				// 受付済:010、照査済:020の場合、キャンセル処理を行う
				if("010".equals(svcKeiUcwkStat) || "020".equals(svcKeiUcwkStat))
				{
					// ***** EKK0161C160（サービス契約内訳キャンセル）*****
					Object[][] ekk0161c160IN = {
							{EKK0161C160CBSMsg.TEMPLATEID,          TEMPLATE_ID_EKK0161C160},
							{EKK0161C160CBSMsg.FUNC_CODE,           (String)ccMsg.get("func_code")},
							{EKK0161C160CBSMsg.SVC_KEI_UCWK_NO,     (String)childMap.get("svc_kei_ucwk_no")},
							{EKK0161C160CBSMsg.MSKM_DTL_NO,         mskmDtlNo},
							{EKK0161C160CBSMsg.SVC_CANCEL_RSN_CD,   (String)ccMsg.get("svc_cancel_rsn_cd")},
							{EKK0161C160CBSMsg.IDO_DIV,             (String)ccMsg.get("ido_div")},
							{EKK0161C160CBSMsg.UPD_DTM_BF,          updDtm},
						};
					CAANMsg ekk0161c160OUT = callSC(handle, scCall, param, fixedText, ekk0161c160IN);
					if(ekk0161c160OUT != null)
					{
						updDtm = ekk0161c160OUT.getString(EKK0161C160CBSMsg.UPD_DTM);
					}
				}
				// 締結済:030、サービス提供中:100、休止・中断中:210、停止中:220の場合、解約処理を行う
				else if("030".equals(svcKeiUcwkStat) || "100".equals(svcKeiUcwkStat) || "210".equals(svcKeiUcwkStat) || "220".equals(svcKeiUcwkStat))
				{
					// ***** EKK0161C180（サービス契約内訳解約）*****
					Object[][] ekk0161c180IN = {
							{EKK0161C180CBSMsg.TEMPLATEID,          TEMPLATE_ID_EKK0161C180},
							{EKK0161C180CBSMsg.FUNC_CODE,           (String)ccMsg.get("func_code")},
							{EKK0161C180CBSMsg.SVC_KEI_UCWK_NO,     (String)childMap.get("svc_kei_ucwk_no")},
							{EKK0161C180CBSMsg.MSKM_DTL_NO,         mskmDtlNo},
							{EKK0161C180CBSMsg.RSV_TSTA_KIBO_YMD,   null},
							{EKK0161C180CBSMsg.SVC_ENDYMD,          (String)ccMsg.get("svc_endymd")},
							{EKK0161C180CBSMsg.SVC_CHRG_ENDYMD,     (String)ccMsg.get("svc_chrg_endymd")},
							{EKK0161C180CBSMsg.SVC_DLRE_CD,         (String)ccMsg.get("svc_dlre_cd")},
							{EKK0161C180CBSMsg.SVC_DLRE_MEMO,       null},
							{EKK0161C180CBSMsg.PNLTY_HASSEI_CD,     (String)ccMsg.get("pnlty_hassei_cd")},
							{EKK0161C180CBSMsg.IDO_DIV,             (String)ccMsg.get("ido_div")},
							{EKK0161C180CBSMsg.UPD_DTM_BF,          updDtm},
//							{EKK0161C180CBSMsg.WARN_FLG,            null},
						};
					CAANMsg ekk0161c180OUT = callSC(handle, scCall, param, fixedText, ekk0161c180IN);
					if(ekk0161c180OUT != null)
					{
						updDtm = ekk0161c180OUT.getString(EKK0161C180CBSMsg.UPD_DTM);
					}
					
					// 機能コードが「チェックのみ」の場合は、以降の処理を行わない。
					if ("2".equals(ccMsg.get("func_code")))
					{
						continue;
					}
					
					// ***** EKK0161C190（サービス契約内訳解約確定）*****
					Object[][] ekk0161c190IN = {
							{EKK0161C190CBSMsg.TEMPLATEID,          TEMPLATE_ID_EKK0161C190},
							{EKK0161C190CBSMsg.FUNC_CODE,           (String)ccMsg.get("func_code")},
							{EKK0161C190CBSMsg.SVC_KEI_UCWK_NO,     (String)childMap.get("svc_kei_ucwk_no")},
							{EKK0161C190CBSMsg.SVC_ENDYMD,          (String)ccMsg.get("svc_endymd")},
							{EKK0161C190CBSMsg.SVC_DSL_KISAN_YMD,   (String)ccMsg.get("svc_chrg_endymd")},
							{EKK0161C190CBSMsg.SVC_DLRE_CD,         (String)ccMsg.get("svc_dlre_cd")},
//							【OM-2013-0001808】対応
							{EKK0161C190CBSMsg.PLAN_END_SBT_CD, PLAN_END_SBT_CD_2},
//							【OM-2013-0001808】対応
							{EKK0161C190CBSMsg.SVC_DLRE_MEMO,       null},
							{EKK0161C190CBSMsg.UPD_DTM_BF,          updDtm},
						};
					CAANMsg ekk0161c190OUT = callSC(handle, scCall, param, fixedText, ekk0161c190IN);
					if(ekk0161c190OUT != null)
					{
						updDtm = ekk0161c190OUT.getString(EKK0161C190CBSMsg.UPD_DTM);
					}
				}
			}
			// 更新年月日をワーク領域に退避
			workMap.put("upd_dtm", updDtm);
		}
		else
		{
			ccMsg.put("plan_chg_flg", "");
		}
	
		return param;
	}
	
	/**
	 * サービス契約内訳コース履歴一覧照会ＣＣのチェック処理用サービスインターフェイス作成。<br>
	 * <br>
	 * @param handle セッションマネージャなどを持ったハンドル
	 * @param param モデルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param fixedText ユーザ任意文字列
	 * @return サービスコンポーネント実行用CAANMsg
	 * @exception RequestParameterExceptionがスローされます。
	 */
	@SuppressWarnings("unchecked")
	public  HashMap<String, Object> getInvokeCBS(SessionHandle handle, IRequestParameterReadWrite param, String fixedText)
	throws RequestParameterException
	{
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(fixedText);
		
		HashMap<String, Object> paramMap = new HashMap<String, Object>();
		
		List<CAANMsg> templates = new ArrayList<CAANMsg>();
		
		// 【取得元：電文ヘッダ(ヘッダ)】
		// 電文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));
		
		// ***** EKK0161B002（サービス契約内訳コース履歴一覧照会）*****
		Object[][] ekk0161b002IN = {
				{EKK0161B002CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK0161B002},
				{EKK0161B002CBSMsg.FUNC_CODE,        "1"},
				{EKK0161B002CBSMsg.KEY_SVC_KEI_NO,   (String)ccMsg.get("key_svc_kei_no")},
			};
		templates.add(((CAANMsg[])editInMsg(param, ekk0161b002IN).get(JCMConstants.TEMPLATE_LIST_KEY))[0]);
		
		// チェック用サービスインターフェイス
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates.toArray(new CAANMsg[0]));
		return paramMap;
	}
	
	/**
	 * IRequestParameterReadWriteにエラー情報をマッピングする。<br>
	 * <br>
	 * @param param (I) 業務データ取得・書込用I/F
	 * @param templates (I) CAANMsgクラス配列
	 * @param returnCode (I) リターンコード
	 * @param fixedText (I) ユーザ任意文字列
	 * @return 業務データ取得・書込用I/F
	 * @exception RequestParameterExceptionがスローされます。
	 */
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param, CAANMsg[] templates, int returnCode, String fixedText)
	throws RequestParameterException
	{
		for (int i = 0; i < templates.length; i++)
		{
			editErrorInfoCom(param, templates, returnCode, fixedText);
		}
		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 Throwable
	{
		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);
		int 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 (null == errList)
		{
			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 dataMapKey
	 * @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) throws RequestParameterException
	{
		// 本来はサービスインターフェイス分の処理が必要
		CAANMsg template = templates[0];
		int templateStatus = template.getInt(JCMConstants.STATUS_INT_KEY);

		if (0 != returnCode)
		{
			templateStatus = 9000;
		}

		if (null == JCMAPLConstMgr.getString("RETURN_MESSAGE_" + String.format("%1$04d", templateStatus)))
		{
			templateStatus = 0;
		}

		int bpStatus = 0;
		Object obj = param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if (null == obj)
		{
			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);
		
		Iterator<String> it = inMap.keySet().iterator();
		while (it.hasNext())
		{
			String key = it.next();
			if (key.endsWith("_err"))
			{
				if (!template.isNull(key))
				{
					if (!inMap.containsKey(key))
					{
						inMap.put(key, template.getString(key));
					}
				}
			}
		}
		
		return param;
	}

	/**
	 * 
	 * @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 (0 != returnCode)
		{
			templateStatus = 9000;
		}

		if (null == JCMAPLConstMgr.getString("RETURN_MESSAGE_" + String.format("%1$04d", templateStatus)))
		{
			templateStatus = 0;
		}

		int bpStatus = 0;
		Object obj = param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if (null == obj)
		{
			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;
	}

}
