/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKTvSvcKeiCancelCC
*	ソースファイル名：JKKTvSvcKeiCancelCC.java
*	作成者			：FAP)古内
*	日付			：2011年12月27日
*＜機能概要＞
*	eo光ＴＶキャンセルの共通コンポーネント
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/12/27	FAP)古内	新規作成
*   v4.00.00	2012/11/5	FAP)辛		【ANK-1250-00-00】対応
*   v4.01.00	2013/1/10	FAP)辛		【ST2-2013-0000008】対応
*	v5.00.00	2013/01/28	FJ)野口	   【ST1-2012-0000846】対応
*										EKK0081B011→EKK0081B035に変更
*   v5.00.01	2013/3/26	FAP)辛		【IT1-2013-0000643】対応
*   v5.00.02	2013/4/9	FAP)馬場	【IT1-2013-0000835】対応
*   v5.00.03	2013/10/08	FAP)田原	【OM-2013-0003115】対応
*   v7.00.00	2014/03/08	FAP)稲岡	【OM-2013-0000904】対応
*   v7.00.01	2014/03/22	FAP)稲岡	【OM-2013-0001010】対応
*   v8.00.00	2014/05/30	FJ)藤本		【OM-2014-0001878】テレビ契約キャンセル処理のサービス契約回線内訳キャンセル時に状態遷移チェックエラーが発生
*   v37.00.00	2018/06/19	FJ)吉田		【OM-2018-0000597】eo光TV新設工事前キャンセルエラー
*   v54.00.00	2021/07/30	FJ)藤本涼	【OM-2021-0000601】テレビサービス契約キャンセル時、エラーが発生
**********************************************************************/
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.JKKStrConst;
import eo.ejb.cbs.cbsmsg.ECK0011B002CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0011B020CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0011B020CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0011C060CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0011C060CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0011D020CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0011D020CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0021C060CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0021C070CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0081B035CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081C160CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081C200CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161B004CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161B004CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0161C160CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0241B001CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0241B001CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0251C070CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0341B501CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0341B501CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0341B504CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0341B504CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0341C330CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0351B002CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0351B002CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0351C220CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0791A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0791A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKU0091C010CBSMsg;


/**
 * eo光ＴＶキャンセル処理を行います。<p>
 * <BR>
 * @author 富士通
 */
public class JKKTvSvcKeiCancelCC extends AbstractCommonComponent
{
	
	private static final String TEMPLATE_ID_EKK0161B004 = "EKK0161B004";
	/**  */
	private static final String TEMPLATE_ID_EKK0341B501 = "EKK0341B501";
	/**  */
	private static final String TEMPLATE_ID_EKK0351B002 = "EKK0351B002";
	/**  */
	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_EKK0081C160 = "EKK0081C160";
	/**  */
	private static final String TEMPLATE_ID_EKK0161C160 = "EKK0161C160";
	/**  */
	private static final String TEMPLATE_ID_EKK0341C330 = "EKK0341C330";
	/**  */
	private static final String TEMPLATE_ID_EKK0351C220 = "EKK0351C220";
	/**  */
	private static final String TEMPLATE_ID_EKK0241B001 = "EKK0241B001";
	/**  */
	private static final String TEMPLATE_ID_EKK0341B504 = "EKK0341B504";
	/**  */
/* ++++++++++ v5.00.00 変更開始 ++++++++++ */
//	private static final String TEMPLATE_ID_EKK0081B011 = "EKK0081B011";
	private static final String TEMPLATE_ID_EKK0081B035 = "EKK0081B035";
/* ++++++++++ v5.00.00 変更終了 ++++++++++ */
	/**  */
	private static final String TEMPLATE_ID_EKK0251C070 = "EKK0251C070";
//********** v4.00.00, v4.01.00 追加 START *********************************************
	/**  */
	private static final String TEMPLATE_ID_EKK0021C070 = "EKK0021C070";
	/**  */
	private static final String TEMPLATE_ID_EKK0011C060 = "EKK0011C060";
	/**  */
	private static final String TEMPLATE_ID_EKK0011B020 = "EKK0011B020";
	/** 申込明細ステータス：キャンセル(920) */
	private static final String MSKM_DTL_STAT_CANCEL = "920";
//********** v4.00.00, v4.01.00 追加 END ***********************************************	
	/**  */
	private static final String TEMPLATE_ID_EKK0791A010 = "EKK0791A010";
	
	// ▼▼▼▼▼OM-2018-0000597 2018/06/19 ADD START▼▼▼▼▼
	/** テンプレートID:EKU0091C010 工事案件取消 */
	private static final String TEMPLATE_ID_EKU0091C010 = "EKU0091C010";
	// ▲▲▲▲▲OM-2018-0000597 2018/06/19 ADD END▲▲▲▲▲
	
	/**
	 * 
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return IRequestParameterReadWrite
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite cancel(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);
		
		// ***** 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);

//*********v4.00.00 追加 START********************************
		String mskmNo = "";
		String mskmDtlNo = "";
		
		//■「照査済」の場合⇒「申込内容承認登録処理」を行う。
		if ("020".equals(curSvcKeiStat))
		{
			// 申込明細の採番
			CAANMsg mskmInfo = execMskm(handle, scCall, param,dataMapKey);
			
			mskmNo = mskmInfo.getString(EKK0011D020CBSMsg.MSKM_NO);
			mskmDtlNo = mskmInfo.getCAANMsgList(EKK0011D020CBSMsg.EKK0011D020CBSMSG1LIST)[0].getString(EKK0011D020CBSMsg1List.MSKM_DTL_NO);
		}
		//■「受付済」の場合、初期処理で取得した「申込番号」で次の処理に後続。
		else
		{
			mskmNo =  (String)ccMsg.get("mskm_no");
			mskmDtlNo = curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.MSKM_DTL_NO);
		}
//*********v4.00.00 追加 END**********************************

		// キャンセルを行う。
		svcCancel(handle, scCall, param, dataMapKey, mskmNo, mskmDtlNo, lastUpdDtm, curSvcKeiStat);
		
		// 割引自動適用
		execWrisvcAutoAply(handle, param, curSvcKeiInfo, dataMapKey, mskmNo);
		
		// 進捗の登録（1201:キャンセル完了）
		registProgressInfo(handle, scCall, param, dataMapKey, mskmDtlNo, "1201");
		
		//■「照査済」かつ異動区分が「住所変更・登録」でない場合⇒「お客様退会CC」を行う。
		if("020".equals(curSvcKeiStat) && !"00019".equals(ccMsg.get("ido_div")))
		{
			callCusTaikaiCmnKino(handle, param, dataMapKey);
		}
		
		// ***** 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,      curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.PCRS_CD));
		ekk0791a010IN.set(EKK0791A010CBSMsg.KEY_RSV_APLY_YMD, opeDate);
		CAANMsg[] ekk0791a010OUT
						= callSC(handle, scCall, param, dataMapKey, ekk0791a010IN).getCAANMsgList(EKK0791A010CBSMsg.EKK0791A010CBSMSG1LIST);
		
		/*--v5.00.01-------------------------*/
		//■「照査済」かつID通知書発行識別コードが「0:発行なし」でない場合⇒「指示書登録CC」を行う。
		if("020".equals(curSvcKeiStat) && !"0".equals(ekk0791a010OUT[0].getString(EKK0791A010CBSMsg1List.ID_TCHISHO_HAK_SKBT_CD)))
		{
			JKKTVSjishoAddCC jKKTVSjishoAddCC = new JKKTVSjishoAddCC();
			ccMsg.put("preSvcStat", curSvcKeiStat);
			jKKTVSjishoAddCC.mainExecute(handle, param, fixedText);
		}
		/*--v5.00.01-------------------------*/
		
		return param;
	}
	
	/**
	 * 割引ＣＣの呼出
	 * 
	 * @param handle
	 * @param param
	 * @param curCustInfo
	 * @param curSvcKeiInfo
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	private void execWrisvcAutoAply(SessionHandle handle,
									  IRequestParameterReadWrite param,
									  CAANMsg curSvcKeiInfo,
									  String dataMapKey,
									  String mskmNo) throws Throwable
	{
		// 割引サービス自動適用CC実行処理
		String workWrisvcAutoAplyDataKey = "WrisvcAutoAplyCC";
		param.setData(workWrisvcAutoAplyDataKey, new HashMap<String, Object>());
		
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		HashMap<String, Object> outMap = (HashMap<String, Object>)param.getData(workWrisvcAutoAplyDataKey);
		
		// 機能コード
		String funcCode = (String) ccMsg.get("func_code");
		
		String ido_div = (String) ccMsg.get("ido_div");
		// ＳＹＳＩＤ
		outMap.put("sysid", ccMsg.get("sysid"));
		// 登録／変更区分
		outMap.put("add_chge_div", "05");
		// 申込番号
		outMap.put("mskm_no", mskmNo);
		// 申込種別コード
		outMap.put("mskm_sbt_cd", "00020");
		// 異動区分
		outMap.put("ido_div", ido_div);
		// 機能コード
		outMap.put("func_code", funcCode);
		// キャンセル理由コード
		outMap.put("svc_cancel_rsn_cd", "10");
		// サービス契約グループリスト
		ArrayList<HashMap<String, Object>> workSvcKeiArray = new ArrayList<HashMap<String, Object>>();
		HashMap<String, Object> workSvcKeiMap = new HashMap<String, Object>();
		// グループ区分
		workSvcKeiMap.put("grp_div", "00");
		// サービス契約リスト
		ArrayList<HashMap<String, Object>> workSvcKeiList = new ArrayList<HashMap<String, Object>>();
		HashMap<String, Object> workSvcKeiData = new HashMap<String, Object>();
		// ＳＹＳＩＤ
		workSvcKeiData.put("sysid", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.SYSID));
		// 対象契約識別コード
		workSvcKeiData.put("tg_kei_skbt_cd", "01");
		// サービス契約番号
		workSvcKeiData.put("svc_kei_no", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.SVC_KEI_NO));
		// サービス契約ステータス
		workSvcKeiData.put("svc_kei_stat", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.SVC_KEI_STAT));
		// サービスコード
		workSvcKeiData.put("svc_cd", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.SVC_CD));
		// 料金グループコード
		workSvcKeiData.put("prc_grp_cd", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.PRC_GRP_CD));
		// 料金コースコード
		workSvcKeiData.put("pcrs_cd", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.PCRS_CD));
		// 料金プランコード
		workSvcKeiData.put("pplan_cd", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.PPLAN_CD));
		// サービス終了年月日
		workSvcKeiData.put("svc_endymd", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.SVC_ENDYMD));
		// サービス課金終了年月日
		workSvcKeiData.put("svc_chrg_endymd", curSvcKeiInfo.getString(EKK0081A010CBSMsg1List.SVC_CHRG_ENDYMD));
		workSvcKeiList.add(workSvcKeiData);
		workSvcKeiMap.put("svc_kei_list", workSvcKeiList);
		workSvcKeiArray.add(workSvcKeiMap);
		outMap.put("svc_kei_grp_list", workSvcKeiArray);
		
		JKKWrisvcAutoAplyCC wrisvcAutoAplyCC = new JKKWrisvcAutoAplyCC();
		wrisvcAutoAplyCC.execute(handle, param, workWrisvcAutoAplyDataKey);
		// 割引サービス契約自動適用CCからの戻り値のメッセージを取得する為、コメントアウト
//		param.removeData(workWrisvcAutoAplyDataKey);
	}
	
	/**
	 * 進捗情報を登録する。
	 * 
	 * @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,
									  String prgsStatus) throws Throwable
	{
		// 作業領域
		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"));
		ekk1091d010IN.set(EKK1091D010CBSMsg.IDO_DTM,          JCCBPCommon.getSysDateTimeStamp());
		ekk1091d010IN.set(EKK1091D010CBSMsg.PRG_STAT,         prgsStatus);									// 1931：休止受付登録完了
		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);
		
	}
	
	/**
	 * 「サービス契約キャンセル」を行う
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param dataMapKey
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private String svcCancel(SessionHandle handle, 
							  ServiceComponentRequestInvoker scCall, 
							  IRequestParameterReadWrite param,
							  String dataMapKey,
							  String mskmNo,
							  String mskmDtlNo,
							  String lastUpdDtm,
							  String curSvcKeiStat) throws Throwable
	{
		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 mskm_lastUpdDtm = (String) ccMsg.get("mskm_lastUpdDtm");
		
		// ***** EKK0081C160（サービス契約キャンセル）*****
		CAANMsg ekk0081c160IN = new CAANMsg(EKK0081C160CBSMsg.class.getName());
		ekk0081c160IN.set(EKK0081C160CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0081C160);
		ekk0081c160IN.set(EKK0081C160CBSMsg.FUNC_CODE,         funcCode);
		ekk0081c160IN.set(EKK0081C160CBSMsg.SVC_KEI_NO,        ccMsg.get("svc_kei_no"));
		ekk0081c160IN.set(EKK0081C160CBSMsg.MSKM_DTL_NO,       mskmDtlNo);
		ekk0081c160IN.set(EKK0081C160CBSMsg.SVC_CANCEL_RSN_CD, "01");
		ekk0081c160IN.set(EKK0081C160CBSMsg.IDO_DIV,           ido_div);
		ekk0081c160IN.set(EKK0081C160CBSMsg.UPD_DTM_BF,        lastUpdDtm);
		CAANMsg ekk0081c160OUT
						= callSC(handle, scCall, param, dataMapKey, ekk0081c160IN);
		
		// 最終更新年月日の取得
		lastUpdDtm = ekk0081c160OUT.getString(EKK0081C200CBSMsg.UPD_DTM);
		
		// ***** 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)
		{
/* ++++++++++ v7.00.01 追加開始 ++++++++++ */
			// サービス契約内訳ステータス＝"910":解約済 または"920":キャンセル済は対象外 
			if (JKKStrConst.CD00056_STAT_DSLZUMI.equals(curSvcKeiUcwkInfo.getString(EKK0161B004CBSMsg1List.SVC_KEI_UCWK_STAT))
					|| JKKStrConst.CD00056_STAT_CANCELZUMI.equals(curSvcKeiUcwkInfo.getString(EKK0161B004CBSMsg1List.SVC_KEI_UCWK_STAT))) 
			{
				continue;
			}
/* ++++++++++ v7.00.01 追加終了 ++++++++++ */
			
			// ***** EKK0161C160（サービス契約内訳キャンセル）*****
			CAANMsg ekk0161c160IN = new CAANMsg(EKK0161C160CBSMsg.class.getName());
			ekk0161c160IN.set(EKK0161C160CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0161C160);
			ekk0161c160IN.set(EKK0161C160CBSMsg.FUNC_CODE,         funcCode);
			ekk0161c160IN.set(EKK0161C160CBSMsg.SVC_KEI_UCWK_NO,   curSvcKeiUcwkInfo.getString(EKK0161B004CBSMsg1List.SVC_KEI_UCWK_NO));
			ekk0161c160IN.set(EKK0161C160CBSMsg.MSKM_DTL_NO,       mskmDtlNo);
			ekk0161c160IN.set(EKK0161C160CBSMsg.SVC_CANCEL_RSN_CD, "01");
			ekk0161c160IN.set(EKK0161C160CBSMsg.IDO_DIV,           ido_div);
			ekk0161c160IN.set(EKK0161C160CBSMsg.UPD_DTM_BF,        lastUpdDtm);
			CAANMsg ekk0161c160OUT
							= callSC(handle, scCall, param, dataMapKey, ekk0161c160IN);
			
			// 最終更新年月日の取得
			lastUpdDtm = ekk0161c160OUT.getString(EKK0161C160CBSMsg.UPD_DTM);
			
			// ***** 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)
			{
/* ++++++++++ v54.0.0 OM-2021-0000601 2021/07/30 ADD START ++++++++++ */
				// 機器提供サービス契約ステータス＝"910":解約済 または"920":キャンセル済は対象外 
				if (JKKStrConst.CD00056_STAT_DSLZUMI.equals(curKktkSvcKeiInfo.getString(EKK0341B501CBSMsg1List.KKTK_SVC_KEI_STAT))
					|| JKKStrConst.CD00056_STAT_CANCELZUMI.equals(curKktkSvcKeiInfo.getString(EKK0341B501CBSMsg1List.KKTK_SVC_KEI_STAT))) 
				{
					continue;
				}
/* ++++++++++ v54.0.0 OM-2021-0000601 2021/07/30 ADD END ++++++++++ */
				
				// ***** EKK0341C330（機器提供サービス契約キャンセル）*****
				CAANMsg ekk0341c330IN = new CAANMsg(EKK0341C330CBSMsg.class.getName());
				ekk0341c330IN.set(EKK0341C330CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0341C330);
				ekk0341c330IN.set(EKK0341C330CBSMsg.FUNC_CODE,         funcCode);
				ekk0341c330IN.set(EKK0341C330CBSMsg.KKTK_SVC_KEI_NO,   curKktkSvcKeiInfo.getString(EKK0341B501CBSMsg1List.KKTK_SVC_KEI_NO));
				ekk0341c330IN.set(EKK0341C330CBSMsg.MSKM_DTL_NO,       mskmDtlNo);
				ekk0341c330IN.set(EKK0341C330CBSMsg.SVC_CANCEL_RSN_CD, "01");
				ekk0341c330IN.set(EKK0341C330CBSMsg.IDO_DIV,           ido_div);
				ekk0341c330IN.set(EKK0341C330CBSMsg.UPD_DTM_BF,        lastUpdDtm);
				CAANMsg ekk0341c330OUT
								= callSC(handle, scCall, param, dataMapKey, ekk0341c330IN);
				
				// 最終更新年月日の取得
				lastUpdDtm = ekk0341c330OUT.getString(EKK0341C330CBSMsg.UPD_DTM);
				
				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));
			}
			
		}
		
		// ***** EKK0351B002（オプションサービス契約一覧照会（サービス契約番号））*****
		CAANMsg ekk0351b002IN = new CAANMsg(EKK0351B002CBSMsg.class.getName());
		ekk0351b002IN.set(EKK0351B002CBSMsg.TEMPLATEID,     TEMPLATE_ID_EKK0351B002);
		ekk0351b002IN.set(EKK0351B002CBSMsg.FUNC_CODE,      "1");
		ekk0351b002IN.set(EKK0351B002CBSMsg.KEY_SVC_KEI_NO, ccMsg.get("svc_kei_no"));
//		ekk0351b002IN.set(EKK0351B002CBSMsg.KEY_BASE_YMD,   opeDate);
		CAANMsg[] ekk0351b002OUT
						= callSC(handle, scCall, param, dataMapKey, ekk0351b002IN).getCAANMsgList(EKK0351B002CBSMsg.EKK0351B002CBSMSG1LIST);
		
		for (CAANMsg curOpSvcKeiInfo : ekk0351b002OUT)
		{
/* ++++++++++ v7.00.01 追加開始 ++++++++++ */
			// オプションサービス契約ステータス＝"910":解約済 または"920":キャンセル済は対象外 
			if (JKKStrConst.CD00056_STAT_DSLZUMI.equals(curOpSvcKeiInfo.getString(EKK0351B002CBSMsg1List.OP_SVC_KEI_STAT))
					|| JKKStrConst.CD00056_STAT_CANCELZUMI.equals(curOpSvcKeiInfo.getString(EKK0351B002CBSMsg1List.OP_SVC_KEI_STAT))) 
			{
				continue;
			}
/* ++++++++++ v7.00.01 追加終了 ++++++++++ */
			
			// ***** EKK0351C220（オプションサービス契約キャンセル）*****
			CAANMsg ekk0351c220IN = new CAANMsg(EKK0351C220CBSMsg.class.getName());
			ekk0351c220IN.set(EKK0351C220CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0351C220);
			ekk0351c220IN.set(EKK0351C220CBSMsg.FUNC_CODE,         funcCode);
			ekk0351c220IN.set(EKK0351C220CBSMsg.OP_SVC_KEI_NO,     curOpSvcKeiInfo.getString(EKK0351B002CBSMsg1List.OP_SVC_KEI_NO));
			ekk0351c220IN.set(EKK0351C220CBSMsg.MSKM_DTL_NO,       mskmDtlNo);
			ekk0351c220IN.set(EKK0351C220CBSMsg.SVC_CANCEL_RSN_CD, "01");
			ekk0351c220IN.set(EKK0351C220CBSMsg.IDO_DIV,           ido_div);
			ekk0351c220IN.set(EKK0351C220CBSMsg.UPD_DTM_BF,        lastUpdDtm);
			CAANMsg ekk0351c220OUT
							= callSC(handle, scCall, param, dataMapKey, ekk0351c220IN);
			
			// 最終更新年月日の取得
			lastUpdDtm = ekk0351c220OUT.getString(EKK0351C220CBSMsg.UPD_DTM);
		}
		
		// ***** EKK0241B001（サービス契約回線内訳一覧照会）*****
		CAANMsg ekk0241b001IN = new CAANMsg(EKK0241B001CBSMsg.class.getName());
		ekk0241b001IN.set(EKK0241B001CBSMsg.TEMPLATEID,     TEMPLATE_ID_EKK0241B001);
		ekk0241b001IN.set(EKK0241B001CBSMsg.FUNC_CODE,      "1");
		ekk0241b001IN.set(EKK0241B001CBSMsg.KEY_SVC_KEI_NO, ccMsg.get("svc_kei_no"));
		CAANMsg[] ekk0241b001OUT
						= callSC(handle, scCall, param, dataMapKey, ekk0241b001IN).getCAANMsgList(EKK0241B001CBSMsg.EKK0241B001CBSMSG1LIST);
		
		for (CAANMsg curKaiUcwkInfo : ekk0241b001OUT)
		{
			// ***** EKK0341B504（機器提供サービス契約一覧照会(サービス契約回線内訳)）*****
			CAANMsg ekk0341b504IN = new CAANMsg(EKK0341B504CBSMsg.class.getName());
			ekk0341b504IN.set(EKK0341B504CBSMsg.TEMPLATEID,                 TEMPLATE_ID_EKK0341B504);
			ekk0341b504IN.set(EKK0341B504CBSMsg.FUNC_CODE,                  funcCode);
			ekk0341b504IN.set(EKK0341B504CBSMsg.KEY_SVC_KEI_KAISEN_UCWK_NO, curKaiUcwkInfo.getString(EKK0241B001CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO));
			
			CAANMsg[] ekk0341b504OUTList
							= callSC(handle, scCall, param, dataMapKey, ekk0341b504IN).getCAANMsgList(EKK0341B504CBSMsg.EKK0341B504CBSMSG1LIST);
			
			for (CAANMsg curKaisenKiki : ekk0341b504OUTList)
			{
/* ++++++++++ v7.00.00 変更開始 ++++++++++ */
				// 機器提供サービスコード＝"C013":V-ONU 以外は対象外
				if (!JKKStrConst.CD00132_VONU.equals(curKaisenKiki.getString(EKK0341B504CBSMsg1List.KKTK_SVC_CD))) 
				{
					continue;
				}
				
				/* ++++++++++ v5.00.03 追加開始 ++++++++++ */
				// 機器提供サービス契約ステータス＝"910":解約済 または"920":キャンセル済は対象外 
				if (JKKStrConst.CD00056_STAT_DSLZUMI.equals(curKaisenKiki.getString(EKK0341B504CBSMsg1List.KKTK_SVC_KEI_STAT))
						|| JKKStrConst.CD00056_STAT_CANCELZUMI.equals(curKaisenKiki.getString(EKK0341B504CBSMsg1List.KKTK_SVC_KEI_STAT))) 
				{
					continue;
				}
				/* ++++++++++ v5.00.03 追加終了 ++++++++++ */
/* ++++++++++ v7.00.00 変更終了 ++++++++++ */
				
				// ***** EKK0341C330（機器提供サービス契約キャンセル）*****
				CAANMsg ekk0341c330IN = new CAANMsg(EKK0341C330CBSMsg.class.getName());
				ekk0341c330IN.set(EKK0341C330CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0341C330);
				ekk0341c330IN.set(EKK0341C330CBSMsg.FUNC_CODE,         funcCode);
				ekk0341c330IN.set(EKK0341C330CBSMsg.KKTK_SVC_KEI_NO,   curKaisenKiki.getString(EKK0341B504CBSMsg1List.KKTK_SVC_KEI_NO));
				ekk0341c330IN.set(EKK0341C330CBSMsg.MSKM_DTL_NO,       mskmDtlNo);
				ekk0341c330IN.set(EKK0341C330CBSMsg.SVC_CANCEL_RSN_CD, "01");
				ekk0341c330IN.set(EKK0341C330CBSMsg.IDO_DIV,           ido_div);
				ekk0341c330IN.set(EKK0341C330CBSMsg.UPD_DTM_BF,        lastUpdDtm);
				CAANMsg ekk0341c330OUT
								= callSC(handle, scCall, param, dataMapKey, ekk0341c330IN);
				
				// 最終更新年月日の取得
				lastUpdDtm = ekk0341c330OUT.getString(EKK0341C330CBSMsg.UPD_DTM);
				
			}
/* ++++++++++ v5.00.00 変更開始 ++++++++++ */
//			// ***** EKK0081B011（同一利用場所サービス契約一覧照会）*****
//			CAANMsg ekk0081b011IN = new CAANMsg(EKK0081B011CBSMsg.class.getName());
//			ekk0081b011IN.set(EKK0081B011CBSMsg.TEMPLATEID,                 TEMPLATE_ID_EKK0081B011);
//			ekk0081b011IN.set(EKK0081B011CBSMsg.FUNC_CODE,                  "1");
//			ekk0081b011IN.set(EKK0081B011CBSMsg.KEY_SYSID,                  ccMsg.get("sysid"));
//			ekk0081b011IN.set(EKK0081B011CBSMsg.KEY_SVC_KEI_KAISEN_UCWK_NO, curKaiUcwkInfo.getString(EKK0241B001CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO));
//			CAANMsg[] ekk0081b011OUTList
//							= callSC(handle, scCall, param, dataMapKey, ekk0081b011IN).getCAANMsgList(EKK0081B011CBSMsg.EKK0081B011CBSMSG1LIST);
//			
//			// サービス回線内訳に紐づく他のサービスが存在し、そちらが有効である場合は、更新しない。
//			// 他のサービス（ネットや電話）が存在し、そちらが有効である場合は、回線が使用中となっているはず。
//			if (ekk0081b011OUTList.length > 0)
//			{
//				continue;
//			}
			// ***** EKK0081B035（同一利用場所サービス契約一覧照会）*****
			CAANMsg ekk0081b035IN = new CAANMsg(EKK0081B035CBSMsg.class.getName());
			ekk0081b035IN.set(EKK0081B035CBSMsg.TEMPLATEID,                 TEMPLATE_ID_EKK0081B035);
			ekk0081b035IN.set(EKK0081B035CBSMsg.FUNC_CODE,                  "1");
			ekk0081b035IN.set(EKK0081B035CBSMsg.KEY_SYSID,                  ccMsg.get("sysid"));
			ekk0081b035IN.set(EKK0081B035CBSMsg.KEY_SVC_KEI_KAISEN_UCWK_NO, curKaiUcwkInfo.getString(EKK0241B001CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO));
			CAANMsg[] ekk0081b035OUTList
							= callSC(handle, scCall, param, dataMapKey, ekk0081b035IN).getCAANMsgList(EKK0081B035CBSMsg.EKK0081B035CBSMSG1LIST);
			
			// サービス回線内訳に紐づく他のサービスが存在し、そちらが有効である場合は、更新しない。
			// 他のサービス（ネットや電話）が存在し、そちらが有効である場合は、回線が使用中となっているはず。
			if (ekk0081b035OUTList.length > 0)
			{
				continue;
			}
/* ++++++++++ v5.00.00 変更終了 ++++++++++ */			
			// OM-2014-0001878 テレビ契約キャンセル処理のサービス契約回線内訳キャンセル時に状態遷移チェックエラーが発生 2014/05/30 START
			String svcKeiKaisenUcwkStat = curKaiUcwkInfo.getString(EKK0241B001CBSMsg1List.SVC_KEI_KAISEN_UCWK_STAT);
			// サービス契約回線内訳ステータスが受付済の場合
			if (JKKStrConst.CD00054_010.equals(svcKeiKaisenUcwkStat))
			{
			// OM-2014-0001878 テレビ契約キャンセル処理のサービス契約回線内訳キャンセル時に状態遷移チェックエラーが発生 2014/05/30 END
				// ***** EKK0251C070（サービス契約回線内訳キャンセル）*****
				CAANMsg ekk0251c070IN = new CAANMsg(EKK0251C070CBSMsg.class.getName());
				ekk0251c070IN.set(EKK0251C070CBSMsg.TEMPLATEID,             TEMPLATE_ID_EKK0251C070);
				ekk0251c070IN.set(EKK0251C070CBSMsg.FUNC_CODE,              funcCode);
				ekk0251c070IN.set(EKK0251C070CBSMsg.SVC_KEI_KAISEN_UCWK_NO, curKaiUcwkInfo.getString(EKK0241B001CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO));
				ekk0251c070IN.set(EKK0251C070CBSMsg.MSKM_DTL_NO,            mskmDtlNo);
				ekk0251c070IN.set(EKK0251C070CBSMsg.SVC_CANCEL_RSN_CD,      "01");
				ekk0251c070IN.set(EKK0251C070CBSMsg.UPD_DTM_BF,             lastUpdDtm);
				CAANMsg ekk0251c070OUT
								= callSC(handle, scCall, param, dataMapKey, ekk0251c070IN);
				
				// 最終更新年月日の取得
				lastUpdDtm = ekk0251c070OUT.getString(EKK0251C070CBSMsg.UPD_DTM);
			// OM-2014-0001878 テレビ契約キャンセル処理のサービス契約回線内訳キャンセル時に状態遷移チェックエラーが発生 2014/05/30 START
			}
			// ※回線が使用中の場合、何もしない（ネット、電話のキャンセル処理と同様にする）
			// OM-2014-0001878 テレビ契約キャンセル処理のサービス契約回線内訳キャンセル時に状態遷移チェックエラーが発生 2014/05/30 END
		}

//*********v4.01.00 追加 START********************************
//■申込、申込明細キャンセル
		// キャンセル前ステータスが「受付済」の場合
		if ("010".equals(curSvcKeiStat))
		{
			boolean isAlive = false;
			
			// ***** EKK0011B020_申込サービス契約内訳一覧照会 *****
			CAANMsg eKK0011B020IN = new CAANMsg(EKK0011B020CBSMsg.class.getName());
			eKK0011B020IN.set(EKK0011B020CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0011B020);
			eKK0011B020IN.set(EKK0011B020CBSMsg.FUNC_CODE,         "1");
			// ＫＥＹ＿申込番号
			eKK0011B020IN.set(EKK0011B020CBSMsg.KEY_MSKM_NO, mskmNo);
			// ＫＥＹ＿予約適用年月日
			eKK0011B020IN.set(EKK0011B020CBSMsg.KEY_RSV_APLY_YMD, JPCBPCommon.getOpeDate(null));
		
			CAANMsg[] eKK0011B020OUTList = callSC(handle, scCall, param, dataMapKey, eKK0011B020IN).getCAANMsgList(EKK0011B020CBSMsg.EKK0011B020CBSMSG1LIST);

			for (CAANMsg statusInfo : eKK0011B020OUTList)
			{
				// 今からキャンセルする申込明細は判定しない
				if(mskmDtlNo.equals(statusInfo.getString(EKK0011B020CBSMsg1List.MSKM_DTL_NO)))
				{
					continue;
				}
				
				//「サービス契約番号」取得
				String svcKeiNo = statusInfo.getString(EKK0011B020CBSMsg1List.SVC_KEI_NO);
				//「申込明細ステータス」取得
				String mskmDtlStat = statusInfo.getString(EKK0011B020CBSMsg1List.MSKM_DTL_STAT);
				
				if(svcKeiNo != null && !"".equals(svcKeiNo))
				{
					if(!MSKM_DTL_STAT_CANCEL.equals(mskmDtlStat))
					{
						isAlive = true;
					}
				}
			}
			
			// 申込に紐付く申込明細が全てキャンセル済みか存在しなかった場合
			if(!isAlive)
			{
				// ***** EKK0011C060（申込キャンセル）*****
				CAANMsg eKK0011C060IN = new CAANMsg(EKK0011C060CBSMsg.class.getName());
				eKK0011C060IN.set(EKK0011C060CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0011C060);
				eKK0011C060IN.set(EKK0011C060CBSMsg.FUNC_CODE,         funcCode);
				eKK0011C060IN.set(EKK0011C060CBSMsg.MSKM_NO,       mskmNo);
				eKK0011C060IN.set(EKK0011C060CBSMsg.MSKM_CANCEL_RSN_CD,       "30");
				eKK0011C060IN.set(EKK0011C060CBSMsg.CONSMBSN_MSKM_STAT_SKBT_CD,       "04");
				eKK0011C060IN.set(EKK0011C060CBSMsg.KK0011_UPD_DTM_BF,       mskm_lastUpdDtm);
				
				CAANMsg[] templateArray = new CAANMsg[1];
				templateArray[0] = new CAANMsg(EKK0011C060CBSMsg1List.class.getName());
				templateArray[0].set(EKK0011C060CBSMsg1List.MSKM_DTL_NO, mskmDtlNo);
				templateArray[0].set(EKK0011C060CBSMsg1List.MSKM_DTL_CANCEL_RSN_CD, "30");
				eKK0011C060IN.set(EKK0011C060CBSMsg.EKK0011C060CBSMSG1LIST,       templateArray);
				callSC(handle, scCall, param, dataMapKey, eKK0011C060IN);
			}
			else
			{
				// ***** EKK0021C070（申込明細キャンセル）*****
				CAANMsg eKK0021C070IN = new CAANMsg(EKK0021C070CBSMsg.class.getName());
				eKK0021C070IN.set(EKK0021C070CBSMsg.TEMPLATEID,        TEMPLATE_ID_EKK0021C070);
				eKK0021C070IN.set(EKK0021C070CBSMsg.FUNC_CODE,         funcCode);
				eKK0021C070IN.set(EKK0021C070CBSMsg.MSKM_DTL_NO,       mskmDtlNo);
				eKK0021C070IN.set(EKK0021C070CBSMsg.MSKM_DTL_CANCEL_RSN_CD,       "30");
				eKK0021C070IN.set(EKK0021C070CBSMsg.UPD_DTM_BF,        mskm_lastUpdDtm);
				callSC(handle, scCall, param, dataMapKey, eKK0021C070IN);
			}
		}
//*********v4.01.00 追加 END********************************
		// ▼▼▼▼▼OM-2018-0000597 2018/06/19 ADD START▼▼▼▼▼
		// サービス契約ステータスが照査済かつ、工事案件番号が取得でき、工事案件ステータスが130の場合
		if ("020".equals(curSvcKeiStat) && ccMsg.get("kojiak_no") != null && !"".equals(ccMsg.get("kojiak_no")) && "130".equals(ccMsg.get("kojiak_stat")))
		{
			// ***** EKU0091C010 工事案件取消 *****
			CAANMsg eKU0091C010IN = new CAANMsg(EKU0091C010CBSMsg.class.getName());
			eKU0091C010IN.set(EKU0091C010CBSMsg.TEMPLATEID,            TEMPLATE_ID_EKU0091C010);
			eKU0091C010IN.set(EKU0091C010CBSMsg.FUNC_CODE,              funcCode);
			eKU0091C010IN.set(EKU0091C010CBSMsg.SVC_KEI_NO,             ccMsg.get("svc_kei_no"));
			eKU0091C010IN.set(EKU0091C010CBSMsg.SVC_KEI_KAISEN_UCWK_NO, ccMsg.get("svc_kei_kaisen_ucwk_no"));
			eKU0091C010IN.set(EKU0091C010CBSMsg.MSKM_DTL_NO,            mskmDtlNo);
			eKU0091C010IN.set(EKU0091C010CBSMsg.KOJIAK_NO,              ccMsg.get("kojiak_no"));
			eKU0091C010IN.set(EKU0091C010CBSMsg.KOJI_UK_CD,             "002");
			eKU0091C010IN.set(EKU0091C010CBSMsg.KOJI_UK_DTAIL_CD,       "C0");
			eKU0091C010IN.set(EKU0091C010CBSMsg.KOJI_UK_OPTNTY_IDO_DTM, JPCBPCommon.getOpeDateTimeStamp(null));
			eKU0091C010IN.set(EKU0091C010CBSMsg.KOJIAK_CANCEL_YMD,      JPCBPCommon.getOpeDate(null));
			callSC(handle, scCall, param, dataMapKey, eKU0091C010IN);
		}
		// ▲▲▲▲▲OM-2018-0000597 2018/06/19 ADD END▲▲▲▲▲
		
		return lastUpdDtm;
	}
	
	/**
	 * 申込内容承認登録、申込明細照査・後続業務依頼のサービスインターフェイスを実行し、採番された申込明細番号を返却します。
	 * 
	 * @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;
	}
	
	/**
	 * お客様退会共通機能を呼び出す。
	 * 
	 * @param handle
	 * @param param
	 * @param dataMapKey
	 * @return void
	 */
	@SuppressWarnings("unchecked")
	private void callCusTaikaiCmnKino(
			SessionHandle handle, 
			IRequestParameterReadWrite param, 
			String dataMapKey) throws Throwable
	{
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		
		// マップ生成
		HashMap<String, Object> taikaiCCMap = new HashMap<String, Object>();
		
		// マップ編集
		taikaiCCMap.put("sysid", ccMsg.get("sysid"));
		taikaiCCMap.put("svc_kei_no", ccMsg.get("svc_kei_no"));
		taikaiCCMap.put(JCMConstants.FUNC_CODE_KEY, ccMsg.get("func_code") );
		param.setData("JCKCustTaikaiCmnCC", taikaiCCMap);
		
		JCKCustTaikaiCmnCC jCKCustTaikaiCmnCC = new JCKCustTaikaiCmnCC();
		jCKCustTaikaiCmnCC.execute(handle, param, "JCKCustTaikaiCmnCC");
	}
	
	/**
	 * 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;
	}
}
