/*******************************************************************************
*	 All Rights reserved,Copyright (c) K-Opticom 
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKK0351C260ETDA
*	ソースファイル名：JEKK0351C260ETDA.java
*	作成者			：EK103142
*	日付			：2011年10月09日
*＜機能概要＞
*	サービス契約解約中止 ETMsgDBアクセス部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	ｖ1.00.00
*
********************************************************************************/

package eo.ejb.common.db;

import java.util.ArrayList;
import java.util.HashMap;

import com.fujitsu.futurity.common.JCMConstants;
import com.fujitsu.futurity.model.base.CAANException;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.base.CAANRuntimeException;
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 eo.ejb.cbm.entity.KK1681ETMsg;
import eo.ejb.cbm.entity.KK1681LE;
import eo.ejb.cbs.cbsmsg.EKK0351C260CBSMsg;
import eo.ejb.cbs.mainproc.JKKejbIdoRsvUtil;
import eo.ejb.common.JKKModelCommon;
import eo.ejb.common.rule.JKKejbRule0083001;

/**
 * <p>
 * オプションサービス契約解約中止ETMsgDBアクセス部品です。
 * </p>
 * @author 富士通
 */
public class JEKK0351C260ETDA 
{
	/** 異動予約状態コード：取消済 */
	private static final String YOYAKU_ROLLBACK = "02";
	
	/** 異動予約状態コード：予約手続中 */
	private static final String YOYAKU_PROCEDURE = "03";
	
	/** 異動予約状態コード：未反映 */
	private static final String YOYAKU_UNREFLECT = "00";
	
	/** 異動予約詳細コード：オプション解約 */
	private static final String OP_CANCELL = "016";
	
	/** ルールエンジン返却値：振舞対象スキーマ項目名 */
	private static final String TRGT_SCHEMA_ID = "TRGT_SCHEMA_ID";
	
	/** ルールエンジン返却値：振舞対象スキーマ（異動予約） */
	private static final String SCHEMA_KK1681 = "KK1681";
	
	/**
	 * コンストラクタ
	 */
	public JEKK0351C260ETDA()
	{
	}
	
	/**
	 * 相関ルール振舞判定を行い、DBアクセス部品を呼び出す
	 * 
	 * @param inCBSMsg  処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */
	public void execDBAccess(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JEKK0351C260ETDA.execDBAccess");

		// ルールエンジン用入力値設定
		JKKejbRule0083001 rule0083 = new JKKejbRule0083001(inCBSMsg);
		rule0083.setSvc_if_id(inCBSMsg.getString(JCMConstants.TEMPLATE_ID_KEY)); // サービスIFIDを設定	
		
		// ルールエンジン実行
		ArrayList<HashMap<String, Object>> rslt = rule0083.referRuleEngine();
		
		//結果が取得できなかった場合は更新処理しない
		if (rslt == null || rslt.size() == 0)
		{
			// 相関エラーのステータスを設定
			inCBSMsg.set(EKK0351C260CBSMsg.OP_SVC_KEI_NO, "EA");
			inCBSMsg.set(EKK0351C260CBSMsg.STATUS, StatusCodes.TEMPLATE_CORRELATION_ERR);
			return;
		}
		
		// 相関ルールチェック結果を格納
		new JKKejbIdoRsvUtil().setOnlyIdoRsvFlg(inCBSMsg, inContext, rslt);
		
		// メッセージ変換を行いDBアクセスを行う
		for(int i = 0; i < rslt.size(); i++)
		{
			execDBAccess(inCBSMsg, rslt.get(i), inContext);
		}
		
		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JEKK0351C260ETDA.execDBAccess");
	}

	/**
	 * DBAccess処理
	 * @param  inCBSMsg 実行前CBSMsg
	 * @param  rs ルールエンジン実行結果格納マップ
	 * @param  inContext AgentDispatchContext
	 * @return inCBSMsg 実行後CBSMsg
	 */
	private void execDBAccess(CAANMsg inCBSMsg, HashMap<String, Object> rs, AgentDispatchContext inContext)
	{
		try
		{
			// 運用日付取得
			String upd_date = JKKModelCommon.getOpeDate(inCBSMsg);
							
			// 振舞対象スキーマが異動予約の場合
			if (SCHEMA_KK1681.equals(rs.get(TRGT_SCHEMA_ID)))
			{
				// 異動予約更新用Msg生成
				CAANMsg update1681ETMsg = new CAANMsg(KK1681ETMsg.class.getName());
					
				// 異動予約番号のリスト取得
				String[] keyNoList = getIDO_RSV_NO(inCBSMsg, upd_date);
				
				// 取得した異動予約番号の数だけ更新処理を行う
				for (int i = 0; i < keyNoList.length; i++)
				{
					// 異動予約番号	IDO_RSV_NO
					update1681ETMsg.set(KK1681ETMsg.IDO_RSV_NO, keyNoList[i]);
					
					// 異動予約取消年月日	IDO_RSV_CL_YMD
					update1681ETMsg.set(KK1681ETMsg.IDO_RSV_CL_YMD, upd_date);
					
					// 異動予約状態コード	IDO_RSV_STAT_CD
					update1681ETMsg.set(KK1681ETMsg.IDO_RSV_STAT_CD, YOYAKU_ROLLBACK);
					
					// 更新年月日時分秒	UPD_DTM
					update1681ETMsg.set(KK1681ETMsg.UPD_DTM, inCBSMsg.getString(JCMConstants.OPERATE_DATETIME_KEY));
					
					// 更新オペレータアカウント	UPD_OPEACNT
					update1681ETMsg.set(KK1681ETMsg.UPD_OPEACNT, inCBSMsg.getString(JCMConstants.OPERATOR_ID_KEY));
					
					// 異動予約番号の更新
					JKKejbDBAUtil dba = new JKKejbDBAUtil(inCBSMsg);
					dba.update(update1681ETMsg);
				}
	
				// 返却項目メッセージ生成
				inCBSMsg.set(EKK0351C260CBSMsg.UPD_DTM, update1681ETMsg.getString(KK1681ETMsg.UPD_DTM));
				inCBSMsg.set(EKK0351C260CBSMsg.UPD_OPEACNT, update1681ETMsg.getString(KK1681ETMsg.UPD_OPEACNT));
			}
		}
		catch(CAANRuntimeException ce)
		{
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}
	}
	
	/**
	 * DBより条件に一致する異動予約番号を取得して配列で返却する。
	 * @param inCBSMsg 入力元のCBSMsg
	 * @param upd_date 運用日付
	 * @return 更新対象の異動予約番号リスト
	 */
	private String[] getIDO_RSV_NO(CAANMsg inCBSMsg, String upd_date)
	{
		KK1681LE le = new KK1681LE();
		
		// 異動予約参照用Msg生成
		CAANMsg conditionETMsg = new CAANMsg(KK1681ETMsg.class.getName());
		conditionETMsg.set(KK1681ETMsg.OP_SVC_KEI_NO, inCBSMsg.getString(EKK0351C260CBSMsg.OP_SVC_KEI_NO));
		conditionETMsg.set(KK1681ETMsg.IDO_RSV_DTL_CD, OP_CANCELL);
		conditionETMsg.set(KK1681ETMsg.MK_FLG, "0");
		
		//条件付き一覧照会
		CAANMsg[] resultMsg;
		try
		{
			resultMsg = le.findByCondition(conditionETMsg);
		}
		catch (CAANException e)
		{
			throw new CAANRuntimeException(e);
		}

		// 異動予約番号取得用Msg配列生成
		ArrayList<String> keyNoList = new ArrayList<String>();
		for (int i = 0; i < resultMsg.length; i++)
		{
			//一覧照会で判定できなかった条件で絞り込み
			if ((YOYAKU_PROCEDURE.equals(resultMsg[i].getString(KK1681ETMsg.IDO_RSV_STAT_CD))
					|| YOYAKU_UNREFLECT.equals(resultMsg[i].getString(KK1681ETMsg.IDO_RSV_STAT_CD)))
				&& resultMsg[i].getString(KK1681ETMsg.RSV_APLY_YMD).compareTo(upd_date) >= 0)
			{
				keyNoList.add(resultMsg[i].getString(KK1681ETMsg.IDO_RSV_NO));
			}
		}
		
		return keyNoList.toArray(new String[0]);
	}
}
