/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKDslLetterSearchCC
*	ソースファイル名：JKKDslLetterSearchCC.java
*	作成者			：FJ
*	日付			：2017年09月21日
*＜機能概要＞
*	解約レター一覧検索処理の共通コンポーネント
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v33.00.00	2017/09/21	FJ)クウン	【ANK-3251-00-00】（契アシRDSツール改善）解約レターのシステム化  新規作成
*	v33.01.00	2017/12/05	FJ)原田		【ANK-3346-00-00】【解約レター機能関連】改善要望　Ｓｔｅｐ１
*	v59.00.00	2022/04/14	FJ)平野		【ANK-4245-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.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.CCException;
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.ejb.cbs.cbsmsg.EKK3111B010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK3111B010CBSMsg1List;

/**
 * 解約レター検索情報取得を行う。<p>
 * <BR>
 * @author 富士通
 */
public class JKKDslLetterSearchCC extends AbstractCommonComponent
{
	/**
	 * 検索フラグ（要）
	 */
	private static final String SEARCH_FLG_Y = "1";
	/**
	 * 検索結果（正常）
	 */
	private static final String NORMAL_END = "0";

	/** 解約レター検索情報取得 */
	private static final String TEMPLATE_ID_EKK3111B010 = "EKK3111B010";
	
	/**
	 * サービスインターフェイスを作成し、取扱コードに関する各諸情報の取得を行う。
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return リクエストパラメータ
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite getDslLetterSearch(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
		// ユーザデータ情報
		HashMap inMap = (HashMap)param.getData(fixedText);

		// 検索フラグ取得
		String search_flg = (String)inMap.get("search_flg");

		// 検索：要の場合
		if (SEARCH_FLG_Y.equals(search_flg))
		{
			// 解約レター一覧情報取得情報取得処理（※指定されたページ）
			String ret = getKaiyakuLettterInfo(handle, param, fixedText, "");
			
			// 検索エラーフラグが
			// 表示ページに該当するデータなしの場合は再検索
			if (JPCModelConstant.SEARCH_ERR_FLG_NODATA.equals(ret))
			{
				// 解約レター一覧情報取得情報取得処理（※先頭ページ）
				ret = getKaiyakuLettterInfo(handle, param, fixedText, "1");
			}
		}
		
		return param;
	}
	
	/**
	 * チェック処理<br>
	 * サービスコンポーネント実行用CAANMsgを返却します。<br>
	 * <br>
	 * 
	 * @param handle セッションハンドル
	 * @param param (I) 業務データ取得用I/F
	 * @param fixedText (I) ユーザ定義文字列
	 * @return サービスコンポーネント実行用CAANMsg
	 * @exception Throwableがスローされます 。
	 */
	@SuppressWarnings("unchecked")
	public HashMap<String, Object> getInvokeCBS(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
		// 返却用
		HashMap<String, Object> paramMap = null;

		// ユーザデータ情報
		HashMap inMap = (HashMap)param.getData(fixedText);

		// 検索フラグ取得
		String search_flg = (String)inMap.get("search_flg");

		// 検索：要の場合
		if (SEARCH_FLG_Y.equals(search_flg))
		{
			// 上りマッピング
			paramMap = editInMsg_EKK3111B010CBS(param, fixedText, "");
		}

		return paramMap;
	}

	/**
	 * サービスインターフェイス処理結果(エラー情報)の取得<br>
	 * 業務データ取得・書込用I/Fをそのまま返却します。<br>
	 * <br>
	 * @param param デルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param templates CAANMsgクラス配列
	 * @param returnCode リターンコード
	 * @param fixedText ユーザ定義文字列
	 * @return 業務データ取得・書込用I/F
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param,
			CAANMsg[] templates, int returnCode, String fixedText) throws Throwable
	{
		// ユーザデータ情報
		HashMap inMap = (HashMap)param.getData(fixedText);

		// 検索フラグ取得
		String search_flg = (String)inMap.get("search_flg");

		// 検索：要の場合
		if (SEARCH_FLG_Y.equals(search_flg))
		{
			// エラー情報の設定
			param = editErrorInfo_EKK3011B010CBS(param, templates, returnCode, fixedText);
		}

		return param;
	}

	/**
	 * 解約レター一覧情報取得情報取得処理
	 * <br>
	 * 契約内容通知書情報の一覧取得を行います。<BR>
	 * ページが指定されなければ、パラメータの表示ページ番号で検索します。<BR>
	 * ページが指定されていれば、指定されたページ番号で検索します。<BR>
	 * ただし、検索結果が取得できた場合であっても、検索エラーフラグに「3：表示ページに該当するデータなし」<BR>
	 * をセットします。<BR>
	 * <P>
	 * @param handle セッションハンドル
	 * @param param 業務データ取得用I/F
	 * @param fixedText ユーザ定義文字列
	 * @param pageNum 表示ページ番号
	 * @return 検索エラーフラグ
	 * @throws Throwable 
	 */
	private String getKaiyakuLettterInfo(SessionHandle handle,
			IRequestParameterReadWrite param, String fixedText, String pageNum) throws Throwable
	{
		
		// 上りマッピング
		HashMap<String, Object> paramMap = editInMsg_EKK3111B010CBS(param, fixedText, pageNum);
		
		// SC呼び出し部品のインスタンス生成
		//（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない。）
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();

		// SC呼出
		Map<?, ?> result = scCall.run(paramMap, handle);

		// 下りマッピング
		String err_flg = editResultRP_EKK3111B010CBS(result, param, fixedText, pageNum);

		return err_flg;
	}

	/**
	 * 上りマッピング<br>
	 * <br>
	 * サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングします。
	 * <br>
	 * @param param 業務データ取得用I/F
	 * @param fixedText ユーザ定義文字列
	 * @param pageNum 表示ページ番号
	 * @return サービスコンポーネント実行用CAANMsg
	 * @throws RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	private HashMap<String, Object> editInMsg_EKK3111B010CBS(IRequestParameterReadOnly param,
			String fixedText, String pageNum) 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 template = new CAANMsg(EKK3111B010CBSMsg.class.getName());

		// テンプレートID
		template.set(EKK3111B010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK3111B010);

		// 機能コード（デフォルト：１）
		template.set(EKK3111B010CBSMsg.FUNC_CODE, "1");

		// オペレータ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);

		// ユーザデータ情報
		HashMap inMap = (HashMap)param.getData(fixedText);
		
		if (inMap != null)
		{
			// 機能コード
			template.set(EKK3111B010CBSMsg.FUNC_CODE, inMap.get(JCMConstants.FUNC_CODE_KEY));
		}

		// 解約レター取得ＣＣマップ.検索処理パターン → 検索処理パターン
		setParam(template ,inMap , EKK3111B010CBSMsg.SEARCH_TYPE , "search_type");

		// 解約レター取得ＣＣマップ.最大検索件数 → 最大検索件数
		setParam(template ,inMap , EKK3111B010CBSMsg.MAX_SEARCH_NUM , "max_search_num");

		// 解約レター取得ＣＣマップ.表示件数 → 表示件数
		setParam(template ,inMap , EKK3111B010CBSMsg.DISPLAY_NUM , "display_num");

		// ページ番号の指定があった場合
		if (!"".equals(pageNum))
		{
			template.set(EKK3111B010CBSMsg.DISPLAY_PAGE_NUM, pageNum);
		}
		else
		{
			// 解約レター取得ＣＣマップ.表示ページ番号 → 表示ページ番号
			setParam(template ,inMap , EKK3111B010CBSMsg.DISPLAY_PAGE_NUM , "display_page_num");
		}
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿ＳＹＳＩＤ → ＫＥＹ＿ＳＹＳＩＤ
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_SYSID , "key_sysid");
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿請求契約番号 → ＫＥＹ＿請求契約番号
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_SEIKY_KEI_NO , "key_seiky_kei_no");
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿お客さまID → ＫＥＹ＿お客さまID
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_SVC_KEI_NO , "key_svc_kei_no");
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿レター登録年月日（自） → ＫＥＹ＿レター登録年月日（自）
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_LETTER_ADD_YMD_FROM , "key_letter_add_ymd_from");

		// 解約レター取得ＣＣマップ.ＫＥＹ＿レター登録年月日（至） → ＫＥＹ＿レター登録年月日（至）
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_LETTER_ADD_YMD_TO , "key_letter_add_ymd_to");
		
		// ANK-3346-00-00 ADD START
		// 解約レター取得ＣＣマップ.ＫＥＹ＿登録者ID → ＫＥＹ＿登録者ID
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_ADD_USER_ID , "key_add_user_id");
		// ANK-3346-00-00 ADD END
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿発行区分 → ＫＥＹ＿発行区分
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_HAK_DIV , "key_hak_div");

		// 解約レター取得ＣＣマップ.ＫＥＹ＿照合済フラグ → ＫＥＹ＿照合済フラグ
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_SHOGO_FLG , "key_shogo_flg");
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿未送信 → ＫＥＹ＿未送信
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_MI_SEND , "key_mi_send");

		// 解約レター取得ＣＣマップ.ＫＥＹ＿レター発行要フラグ → ＫＥＹ＿レター発行要フラグ
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_LETTER_HAK_Y , "key_letter_hak_y");
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿ソート項目Ｎｏ → ＫＥＹ＿ソート項目Ｎｏ
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_SORT_ITEM_NO , "key_sort_item_no");

		// 解約レター取得ＣＣマップ.ＫＥＹ＿ソート区分 → ＫＥＹ＿ソート区分
		setParam(template ,inMap , EKK3111B010CBSMsg.KEY_SORT_KBN , "key_sort_kbn");

		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	/**
	 * 下りマッピング
	 * <br>
	 * サービスコンポーネント実行後に、IRequestParameterReadWriteに必要なデータをマッピングします<br>
	 * <br>
	 * @param msgList CAANMsgクラス
	 * @param param 業務データ取得・書込用I/F
	 * @param fixedText ユーザ定義文字列
	 * @param pageNum 表示ページ番号
	 * @return 検索エラーフラグ
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	private String editResultRP_EKK3111B010CBS(Map<?, ?> msgList,
			IRequestParameterReadWrite param, String fixedText, String pageNum) throws Throwable
	{
		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];
		CAANMsg[] templateArray = null;

		// 結果を詰めるマップを取得。
		HashMap dataMap = null;
		ArrayList dataList = null;

		// 検索エラーフラグ
		String err_flg = NORMAL_END;
		
		// 業務データ設定
		dataMap = (HashMap)param.getData(fixedText);
		if (dataMap == null)
		{
			dataMap = new HashMap();
			param.setData(fixedText, dataMap);
		}
		// 解約レター取得ＣＣマップ.総検索件数 ← 総検索件数
		getParam(parentTemplate, dataMap, "total_search_num", EKK3111B010CBSMsg.TOTAL_SEARCH_NUM);

		// 解約レター取得ＣＣマップ.総ページ数 ← 総ページ数
		getParam(parentTemplate, dataMap, "total_page_num", EKK3111B010CBSMsg.TOTAL_PAGE_NUM);

		// 解約レター取得ＣＣマップ.検索エラーフラグ ← 検索エラーフラグ
		getParam(parentTemplate, dataMap, "search_err_flg", EKK3111B010CBSMsg.SEARCH_ERR_FLG);

		templateArray = parentTemplate.getCAANMsgList(EKK3111B010CBSMsg.EKK3111B010CBSMSG1LIST);
		dataList = (ArrayList)dataMap.get("EKK3111B010CBSMsg1List");

		if (dataList == null)
		{
			dataList = new ArrayList();
		}

		if (templateArray != null)
		{
			for (int i = 0; i < templateArray.length; i++)
			{
				CAANMsg childTemplate = templateArray[i];
				if (i >= dataList.size())
				{
					dataList.add(new HashMap());
				}
				HashMap childMap = (HashMap)dataList.get(i);

				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター登録番号 ← 解約レター一覧情報取得.解約レター登録番号
				getParam(childTemplate, childMap, "dsl_letter_add_no", EKK3111B010CBSMsg1List.DSL_LETTER_ADD_NO);

				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レターステータス ← 解約レター一覧情報取得.解約レターステータス
				getParam(childTemplate, childMap, "dsl_letter_stat", EKK3111B010CBSMsg1List.DSL_LETTER_STAT);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター発行区分 ← 解約レター一覧情報取得.解約レター発行区分
				getParam(childTemplate, childMap, "dsl_letter_hak_div", EKK3111B010CBSMsg1List.DSL_LETTER_HAK_DIV);

				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター発行区分名称 ← 解約レター一覧情報取得.解約レター発行区分名称
				getParam(childTemplate, childMap, "dsl_letter_hak_div_nm", EKK3111B010CBSMsg1List.DSL_LETTER_HAK_DIV_NM);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター発行要否 ← 解約レター一覧情報取得.解約レター発行要否
				getParam(childTemplate, childMap, "dsl_letter_hak_yh", EKK3111B010CBSMsg1List.DSL_LETTER_HAK_YH);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター登録年月日 ← 解約レター一覧情報取得.解約レター登録年月日
				getParam(childTemplate, childMap, "dsl_letter_add_ymd", EKK3111B010CBSMsg1List.DSL_LETTER_ADD_YMD);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター送信年月日 ← 解約レター一覧情報取得.解約レター送信年月日
				getParam(childTemplate, childMap, "dsl_letter_snd_ymd", EKK3111B010CBSMsg1List.DSL_LETTER_SND_YMD);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター取消年月日 ← 解約レター一覧情報取得.解約レター取消年月日
				getParam(childTemplate, childMap, "dsl_letter_cl_ymd", EKK3111B010CBSMsg1List.DSL_LETTER_CL_YMD);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター照合済フラグ ← 解約レター一覧情報取得.解約レター照合済フラグ
				getParam(childTemplate, childMap, "dsl_letter_shogo_flg", EKK3111B010CBSMsg1List.DSL_LETTER_SHOGO_FLG);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター照合済フラグ名称 ← 解約レター一覧情報取得.解約レター照合済フラグ名称
				getParam(childTemplate, childMap, "dsl_letter_shogo_flg_nm", EKK3111B010CBSMsg1List.DSL_LETTER_SHOGO_FLG_NM);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.請求契約番号 ← 解約レター一覧情報取得.請求契約番号
				getParam(childTemplate, childMap, "seiky_kei_no", EKK3111B010CBSMsg1List.SEIKY_KEI_NO);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.SYSID ← 解約レター一覧情報取得.SYSID
				getParam(childTemplate, childMap, "sysid", EKK3111B010CBSMsg1List.SYSID);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.ネット-サービス契約番号 ← 解約レター一覧情報取得.ネット-サービス契約番号
				getParam(childTemplate, childMap, "net_svc_kei_no", EKK3111B010CBSMsg1List.NET_SVC_KEI_NO);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.電話-サービス契約番号 ← 解約レター一覧情報取得.電話-サービス契約番号
				getParam(childTemplate, childMap, "tel_svc_kei_no", EKK3111B010CBSMsg1List.TEL_SVC_KEI_NO);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.テレビ-サービス契約番号 ← 解約レター一覧情報取得.テレビ-サービス契約番号
				getParam(childTemplate, childMap, "tv_svc_kei_no", EKK3111B010CBSMsg1List.TV_SVC_KEI_NO);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.解約レター送付先住所 ← 解約レター一覧情報取得.解約レター送付先住所
				getParam(childTemplate, childMap, "dsl_letter_sohus_state_nm", EKK3111B010CBSMsg1List.DSL_LETTER_SOHUS_STATE_NM);
				
				// ANK-3346-00-00 ADD START
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.登録ユーザー名 ← 解約レター一覧情報取得.登録ユーザー名
				getParam(childTemplate, childMap, "add_user_nm", EKK3111B010CBSMsg1List.ADD_USER_NM);
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.登録オペレータアカウント ← 解約レター一覧情報取得.登録オペレータアカウント
				getParam(childTemplate, childMap, "add_opeacnt", EKK3111B010CBSMsg1List.ADD_OPEACNT);
				// ANK-3346-00-00 ADD END
				
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.更新年月日時分秒 ← 解約レター一覧情報取得.解約レター登録年月日
				getParam(childTemplate, childMap, "upd_dtm", EKK3111B010CBSMsg1List.UPD_DTM);
				// ANK-4245-00-00 ADD START
				// 解約レター取得ＣＣマップ.解約レター一覧情報取得.サービス契約回線内訳番号 ← 解約レター一覧情報取得.サービス契約回線内訳番号
				getParam(childTemplate, childMap, "svc_kei_kaisen_ucwk_no", EKK3111B010CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO);
				// ANK-4245-00-00 ADD END

			}
		}

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);
		Integer return_code_num = (Integer)return_code;

		// ページ番号の指定があった場合
		if (!"".equals(pageNum))
		{
			// 実行結果が正常であれば、検索エラーフラグを置き換える
			if (return_code_num.intValue() == 0)
			{
				dataMap.put("search_err_flg", JPCModelConstant.SEARCH_ERR_FLG_NODATA);
			}
			
			// 表示ページ番号上書き
			dataMap.put(EKK3111B010CBSMsg.DISPLAY_PAGE_NUM, pageNum);
		}

		dataMap.put("EKK3111B010CBSMsg1List", dataList);

		// エラー情報の設定
		param = editErrorInfo_EKK3011B010CBS(param, templates, return_code_num, fixedText);

		//エラー情報のマップを取得
		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));

		// エラー発生時はExceptionを設定
		if (errList != null && !errList.isEmpty())
		{
			throw new CCException("", new SCCallException("", return_code_num.toString(), parentTemplate.getInt(EKK3111B010CBSMsg.STATUS)));
		}

		// ◇処理結果の判定
		// 取得したリターンコード、ステータスの内容を見て異常かどうかの判断をする。
		int status = parentTemplate.getInt(JCMConstants.STATUS_INT_KEY);

		// 異常の場合、SCCallExceptionを生成してスローする
		if(!("0".equals(return_code_num.toString()) && 0 == status))
		{
			SCCallException scCallEx = new SCCallException("戻り値不正", return_code_num.toString(), status);
			throw scCallEx;
		}

		return err_flg;
	}
	
	/**
	 * サービスインターフェイス処理結果(エラー情報)の取得<br>
	 * 業務データ取得・書込用I/Fをそのまま返却します。<br>
	 * <br>
	 * @param param デルグループ、コントロールマップを含むパラメータオブジェクト
	 * @param templates CAANMsgクラス配列
	 * @param returnCode リターンコード
	 * @param fixedText ユーザ定義文字列
	 * @return 業務データ取得・書込用I/F
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editErrorInfo_EKK3011B010CBS(IRequestParameterReadWrite param,
			CAANMsg[] templates, int returnCode, String fixedText) throws Throwable
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(EKK3111B010CBSMsg.STATUS);
		if (returnCode != 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);
		if (inMap == null)
		{
			inMap = new HashMap();
			param.setData(fixedText, inMap);
		}

		// 解約レター取得ＣＣマップ.検索処理パターン → 検索処理パターン のエラー情報返却
		getParamErr(template, inMap, "search_type_err", EKK3111B010CBSMsg.SEARCH_TYPE_ERR);

		// 解約レター取得ＣＣマップ.最大検索件数 → 最大検索件数 のエラー情報返却
		getParamErr(template, inMap, "max_search_num_err", EKK3111B010CBSMsg.MAX_SEARCH_NUM_ERR);

		// 解約レター取得ＣＣマップ.表示件数 → 表示件数 のエラー情報返却
		getParamErr(template, inMap, "display_num_err", EKK3111B010CBSMsg.DISPLAY_NUM_ERR);

		// 解約レター取得ＣＣマップ.表示ページ番号 → 表示ページ番号 のエラー情報返却
		getParamErr(template, inMap, "display_page_num_err", EKK3111B010CBSMsg.DISPLAY_PAGE_NUM_ERR);

		// 解約レター取得ＣＣマップ.ＫＥＹ＿ＳＹＳＩＤ → ＫＥＹ＿ＳＹＳＩＤ のエラー情報返却
		getParamErr(template, inMap, "key_sysid_err", EKK3111B010CBSMsg.KEY_SYSID_ERR);
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿請求契約番号エラー → ＫＥＹ＿請求契約番号エラー のエラー情報返却
		getParamErr(template, inMap, "key_seiky_kei_no_err", EKK3111B010CBSMsg.KEY_SEIKY_KEI_NO_ERR);
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿お客さまIDエラーー → ＫＥＹ＿お客さまIDエラーのエラー情報返却
		getParamErr(template, inMap, "key_svc_kei_no_err", EKK3111B010CBSMsg.KEY_SVC_KEI_NO_ERR);

		// 解約レター取得ＣＣマップ.ＫＥＹ＿レター登録年月日（自）エラー → ＫＥＹ＿レター登録年月日（自）エラー のエラー情報返却
		getParamErr(template, inMap, "key_letter_add_ymd_from_err", EKK3111B010CBSMsg.KEY_LETTER_ADD_YMD_FROM_ERR);

		// 解約レター取得ＣＣマップ.ＫＥＹ＿レター登録年月日（至） → ＫＥＹ＿レター登録年月日（至） のエラー情報返却
		getParamErr(template, inMap, "key_letter_add_ymd_to_err", EKK3111B010CBSMsg.KEY_LETTER_ADD_YMD_TO_ERR);

		// ANK-3346-00-00 ADD START
		// 解約レター取得ＣＣマップ.ＫＥＹ＿登録者ＩＤエラ → ＫＥＹ＿登録者ＩＤエラ のエラー情報返却
		getParamErr(template, inMap, "key_add_user_id_err", EKK3111B010CBSMsg.KEY_ADD_USER_ID_ERR);
		// ANK-3346-00-00 ADD END

		// 解約レター取得ＣＣマップ.ＫＥＹ＿発行区分エラ → ＫＥＹ＿発行区分エラ のエラー情報返却
		getParamErr(template, inMap, "key_hak_div_err", EKK3111B010CBSMsg.KEY_HAK_DIV_ERR);
		
		// 解約レター取得ＣＣマップ. ＫＥＹ＿照合済エラー →  ＫＥＹ＿照合済エラー のエラー情報返却
		getParamErr(template, inMap, "key_shogo_flg_err", EKK3111B010CBSMsg.KEY_SHOGO_FLG_ERR);

		// 解約レター取得ＣＣマップ.ＫＥＹ＿未送信エラー → ＫＥＹ＿未送信エラー のエラー情報返却
		getParamErr(template, inMap, "key_mi_send_err", EKK3111B010CBSMsg.KEY_MI_SEND_ERR);
		
		// 解約レター取得ＣＣマップ.ＫＥＹ＿レター発行要エラー → ＫＥＹ＿レター発行要エラー のエラー情報返却
		getParamErr(template, inMap, "key_letter_hak_y_err", EKK3111B010CBSMsg.KEY_LETTER_HAK_Y_ERR);

		// 解約レター取得ＣＣマップ.ＫＥＹ＿ソート項目Ｎｏ → ＫＥＹ＿ソート項目Ｎｏ のエラー情報返却
		getParamErr(template, inMap, "key_sort_item_no_err", EKK3111B010CBSMsg.KEY_SORT_ITEM_NO_ERR);

		// 解約レター取得ＣＣマップ.ＫＥＹ＿ソート区分 → ＫＥＹ＿ソート区分 のエラー情報返却
		getParamErr(template, inMap, "key_sort_kbn_err", EKK3111B010CBSMsg.KEY_SORT_KBN_ERR);

		return param;
	}

	/**
	 * パラメタがNullの場合、NULLを設定する。
	 * それ以外の場合、キー情報を取得し、情報を設定する。
	 * @param template 情報
	 * @param childMap マップ情報
	 * @param setKomoku 項目情報
	 * @param key キー情報
	 * @return 
	 */
	private void setParam(CAANMsg template, HashMap<String, String> inMap, String setKomoku, String key)
	{
		if (inMap == null || inMap.get(key) == null || "".equals(inMap.get(key)))
		{
			template.setNull(setKomoku);
		}
		else
		{
			template.set(setKomoku, (String)inMap.get(key));
		}
	}
	
	/**
	 * パラメタがNullの場合、NULLを設定する。
	 * それ以外の場合、キー情報を取得し、情報を設定する。
	 * @param template 情報
	 * @param childMap マップ情報
	 * @param setKomoku 項目情報
	 * @param key キー情報
	 * @return 
	 */
	private void getParam(CAANMsg template, HashMap<String, String> childMap, String setKomoku, String key)
	{
		if (template.isNull(key))
		{
			childMap.put(setKomoku, "");
		}
		else
		{
			childMap.put(setKomoku, template.getString(key));
		}		
	}
	
	/**
	 * パラメタがNull以外の場合、
	 * かつキー項目情報が含まれない場合、
	 * キー情報を取得し、情報を設定する。
	 * @param template 情報
	 * @param childMap マップ情報
	 * @param setKomoku 項目情報
	 * @param key キー情報
	 * @return 
	 */
	private void getParamErr(CAANMsg template, HashMap<String, String> inMap, String setKomoku, String key)
	{		
		if (!template.isNull(key))
		{
			if (!inMap.containsKey(setKomoku))
			{
				inMap.put(setKomoku, template.getString(key));
			}
		}
	}

}
