/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKK0251TPMA
*	ソースファイル名：JKK0251TPMA.java
*	作成者			：富士通
*	日付			：2011年11月28日
*＜機能概要＞
*	サービス契約回線内訳のサービスIF顧客独自処理部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/11/28	富士通		新規作成
*
********************************************************************************/

package eo.ejb.cbs.mainproc;

import java.util.HashMap;

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.KK0251ETMsg;
import eo.ejb.common.db.JKKejbExclusiveProcKK0251;
import eo.ejb.common.db.JKKejbExclusiveProcKK2111;
import eo.ejb.common.db.JKKejbKK0251DBABase;

/**
 * <p>
 * サービス契約回線内訳のサービスIF顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JKK0251TPMA implements TemplateMainHandler
{

	/** CBS層 サービス契約回線内訳キー項目名 */
	private static final String CBS_PK_NAME = "svc_kei_kaisen_ucwk_no";

	/** CBS層 世代登録年月日時分秒キー項目名 */
	private static final String CBS_GENE_NAME = "gene_add_dtm";

	/** CBS層 世代登録年月日時分秒エラーキー項目名 */
	private static final String CBS_GENE_NAME_ERR = "gene_add_dtm_err";

	/** CBS層 サービス契約番号キー項目名 */
	private static final String CBS_SVC_KEI_NO = "svc_kei_no";

	/** CBS層 更新年月日時分秒（更新前）キー項目名 */
	private static final String CBS_UPD_BF_NAME = "upd_dtm_bf";

	/** CBS層 更新年月日時分秒（更新前）リスト用キー項目名 */
	private static final String CBS_UPD_BF_LIST_NAME = "kk0241_upd_dtm_bf";

	/**
	 * リスト処理の対象
	 */
	private static final HashMap<String, String> TEMPLATE_LIST_MAP = new HashMap<String, String>();

	static
	{
		TEMPLATE_LIST_MAP.put("EKK0251C050", "EKK0251C050CBSMsg1List");
		TEMPLATE_LIST_MAP.put("EKK0251C060", "EKK0251C060CBSMsg1List");
	}

	/** エラーフラグ */
	private static final String ERR_FLG = "EA";

	/** エラーフラグ設定項目名 */
	private static final String ERR_CONTENTS = "upd_dtm_bf_err";

	/** エラーフラグ設定項目名リスト用 */
	private static final String ERR_CONTENTS_LIST = "kk0241_upd_dtm_bf_err";

	/**
	 * <p>
	 * サービス契約回線内訳のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProc(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 必要な項目を保持したETMsgを作成する
		CAANMsg inETMsg = new CAANMsg(KK0251ETMsg.class.getName());

		// プライマリキーを設定
		inETMsg.set(KK0251ETMsg.SVC_KEI_KAISEN_UCWK_NO, inCBSMsg.getString(CBS_PK_NAME));

		// 更新情報の設定
		inETMsg.set(KK0251ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
		inETMsg.set(KK0251ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

		// メイン処理の呼び出し
		boolean 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);
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
			return;
		}
	}

	/**
	 * <p>
	 * サービス契約回線内訳のスキーマのロック、タイムスタンプチェック、およびタイムスタンプ更新を行います（リスト単位）。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProcList(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// サービスインターフェイスIDの取得
		String templateId = inCBSMsg.getString(JCMConstants.TEMPLATE_ID_KEY);

		// 指定されたサービスインターフェイスが対象外の場合は処理を行わない
		if (!TEMPLATE_LIST_MAP.containsKey(templateId))
		{
			return;
		}

		// 明細の取得
		CAANMsg[] svcKeiList = inCBSMsg.getCAANMsgList(TEMPLATE_LIST_MAP.get(templateId));

		// 機能コードの取得
		String funcCd = inCBSMsg.getString(JCMConstants.FUNC_CODE_KEY);

		// 必要な項目を保持したETMsgを作成する
		CAANMsg inETMsg = new CAANMsg(KK0251ETMsg.class.getName());
		inETMsg.set(KK0251ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
		inETMsg.set(KK0251ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

		// 明細件数分処理を行う
		for (int i = 0; i < svcKeiList.length; i++)
		{
			// サービス契約番号、更新年月日時分秒（更新前）の取得
			String svcKeiNo = svcKeiList[i].getString(CBS_SVC_KEI_NO);
			String updDtmBf = svcKeiList[i].getString(CBS_UPD_BF_LIST_NAME);

			// ログの出力
			outLogList(inCBSMsg, svcKeiNo, updDtmBf);

			boolean ret = true;

			// サービス契約排他制御排他処理部品（サービス契約番号）の呼び出し
			ret = new JKKejbExclusiveProcKK2111().isExProcSvcKeiNo(inETMsg, svcKeiNo, updDtmBf, funcCd);

			// 処理結果がfalseの場合は関連制約エラーとする
			if (!ret)
			{
				svcKeiList[i].set(ERR_CONTENTS_LIST, ERR_FLG);
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
				return;
			}
		}
	}

	/**
	 * <p>
	 * サービス契約回線内訳のスキーマのレコード検索、ロック、タイムスタンプチェック、およびタイムスタンプ更新を行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execExclusiveProcRefTgt(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		CAANMsg retMsg = null;

		// 処理対象のメッセージに世代登録年月日時分秒が入力項目として存在する場合はプライマリ検索を行う
		if(inCBSMsg.containsKeyOfSchema(CBS_GENE_NAME_ERR))
		{
			// プライマリ検索用のメッセージを作成
			CAANMsg inETMsg = new CAANMsg(KK0251ETMsg.class.getName());
			inETMsg.set(KK0251ETMsg.SVC_KEI_KAISEN_UCWK_NO, inCBSMsg.getString(CBS_PK_NAME));
			inETMsg.set(KK0251ETMsg.GENE_ADD_DTM, inCBSMsg.getString(CBS_GENE_NAME));

			// プライマリ検索を行う
			retMsg = new JKKejbKK0251DBABase().findByPrimaryKey(inETMsg);
		}
		else
		{
			// カレント検索用のメッセージを作成
			CAANMsg inETMsg = new CAANMsg(KK0251ETMsg.class.getName());
			inETMsg.set(KK0251ETMsg.SVC_KEI_KAISEN_UCWK_NO, inCBSMsg.getString(CBS_PK_NAME));

			// カレント検索を行う
			retMsg = new JKKejbKK0251DBABase().findByCurrent(inETMsg);
		}

		// レコードが取得できなかった場合、処理を終了する
		if (null == retMsg)
		{
			return;
		}

		// 更新情報の設定
		retMsg.set(KK0251ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
		retMsg.set(KK0251ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));

		// メイン処理の呼び出し
		boolean ret = this.execExclusiveMain(retMsg, inCBSMsg.getString(CBS_UPD_BF_NAME), inCBSMsg.getString(JCMConstants.FUNC_CODE_KEY));

		// 処理結果がfalseの場合は関連制約エラーとする
		if (!ret)
		{
			inCBSMsg.set(ERR_CONTENTS, ERR_FLG);
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
			return;
		}
	}

	/**
	 * <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;

		// サービス契約回線内訳排他処理部品（サービス契約回線内訳番号）の呼び出し
		ret = new JKKejbExclusiveProcKK0251().isExProcKaisenUcwkNo(inETMsg, inETMsg.getString(KK0251ETMsg.SVC_KEI_KAISEN_UCWK_NO), updDtmBf, funcCd);

		return ret;
	}

	/**
	 * <p>
	 * ログの出力を行います。
	 * </p>
	 * @param inETMsg 処理対象のメッセージキャリア（ET）
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 */
	private void outLog(CAANMsg inETMsg, String updDtmBf)
	{
		// プライマリキーの出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK0251TPMA.svc_kei_kaisen_ucwk_no=" + inETMsg.getString(KK0251ETMsg.SVC_KEI_KAISEN_UCWK_NO));

		// 更新年月日時分秒（更新前）の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK0251TPMA.upd_dtm_bf=" + updDtmBf);
	}

	/**
	 * <p>
	 * ログの出力を行います（リスト用）。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param seikyKeiNo サービス契約番号
	 * @param updDtmBf 更新年月日時分秒（更新前）
	 */
	private void outLogList(CAANMsg inCBSMsg, String seikyKeiNo, String updDtmBf)
	{
		// プライマリキーの出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK0251TPMA.svc_kei_kaisen_ucwk_no=" + inCBSMsg.getString(CBS_PK_NAME));

		// サービス契約番号の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK0251TPMA.svc_kei_no=" + seikyKeiNo);

		// 更新年月日時分秒（更新前）の出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "JKK0251TPMA.upd_dtm_bf=" + updDtmBf);
	}

}