/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JCHBankIcrnInfoStkuCC
*   ソースファイル名：JCHBankIcrnInfoStkuCC.java
*   作成者          ：富士通
*   日付            ：2011年12月15日
*＜機能概要＞
*   金融機関一覧情報取得CC部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/12/15	富士通		新規作成
 *	v6.00.00	2013/10/30	FJ)鈴木		【OM-2013-0002865】入金経路が総合口座（パーフェクト口座）の場合、業務パラメータから取得した引落金融機関、支店を初期表示させる
*
**********************************************************************/
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.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.JACStrConst;
import eo.common.constant.JPCModelConstant;
import eo.ejb.cbs.cbsmsg.EKK0511B003CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0511B003CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0511B004CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0511B004CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EZM0321A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EZM0321A010CBSMsg1List;

/**
 * 金融機関一覧情報を取得するＣＣ部品です。<p>
 * <BR>
 * @author 富士通
 */
public class JCHBankIcrnInfoStkuCC extends AbstractCommonComponent {

	/** マップID */
	private static final String MAP_CC_ID = "BANKICRNINFOSTKUCC";
	
	/** テンプレートID(金融機関一覧照会３) */
	private static final String TEMPLATE_ID_EKK0511B003 = "EKK0511B003";
	
	/** テンプレートID(金融機関一覧照会４) */
	private static final String TEMPLATE_ID_EKK0511B004 = "EKK0511B004";

	/** テンプレートID(業務パラメータ一意照会) */
	public static final String TEMPLATE_ID_EZM0321A010 = "EZM0321A010";

	/** 金融機関一覧情報取得マップキー(金融機関一覧照会明細) */
	private static final String MAP_KEY_EKK0511B003CBSMsg1List = "EKK0511B003CBSMsg1List";

	/** 金融機関一覧情報取得マップキー(業務パラメータ一覧照会明細) */
	private static final String MAP_KEY_EZM0321A010CBSMsg1List = "EZM0321A010CBSMsg1List";

	/** 金融機関一覧情報取得マップキー(ＫＥＹ＿金融機関コード) */
	private static final String MAP_KEY_KEY_BANK_CD = "key_bank_cd";
	
	/** 金融機関一覧情報取得マップキー(金融機関コード) */
	private static final String MAP_KEY_BANK_CD = "bank_cd";
	
	/** 金融機関一覧情報取得マップキー(検索キー金融機関コード) */
	private static final String MAP_KEY_SEARCH_KEY_BANK_CD = "search_key_bank_cd";
	
	/** 金融機関一覧情報取得マップキー(検索キー金融機関コードインデックス) */
	private static final String MAP_KEY_SEARCH_KEY_BANK_CD_INDEX = "search_key_bank_cd_index";
	
	/** 総合口座（パーフェクト口座）かどうかを表すフラグ */
	private static final String TTLKOZA_PFCT_FLG = "ttlkoza_pfct_flg";
	
	/** 1:総合口座（パーフェクト口座）である */
	private static final String TTLKOZA_PFCT_FLG_TRUE = "1";
	
	/** 金融機関一覧情報取得マップキー(指定口座コード) */
	private static final String MAP_KEY_SHITEIKOZA_CD = "shiteikoza_cd";
	
	/** 格納マップキー（払込先金融機関）*/
	private static final String MAP_KEY_HRAKMISAKI_BANK_CD = "hrakmisaki_bank_cd";
	/**
	 * 金融機関一覧情報取得マップに指定されたキー情報を基に金融機関一覧情報を取得します。
	 * <br>
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return リクエストパラメータ
	 * @throws Exception 例外が発生した場合
	 */
	public IRequestParameterReadWrite getInfo(SessionHandle handle, 
			IRequestParameterReadWrite param, String fixedText) throws Exception
	{
		HashMap<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (inMap != null)
		{
			String ttlkoza = (String)inMap.get(TTLKOZA_PFCT_FLG);
			if (TTLKOZA_PFCT_FLG_TRUE.equals(ttlkoza))
			{
				/* ◇業務パラメータ管理一意照会取得処理 */
				execEZM0321A010(handle, param);
	
				if (inMap.get(MAP_KEY_EZM0321A010CBSMsg1List) != null)
				{
					// 指定口座を取得する
					String shiteiKozaCd = (String)inMap.get(MAP_KEY_SHITEIKOZA_CD);

					// 払込金融機関、支店リスト（業務パラメータ）を取得する
					ArrayList dataList = (ArrayList)inMap.get(MAP_KEY_EZM0321A010CBSMsg1List);

					for (int i = 0; i < dataList.size(); i++)
					{
						HashMap tmpMap = (HashMap)dataList.get(i);
						String bankCd = (String)tmpMap.get(MAP_KEY_HRAKMISAKI_BANK_CD);

						// bankCdには指定口座:払込先金融機関/払込先金融機関支店の形式で値が格納されている
						String[] bankArray = bankCd.split(JACStrConst.COLON); // コロンで分割
						
						// 対象の指定口座の場合
						if (shiteiKozaCd.equals(bankArray[0]))
						{
							String bank = bankArray[1].split(JACStrConst.SLASH)[0]; // 払込先金融機関コード
							//String bankSub = bankArray[1].split(JACStrConst.SLASH)[1]; // 払込先金融機関支店コード
							// 金融機関リスト検索のキーを入れ替える
							inMap.put(MAP_KEY_KEY_BANK_CD, bank);
							
							break;
						}
					}
				}
			}
		}

		/* ◇金融機関一覧照会３サービスインターフェイス */
		execEKK0511B003(handle, param);

		/* ◇ＫＥＹ＿金融機関コード判定 */
		if (setSearchKeyBankCd(param) != null)
		{
			/* ◇金融機関一覧照会４サービスインターフェイス */
			execEKK0511B004(handle, param);
		}
		
		return param;
	}
	
	/**
	 * 金融機関一覧情報取得処理チェック処理.<br>
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException RequestParameterException
	 */
	public HashMap<String, Object> getInvokeCBS(SessionHandle handle, 
				IRequestParameterReadWrite param, String fixedText) throws RequestParameterException 
	{
		/* ◇パラメータマップ生成 */
		HashMap<String, Object> paramMap = this.createNewParamMap(param);
		
		/* ◇テンプレートリスト生成 */
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();
		
		// 金融機関一覧照会３サービスIF用メッセージ設定処理
		ArrayList<CAANMsg> templateEKK0511B003 = editInMsgEKK0511B003(param);
		for (CAANMsg msg : templateEKK0511B003)
		{
			templateList.add(msg);
		}
		
		// 金融機関一覧照会４サービスIF用メッセージ設定処理
		ArrayList<CAANMsg> templateEKK0511B004 = null;
		/* ◇ＫＥＹ＿金融機関コード判定 */
		if (setSearchKeyBankCd(param) != null)
		{	
			templateEKK0511B004 = editInMsgEKK0511B004(param);
			for (CAANMsg msg : templateEKK0511B004)
			{
				templateList.add(msg);
			}
		}
		
		CAANMsg[] templates = templateList.toArray(new CAANMsg[templateList.size()]);
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);
		
		return paramMap;
	}

	// ▼▼ サービスIF呼び出し ▼▼
	/**
	 * 金融機関一覧照会３サービスインタフェイスを実行します。
	 * <br>
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @throws Exception 例外が発生した場合
	 */
	private void execEKK0511B003(SessionHandle handle, IRequestParameterReadWrite param) throws Exception
	{
		/* ◇パラメータマップ生成 */
		HashMap<String, Object> paramMap = this.createNewParamMap(param);
		
		/* ◇テンプレートリスト生成 */
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();
		
		// 上りマッピング
		ArrayList<CAANMsg> templateEKK0511B003 = editInMsgEKK0511B003(param);
		for (CAANMsg msg : templateEKK0511B003)
		{
			templateList.add(msg);
		}
		CAANMsg[] templates = templateList.toArray(new CAANMsg[templateList.size()]);
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);
		
		// ＳＣ呼出実行
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		Map<?, ?> result = scCall.run(paramMap, handle);
		
		// 下りマッピング
		editOutMsgEKK0511B003(result, param);
	}
	
	/**
	 * 金融機関一覧照会４サービスインタフェイスを実行します。
	 * <br>
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @throws Exception 例外が発生した場合
	 */
	private void execEKK0511B004(SessionHandle handle, IRequestParameterReadWrite param) throws Exception
	{
		/* ◇パラメータマップ生成 */
		HashMap<String, Object> paramMap = this.createNewParamMap(param);
		
		/* ◇テンプレートリスト生成 */
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();
		
		// 上りマッピング
		ArrayList<CAANMsg> templateEKK0511B004 = editInMsgEKK0511B004(param);
		for (CAANMsg msg : templateEKK0511B004)
		{
			templateList.add(msg);
		}
		CAANMsg[] templates = templateList.toArray(new CAANMsg[templateList.size()]);
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);
		
		// ＳＣ呼出実行
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		Map<?, ?> result = scCall.run(paramMap, handle);
		
		// 下りマッピング
		editOutMsgEKK0511B004(result, param);
	}
	
	// ▲▲ サービスIF呼び出し ▲▲
	
	// ▼▼ サービスIF用メッセージ設定処理 ▼▼
	/**
	 * 金融機関一覧照会３サービスインターフェイス用メッセージ設定処理<br>
	 * @param param リクエストパラメータ
	 * @return ArrayList<CAANMsg>
	 * @throws RequestParameterException
	 */
	private ArrayList<CAANMsg> editInMsgEKK0511B003(IRequestParameterReadWrite param) throws RequestParameterException
	{
		HashMap<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();
		
		/* ◇ユーザデータ情報 */
		CAANMsg template = new CAANMsg(EKK0511B003CBSMsg.class.getName());
		this.setTemplateCommonItem(param, template, 
				EKK0511B003CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0511B003, EKK0511B003CBSMsg.FUNC_CODE);
		
		/* ◇業務データの設定 */
		// 機能コード
		template.set(EKK0511B003CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);
		
		templateList.add(template);
		
		return templateList;
	}
	
	/**
	 * 金融機関一覧照会４サービスインターフェイス用メッセージ設定処理<br>
	 * @param param リクエストパラメータ
	 * @return ArrayList<CAANMsg>
	 * @throws RequestParameterException
	 */
	private ArrayList<CAANMsg> editInMsgEKK0511B004(IRequestParameterReadWrite param) throws RequestParameterException
	{
		HashMap<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();
		
		/* ◇ユーザデータ情報 */
		CAANMsg template = new CAANMsg(EKK0511B004CBSMsg.class.getName());
		this.setTemplateCommonItem(param, template, 
				EKK0511B004CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0511B004, EKK0511B004CBSMsg.FUNC_CODE);
		
		/* ◇業務データの設定 */
		// 機能コード
		template.set(EKK0511B004CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);
		
		// 検索キー金融機関コード → ＫＥＹ＿金融機関コード
		template.set(EKK0511B004CBSMsg.KEY_BANK_CD, (String)inMap.get(MAP_KEY_SEARCH_KEY_BANK_CD));
		
		templateList.add(template);
		
		return templateList;
	}
	
	// ▲▲ サービスIF用メッセージ設定処理 ▲▲

	// ▼▼ サービスIF用メッセージ取得処理 ▼▼
	/**
	 * 金融機関一覧照会３サービスインターフェイス用メッセージ取得処理<br>
	 * 
	 * @param msgList メッセージリスト
	 * @param param リクエストパラメータ
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	private IRequestParameterReadWrite editOutMsgEKK0511B003(Map<?, ?> msgList,
			IRequestParameterReadWrite param) throws Exception
	{

		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];
		CAANMsg[] templateArray = null;
		
		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);

		// 業務データ設定
		HashMap<String, Object> dataMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (dataMap == null)
		{
			dataMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, dataMap);
		}
		templateArray = parentTemplate.getCAANMsgList(EKK0511B003CBSMsg.EKK0511B003CBSMSG1LIST);
		ArrayList dataList = (ArrayList)dataMap.get("EKK0511B003CBSMsg1List");
		
		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);
				
				// 金融機関一覧情報取得マップ.金融機関一覧照会明細.金融機関コード ← 金融機関一覧照会明細.金融機関コード
				if (childTemplate.isNull(EKK0511B003CBSMsg1List.BANK_CD)) {
					childMap.put("bank_cd", new String());
				} else {
					childMap.put("bank_cd", childTemplate.getString(EKK0511B003CBSMsg1List.BANK_CD));
				}
				
				// 金融機関一覧情報取得マップ.金融機関一覧照会明細.金融機関名 ← 金融機関一覧照会明細.金融機関名
				if (childTemplate.isNull(EKK0511B003CBSMsg1List.BANK_NM)) {
					childMap.put("bank_nm", new String());
				} else {
					childMap.put("bank_nm", childTemplate.getString(EKK0511B003CBSMsg1List.BANK_NM));
				}
			}
		}
		dataMap.put("EKK0511B003CBSMsg1List", dataList);

		// エラー情報の設定
		editErrorInfo(param, templates, (Integer)return_code);

		//エラー情報のマップを取得
		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));
		
		// 例外通知
		String rtnCode = msgList.get(JCMConstants.RET_CD_INT_KEY).toString();
		String status = (String)param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if(!("0".equals(rtnCode) && 0 == Integer.parseInt(status)))
		{
			throw new SCCallException("INVALID_RETURN_MESSAGE", rtnCode, (Integer)return_code);
		}

		return param;
	}
	
	/**
	 * 金融機関一覧照会４サービスインターフェイス用メッセージ取得処理<br>
	 * 
	 * @param msgList メッセージリスト
	 * @param param リクエストパラメータ
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	private IRequestParameterReadWrite editOutMsgEKK0511B004(Map<?, ?> msgList,
			IRequestParameterReadWrite param) throws Exception
	{

		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];
		CAANMsg[] templateArray = null;
		
		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);

		// 業務データ設定
		HashMap<String, Object> dataMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (dataMap == null)
		{
			dataMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, dataMap);
		}
		templateArray = parentTemplate.getCAANMsgList(EKK0511B004CBSMsg.EKK0511B004CBSMSG1LIST);
		ArrayList dataList = (ArrayList)dataMap.get("EKK0511B004CBSMsg1List");
		  
		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);
				
				// 金融機関一覧情報取得マップ.金融機関支店一覧照会明細.金融機関支店コード ← 金融機関一覧照会明細.金融機関支店コード
				if (childTemplate.isNull(EKK0511B004CBSMsg1List.BANK_SHITEN_CD)) {
					childMap.put("bank_shiten_cd", new String());
				} else {
					childMap.put("bank_shiten_cd", childTemplate.getString(EKK0511B004CBSMsg1List.BANK_SHITEN_CD));
				}
				
				// 金融機関一覧情報取得マップ.金融機関支店一覧照会明細.金融機関支店名 ← 金融機関一覧照会明細.金融機関支店名
				if (childTemplate.isNull(EKK0511B004CBSMsg1List.BANK_SHITEN_NM)) {
					childMap.put("bank_shiten_nm", new String());
				} else {
					childMap.put("bank_shiten_nm", childTemplate.getString(EKK0511B004CBSMsg1List.BANK_SHITEN_NM));
				}
			}
		}
		dataMap.put("EKK0511B004CBSMsg1List", dataList);

		// エラー情報の設定
		editErrorInfo(param, templates, (Integer)return_code);

		//エラー情報のマップを取得
		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));
		
		// 例外通知
		String rtnCode = msgList.get(JCMConstants.RET_CD_INT_KEY).toString();
		String status = (String)param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if(!("0".equals(rtnCode) && 0 == Integer.parseInt(status)))
		{
			throw new SCCallException("INVALID_RETURN_MESSAGE", rtnCode, (Integer)return_code);
		}

		return param;
	}

	// ▲▲ サービスIF用メッセージ取得処理 ▲▲
	
	// ▼▼ エラー情報マッピング処理 ▼▼
	/**
	 * サービスIF実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * @param param リクエストパラメータ
	 * @param templates テンプレート
	 * @param returnCode リターンコード
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException RequestParameterException
	 */
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param, CAANMsg[] templates, int returnCode) throws RequestParameterException
	{
		
		for (CAANMsg template : templates)
		{
			String templateId = template.getString("templateID");
			CAANMsg[] workTemplates = { template };
			if (TEMPLATE_ID_EKK0511B003.equals(templateId))
			{
				// 金融機関一覧照会３
				editErrorInfoEKK0511B003(param, workTemplates, returnCode);
			}
			else if (TEMPLATE_ID_EKK0511B004.equals(templateId))
			{
				// 金融機関一覧照会４
				editErrorInfoEKK0511B004(param, workTemplates, returnCode);
			}
			else if (TEMPLATE_ID_EZM0321A010.equals(templateId))
			{
				// 業務パラメータ一意照会
				editErrorInfoEZM0321A010(param, workTemplates, returnCode);
			}
		}
		
		return param;
	}
	
	/**
	 * 金融機関一覧照会３サービスIF実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * @param param リクエストパラメータ
	 * @param templates テンプレート
	 * @param returnCode リターンコード
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException RequestParameterException
	 */
	public IRequestParameterReadWrite editErrorInfoEKK0511B003(IRequestParameterReadWrite param
			, CAANMsg[] templates, int returnCode) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(EKK0511B003CBSMsg.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);
		}
		
		return param;
	}
	
	/**
	 * 金融機関一覧照会４サービスIF実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * @param param リクエストパラメータ
	 * @param templates テンプレート
	 * @param returnCode リターンコード
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException RequestParameterException
	 */
	public IRequestParameterReadWrite editErrorInfoEKK0511B004(IRequestParameterReadWrite param
			, CAANMsg[] templates, int returnCode) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(EKK0511B004CBSMsg.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<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);

		// 金融機関一覧情報取得マップ.ＫＥＹ＿金融機関コード → ＫＥＹ＿金融機関コード のエラー情報返却
		if (!template.isNull(EKK0511B004CBSMsg.KEY_BANK_CD_ERR)) {
			if (!inMap.containsKey("key_bank_cd_err")) {
				inMap.put("key_bank_cd_err", template.getString(EKK0511B004CBSMsg.KEY_BANK_CD_ERR));
			}
		}
		
		return param;
	}

	// ▲▲ エラー情報マッピング処理 ▲▲

	// ▼▼ クラス内共通処理 ▼▼
	/**
	 * サービスインタフェースに渡すパラメータマップを新規に作成します。
	 * マップには共通項目である電文ヘッダ、コントロールマップを設定します。
	 * <br>
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @throws RequestParameterException パラメータ取得で例外が発生した場合
	 */
	private HashMap<String, Object> createNewParamMap(IRequestParameterReadWrite param) throws RequestParameterException
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();

		/* ◇電文ヘッダ */
		// 電文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));
		
		return paramMap;
	}
	
	/**
	 * テンプレートの共通項目を設定します。
	 * <br>
	 * @param param リクエストパラメータ
	 * @param template テンプレート
	 * @param templateIdKey テンプレートIDキー名
	 * @param templateIdVal テンプレートID値
	 * @param templateFuncCdKey テンプレート機能コードキー名
	 * @throws RequestParameterException パラメータ取得で例外が発生した場合
	 */
	private CAANMsg setTemplateCommonItem(IRequestParameterReadWrite param, CAANMsg template, 
											String templateIdKey, String templateIdVal, String templateFuncCdKey) throws RequestParameterException
	{
		// テンプレートID
		template.set(templateIdKey, templateIdVal);

		// 機能コード（デフォルト：１）
		template.set(templateFuncCdKey, "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);
		
		return template;
	}

	/**
	 * 検索キー金融機関コード設定処理<br>
	 * 金融機関一覧情報取得マップで指定された値、もしくは金融機関一覧照会３の明細先頭行から
	 * 金融機関一覧照会４の検索キーで使用する金融機関コードを取得し、パラメータに設定します。
	 * <br>
	 * @param param リクエストパラメータ
	 * @return 検索ＫＥＹ＿金融機関コード
	 * @throws RequestParameterException パラメータ取得で例外が発生した場合
	 */
	private String setSearchKeyBankCd(IRequestParameterReadWrite param) throws RequestParameterException
	{
		String searchKeyBankCd = null;
		
		HashMap<String, Object> dataMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);

		// 検索キー金融機関コードインデックス
		dataMap.put(MAP_KEY_SEARCH_KEY_BANK_CD_INDEX, "0");

		if (dataMap.get(MAP_KEY_KEY_BANK_CD) != null && JACStrConst.KARA_MOJI.equals(dataMap.get(MAP_KEY_KEY_BANK_CD)) == false)
		{
			// 金融機関コードの指定がある場合
			if (isExistBankCdInList(param, (String)dataMap.get(MAP_KEY_KEY_BANK_CD)))
			{
				// 金融機関一覧照会３の明細に存在する場合は、指定された値をそのまま返却
				searchKeyBankCd = (String)dataMap.get(MAP_KEY_KEY_BANK_CD);
			}
			else
			{
				// 金融機関一覧照会３の明細に存在しない場合は、金融機関一覧照会３の明細の先頭行から返却
				searchKeyBankCd = JCHBPCommon.getBPListValueString(param, MAP_CC_ID, MAP_KEY_EKK0511B003CBSMsg1List, 0, MAP_KEY_BANK_CD);
			}
		}
		else
		{
			// 金融機関コードの指定がない場合、金融機関一覧照会３の明細の先頭行から返却
			searchKeyBankCd = JCHBPCommon.getBPListValueString(param, MAP_CC_ID, MAP_KEY_EKK0511B003CBSMsg1List, 0, MAP_KEY_BANK_CD);
		}
		
		// パラメータ設定
		dataMap.put(MAP_KEY_SEARCH_KEY_BANK_CD, searchKeyBankCd);
		
		return searchKeyBankCd;
	}
	
	/**
	 * 金融機関コード存在確認処理<br>
	 * 金融機関一覧情報取得マップで指定された値が金融機関一覧照会３の明細リストに存在するか確認します。
	 * <br>
	 * @param param リクエストパラメータ
	 * @param keyBankCd 金融機関コード
	 * @throws RequestParameterException パラメータ取得で例外が発生した場合
	 */
	private boolean isExistBankCdInList(IRequestParameterReadWrite param, String keyBankCd) throws RequestParameterException
	{
		boolean isExist = false;
		
		HashMap<String, Object> dataMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (dataMap.get(MAP_KEY_EKK0511B003CBSMsg1List) != null)
		{
			ArrayList<HashMap<String,Object>> dataList = (ArrayList<HashMap<String,Object>>)dataMap.get(MAP_KEY_EKK0511B003CBSMsg1List);
			for (int idx = 0; idx < dataList.size(); idx++)
			{
				HashMap<String,Object> childMap = dataList.get(idx);
				if (childMap.get(MAP_KEY_BANK_CD) != null && JACStrConst.KARA_MOJI.equals(childMap.get(MAP_KEY_BANK_CD)) == false
						&& keyBankCd.equals(childMap.get(MAP_KEY_BANK_CD)) )
				{
					isExist = true;
					// 検索キー金融機関コードインデックス
					dataMap.put(MAP_KEY_SEARCH_KEY_BANK_CD_INDEX, String.valueOf(idx));
					
					break;
				}
			}
		}
		
		return isExist;
	}
	
	/**
	 * 業務パラメータ管理一意照会サービスインタフェイスを実行します。
	 * <br>
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @throws Exception 例外が発生した場合
	 */
	private void execEZM0321A010(SessionHandle handle, IRequestParameterReadWrite param) throws Exception
	{
		/* ◇パラメータマップ生成 */
		HashMap<String, Object> paramMap = this.createNewParamMap(param);

		/* ◇テンプレートリスト生成 */
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();

		// 上りマッピング
		ArrayList<CAANMsg> templateEZM0321A010 = editInMsgEZM0321A010(param);
		for (CAANMsg msg : templateEZM0321A010)
		{
			templateList.add(msg);
		}
		CAANMsg[] templates = templateList.toArray(new CAANMsg[templateList.size()]);
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// ＳＣ呼出実行
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		Map<?, ?> result = scCall.run(paramMap, handle);

		// 下りマッピング
		editOutMsgEZM0321A010(result, param);
	}
	
	/**
	 * 業務パラメータ管理一意照会サービスインターフェイス用メッセージ設定処理<br>
	 * @param param リクエストパラメータ
	 * @param chohyoReqMap 帳票出力依頼リストマップ
	 * @param wkpara 業務パラメータ識別
	 * @return ArrayList<CAANMsg>
	 * @throws RequestParameterException
	 */
	private ArrayList<CAANMsg> editInMsgEZM0321A010(IRequestParameterReadWrite param) throws RequestParameterException
	{
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();

		/* ◇ユーザデータ情報 */
		CAANMsg template = new CAANMsg(EZM0321A010CBSMsg.class.getName());
		this.setTemplateCommonItem(param, template, 
				EZM0321A010CBSMsg.TEMPLATEID, TEMPLATE_ID_EZM0321A010, EZM0321A010CBSMsg.FUNC_CODE);

		/* ◇業務データの設定 */
		// 機能コード
		template.set(EZM0321A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);

		// 業務パラメータID
		template.set(EZM0321A010CBSMsg.KEY_WORK_PARAM_ID, JACStrConst.WKPARA_CH_HRKMSK_BANK_CD);

		templateList.add(template);

		return templateList;
	}

	/**
	 * 業務パラメータ管理一意照会サービスインターフェイス用メッセージ取得処理<br>
	 * 
	 * @param msgList メッセージリスト
	 * @param param リクエストパラメータ
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editOutMsgEZM0321A010(Map<?, ?> msgList,
				IRequestParameterReadWrite param) throws Exception
	{
		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];
		CAANMsg[] templateArray = null;
		
		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);

		// 業務データ設定
		HashMap<String, Object> dataMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (dataMap == null)
		{
			dataMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, dataMap);
		}
		
		// 払込先金融機関コード・払込先金融機関支店コード
		String[] hrkmBankCd = new String[]{};
		
		// 業務パラメータ取得
		templateArray = parentTemplate.getCAANMsgList(EZM0321A010CBSMsg.EZM0321A010CBSMSG1LIST);
		
		ArrayList dataList = (ArrayList)dataMap.get("EZM0321A010CBSMsg1List");
		if (dataList == null) {
			dataList = new ArrayList();
		}

		if (templateArray != null && templateArray.length != 0)
		{
			// 業務パラメータには「指定口座:払込先金融機関/払込先金融機関支店」（x:aaa/bbb, y:ccc/ddd, ・・・）の形式で値が格納されている
			hrkmBankCd = templateArray[0].getString(EZM0321A010CBSMsg1List.WORK_PARAM_SETTE_VALUE).split(JACStrConst.COMMA);
		}
		
		if (hrkmBankCd != null && hrkmBankCd.length != 0)
		{
			// 指定口座コードをkeyとして、払込先金融機関コード、払込先金融機関支店コードを格納する
			for (int i = 0; i < hrkmBankCd.length; i++)
			{
				if ( i >= dataList.size())
				{
					dataList.add(new HashMap());
				}
				HashMap childMap = (HashMap)dataList.get(i);
				childMap.put(MAP_KEY_HRAKMISAKI_BANK_CD, hrkmBankCd[i]);
			}
		}
		
		// 業務データに格納する
		dataMap.put("EZM0321A010CBSMsg1List", dataList);

		// エラー情報の設定
		editErrorInfo(param, templates, (Integer)return_code);

		//エラー情報のマップを取得
		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));
		
		// 例外通知
		String rtnCode = msgList.get(JCMConstants.RET_CD_INT_KEY).toString();
		String status = (String)param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if(!("0".equals(rtnCode) && 0 == Integer.parseInt(status)))
		{
			throw new SCCallException("INVALID_RETURN_MESSAGE", rtnCode, (Integer)return_code);
		}

		return param;
	}

	/**
	 * 業務パラメータ管理一意照会サービスコンポーネント実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * @param param リクエストパラメータ
	 * @param templates テンプレート
	 * @param returnCode リターンコード
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException RequestParameterException
	 */
	private IRequestParameterReadWrite editErrorInfoEZM0321A010(IRequestParameterReadWrite param
			, CAANMsg[] templates, int returnCode) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(EZM0321A010CBSMsg.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<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		
		// 業務パラメータ管理情報取得マップ.ＫＥＹ＿業務パラメータIDエラー → ＫＥＹ＿業務パラメータIDエラー
		if (!template.isNull(EZM0321A010CBSMsg.KEY_WORK_PARAM_ID_ERR))
		{
			if (!inMap.containsKey("key_work_param_id_err"))
			{
				inMap.put("key_work_param_id_err", template.getString(EZM0321A010CBSMsg.KEY_WORK_PARAM_ID_ERR));
			}
		}
		return param;
	}

	// ▲▲ クラス内共通処理 ▲▲

}
