/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKK0081C080TPMA
*	ソースファイル名：JEKK0081C080TPMA.java
*	作成者			：富士通
*	日付			：2011年10月05日
*＜機能概要＞
*	サービス契約休止変更の副次処理を呼び出す部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/10/05	富士通		新規作成
*	v7.00.00	2013/12/05	FJ)大山		ANK-1578-00-00
*	v6.00.00	2013/12/25	FJ)小島		OM-2013-0005081
*	v6.01.00	2013/12/28	FJ)小島		OM-2013-0005081
*	v7.00.01	2014/01/08	FJ)小島		IT1-2014-0000016
*	v10.00.00	2014/08/22	FJ)小島		OM-2014-0002565
*
********************************************************************************/

package eo.ejb.cbs.mainproc;

import com.fujitsu.futurity.common.JCMConstants;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.ejb.common.JSYejbLog;
import com.fujitsu.futurity.model.ejb.common.StatusCodes;
import com.fujitsu.futurity.model.ejb.common.fw.AgentDispatchContext;
import com.fujitsu.futurity.model.ejb.common.fw.TemplateMainHandler;

import eo.ejb.cbm.entity.KK0081ETMsg;
import eo.ejb.cbs.cbsmsg.EKK0081C080CBSMsg;
import eo.ejb.common.JKKModelCommon;
import eo.ejb.common.db.JEKK0081C080ETDA;
import eo.ejb.common.db.JKKejbKK0081DBABase;
import eo.ejb.common.db.JKKejbKK0081SubTypeCreate;
import eo.ejb.common.db.JKKejbKK0161SecProc;
import eo.ejb.common.db.JKKejbKK0341SecProc;
import eo.ejb.common.db.JKKejbKK0351SecProc;
import eo.ejb.common.db.JKKejbKK0441SecProc;
import eo.ejb.common.db.JKKejbKK0451SecProc;
import eo.ejb.common.db.JKKejbKK2811SecProc;
import eo.ejb.common.entity.JEKK0081C080KRCK;
import eo.ejb.common.entity.JKKejbIdoRestrictController;

/**
 * <p>
 * サービス契約休止変更の顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JEKK0081C080TPMA implements TemplateMainHandler
{

	/**
	 * <p>
	 * サービス契約休止変更の関連制約部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execKRCK(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0081C080TPMA#execKRCK");

		// サービス契約休止変更の関連制約部品の呼び出し
		new JEKK0081C080KRCK().execKRCK(inCBSMsg, inContext);

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0081C080TPMA#execKRCK");
	}

	/**
	 * <p>
	 * サービス契約休止変更のDBアクセス部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execDBAccess(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0081C080TPMA#execDBAccess");

		// サービス契約休止変更のDBアクセス部品の呼び出し
		new JEKK0081C080ETDA().execDBAccess(inCBSMsg, inContext);

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0081C080TPMA#execDBAccess");
	}

	/**
	 * <p>
	 * サービス契約休止変更の副次処理部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void createSubTypeKK0081(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0081C080TPMA#createSubTypeKK0081");

		// 相関ルールチェック結果を確認
		boolean ret = new JKKejbIdoRsvUtil().isSingleIdoRsv(inCBSMsg, inContext);

		//異動予約のみにふるまう場合は、なにもせずに処理終了
		if (!ret)
		{

			// サービス契約サブタイプ登録処理の呼び出し
			JKKejbKK0081SubTypeCreate instance = new JKKejbKK0081SubTypeCreate(inCBSMsg);
			instance.setSvcKeiNo(inCBSMsg.getString(EKK0081C080CBSMsg.SVC_KEI_NO));
			instance.setGeneAddDtm(inCBSMsg.getString(EKK0081C080CBSMsg.GENE_ADD_DTM));
			instance.createSubTypeKK0081();

		}

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0081C080TPMA#createSubTypeKK0081");
	}

	/**
	 * <p>
	 * サービス契約休止変更の副次処理部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void invoke(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0081C080TPMA#invoke");

		// 相関ルールチェック結果を確認
		boolean ret = new JKKejbIdoRsvUtil().isSingleIdoRsv(inCBSMsg, inContext);

		//異動予約のみにふるまう場合は、なにもせずに処理終了
		if (!ret)
		{
			String svc_kei_no = inCBSMsg.getString(EKK0081C080CBSMsg.SVC_KEI_NO);
			String gene_add_dtm = inCBSMsg.getString(EKK0081C080CBSMsg.GENE_ADD_DTM);
			
			String opeDate = JKKModelCommon.getOpeDate(inCBSMsg);
			String updDtm = inCBSMsg.getString(EKK0081C080CBSMsg.OPERATEDATETIME);
			String updOpeAct = inCBSMsg.getString(EKK0081C080CBSMsg.OPERATORID);

			JKKejbKK0161SecProc instance161 = new JKKejbKK0161SecProc();
			JKKejbKK0341SecProc instance341 = new JKKejbKK0341SecProc();
			JKKejbKK0351SecProc instance351 = new JKKejbKK0351SecProc();
			// OM-2014-0002565 ADD START
			JKKejbKK0441SecProc instance441 = new JKKejbKK0441SecProc();
			// OM-2014-0002565 ADD END
			JKKejbKK0451SecProc instance451 = new JKKejbKK0451SecProc();
			JKKejbKK2811SecProc instance2811 = new JKKejbKK2811SecProc();

			instance161.execFromSvcKei(inCBSMsg, inContext, svc_kei_no, gene_add_dtm);
			instance341.execFromSvcKei(inCBSMsg, inContext, svc_kei_no, gene_add_dtm);
			instance341.execFromKktkSvcKei(inCBSMsg, inContext, svc_kei_no, gene_add_dtm);
			instance351.execFromSvcKei(inCBSMsg, inContext, svc_kei_no, gene_add_dtm);
			// OM-2014-0002565 ADD START
			instance441.execFromSvcKei(inCBSMsg, inContext, svc_kei_no, gene_add_dtm);
			// OM-2014-0002565 ADD END
			instance451.updateSetWribPauseYmd(inCBSMsg, svc_kei_no, opeDate, updDtm, updOpeAct);
			instance2811.execFromKktkSvcKei(inCBSMsg, inContext, svc_kei_no, gene_add_dtm);
		}

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0081C080TPMA#invoke");

	}

	/**
	 * <p>
	 * サービス契約休止変更時の異動制約チェックを呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @return 
	*/
	public void idoKhChk(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0081C080TPMA.idoKhChk");

		if (inCBSMsg.isNull(EKK0081C080CBSMsg.SVC_KEI_NO))
		{
			return;
		}

		// 異動可否判定チェック部品の呼び出し
		JKKejbIdoRestrictController idoKh = new JKKejbIdoRestrictController(inCBSMsg);

		// 呼び出しパラメータの設定
		//※1 カレントレコードのステータスにより基準日付に以下の項目を設定。
		//・「サービス提供中(100)」の場合：サービス休止年月日
		//・「休止・中断中(210)」の場合　：サービス休止解除年月日

		// カレント検索用のメッセージを作成
		CAANMsg inETMsg = new CAANMsg(KK0081ETMsg.class.getName());
		inETMsg.set(KK0081ETMsg.SVC_KEI_NO, inCBSMsg.getString(EKK0081C080CBSMsg.SVC_KEI_NO));
		inETMsg.set(KK0081ETMsg.RSV_APLY_YMD, JKKModelCommon.getOpeDate(inCBSMsg));

		// サービス契約のカレント検索を行う
		CAANMsg otETMsg = new JKKejbKK0081DBABase().findByCurrent(inETMsg);

		// 検索結果が0件の場合、処理を終了する
		if (null == otETMsg)
		{
			return;
		}

		if ("100".equals(otETMsg.getString(KK0081ETMsg.SVC_KEI_STAT)))
		{
			idoKh.setBaseDate(inCBSMsg.getString(EKK0081C080CBSMsg.SVC_PAUSE_YMD));
		}
		else
		{
			idoKh.setBaseDate(inCBSMsg.getString(EKK0081C080CBSMsg.SVC_PAUSE_RLS_YMD));
		}

		idoKh.setIdo_div(inCBSMsg.getString(EKK0081C080CBSMsg.IDO_DIV));
		idoKh.setMskm_dtl_no(inCBSMsg.getString(EKK0081C080CBSMsg.MSKM_DTL_NO));
		idoKh.setTg_skbt_cd(JKKejbIdoRestrictController.TG_SKBT_CD_KK0081);
		idoKh.setSvc_kei_no(inCBSMsg.getString(EKK0081C080CBSMsg.SVC_KEI_NO));

		// 異動可否判定
		boolean rslt = idoKh.isIdoKahi();

		// 異動登録可の場合はtrue、不可の場合はfalse
		if (!rslt)
		{
			inCBSMsg.set(EKK0081C080CBSMsg.IDO_DIV_ERR, idoKh.getErrFlg());
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.TEMPLATE_CORRELATION_ERR);
		}

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0081C080TPMA.idoKhChk");
	}

}
