/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKK0161C120TPMA
*	ソースファイル名：JEKK0161C120TPMA.java
*	作成者			：富士通
*	日付			：2011年10月17日
*＜機能概要＞
*	サービス契約内訳料金プラン変更確定の副次処理を呼び出す部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/10/17	富士通		新規作成
*
********************************************************************************/

package eo.ejb.cbs.mainproc;

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.EKK0161C120CBSMsg;
import eo.ejb.common.JKKModelCommon;
import eo.ejb.common.JKKejbBusinessException;
import eo.ejb.common.db.JEKK0161C120ETDA;
import eo.ejb.common.db.JKKejbKK0161SubTypeCreate;
import eo.ejb.common.entity.JEKK0161C120KRCK;

/**
 * <p>
 * サービス契約内訳料金プラン変更確定の顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JEKK0161C120TPMA implements TemplateMainHandler
{

	/**
	 * サービス契約内訳料金プラン変更確定顧客独自処理の副次処理部品の呼び出しを行います。
	 * 
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void createSubTypeKK0161(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 実行判定
		if (new JKKejbIdoRsvUtil().isSingleIdoRsv(inCBSMsg, inContext))
		{
			// 異動予約のみに振舞う場合、処理を終了する
			return;
		}
		
		// サービス契約サブタイプ登録処理の呼び出し
		JKKejbKK0161SubTypeCreate instance = new JKKejbKK0161SubTypeCreate(inCBSMsg);
		
		String svcKeiUcwkNo = inCBSMsg.getString(EKK0161C120CBSMsg.SVC_KEI_UCWK_NO);
		
		instance.setSvcKeiUcwkNo(svcKeiUcwkNo);
		instance.setGeneAddDtm((String)JKKModelCommon.getCurrentGeneAddDtmKK0161(inCBSMsg, inContext, svcKeiUcwkNo));
		instance.createSubTypeKK0161();
	}

	/**
	 * <p>
	 * サービス契約内訳料金プラン変更確定の関連制約部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execKRCK(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0161C120TPMA#execKRCK");

		// サービス契約内訳料金プラン変更確定の関連制約部品の呼び出し
		new JEKK0161C120KRCK().execKRCK(inCBSMsg, inContext);

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0161C120TPMA#execKRCK");
	}

	/**
	 * <p>
	 * サービス契約内訳料金プラン変更確定のDBアクセス部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execDBAccess(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0161C120TPMA#execDBAccess");

		try
		{
			// サービス契約内訳料金プラン変更確定のDBアクセス部品の呼び出し
			new JEKK0161C120ETDA().execDBAccess(inCBSMsg, inContext);
		}
		catch (JKKejbBusinessException e) {
			
			// エラーフラグ・エラー返却項目を設定
			inCBSMsg.set(EKK0161C120CBSMsg.SVC_KEI_UCWK_NO_ERR, "EC");
			// エラーステータスを設定
			inCBSMsg.set(EKK0161C120CBSMsg.STATUS, StatusCodes.RELATION_ERR);
		}
		

		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0161C120TPMA#execDBAccess");
	}
}
