/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKK0521C130TPMA
*	ソースファイル名：JEKK0521C130TPMA.java
*	作成者			：富士通
*	日付			：2011年11月29日
*＜機能概要＞
*	クレジット有効性NG登録顧客独自処理部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/11/29	富士通		新規作成
*
********************************************************************************/

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.KK0521ETMsg;
import eo.ejb.cbs.cbsmsg.EKK0521C130CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0521C130CBSMsg1List;
import eo.ejb.common.db.JKKejbExclusiveProcKK0491;

/**
 * <p>
 * クレジット有効性NG登録顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JEKK0521C130TPMA implements TemplateMainHandler
{

	/** エラーフラグ */
	private static final String ERR_FLG = "EA";

	/**
	 * <p>
	 * クレジット有効性NG登録のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProc(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 請求契約明細の取得
		CAANMsg[] seikyList = inCBSMsg.getCAANMsgList(EKK0521C130CBSMsg.EKK0521C130CBSMSG1LIST);

		// 機能コードの取得
		String funcCd = inCBSMsg.getString(EKK0521C130CBSMsg.FUNC_CODE);

		// 必要な項目を保持したETMsgを作成する
		CAANMsg inETMsg = new CAANMsg(KK0521ETMsg.class.getName());
		inETMsg.set(KK0521ETMsg.UPD_DTM, inCBSMsg.getString(EKK0521C130CBSMsg.OPERATEDATETIME));
		inETMsg.set(KK0521ETMsg.UPD_OPEACNT, inCBSMsg.getString(EKK0521C130CBSMsg.OPERATORID));

		// 明細件数分処理を行う
		for (int i = 0; i < seikyList.length; i++)
		{
			// 請求契約番号、更新年月日時分秒（更新前）の取得
			String seikyKeiNo = seikyList[i].getString(EKK0521C130CBSMsg1List.SEIKY_KEI_NO);
			String updDtmBf = seikyList[i].getString(EKK0521C130CBSMsg1List.KK0481_UPD_DTM_BF);

			// ログの出力
			outLog(inCBSMsg, seikyKeiNo, updDtmBf);

			boolean ret = true;

			// 請求契約排他処理部品（請求契約番号）の呼び出し
			ret = new JKKejbExclusiveProcKK0491().isExProcSeikyKeiNo(inETMsg, seikyKeiNo, updDtmBf, funcCd);

			// 処理結果がfalseの場合は関連制約エラーとする
			if (!ret)
			{
				seikyList[i].set(EKK0521C130CBSMsg1List.KK0481_UPD_DTM_BF_ERR, ERR_FLG);
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
				return;
			}
		}
	}

	/**
	 * <p>
	 * ログの出力を行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param seikyKeiNo 請求契約番号
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 */
	private void outLog(CAANMsg inCBSMsg, String seikyKeiNo, String updDtmBf)
	{
		// プライマリキーの出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JEKK0521C130TPMA.seiky_way_no_crecard="
				+ inCBSMsg.getString(EKK0521C130CBSMsg.SEIKY_WAY_NO_CRECARD));

		// 請求契約番号の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JEKK0521C130TPMA.seiky_kei_no=" + seikyKeiNo);

		// 更新年月日時分秒（更新前）の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JEKK0521C130TPMA.upd_dtm_bf=" + updDtmBf);
	}

}
