/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JKKMskmImgSearchCC
*   ソースファイル名：JKKMskmImgSearchCC.java
*   作成者          ：FJ)鈴木
*   日付            ：2017年07月11日
*＜機能概要＞
*   申込書イメージ付替情報検索CCです。
*＜修正履歴＞
*   バージョン  修正日      修正者      修正内容
*	v33.00.00	2017/07/11	FJ)鈴木		【ANK-3097-00-00】申込書イメージ付け替え機能の実装＜随時削減策＞
*
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.fujitsu.futurity.bp.x21.bpm.ServiceComponentRequestInvoker;
import com.fujitsu.futurity.bp.x21.bpm.db.SessionHandle;
import com.fujitsu.futurity.bp.x21.bpm.exception.RequestParameterException;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadOnly;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadWrite;
import com.fujitsu.futurity.bp.x21.cc.AbstractCommonComponent;
import com.fujitsu.futurity.bp.x21.cc.exception.SCCallException;
import com.fujitsu.futurity.common.JCMConstants;
import com.fujitsu.futurity.common.x01.sc.SCControlMapKeys;
import com.fujitsu.futurity.mapping.bp.common.TemplateErrorUtil;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.common.JCMAPLConstMgr;

import eo.common.constant.JPCModelConstant;
import eo.common.util.JKKStringUtil;
import eo.ejb.cbs.cbsmsg.EKK0021A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0021A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081B024CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081B024CBSMsg1List;


/**
 * 申込書イメージ付替情報検索CCです。<p>
 * <br>
 * @author FJ
 */
public class JKKMskmImgSearchCC extends AbstractCommonComponent
{

	/** 入力項目 サービス契約番号(付替先) */
	private static final String SAKI_SVC_KEI_NO = "saki_svc_kei_no";
	
	/** 入力項目 サービス契約番号（付替元） */
	private static final String MOTO_SVC_KEI_NO = "moto_svc_kei_no";
	
	/** 入力項目 受付番号 (付替元)*/
	private static final String MOTO_MSKMSHO_NO = "moto_mskmsho_no";
	
	/** 出力項目：サービス契約一意照会明細 */
	private static final String SVC_KEI_LIST = "svc_kei_list";
	
	/** 出力項目：申込明細一意照会明細 */
	private static final String MSKM_DTL_LIST = "mskm_dtl_list";
	
	/** 出力項目：処理結果コード */
	private static final String TRAN_RSLT_CD = "tran_rslt_cd";
	
	/** 処理結果コード：正常 */
	private static final String TRAN_RSLT_CD_NORMAL = "0";
	
	/** 処理結果コード：サービス契約存在チェックエラー */
	private static final String TRAN_RSLT_CD_NO_DATA = "1";
	
	/** 処理結果コード：サービス契約番号‐受付番号紐付けチェックエラー */
	private static final String TRAN_RSLT_CD_UNMATCH_MSKMSHO_NO = "2";

	/** エラーメッセージ */
	private static final String ERR_MSG = "INVALID_RETURN_MESSAGE";

	/** SC呼び出し部品 */
	ServiceComponentRequestInvoker scCall = null;

	/**
	 * 申込書イメージ付替情報検索処理を行います。
	 * <br>
	 * @param handle セッションマネージャなどを持ったハンドル
	 * @param param モデルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param fixedText ユーザ任意文字列
	 * @throws Throwable 例外が発生した場合
	 * @return モデルグループ、コントロールマップを含むパラメータオブジェクト
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite executeMskmImgSearch(SessionHandle handle, IRequestParameterReadWrite param, String fixedText)
	throws Throwable
	{
		// 初期処理
		init(param, fixedText);
		
		// リクエストパラメータ取得
		HashMap<String, Object> trgtData = (HashMap<String, Object>)param.getData(fixedText);
		
		// サービス契約番号（付替先）
		String sakiSvcKeiNo = (String)trgtData.get(SAKI_SVC_KEI_NO);
		
		// サービス契約番号（付替元）
		String motoSvcKeiNo = (String)trgtData.get(MOTO_SVC_KEI_NO);
		
		// 受付番号（付替元）
		String motoMskmshoNo = (String)trgtData.get(MOTO_MSKMSHO_NO);
		
		//処理結果コードに"0 : 正常"を設定
		String tranRsltCd = TRAN_RSLT_CD_NORMAL;
		
		// 運用日を取得する
		String opeDate = JPCBPCommon.getOpeDate(null);
		
		// 申込明細一意照会結果
		CAANMsg[] eKK0021A010MsgList = null;
		// サービス契約一意照会結果
		CAANMsg[] eKK0081A010MsgList = null;
		
		//検索ボタン押下
		
		//サービス契約番号（付替元）の存在有無判定
		//サービス契約番号（付替元･付替先）両方持っている場合は付替元検索、付替元がない場合は付替先検索
		
		if (!JKKStringUtil.isNullBlank(motoSvcKeiNo))
		{
			//付替元検索
			// サービス契約履歴一覧照会
			CAANMsg[] eKK0081B024MsgList = callEKK0081B024(handle, param, fixedText, motoSvcKeiNo);
			if (null == eKK0081B024MsgList || 0 == eKK0081B024MsgList.length)
			{
				//サービス契約存在チェックエラー
				tranRsltCd = TRAN_RSLT_CD_NO_DATA;
			}
			else
			{
				for (int i = 0; null != eKK0081B024MsgList && i < eKK0081B024MsgList.length ; i++)
				{
					String mskmDtlNo = eKK0081B024MsgList[i].getString(EKK0081B024CBSMsg1List.MSKM_DTL_NO);
					// 申込明細一意照会
					CAANMsg[] tmpEKK0021A010MsgList = callEKK0021A010(handle, param, fixedText, mskmDtlNo);
				
					String mskmshoNo = tmpEKK0021A010MsgList[0].getString(EKK0021A010CBSMsg1List.MSKMSHO_NO);
					if (!JKKStringUtil.isNullBlank(motoMskmshoNo) && motoMskmshoNo.equals(mskmshoNo))
					{
						eKK0021A010MsgList = tmpEKK0021A010MsgList;
						break;
					}
				}
				if (null == eKK0021A010MsgList)
				{
					//サービス契約番号‐受付番号紐付チェックエラー
					tranRsltCd = TRAN_RSLT_CD_UNMATCH_MSKMSHO_NO;
				}
				if (TRAN_RSLT_CD_NORMAL.equals(tranRsltCd))
				{
					// サービス契約一意照会
					eKK0081A010MsgList = callEKK0081A010(handle, param, fixedText, motoSvcKeiNo, opeDate);
				}
			}
		}
		//付替先検索（初期表示時）
		else if (!JKKStringUtil.isNullBlank(sakiSvcKeiNo))
		{
			// サービス契約履歴一覧照会
			CAANMsg[] eKK0081B024MsgList = callEKK0081B024(handle, param, fixedText, sakiSvcKeiNo);
			if (null != eKK0081B024MsgList && 0 < eKK0081B024MsgList.length)
			{
				String mskmDtlNo = eKK0081B024MsgList[0].getString(EKK0081B024CBSMsg1List.MSKM_DTL_NO);
				// 申込明細一意照会
				eKK0021A010MsgList = callEKK0021A010(handle, param, fixedText, mskmDtlNo);
			}

			// サービス契約一意照会
			eKK0081A010MsgList = callEKK0081A010(handle, param, fixedText, sakiSvcKeiNo, opeDate);
		}
		// 出力情報設定
		setParam(trgtData, tranRsltCd, eKK0021A010MsgList, eKK0081A010MsgList);
		
		return param ;
	}
	
	/**
	 * 出力情報を設定します。
	 * <br>
	 * @param trgtData
	 * @param tranRsltCd
	 * @param eKK0021A010MsgList
	 * @param eKK0081A010MsgList
	 */
	private void setParam(HashMap<String, Object> trgtData, String tranRsltCd,
			CAANMsg[] eKK0021A010MsgList, CAANMsg[] eKK0081A010MsgList)
	{
		trgtData.put(TRAN_RSLT_CD, tranRsltCd);
		trgtData.put(SVC_KEI_LIST, convMapList(eKK0081A010MsgList));
		trgtData.put(MSKM_DTL_LIST, convMapList(eKK0021A010MsgList));
	}

	/**
	 * CAANMsgの配列をMapのListに変換します。
	 * <br>
	 * @param msgList CAANMsgの配列
	 * @return 変換結果
	 */
	private List<Map<String, Object>> convMapList(CAANMsg[] msgList)
	{
		List<Map<String, Object>> mapList = new ArrayList<Map<String, Object>>();
		if (null != msgList)
		{
			for (CAANMsg msg : msgList)
			{
				Map<String, Object> map = new HashMap<String, Object>();
				map = msg.getHashMap();
				mapList.add(map);
			}
		}

		return mapList;
	}


	/**
	 * 申込書イメージ付替情報検索処理の初期処理です。
	 * <br>
	 * @param param モデルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param fixedText ユーザ任意文字列
	 * @throws Throwable 例外が発生した場合
	 */
	private void init(IRequestParameterReadWrite param, String fixedText)
	throws Throwable
	{
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない。
		if (null == this.scCall)
		{
			this.scCall = new ServiceComponentRequestInvoker();
		}
		
		// リターンコードに正常を設定
		param.setControlMapData(SCControlMapKeys.RETURN_CODE, JCMConstants.RET_NORMAL);
		
		// リクエストパラメータ取得
		HashMap<String, Object> trgtData = (HashMap<String, Object>)param.getData(fixedText);
		
		// 出力項目の初期値設定（正常をセット）
		trgtData.put(TRAN_RSLT_CD, TRAN_RSLT_CD_NORMAL);
	}

	
	/**
	 * サービス契約履歴一覧照会サービスインターフェースを呼び出します。
	 * <br>
	 * @param handle セッションマネージャなどを持ったハンドル
	 * @param param モデルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param fixedText ユーザ任意文字列
	 * @param svcKeiNo サービス契約番号
	 * @return サービス契約履歴一覧照会明細
	 * @throws Throwable 例外が発生した場合
	 */
	private CAANMsg[] callEKK0081B024(
			SessionHandle handle
			, IRequestParameterReadWrite param
			, String fixedText
			, String svcKeiNo)
	throws Throwable
	{
		// 上り情報を生成
		CAANMsg template = new CAANMsg(EKK0081B024CBSMsg.class.getName());
		
		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EKK0081B024CBSMsg().getContents());
		
		// 共通部を設定
		editBasicCmn(param, template);
		
		// テンプレートID(SIFのID)
		template.set(EKK0081B024CBSMsg.TEMPLATEID, "EKK0081B024");
		
		// 機能コード
		template.set(EKK0081B024CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2);
		
	    // サービス契約番号
		template.set(EKK0081B024CBSMsg.KEY_SVC_KEI_NO, svcKeiNo);
		
		HashMap<String, Object> inMap = editInMsgBasicCmn(param, template);
		
		// サービスインターフェース呼び出し
		CAANMsg rsltMsg = callSvcInter(handle, param, fixedText, inMap, new EKK0081B024CBSMsg().getContents());
		
		// 結果を返却
		CAANMsg[] rsltMsgList = rsltMsg.getCAANMsgList(EKK0081B024CBSMsg.EKK0081B024CBSMSG1LIST);
		
		return rsltMsgList;
	}
	
	/**
	 * サービス契約一意照会サービスインターフェースを呼び出します。
	 * <br>
	 * @param handle セッションマネージャなどを持ったハンドル
	 * @param param モデルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param fixedText ユーザ任意文字列
	 * @param sakiSvcKeiNo サービス契約番号
	 * @param opeDate 運用日付
	 * @return サービス契約一意照会明細
	 * @throws Throwable 例外が発生した場合
	 */
	private CAANMsg[] callEKK0081A010(
			SessionHandle handle
			, IRequestParameterReadWrite param
			, String fixedText
			, String sakiSvcKeiNo
			, String opeDate)
	throws Throwable
	{
		// 上り情報を生成
		CAANMsg template = new CAANMsg(EKK0081A010CBSMsg.class.getName());
		
		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EKK0081A010CBSMsg().getContents());
		
		// 共通部を設定
		editBasicCmn(param, template);
		
		// テンプレートID(SIFのID)
		template.set(EKK0081A010CBSMsg.TEMPLATEID, "EKK0081A010");
		
		// 機能コード："2"(カレント)
		template.set(EKK0081A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2);
		
	    // サービス契約番号（付替先）
		template.set(EKK0081A010CBSMsg.KEY_SVC_KEI_NO, sakiSvcKeiNo);
		
	    // 予約適用日を設定
		template.set(EKK0081A010CBSMsg.KEY_RSV_APLY_YMD, opeDate);
		
		HashMap<String, Object> inMap = editInMsgBasicCmn(param, template);
		
		// サービスインターフェース呼び出し
		CAANMsg rsltMsg = callSvcInter(handle, param, fixedText, inMap, new EKK0081A010CBSMsg().getContents());
		
		// 結果を返却
		CAANMsg[] rsltMsgList = rsltMsg.getCAANMsgList(EKK0081A010CBSMsg.EKK0081A010CBSMSG1LIST);
		
		return rsltMsgList;
	}
	
	
	/**
	 *申込明細一意照会サービスインターフェースを呼び出します
	 *
	 * @param handle セッションマネージャなどを持ったハンドル
	 * @param param モデルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param fixedText ユーザ任意文字列
	 * @param mskmshoDtlNo 申込明細番号
	 * @return 申込明細一意照会明細
	 * @throws Throwable
	 */
	
	private CAANMsg[] callEKK0021A010(
			SessionHandle handle
			, IRequestParameterReadWrite param
			, String fixedText
			, String mskmshoDtlNo)
	throws Throwable
	{
		// 上り情報を生成
		CAANMsg template = new CAANMsg(EKK0021A010CBSMsg.class.getName());
		
		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EKK0021A010CBSMsg().getContents());
		
		// 共通部を設定
		editBasicCmn(param, template);
		
		// テンプレートID(SIFのID)
		template.set(EKK0021A010CBSMsg.TEMPLATEID, "EKK0021A010");
		
		// 機能コード
		template.set(EKK0021A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2);
		
		// 申込明細番号（付替先）
		template.set(EKK0021A010CBSMsg.KEY_MSKM_DTL_NO, mskmshoDtlNo);
		
		HashMap<String, Object> inMap = editInMsgBasicCmn(param, template);
		
		// サービスインターフェース呼び出し
		CAANMsg rsltMsg = callSvcInter(handle, param, fixedText, inMap, new EKK0021A010CBSMsg().getContents());
		
		// 結果を返却
		CAANMsg[] rsltMsgList = rsltMsg.getCAANMsgList(EKK0021A010CBSMsg.EKK0021A010CBSMSG1LIST);
		
		return rsltMsgList;
	}

	/** ▼▼▼▼▼共通で利用するサービスインターフェイス用メソッドです▼▼▼▼▼ */

	/**
	 * サービスインターフェース呼び出し処理です。
	 * <br>
	 * @param handle セッションマネージャなどを持ったハンドル
	 * @param param モデルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param fixedText ユーザ任意文字列
	 * @param siInMap サービスインターフェースの入力マップ
	 * @param contents サービスインターフェースのテンプレート項目の配列
	 * @return 業務データ
	 * @throws Throwable 例外が発生した場合 
	 */
	private CAANMsg callSvcInter(
			SessionHandle handle
			, IRequestParameterReadWrite param
			, String fixedText
			, HashMap<String, Object> siInMap
			, Object[][] contents)
	throws Throwable
	{
		// サービスインターフェースの呼び出し
		Map<?, ?> rsltMap = this.scCall.run(siInMap, handle);
		// エラーマッピング処理
		editResultRP(rsltMap, param, fixedText, contents);
		// エラーチェック処理
		errChk(rsltMap);
		// 業務データ取得処理
		CAANMsg workData = getWorkCAANMsg(rsltMap);
		
		return workData;
	}

	/**
	 * エラーチェック処理です。
	 * <br>
	 * @param msgList サービスインタフェース実行結果
	 * @throws SCCallException 例外が発生した場合
	 */
	private void errChk(
			Map<?, ?> msgList) 
			throws SCCallException
	{
		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg template = templates[0];
		
		// リターンコード取得
		Integer returnCode = (Integer)msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// ステータス取得
		int templateStatus = template.getInt(JCMConstants.STATUS_INT_KEY);
		
		if ((0 != returnCode.intValue()) || (0 != templateStatus))
		{
			String errMsg = ERR_MSG;
			throw new SCCallException(errMsg, String.valueOf(returnCode), templateStatus);
		}
	}

	/**
	 * 業務データの取得処理です。
	 * <br>
	 * @param rslt SVIFの実行結果データ
	 * @return 業務データ
	 */
	private CAANMsg getWorkCAANMsg(Map<?, ?> rslt)
	{
		CAANMsg[] templates = (CAANMsg[])rslt.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];
		
		return parentTemplate;
	}
	
	/**
	 * サービスコンポーネント実行後に、IRequestParameterReadWriteに必要なデータをマッピングする
	 * <br>
	 * @param msgList CAANMsgクラス
	 * @param param 業務データ取得・書込用I/F
	 * @param fixedText ユーザ任意文字列
	 * @param contents サービスインターフェースのテンプレート項目の配列
	 * @return 業務データ取得・書込用I/F
	 * @throws Throwable 例外が発生した場合
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editResultRP(
			Map<?, ?> msgList
			, IRequestParameterReadWrite param
			, String fixedText
			, Object[][] contents)
	throws Throwable 
	{
		
		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg template = templates[0];
		
		// リターンコード取得
		Integer returnCode = (Integer)msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// ステータス取得
		int templateStatus = template.getInt(JCMConstants.STATUS_INT_KEY);
		
		if (returnCode.intValue() != 0)
		{
			templateStatus = 9000;
		}
		if (JCMAPLConstMgr.getString("RETURN_MESSAGE_"
				+ String.format("%1$04d", templateStatus)) == null)
		{
			templateStatus = 0;
		}
		
		int bpStatus = 0;
		Object obj = param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if (obj == null)
		{
			bpStatus = -1;
		}
		else
		{
			bpStatus = Integer.parseInt((String)param.getControlMapData(SCControlMapKeys.RETURN_CODE));
		}
		
		if (templateStatus > bpStatus)
		{
			// BPにサービスコンポーネントのステータスを設定する。
			String formatStatus = String.format("%1$04d", templateStatus);
			String message = JCMAPLConstMgr.getString("RETURN_MESSAGE_"
					+ formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, message);
		}
		// ユーザデータ情報
		HashMap inMap = (HashMap)param.getData(fixedText);
		
		// ユーザデータ情報にエラー情報をマッピング
		for(int i = 0 ; contents != null && i < contents.length ; i++)
		{
			String element = null;
			element = (String)contents[i][0];
			if (element.indexOf("_err") > 0)
			{
				if (!template.isNull(element))
				{
					if (!inMap.containsKey(element))
					{
						inMap.put(element, template.getString(element));
					}
				}
			}
		}
		
		// エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>)param.getControlMapData(SCControlMapKeys.ERROR_INFO);
		if(errList == null)
		{
			errList = new ArrayList<Object>();
		}
		
		// コントロールマップに設定
		param.setControlMapData(SCControlMapKeys.ERROR_INFO, TemplateErrorUtil.getErrorInfo(msgList, errList));
		
		return param;
	}
	
	/**
	 * サービスI/F実行用の上り情報を生成する
	 * 
	 * @param param リクエストパラメータ
	 * @param template 条件の設定先
	 * @return S/I上り情報
	 * @throws RequestParameterException 例外が発生した場合
	 */
	private HashMap<String, Object> editInMsgBasicCmn(IRequestParameterReadOnly param, CAANMsg template)
	throws RequestParameterException 
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();
		/* SCインプット共通データ */
		// **********************************************
		// 【取得元：電文ヘッダ(ヘッダ)】
		// **********************************************
		// 電文ID
		paramMap.put(JCMConstants.TRANZACTION_ID_KEY, param.getTelegramID());
		// ユースケースID
		paramMap.put(JCMConstants.USECASE_ID_KEY, param.getUsecaseID());
		// オペレーションID
		paramMap.put(JCMConstants.OPERATION_ID_KEY, param.getOperationID());
		// サービス呼び出し区分
		paramMap.put(JCMConstants.CALL_TYPE_KEY, param.getCallType());
		
		// **********************************************
		// 【取得元：ユーザエリア(コントロールマップ)】
		// **********************************************
		// 依頼先ホスト名
		paramMap.put(JCMConstants.CLIENT_HOST_NAME_KEY, param.getControlMapData(SCControlMapKeys.REQ_HOSTNAME));
		// 依頼元IPアドレス
		paramMap.put(JCMConstants.CLIENT_IP_ADDRESS_KEY, param.getControlMapData(SCControlMapKeys.REQ_HOSTIP));
		// 依頼元画面ID
		paramMap.put(JCMConstants.INVOKE_GAMEN_ID_KEY, param.getControlMapData(SCControlMapKeys.REQ_VIEWID));
		// オペレータID
		paramMap.put(JCMConstants.OPERATOR_ID_KEY, param.getControlMapData(SCControlMapKeys.OPERATOR_ID));
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);
		
		return paramMap;

	}
	
	/**
	 * 条件部の共通する項目の設定
	 * @param param リクエストパラメータ
	 * @param template 条件の設定先
	 * @throws RequestParameterException 例外が発生した場合
	 */
	private void editBasicCmn(IRequestParameterReadOnly param, CAANMsg template)
	throws RequestParameterException
	{
		// オペレータID
		Object operatorId = param.getControlMapData(SCControlMapKeys.OPERATOR_ID);
		template.set(JCMConstants.OPERATOR_ID_KEY, operatorId);
		
		// 運用日付
		Object operateDate = param.getControlMapData(SCControlMapKeys.OPE_DATE);
		template.set(JCMConstants.OPERATE_DATE_KEY, operateDate);
		
		// 運用日時
		Object operateDateTime = param.getControlMapData(SCControlMapKeys.OPE_TIME);
		template.set(JCMConstants.OPERATE_DATETIME_KEY, operateDateTime);
		
	}
	
	/**
	 * 持ちうるフィールドにNullマッピングで埋める
	 * 
	 * @param msg 対象クラス
	 * @param contents 対応クラスのフィールド列挙
	 */
	private void fillCAANMSGNullMapping(CAANMsg msg, Object[][] contents)
	{
		// 要素ごとのループ
		for(int i = 0 ; i < contents.length ; i++)
		{
			Object element = null;
			// キーに該当する箇所の取得
			element = contents[i][0];
			// Nullでマッピング
			msg.setNull((String)element);
		}
	}

	/** ▲▲▲▲▲共通で利用するサービスインターフェイス用メソッドです▲▲▲▲▲ */
}