/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKTvSvcKeiPauseChgRsvClCC
*	ソースファイル名：JKKTvSvcKeiPauseChgRsvClCC.java
*	作成者			：FAP)古内
*	日付			：2011年12月27日
*＜機能概要＞
*	eo光ＴＶ休止変更・予約取消の共通コンポーネント
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/12/27	FJ)古内		新規作成
*	v6.00.00	2014/01/20	FJ)磯俣		【OM-2014-0000103】視聴制御をステータスで判断する
*	v38.00.00	2018/08/03	FJ) 吉田		【OM-2018-0000601】休止予約取消時進捗不備
*	v74.00.00	2025/02/03	FJ) 森下		【ANK-4592-00-00】テレビ新コース（スカパー用）導入対応
*
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.Arrays;
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.JPCModelConstant;
import eo.common.util.JKKStringUtil;
import eo.common.util.JPCCommonUtil;
import eo.ejb.cbs.cbsmsg.ECK0011B002CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0011D020CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0011D020CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0021C060CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0081C080CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081C280CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0161B004CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161B004CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0341B501CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0341B501CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0351A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0351A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0351B001CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0351B001CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0791A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0791A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0821A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0821A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK1681B001CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1681B001CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EZM0321A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EZM0321A010CBSMsg1List;


/**
 * eo光ＴＶ休止変更・予約取消処理を行います。<p>
 * <BR>
 * @author 富士通
 */
public class JKKTvSvcKeiPauseChgRsvClCC extends AbstractCommonComponent
{
	
	private static final String TEMPLATE_ID_EKK0161B004 = "EKK0161B004";
	/**  */
	private static final String TEMPLATE_ID_EKK0341B501 = "EKK0341B501";
	/**  */
	private static final String TEMPLATE_ID_EZM0321A010 = "EZM0321A010";
	/**  */
	private static final String TEMPLATE_ID_EKK0081A010 = "EKK0081A010";
	/**  */
	private static final String TEMPLATE_ID_EKK0011D020 = "EKK0011D020";
	/**  */
	private static final String TEMPLATE_ID_EKK0021C060 = "EKK0021C060";
	/**  */
	private static final String TEMPLATE_ID_EKK1091D010 = "EKK1091D010";
	/**  */
	private static final String TEMPLATE_ID_EKK0351B001 = "EKK0351B001";
	/**  */
	private static final String TEMPLATE_ID_EKK0351A010 = "EKK0351A010";
	/**  */
	private static final String TEMPLATE_ID_EKK0821A010 = "EKK0821A010";
	/**  */
	private static final String TEMPLATE_ID_EKK0161A010 = "EKK0161A010";
	/**  */
	private static final String TEMPLATE_ID_EKK0791A010 = "EKK0791A010";
	/**  */
	private static final String TEMPLATE_ID_EKK1681B001 = "EKK1681B001";
	/**  */
	private static final String TEMPLATE_ID_EKK0081C280 = "EKK0081C280";
	/**  */
	private static final String TEMPLATE_ID_EKK0081C080 = "EKK0081C080";
	
	/** 視聴制御依頼処理コード　23：サービス契約休止（休止解除） */
	public static final String WCTRL_REQ_TRN_CD_SVC_PAUSE_RLS = "29";
	
	// OM-2018-0000601 ADD START
	/** サービス契約ステータス：休止・中断中 */
	private static final String SVC_KEI_STAT_KYUS = "210";
	// OM-2018-0000601 ADD END
	
	// ANK-4592-00-00 ADD START
	/** 作業マップ名 */
	private static final String CC_WORK_SPTVDSL_STP_PAUSE = "JKKSptDslStpPause";
	/** 作業マップ名 */
	private static final String CC_WORK_SPTVKAIHK_PAUSE_STP_RLS = "JKKSptvKaihkPauseStpRls";
	
	/** 処理コード 解約・停止・休止 */
	private static final String SHORI_CD_DSL_STP_PAUSE = "4";
	/** 処理コード 回復・休止解除・停止解除 */
	private static final String SHORI_CD_KAIHK_PAUSE_STP_RLS = "5";
	
	/** 操作区分 休止  */
	private static final String OPE_DIV_KYUSI = "2";
	// ANK-4592-00-00 ADD END

	
	/**
	 * 
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return IRequestParameterReadWrite
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite pauseChgRsvCl(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
		String dataMapKey = fixedText;
		
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		
		// 更新年月日時分秒
		String lastUpdDtm = (String) ccMsg.get("lastUpdDtm");
		
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		// 運用日
		String opeDate = JPCBPCommon.getOpeDate(null);
		
		// 休止解除年月日
		String paruseRlsYmd = (String) ccMsg.get("pause_rls_ymd");
		
		// ***** EKK0081A010（サービス契約一意照会）*****
		CAANMsg ekk0081a010IN = new CAANMsg(EKK0081A010CBSMsg.class.getName());
		ekk0081a010IN.set(EKK0081A010CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK0081A010);
		ekk0081a010IN.set(EKK0081A010CBSMsg.FUNC_CODE,        "2");
		ekk0081a010IN.set(EKK0081A010CBSMsg.KEY_SVC_KEI_NO,   ccMsg.get("svc_kei_no"));
		ekk0081a010IN.set(EKK0081A010CBSMsg.KEY_GENE_ADD_DTM, "");
		ekk0081a010IN.set(EKK0081A010CBSMsg.KEY_RSV_APLY_YMD, opeDate);
		CAANMsg curSvcKeiInfo
						= callSC(handle, scCall, param, dataMapKey, ekk0081a010IN).getCAANMsgList(EKK0081A010CBSMsg.EKK0081A010CBSMSG1LIST)[0];
		
		// サービス契約ステータスの取得
		String curSvcKeiStat = curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.SVC_KEI_STAT);
		
		// 申込明細の採番
		CAANMsg mskmInfo = execMskm(handle, scCall, param,dataMapKey);
		
		String mskmNo = mskmInfo.getString(EKK0011D020CBSMsg.MSKM_NO);
		String mskmDtlNo = mskmInfo.getCAANMsgList(EKK0011D020CBSMsg.EKK0011D020CBSMSG1LIST)[0].getString(EKK0011D020CBSMsg1List.MSKM_DTL_NO);
		
		// 予約取消依頼データの場合
		//     サービス提供中 かつ サービス休止年月日 = null かつ 
		//     サービス休止解除年月日 = null かつ 休止料金提供年月 = null
		if("100".equals(curSvcKeiStat) && 
				(ccMsg.get("pause_sta_ymd") == null || "".equals(ccMsg.get("pause_sta_ymd"))) &&
				(ccMsg.get("pause_rls_ymd") == null || "".equals(ccMsg.get("pause_rls_ymd"))) &&
				(ccMsg.get("pause_prc_tk_ym") == null || "".equals(ccMsg.get("pause_prc_tk_ym"))))
		{
			// 予約取消を行う。
			svcPauseRsvCl(handle, scCall, param, dataMapKey, mskmDtlNo, lastUpdDtm);
			
			// 視聴制御を行わないため処理を終了する。
			return param;
		}
		else
		{
			// サービス契約休止変更を行う。
			// OM-2018-0000601 MOD START
//			svcPauseChg(handle, scCall, param, dataMapKey, mskmDtlNo, lastUpdDtm);
			// ANK-4592-00-00 MOD START
//			svcPauseChg(handle, scCall, param, dataMapKey, mskmDtlNo, lastUpdDtm, curSvcKeiStat);
			svcPauseChg(handle, scCall, param, dataMapKey, mskmDtlNo, lastUpdDtm, curSvcKeiStat, curSvcKeiInfo);
			// ANK-4592-00-00 MOD END
			// OM-2018-0000601 MOD END
			
		}
		
//		// 運用日と休止解除年月日が同一である場合は、視聴制御オーダを発行
//		if (paruseRlsYmd.equals(opeDate))
		// 休止解除年月日が運用日から１日以内（過去日を含まない）である場合は、視聴制御オーダを発行
		if (JCCBPCommon.subtractDay(paruseRlsYmd, opeDate) <= 1 && JCCBPCommon.subtractDay(paruseRlsYmd, opeDate) >= 0)
		{
			// ***** EKK0161B004（サービス契約内訳一覧照会）*****
			CAANMsg ekk0161b004IN = new CAANMsg(EKK0161B004CBSMsg.class.getName());
			ekk0161b004IN.set(EKK0161B004CBSMsg.TEMPLATEID,     TEMPLATE_ID_EKK0161B004);
			ekk0161b004IN.set(EKK0161B004CBSMsg.FUNC_CODE,      "1");
			ekk0161b004IN.set(EKK0161B004CBSMsg.KEY_SVC_KEI_NO, ccMsg.get("svc_kei_no"));
			CAANMsg[] ekk0161b004OUT
							= callSC(handle, scCall, param, dataMapKey, ekk0161b004IN).getCAANMsgList(EKK0161B004CBSMsg.EKK0161B004CBSMSG1LIST);
			
			HashMap<String, HashMap<String, String>> svcUcwkMap = new HashMap<String, HashMap<String, String>>();
			
			for (CAANMsg curSvcKeiUcwkInfo : ekk0161b004OUT)
			{
/* ++++++++++ v6.00.00 追加開始 ++++++++++ */
				// 内訳ステータスがサービス提供中でなく休止中でもない場合、視聴制御処理はしない
				String svcUwstat = curSvcKeiUcwkInfo.getString(EKK0161B004CBSMsg1List.SVC_KEI_UCWK_STAT);
				if(!"100".equals(svcUwstat)
						&& !"210".equals(svcUwstat))
				{
					continue;
				}
/* ++++++++++ v6.00.00 追加終了 ++++++++++ */
				
				// ***** EKK0341B501（機器提供サービス契約一覧照会(サービス契約内訳番号)）*****
				CAANMsg ekk0341b501IN = new CAANMsg(EKK0341B501CBSMsg.class.getName());
				ekk0341b501IN.set(EKK0341B501CBSMsg.TEMPLATEID,          TEMPLATE_ID_EKK0341B501);
				ekk0341b501IN.set(EKK0341B501CBSMsg.FUNC_CODE,           "1");
				ekk0341b501IN.set(EKK0341B501CBSMsg.KEY_SVC_KEI_UCWK_NO, curSvcKeiUcwkInfo.getString(EKK0161B004CBSMsg1List.SVC_KEI_UCWK_NO));
				CAANMsg[] ekk0341b501OUT
								= callSC(handle, scCall, param, dataMapKey, ekk0341b501IN).getCAANMsgList(EKK0341B501CBSMsg.EKK0341B501CBSMSG1LIST);
				
				for (CAANMsg curKktkSvcKeiInfo : ekk0341b501OUT)
				{
					if (!svcUcwkMap.containsKey(curSvcKeiUcwkInfo.getString(EKK0161B004CBSMsg1List.SVC_KEI_UCWK_NO)))
					{
						svcUcwkMap.put(curSvcKeiUcwkInfo.getString(EKK0161B004CBSMsg1List.SVC_KEI_UCWK_NO), new HashMap<String, String>());
					}
					HashMap<String, String> ucwkInfo = svcUcwkMap.get(curSvcKeiUcwkInfo.getString(EKK0161B004CBSMsg1List.SVC_KEI_UCWK_NO));
					ucwkInfo.put(curKktkSvcKeiInfo.getString(EKK0341B501CBSMsg1List.KKTK_SVC_CD), curKktkSvcKeiInfo.getString(EKK0341B501CBSMsg1List.KIKI_SEIZO_NO));
					ucwkInfo.put(curKktkSvcKeiInfo.getString(EKK0341B501CBSMsg1List.KKTK_SVC_CD) + "_MODEL", curKktkSvcKeiInfo.getString(EKK0341B501CBSMsg1List.TAKNKIKI_MODEL_CD));
				}
			}
			
			Iterator<String> it = svcUcwkMap.keySet().iterator();
			// 視聴制御オーダ発行
			while (it.hasNext())
			{
				String svcUcwkNo = it.next();
				HashMap<String, String> ucwkInfo = svcUcwkMap.get(svcUcwkNo);
				// 視聴制御
				execWctrlOrder(handle, param, scCall, svcUcwkNo, ucwkInfo, dataMapKey);
			}
		}
		
		return param;
	}
	
	/**
	 * 進捗情報を登録する。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param dataMapKey
	 * @param mskmDtlNo
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	private void registProgressInfo(SessionHandle handle,
									  ServiceComponentRequestInvoker scCall,
									  IRequestParameterReadWrite param,
									  String dataMapKey,
									  String mskmDtlNo,
									// OM-2018-0000601 MOD START
//									  String prgsStatus) throws Throwable
									  String prgsStatus,
									  String idoDtm) throws Throwable
									// OM-2018-0000601 MOD END
	{
		// 作業領域
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		
		// 機能コード
		String funcCode = (String) ccMsg.get("func_code");
		
		CAANMsg ekk1091d010IN = new CAANMsg(EKK1091D010CBSMsg.class.getName());
		ekk1091d010IN.set(EKK1091D010CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK1091D010);
		ekk1091d010IN.set(EKK1091D010CBSMsg.FUNC_CODE,        funcCode);
		ekk1091d010IN.set(EKK1091D010CBSMsg.SVC_KEI_NO,       ccMsg.get("svc_kei_no"));
		ekk1091d010IN.set(EKK1091D010CBSMsg.IDO_DIV,          ccMsg.get("ido_div"));
		// OM-2018-0000601 MOD START
//		ekk1091d010IN.set(EKK1091D010CBSMsg.IDO_DTM,          JCCBPCommon.getSysDateTimeStamp());
		ekk1091d010IN.set(EKK1091D010CBSMsg.IDO_DTM,          idoDtm);
		// OM-2018-0000601 MOD END
		ekk1091d010IN.set(EKK1091D010CBSMsg.PRG_STAT,         prgsStatus);									// 1932：休止受付変更登録完了
		ekk1091d010IN.set(EKK1091D010CBSMsg.PRG_TKJK_1,       ccMsg.get("prg_tkjk_1"));
		ekk1091d010IN.set(EKK1091D010CBSMsg.PRG_TKJK_2,       ccMsg.get("prg_tkjk_2"));
		ekk1091d010IN.set(EKK1091D010CBSMsg.MSKM_DTL_NO,      mskmDtlNo);
		
		ArrayList<HashMap<String, Object>> inList = (ArrayList<HashMap<String, Object>>) ccMsg.get("ido_list");
		CAANMsg[] templateArray = new CAANMsg[inList.size()];

		for (int i = 0; i < inList.size(); i++) {
			HashMap<String, Object> childMap = inList.get(i);

			templateArray[i] = new CAANMsg(EKK1091D010CBSMsg1List.class.getName());

			// リクエストパラメータ.異動理由明細.異動理由コード → 異動理由明細.異動理由コード
			if (childMap == null || childMap.get("ido_rsn_cd") == null || "".equals(childMap.get("ido_rsn_cd"))) {
				templateArray[i].set(EKK1091D010CBSMsg1List.IDO_RSN_CD, "C6");
			} else {
				templateArray[i].set(EKK1091D010CBSMsg1List.IDO_RSN_CD, (String) childMap.get("ido_rsn_cd"));
			}

			// リクエストパラメータ.異動理由明細.異動理由メモ → 異動理由明細.異動理由メモ
			if (childMap == null || childMap.get("ido_rsn_memo") == null || "".equals(childMap.get("ido_rsn_memo"))) {
				templateArray[i].setNull(EKK1091D010CBSMsg1List.IDO_RSN_MEMO);
			} else {
				templateArray[i].set(EKK1091D010CBSMsg1List.IDO_RSN_MEMO, (String) childMap.get("ido_rsn_memo"));
			}
		}
		ekk1091d010IN.set(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST, templateArray);

		callSC(handle, scCall, param, dataMapKey, ekk1091d010IN);
		
	}
	
	/**
	 * 視聴制御オーダを「視聴制御依頼処理コード：29（サービス契約休止解除）」にて発行する。
	 * 
	 * @param handle
	 * @param param
	 * @param curCustInfo
	 * @param curSvcKeiInfo
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	private void execWctrlOrder(SessionHandle handle,
								  IRequestParameterReadWrite param,
								  ServiceComponentRequestInvoker scCall,
								  String svcUcwkNo,
								  HashMap<String, String> ucwkInfo,
								  String dataMapKey) throws Throwable
	{

		// 作業領域
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		
		// 機能コード
		String funcCode = (String) ccMsg.get("func_code");
		
		// 運用日
		String opeDate = JPCBPCommon.getOpeDate(null);
		
		JKKWctrlOrderSendCC orderSendCC = new JKKWctrlOrderSendCC();
		String workOrderSendDataKey = "WctrlOrderSendMap";
		param.setData(workOrderSendDataKey, new HashMap<String, Object>());
		HashMap<String, Object> outMap = (HashMap<String, Object>)param.getData(workOrderSendDataKey);
		
		// ***** EKK0351B001（eo光テレビオプションチャンネル情報一覧照会）*****
		CAANMsg ekk0351b001IN = new CAANMsg(EKK0351B001CBSMsg.class.getName());
		ekk0351b001IN.set(EKK0351B001CBSMsg.TEMPLATEID,          TEMPLATE_ID_EKK0351B001);
		ekk0351b001IN.set(EKK0351B001CBSMsg.FUNC_CODE,           "1");
		ekk0351b001IN.set(EKK0351B001CBSMsg.KEY_SVC_KEI_UCWK_NO, svcUcwkNo);
		CAANMsg[] ekk0351b001OUT
						= callSC(handle, scCall, param, dataMapKey, ekk0351b001IN).getCAANMsgList(EKK0351B001CBSMsg.EKK0351B001CBSMSG1LIST);
		
		// ***** 視聴制御発行情報を取得する。 *****
		
		ArrayList<HashMap<String, Object>> digitalTiaList = new ArrayList<HashMap<String, Object>>();
		
		for (CAANMsg curOpSvcKeiInfo : ekk0351b001OUT)
		{
			// ***** EKK0351A010（オプションサービス契約一意照会）*****
			CAANMsg ekk0351a010IN = new CAANMsg(EKK0351A010CBSMsg.class.getName());
			ekk0351a010IN.set(EKK0351A010CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0351A010);
			ekk0351a010IN.set(EKK0351A010CBSMsg.FUNC_CODE,         "2");
			ekk0351a010IN.set(EKK0351A010CBSMsg.KEY_OP_SVC_KEI_NO, curOpSvcKeiInfo.getString(EKK0351B001CBSMsg1List.OP_SVC_KEI_NO));
			ekk0351a010IN.set(EKK0351A010CBSMsg.KEY_RSV_APLY_YMD,  opeDate);
			
			CAANMsg[] ekk0351a010INOUT
							= callSC(handle, scCall, param, dataMapKey, ekk0351a010IN).getCAANMsgList(EKK0351A010CBSMsg.EKK0351A010CBSMSG1LIST);
			
			boolean isEnabledOpSvc = false;
			
			if ("210".equals(ekk0351a010INOUT[0].getString(EKK0351A010CBSMsg1List.OP_SVC_KEI_STAT)))
			{
				// 視聴制御送信対象とする。
				isEnabledOpSvc = true;
			}
			else if ("100".equals(ekk0351a010INOUT[0].getString(EKK0351A010CBSMsg1List.OP_SVC_KEI_STAT)))
			{
				// 視聴制御送信対象とする。
				isEnabledOpSvc = true;
			}
			else if ("030".equals(ekk0351a010INOUT[0].getString(EKK0351A010CBSMsg1List.OP_SVC_KEI_STAT)))
			{
				String svcStaYmd = "";
				
				// サービス開始年月日が取得できないため、異動予約よりサービス開始年月日を取得する。
				if (ekk0351a010INOUT[0].isNull(EKK0351A010CBSMsg1List.SVC_STAYMD))
				{
					// ***** EKK1681B001（異動予約一意照会）*****
					CAANMsg ekk1681b001IN = new CAANMsg(EKK1681B001CBSMsg.class.getName());
					ekk1681b001IN.set(EKK1681B001CBSMsg.TEMPLATEID,          TEMPLATE_ID_EKK1681B001);
					ekk1681b001IN.set(EKK1681B001CBSMsg.FUNC_CODE,           "1");
					ekk1681b001IN.set(EKK1681B001CBSMsg.KEY_OP_SVC_KEI_NO,   curOpSvcKeiInfo.getString(EKK0351B001CBSMsg1List.OP_SVC_KEI_NO));
					ekk1681b001IN.set(EKK1681B001CBSMsg.KEY_IDO_DIV,         "00031");
					ekk1681b001IN.set(EKK1681B001CBSMsg.KEY_IDO_RSV_DTL_CD,  "014");
					ekk1681b001IN.set(EKK1681B001CBSMsg.KEY_IDO_RSV_STAT_CD, "00");
					
					CAANMsg[] ekk1681b001OUT
									= callSC(handle, scCall, param, dataMapKey, ekk1681b001IN).getCAANMsgList(EKK1681B001CBSMsg.EKK1681B001CBSMSG1LIST);
					
					if (ekk1681b001OUT.length > 0)
					{
						svcStaYmd = ekk1681b001OUT[0].getString(EKK1681B001CBSMsg1List.RSV_APLY_YMD);
					}
				}
				else
				{
					svcStaYmd = ekk0351a010INOUT[0].getString(EKK0351A010CBSMsg1List.SVC_STAYMD);
				}
				if (!"".equals(svcStaYmd))
				{
					// サービス開始年月日が運用日から２日以内（過去日を含まない）である場合
					if (JCCBPCommon.subtractDay(svcStaYmd, opeDate) <= 2 && JCCBPCommon.subtractDay(svcStaYmd, opeDate) >= 0)
					{
						isEnabledOpSvc = true;
					}
				}
			}
			
			if (isEnabledOpSvc)
			{
				// ***** EKK0821A010（オプションサービス一意照会）*****
				CAANMsg ekk0821a010IN = new CAANMsg(EKK0821A010CBSMsg.class.getName());
				ekk0821a010IN.set(EKK0821A010CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK0821A010);
				ekk0821a010IN.set(EKK0821A010CBSMsg.FUNC_CODE,        "2");
				ekk0821a010IN.set(EKK0821A010CBSMsg.KEY_OP_SVC_CD,    ekk0351a010INOUT[0].getString(EKK0351A010CBSMsg1List.OP_SVC_CD));
				ekk0821a010IN.set(EKK0821A010CBSMsg.KEY_RSV_APLY_YMD, opeDate);
				
				CAANMsg[] ekk0821a010OUT
								= callSC(handle, scCall, param, dataMapKey, ekk0821a010IN).getCAANMsgList(EKK0821A010CBSMsg.EKK0821A010CBSMSG1LIST);
				
				// デジタルティアグループコードが空でない場合
				if(!ekk0821a010OUT[0].isNull(EKK0821A010CBSMsg1List.DGTIA_GRP_CD))
				{
					HashMap<String, Object> digitalTiaMap = new HashMap<String, Object>();
					digitalTiaMap.put("wc01611_dgtia_grp_cd", ekk0821a010OUT[0].getString(EKK0821A010CBSMsg1List.DGTIA_GRP_CD));
					digitalTiaList.add(digitalTiaMap);
				}
			}
		}
		
		// サービス契約内訳のディジタルティアグループコードを取得する。
		
		// ***** EKK0161A010（サービス契約内訳一意照会）*****
		CAANMsg ekk0161a010IN = new CAANMsg(EKK0161A010CBSMsg.class.getName());
		ekk0161a010IN.set(EKK0161A010CBSMsg.TEMPLATEID,          TEMPLATE_ID_EKK0161A010);
		ekk0161a010IN.set(EKK0161A010CBSMsg.FUNC_CODE,           "2");
		ekk0161a010IN.set(EKK0161A010CBSMsg.KEY_SVC_KEI_UCWK_NO, svcUcwkNo);
		ekk0161a010IN.set(EKK0161A010CBSMsg.KEY_RSV_APLY_YMD,    opeDate);
		CAANMsg[] ekk0161a010OUT
						= callSC(handle, scCall, param, dataMapKey, ekk0161a010IN).getCAANMsgList(EKK0161A010CBSMsg.EKK0161A010CBSMSG1LIST);
		
		// ***** EKK0791A010（料金コース一意照会）*****
		CAANMsg ekk0791a010IN = new CAANMsg(EKK0791A010CBSMsg.class.getName());
		ekk0791a010IN.set(EKK0791A010CBSMsg.TEMPLATEID,       TEMPLATE_ID_EKK0791A010);
		ekk0791a010IN.set(EKK0791A010CBSMsg.FUNC_CODE,        "2");
		ekk0791a010IN.set(EKK0791A010CBSMsg.KEY_PCRS_CD,      ekk0161a010OUT[0].getString(EKK0161A010CBSMsg1List.PCRS_CD));
		ekk0791a010IN.set(EKK0791A010CBSMsg.KEY_RSV_APLY_YMD, opeDate);
		CAANMsg[] ekk0791a010OUT
						= callSC(handle, scCall, param, dataMapKey, ekk0791a010IN).getCAANMsgList(EKK0791A010CBSMsg.EKK0791A010CBSMSG1LIST);
		
		HashMap<String, Object> digitalTiaMap = new HashMap<String, Object>();
		digitalTiaMap.put("wc01611_dgtia_grp_cd", ekk0791a010OUT[0].getString(EKK0791A010CBSMsg1List.DGTIA_GRP_CD));
		digitalTiaList.add(digitalTiaMap);
		String bcasStbId = ucwkInfo.get("C010");
		String ccasStbId = ucwkInfo.get("C011");
		
		// 視聴制御依頼処理コード
		outMap.put("wc0011d_wctrl_req_trn_cd", WCTRL_REQ_TRN_CD_SVC_PAUSE_RLS);
		
		outMap.put("wc0011d_sysid", ccMsg.get("sysid"));
		outMap.put("wc0011d_svc_kei_no", ccMsg.get("svc_kei_no"));
		outMap.put("wc0011d_svc_kei_ucwk_no", svcUcwkNo);
		outMap.put("wca001_key_tk_mdl_cd", ucwkInfo.get("C009_MODEL"));
		outMap.put("wca001_key_kk_seizo_no", ucwkInfo.get("C009"));
		outMap.put("wc01611_EWC0161D010CBSMsg1List", digitalTiaList);
		
		outMap.put("func_code", funcCode);
		
		orderSendCC.sendWctrlOrder(handle, param, workOrderSendDataKey);
		
		param.removeData(workOrderSendDataKey);
	}
	
	/**
	 * 「サービス休止変更」を行う
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param dataMapKey
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private void svcPauseChg(SessionHandle handle, 
							   ServiceComponentRequestInvoker scCall, 
							   IRequestParameterReadWrite param,
							   String dataMapKey,
							   String mskmDtlNo,
							// OM-2018-0000601 MOD START
//							   String lastUpdDtm) throws Throwable
							   String lastUpdDtm,
							// ANK-4592-00-00 MOD START
//							   String lastStat) throws Throwable
							   String lastStat,
							   CAANMsg curSvcKeiInfo) throws Throwable
							// ANK-4592-00-00 MOD END
							// OM-2018-0000601 MOD END
	{
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		
		// 機能コード
		String funcCode = (String) ccMsg.get("func_code");
		
		// 異動区分
		String ido_div = (String) ccMsg.get("ido_div");
		
		// 休止開始年月日
		String pauseStaYmd = (String) ccMsg.get("pause_sta_ymd");
		
		// 休止解除年月日
		String pauseRlsYmd = (String) ccMsg.get("pause_rls_ymd");
		
		// 休止料金適用年月
		String workYm = (String) ccMsg.get("pause_prc_tk_ym");
		String parusePrcTkYmd = null;
		if("".equals(workYm) || workYm == null)
		{
			parusePrcTkYmd = "";
		}
		else
		{
			parusePrcTkYmd = workYm + "01";
		}

		// 休止メモ
		String pauseMemo = (String) ccMsg.get("pause_memo");
		
		// 運用日
		String opeDate = JPCBPCommon.getOpeDate(null);
		
		// ***** EKK0081C080（サービス契約休止受付）*****
		CAANMsg ekk0081c080IN = new CAANMsg(EKK0081C080CBSMsg.class.getName());
		ekk0081c080IN.set(EKK0081C080CBSMsg.TEMPLATEID,             TEMPLATE_ID_EKK0081C080);
		ekk0081c080IN.set(EKK0081C080CBSMsg.FUNC_CODE,              funcCode);
		ekk0081c080IN.set(EKK0081C080CBSMsg.SVC_KEI_NO,             ccMsg.get("svc_kei_no"));
		ekk0081c080IN.set(EKK0081C080CBSMsg.MSKM_DTL_NO,            mskmDtlNo);
		ekk0081c080IN.set(EKK0081C080CBSMsg.PAUSE_STP_CD,           "00");	// 休止中断コード（00:休止中(SOD未発行)）
		ekk0081c080IN.set(EKK0081C080CBSMsg.SVC_PAUSE_YMD,          pauseStaYmd);
		ekk0081c080IN.set(EKK0081C080CBSMsg.SVC_PAUSE_RSN_CD,       "");
		ekk0081c080IN.set(EKK0081C080CBSMsg.SVC_PAUSE_RSN_MEMO,     pauseMemo);
		ekk0081c080IN.set(EKK0081C080CBSMsg.SVC_PAUSE_RLS_YMD,      pauseRlsYmd);
		ekk0081c080IN.set(EKK0081C080CBSMsg.SVC_PAUSE_RLS_RSN_CD,   "");
		ekk0081c080IN.set(EKK0081C080CBSMsg.SVC_PAUSE_RLS_RSN_MEMO, "");
		ekk0081c080IN.set(EKK0081C080CBSMsg.SVC_PAUSE_CHRG_STA_YMD, parusePrcTkYmd);
		ekk0081c080IN.set(EKK0081C080CBSMsg.IDO_DIV,                ido_div);
		ekk0081c080IN.set(EKK0081C080CBSMsg.UPD_DTM_BF,             lastUpdDtm);
		
		// OM-2018-0000601 MOD START
//		callSC(handle, scCall, param, dataMapKey, ekk0081c080IN);
		CAANMsg ekk0081c080OUT = callSC(handle, scCall, param, dataMapKey, ekk0081c080IN);
		// OM-2018-0000601 MOD END
		
//		if (opeDate.equals(pauseStaYmd))
//		{
//			// 進捗（2401：休止開始完了）
//			registProgressInfo(handle, scCall, param, dataMapKey, mskmDtlNo, "2401");
//		}
//		else if (opeDate.equals(pauseRlsYmd))
//		{
//			// 進捗（2402：休止解除完了）
//			registProgressInfo(handle, scCall, param, dataMapKey, mskmDtlNo, "2402");
//		}
//		else
//		{
		// OM-2018-0000601 ADD START
		//異動年月日時分秒
		String idoDtm = JCCBPCommon.getSysDateTimeStamp();
		String newStat = new String(lastStat);
		// 休止変更後のサービス契約ステータス
		if (null != ekk0081c080OUT && !ekk0081c080OUT.isNull(EKK0081C080CBSMsg.SVC_KEI_STAT))
		{
			newStat = ekk0081c080OUT.getString(EKK0081C080CBSMsg.SVC_KEI_STAT);
		}
		
		// OM-2018-0000601 ADD END
		// 進捗（1932：休止受付変更登録完了）
		// OM-2018-0000601 MOD START
//		registProgressInfo(handle, scCall, param, dataMapKey, mskmDtlNo, "1932");
		registProgressInfo(handle, scCall, param, dataMapKey, mskmDtlNo, "1932", idoDtm);

		// サービス契約ステータスが変わっている場合
		if (!lastStat.equals(newStat))
		{
			// ANK-4592-00-00 ADD START
			String ccWorkName = null;
			// ANK-4592-00-00 ADD END
			
			// 休止・中断中になっているなら（サービス休止開始日が運用日当日の場合）
			if (!SVC_KEI_STAT_KYUS.equals(lastStat) && SVC_KEI_STAT_KYUS.equals(newStat))
			{
				// 休止開始日が運用日と同じ日
				// 進捗（2401：休止開始完了）
				registProgressInfo(handle, scCall, param, dataMapKey, mskmDtlNo, "2401", idoDtm);
				
				// ANK-4592-00-00 ADD START
				// スカパー鍵情報操作上りマッピング
				ccWorkName = CC_WORK_SPTVDSL_STP_PAUSE;
				
				HashMap<String, Object> workMap = new HashMap<String, Object>();
				workMap.put("func_cd", funcCode);
				workMap.put("shori_cd", SHORI_CD_DSL_STP_PAUSE);
				workMap.put("svc_kei_no", ccMsg.get("svc_kei_no"));
				workMap.put("snst_mt_ymd", pauseStaYmd);
				workMap.put("ope_div", OPE_DIV_KYUSI);
				param.setData(CC_WORK_SPTVDSL_STP_PAUSE, workMap);
				// ANK-4592-00-00 ADD END
			}
			// 休止・中断中でないなら（サービス休止解除年月日＝運用日の場合）
			else if (SVC_KEI_STAT_KYUS.equals(lastStat) && !SVC_KEI_STAT_KYUS.equals(newStat))
			{
				// 休止終了日が運用日と同じ日
				// 進捗（2402：休止解除完了）
				registProgressInfo(handle, scCall, param, dataMapKey, mskmDtlNo, "2402", idoDtm);
				
				// ANK-4592-00-00 ADD START
				// スカパー鍵情報操作上りマッピング
				ccWorkName = CC_WORK_SPTVKAIHK_PAUSE_STP_RLS;
				
				HashMap<String, Object> workMap = new HashMap<String, Object>();
				workMap.put("func_cd", funcCode);
				workMap.put("shori_cd", SHORI_CD_KAIHK_PAUSE_STP_RLS);
				workMap.put("svc_kei_no", ccMsg.get("svc_kei_no"));
				workMap.put("snst_mt_ymd", pauseRlsYmd);
				param.setData(CC_WORK_SPTVKAIHK_PAUSE_STP_RLS, workMap);
				// ANK-4592-00-00 ADD END
			}
			
			// ANK-4592-00-00 ADD START
			if (JPCModelConstant.FUNC_CD_1.equals(funcCode) && !JKKStringUtil.isNullBlank(ccWorkName))
			{
				// スカパー鍵情報操作CC呼出
				JKKSptvKeyInfOperateCC JKKSptvKeyInfOperateCC = new JKKSptvKeyInfOperateCC();
				JKKSptvKeyInfOperateCC.execute(handle,  param, ccWorkName);
			}
			// ANK-4592-00-00 ADD END
		}

		// OM-2018-0000601 MOD END
//		}
	}

	/**
	 * 「サービス休止予約解除」を行う
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param dataMapKey
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private String svcPauseRsvCl(SessionHandle handle, 
								ServiceComponentRequestInvoker scCall, 
								IRequestParameterReadWrite param,
								String dataMapKey,
								String mskmDtlNo,
								String lastUpdDtm) throws Throwable
	{
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		
		// 機能コード
		String funcCode = (String) ccMsg.get("func_code");
		
		// ***** EKK0081C280（サービス契約休止予約取消）*****
		CAANMsg ekk0081c280IN = new CAANMsg(EKK0081C280CBSMsg.class.getName());
		ekk0081c280IN.set(EKK0081C280CBSMsg.TEMPLATEID,             TEMPLATE_ID_EKK0081C280);
		ekk0081c280IN.set(EKK0081C280CBSMsg.FUNC_CODE,              funcCode);
		ekk0081c280IN.set(EKK0081C280CBSMsg.SVC_KEI_NO,             ccMsg.get("svc_kei_no"));
		ekk0081c280IN.set(EKK0081C280CBSMsg.MSKM_DTL_NO,            mskmDtlNo);
		ekk0081c280IN.set(EKK0081C280CBSMsg.UPD_DTM_BF,             lastUpdDtm);
		
		CAANMsg ekk0081c280OUT = callSC(handle, scCall, param, dataMapKey, ekk0081c280IN);
		
		// OM-2018-0000601 ADD START
		// 進捗
		registProgressInfo(handle, scCall, param, dataMapKey, mskmDtlNo, "1932", JCCBPCommon.getSysDateTimeStamp());
		// OM-2018-0000601 ADD END
		
		return ekk0081c280OUT.getString(EKK0081C280CBSMsg.UPD_DTM);
	}
	
	/**
	 * 申込内容承認登録、申込明細照査・後続業務依頼のサービスインターフェイスを実行し、採番された申込明細番号を返却します。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param dataMapKey
	 * @return
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private CAANMsg execMskm(SessionHandle handle, 
							  ServiceComponentRequestInvoker scCall, 
							  IRequestParameterReadWrite param,
							  String dataMapKey) throws Exception
	{
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		
		// 機能コード
		String funcCode = (String) ccMsg.get("func_code");
		
		// ***** EKK0011D020（申込内容承認登録）*****
		CAANMsg ekk0011d020IN = new CAANMsg(EKK0011D020CBSMsg.class.getName());
		ekk0011d020IN.set(EKK0011D020CBSMsg.TEMPLATEID,                 TEMPLATE_ID_EKK0011D020);
		ekk0011d020IN.set(EKK0011D020CBSMsg.FUNC_CODE,                  funcCode);
		ekk0011d020IN.set(EKK0011D020CBSMsg.SYSID,                      ccMsg.get("sysid"));
		ekk0011d020IN.set(EKK0011D020CBSMsg.MSKM_SBT_CD,                "00020");
		ekk0011d020IN.set(EKK0011D020CBSMsg.MSKM_UK_DTM,                JPCBPCommon.getOpeDateTimeStamp(null));
		ekk0011d020IN.set(EKK0011D020CBSMsg.MSKM_UK_TNT_USER_ID,        param.getControlMapData(SCControlMapKeys.OPERATOR_ID));
		ekk0011d020IN.set(EKK0011D020CBSMsg.MSKM_YMD,                   JPCBPCommon.getOpeDate(null));
		ekk0011d020IN.set(EKK0011D020CBSMsg.CONSMBSN_MSKM_STAT_SKBT_CD, "04");

		CAANMsg[] ekk0011d020msglist = new CAANMsg[]{new CAANMsg(EKK0011D020CBSMsg1List.class.getName())};

		if (ccMsg.get("manssbsys_rnki_yo_kijiran") == null || "".equals(ccMsg.get("manssbsys_rnki_yo_kijiran"))) {
			ekk0011d020msglist[0].setNull(EKK0011D020CBSMsg1List.MANSSBSYS_RNKI_YO_KIJIRAN);
		} else {
			ekk0011d020msglist[0].set(EKK0011D020CBSMsg1List.MANSSBSYS_RNKI_YO_KIJIRAN, ccMsg.get("manssbsys_rnki_yo_kijiran"));
		}
		
		ekk0011d020IN.set(EKK0011D020CBSMsg.EKK0011D020CBSMSG1LIST,     ekk0011d020msglist);
		
		CAANMsg mskmInfo = callSC(handle, scCall, param, dataMapKey, ekk0011d020IN);
		
		String mskmDtlNo = mskmInfo.getCAANMsgList(EKK0011D020CBSMsg.EKK0011D020CBSMSG1LIST)[0].getString(EKK0011D020CBSMsg1List.MSKM_DTL_NO);
		
		// ***** EKK0021C060（申込明細照査・後続業務依頼）*****
		CAANMsg ekk0021c060IN = new CAANMsg(EKK0021C060CBSMsg.class.getName());
		ekk0021c060IN.set(EKK0021C060CBSMsg.TEMPLATEID,    TEMPLATE_ID_EKK0021C060);
		ekk0021c060IN.set(EKK0021C060CBSMsg.FUNC_CODE,     funcCode);
		ekk0021c060IN.set(EKK0021C060CBSMsg.MSKM_DTL_NO,   mskmDtlNo);
		ekk0021c060IN.set(EKK0021C060CBSMsg.KZKWRK_REQYMD, JPCBPCommon.getOpeDate(null));
		ekk0021c060IN.set(EKK0021C060CBSMsg.UPD_DTM_BF,    mskmInfo.getString(EKK0011D020CBSMsg.UPD_DTM));
		ekk0021c060IN.set(EKK0021C060CBSMsg.IDO_DIV,       ccMsg.get("ido_div"));
		
		callSC(handle, scCall, param, dataMapKey, ekk0021c060IN);
		
		return mskmInfo;
	}
	
	/**
	 * 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("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);
					}
				}
			}
		}
	}

	/**
	 * 
	 * @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(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;
	}
	
	/**
	 * 業務パラメータを取得。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param dataMapKey
	 * @param keyword
	 * @return String
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private String getBuisinessParameter(SessionHandle handle, 
										ServiceComponentRequestInvoker scCall, 
										IRequestParameterReadWrite param,
										String dataMapKey,
										String keyword) throws Exception 
	{
		// ***** EZM0321A010（業務パラメータ管理一意照会）*****
		CAANMsg ezm0321a010IN = new CAANMsg(EZM0321A010CBSMsg.class.getName());
		ezm0321a010IN.set(EZM0321A010CBSMsg.TEMPLATEID,        TEMPLATE_ID_EZM0321A010);
		ezm0321a010IN.set(EZM0321A010CBSMsg.FUNC_CODE,         "1");
		ezm0321a010IN.set(EZM0321A010CBSMsg.KEY_WORK_PARAM_ID, keyword);
		
		CAANMsg[] ezm0321a010cbsMsg1list 
						= callSC(handle, scCall, param, dataMapKey, ezm0321a010IN).getCAANMsgList(EZM0321A010CBSMsg.EZM0321A010CBSMSG1LIST);
		
		return ezm0321a010cbsMsg1list[0].getString(EZM0321A010CBSMsg1List.WORK_PARAM_SETTE_VALUE);
	}
	
	/**
	 * 機器変更ＣＣのチェック処理用サービスインターフェイス作成。<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;
	}

	/**
	 * 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;
	}
}
