/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKRankInquiryCC
*	ソースファイル名：JKKRankInquiryCC.java
*	作成者			：FJ）藤本
*	日付			：2016年06月07日
*＜機能概要＞
*	お客様ランク情報取得の共通コンポーネントクラスです。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v26.00.00	2016/06/07	FJ）藤本	【ANK-2687-00-00】プレミアムサポート施策
*	v26.01.00	2016/07/08	FJ）藤本	【IT1-2016-0000088】TRANKの不正な応答が正常に解析できた場合にシステムエラー
*	v66.00.00	2023/03/08  FJ)吉川		【ANK-4307-00-00】【eo定期】プレミアムクラブリニューアル対応

**********************************************************************/
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.IRequestParameterReadWrite;
import com.fujitsu.futurity.bp.x21.cc.AbstractCommonComponent;
import com.fujitsu.futurity.bp.x21.cc.exception.SCCallException;
import com.fujitsu.futurity.bp.x21.values.MessageID;
import com.fujitsu.futurity.common.JCMConstants;
import com.fujitsu.futurity.common.JSYbpmLog;
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.JCKStrConst;
import eo.common.constant.JPCModelConstant;
import eo.common.util.JKKStringUtil;
import eo.ejb.cbs.cbsmsg.ECK0011A010CBSMsg;
import eo.ejb.cbs.cbsmsg.ECK0011A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKKA0050001CBSMsg;
import eo.ejb.cbs.cbsmsg.EKKA0050001CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKKA0050001CBSMsg2List;
import eo.ejb.cbs.cbsmsg.EKKA0050001CBSMsg3List;
import eo.ejb.cbs.cbsmsg.EKKA0050001CBSMsg4List;


/**
 * お客様ランク情報取得の共通コンポーネントクラスです。
 * <BR>
 * @author FJ
 */
public class JKKRankInquiryCC extends AbstractCommonComponent
{
	/** テンプレートID　お客様一意照会 */
	private static final String TEMPLATE_ID_ECK0011A010 = "ECK0011A010";

	/** テンプレートID　お客様ランク情報一意照会 */
	private static final String TEMPLATE_ID_EKKA0050001 = "EKKA0050001";

	/**
	 * ランク情報を取得します。
	 * <br>
	 * ランク情報が取得できない場合（TRANKシステムとの通信でエラーが発生するなど）は、
	 * レスポンスに空文字を設定して正常終了します。
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText ユーザ定義文字列
	 * @return リクエストパラメータ
	 * @throws Throwable 例外が発生した場合
	 */
	public IRequestParameterReadWrite rankInquiry(SessionHandle handle,
													IRequestParameterReadWrite param, 
													String fixedText) throws Throwable
	{
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(fixedText);
		if (null == ccMsg)
		{
			ccMsg = new HashMap<String, Object>();
			param.setData(fixedText, ccMsg);
		}

		String opeDate = JCCBPCommon.getOpeDate(null);
		String funcCode = (String)ccMsg.get("func_code");
		String keySysid = (String)ccMsg.get("key_sysid");

		// 入力項目のSYSIDが設定されていない場合（対応履歴からの呼び出し）
		if (null == keySysid || keySysid.isEmpty())
		{
			// 作業項目領域
			Map<Object, Object> workAreaMap = param.getMappingWorkArea();
			if (null != workAreaMap)
			{
				HashMap<Object, Object> workMap = (HashMap<Object, Object>)workAreaMap.get("WORK");
				if (null != workMap)
				{
					// 作業項目情報のワークSYSIDを取得
					keySysid = (String)workMap.get("sysid_w");
				}
			}
		}

		// お客様ランク情報一意照会明細
		CAANMsg[] ekka0050001Msg1List = new CAANMsg[]{new CAANMsg(EKKA0050001CBSMsg1List.class.getName())};
		// 契約情報リスト
		CAANMsg[] ekka0050001Msg2List = new CAANMsg[0];
		// 保有ポイント内訳リスト
		CAANMsg[] ekka0050001Msg3List = new CAANMsg[0];
		// ランクアップ条件リスト
		CAANMsg[] ekka0050001Msg4List = new CAANMsg[0];

		try
		{
			// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
			ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();

			// お客様一意照会の上りマッピング
			Object[][] eck0011a010In =
			{
				{ECK0011A010CBSMsg.TEMPLATEID, TEMPLATE_ID_ECK0011A010},
				{ECK0011A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2},
				{ECK0011A010CBSMsg.KEY_SYSID, keySysid},
				{ECK0011A010CBSMsg.KEY_RSV_APLY_YMD, opeDate}
			};

			// サービスIF実行
			CAANMsg[] eck0011a010Msg1List = callSC(handle, scCall, param, fixedText, eck0011a010In, new ECK0011A010CBSMsg().getContents())
												.getCAANMsgList(ECK0011A010CBSMsg.ECK0011A010CBSMSG1LIST);

			if (null != eck0011a010Msg1List && eck0011a010Msg1List.length > 0)
			{
				String memberSbtCd = eck0011a010Msg1List[0].getString(ECK0011A010CBSMsg1List.MEMBER_SBT_CD);
				String eonetidMiIkoFlg = eck0011a010Msg1List[0].getString(ECK0011A010CBSMsg1List.EONETID_MI_IKO_FLG);
				// eonetID未移行フラグがnullの場合
				if (JKKStringUtil.isNullBlank(eonetidMiIkoFlg))
				{
					// 「0:移行済」を設定
					eonetidMiIkoFlg = JCKStrConst.CD00602_IKO_ZM;
				}

				ccMsg.put(EKKA0050001CBSMsg.KEY_KAIIN_SBT_CD, memberSbtCd);
				// IT1-2016-0000088 MOD START
//				ccMsg.put(EKKA0050001CBSMsg.KEY_EONETID_MIIKO_FLG, memberSbtCd);
				ccMsg.put(EKKA0050001CBSMsg.KEY_EONETID_MIIKO_FLG, eonetidMiIkoFlg);
				// IT1-2016-0000088 MOD END

				// お客様ランク情報一意照会の上りマッピング
				Object[][] ekka0050001In =
				{
						{EKKA0050001CBSMsg.TEMPLATEID, TEMPLATE_ID_EKKA0050001},
						{EKKA0050001CBSMsg.FUNC_CODE, funcCode},
						{EKKA0050001CBSMsg.KEY_SYSID, keySysid},
						{EKKA0050001CBSMsg.KEY_KAIIN_SBT_CD, memberSbtCd},
						{EKKA0050001CBSMsg.KEY_EONETID_MIIKO_FLG, eonetidMiIkoFlg}
				};

				// サービスIF実行
				CAANMsg ekka0050001Out = callSC(handle, scCall, param, fixedText, ekka0050001In, new EKKA0050001CBSMsg().getContents());

				// お客様ランク情報一意照会明細
				CAANMsg[] tmpEkka0050001Msg1List = ekka0050001Out.getCAANMsgList(EKKA0050001CBSMsg.EKKA0050001CBSMSG1LIST);
				ekka0050001Msg1List = tmpEkka0050001Msg1List;
				// 契約リスト
				CAANMsg[] tmpEkka0050001Msg2List = ekka0050001Out.getCAANMsgList(EKKA0050001CBSMsg.EKKA0050001CBSMSG2LIST);
				ekka0050001Msg2List = tmpEkka0050001Msg2List;
				// 保有ポイント内訳リスト
				CAANMsg[] tmpEkka0050001Msg3List = ekka0050001Out.getCAANMsgList(EKKA0050001CBSMsg.EKKA0050001CBSMSG3LIST);
				ekka0050001Msg3List = tmpEkka0050001Msg3List;
				// ランクアップ条件リスト
				CAANMsg[] tmpEkka0050001Msg4List = ekka0050001Out.getCAANMsgList(EKKA0050001CBSMsg.EKKA0050001CBSMSG4LIST);
				ekka0050001Msg4List = tmpEkka0050001Msg4List;
			}
		}
		catch (Throwable e)
		{
			// エラーログ出力
			String errMsg = e.toString();
			Throwable cause = e.getCause();
			if (null != cause)
			{
				errMsg += cause.toString();
			}
			JSYbpmLog.println(JSYbpmLog.ERROR, this.getClass(), errMsg, MessageID.ERR_ERROR_MSG,
					new String[]{"ランク情報取得処理(" + this.getClass().getName() + ")で"}, null);

			// エラー情報、ユーザデータ出力
			ArrayList<Object> errList = (ArrayList<Object>)param.getControlMapData(SCControlMapKeys.ERROR_INFO);
			if (null == errList)
			{
				errList = new ArrayList<Object>();
			}
			JSYbpmLog.println(JSYbpmLog.ERROR, this.getClass(), null, MessageID.EXE_DUMP_TELEGRAM_MSG,
					new String[]{"エラー電文情報 " + SCControlMapKeys.ERROR_INFO + "=" + errList + ", " + fixedText + "=" + ccMsg}, null);
		}

		// 出力項目設定
		// お客様ランク情報一意照会明細を作成
		List<Map<String, Object>> detailList = new ArrayList<Map<String, Object>>();
		Map<String, Object> detail = new HashMap<String, Object>();
		// IT1-2016-0000088 ADD START
		if (null == ekka0050001Msg1List || 0 == ekka0050001Msg1List.length)
		{
			ekka0050001Msg1List = new CAANMsg[]{new CAANMsg(EKKA0050001CBSMsg1List.class.getName())};
		}
		// IT1-2016-0000088 ADD END
		detail.put(EKKA0050001CBSMsg1List.FUNC_CODE,
				JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.FUNC_CODE)));
		detail.put(EKKA0050001CBSMsg1List.SYSID,
				JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.SYSID)));
		detail.put(EKKA0050001CBSMsg1List.KAIIN_SBT_CD,
				JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.KAIIN_SBT_CD)));
		detail.put(EKKA0050001CBSMsg1List.EONETID_MIIKO_FLG,
				JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.EONETID_MIIKO_FLG)));
		detail.put(EKKA0050001CBSMsg1List.RNK_CD,
				JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.RNK_CD)));
		detail.put(EKKA0050001CBSMsg1List.RNK_NM,
				JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.RNK_NM)));
		detail.put(EKKA0050001CBSMsg1List.PRESUP_KISAN_DATE,
				JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.PRESUP_KISAN_DATE)));
		detail.put(EKKA0050001CBSMsg1List.KEI_YEARS,
				JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.KEI_YEARS)));
		// ANK-4307-00-00 MOD START
		//detail.put(EKKA0050001CBSMsg1List.TIC_NUM,
		//		JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.TIC_NUM)));
		String hoyuPoint = "";
		//保有ポイント
		String Point = JKKStringUtil.nullToBlank(ekka0050001Msg1List[0].getString(EKKA0050001CBSMsg1List.TOTAL_HOYU_PT_SU));
		if(Point != null && !"".equals(Point))
		{
			int intPoint = Integer.parseInt(Point);
			//保有ポイントを３桁ごとにカンマで区切る
			hoyuPoint = String.format("%,d", intPoint);
		}
		detail.put(EKKA0050001CBSMsg1List.TOTAL_HOYU_PT_SU ,hoyuPoint);
		// ANK-4307-00-00 MOD END
		
		
		// 契約リストを設定（お客様ランク情報一意照会明細配下のListとする）
		List<Map<String, String>> keiList = new ArrayList<Map<String, String>>();
		for (int i = 0; i < ekka0050001Msg2List.length; i++)
		{
			Map<String, String> kei = new HashMap<String, String>();
			kei.put(EKKA0050001CBSMsg2List.SRV_KEI_NM,
					JKKStringUtil.nullToBlank(ekka0050001Msg2List[i].getString(EKKA0050001CBSMsg2List.SRV_KEI_NM)));
			kei.put(EKKA0050001CBSMsg2List.KEI_UM_FLG,
					JKKStringUtil.nullToBlank(ekka0050001Msg2List[i].getString(EKKA0050001CBSMsg2List.KEI_UM_FLG)));
			keiList.add(kei);
		}
		detail.put(EKKA0050001CBSMsg.EKKA0050001CBSMSG2LIST, keiList);

		// ANK-4307-00-00 DEL START
//		// チケットリストを設定（お客様ランク情報一意照会明細配下のListとする）
//		List<Map<String, String>> ticketList = new ArrayList<Map<String, String>>();
//		for (int i = 0; i < ekka0050001Msg3List.length; i++)
//		{
//			Map<String, String> ticket = new HashMap<String, String>();
//			ticket.put(EKKA0050001CBSMsg3List.TIC_STS_CD,
//					JKKStringUtil.nullToBlank(ekka0050001Msg3List[i].getString(EKKA0050001CBSMsg3List.TIC_STS_CD)));
//			ticket.put(EKKA0050001CBSMsg3List.TIC_STS_CD_NM,
//					JKKStringUtil.nullToBlank(ekka0050001Msg3List[i].getString(EKKA0050001CBSMsg3List.TIC_STS_CD_NM)));
//			ticket.put(EKKA0050001CBSMsg3List.SISK_CD,
//					JKKStringUtil.nullToBlank(ekka0050001Msg3List[i].getString(EKKA0050001CBSMsg3List.SISK_CD)));
//			ticket.put(EKKA0050001CBSMsg3List.SISK_NM,
//					JKKStringUtil.nullToBlank(ekka0050001Msg3List[i].getString(EKKA0050001CBSMsg3List.SISK_NM)));
//			ticket.put(EKKA0050001CBSMsg3List.EXPIRE_DATE,
//					JKKStringUtil.nullToBlank(ekka0050001Msg3List[i].getString(EKKA0050001CBSMsg3List.EXPIRE_DATE)));
//			ticketList.add(ticket);
//		}
//		detail.put(EKKA0050001CBSMsg.EKKA0050001CBSMSG3LIST, ticketList);
		// ANK-4307-00-00 DEL END
		
		// ANK-4307-00-00 ADD START
		// 保有ポイント内訳リストを設定（お客様ランク情報一意照会明細配下のListとする）
		List<Map<String, String>>pointList = new ArrayList<Map<String, String>>();
		for (int i = 0; i < ekka0050001Msg3List.length; i++)
		{
			Map<String, String> point = new HashMap<String, String>();
			point.put(EKKA0050001CBSMsg3List.TEKIYO_ED_YMD,
					JKKStringUtil.nullToBlank(ekka0050001Msg3List[i].getString(EKKA0050001CBSMsg3List.TEKIYO_ED_YMD)));
			point.put(EKKA0050001CBSMsg3List.HOYU_PT_SU,
					JKKStringUtil.nullToBlank(ekka0050001Msg3List[i].getString(EKKA0050001CBSMsg3List.HOYU_PT_SU)));
			pointList.add(point);
		}
		detail.put(EKKA0050001CBSMsg.EKKA0050001CBSMSG3LIST, pointList);
		// ANK-4307-00-00 ADD END


		// ランクアップ条件リストを設定（お客様ランク情報一意照会明細配下のListとする）
		List<Map<String, String>> rankupList = new ArrayList<Map<String, String>>();
		for (int i = 0; i < ekka0050001Msg4List.length; i++)
		{
			Map<String, String> rankup = new HashMap<String, String>();
			rankup.put(EKKA0050001CBSMsg4List.RNKUP_TEXT,
					JKKStringUtil.nullToBlank(ekka0050001Msg4List[i].getString(EKKA0050001CBSMsg4List.RNKUP_TEXT)));
			rankupList.add(rankup);
		}
		detail.put(EKKA0050001CBSMsg.EKKA0050001CBSMSG4LIST, rankupList);

		// お客様ランク情報一意照会明細をリストとして格納
		detailList.add(detail);

		// お客様ランク情報一意照会明細を設定
		ccMsg.put(EKKA0050001CBSMsg.EKKA0050001CBSMSG1LIST, detailList);

		return param;
	}
	
	
	/**
	 * BPチェック用パラメータ作成。<br />
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText ユーザ定義文字列
	 * @return BPチェック用パラメータ
	 */
	public HashMap<?, ?> getInvokeCBS(SessionHandle handle, IRequestParameterReadWrite param, String fixedText)
	{
		// BPチェックはスキップする
		return JCKPmpScParamHenshu.createBpNotCheckParam();
	}
	
	
	/**
	 * ＢＰチェック結果を編集する。<br />
	 * @param param リクエストパラメータ
	 * @param caanMsgs サービスインターフェイス用のパラメータ配列
	 * @param returnCode リターンコード
	 * @return リクエストパラメータ
	 * @throws Throwable 例外が発生した場合
	 */
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param, CAANMsg[] caanMsgs, Integer returnCode) throws Throwable
	{
		return JCKPmpScParamHenshu.editErrorInfo(param, caanMsgs, returnCode);
	}
	
	
	/**
	 * SC(サービスインターフェイス）を呼び出す。
	 * @param handle セッションハンドル
	 * @param scCall SC呼び出し部品
	 * @param param リクエストパラメータ
	 * @param dataMapKey パラメータキー
	 * @param mappingData マッピングデータ
	 * @param contents CAANMsgのコンテンツ
	 * @return CAANMsg
	 * @throws Throwable 例外が発生した場合
	 */
	private CAANMsg callSC(SessionHandle handle, 
							ServiceComponentRequestInvoker scCall, 
							IRequestParameterReadWrite param, 
							String dataMapKey,
							Object[][] mappingData,
							Object[][] contents) throws Throwable
	{
		HashMap<String, Object> paramMap = editInMsg(param, mappingData);

		Map<?, ?> result = scCall.run(paramMap, handle);

		CAANMsg[] templates = (CAANMsg[])result.get(JCMConstants.TEMPLATE_LIST_KEY);

		CAANMsg msg = templates[0];

		// リターンコード取得
		Object return_code = result.get(JCMConstants.RET_CD_INT_KEY);

		int status = msg.getInt(JCMConstants.STATUS_INT_KEY);

		editErrorInfoCom(param, templates, (Integer)return_code, dataMapKey, mappingData, contents);

		//エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>)param.getControlMapData(SCControlMapKeys.ERROR_INFO);

		if (null == errList)
		{
			errList = new ArrayList<Object>();
		}

		// コントロールマップに設定
		param.setControlMapData(SCControlMapKeys.ERROR_INFO, TemplateErrorUtil.getErrorInfo(result, errList));

		// 異常の場合、SCCallExceptionを生成してスローする
		if(!("0".equals(return_code.toString()) && 0 == status))
		{
			throw new SCCallException("戻り値不正", return_code.toString(), status);
		}

		return msg;
	}
	
	
	/**
	 * 共通項目のメッセージを作成します。
	 * @param param リクエストパラメータ
	 * @param mappingData マッピングデータ
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException リクエストパラメータの操作でエラーが発生した場合
	 */
	private HashMap<String, Object> editInMsg(IRequestParameterReadWrite param,
												Object[][] mappingData) 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));

		String svcIf = (String)mappingData[0][1];

		CAANMsg template = new CAANMsg(String.format("eo.ejb.cbs.cbsmsg.%sCBSMsg", svcIf));

		// オペレータID
		template.set(JCMConstants.OPERATOR_ID_KEY, param.getControlMapData(SCControlMapKeys.OPERATOR_ID));

		// 運用日付
		template.set(JCMConstants.OPERATE_DATE_KEY, param.getControlMapData(SCControlMapKeys.OPE_DATE));

		// 運用日時
		template.set(JCMConstants.OPERATE_DATETIME_KEY, param.getControlMapData(SCControlMapKeys.OPE_TIME));
		
		for (int i = 0; i < mappingData.length; i++)
		{
			if ("".equals(mappingData[i][1]))
			{
				template.setNull((String)mappingData[i][0]);
			}
			else
			{
				template.set((String)mappingData[i][0], mappingData[i][1]);
			}
		}

		CAANMsg[] templates = new CAANMsg[1];

		templates[0] = template;

		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	/**
	 * エラー情報を取得します。
	 * @param param リクエストパラメータ
	 * @param templates CAANMsgクラス
	 * @param returnCode リターンコード
	 * @param dataMapKey パラメータキー
	 * @param mappingData マッピングデータ
	 * @param contents CAANMsgのコンテンツ
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException リクエストパラメータの操作でエラーが発生した場合
	 */
	private IRequestParameterReadWrite editErrorInfoCom(IRequestParameterReadWrite param,
														CAANMsg[] templates, 
														int returnCode,
														String dataMapKey,
														Object[][] mappingData,
														Object[][] contents) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(JCMConstants.STATUS_INT_KEY);
		
		if (0 != returnCode)
		{
			templateStatus = 9000;
		}

		if (null == JCMAPLConstMgr.getString("RETURN_MESSAGE_" + String.format("%1$04d", templateStatus)))
		{
			templateStatus = 0;
		}

		int bpStatus = 0;

		Object obj = param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		
		if (null == obj)
		{
			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, String> inMap = null;

		// ユーザデータ情報
		inMap = (HashMap<String, String>)param.getData(dataMapKey);

		for (int i = 0; null != contents && i < contents.length ; i++)
		{
			String itemNm = (String)contents[i][0];
			if (itemNm.endsWith("_err"))
			{
				String errCd = (String)template.getString(itemNm);
				if (!JKKStringUtil.isNullBlank(errCd))
				{
					inMap.put(itemNm, errCd);
				}
			}
		}

		return param;
	}
}
