/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JKKFamipaWribOperateMapperCC
*   ソースファイル名：JKKFamipaWribOperateMapperCC.java
*   作成者          ：FJ
*   日付            ：2014年04月01日
*＜機能概要＞
*   ファミリーパック割引操作部品
*＜修正履歴＞
*   バージョン  修正日      修正者      修正内容
*	v8.00.00	2014/04/01	FJ)藤原		新規作成(ANK-1988-00-00)
*	v8.00.01	2014/04/15	FJ)藤原		IT1-2014-0000106
*	v8.00.02	2014/05/14	FJ)福岡		OM-2014-0001834
*	v32.00.00	2017/05/30	FJ)清原		IT2-2017-0000013 セキュリティーパック、プレミアムパックが解約されない
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
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.parameter.IRequestParameterReadWrite;
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 com.fujitsu.futurity.model.ejb.common.JSYejbLog;

import eo.common.constant.JKKStrConst;
import eo.common.util.JPCDateUtil;
import eo.ejb.cbs.cbsmsg.EKK0451A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0451A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0451B005CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0451C020CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0451C030CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0451C070CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0481B002CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg1List;

/**
 * ファミリーパック割引操作部品CC CC-SCマッピングクラス
 * 
 * @author 富士通
 */
public class JKKFamipaWribOperateMapperCC
{
	/** SC呼び出し部品 */
	private ServiceComponentRequestInvoker scCall = null;
	/** セッションハンドル */
	private SessionHandle handle = null;
	/** 業務データ取得用I/F */
	private IRequestParameterReadWrite param = null;
	/** オンライン運用日付 */
	private String opeDate = null;
	
	/** 割引サービス契約一意照会 */
	private final String EKK0451A010 = "EKK0451A010";
	/** 割引サービス対象契約一覧照会 */
	private final String EKK0481B002 = "EKK0481B002";
	/** 割引サービス契約解約 */
	private final String EKK0451C020 = "EKK0451C020";
	/** 割引サービス契約解約確定 */
	private final String EKK0451C030 = "EKK0451C030";
	/** 割引サービス契約キャンセル */
	private final String EKK0451C070 = "EKK0451C070";
	/** 進捗登録 */
	private final String EKK1091D010 = "EKK1091D010";
	
	/**
	 * 
	 * 進捗ステータス（ファミリーパック取消完了）
	 * 
	 * [キャンセル][解約]時に使用する
	 */
	private final String PRG_STAT_FAMIRY_PACK_DEL_FIN = "5111";
	
	/**
	 * 
	 * リクエストパラメータのキー定数
	 * 
	 * ・サービス契約番号
	 * ・解約起算日
	 * ・解約理由コード
	 * ・キャンセル理由コード
	 * ・申込明細番号
	 * ・異動区分
	 * 
	 */
	private final String KEY_SVC_KEI_NO         = "svc_kei_no";
	private final String KEY_SVC_DSL_KISAN_YMD  = "svc_dsl_ymd";
	private final String KEY_SVC_DLRE_CD        = "svc_dlre_cd";
	private final String KEY_MSKM_DTL_NO        = "mskm_dtl_no";
	private final String KEY_CANCEL_CD          = "svc_cancel_cd";
	private final String KEY_IDO_DIV            = "ido_div";
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>コンストラクタ<br>
	 * <dt>処理補足：
	 * <dd>フィールド変数の値を設定する<br>
	 * </dl>
	 * 
	 * @param iCmnHandle セッションハンドル
	 * @param iCmnParam 業務データ取得用I/F
	 * @param iOpeDate オンライン運用日付
	 */
	public JKKFamipaWribOperateMapperCC(SessionHandle iCmnHandle,
										IRequestParameterReadWrite iCmnParam,
										String iOpeDate) {
		this.handle = iCmnHandle;
		this.param = iCmnParam;
		this.opeDate = iOpeDate;
		this.scCall = new ServiceComponentRequestInvoker();
	}

	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>デバッグログを出力する<br>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param dumpObj 出力するオブジェクト
	 */
	@SuppressWarnings("static-access")
	private void printlnEjbLog(Object dumpObj) {
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), dumpObj, null, null, null);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>持ちうるフィールドにNullマッピングで埋める<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param msg 対象クラス
	 * @param contents 対応クラスのフィールド列挙
	 */
	private void fillCAANMSGNullMapping(CAANMsg msg, Object[][] contents) {
		
		// 要素ごとのループ
		for (int i = 0; i < contents.length; i++) {

			Object element = null;

			// キーに該当する箇所の取得
			element = contents[i][0];
			// Nullでマッピング
			msg.setNull((String) element);
		}
	}

	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>S/IF呼出時の共通情報を設定する<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param template 条件の設定先
	 * @throws Throwable
	 */
	private void templateCommonInfo(CAANMsg template) throws Throwable {
		
		// オペレータID
		Object operatorId = this.param.getControlMapData(SCControlMapKeys.OPERATOR_ID);
		template.set(JCMConstants.OPERATOR_ID_KEY, operatorId);

		// 運用日付
		Object operateDate = this.param.getControlMapData(SCControlMapKeys.OPE_DATE);
		template.set(JCMConstants.OPERATE_DATE_KEY, operateDate);

		// 運用日時
		Object operateDateTime = this.param.getControlMapData(SCControlMapKeys.OPE_TIME);
		template.set(JCMConstants.OPERATE_DATETIME_KEY, operateDateTime);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>SCインプット共通データ設定処理です。<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param inMap
	 * @return パラメータマップ
	 * @throws Throwable
	 */
	private HashMap<String, Object> setSCInputCommonData(HashMap<String, Object> inMap) throws Throwable {
		
		/* SCインプット共通データ */
		// **********************************************
		// 【取得元：電文ヘッダ(ヘッダ)】
		// **********************************************
		// 電文ID
		inMap.put(JCMConstants.TRANZACTION_ID_KEY, this.param.getTelegramID());
		// ユースケースID
		inMap.put(JCMConstants.USECASE_ID_KEY, this.param.getUsecaseID());
		// オペレーションID
		inMap.put(JCMConstants.OPERATION_ID_KEY, this.param.getOperationID());
		// サービス呼び出し区分
		inMap.put(JCMConstants.CALL_TYPE_KEY, this.param.getCallType());

		// **********************************************
		// 【取得元：ユーザエリア(コントロールマップ)】
		// **********************************************
		// 依頼先ホスト名
		inMap.put(JCMConstants.CLIENT_HOST_NAME_KEY, this.param.getControlMapData(SCControlMapKeys.REQ_HOSTNAME));
		// 依頼元IPアドレス
		inMap.put(JCMConstants.CLIENT_IP_ADDRESS_KEY, this.param.getControlMapData(SCControlMapKeys.REQ_HOSTIP));
		// 依頼元画面ID
		inMap.put(JCMConstants.INVOKE_GAMEN_ID_KEY, this.param.getControlMapData(SCControlMapKeys.REQ_VIEWID));
		// オペレータID
		inMap.put(JCMConstants.OPERATOR_ID_KEY, this.param.getControlMapData(SCControlMapKeys.OPERATOR_ID));

		return inMap;
	}

	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>呼び出したサービスIFの処理結果を判定する.<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param result
	 * @throws Throwable
	 */
	@SuppressWarnings("boxing")
	private void checkExecutionResult(Map<?, ?> result) throws Throwable {
		
		// 取得したリターンコード、ステータスの内容を見て異常かどうかの判断をする。
		String rtnCode = result.get(JCMConstants.RET_CD_INT_KEY).toString();
		CAANMsg[] templates = (CAANMsg[])result.get(JCMConstants.TEMPLATE_LIST_KEY);
		Integer status = templates[0].getInt(JCMConstants.STATUS_INT_KEY);
		
		// 異常の場合、SCCallExceptionを生成してスローする
		if (!("0".equals(rtnCode) && 0 == status.intValue()))
		{
			SCCallException scCallEx = new SCCallException("戻り値不正", rtnCode, status);
			throw scCallEx;
		}
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービスIFの結果を取得する<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param rsltMap サービスIFリスト
	 * @return templateList 結果が格納されたリスト
	 * @throws Throwable 
	 */
	private ArrayList<CAANMsg> getRsltList(Map<?, ?> rsltMap) {
		
		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[])rsltMap.get(JCMConstants.TEMPLATE_LIST_KEY);
		ArrayList<CAANMsg> resultList = new ArrayList<CAANMsg>(Arrays.asList(templates));
		return resultList;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービスコンポーネント実行後に、IRequestParameterReadWriteに必要なデータをマッピングする<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param param 
	 * @param mapName 
	 * @return templateList 結果が格納されたリスト
	 * @throws Throwable 
	 */
	@SuppressWarnings({ "unchecked", "cast", "boxing" })
	public IRequestParameterReadWrite editResultRP(Map<?, ?> msgList,
													@SuppressWarnings("hiding") IRequestParameterReadWrite param,
													String mapName) throws Throwable {
		
		// 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);
		}
		
		// 結果を詰めるマップを取得。
		HashMap dataMap = null;

		/* 業務データ設定 */
		dataMap = (HashMap)param.getData(mapName);
		if (dataMap == null) {
			dataMap = new HashMap();
			param.setData(mapName, dataMap);
		}

		// エラー情報の設定
		param = editErrorInfo(param, templates, (Integer)return_code, mapName);

		//エラー情報のマップを取得
		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;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>割引サービス契約一意照会サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd
	 * @param  wribSvcKeiNo
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg[] callEKK0451A010(String funcCd, String wribSvcKeiNo) throws Throwable {
		
		printlnEjbLog("callEKK0451A010 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 割引サービス契約一意照会サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0451A010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0451A010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0451A010CBSMsg.TEMPLATEID, this.EKK0451A010);
		// 機能コード
		template.set(EKK0451A010CBSMsg.FUNC_CODE, funcCd);

		// 割引サービス契約番号
		template.set(EKK0451A010CBSMsg.KEY_WRIB_SVC_KEI_NO, wribSvcKeiNo);
		// 予約適用年月日
		template.set(EKK0451A010CBSMsg.KEY_RSV_APLY_YMD, this.opeDate);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0451A010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0451List = getRsltList(result);
		
		CAANMsg kk0451 = kk0451List.get(0);
		CAANMsg[] ret = kk0451.getCAANMsgList(EKK0451A010CBSMsg.EKK0451A010CBSMSG1LIST);
		
		printlnEjbLog("callEKK0451A010 end");
		return ret;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>自動解除対象割引サービス対象契約一覧照会サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  svcKeiNo
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg[] callEKK0481B002(String funcCd, String svcKeiNo) throws Throwable {
		printlnEjbLog("callEKK0481B002 start");
		
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 自動解除対象割引サービス対象契約一覧照会サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0481B002CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0481B002CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0481B002CBSMsg.TEMPLATEID, this.EKK0481B002);
		// 機能コード
		template.set(EKK0481B002CBSMsg.FUNC_CODE, funcCd);
		
		// サービス契約番号
		template.set(EKK0481B002CBSMsg.KEY_SVC_KEI_NO, svcKeiNo);

		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0481B002);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0481List = getRsltList(result);
		
		CAANMsg kk0481 = kk0481List.get(0);
		CAANMsg[] ret  = kk0481.getCAANMsgList(EKK0481B002CBSMsg.EKK0481B002CBSMSG1LIST);
		
		printlnEjbLog("callEKK0481B002 end");
		return ret;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>割引サービス契約解約サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  msg
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK0451C020(String funcCd, Map<String, Object> ccMapWork, CAANMsg msg) throws Throwable {
		printlnEjbLog("callEKK0451C020 start");
		
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 割引サービス契約解約サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0451C020CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0451C020CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0481B002CBSMsg.TEMPLATEID, this.EKK0451C020);
		// 機能コード
		template.set(EKK0481B002CBSMsg.FUNC_CODE, funcCd);
		
		/* 業務 ↓↓ ここから ================================================================================= */
		
		// 割引サービス契約番号 
		template.set(EKK0451C020CBSMsg.WRIB_SVC_KEI_NO, msg.getString(EKK0451A010CBSMsg1List.WRIB_SVC_KEI_NO));
		// 予約適用開始希望年月日
/* v8.00.01 MOD START                    ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
//		template.set(EKK0451C020CBSMsg.RSV_TSTA_KIBO_YMD, JPCDateUtil.addDay((String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD), 1));
		template.set(EKK0451C020CBSMsg.RSV_TSTA_KIBO_YMD, this.opeDate);
/* v8.00.01 MOD END                      ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
		// 申込明細番号
		template.set(EKK0451C020CBSMsg.MSKM_DTL_NO, ccMapWork.get(this.KEY_MSKM_DTL_NO));
		
// v8.00.02 MOD START
		
//		// プラン終了種別コード：3(強制解約による終了)
//		template.set(EKK0451C020CBSMsg.PLAN_END_SBT_CD, "3");
		
		// プラン終了種別コード（住変時は「通常解約」、以外は「強制解約」）
		template.set(EKK0451C020CBSMsg.PLAN_END_SBT_CD, "00019".equals(ccMapWork.get(this.KEY_IDO_DIV)) ? "2" : "3");
// v8.00.02 MOD END
		
		// サービス終了年月日
/* v8.00.01 MOD START                    ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
//		template.set(EKK0451C020CBSMsg.SVC_ENDYMD, JPCDateUtil.addDay((String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD), 1));
		template.set(EKK0451C020CBSMsg.SVC_ENDYMD, this.opeDate);
/* v8.00.01 MOD END                      ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
		// プラン課金開始年月日
// v32.00.00 Mod Start
//		template.set(EKK0451C020CBSMsg.PLAN_CHRG_STAYMD, msg.getString(EKK0451A010CBSMsg1List.PLAN_CHRG_STAYMD));
		template.set(EKK0451C020CBSMsg.PLAN_CHRG_STAYMD, getSvcChrgStaYmd(msg.getString(EKK0451A010CBSMsg1List.SVC_STA_YMD)
				, msg.getString(EKK0451A010CBSMsg1List.SVC_CHRG_STAYMD)
				, (String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD)));
// v32.00.00 Mod End
		
		// サービス課金開始年月日
// v32.00.00 Mod Start
//		template.set(EKK0451C020CBSMsg.SVC_CHRG_STAYMD,  msg.getString(EKK0451A010CBSMsg1List.SVC_CHRG_STAYMD));
		template.set(EKK0451C020CBSMsg.SVC_CHRG_STAYMD, getSvcChrgStaYmd(msg.getString(EKK0451A010CBSMsg1List.SVC_STA_YMD)
				, msg.getString(EKK0451A010CBSMsg1List.SVC_CHRG_STAYMD)
				, (String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD)));
// v32.00.00 Mod End
		
		// サービス課金終了年月日算出フラグ
		template.set(EKK0451C020CBSMsg.SVC_CHRG_ENDYMD_FLG, "0");
		// サービス課金終了年月日
		template.set(EKK0451C020CBSMsg.SVC_CHRG_ENDYMD, JPCDateUtil.addDay((String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD), -1));
		// サービス解約年月日
/* v8.00.01 MOD START                    ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
//		template.set(EKK0451C020CBSMsg.SVC_DSL_YMD, JPCDateUtil.addDay((String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD), 1));
		template.set(EKK0451C020CBSMsg.SVC_DSL_YMD, this.opeDate);
/* v8.00.01 MOD END                      ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
		// サービス解約理由コード
		template.set(EKK0451C020CBSMsg.SVC_DLRE_CD, ccMapWork.get(this.KEY_SVC_DLRE_CD));
		// サービス解約理由メモ：null
		// 違約金発生コード：無
		template.set(EKK0451C020CBSMsg.PNLTY_HASSEI_CD, "0");
		// 異動区分
		template.set(EKK0451C020CBSMsg.IDO_DIV, ccMapWork.get(this.KEY_IDO_DIV));
		// 解約理由：自動解除
		template.set(EKK0451C020CBSMsg.WRIB_DSL_CNCL_OPTY_CD, "1");
		// 更新年月日時分秒(更新前)
		template.set(EKK0451C020CBSMsg.UPD_DTM_BF, msg.getString(EKK0451A010CBSMsg1List.LAST_UPD_DTM));
		
		/* 業務 ↑↑ ここまで ================================================================================= */
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0451C020);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0451List = getRsltList(result);
		
		printlnEjbLog("callEKK0451C020 end");
		return kk0451List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>割引サービス契約解約確定サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  tgMsg
	 * @param  resMsg
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK0451C030(String funcCd, Map<String, Object> ccMapWork, CAANMsg tgMsg, CAANMsg resMsg) throws Throwable {
		printlnEjbLog("callEKK0451C030 start");
		
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 割引サービス契約解約確定サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0451C030CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0451C030CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0451C030CBSMsg.TEMPLATEID, this.EKK0451C030);
		// 機能コード
		template.set(EKK0451C030CBSMsg.FUNC_CODE, funcCd);
		
		/* 業務 ↓↓ ここから ================================================================================= */
		
		// 割引サービス契約番号
		template.set(EKK0451C030CBSMsg.WRIB_SVC_KEI_NO, tgMsg.getString(EKK0451A010CBSMsg1List.WRIB_SVC_KEI_NO));
		// 世代登録年月日時分秒
		template.set(EKK0451C030CBSMsg.GENE_ADD_DTM, resMsg.getString(EKK0451A010CBSMsg1List.GENE_ADD_DTM));
		// サービス終了年月日
/* v8.00.01 MOD START                    ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
//		template.set(EKK0451C030CBSMsg.SVC_ENDYMD, JPCDateUtil.addDay((String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD), 1));
		template.set(EKK0451C030CBSMsg.SVC_ENDYMD, this.opeDate);
/* v8.00.01 MOD END                      ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
		// サービス課金終了年月日
		template.set(EKK0451C030CBSMsg.SVC_CHRG_ENDYMD,  JPCDateUtil.addDay((String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD), -1));
		// サービス解約年月日
/* v8.00.01 MOD START                    ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
//		template.set(EKK0451C030CBSMsg.SVC_DSL_YMD, JPCDateUtil.addDay((String)ccMapWork.get(this.KEY_SVC_DSL_KISAN_YMD), 1));
		template.set(EKK0451C030CBSMsg.SVC_DSL_YMD, this.opeDate);
/* v8.00.01 MOD END                      ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
		// サービス解約理由コード 01.通常解約
		template.set(EKK0451C030CBSMsg.SVC_DLRE_CD, ccMapWork.get(this.KEY_SVC_DLRE_CD));
		// サービス解約理由メモ：null
		// 更新年月日時分秒(更新前)
		template.set(EKK0451C030CBSMsg.UPD_DTM_BF, resMsg.getString(EKK0451A010CBSMsg1List.UPD_DTM));
		
		/* 業務 ↑↑ ここまで ================================================================================= */
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);
		
		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0451C030);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0451List = getRsltList(result);
		
		printlnEjbLog("callEKK0451C030 end");
		return kk0451List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>割引サービス契約キャンセルサービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  msg
	 * @param  svcMsg
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK0451C070(String funcCd, Map<String, Object> ccMapWork, CAANMsg msg) throws Throwable {
		printlnEjbLog("callEKK0451C070 start");
		
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 割引サービス契約解約サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0451C070CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0451C070CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0451C070CBSMsg.TEMPLATEID, this.EKK0451C070);
		// 機能コード
		template.set(EKK0451C070CBSMsg.FUNC_CODE, funcCd);
		
		/* 業務 ↓↓ ここから ================================================================================= */
		
		// 割引サービス契約番号 
		template.set(EKK0451C070CBSMsg.WRIB_SVC_KEI_NO, msg.getString(EKK0451A010CBSMsg1List.WRIB_SVC_KEI_NO));
		// 申込明細番号
		template.set(EKK0451C070CBSMsg.MSKM_DTL_NO, ccMapWork.get(this.KEY_MSKM_DTL_NO));
		// サービスキャンセル理由コード:強制解約によるキャンセル
		template.set(EKK0451C070CBSMsg.SVC_CANCEL_RSN_CD, ccMapWork.get(this.KEY_CANCEL_CD));
		// 異動区分
		template.set(EKK0451C070CBSMsg.IDO_DIV, ccMapWork.get(this.KEY_IDO_DIV));
		// 解約キャンセル契機コード：自動解除
		template.set(EKK0451C070CBSMsg.WRIB_DSL_CNCL_OPTY_CD, "1");
		// 更新年月日時分秒(更新前)
		template.set(EKK0451C070CBSMsg.UPD_DTM_BF, msg.getString(EKK0451A010CBSMsg1List.LAST_UPD_DTM));
		
		/* 業務 ↑↑ ここまで ================================================================================= */
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0451C070);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0451List = getRsltList(result);
		
		printlnEjbLog("callEKK0451C070 end");
		return kk0451List.get(0);
		
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>進捗登録サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param wribSvcCd 
	 * @return 
	 * @throws Throwable
	 */
//v32.00.00 Mod Start
//	public CAANMsg[] callEKK1091D010(String funcCd, Map<String, Object> ccMapWork) throws Throwable {
	public CAANMsg[] callEKK1091D010(String funcCd, Map<String, Object> ccMapWork, String wribSvcCd) throws Throwable {
//v32.00.00 Mod End
		printlnEjbLog("callEKK1091D010 start");
		
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 進捗登録サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK1091D010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK1091D010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK1091D010CBSMsg.TEMPLATEID, this.EKK1091D010);
		// 機能コード
		template.set(EKK1091D010CBSMsg.FUNC_CODE, funcCd);
		
		// 申込明細番号
		template.set(EKK1091D010CBSMsg.MSKM_DTL_NO, ccMapWork.get(this.KEY_MSKM_DTL_NO));
		// サービス契約番号
		template.set(EKK1091D010CBSMsg.SVC_KEI_NO, ccMapWork.get(this.KEY_SVC_KEI_NO));
		// 異動区分
		template.set(EKK1091D010CBSMsg.IDO_DIV, ccMapWork.get(this.KEY_IDO_DIV));
		// 異動年月日時分秒
		template.set(EKK1091D010CBSMsg.IDO_DTM, JCCBPCommon.getSysDateTimeStamp());
		// 進捗ステータス
		//v32.00.00 Mod Start
//		template.set(EKK1091D010CBSMsg.PRG_STAT, this.PRG_STAT_FAMIRY_PACK_DEL_FIN);
		template.set(EKK1091D010CBSMsg.PRG_STAT, setPrgStat(wribSvcCd));
		//v32.00.00 Mod End
		// 異動理由明細
		template.set(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST, idouReasenDtl());
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK1091D010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk1091List = getRsltList(result);
		
		CAANMsg kk1091 = kk1091List.get(0);
		CAANMsg[] ret  = kk1091.getCAANMsgList(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST);
		
		printlnEjbLog("callEKK1091D010 end");
		return ret;
	}
	//v32.00.00 Add Start

	/**
	 * 進捗ステータスを設定
	 * @param wribSvcCd 割引サービスコード
	 * @return 進捗ステータス
	 */
	private String setPrgStat(String wribSvcCd) 
	{
		// ファミリーパック割引の場合、「ファミリーパック取消完了」を設定
		if(JKKStrConst.WRIB_SVC_FAMIPA.equals(wribSvcCd))
		{
			return this.PRG_STAT_FAMIRY_PACK_DEL_FIN;
		}
		// セキュリティパックの場合、「セキュリティパック解約完了」を設定
		else if(JKKStrConst.WRIB_SVC_CD_SECURITY_PACK.equals(wribSvcCd))
		{
			return JKKStrConst.CD00647_SECURITYPACK_DSL_FIN;
		}
		// 上記以外の場合、「キャンペーン取消完了」を設定
		else
		{
			return JKKStrConst.CD00647_CAMPAIGN_CSL;
		}
	}

	/**
	 * 
	 * 割引サービス契約スキーマに設定する,サービス課金開始年月日を返却する.
	 * 
	 * @param  kk0451StaYmd サービス開始年月日
	 * @param  kk0451ChrgStaYmd 課金開始年月日
	 * @param  svcDslKisanYmd サービス解約起算日
	 * 
	 * @return サービス課金開始年月日
	 */
	private String getSvcChrgStaYmd(String kk0451StaYmd,
										String kk0451ChrgStaYmd,
										String svcDslKisanYmd) {
		
		printlnEjbLog("業務log_getSvcChrgStaYmd：---start---");
		
		String ret = "";
		
		// ======================================================================================
		// 
		// サービス課金開始年月日算出処理
		// 以下2パターンにて判定を行い,返却する.
		// 
		// 1.サービス解約起算日がサービス課金開始年月日より後               ：KK0451.サービス課金開始年月日
		// 2.サービス解約起算日がサービス課金開始年月日と同一               ：KK0451.サービス開始年月日
		// ※サービス解約起算日がｅｏ光ネットの課金開始前については課金開始前に呼び出されることは想定してないため考慮しない
		// 
		// ======================================================================================
		//解約起算日  ≦　割引サービス契約.サービス課金開始年月日
		if (0 <= JPCDateUtil.subtractDay(kk0451ChrgStaYmd, svcDslKisanYmd))
		{
			printlnEjbLog("パック課金開始前(利用開始当月)");
			
			// サービス開始年月日
			ret = kk0451StaYmd;
		}
		else
		{
			printlnEjbLog("パック課金開始後(利用開始翌月以降)");
			
			// サービス課金開始年月日
			ret = kk0451ChrgStaYmd;
		}
		
		printlnEjbLog("業務log_戻り：" + ret);
		printlnEjbLog("業務log_getSvcChrgStaYmd：---end---");
		return ret;
	}
	
	//v32.00.00 Add End
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>異動理由明細の作成<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @return ekk1091D010CBSMsg1List
	 * @throws Throwable
	 */
	private CAANMsg[] idouReasenDtl() throws Throwable {
		
		ArrayList<CAANMsg> list = new ArrayList<CAANMsg>();
		
		CAANMsg item = new CAANMsg(EKK1091D010CBSMsg1List.class.getName());
		// nullを設定
		fillCAANMSGNullMapping(item, new EKK1091D010CBSMsg1List().getContents());
		
		item.set(EKK1091D010CBSMsg1List.IDO_RSN_CD, "01");
		
		list.add(item);
		
		CAANMsg[] ekk1091D010CBSMsg1List = list.toArray(new CAANMsg[0]);
		
		return ekk1091D010CBSMsg1List;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービスコンポーネント実行後に、IRequestParameterReadWriteにエラー情報をマッピングする<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param param      業務データ取得・書込用I/F
	 * @param templates  CAANMsgクラス配列
	 * @param returnCode リターンコード
	 * @param mapName    SCマップ名
	 * 
	 * @return 業務データ取得・書込用I/F
	 */
	@SuppressWarnings({ "unchecked", "cast", "null", "boxing" })
	public IRequestParameterReadWrite editErrorInfo(@SuppressWarnings("hiding") IRequestParameterReadWrite param,
													 CAANMsg[] templates,
													 int returnCode,
													 String mapName) throws Throwable {
		CAANMsg template = templates[0];
		CAANMsg[] templateArray = null;
		int templateStatus = template.getInt(EKK0451B005CBSMsg.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 inMap = null;
		ArrayList inList = null;
		
		// 作業項目領域
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		
		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData(mapName);
		if (inMap == null) {
			inMap = new HashMap();
			param.setData(mapName, inMap);
		}

		String svcIf = null;
		if (svcIf == null) {
			return param;
			
		} else {
			
			// 処理なし
		}
		return param;
	}
}
