/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKK0351C080TPMA
*	ソースファイル名：JEKK0351C080TPMA.java
*	作成者			：富士通
*	日付			：2011年10月05日
*＜機能概要＞
*	オプションサービス契約サービス契約変更の副次処理を呼び出す部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/10/05	富士通		新規作成
*
********************************************************************************/

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.cbs.cbsmsg.EKK0351C080CBSMsg;
import eo.ejb.common.db.JEKK0351C080ETDA;
import eo.ejb.common.db.JKKejbKK0351SubTypeCreate;
import eo.ejb.common.entity.JEKK0351C080KRCK;
import eo.ejb.common.entity.JKKejbIdoRestrictController;

/**
 * <p>
 * オプションサービス契約サービス契約変更の顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JEKK0351C080TPMA implements TemplateMainHandler
{

	/**
	 * <p>
	 * オプションサービス契約サービス契約変更の関連制約部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execKRCK(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C080TPMA#execKRCK");

		// オプションサービス契約サービス契約変更の関連制約部品の呼び出し
		new JEKK0351C080KRCK().execKRCK(inCBSMsg, inContext);

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C080TPMA#execKRCK");
	}

	/**
	 * <p>
	 * オプションサービス契約サービス契約変更のDBアクセス部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execDBAccess(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C080TPMA#execDBAccess");

		// オプションサービス契約サービス契約変更のDBアクセス部品の呼び出し
		new JEKK0351C080ETDA().execDBAccess(inCBSMsg, inContext);

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C080TPMA#execDBAccess");
	}

	/**
	 * <p>
	 * オプションサービス契約サービス契約変更の副次処理部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void createSubTypeKK0351(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C080TPMA#createSubTypeKK0351");

		// 相関ルールチェック結果を確認
		boolean ret = new JKKejbIdoRsvUtil().isSingleIdoRsv(inCBSMsg, inContext);

		//異動予約のみにふるまう場合は、なにもせずに処理終了
		if(!ret)
		{
			// オプションサービス契約サブタイプ登録処理の呼び出し
			JKKejbKK0351SubTypeCreate instance = new JKKejbKK0351SubTypeCreate(inCBSMsg);
			instance.setOpSvcKeiNo(inCBSMsg.getString(EKK0351C080CBSMsg.OP_SVC_KEI_NO));
			instance.setGeneAddDtm(inCBSMsg.getString(EKK0351C080CBSMsg.GENE_ADD_DTM));
			instance.createSubTypeKK0351();
		}

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C080TPMA#createSubTypeKK0351");
	}

	/**
	 * <p>
	 * オプションサービス契約サービス契約変更時の異動制約チェックを呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void idoKhChk(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0351C080TPMA#idoKhChk");

		if (inCBSMsg.isNull(EKK0351C080CBSMsg.OP_SVC_KEI_NO))
		{
			return;
		}

		if (inCBSMsg.isNull(EKK0351C080CBSMsg.SVC_KEI_NO))
		{
			return;
		}

		// 異動可否判定チェック部品の呼び出し
		JKKejbIdoRestrictController idoKh = new JKKejbIdoRestrictController(inCBSMsg);
		
		// 呼び出しパラメータの設定
		idoKh.setBaseDate(inCBSMsg.getString(EKK0351C080CBSMsg.RSV_APLY_YMD));
		idoKh.setIdo_div(inCBSMsg.getString(EKK0351C080CBSMsg.IDO_DIV));
		idoKh.setMskm_dtl_no(inCBSMsg.getString(EKK0351C080CBSMsg.MSKM_DTL_NO));
		idoKh.setTg_skbt_cd(JKKejbIdoRestrictController.TG_SKBT_CD_KK0351);
		idoKh.setSvc_kei_no_new(inCBSMsg.getString(EKK0351C080CBSMsg.SVC_KEI_NO));
		idoKh.setOp_svc_kei_no(inCBSMsg.getString(EKK0351C080CBSMsg.OP_SVC_KEI_NO));
		
		// 異動可否判定
		boolean rslt = idoKh.isIdoKahi();

		// 異動登録可の場合はtrue、不可の場合はfalse
		if (!rslt)
		{
			inCBSMsg.set(EKK0351C080CBSMsg.IDO_DIV_ERR, idoKh.getErrFlg());
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.TEMPLATE_CORRELATION_ERR);
		}
		
		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0351C080TPMA#idoKhChk");
	}
}