/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JKKChkBmpInfChgMapperCC
*   ソースファイル名：JKKChkBmpInfChgMapperCC.java
*   作成者          ：富士通
*   日付            ：2012年11月13日
*＜機能概要＞
*   番ポ情報変更チェックCCで使用するマッパークラスです。
*＜修正履歴＞
*   バージョン  修正日       修正者      修正内容
*   v4.00.00    2012/11/13   FJ）        新規作成
*   v72.00.00   2024/07/11   FJ）大路    ANK-4494-00-00_【eo定期】 双方向番ポ対応
*   
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;

import com.fujitsu.futurity.bp.custom.constant.JKKChkBmpInfChgConstCC;
import com.fujitsu.futurity.bp.custom.constant.JKKSvcConst;
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.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.JKKStrConst;
import eo.common.constant.JPCModelConstant;
import eo.ejb.cbs.cbsmsg.EKK0191A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0191A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0191B001CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0191B001CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0191C012CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0191C014CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EZM0121A010CBSMsg;

/**
 * 番ポ情報変更チェック処理用マッピングクラス<p>
 * <br>
 * @author FJ
 */
public class JKKChkBmpInfChgMapperCC
{
	/** 
	 * --------------------------------------------------------------------------------------------
	 * 
	 * 上りマッピング処理 START 
	 * 
	 * --------------------------------------------------------------------------------------------
	 */

	/**
	 * EKK0191A010_サービス契約内訳＜eo光電話＞一意照会
	 * サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param svcKeiUcwkNo サービス契約内訳番号
	 * @return S/I上り情報
	 * @throws RequestParameterException
	 */
	public HashMap<String, Object> editInMsgEKK0191A010(
			IRequestParameterReadWrite param,
			String svcKeiUcwkNo)
			throws RequestParameterException
	{
		CAANMsg template = new CAANMsg(EKK0191A010CBSMsg.class.getName());

		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EKK0191A010CBSMsg().getContents());

		// 共通部を設定
		editInMsgBasicCmn(param, template);

		// テンプレートID(SIFのID)
		template.set(EKK0191A010CBSMsg.TEMPLATEID, "EKK0191A010");

		// 機能コード
		template.set(EKK0191A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2);

		// ＫＥＹ＿サービス契約内訳番号
		template.set(EKK0191A010CBSMsg.KEY_SVC_KEI_UCWK_NO, svcKeiUcwkNo);
		// ＫＥＹ＿世代登録年月日時分秒
		template.setNull(EKK0191A010CBSMsg.KEY_GENE_ADD_DTM);

		// 上り情報を生成
		return editInMsgCmn(param, template);
	}

	/**
	 * EKK0191B001_サービス契約内訳＜eo光電話＞一覧照会（サービス契約番号）
	 * サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param svcKeiNo サービス契約番号
	 * @return S/I上り情報
	 * @throws RequestParameterException
	 */
	public HashMap<String, Object> editInMsgEKK0191B001(
			IRequestParameterReadWrite param,
			String svcKeiNo)
			throws RequestParameterException
	{
		CAANMsg template = new CAANMsg(EKK0191B001CBSMsg.class.getName());

		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EKK0191B001CBSMsg().getContents());

		// 共通部を設定
		editInMsgBasicCmn(param, template);

		// テンプレートID(SIFのID)
		template.set(EKK0191B001CBSMsg.TEMPLATEID, "EKK0191B001");

		// 機能コード
		template.set(EKK0191B001CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);

		// ＫＥＹ＿サービス契約番号
		template.set(EKK0191B001CBSMsg.KEY_SVC_KEI_NO, convBlankToNull(svcKeiNo));

		// 上り情報を生成
		return editInMsgCmn(param, template);
	}

	/**
	 * EKK0191C012_サービス契約内訳＜eo光電話＞番ポ情報変更
	 * サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param trgtData 対象データ
	 * @param msgEKK0191A010 サービス契約内訳＜eo光電話＞一意照会結果
	 * @param msgEKK0191B001 サービス契約内訳＜eo光電話＞一覧照会（サービス契約番号）結果
	 * @return S/I上り情報
	 * @throws RequestParameterException
	 */
	public HashMap<String, Object> editInMsgEKK0191C012(
			IRequestParameterReadWrite param, HashMap trgtData,
			CAANMsg msgEKK0191A010, CAANMsg msgEKK0191B001)
			throws RequestParameterException
	{
		CAANMsg template = new CAANMsg(EKK0191C012CBSMsg.class.getName());
		
		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EKK0191C012CBSMsg().getContents());

		// 共通部を設定
		editInMsgBasicCmn(param, template);

		// 申込明細番号を取得
		String mskmDtlNo = msgEKK0191B001.getString(EKK0191B001CBSMsg1List.MSKM_DTL_NO);
		// 最終更新年月日時分秒を取得
		String lastUpdDtm = msgEKK0191A010.getString(EKK0191A010CBSMsg1List.LAST_UPD_DTM);

		// テンプレートID(SIFのID)
		template.set(EKK0191C012CBSMsg.TEMPLATEID, "EKK0191C012");

		// 機能コード
		template.set(EKK0191C012CBSMsg.FUNC_CODE, (String)trgtData.get(JKKChkBmpInfChgConstCC.FUNC_CODE));

		// サービス契約内訳<eo光電話>一意照会の結果を転記
		createUpdMsg(template, msgEKK0191A010, new EKK0191C012CBSMsg().getContents());

		// 以下の項目は上書き
		// 申込明細番号
		template.set(EKK0191C012CBSMsg.MSKM_DTL_NO, convBlankToNull(mskmDtlNo));
		// 予約適用年月日
		template.set(EKK0191C012CBSMsg.RSV_APLY_YMD, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.RSV_APLY_YMD)));
		// 異動区分
		template.set(EKK0191C012CBSMsg.IDO_DIV, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.IDO_DIV)));
		// 電話番号
		template.set(EKK0191C012CBSMsg.TELNO, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.TELNO)));
		// NTT契約者住所コード
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_AD_CD, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_AD_CD)));
		// NTT契約者郵便番号
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_PCD, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_PCD)));
		// NTT契約者都道府県名
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_STATE_NM, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_STATE_NM)));
		// NTT契約者市区町村名
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_CITY_NM, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_CITY_NM)));
		// NTT契約者大字通称名
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_OAZTSU_NM, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_OAZTSU_NM)));
		// NTT契約者字丁目名
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_AZCHO_NM, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_AZCHO_NM)));
		// NTT契約者番地号
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_BNCHIGO, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_BNCHIGO)));
		// NTT契約者住所補記・建物名
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_ADRTTM, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_ADRTTM)));
		// NTT契約者住所補記・部屋番号
		template.set(EKK0191C012CBSMsg.NTT_KEISHA_ADRRM, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_ADRRM)));
		// 番ポ有無
		template.set(EKK0191C012CBSMsg.BMP_UM, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.BMP_UM)));
		// 同番移転申込有無
		if (!isNull(trgtData.get(JKKChkBmpInfChgConstCC.DOBANITEN_UM)))
		{
			template.set(EKK0191C012CBSMsg.DOBANITEN_MSKM_UM, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.DOBANITEN_UM)));
		}
		// 同番移転依頼制御コード
		if (!isNull(trgtData.get(JKKChkBmpInfChgConstCC.DOBANITEN_REQ_CTRL_CD)))
		{
			template.set(EKK0191C012CBSMsg.DOBANITEN_REQ_CTRL_CD, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.DOBANITEN_REQ_CTRL_CD)));
		}
		// 同番移転判定コード
		if (isNull(trgtData.get(JKKChkBmpInfChgConstCC.DOBANITEN_JDG_CD)))
		{
			template.set(EKK0191C012CBSMsg.DOBANITEN_JDG_CD, convBlankToNull(JKKSvcConst.DOBANITEN_JDG_CD_MISETTE));
		}
		else
		{
			template.set(EKK0191C012CBSMsg.DOBANITEN_JDG_CD, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.DOBANITEN_JDG_CD)));
		}
		// 緊急通報用住所チェックレベル
		if (!isNull(trgtData.get(JKKChkBmpInfChgConstCC.EMG_AD_CHK_LV)))
		{
			template.set(EKK0191C012CBSMsg.EMG_AD_CHK_LV, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.EMG_AD_CHK_LV)));
		}
		// NTT契約者住所チェックレベル
		if (!isNull(trgtData.get(JKKChkBmpInfChgConstCC.NTT_AD_CHK_LV)))
		{
			template.set(EKK0191C012CBSMsg.NTT_AD_CHK_LV, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_AD_CHK_LV)));
		}
		// 緊急通報用契約者個別指定フラグ
		if (!isNull(trgtData.get(JKKChkBmpInfChgConstCC.EMG_KSH_KSITEI_FLG)))
		{
			template.set(EKK0191C012CBSMsg.EMG_KSH_KSITEI_FLG, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.EMG_KSH_KSITEI_FLG)));
		}

		// 更新年月日時分秒(更新前)
		template.set(EKK0191C012CBSMsg.UPD_DTM_BF, convBlankToNull(lastUpdDtm));

		// 上り情報を生成
		return editInMsgCmn(param, template);
	}

	/**
	 * EKK1091D010_進捗登録
	 * サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param trgtData 対象データ
	 * @param msgEKK0191B001 サービス契約内訳＜eo光電話＞一覧照会（サービス契約番号）結果
	 * @param prgTkjk1 進捗特記事項1
	 * @return S/I上り情報
	 * @throws RequestParameterException
	 */
	public HashMap<String, Object> editInMsgEKK1091D010(
			IRequestParameterReadWrite param, HashMap trgtData, CAANMsg msgEKK0191B001, String prgTkjk1)
			throws RequestParameterException
	{
		CAANMsg template = new CAANMsg(EKK1091D010CBSMsg.class.getName());

		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EKK1091D010CBSMsg().getContents());

		// 共通部を設定
		editInMsgBasicCmn(param, template);

		// 申込明細番号を取得
		// OT-2013-0000577 番ポ情報登録画面で番ポ情報チェックがされていない 2013/04/08 START
//		String mskmDtlNo = msgEKK0191B001.getString(EKK0191B001CBSMsg1List.MSKM_DTL_NO);
		String mskmDtlNo = "";
		if (null != msgEKK0191B001)
		{
			mskmDtlNo = msgEKK0191B001.getString(EKK0191B001CBSMsg1List.MSKM_DTL_NO);
		}
		// OT-2013-0000577 番ポ情報登録画面で番ポ情報チェックがされていない 2013/04/08 END

		// テンプレートID(SIFのID)
		template.set(EKK1091D010CBSMsg.TEMPLATEID, "EKK1091D010");

		// 機能コード
		template.set(EKK1091D010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);

		// 申込明細番号
		template.set(EKK1091D010CBSMsg.MSKM_DTL_NO, mskmDtlNo);
		// サービス契約番号
		template.set(EKK1091D010CBSMsg.SVC_KEI_NO, (String)trgtData.get(JKKChkBmpInfChgConstCC.SVC_KEI_NO));
		// サービス契約内訳番号
		template.set(EKK1091D010CBSMsg.SVC_KEI_UCWK_NO, (String)trgtData.get(JKKChkBmpInfChgConstCC.SVC_KEI_UCWK_NO));
		// 異動区分
		template.set(EKK1091D010CBSMsg.IDO_DIV, (String)trgtData.get(JKKChkBmpInfChgConstCC.IDO_DIV));
		// 異動年月日時分秒
		// 2013/01/10 IT1-2013-0000039 MOD START
		//template.set(EKK1091D010CBSMsg.IDO_DTM, JCCBPCommon.getOpeDateTimeStamp(null));
		template.set(EKK1091D010CBSMsg.IDO_DTM, JCCBPCommon.getSysDateTimeStamp());
		// 2013/01/10 IT1-2013-0000039 MOD END
		// 進捗ステータス 「ｅｏ電話番ポエリアチェックNG」
		template.set(EKK1091D010CBSMsg.PRG_STAT, JKKStrConst.CD00647_BMP_AREA_CHK_NG);
		// 進捗特記事項1
		template.set(EKK1091D010CBSMsg.PRG_TKJK_1, prgTkjk1);

		ArrayList<HashMap<String, Object>> idoRsnList = (ArrayList<HashMap<String, Object>>)trgtData.get(JKKChkBmpInfChgConstCC.IDO_RSN_LIST);

		if (idoRsnList != null && idoRsnList.size() > 0)
		{
			CAANMsg[] template1 = new CAANMsg[idoRsnList.size()];
			for (int i = 0; i < idoRsnList.size(); i++)
			{
				HashMap<String, Object> idoRsnInfo = idoRsnList.get(i);
				template1[i] = new CAANMsg(EKK1091D010CBSMsg1List.class.getName());
				
				// nullマッピングを実施
				fillCAANMSGNullMapping(template1[i], new EKK1091D010CBSMsg1List().getContents());
				
				// 異動理由コード
				template1[i].set(EKK1091D010CBSMsg1List.IDO_RSN_CD, (String)idoRsnInfo.get(JKKChkBmpInfChgConstCC.IDO_RSN_CD));
				// 異動理由メモ
				template1[i].set(EKK1091D010CBSMsg1List.IDO_RSN_MEMO, (String)idoRsnInfo.get(JKKChkBmpInfChgConstCC.IDO_RSN_MEMO));
			}
			template.set(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST, template1);

		}
		
		// 上り情報を生成
		return editInMsgCmn(param, template);
	}

	// OT-2013-0000577 番ポ情報登録画面で番ポ情報チェックがされていない 2013/04/08 START
	/**
	 * EKK0191C014_番ポ情報登録可否チェック
	 * サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param trgtData 対象データ
	 * @return S/I上り情報
	 * @throws RequestParameterException
	 */
	public HashMap<String, Object> editInMsgEKK0191C014(
			IRequestParameterReadWrite param, HashMap trgtData)
			throws RequestParameterException
	{
		CAANMsg template = new CAANMsg(EKK0191C014CBSMsg.class.getName());
		
		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EKK0191C014CBSMsg().getContents());

		// 共通部を設定
		editInMsgBasicCmn(param, template);

		// テンプレートID(SIFのID)
		template.set(EKK0191C014CBSMsg.TEMPLATEID, "EKK0191C014");

		// 機能コード
		template.set(EKK0191C014CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);

		// 電話番号
		template.set(EKK0191C014CBSMsg.TELNO, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.TELNO)));
		// NTT契約者住所コード
		template.set(EKK0191C014CBSMsg.NTT_KEISHA_AD_CD, convBlankToNull((String)trgtData.get(JKKChkBmpInfChgConstCC.NTT_KEISHA_AD_CD)));

		// 上り情報を生成
		return editInMsgCmn(param, template);
	}
	// OT-2013-0000577 番ポ情報登録画面で番ポ情報チェックがされていない 2013/04/08 END

// ANK-4494-00-00 ADD START
	/**
	 * EZM0121A010_電話番号一意照会
	 * サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param telno 電話番号
	 * @return S/I上り情報
	 * @throws RequestParameterException
	 */
	public HashMap<String, Object> editInMsgEZM0121A010(
			IRequestParameterReadWrite param,
			String telno)
			throws RequestParameterException
	{
		CAANMsg template = new CAANMsg(EZM0121A010CBSMsg.class.getName());

		// nullマッピングを実施
		fillCAANMSGNullMapping(template, new EZM0121A010CBSMsg().getContents());

		// 共通部を設定
		editInMsgBasicCmn(param, template);

		// テンプレートID(SIFのID)
		template.set(EZM0121A010CBSMsg.TEMPLATEID, "EZM0121A010");

		// 機能コード
		template.set(EZM0121A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);

		// ＫＥＹ＿電話番号
		template.set(EZM0121A010CBSMsg.KEY_TELNO, convBlankToNull(telno));

		// 上り情報を生成
		return editInMsgCmn(param, template);
	}
// ANK-4494-00-00 ADD END

	/**
	 * 照会系メッセージから更新メッセージを作成する
	 * 
	 * @param updMsg 更新メッセージ
	 * @param shokaiMsg 照会メッセージ
	 * @param updContents 更新コンテンツ
	 */
	private void createUpdMsg(CAANMsg updMsg, CAANMsg shokaiMsg, Object[][] updContents)
	{
		if (updMsg == null || shokaiMsg == null)
		{
			return;
		}
		
		for(int i = 0 ; updContents != null && i < updContents.length ; i++)
		{
			String element = null;
			element = (String)updContents[i][0];
			if (element.indexOf("_err") > 0)
			{
				element = element.substring(0, element.indexOf("_err"));
				if (shokaiMsg.containsKeyOfMsgData(element))
				{
					if (shokaiMsg.isNull(element))
					{
						updMsg.setNull(element);
					}
					else
					{
						updMsg.set(element, shokaiMsg.getObject(element));
					}
				}
			}
		}
	}

	/** 
	 * --------------------------------------------------------------------------------------------
	 * 
	 * 上りマッピング処理 END 
	 * 
	 * --------------------------------------------------------------------------------------------
	 */

	/** 
	 * --------------------------------------------------------------------------------------------
	 * 
	 * 下りマッピング処理 START 
	 * 
	 * --------------------------------------------------------------------------------------------
	 */
	/** 
	 * --------------------------------------------------------------------------------------------
	 * 
	 * 下りマッピング処理 END 
	 * 
	 * --------------------------------------------------------------------------------------------
	 */

	/** 
	 * --------------------------------------------------------------------------------------------
	 * 
	 * エラーマッピング処理 START 
	 * 
	 * --------------------------------------------------------------------------------------------
	 */
	
	/**
	 * <pre>
	 * サービスコンポーネント実行後に、IRequestParameterReadWriteに必要なデータをマッピングする
	 * 
	 * </pre>
	 * @param msgList CAANMsgクラス
	 * @param param 業務データ取得・書込用I/F
	 * @param fixedText ユーザ任意文字列
	 * @param contents サービスインターフェースのテンプレート項目の配列
	 * @return 業務データ取得・書込用I/F
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public 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 && !"search_err_flg".equals(element))
			{
				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;
	}
	
	/** 
	 * --------------------------------------------------------------------------------------------
	 * 
	 * エラーマッピング処理 END 
	 * 
	 * --------------------------------------------------------------------------------------------
	 */
	
	/** 
	 * --------------------------------------------------------------------------------------------
	 * 
	 * ユーティリティメソッド START 
	 * 
	 * --------------------------------------------------------------------------------------------
	 */
	
	/**
	 * 条件部の共通する項目の設定する
	 * 
	 * @param param リクエストパラメータ
	 * @param template template 条件の設定先
	 * @throws RequestParameterException
	 */
	private void editInMsgBasicCmn(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);
		
	}
	
	/**
	 * サービスI/F実行用の上り情報を生成する
	 * 
	 * @param param リクエストパラメータ
	 * @param template 条件の設定先
	 * @return S/I上り情報
	 * @throws RequestParameterException
	 * @exception RequestParameterException
	 */
	private HashMap<String, Object> editInMsgCmn(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;

	}
	
	/**
	 * 持ちうるフィールドに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);
		}
	}

	/**
	 * オブジェクトに値が設定されているか判定する
	 * 
	 * @param arg0 判定するオブジェクト
	 * @return オブジェクトに値が設定されていない場合はtrue
	 */
	private boolean isNull(Object arg0) 
	{
		if (arg0 == null) 
		{
			return true;
		}

		return 0 == arg0.toString().length();
	}

	/**
	 * 文字列が空文字ならnullに変換する
	 * 
	 * @param value 判定する文字列
	 * @return 変換後文字列
	 */
	private String convBlankToNull(String value)
	{
		return JKKSvcConst.STRING_BLANK.equals(value) ? null : value;
	}

	/** 
	 * --------------------------------------------------------------------------------------------
	 * 
	 * ユーティリティメソッド END 
	 * 
	 * --------------------------------------------------------------------------------------------
	 */
}