/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKK0351C250TPMA
*	ソースファイル名：JEKK0351C250TPMA.java
*	作成者			：富士通
*	日付			：2011年10月19日
*＜機能概要＞
*	オプションサービス契約解約確定の副次処理を呼び出す部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/10/19	富士通		新規作成
*	v4.00.00	2013/04/17	FJ)沖田		IT1-2012-0000903
*  v32.00.00	2017/04/05	FJ)三宅隆	ANK-3149-00-00
*
********************************************************************************/

package eo.ejb.cbs.mainproc;

import java.util.ArrayList;
import java.util.HashMap;

import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.ejb.common.JSYejbLog;
import com.fujitsu.futurity.model.ejb.common.fw.AgentDispatchContext;
import com.fujitsu.futurity.model.ejb.common.fw.TemplateMainHandler;

import eo.ejb.cbs.cbsmsg.EKK0351C250CBSMsg;
import eo.ejb.common.JKKModelCommon;
import eo.ejb.common.JKKModelConst;
import eo.ejb.common.db.JEKK0351C250ETDA;
import eo.ejb.common.db.JKKejbKK0351SecProc;
import eo.ejb.common.db.JKKejbKK0351SubTypeCreate;
import eo.ejb.common.entity.JEKK0351C250KRCK;
import eo.ejb.common.entity.JKKejbIdoRestrictController;
import eo.ejb.common.db.JKKejbKK3081SecProc;

/**
 * <p>
 * オプションサービス契約解約確定の顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JEKK0351C250TPMA implements TemplateMainHandler
{

	/**
	 * <p>
	 * オプションサービス契約解約確定の副次処理部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void createSubTypeKK0351(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C250TPMA#createSubTypeKK0351");

		//異動予約のみにふるまう場合は、なにもせずに処理終了
		if(!new JKKejbIdoRsvUtil().isSingleIdoRsv(inCBSMsg, inContext))
		{
			// オプションサービス契約サブタイプ登録処理の呼び出し
			JKKejbKK0351SubTypeCreate instance = new JKKejbKK0351SubTypeCreate(inCBSMsg);
			instance.setOpSvcKeiNo(inCBSMsg.getString(EKK0351C250CBSMsg.OP_SVC_KEI_NO));
			instance.setGeneAddDtm(inCBSMsg.getString(EKK0351C250CBSMsg.GENE_ADD_DTM));
			instance.createSubTypeKK0351();

		}

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C250TPMA#createSubTypeKK0351");
	}

	/**
	 * <p>
	 * オプションサービス契約解約確定の関連制約部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execKRCK(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C250TPMA#execKRCK");

		// オプションサービスサービス契約解約の関連制約部品の呼び出し
		new JEKK0351C250KRCK().execKRCK(inCBSMsg, inContext);

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C250TPMA#execKRCK");
	}

	/**
	 * <p>
	 * オプションサービス契約解約のDBアクセス部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execDBAccess(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C250TPMA#execDBAccess");

		// オプションサービス契約解約のDBアクセス部品の呼び出し
		new JEKK0351C250ETDA().execDBAccess(inCBSMsg, inContext);

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C250TPMA#execDBAccess");
	}

	/**
	 * <p>
	 * オプションサービス契約解約時の予約取消処理の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void cancelReserveKK0351(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C250TPMA#cancelReserveKK0351");

		// 部品呼び出し時に必要な項目を取得する
		String opSvcKeiNo = inCBSMsg.getString(EKK0351C250CBSMsg.OP_SVC_KEI_NO);
		String idoDiv = inCBSMsg.getString(EKK0351C250CBSMsg.IDO_DIV);
		String mskmDtlNo = inCBSMsg.getString(EKK0351C250CBSMsg.MSKM_DTL_NO);
		String opeDate = JKKModelCommon.getOpeDate(inCBSMsg);
		String updDtm = inCBSMsg.getString(EKK0351C250CBSMsg.OPERATEDATETIME);
		String updOpeAct = inCBSMsg.getString(EKK0351C250CBSMsg.OPERATORID);

		// プラン終了年月日、サービス解約年月日、サービス終了年月日
		String svcEndymd = inCBSMsg.getString(EKK0351C250CBSMsg.SVC_ENDYMD);
		// プラン課金終了年月日、サービス課金終了年月日
		String svcChrgEndymd = inCBSMsg.getString(EKK0351C250CBSMsg.SVC_CHRG_ENDYMD);
		// サービス解約理由コード
		String svcDlreCd = inCBSMsg.getString(EKK0351C250CBSMsg.SVC_DLRE_CD);
		// サービス解約理由メモ
		String svcDlreMemo = inCBSMsg.getString(EKK0351C250CBSMsg.SVC_DLRE_MEMO);
		// 解約担当ユーザーID
		String dslTntUserId = inCBSMsg.getString(EKK0351C250CBSMsg.DSL_TNT_USER_ID);
		
		// 予約中の強制解約(サービス解約理由コード＝"強制解約")、および住所変更予約中の解約の場合
		if (JKKModelConst.SVC_DLRE_CD_KSI_DSL.equals(svcDlreCd) || isAdchgRsvChu(inCBSMsg))
		{
			// オプションサービス契約予約取消処理の呼び出し（自動予約取消ワーク登録処理）
			new JKKejbKK0351SecProc().cancelReserve(opSvcKeiNo, idoDiv, mskmDtlNo,
					opeDate, updDtm, updOpeAct, JKKModelConst.AUTO_RSV_CL_STAT_CD_MI_JSSI);

			// オプションサービス契約予約解約処理（未来日・予約確定レコードのみ予約解約）の呼び出し
			new JKKejbKK0351SecProc().dslRsvFixRec(opSvcKeiNo, opeDate,
					svcEndymd, svcChrgEndymd, svcDlreCd, svcDlreMemo, dslTntUserId, updDtm, updOpeAct);
		}
		// 上記以外の場合
		else
		{
			// オプションサービス契約予約取消処理の呼び出し（自動予約取消ワーク登録処理）
			new JKKejbKK0351SecProc().cancelReserve(opSvcKeiNo, idoDiv, mskmDtlNo,
					opeDate, updDtm, updOpeAct, JKKModelConst.AUTO_RSV_CL_STAT_CD_CL_ZM);
		}
		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C250TPMA#cancelReserveKK0351");
	}

	/**
	 * <p>
	 * 住所変更予約中チェック処理
	 * </p>
	 * @param inMsg 処理対象のメッセージ
	 * @return チェック結果(住所変更予約あり:true, 住所変更予約なし:false)
	 */
	private boolean isAdchgRsvChu(CAANMsg inMsg)
	{

		// 異動可否判定チェック部品の呼び出し
		JKKejbIdoRestrictController idoKh = new JKKejbIdoRestrictController(inMsg);

		// 呼び出しパラメータの設定
		idoKh.setBaseDate(inMsg.getString(EKK0351C250CBSMsg.SVC_ENDYMD));
		idoKh.setIdo_div(inMsg.getString(EKK0351C250CBSMsg.IDO_DIV));
		idoKh.setMskm_dtl_no(inMsg.getString(EKK0351C250CBSMsg.MSKM_DTL_NO));
		idoKh.setTg_skbt_cd(JKKejbIdoRestrictController.TG_SKBT_CD_KK0351);
		idoKh.setOp_svc_kei_no(inMsg.getString(EKK0351C250CBSMsg.OP_SVC_KEI_NO));

		// 住所変更予約取得処理
		ArrayList<HashMap<String, Object>> adchgRsvList = idoKh.getAdchgRsvList();
		
		if (0 < adchgRsvList.size()) 
		{
			return true;
		}
		
		return false;
	}

// ANK-3149-00-00 ADD START
	/**
	 * <p>
	 * 他事業者契約異動通知副次処理の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * 
	*/
	public void tajigyosyaKK3081(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C250TPMA#tajigyosyaKK3081");
		
		// ANK-3149-00-00 MOD START
		//if(!"1".equals(inCBSMsg.getObject(EKK0351C250CBSMsg.OP_HKTGI_UM))){
		if(!"1".equals(inCBSMsg.getObject(EKK0351C250CBSMsg.OP_HKTGI_UM)) && !new JKKejbIdoRsvUtil().isSingleIdoRsv(inCBSMsg, inContext)){
		// ANK-3149-00-00 MOD END
			// 異動予約のみにふるまわない場合かつオプション引継有無が"1"以外の場合に他事業者契約異動通知副次処理を呼出す
			new JKKejbKK3081SecProc().tajgsKeiIdtDsl(inCBSMsg, inContext);
		}

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C250TPMA#tajigyosyaKK3081");
	}
//ANK-3149-00-00 ADD END

}
