/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JECK0111D010TPMA
*	ソースファイル名：JECK0111D010TPMA.java
*	作成者			：富士通
*	日付			：2011年11月30日
*＜機能概要＞
*	グループ登録顧客独自処理部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/11/30	富士通		新規作成
*
********************************************************************************/

package eo.ejb.cbs.mainproc;

import java.util.ArrayList;

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.CK0111ETMsg;
import eo.ejb.cbs.cbsmsg.ECK0111D010CBSMsg;
import eo.ejb.cbs.cbsmsg.ECK0111D010CBSMsg1List;
import eo.ejb.common.db.JCKejbExclusiveProcCK0011;

/**
 * <p>
 * グループ登録顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JECK0111D010TPMA implements TemplateMainHandler
{

	/** エラーフラグ */
	private static final String ERR_FLG = "EA";

	/**
	 * <p>
	 * グループ登録のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProc(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 使用する項目の取得
		CAANMsg[] sysids = inCBSMsg.getCAANMsgList(ECK0111D010CBSMsg.ECK0111D010CBSMSG1LIST);
		String updDtmBf = inCBSMsg.getString(ECK0111D010CBSMsg.UPD_DTM_BF);

		// SYSIDのリストを作成する
		ArrayList<String> sysidList = new ArrayList<String>();
		
		for (int i = 0; i < sysids.length; i++)
		{
			sysidList.add(sysids[i].getString(ECK0111D010CBSMsg1List.SYSID));
		}

		// 必要な項目を保持したETMsgを作成する
		CAANMsg inETMsg = new CAANMsg(CK0111ETMsg.class.getName());

		// 更新情報の設定
		inETMsg.set(CK0111ETMsg.UPD_DTM, inCBSMsg.getString(ECK0111D010CBSMsg.OPERATEDATETIME));
		inETMsg.set(CK0111ETMsg.UPD_OPEACNT, inCBSMsg.getString(ECK0111D010CBSMsg.OPERATORID));

		// ログの出力
		outLogCK0011(inETMsg, sysidList, updDtmBf);

		// メイン処理の呼び出し
		boolean ret = new JCKejbExclusiveProcCK0011().isExProcSysidList(inETMsg, sysidList, updDtmBf, inCBSMsg.getString(ECK0111D010CBSMsg.FUNC_CODE));

		// 処理結果がfalseの場合は関連制約エラーとする
		if (!ret)
		{
			inCBSMsg.set(ECK0111D010CBSMsg.UPD_DTM_BF_ERR, ERR_FLG);
			inCBSMsg.set(ECK0111D010CBSMsg.STATUS, StatusCodes.RELATION_ERR);
		}
	}

	/**
	 * <p>
	 * ログの出力を行います。
	 * </p>
	 * @param inETMsg 処理対象のメッセージキャリア（ET）
	 * @param sysidList SYSIDのリスト
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 */
	private void outLogCK0011(CAANMsg inETMsg, ArrayList<String> sysidList, String updDtmBf)
	{
		// SYSIDの出力
		for (int i = 0; i < sysidList.size(); i++)
		{
			JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JECK0111D010TPMA.sysid_" + i + "=" + sysidList.get(i));
		}

		// 更新年月日時分秒（更新前）の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JECK0111D010TPMA.upd_dtm_bf=" + updDtmBf);
	}

}
