/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JCK0261TPMA
*	ソースファイル名：JCK0261TPMA.java
*	作成者			：FJ)澤田　健太
*	日付			：2017年11月08日
*＜機能概要＞
*	自社利用組織のサービスIF顧客独自処理部品
*＜修正履歴＞
*	バージョン	修正日		修正者		    修正内容
*	v35.00.00	2017/11/08	FJ)澤田　健太		新規作成
*
********************************************************************************/

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.CK0261ETMsg;
import eo.ejb.common.db.JCKejbExclusiveProcCK0261;

/**
 * <p>
 * 自社利用組織のサービスIF顧客独自処理部品クラスです。
 * </p>
 * @author 澤田　健太
 */
public class JCK0261TPMA implements TemplateMainHandler
{

	/** CBS層 自社利用組織キー項目名（１） */
	private static final String CBS_PK_NAME_1 = "sysid";

	/** CBS層 更新年月日時分秒（更新前）キー項目名 */
	private static final String CBS_UPD_BF_NAME = "upd_dtm_bf";

	/** エラーフラグ */
	private static final String ERR_FLG_EA = "EA";
	
	/** エラーフラグ */
	private static final String ERR_FLG_EB = "EB";

	/** エラーフラグ設定項目名 */
	private static final String ERR_CONTENTS = "upd_dtm_bf_err";
	
	/** エラーフラグ設定項目名 */
	private static final String ERR_CONTENTS_SYSID = "sysid_err";

	/**
	 * <p>
	 * 自社利用組織のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProc(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 必要な項目を保持したETMsgを作成する
		CAANMsg inETMsg = new CAANMsg(CK0261ETMsg.class.getName());

		// プライマリキーを設定
		inETMsg.set(CK0261ETMsg.SYSID, inCBSMsg.getString(CBS_PK_NAME_1));

		// 更新情報の設定
		inETMsg.set(CK0261ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
		inETMsg.set(CK0261ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

		// メイン処理の呼び出し
		boolean ret = this.execExistenceMain(inETMsg, inCBSMsg.getString(CBS_UPD_BF_NAME), inCBSMsg.getString(JCMConstants.FUNC_CODE_KEY));

		// 処理結果がfalseの場合は関連制約エラーとする
		if (!ret)
		{
			inCBSMsg.set(ERR_CONTENTS_SYSID, ERR_FLG_EA);
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
			return;
		}
		
		// メイン処理の呼び出し
		ret = this.execExclusiveMain(inETMsg, inCBSMsg.getString(CBS_UPD_BF_NAME), inCBSMsg.getString(JCMConstants.FUNC_CODE_KEY));

		// 処理結果がfalseの場合は関連制約エラーとする
		if (!ret)
		{
			inCBSMsg.set(ERR_CONTENTS, ERR_FLG_EB);
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
			return;
		}
	}
	
	/**
	 * <p>
	 * 自社利用組織のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExistenceProc(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 必要な項目を保持したETMsgを作成する
		CAANMsg inETMsg = new CAANMsg(CK0261ETMsg.class.getName());

		// プライマリキーを設定
		inETMsg.set(CK0261ETMsg.SYSID, inCBSMsg.getString(CBS_PK_NAME_1));

		// 更新情報の設定
		inETMsg.set(CK0261ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
		inETMsg.set(CK0261ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

		// メイン処理の呼び出し
		boolean ret = this.execExistenceMain(inETMsg, inCBSMsg.getString(CBS_UPD_BF_NAME), inCBSMsg.getString(JCMConstants.FUNC_CODE_KEY));

		// 処理結果がfalseの場合は関連制約エラーとする
		if (ret)
		{
			inCBSMsg.set(ERR_CONTENTS_SYSID, ERR_FLG_EA);
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
			return;
		}
	}
	
	/**
	 * <p>
	 * 自社利用組織のスキーマの存在チェックを行います。
	 * </p>
	 * @param inETMsg 処理対象のメッセージキャリア（ET）
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 * @param funcCd 機能コード
	 * @return スキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新が正常終了の場合はtrue。
	 */
	private boolean execExistenceMain(CAANMsg inETMsg, String updDtmBf, String funcCd)
	{
		// ログの出力
		outLog(inETMsg, updDtmBf);

		boolean ret = true;

		// 自社利用組織排他処理部品（SYSID）の呼び出し
		ret = new JCKejbExclusiveProcCK0261().isSysid(inETMsg, inETMsg.getString(CK0261ETMsg.SYSID), updDtmBf, funcCd);

		return ret;
	}
	
	/**
	 * <p>
	 * 自社利用組織のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います。
	 * </p>
	 * @param inETMsg 処理対象のメッセージキャリア（ET）
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 * @param funcCd 機能コード
	 * @return スキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新が正常終了の場合はtrue。
	 */
	private boolean execExclusiveMain(CAANMsg inETMsg, String updDtmBf, String funcCd)
	{
		// ログの出力
		outLog(inETMsg, updDtmBf);

		boolean ret = true;

		// 自社利用組織排他処理部品（SYSID）の呼び出し
		ret = new JCKejbExclusiveProcCK0261().isExProcSysid(inETMsg, inETMsg.getString(CK0261ETMsg.SYSID), updDtmBf, funcCd);

		return ret;
	}

	/**
	 * <p>
	 * ログの出力を行います。
	 * </p>
	 * @param inETMsg 処理対象のメッセージキャリア（ET）
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 */
	private void outLog(CAANMsg inETMsg, String updDtmBf)
	{
		// プライマリキーの出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JCK0261TPMA.sysid=" + inETMsg.getString(CK0261ETMsg.SYSID));

		// 更新年月日時分秒（更新前）の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JCK0261TPMA.upd_dtm_bf=" + updDtmBf);
	}

}