/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKTvCourseChoiceUpdCC
*	ソースファイル名：JKKTvCourseChoiceUpdCC.java
*	作成者			：FJ
*	日付			：2012年10月16日
*＜機能概要＞
*	eo光TVコース選択情報変更の共通コンポーネント
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v4.00.00	2012/10/16	FJ			新規作成
*   v6.00.00	2013/12/16	FJ)宇野	   【ANK-1672-00-00】対応
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
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.ejb.cbs.cbsmsg.EKK0161C110CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161C120CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg1List;

/**
 * eo光テレビ コース変更処理を行います。<p>
 * <BR>
 * @author 富士通
 */
public class JKKTvCourseChoiceUpdCC extends AbstractCommonComponent
{
	
	/** テンプレートID(EKK0161C110) サービス契約内訳料金プラン変更 */
	private static final String TEMPLATE_ID_EKK0161C110 = "EKK0161C110";
	/** テンプレートID(EKK0161C120) サービス契約内訳料金プラン変更確定 */
	private static final String TEMPLATE_ID_EKK0161C120 = "EKK0161C120";
	/** テンプレートID(EKK1091D010) 進捗登録 */
	private static final String TEMPLATE_ID_EKK1091D010 = "EKK1091D010";
	
	/**
	 * 
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return IRequestParameterReadWrite
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite execCrsChg(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
		
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(fixedText);
		
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		// 処理区分
		String funcCd = (String)ccMsg.get("func_code");
		
		// 機能コードが「チェックのみ」の場合は、処理を行わない。
		if ("2".equals(funcCd))
		{
			return param;
		}
		
		// 更新対象リスト情報の取得
		ArrayList<HashMap<String, Object>> svc_list = (ArrayList)ccMsg.get("KKSV031106CCList"); 
		HashMap<String, Object> childMap = new HashMap<String, Object>();
		
		if(svc_list == null || svc_list.size() == 0)
		{
			return param;
		}
		
// +++++++++++ v6.00.00修正開始 ++++++++++++++
		boolean kojiChk = false;
// +++++++++++ v6.00.00修正終了 ++++++++++++++
		for(int i = 0; i < svc_list.size(); i++)
		{
			childMap = svc_list.get(i);
			
			// サービス契約内訳料金プラン変更
			execEKK0161C110(handle, param, scCall, ccMsg, childMap);
// +++++++++++ v6.00.00修正開始 ++++++++++++++
			if( "0".equals(childMap.get("koji_um")))
			{
				kojiChk = true;
			}
			
			// 予約適用年月日が最大日付でない場合（工事が発生しない場合）
			if (!"20991231".equals(ccMsg.get("rsv_aply_ymd")) && kojiChk)
			{
// +++++++++++ v6.00.00修正終了 ++++++++++++++	
				// サービス契約内訳料金プラン変更確定
				execEKK0161C120(handle, param, scCall, ccMsg, childMap);
			}
			
			// 進捗登録
			execEKK1091D010(handle, param, scCall, ccMsg, childMap);
		}
		
		return param;
	}
	
	/**
	 * サービス契約内訳料金プラン変更サービスを実行し値を取得します。
	 * @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
	 */
	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);
		
		
		// 作業領域の取得
		Map<Object, Object> workMap = param.getMappingWorkArea();
		
		// WORK.申込明細番号 → 申込明細番号
		template.set(EKK0161C110CBSMsg.MSKM_DTL_NO, workMap.get("mskm_dtl_no"));
		
		// WORK.更新年月日時分秒 → 更新年月日時分秒(更新前)
		template.set(EKK0161C110CBSMsg.UPD_DTM_BF, workMap.get("work_upd_dtm"));
		
		
		// 機能コード
		template.set(EKK0161C110CBSMsg.FUNC_CODE, dataMap.get(JCMConstants.FUNC_CODE_KEY));

		// eo光TVコース選択情報変更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光TVコース選択情報変更CCマップ.料金コースコード → 料金コースコード
		if ("".equals(childMap.get("pcrs_cd"))) {
			template.setNull(EKK0161C110CBSMsg.PCRS_CD);
		} else {
			template.set(EKK0161C110CBSMsg.PCRS_CD, (String) childMap.get("pcrs_cd"));
		}

		// eo光TVコース選択情報変更CCマップ.料金プランコード → 料金プランコード
		if ("".equals(childMap.get("pplan_cd"))) {
			template.setNull(EKK0161C110CBSMsg.PPLAN_CD);
		} else {
			template.set(EKK0161C110CBSMsg.PPLAN_CD, (String) childMap.get("pplan_cd"));
		}

		// eo光TVコース選択情報変更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光TVコース選択情報変更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光TVコース選択情報変更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光TVコース選択情報変更CCマップ.異動区分 → 異動区分
		if ("".equals(dataMap.get("ido_div"))) {
			template.setNull(EKK0161C110CBSMsg.IDO_DIV);
		} else {
			template.set(EKK0161C110CBSMsg.IDO_DIV, (String) dataMap.get("ido_div"));
		}

		// eo光TVコース選択情報変更CCマップ.プラン課金開始年月日 → プラン課金開始年月日
		if ("".equals(childMap.get("plan_chrg_staymd"))) {
			template.setNull(EKK0161C110CBSMsg.PLAN_CHRG_STAYMD);
		} else {
			template.set(EKK0161C110CBSMsg.PLAN_CHRG_STAYMD, (String) childMap.get("plan_chrg_staymd"));
		}

		// eo光TVコース選択情報変更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光TVコース選択情報変更CCマップ.工事有無 → 工事有無
		if ("".equals(childMap.get("koji_um"))) {
			template.setNull(EKK0161C110CBSMsg.KOJI_UM);
		} else {
			template.set(EKK0161C110CBSMsg.KOJI_UM, (String) childMap.get("koji_um"));
		}

		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
	 */
	@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];

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		
		// WORK.更新年月日時分秒 ← 更新年月日時分秒
		if (parentTemplate.isNull(EKK0161C110CBSMsg.UPD_DTM)) {
			workMap.put("work_upd_dtm", new String());
		} else {
			workMap.put("work_upd_dtm", 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);
		// プラン課金開始年月日
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.PLAN_CHRG_STAYMD_ERR);
		// プラン課金終了年月日
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.PLAN_CHRG_ENDYMD_ERR);
		// 工事有無
		setErrDataMap(childMap, template, EKK0161C110CBSMsg.KOJI_UM_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
	 */
	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);
		
		
		// 作業領域の取得
		Map<Object, Object> workMap = param.getMappingWorkArea();
		
		// WORK.更新年月日時分秒 → 更新年月日時分秒(更新前)
		template.set(EKK0161C120CBSMsg.UPD_DTM_BF, workMap.get("work_upd_dtm"));
		
		
		// 機能コード
		template.set(EKK0161C120CBSMsg.FUNC_CODE, dataMap.get(JCMConstants.FUNC_CODE_KEY));

		// eo光TVコース選択情報変更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光TVコース選択情報変更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光TVコース選択情報変更CCマップ.プラン課金開始年月日 → プラン課金開始年月日
		if ("".equals(childMap.get("plan_chrg_staymd"))) {
			template.setNull(EKK0161C120CBSMsg.PLAN_CHRG_STAYMD);
		} else {
			template.set(EKK0161C120CBSMsg.PLAN_CHRG_STAYMD, (String) childMap.get("plan_chrg_staymd"));
		}

		// 機器出荷有無("0":無)
		template.set(EKK0161C120CBSMsg.KKSHKA_UM, "0");

		// eo光TVコース選択情報変更CCマップ.工事有無 → 工事有無
		if ("".equals(childMap.get("koji_um"))) {
			template.setNull(EKK0161C120CBSMsg.KOJI_UM);
		} else {
			template.set(EKK0161C120CBSMsg.KOJI_UM, (String) childMap.get("koji_um"));
		}

		// eo光TVコース選択情報変更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"));
		}

		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
	 */
	@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];

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		
		// WORK.更新年月日時分秒 ← 更新年月日時分秒
		if (parentTemplate.isNull(EKK0161C120CBSMsg.UPD_DTM)) {
			workMap.put("work_upd_dtm", new String());
		} else {
			workMap.put("work_upd_dtm", 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.PLAN_CHRG_STAYMD_ERR);
		// 更新年月日時分秒
		setErrDataMap(inMap, template, EKK0161C120CBSMsg.UPD_DTM_BF_ERR);
		// 機器出荷有無
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.KKSHKA_UM_ERR);
		// 工事有無
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.KOJI_UM_ERR);
		// プラン課金終了年月日
		setErrDataMap(childMap, template, EKK0161C120CBSMsg.PLAN_CHRG_ENDYMD_ERR);
		
		
		return param;
	}
	
	/**
	 * 進捗登録サービスを実行し値を取得します。
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param scCall 
	 * @param dataMap リクエストデータ
	 * @throws Exception 
	 */
	private void execEKK1091D010(SessionHandle handle,
									IRequestParameterReadWrite param,
									ServiceComponentRequestInvoker scCall,
									Map<String, Object> dataMap,
									HashMap<String, Object> childMap) throws Exception
	{
		
		// ◇ 上りマッピング処理
		// リクエストパラメータを引数に上りマッピング処理メソッドを実行
		HashMap<String, Object> paramMap = editInMsg_EKK1091D010(param, dataMap, childMap);
		
		// ◇ SC呼出実行 (進捗登録)
		Map<?, ?> result = scCall.run(paramMap, handle);
		
		editOutMsg_EKK1091D010(result, param, dataMap, childMap);
		
		//処理結果判定
		jdgErrRslt(result, 0);
	}
	
	/**
	 * 進捗登録のメッセージを作成します。
	 * 
	 * @param param
	 * @param inMap
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	private HashMap<String, Object> editInMsg_EKK1091D010(IRequestParameterReadWrite param,
																Map<String, Object> dataMap,
																HashMap<String, Object> childMap) throws RequestParameterException
	{
		
		// 共通領域の設定
		HashMap<String, Object> paramMap = editInMsg(param);

		CAANMsg template = new CAANMsg(EKK1091D010CBSMsg.class.getName());

		// テンプレートID
		template.set(EKK1091D010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK1091D010);

		template.set(EKK1091D010CBSMsg.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;
		ArrayList inList = null;
		
		// 作業領域の取得
		Map<Object, Object> workMap = param.getMappingWorkArea();
		
		// WORK.申込明細番号 → 申込明細番号
		template.set(EKK1091D010CBSMsg.MSKM_DTL_NO, workMap.get("mskm_dtl_no"));
		
		
		// 機能コード
		template.set(EKK1091D010CBSMsg.FUNC_CODE, dataMap.get(JCMConstants.FUNC_CODE_KEY));

		// 進捗登録マップ.請求契約番号 → 請求契約番号
		if ("".equals(childMap.get("seiky_kei_no"))) {
			template.setNull(EKK1091D010CBSMsg.SEIKY_KEI_NO);
		} else {
			template.set(EKK1091D010CBSMsg.SEIKY_KEI_NO, (String) childMap.get("seiky_kei_no"));
		}

		// 進捗登録マップ.請求方法番号（口座） → 請求方法番号(口座)
		if ("".equals(childMap.get("seiky_way_no_koza"))) {
			template.setNull(EKK1091D010CBSMsg.SEIKY_WAY_NO_KOZA);
		} else {
			template.set(EKK1091D010CBSMsg.SEIKY_WAY_NO_KOZA, (String) childMap.get("seiky_way_no_koza"));
		}

		// 進捗登録マップ.請求方法番号（クレジットカード） → 請求方法番号(クレジットカード)
		if ("".equals(childMap.get("seiky_way_no_crecard"))) {
			template.setNull(EKK1091D010CBSMsg.SEIKY_WAY_NO_CRECARD);
		} else {
			template.set(EKK1091D010CBSMsg.SEIKY_WAY_NO_CRECARD, (String) childMap.get("seiky_way_no_crecard"));
		}

		// 進捗登録マップ.サービス契約番号 → サービス契約番号
		if ("".equals(dataMap.get("svc_kei_no"))) {
			template.setNull(EKK1091D010CBSMsg.SVC_KEI_NO);
		} else {
			template.set(EKK1091D010CBSMsg.SVC_KEI_NO, (String) dataMap.get("svc_kei_no"));
		}

		// 進捗登録マップ.サービス契約内訳番号 → サービス契約内訳番号
		if ("".equals(childMap.get("svc_kei_ucwk_no"))) {
			template.setNull(EKK1091D010CBSMsg.SVC_KEI_UCWK_NO);
		} else {
			template.set(EKK1091D010CBSMsg.SVC_KEI_UCWK_NO, (String) childMap.get("svc_kei_ucwk_no"));
		}

		// 進捗登録マップ.サービス契約回線内訳番号 → サービス契約回線内訳番号
		if ("".equals(childMap.get("svc_kei_kaisen_ucwk_no"))) {
			template.setNull(EKK1091D010CBSMsg.SVC_KEI_KAISEN_UCWK_NO);
		} else {
			template.set(EKK1091D010CBSMsg.SVC_KEI_KAISEN_UCWK_NO, (String) childMap.get("svc_kei_kaisen_ucwk_no"));
		}

		// 進捗登録マップ.機器提供サービス契約番号 → 機器提供サービス契約番号
		if ("".equals(childMap.get("kktk_svc_kei_no"))) {
			template.setNull(EKK1091D010CBSMsg.KKTK_SVC_KEI_NO);
		} else {
			template.set(EKK1091D010CBSMsg.KKTK_SVC_KEI_NO, (String) childMap.get("kktk_svc_kei_no"));
		}

		// 進捗登録マップ.オプションサービス契約番号 → オプションサービス契約番号
		if ("".equals(childMap.get("op_svc_kei_no"))) {
			template.setNull(EKK1091D010CBSMsg.OP_SVC_KEI_NO);
		} else {
			template.set(EKK1091D010CBSMsg.OP_SVC_KEI_NO, (String) childMap.get("op_svc_kei_no"));
		}

		// 請求オプションサービス契約番号
		if ("".equals(childMap.get("seiopsvc_kei_no"))) {
			template.setNull(EKK1091D010CBSMsg.SEIOPSVC_KEI_NO);
		} else {
			template.set(EKK1091D010CBSMsg.SEIOPSVC_KEI_NO, (String) dataMap.get("seiopsvc_kei_no"));
		}

		// 進捗登録マップ.サブオプションサービス契約番号 → サブオプションサービス契約番号
		if ("".equals(childMap.get("sbop_svc_kei_no"))) {
			template.setNull(EKK1091D010CBSMsg.SBOP_SVC_KEI_NO);
		} else {
			template.set(EKK1091D010CBSMsg.SBOP_SVC_KEI_NO, (String) childMap.get("sbop_svc_kei_no"));
		}

		// 進捗登録マップ.割引サービス契約番号 → 割引サービス契約番号
		if ("".equals(childMap.get("wrib_svc_kei_no"))) {
			template.setNull(EKK1091D010CBSMsg.WRIB_SVC_KEI_NO);
		} else {
			template.set(EKK1091D010CBSMsg.WRIB_SVC_KEI_NO, (String) childMap.get("wrib_svc_kei_no"));
		}

		// 進捗登録マップ.異動区分 → 異動区分
		if ("".equals(dataMap.get("ido_div"))) {
			template.setNull(EKK1091D010CBSMsg.IDO_DIV);
		} else {
			template.set(EKK1091D010CBSMsg.IDO_DIV, (String) dataMap.get("ido_div"));
		}
		
		// ワークマップ.異動年月日時分秒 → 異動年月日時分秒
		if (!workMap.containsKey("work_ido_dtm") || "".equals(workMap.get("work_ido_dtm"))) {
			String sysDate = JPCBPCommon.getSysDateTimeStamp();
			template.set(EKK1091D010CBSMsg.IDO_DTM, sysDate);
			workMap.put("work_ido_dtm", sysDate);
		} else {
			template.set(EKK1091D010CBSMsg.IDO_DTM, (String) workMap.get("work_ido_dtm"));
		}

		// 進捗登録マップ.進捗ステータス → 進捗ステータス
		if ("".equals(childMap.get("prg_stat"))) {
			template.setNull(EKK1091D010CBSMsg.PRG_STAT);
		} else {
			template.set(EKK1091D010CBSMsg.PRG_STAT, (String) childMap.get("prg_stat"));
		}

		// 進捗登録マップ.進捗メモ → 進捗メモ
		if ("".equals(childMap.get("prg_memo"))) {
			template.setNull(EKK1091D010CBSMsg.PRG_MEMO);
		} else {
			template.set(EKK1091D010CBSMsg.PRG_MEMO, (String) childMap.get("prg_memo"));
		}

		// 進捗登録マップ.進捗特記事項1 → 進捗特記事項1
		if ("".equals(childMap.get("prg_tkjk_1"))) {
			template.setNull(EKK1091D010CBSMsg.PRG_TKJK_1);
		} else {
			template.set(EKK1091D010CBSMsg.PRG_TKJK_1, (String) childMap.get("prg_tkjk_1"));
		}

		// 進捗登録マップ.進捗特記事項2 → 進捗特記事項2
		if ("".equals(childMap.get("prg_tkjk_2"))) {
			template.setNull(EKK1091D010CBSMsg.PRG_TKJK_2);
		} else {
			template.set(EKK1091D010CBSMsg.PRG_TKJK_2, (String) childMap.get("prg_tkjk_2"));
		}
		
		// 異動理由明細
		inList = (ArrayList)childMap.get("EKK1091D010CBSMsg1List");
		ArrayList<String> inMapList = new ArrayList<String>();
		
		if (inMapList != null) 
		{
			for (int j = 0; j < inList.size(); j++) 
			{
				HashMap idoRsnMap = (HashMap)inList.get(j);
				
				if (!"".equals(idoRsnMap.get("ido_rsn_cd"))) 
				{
					inMapList.add((String)idoRsnMap.get("ido_rsn_cd"));
				}
			}
		}
		
		templateArray = template.getCAANMsgList(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST);
		if (templateArray == null)
		{
			templateArray = new CAANMsg[inMapList.size()];
		}
		
		if (inMapList != null) 
		{
			for (int j = 0; j < inMapList.size(); j++) 
			{
				String idoRsnCd = (String)inMapList.get(j);
				
				CAANMsg childTemplate = templateArray[j];
				if (childTemplate == null) 
				{
					childTemplate = new CAANMsg(EKK1091D010CBSMsg1List.class.getName());
				}
				
				// 異動理由コード
				childTemplate.set(EKK1091D010CBSMsg1List.IDO_RSN_CD, idoRsnCd);
				// 異動理由メモ
				childTemplate.setNull(EKK1091D010CBSMsg1List.IDO_RSN_MEMO);
				
				templateArray[j] = childTemplate;
			}
		}
		
		template.set(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST, templateArray);
		
		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
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite editOutMsg_EKK1091D010(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);

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		
        // エラー情報の設定
        param = editErrorInfo_EKK1091D010(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_EKK1091D010(IRequestParameterReadWrite param, 
																	Map<String, Object> inMap,
																	CAANMsg[] templates,
																	int returnCode,
																	HashMap<String, Object> childMap) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(EKK1091D010CBSMsg.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, EKK1091D010CBSMsg.MSKM_DTL_NO_ERR);
		// 請求契約番号
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.SEIKY_KEI_NO_ERR);
		// 請求方法番号（口座）
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.SEIKY_WAY_NO_KOZA_ERR);
		// 請求方法番号（クレジットカード）
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.SEIKY_WAY_NO_CRECARD_ERR);
		// サービス契約番号
		setErrDataMap(inMap, template, EKK1091D010CBSMsg.SVC_KEI_NO_ERR);
		// サービス契約内訳番号
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.SVC_KEI_UCWK_NO_ERR);
		// サービス契約回線内訳番号
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.SVC_KEI_KAISEN_UCWK_NO_ERR);
		// 機器提供サービス契約番号
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.KKTK_SVC_KEI_NO_ERR);
		// オプションサービス契約番号
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.OP_SVC_KEI_NO_ERR);
		// 請求オプションサービス契約番号
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.SEIOPSVC_KEI_NO_ERR);
		// サブオプションサービス契約番号
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.SBOP_SVC_KEI_NO_ERR);
		// 割引サービス契約番号
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.WRIB_SVC_KEI_NO_ERR);
		// 異動区分
		setErrDataMap(inMap, template, EKK1091D010CBSMsg.IDO_DIV_ERR);
		// 異動年月日時分秒
		setErrDataMap(inMap, template, EKK1091D010CBSMsg.IDO_DTM_ERR);
		// 進捗ステータス
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.PRG_STAT_ERR);
		// 進捗メモ
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.PRG_MEMO_ERR);
		// 進捗特記事項1
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.PRG_TKJK_1_ERR);
		// 進捗特記事項2
		setErrDataMap(childMap, template, EKK1091D010CBSMsg.PRG_TKJK_2_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));
			}
		}
	}
	
	/**
	 * eo光TVコース選択情報変更CCのチェック処理用サービスインターフェイス作成。<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> paramMap = new HashMap<String, Object>();
		
		List<CAANMsg> templates = new ArrayList<CAANMsg>();
		
		// チェック用サービスインターフェイス
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, Arrays.asList(templates));
		
		return paramMap;
	}

}
