/*********************************************************************
*	All Right reserved,Copyright (c) Fujitsu, 2011
**********************************************************************
*＜プログラム内容＞
*	システム名		：契約管理
*	モジュール名	：JKKKikiChgTVCC
*	ソースファイル名：JKKKikiChgTVCC.java
*	作成者			：富士通
*	日付			：2012年09月05日
*＜機能概要＞
*	機器変更処理の共通コンポーネント
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v3.00.00	2012/09/05	FJ）		新規作成
*
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;


import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
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.IRequestParameterReadOnly;
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.ECK0011B002CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0161C110CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161C120CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0341A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.ETN0081B030CBSMsg;


/**
 * 機器変更処理を行います。<p>
 * <BR>
 * @author 富士通
 */
public class JKKKikiChgTVCC extends AbstractCommonComponent
{
// IT2-2013-0000139対応 20130210 星野 DEL START
//	/** 引継領域 */
//	private static ThreadLocal<HashMap<String, Object>> ccMap = new ThreadLocal<HashMap<String,Object>>();
//	
	/** マッパー */
	private static JKKKikiChgTVMapperCC mapper = new JKKKikiChgTVMapperCC();
//	
//	/** 引継情報 */
//	private class CCMAP {
//		/** 機器提供サービス契約リスト */
//		private static final String CHG_KIKI_LIST = "chg_kiki_list";
//		/** 申込明細番号 */
//		private static final String MSKM_DTL_NO = "mskm_dtl_no";
//		/** 機能コード */
//		private static final String FUNC_CODE = "func_code";
//	}
//	/** 機器変更情報 */
//	private class CHG_KIKI {
//		/** 機器提供サービス契約番号 */
//		private static final String KKTK_SVC_KEI_NO = "kktk_svc_kei_no";
//		/** 世代登録年月日時分秒 */
//		private static final String GENE_ADD_DTM = "gene_add_dtm";
//		/** 料金コースコード */
//		private static final String PCRS_CD_TV = "pcrs_cd_tv";
//		/** 料金プランコード */
//		private static final String PPLAN_CD_TV = "pplan_cd_tv";
//	}
//	/** 作業領域 */
//	private class WORK {
//		/** 最終更新年月日時分秒 */
//		private static final String LAST_UPD_DTM = "last_upd_dtm";
//	}
// IT2-2013-0000139対応 20130210 星野 DEL END

	
// IT2-2013-0000139対応 20130210 星野 ADD START
	/** テンプレートID(EKK0161C110) サービス契約内訳料金プラン変更 */
	private static final String TEMPLATE_ID_EKK0161C110 = "EKK0161C110";
	/** テンプレートID(EKK0161C120) サービス契約内訳料金プラン変更確定 */
	private static final String TEMPLATE_ID_EKK0161C120 = "EKK0161C120";
	/** 更新年月日時分秒(ワーク領域格納用キー) */
	private static final String UPD_DTM_WORK = "upd_dtm_work";
// IT2-2013-0000139対応 20130210 星野 ADD END

	/**
	 * 
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return IRequestParameterReadWrite
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite chgKikiInfo(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
// IT2-2013-0000139対応 20130210 星野 MOD START
//		// 引継情報をローカルに取り込む
//		if (!init(param, fixedText)) {
//			return param;
//		}
//		
//		// 引継情報の変更対象機器リストを取得し、ループ対象とする
//		List<HashMap<String, Object>> chgKikiList = (List<HashMap<String, Object>>)ccMap.get().get(CCMAP.CHG_KIKI_LIST);
//		for (HashMap<String, Object> chgKikiMap : chgKikiList)
//		{
//			String kktkSvcKeiNo = (String)chgKikiMap.get(CHG_KIKI.KKTK_SVC_KEI_NO);
//			String geneAddStm = (String)chgKikiMap.get(CHG_KIKI.GENE_ADD_DTM);
//			
//			//-------------------------------------------
//			// 機器提供サービス契約一意照会
//			//-------------------------------------------
//			executeEKK0341A010(handle, param, kktkSvcKeiNo, geneAddStm);
//			
//			//-------------------------------------------
//			// サービス契約内訳一意照会
//			//-------------------------------------------
//			executeEKK0161A010(handle, param);
//			
//			// サービス契約内訳の料金コースと引継情報のＴＶコースに差異がある場合はプラン変更を実施する
//			String pcrsCdTv = (String)chgKikiMap.get(CHG_KIKI.PCRS_CD_TV);
//			String pplanCdTv = (String)chgKikiMap.get(CHG_KIKI.PPLAN_CD_TV);
//			if (isExecuteTVPplanChange(pcrsCdTv, getStringKk0161A010(param, EKK0161A010CBSMsg1List.PCRS_CD), pplanCdTv, getStringKk0161A010(param, EKK0161A010CBSMsg1List.PPLAN_CD)))
//			{
//// lot2障害対応 Nao.F START プランはviewから移送
//				//-------------------------------------------
//				// 料金プラン一覧照会
//				//-------------------------------------------
////				executeEKK0591B003(handle, param, pcrsCdTv);
//// lot2障害対応 Nao.F END プランはviewから移送
//				//-------------------------------------------
//				// サービス契約内訳手続中料金プラン変更
//				//-------------------------------------------
//				executeEKK0161C100(handle, param, pcrsCdTv, pplanCdTv);
//			}
//		}
		
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(fixedText);
		
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		// workMapに上りマッピングの更新年月日時分秒を設定する。
		workMap.put(UPD_DTM_WORK, (String)ccMsg.get("upd_dtm_bf"));
		
		// 処理区分
		String funcCd = (String)ccMsg.get("func_code");
		
		
		// 更新対象リスト情報の取得
		ArrayList<HashMap<String, Object>> svc_list = (ArrayList)ccMsg.get("KKSV061201CCList"); 
		HashMap<String, Object> childMap = new HashMap<String, Object>();
		
		
		if(svc_list == null || svc_list.size() == 0 )
		{
			return param;
		}
		
		for(int i = 0; i < svc_list.size(); i++)
		{
			
			childMap = svc_list.get(i);
			
// ST2-2013-0001558対応 20130320 星野 ADD START
			//-------------------------------------------
			// サービス契約内訳一意照会
			//-------------------------------------------
			executeEKK0161A010(handle, param, (String)childMap.get("svc_kei_ucwk_no"));
			
			// サービス契約内訳の料金コースと引継情報のＴＶコースに差異がある場合はプラン変更を実施する
			String pcrsCdTv = (String)childMap.get("pcrs_cd");
			String pplanCdTv = (String)childMap.get("pplan_cd");
			if (isExecuteTVPplanChange(pcrsCdTv, getStringKk0161A010(param, EKK0161A010CBSMsg1List.PCRS_CD), pplanCdTv, getStringKk0161A010(param, EKK0161A010CBSMsg1List.PPLAN_CD)))
			{
// ST2-2013-0001558対応 20130320 星野 ADD END
				
				// サービス契約内訳料金プラン変更
				execEKK0161C110(handle, param, scCall, ccMsg, childMap);
			
// ST2-2013-0001558対応 20130320 星野 DEL START
// 住所変更からのＴＶコース変更では工事完了に合わせてコース変更確定バッチで確定するので、ここでの確定は行わない
//			// 本登録時に実行する
//			if("1".equals(funcCd))
//			{
//				// サービス契約内訳料金プラン変更確定
//				execEKK0161C120(handle, param, scCall, ccMsg, childMap);
//			}
// ST2-2013-0001558対応 20130320 星野 DEL END
			
// ST2-2013-0001558対応 20130320 星野 ADD START
			}
// ST2-2013-0001558対応 20130320 星野 ADD END
		}

// IT2-2013-0000139対応 20130210 星野 MOD END
		return param;
	}
	
// IT2-2013-0000139対応 20130210 星野 DEL START
//	/**
//	 * 機器提供サービス契約一意照会サービスI/F実行
//	 * 
//	 * @param handle
//	 * @param param
//	 * @param kktkSvcKeiNo
//	 * @param geneAddDtm
//	 * @return
//	 * @throws Throwable 
//	 */
//	private void executeEKK0341A010(	SessionHandle handle,
//										IRequestParameterReadWrite param,
//										String kktkSvcKeiNo,
//										String geneAddDtm) throws Throwable
//	{
//		HashMap<String, Object> inMap = new HashMap<String, Object>();
//		param.setData(JKKKikiChgTVMapperCC.TEMPLATE_ID_EKK0341A010, inMap);
//		
//		// 引継データ.機器提供サービス契約番号 → 機器提供サービス契約番号
//		inMap.put(EKK0341A010CBSMsg.KEY_KKTK_SVC_KEI_NO, kktkSvcKeiNo);
//		// 機能コード（固定：1）
//		inMap.put(EKK0341A010CBSMsg.FUNC_CODE, "1");
//		// 引継データ.世代登録年月日時分秒 → ＫＥＹ＿世代登録年月日時分秒
//		inMap.put(EKK0341A010CBSMsg.KEY_GENE_ADD_DTM, geneAddDtm);
//		
//		/* ◇上りマッピング処理 */
//		HashMap<String, Object> paramMap = mapper.editInMsgEKK0341A010(param);
//		/* ◇ＳＣ呼出実行 */
//		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
//		Map<?, ?> result = scCall.run(paramMap, handle);
//		/* ◇下りマッピング処理 */
//		param = mapper.editResultRPEKK0341A010(result, param);
//		checkExecutionResult(result);
//		
//		return;
//	}
//	
	/**
	 * サービス契約内訳一意照会サービスI/F実行
	 * 
	 * @param handle
	 * @param param
	 * @return
	 * @throws Throwable 
	 */
	private void executeEKK0161A010(	SessionHandle handle,
										IRequestParameterReadWrite param, 
										String svcKeiUcwkNo) throws Throwable
	{
		HashMap<String, Object> inMap = new HashMap<String, Object>();
		param.setData(JKKKikiChgTVMapperCC.TEMPLATE_ID_EKK0161A010, inMap);
		
		// 機器提供サービス契約一意照会.サービス契約内訳番号 → サービス契約内訳番号
		inMap.put(EKK0161A010CBSMsg.KEY_SVC_KEI_UCWK_NO, svcKeiUcwkNo);
		// 機能コード（固定：2）
		inMap.put(EKK0161A010CBSMsg.FUNC_CODE, "2");
		// 運用日 → ＫＥＹ＿予約適用年月日
		inMap.put(EKK0161A010CBSMsg.KEY_RSV_APLY_YMD, JCCBPCommon.getOpeDate(null));
		
		/* ◇上りマッピング処理 */
		HashMap<String, Object> paramMap = mapper.editInMsgEKK0161A010(param);
		/* ◇ＳＣ呼出実行 */
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		Map<?, ?> result = scCall.run(paramMap, handle);
		/* ◇下りマッピング処理 */
		param = mapper.editResultRPEKK0161A010(result, param);
		checkExecutionResult(result);
		
//		// 最終更新年月日
//		getWorkMap(param).put(WORK.LAST_UPD_DTM, getStringKk0341A010(param, EKK0341A010CBSMsg1List.LAST_UPD_DTM));
		
		return;
	}
//	
//	/**
//	 * 料金プラン一覧照会サービスI/F実行
//	 * 
//	 * @param handle
//	 * @param param
//	 * @param pcrsCdTv
//	 * @return
//	 * @throws Throwable 
//	 */
//	private void executeEKK0591B003(	SessionHandle handle,
//										IRequestParameterReadWrite param,
//										String pcrsCdTv) throws Throwable
//	{
//		HashMap<String, Object> inMap = new HashMap<String, Object>();
//		param.setData(JKKKikiChgTVMapperCC.TEMPLATE_ID_EKK0591B003, inMap);
//		
//		// 引継データ.料金コースコード → 料金コースコード
//		inMap.put(EKK0591B003CBSMsg.KEY_PCRS_CD, pcrsCdTv);
//		// 機能コード（固定：1）
//		inMap.put(EKK0591B003CBSMsg.FUNC_CODE, "1");
//		
//		/* ◇上りマッピング処理 */
//		HashMap<String, Object> paramMap = mapper.editInMsgEKK0591B003(param);
//		/* ◇ＳＣ呼出実行 */
//		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
//		Map<?, ?> result = scCall.run(paramMap, handle);
//		/* ◇下りマッピング処理 */
//		param = mapper.editResultRPEKK0591B003(result, param);
//		checkExecutionResult(result);
//		
//		return;
//	}
//	
//	/**
//	 * サービス契約内訳手続中料金プラン変更サービスI/F実行
//	 * 
//	 * @param handle
//	 * @param param
//	 * @param pcrsCdTv
//	 * @return
//	 * @throws Throwable 
//	 */
//	private void executeEKK0161C100(	SessionHandle handle,
//										IRequestParameterReadWrite param,
//										String pcrsCdTv,
//										String pplanCdTv) throws Throwable
//	{
//		HashMap<String, Object> inMap = new HashMap<String, Object>();
//		param.setData(JKKKikiChgTVMapperCC.TEMPLATE_ID_EKK0161C100, inMap);
//		
//		// 機器提供サービス契約一意照会.サービス契約内訳番号 → サービス契約内訳番号
//		inMap.put(EKK0161C100CBSMsg.SVC_KEI_UCWK_NO, getStringKk0341A010(param, EKK0341A010CBSMsg1List.SVC_KEI_UCWK_NO));
//		// 引継データ.申込明細番号 → 申込明細番号
//		inMap.put(EKK0161C100CBSMsg.MSKM_DTL_NO, ccMap.get().get(CCMAP.MSKM_DTL_NO));
//		// 引継データ.料金コースコード → 料金コースコード
//		inMap.put(EKK0161C100CBSMsg.PCRS_CD, pcrsCdTv);
//		// 料金プラン一覧照会.料金プランコード → 料金プランコード
//		inMap.put(EKK0161C100CBSMsg.PPLAN_CD, pplanCdTv);
//		// 引継データ.機能コード → 機能コード
//		inMap.put(EKK0161C100CBSMsg.FUNC_CODE, ccMap.get().get(CCMAP.FUNC_CODE));
//		// 最終更新年月日
//		inMap.put(EKK0161C100CBSMsg.UPD_DTM_BF, getWorkMap(param).get(WORK.LAST_UPD_DTM));
//		
//		/* ◇上りマッピング処理 */
//		HashMap<String, Object> paramMap = mapper.editInMsgEKK0161C100(param);
//		/* ◇ＳＣ呼出実行 */
//		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
//		Map<?, ?> result = scCall.run(paramMap, handle);
//		/* ◇下りマッピング処理 */
//		param = mapper.editResultRPEKK0161C100(result, param);
//		checkExecutionResult(result);
//		
//		return;
//	}
//	
	/**
	 * 呼び出したサービスIFの処理結果を判定します。
	 * 
	 * @param result
	 * @throws Throwable
	 */
	private void checkExecutionResult(Map<?, ?> result) throws Throwable
	{
		// 取得したリターンコード、ステータスの内容を見て異常かどうかの判断をする。
		String rtnCode = result.get(JCMConstants.RET_CD_INT_KEY).toString();
		CAANMsg[] templates = (CAANMsg[])result.get(JCMConstants.TEMPLATE_LIST_KEY);
		Integer status = templates[0].getInt(JCMConstants.STATUS_INT_KEY);
		
		// 異常の場合、SCCallExceptionを生成してスローする
		if (!("0".equals(rtnCode) && 0 == status.intValue()))
		{
			SCCallException scCallEx = new SCCallException("戻り値不正", rtnCode, status);
			throw scCallEx;
		}
	}
	
//	/**
//	 * 作業領域取得
//	 * 
//	 * @param param
//	 * @return
//	 * @throws RequestParameterException
//	 */
//	@SuppressWarnings("unchecked")
//	private HashMap<String, Object> getWorkMap(IRequestParameterReadWrite param) throws RequestParameterException
//	{
//		Map workAreaMap = (Map)param.getMappingWorkArea();
//		if (workAreaMap == null) {
//			workAreaMap = new HashMap();
//			param.setMappingWorkArea(workAreaMap);
//		}
//		HashMap<String, Object> workMap = (HashMap<String, Object>)workAreaMap.get("WORK");
//		if (workMap == null) {
//			workMap = new HashMap<String, Object>();
//			workAreaMap.put("WORK", workMap);
//		}
//		return workMap;
//	}
//	
//	/**
//	 * 機器提供サービス契約一意照会の結果取得
//	 * 
//	 * @param param
//	 * @param target
//	 * @return
//	 * @throws RequestParameterException
//	 */
//	@SuppressWarnings("unchecked")
//	private String getStringKk0341A010(IRequestParameterReadOnly param, String target) throws RequestParameterException
//	{
//		// 機器提供サービス契約一意照会の結果取得
//		HashMap<String, Object> ekk0341A010Map = (HashMap<String, Object>)param.getData(JKKKikiChgTVMapperCC.TEMPLATE_ID_EKK0341A010);
//		ArrayList ekk0341A010MapList = (ArrayList)ekk0341A010Map.get(EKK0341A010CBSMsg.EKK0341A010CBSMSG1LIST);
//		ekk0341A010Map = (HashMap<String, Object>)ekk0341A010MapList.get(0);
//		
//		return (String)ekk0341A010Map.get(target);
//	}
//	
	/**
	 * サービス契約内訳一意照会の結果取得
	 * 
	 * @param param
	 * @param target
	 * @return
	 * @throws RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	private String getStringKk0161A010(IRequestParameterReadOnly param, String target) throws RequestParameterException
	{
		// サービス契約内訳一意照会の結果取得
		HashMap<String, Object> ekk0161A010Map = (HashMap<String, Object>)param.getData(JKKKikiChgTVMapperCC.TEMPLATE_ID_EKK0161A010);
		ArrayList ekk0161A010MapList = (ArrayList)ekk0161A010Map.get(EKK0161A010CBSMsg.EKK0161A010CBSMSG1LIST);
		ekk0161A010Map = (HashMap<String, Object>)ekk0161A010MapList.get(0);
		
		return (String)ekk0161A010Map.get(target);
	}
	
//	/**
//	 * 料金プラン一覧照会の結果取得
//	 * 
//	 * @param param
//	 * @param target
//	 * @return
//	 * @throws RequestParameterException
//	 */
//	@SuppressWarnings("unchecked")
//	private String getStringKK0591B003(IRequestParameterReadOnly param, String target) throws RequestParameterException
//	{
//		// 機器提供サービス契約一意照会の結果取得
//		HashMap<String, Object> ekk0591B003Map = (HashMap<String, Object>)param.getData(JKKKikiChgTVMapperCC.TEMPLATE_ID_EKK0591B003);
//		ArrayList ekk0591B003MapMapList = (ArrayList)ekk0591B003Map.get(EKK0591B003CBSMsg.EKK0591B003CBSMSG1LIST);
//		ekk0591B003Map = (HashMap<String, Object>)ekk0591B003MapMapList.get(0);
//		
//		return (String)ekk0591B003Map.get(target);
//	}
//	
	/**
	 * TVコース変更実施判定
	 * 差異がある場合はtrue、同じ場合はfalse
	 * 
	 * @param pcrsCdTv
	 * @param pcrsCd
	 * @return
	 */
	private boolean isExecuteTVPplanChange(String pcrsCdTv, String pcrsCd, String pplanCdTv, String pplanCd)
	{
		// 値が設定されていて、差異がある場合
		if ((pcrsCdTv != null && pcrsCd != null && !pcrsCdTv.equals(pcrsCd))
				|| (pplanCdTv != null && pplanCd != null && !pplanCdTv.equals(pplanCd)))
		{
			return true;
		}
		return false;
	}
	
//	/**
//	 * マップデータをローカル領域に保存
//	 * 
//	 * @param param
//	 * @param fixedText
//	 * @return
//	 * @throws RequestParameterException 
//	 */
//	@SuppressWarnings("unchecked")
//	private boolean init(IRequestParameterReadWrite param, String fixedText) throws RequestParameterException
//	{
//		HashMap<String, Object> inMap = (HashMap<String, Object>)param.getData(fixedText);
//		if (inMap == null) {
//			return false;
//		}
//		ccMap.set(inMap);
//		return true;
//	}
// IT2-2013-0000139対応 20130210 星野 DEL END
	
	/**
	 * 機器変更チェック処理.
	 * <br>
	 * @param   handle     セッションマネージャなどを持ったハンドル情報
	 * @param   param      モデルグループ、コントロールマップを含むリクエストパラメータ
	 * @param   fixedText  ユーザ任意文字列
	 * @throws  Exception  例外が発生した場合
	 * @return  リクエストパラメータ(param)に戻り値を追加して返却する
	 */
	public HashMap<String, Object> getInvokeCBS(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Exception
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, new CAANMsg[0]);
		return paramMap;
	}
	
	
	/**
	 * サービスインターフェイス処理結果(エラー情報)の取得<br>
	 * 業務データ取得・書込用I/Fをそのまま返却します。<br>
	 * <br>
	 * 
	 * @param param モデルグループ、コントロールマップを含むリクエストパラメータ
	 * @param templates CAANMsgクラス配列
	 * @param returnCode リターンコード
	 * @return 業務データ取得・書込用I/F
	 * @throws Throwable
	 */
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param, CAANMsg[] templates, Integer returnCode) throws Throwable
	{
		return param;
	}

// IT2-2013-0000139対応 20130210 星野 ADD START
	/**
	 * サービス契約内訳料金プラン変更サービスを実行し値を取得します。
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param scCall 
	 * @param dataMap リクエストデータ
	 * @throws Exception 
	 */
	private void execEKK0161C110(SessionHandle handle,
									IRequestParameterReadWrite param,
									ServiceComponentRequestInvoker scCall,
									Map<String, Object> dataMap,
									HashMap<String, Object> childMap) throws Exception
	{
		
		// ◇ 上りマッピング処理
		// リクエストパラメータを引数に上りマッピング処理メソッドを実行
		HashMap<String, Object> paramMap = editInMsg_EKK0161C110(param, dataMap, childMap);
		
		// ◇ SC呼出実行 (サービス契約一意照会)
		Map<?, ?> result = scCall.run(paramMap, handle);
		
		editOutMsg_EKK0161C110(result, param, dataMap, childMap);
		
		//処理結果判定
		jdgErrRslt(result, 0);
	}
	
	/**
	 * サービス契約内訳料金プラン変更のメッセージを作成します。
	 * 
	 * @param param
	 * @param inMap
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	private HashMap<String, Object> editInMsg_EKK0161C110(IRequestParameterReadWrite param,
																Map<String, Object> dataMap,
																HashMap<String, Object> childMap) throws RequestParameterException
	{
		
		// 共通領域の設定
		HashMap<String, Object> paramMap = editInMsg(param);

		CAANMsg template = new CAANMsg(EKK0161C110CBSMsg.class.getName());

		// テンプレートID
		template.set(EKK0161C110CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0161C110);

		template.set(EKK0161C110CBSMsg.FUNC_CODE, "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);

		CAANMsg[] templateArray = null;
		HashMap inMap = null;
		ArrayList inList = null;
		
		// 作業領域の取得
		Map<Object, Object> workMap = param.getMappingWorkArea();
		
		
		ArrayList<HashMap<String,String>> meisaiList = (ArrayList<HashMap<String,String>>)dataMap.get("EKK0011D020WORKLIST");

		if(meisaiList == null || meisaiList.size() == 0)
		{
			template.setNull(EKK0161C110CBSMsg.MSKM_DTL_NO);
			
		}else{
			
			
			HashMap reMap = (HashMap)meisaiList.get(0);
			String meisai = (String)reMap.get("ekk0011d020_mskm_dtl_no_work");
			
			// 作業項目.申込明細番号 → 申込明細番号
			if (meisai == null || "".equals(meisai)) {
				template.setNull(EKK0161C110CBSMsg.MSKM_DTL_NO);
			} else {
				template.set(EKK0161C110CBSMsg.MSKM_DTL_NO, meisai);
			}
		}
		
		
		// 機能コード
		template.set(EKK0161C110CBSMsg.FUNC_CODE, dataMap.get(JCMConstants.FUNC_CODE_KEY));
		

		if ("".equals(workMap.get(UPD_DTM_WORK))) {
			template.setNull(EKK0161C110CBSMsg.UPD_DTM_BF);
		} else {
			template.set(EKK0161C110CBSMsg.UPD_DTM_BF, (String) workMap.get(UPD_DTM_WORK));
		}
		
		// eo光テレビコース変更CCマップ.サービス契約内訳番号 → サービス契約内訳番号
		if ("".equals(childMap.get("svc_kei_ucwk_no"))) {
			template.setNull(EKK0161C110CBSMsg.SVC_KEI_UCWK_NO);
		} else {
			template.set(EKK0161C110CBSMsg.SVC_KEI_UCWK_NO, (String) childMap.get("svc_kei_ucwk_no"));
		}

		// eo光テレビコース変更CCマップ.料金コースコード → 料金コースコード
		if ("".equals(childMap.get("pcrs_cd"))) {
			template.setNull(EKK0161C110CBSMsg.PCRS_CD);
		} else {
			template.set(EKK0161C110CBSMsg.PCRS_CD, (String) childMap.get("pcrs_cd"));
		}

		// eo光テレビコース変更CCマップ.料金プランコード → 料金プランコード
		if ("".equals(childMap.get("pplan_cd"))) {
			template.setNull(EKK0161C110CBSMsg.PPLAN_CD);
		} else {
			template.set(EKK0161C110CBSMsg.PPLAN_CD, (String) childMap.get("pplan_cd"));
		}

		// eo光テレビコース変更CCマップ.提供方式契約番号 → 提供方式契約番号
		if ("".equals(childMap.get("tk_hoshiki_kei_no"))) {
			template.setNull(EKK0161C110CBSMsg.TK_HOSHIKI_KEI_NO);
		} else {
			template.set(EKK0161C110CBSMsg.TK_HOSHIKI_KEI_NO, (String) childMap.get("tk_hoshiki_kei_no"));
		}

		// eo光テレビコース変更CCマップ.予約適用年月日 → 予約適用年月日
		if ("".equals(childMap.get("rsv_aply_ymd"))) {
			template.setNull(EKK0161C110CBSMsg.RSV_APLY_YMD);
		} else {
			template.set(EKK0161C110CBSMsg.RSV_APLY_YMD, (String) childMap.get("rsv_aply_ymd"));
		}

		// eo光テレビコース変更CCマップ.違約金発生コード → 違約金発生コード
		if ("".equals(childMap.get("pnlty_hassei_cd"))) {
			template.setNull(EKK0161C110CBSMsg.PNLTY_HASSEI_CD);
		} else {
			template.set(EKK0161C110CBSMsg.PNLTY_HASSEI_CD, (String) childMap.get("pnlty_hassei_cd"));
		}

		// eo光テレビコース変更CCマップ.異動区分 → 異動区分
		if ("".equals(dataMap.get("ido_div"))) {
			template.setNull(EKK0161C110CBSMsg.IDO_DIV);
		} else {
			template.set(EKK0161C110CBSMsg.IDO_DIV, (String) dataMap.get("ido_div"));
		}

		// eo光テレビコース変更CCマップ.プラン課金開始年月日 → プラン課金開始年月日
		if ("".equals(childMap.get("kakin_sta_ymd"))) {
			template.setNull(EKK0161C110CBSMsg.PLAN_CHRG_STAYMD);
		} else {
			template.set(EKK0161C110CBSMsg.PLAN_CHRG_STAYMD, (String) childMap.get("kakin_sta_ymd"));
		}

		// eo光テレビコース変更CCマップ.プラン課金終了年月日 → プラン課金終了年月日
		if ("".equals(childMap.get("plan_chrg_endymd"))) {
			template.setNull(EKK0161C110CBSMsg.PLAN_CHRG_ENDYMD);
		} else {
			template.set(EKK0161C110CBSMsg.PLAN_CHRG_ENDYMD, (String) childMap.get("plan_chrg_endymd"));
		}

		// eo光テレビコース変更CCマップ.コース変更時期 → 即時/翌月
		if ("".equals(childMap.get("crs_chg_jiki"))) {
			template.setNull(EKK0161C110CBSMsg.SKJ_YKGT);
		} else {
			template.set(EKK0161C110CBSMsg.SKJ_YKGT, (String) childMap.get("crs_chg_jiki"));
		}
		
		
		
		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 msgList (I) CAANMsgクラス 
	 * @param param (I) 業務データ取得・書込用I/F
	 * @return 業務データ取得・書込用I/F
	 * @since 2011.11.25
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite editOutMsg_EKK0161C110(Map<?, ?> msgList,
			IRequestParameterReadWrite param,
			Map<String, Object> dataMap,
			HashMap<String, Object> childMap) throws Exception {

		// 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);
		}
		
		
		if (parentTemplate.isNull(EKK0161C110CBSMsg.UPD_DTM)) {
			workMap.put(UPD_DTM_WORK, new String());
		} else {
			workMap.put(UPD_DTM_WORK, parentTemplate.getString(EKK0161C110CBSMsg.UPD_DTM));
		}
		
		// エラー情報の設定
        param = editErrorInfo_EKK0161C110(param, dataMap, templates, (Integer)return_code, childMap);

		//エラー情報のマップを取得
		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;
	}
	
	/**
	 * サービス契約内訳料金プラン変更エラー処理メソッド
	 * @param param
	 * @param inMap
	 * @param templates
	 * @param returnCode
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException
	 */
	private IRequestParameterReadWrite editErrorInfo_EKK0161C110(IRequestParameterReadWrite param, 
																	Map<String, Object> inMap,
																	CAANMsg[] templates,
																	int returnCode,
																	HashMap<String, Object> childMap) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(EKK0161C110CBSMsg.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);
		}

		// サービス契約内訳番号
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.SVC_KEI_UCWK_NO_ERR);
		// 料金コースコード
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.PCRS_CD_ERR);
		// 料金プランコード
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.PPLAN_CD_ERR);
		// 提供方式契約番号
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.TK_HOSHIKI_KEI_NO_ERR);
		// 予約適用年月日
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.RSV_APLY_YMD_ERR);
		// 違約金発生コード
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.PNLTY_HASSEI_CD_ERR);
		// 異動区分
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.IDO_DIV_ERR);
		// 更新年月日時分秒
		setErrDataMap(inMap, template, EKK0161C110CBSMsg.UPD_DTM_BF_ERR);
		
		
		return param;
	}
	
	/**
	 * サービス契約内訳料金プラン変更確定サービスを実行し値を取得します。
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param scCall 
	 * @param dataMap リクエストデータ
	 * @throws Exception 
	 */
	private void execEKK0161C120(SessionHandle handle,
									IRequestParameterReadWrite param,
									ServiceComponentRequestInvoker scCall,
									Map<String, Object> dataMap,
									HashMap<String, Object> childMap) throws Exception
	{
		
		// ◇ 上りマッピング処理
		// リクエストパラメータを引数に上りマッピング処理メソッドを実行
		HashMap<String, Object> paramMap = editInMsg_EKK0161C120(param, dataMap, childMap);
		
		// ◇ SC呼出実行 (サービス契約一意照会)
		Map<?, ?> result = scCall.run(paramMap, handle);
		
		editOutMsg_EKK0161C120(result, param, dataMap, childMap);
		
		//処理結果判定
		jdgErrRslt(result, 0);
	}
	
	/**
	 * サービス契約内訳料金プラン変更確定のメッセージを作成します。
	 * 
	 * @param param
	 * @param inMap
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	private HashMap<String, Object> editInMsg_EKK0161C120(IRequestParameterReadWrite param,
																Map<String, Object> dataMap,
																HashMap<String, Object> childMap) throws RequestParameterException
	{
		
		// 共通領域の設定
		HashMap<String, Object> paramMap = editInMsg(param);

		CAANMsg template = new CAANMsg(EKK0161C120CBSMsg.class.getName());

		// テンプレートID
		template.set(EKK0161C120CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0161C120);

		template.set(EKK0161C120CBSMsg.FUNC_CODE, "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);

		CAANMsg[] templateArray = null;
		HashMap inMap = null;
		ArrayList inList = null;
		
		// 作業領域の取得
		Map<Object, Object> workMap = param.getMappingWorkArea();
		
		// 作業項目.更新年月日時分秒 → 更新年月日時分秒(更新前)
		if (workMap.get(UPD_DTM_WORK) == null || "".equals(workMap.get(UPD_DTM_WORK))) {
			template.setNull(EKK0161C120CBSMsg.UPD_DTM_BF);
		} else {
			template.set(EKK0161C120CBSMsg.UPD_DTM_BF, workMap.get(UPD_DTM_WORK));
		}
		
		// 機能コード
		template.set(EKK0161C120CBSMsg.FUNC_CODE, dataMap.get(JCMConstants.FUNC_CODE_KEY));

		// eo光テレビコース変更CCマップ.サービス契約内訳番号 → サービス契約内訳番号
		if ("".equals(childMap.get("svc_kei_ucwk_no"))) {
			template.setNull(EKK0161C120CBSMsg.SVC_KEI_UCWK_NO);
		} else {
			template.set(EKK0161C120CBSMsg.SVC_KEI_UCWK_NO, (String) childMap.get("svc_kei_ucwk_no"));
		}

		// eo光テレビコース変更CCマップ.予約適用年月日 → 予約適用年月日
		if ("".equals(childMap.get("rsv_aply_ymd"))) {
			template.setNull(EKK0161C120CBSMsg.RSV_APLY_YMD);
		} else {
			template.set(EKK0161C120CBSMsg.RSV_APLY_YMD, (String) childMap.get("rsv_aply_ymd"));
		}

		// eo光テレビコース変更CCマップ.機器出荷有無 → 機器出荷有無
		if ("".equals(childMap.get("kkshka_um"))) {
			template.setNull(EKK0161C120CBSMsg.KKSHKA_UM);
		} else {
			template.set(EKK0161C120CBSMsg.KKSHKA_UM, (String) childMap.get("kkshka_um"));
		}

		// eo光テレビコース変更CCマップ.工事有無 → 工事有無
		if ("".equals(childMap.get("koji_um"))) {
			template.setNull(EKK0161C120CBSMsg.KOJI_UM);
		} else {
			template.set(EKK0161C120CBSMsg.KOJI_UM, (String) childMap.get("koji_um"));
		}

		// eo光テレビコース変更CCマップ.プラン課金開始年月日 → プラン課金開始年月日
		if ("".equals(childMap.get("kakin_sta_ymd"))) {
			template.setNull(EKK0161C120CBSMsg.PLAN_CHRG_STAYMD);
		} else {
			template.set(EKK0161C120CBSMsg.PLAN_CHRG_STAYMD, (String) childMap.get("kakin_sta_ymd"));
		}

		// eo光テレビコース変更CCマップ.プラン課金終了年月日 → プラン課金終了年月日
		if ("".equals(childMap.get("plan_chrg_endymd"))) {
			template.setNull(EKK0161C120CBSMsg.PLAN_CHRG_ENDYMD);
		} else {
			template.set(EKK0161C120CBSMsg.PLAN_CHRG_ENDYMD, (String) childMap.get("plan_chrg_endymd"));
		}

		// eo光テレビコース変更CCマップ.コース変更時期 → 即時/翌月
		if ("".equals(childMap.get("crs_chg_jiki"))) {
			template.setNull(EKK0161C120CBSMsg.SKJ_YKGT);
		} else {
			template.set(EKK0161C120CBSMsg.SKJ_YKGT, (String) childMap.get("crs_chg_jiki"));
		}
		
		
		
		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 msgList (I) CAANMsgクラス 
	 * @param param (I) 業務データ取得・書込用I/F
	 * @return 業務データ取得・書込用I/F
	 * @since 2011.11.25
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite editOutMsg_EKK0161C120(Map<?, ?> msgList,
			IRequestParameterReadWrite param,
			Map<String, Object> dataMap,
			HashMap<String, Object> childMap) throws Exception {

		// 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);
		}
		
		if (parentTemplate.isNull(EKK0161C120CBSMsg.UPD_DTM)) {
			workMap.put(UPD_DTM_WORK, new String());
		} else {
			workMap.put(UPD_DTM_WORK, parentTemplate.getString(EKK0161C120CBSMsg.UPD_DTM));
		}
		
		// エラー情報の設定
        param = editErrorInfo_EKK0161C120(param, dataMap, templates, (Integer)return_code, childMap);

		//エラー情報のマップを取得
		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;
	}
	
	/**
	 * サービス契約内訳料金プラン変更確定エラー処理メソッド
	 * @param param
	 * @param inMap
	 * @param templates
	 * @param returnCode
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException
	 */
	private IRequestParameterReadWrite editErrorInfo_EKK0161C120(IRequestParameterReadWrite param, 
																	Map<String, Object> inMap,
																	CAANMsg[] templates,
																	int returnCode,
																	HashMap<String, Object> childMap) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(EKK0161C120CBSMsg.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);
		}

		// サービス契約内訳番号
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.SVC_KEI_UCWK_NO_ERR);
		// 予約適用年月日
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.RSV_APLY_YMD_ERR);
		// 機器出荷有無
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.KKSHKA_UM_ERR);
		// 工事有無
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.KOJI_UM_ERR);
		// プラン課金終了年月日
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.PLAN_CHRG_ENDYMD_ERR);
		// 即時/翌月
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.SKJ_YKGT_ERR);
		
		return param;
	}
	
	/**
	 * 共通項目の設定
	 * @param param
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	private HashMap<String, Object> editInMsg(IRequestParameterReadWrite param) 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));

		return paramMap;
	}
	
	/**
	 * IFの戻り値を判定し、結果が異常の場合、SCCallExceptionを発生させます。
	 * @param result CAANMsgクラス
	 * @param cnt CAANMsgの対象位置
	 * @throws Exception
	 */
	private void jdgErrRslt(Map<?, ?> result, int cnt) throws Exception
	{
		CAANMsg[] templates = (CAANMsg[])result.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg msg = templates[cnt];

		// 取得したリターンコード、ステータスの内容を見て異常かどうかの判断をする。
		String rtnCode = result.get(JCMConstants.RET_CD_INT_KEY).toString();
		Integer status = msg.getInt(JCMConstants.STATUS_INT_KEY);
		Integer zero = 0;

		// 異常の場合、SCCallExceptionを生成してスローする
		if(!("0".equals(rtnCode) && zero.equals(status)))
		{
			SCCallException scCallEx = new SCCallException("戻り値不正", rtnCode, status);
			throw scCallEx;
		}
	}
	
	/**
	 * Mapにエラーデータを格納します。
	 * @param inMap データ格納Map
	 * @param template CAANMsgクラス
	 * @param mapKey 取得と格納するキー
	 */
	private void setErrDataMap(Map<String, Object> inMap, CAANMsg template, String mapKey)
	{
		if(!template.isNull(mapKey))
		{
			if(!inMap.containsKey(mapKey))
			{
				inMap.put(mapKey, template.getString(mapKey));
			}
		}
	}
	
	/**
	 * 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,
							CAANMsg inCAANMsg) throws Exception
	{
		HashMap<String, Object> paramMap = editInMsg(param, inCAANMsg);
		
		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 = templates[0].getInt(ETN0081B030CBSMsg.STATUS);

		editErrorInfoCom(param, templates, (Integer)return_code, dataMapKey);
		
		//エラー情報のマップを取得
		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,
											   CAANMsg msg) 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));
		
		// オペレータID
		msg.set(JCMConstants.OPERATOR_ID_KEY, param.getControlMapData(SCControlMapKeys.OPERATOR_ID));
		// 運用日付
		msg.set(JCMConstants.OPERATE_DATE_KEY, param.getControlMapData(SCControlMapKeys.OPE_DATE));
		// 運用日時
		msg.set(JCMConstants.OPERATE_DATETIME_KEY, param.getControlMapData(SCControlMapKeys.OPE_TIME));
		
		setNullToMsg(msg);
		
		CAANMsg[] templates = new CAANMsg[]{msg};
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);
		return paramMap;
	}
	
	@SuppressWarnings("unchecked")
	private void setNullToMsg(CAANMsg msg)
	{
		Iterator<String> caanMsgKeys = msg.getSchema().getSchemaKeySet().iterator();
		while (caanMsgKeys.hasNext())
		{
			String key = caanMsgKeys.next();
			if (key.endsWith("_err"))
			{
				String tmpKey = key.substring(0, key.length() - 4);
				
				if (!msg.containsKeyOfMsgData(tmpKey) || "".equals(msg.getObject(tmpKey)))
				{
					msg.setNull(tmpKey);
					continue;
				}
				Object obj = msg.getObject(tmpKey);
				if (obj instanceof CAANMsg[])
				{
					for (CAANMsg submsg : (CAANMsg[]) obj)
					{
						setNullToMsg(submsg);
					}
				}
			}
		}
	}

	/**
	 * 処理概要:
	 * サービスコンポーネント実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * 
	 * @param param 業務データ取得・書込用I/F
	 * @param templates CAANMsgクラス配列
	 * @param returnCode リターンコード
	 * @param dataMapKey データキー
	 * @return IRequestParameterReadWrite 業務データ取得・書込用I/F
	 * @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(ECK0011B002CBSMsg.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<String, String> inMap = null;

		// ユーザデータ情報
		inMap = (HashMap<String, String>)param.getData(dataMapKey);
		
		Iterator<String> it = template.getHashMap().keySet().iterator();
		while (it.hasNext())
		{
			String key = it.next();
			if (key.endsWith("_err"))
			{
				if (!template.isNull(key))
				{
					inMap.put(key, template.getString(key));
				}
			}
		}
		
		return param;
	}
// IT2-2013-0000139対応 20130210 星野 ADD END
}
