/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKK1071TPMA
*	ソースファイル名：JKK1071TPMA.java
*	作成者			：富士通
*	日付			：2011年11月28日
*＜機能概要＞
*	審査のサービスIF顧客独自処理部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/11/28	富士通		新規作成
*
********************************************************************************/

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.CK0011ETMsg;
import eo.ejb.cbm.entity.KK0491ETMsg;
import eo.ejb.cbm.entity.KK2111ETMsg;
import eo.ejb.common.db.JCKejbExclusiveProcCK0011;
import eo.ejb.common.db.JKKejbExclusiveProcKK0491;
import eo.ejb.common.db.JKKejbExclusiveProcKK2111;

/**
 * <p>
 * 審査のサービスIF顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JKK1071TPMA implements TemplateMainHandler
{

	/** CBS層 サービス契約番号キー項目名 */
	private static final String CBS_SVC_KEI_NO = "svc_kei_no";

	/** CBS層 SYSIDキー項目名 */
	private static final String CBS_SYSID = "sysid";

	/** CBS層 SYSIDリストキー項目名 */
	private static final String CBS_SYSID_LIST = "EKK1071C041CBSMsg1List";

	/** CBS層 請求契約番号キー項目名 */
	private static final String CBS_SEIKY_KEI_NO = "seiky_kei_no";

	/** CBS層 更新年月日時分秒（更新前）キー項目名 */
	private static final String CBS_UPD_BF_NAME = "upd_dtm_bf";

	/** エラーフラグ */
	private static final String ERR_FLG = "EA";

	/** エラーフラグ設定項目名 */
	private static final String ERR_CONTENTS = "upd_dtm_bf_err";

	/**
	 * <p>
	 * 審査のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います（サービス契約排他制御用）。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProc(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 使用する項目の取得
		String svcKeiNo = inCBSMsg.getString(CBS_SVC_KEI_NO);
		String updDtmBf = inCBSMsg.getString(CBS_UPD_BF_NAME);

		// 必要な項目を保持したETMsgを作成する
		CAANMsg inETMsg = new CAANMsg(KK2111ETMsg.class.getName());

		// プライマリキーを設定
		inETMsg.set(KK2111ETMsg.SVC_KEI_NO, svcKeiNo);

		// 更新情報の設定
		inETMsg.set(KK2111ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
		inETMsg.set(KK2111ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

		// ログの出力
		outLog(inETMsg, updDtmBf);

		// メイン処理の呼び出し
		boolean ret = new JKKejbExclusiveProcKK2111().isExProcSvcKeiNo(inETMsg, svcKeiNo, updDtmBf, inCBSMsg.getString(JCMConstants.FUNC_CODE_KEY));

		// 処理結果がfalseの場合は関連制約エラーとする
		if (!ret)
		{
			inCBSMsg.set(ERR_CONTENTS, ERR_FLG);
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
		}
	}

	/**
	 * <p>
	 * 審査のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います（お客様用）。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProcCK0011(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// SYSIDをリストで保持しているインターフェイスの場合
		if (inCBSMsg.containsKeyOfSchema(CBS_SYSID_LIST))
		{
			// 使用する項目の取得
			CAANMsg[] sysids = inCBSMsg.getCAANMsgList(CBS_SYSID_LIST);
			String sysid = null;
			
			if (0 < sysids.length && !sysids[0].isNull(CBS_SYSID)) 
			{
				sysid = sysids[0].getString(CBS_SYSID);
			}
			else
			{
				return;
			}
			
			String updDtmBf = inCBSMsg.getString(CBS_UPD_BF_NAME);

			// 必要な項目を保持したETMsgを作成する
			CAANMsg inETMsg = new CAANMsg(CK0011ETMsg.class.getName());
			
			// プライマリキーを設定
			inETMsg.set(CK0011ETMsg.SYSID, sysid);

			// 更新情報の設定
			inETMsg.set(CK0011ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
			inETMsg.set(CK0011ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

			// ログの出力
			outLogCK0011(inETMsg, updDtmBf);

			// メイン処理の呼び出し
			boolean ret = new JCKejbExclusiveProcCK0011().isExProcSysid(inETMsg, sysid, updDtmBf, inCBSMsg	.getString(JCMConstants.FUNC_CODE_KEY));

			// 処理結果がfalseの場合は関連制約エラーとする
			if (!ret)
			{
				inCBSMsg.set(ERR_CONTENTS, ERR_FLG);
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
			}
		}
		else
		{
			// 使用する項目の取得
			String sysid = inCBSMsg.getString(CBS_SYSID);
			String updDtmBf = inCBSMsg.getString(CBS_UPD_BF_NAME);

			// 必要な項目を保持したETMsgを作成する
			CAANMsg inETMsg = new CAANMsg(CK0011ETMsg.class.getName());

			// プライマリキーを設定
			inETMsg.set(CK0011ETMsg.SYSID, sysid);

			// 更新情報の設定
			inETMsg.set(CK0011ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
			inETMsg.set(CK0011ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

			// ログの出力
			outLogCK0011(inETMsg, updDtmBf);

			// メイン処理の呼び出し
			boolean ret = new JCKejbExclusiveProcCK0011().isExProcSysid(inETMsg, sysid, updDtmBf, inCBSMsg	.getString(JCMConstants.FUNC_CODE_KEY));

			// 処理結果がfalseの場合は関連制約エラーとする
			if (!ret)
			{
				inCBSMsg.set(ERR_CONTENTS, ERR_FLG);
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
			}
		}
	}

	/**
	 * <p>
	 * 審査のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います（請求契約用）。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProcKK0491(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 使用する項目の取得
		String seikyKeiNo = inCBSMsg.getString(CBS_SEIKY_KEI_NO);
		String updDtmBf = inCBSMsg.getString(CBS_UPD_BF_NAME);

		// 必要な項目を保持したETMsgを作成する
		CAANMsg inETMsg = new CAANMsg(KK0491ETMsg.class.getName());

		// プライマリキーを設定
		inETMsg.set(KK0491ETMsg.SEIKY_KEI_NO, seikyKeiNo);

		// 更新情報の設定
		inETMsg.set(KK0491ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
		inETMsg.set(KK0491ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

		// ログの出力
		outLogKK0491(inETMsg, updDtmBf);

		// メイン処理の呼び出し
		boolean ret = new JKKejbExclusiveProcKK0491().isExProcSeikyKeiNo(inETMsg, seikyKeiNo, updDtmBf, inCBSMsg	.getString(JCMConstants.FUNC_CODE_KEY));

		// 処理結果がfalseの場合は関連制約エラーとする
		if (!ret)
		{
			inCBSMsg.set(ERR_CONTENTS, ERR_FLG);
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
		}
	}

	/**
	 * <p>
	 * ログの出力を行います（サービス契約排他制御用）。
	 * </p>
	 * @param inETMsg 処理対象のメッセージキャリア（ET）
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 */
	private void outLog(CAANMsg inETMsg, String updDtmBf)
	{
		// プライマリキーの出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK1071TPMA.svc_kei_no=" + inETMsg.getString(KK2111ETMsg.SVC_KEI_NO));

		// 更新年月日時分秒（更新前）の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK1071TPMA.upd_dtm_bf=" + updDtmBf);
	}

	/**
	 * <p>
	 * ログの出力を行います（お客様用）。
	 * </p>
	 * @param inETMsg 処理対象のメッセージキャリア（ET）
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 */
	private void outLogCK0011(CAANMsg inETMsg, String updDtmBf)
	{
		// プライマリキーの出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK1071TPMA.sysid=" + inETMsg.getString(CK0011ETMsg.SYSID));

		// 更新年月日時分秒（更新前）の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK1071TPMA.upd_dtm_bf=" + updDtmBf);
	}

	/**
	 * <p>
	 * ログの出力を行います（請求契約用）。
	 * </p>
	 * @param inETMsg 処理対象のメッセージキャリア（ET）
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 */
	private void outLogKK0491(CAANMsg inETMsg, String updDtmBf)
	{
		// プライマリキーの出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK1071TPMA.seiky_kei_no=" + inETMsg.getString(KK0491ETMsg.SEIKY_KEI_NO));

		// 更新年月日時分秒（更新前）の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK1071TPMA.upd_dtm_bf=" + updDtmBf);
	}

}