/*********************************************************************
 * All Rights reserved,Copyright (c) K-Opticom
 **********************************************************************
 *＜プログラム内容＞
 *   システム名      ：eo顧客基幹システム
 *   モジュール名    ：JKKPrgshokaiCC
 *   ソースファイル名：JKKPrgshokaiCC.java
 *   作成者          ：FJ
 *   日付            ：2011年11月02日
 *＜機能概要＞
 * 進捗情報照会CC<br/>
 * 進捗情報照会画面で指定された検索条件に従い、進捗情報の照会処理を行う。
 *＜修正履歴＞
 *   バージョン  修正日       修正者      修正内容
 *   v1.00.00    2011/11/02   FJ）　　    新規作成
 *   v4.00.00    2012/10/10   FJ）森      IT1-2012-0001145 進捗日時の取得元を進捗年月日時分秒から登録年月日時分秒に変更
 *   v73.00.00   2024/10/09   FJ)森下     【ANK-4427-00-00】NTT卸対応
 *
 **********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedHashMap;
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.sc.exception.SCException;
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.common.util.JKKStringUtil;
import eo.ejb.cbs.cbsmsg.EZM0171A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EZM0171A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EZM0321B010CBSMsg;
import eo.ejb.cbs.cbsmsg.EZM0321B010CBSMsg1List;

/**
 * 進捗情報照会CC<br>
 * <br>
 * 進捗情報照会画面で指定された検索条件に従い、進捗情報の照会処理を行う。<br>
 * 
 * @author FJ
 */
public class JKKPrgshokaiCC extends AbstractCommonComponent
{

	/** サービスインターフェイスのパッケージ */
	private static final String PACKAGE_NAME = "eo.ejb.cbs.cbsmsg.";

	/** サフィックス１ */
	private static final String SAF = "CBSMsg1List";

	/** サフィックス２ */
	private static final String SAF2 = "CBSMsg";

	/** 空文字 */
	private static final String STR_EMPTY = "";

	/** グルーピングマップ キーセパレータ */
	private static final String GRP_MAP_SEP = "#";

	/** 日時書式(yyyyMMddHHmmssSSS) */
	private static final String FMT_YMDHMSS = "yyyyMMddHHmmssSSS";

	/** 日時編集書式(yyyy/MM/dd HH:mm:ss)  */
	private static final String EDIT_YMDHMS = "yyyy/MM/dd HH:mm:ss";

	// ANK-4427-00-00 ADD START
	/**  化かし前進捗ステータス */
	private static final String PRG_STAT_BEFORE = "prg_stat_before";
	/**  化かし前進捗特記事項1 */
	private static final String PRG_TKJK1_BEFORE = "prg_tkjk1_before";
	/**  化かし後進捗ステータス */
	private static final String PRG_STAT_AFTER = "prg_tkjk1_after";
	
	/** テンプレートID EZM0321B010 */
	private static final String TEMPLATE_ID_EZM0321B010 = "EZM0321B010";
	/** テンプレートID EZM0171A010 */
	private static final String TEMPLATE_ID_EZM0171A010 = "EZM0171A010";
	// ANK-4427-00-00 ADD END

	/**
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite prgshokai(SessionHandle handle, IRequestParameterReadWrite param, String fixedText)
			throws Exception
	{
		Map<String, Object> dataMap = (HashMap<String, Object>)param.getData(fixedText);
		List<Map<String, String>> trgtList = new ArrayList<Map<String, String>>();

		// サービスの呼出
		Map<String, String> inMap = new HashMap<String, String>();
		inMap.put("svc_kei_no", (String)dataMap.get("svc_kei_no"));
		inMap.put("ido_div", (String)dataMap.get("ido_div"));
		inMap.put("sort_item", (String)dataMap.get("sort_item"));
		inMap.put("sort_order", (String)dataMap.get("sort_order"));
		CAANMsg[] retList = runSc(handle, param, "EKK1091B001", fixedText);

		// CAANMsg[] retList = getDummyData();

		// 出力情報の修正
		Map<String, List<Map<String, String>>> tmpMap = new LinkedHashMap<String, List<Map<String, String>>>();

// OT-2013-0000626 2013/04/09 MOD START
//		for (int i = 0; i < retList.length; i++)
//		{
//			String key = retList[i].getString("ido_div") + GRP_MAP_SEP + retList[i].getString("ido_dtm");
//			if (isEmptyKey(tmpMap, key))
//			{
//				tmpMap.put(key, new ArrayList<Map<String, String>>());
//			}
//
//			tmpMap.get(key).add(map(retList[i]));
//		}
		if (!JKKBpCommon.isNull(retList))
		{
			for (int i = 0; i < retList.length; i++)
			{
				String key = retList[i].getString("ido_div") + GRP_MAP_SEP + retList[i].getString("ido_dtm");
				if (isEmptyKey(tmpMap, key))
				{
					tmpMap.put(key, new ArrayList<Map<String, String>>());
				}

				tmpMap.get(key).add(map(retList[i]));
			}
		}
// OT-2013-0000626 2013/04/09 MOD END

		// グループに対しての処理
		List<Map<String, String>> keyList = new ArrayList<Map<String, String>>();
		Iterator<String> iter = tmpMap.keySet().iterator();
		while (iter.hasNext())
		{
			setCtrlParam(keyList, trgtList, tmpMap.get(iter.next()));
		}

		dataMap.put("trgt_ido_div_list", keyList);

		// ANK-4427-00-00 ADD STARAT
		modTypeN(handle, param, fixedText, tmpMap);
		// ANK-4427-00-00 ADD END

		// ページング処理を実施
		setPaging(dataMap, trgtList);

		return param;
	}

	/**
	 * <dd>出力する一覧に制御項目を付与します。
	 * 
	 * @param keyList
	 *            対象マップのキー一覧
	 * @param trgtList
	 *            対象マップリスト
	 * @param src
	 *            出力する一覧
	 */
	private void setCtrlParam(List<Map<String, String>> keyList, List<Map<String, String>> trgtList,
			List<Map<String, String>> src)
	{
		boolean isTop = true;
		for (int i = 0; i < src.size(); i++)
		{
			Map<String, String> obj = src.get(i);

			obj.put("record_id", obj.get("ido_div") + obj.get("ido_dtm"));

			if (isTop)
			{
				obj.put("record_type", "p");
				isTop = false;

				// キーリストに追加
				boolean isKeyExists = false;
				for (int j = 0; j < keyList.size(); j++)
				{
					String idoDiv = keyList.get(j).get("ido_div");
					if (idoDiv.equals(obj.get("ido_div")))
					{
						isKeyExists = true;
						break;
					}
				}

				if (!isKeyExists)
				{
					Map<String, String> key = new HashMap<String, String>();
					key.put("ido_div", obj.get("ido_div"));
					key.put("ido_div_nm", obj.get("ido_div_nm"));
					keyList.add(key);
				}
			}
			else
			{
				obj.put("record_type", "c");
			}

			trgtList.add(obj);
		}
	}

	/**
	 * <dd><code>EKK1091B001</code> の出力形式 → <code>JKKPrgshokaiCC</code>
	 * の出力形式へマップする。
	 * 
	 * @param src
	 *            <code>EKK1091B001</code>の出力オブジェクト
	 * @return 出力マップオブジェクト
	 */
	private Map<String, String> map(CAANMsg src)
	{
		Map<String, String> ret = new HashMap<String, String>();
		// 進捗番号
		ret.put("prg_no", src.getString("prg_no"));
		// 異動区分
		ret.put("ido_div", src.getString("ido_div"));
		// 異動区分名称
		ret.put("ido_div_nm", src.getString("ido_div_nm"));
		// 異動理由１
		ret.put("ido_rsn_1", src.getString("ido_rsn_cd_1"));
		// 異動理由１名称
		ret.put("ido_rsn_1_nm", src.getString("ido_rsn_cd_nm_1"));
		// 異動理由２
		ret.put("ido_rsn_2", src.getString("ido_rsn_cd_2"));
		// 異動理由２名称
		ret.put("ido_rsn_2_nm", src.getString("ido_rsn_cd_nm_2"));
		// 異動理由３
		ret.put("ido_rsn_3", src.getString("ido_rsnv_3"));
		// 異動理由３名称
		ret.put("ido_rsn_3_nm", src.getString("ido_rsn_cd_nm_3"));
		// 異動理由４
		ret.put("ido_rsn_4", src.getString("ido_rsn_cd_4"));
		// 異動理由４名称
		ret.put("ido_rsn_4_nm", src.getString("ido_rsn_cd_nm_4"));
		// 異動理由５
		ret.put("ido_rsn_5", src.getString("ido_rsn_cd_5"));
		// 異動理由５名称
		ret.put("ido_rsn_5_nm", src.getString("ido_rsn_cd_nm_5"));
		// 進捗ステータス
		ret.put("prg_stat", src.getString("prg_stat"));
		// 進捗ステータス名称
		ret.put("prg_stat_nm", src.getString("prg_stat_nm"));
		// 進捗日時
// IT1-2012-0001145 2012/10/10 mod strat
//		String prgTime = src.getString("prg_dtm");
		String prgTime = src.getString("add_dtm");
// IT1-2012-0001145 2012/10/10 mod end
		if (prgTime != null && !"".equals(prgTime))
		{
			ret.put("prg_time", getYmdString(prgTime));
		}
		// 部署
		ret.put("org_nm", src.getString("org_nm"));
		// 担当者
		ret.put("user_nm", src.getString("user_nm"));
		// 申込書番号
		ret.put("mskmsho_no", src.getString("mskmsho_no"));
		// 申込年月日
		ret.put("mskm_ymd", src.getString("mskm_ymd"));
		// 代理店コード（取扱コード）１
		ret.put("trat_cd_1", src.getString("agnt_cd_1"));
		// 代理店コード（取扱コード）２
		ret.put("trat_cd_2", src.getString("agnt_cd_2"));
		// 代理店コード（取扱コード）３
		ret.put("trat_cd_3", src.getString("agnt_cd_3"));
		// 代理店コード（取扱コード）４
		ret.put("trat_cd_4", src.getString("agnt_cd_4"));
		// 事務手数料
		ret.put("jimu_commision", src.getString("icjkn_sette_cd_nm_1"));
		// 標準工事費
		ret.put("stdard_kojihi", src.getString("icjkn_sette_cd_nm_2"));
		// 進捗特記事項１
		ret.put("tkjk_1", src.getString("prg_tkjk_1"));
		// 進捗特記事項２
		ret.put("tkjk_2", src.getString("prg_tkjk_2"));
		// 進捗メモ
		ret.put("prg_memo", src.getString("prg_memo"));
		// 異動年月日時分秒
		ret.put("ido_dtm", src.getString("ido_dtm"));
		// 申込明細番号
		ret.put("mskm_dtl_no", src.getString("mskm_dtl_no"));
		// 更新年月日時分秒
		ret.put("upd_dtm", src.getString("upd_dtm"));
		
		// 2012-06-25 ANK-0397-00-0007 ADD_START
		// 申込書明細番号
		ret.put("mskmsho_dtl_no", src.getString("mskmsho_dtl_no"));
		// 2012-06-25 ANK-0397-00-0007 ADD_END

		
		return ret;
	}

	/**
	 * yyyy/MM/dd hh:mm:ss 形式の文字列を取得する
	 * 
	 * @param str
	 *            yyyyMMddhhmmss形式の文字列
	 * @return yyyy/MM/dd hh:mm:ss 形式の文字列
	 */
	private String getYmdString(String str)
	{
		try
		{
			return new SimpleDateFormat(EDIT_YMDHMS).format(new SimpleDateFormat(FMT_YMDHMSS).parse(str));
		}
		catch (ParseException e)
		{
			return "";
		}
	}

	/**
	 * @param dataMap
	 * @param rirekiList
	 */
	private void setPaging(Map<String, Object> dataMap, List<Map<String, String>> rirekiList)
	{
		int displayNum = Integer.parseInt((String)dataMap.get("display_num"));
		int totalPageNum = 1;
		int displayPageNum = Integer.parseInt((String)dataMap.get("display_page_num"));
		int fromIndex = ((displayPageNum - 1) * displayNum);
		int toIndex = (displayPageNum * displayNum) - 1;

		// １ページあたりの表示件数を超えた場合
		if (rirekiList.size() > displayNum)
		{
			totalPageNum = rirekiList.size() / displayNum;
			if (rirekiList.size() % displayNum > 0)
			{
				totalPageNum++;
			}
		}

		dataMap.put("trgt_data_list", subList(rirekiList, fromIndex, toIndex));
		dataMap.put("total_search_num", Integer.toString(rirekiList.size()));
		dataMap.put("total_page_num", Integer.toString(totalPageNum));
	}

	/**
	 * @param map
	 * @param key
	 * @return boolean
	 */
	private boolean isEmptyKey(Map<String, ?> map, String key)
	{
		if (map == null || map.get(key) == null || STR_EMPTY.equals(map.get(key)))
		{
			return true;
		}
		else
		{
			return false;
		}
	}

	/**
	 * @param handle ハンドラ
	 * @param param パラメータ
	 * @param templateId テンプレートID
	 * @param fixedText ユーザ定義文字列
	 * @return CAANMsg[] S-IF実行結果
	 * @throws SCException
	 * @throws RequestParameterException
	 */
	private CAANMsg[] runSc(SessionHandle handle, IRequestParameterReadWrite param, String templateId, String fixedText)
			throws SCException, RequestParameterException
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();
		Map<String, Object> inMap = (HashMap<String, Object>)param.getData(fixedText);

		// 【取得元：電文ヘッダ(ヘッダ)】
		paramMap.put(JCMConstants.TRANZACTION_ID_KEY, param.getTelegramID());
		paramMap.put(JCMConstants.USECASE_ID_KEY, param.getUsecaseID());
		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));
		paramMap.put(JCMConstants.CLIENT_IP_ADDRESS_KEY, param.getControlMapData(SCControlMapKeys.REQ_HOSTIP));
		paramMap.put(JCMConstants.INVOKE_GAMEN_ID_KEY, param.getControlMapData(SCControlMapKeys.REQ_VIEWID));
		paramMap.put(JCMConstants.OPERATOR_ID_KEY, param.getControlMapData(SCControlMapKeys.OPERATOR_ID));

		CAANMsg template = new CAANMsg(PACKAGE_NAME + templateId + SAF2);

		template.set(JCMConstants.TEMPLATE_ID_KEY, templateId);
		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));

		if (inMap != null)
		{
			// 機能コード
			template.set(JCMConstants.FUNC_CODE_KEY, inMap.get(JCMConstants.FUNC_CODE_KEY));
		}

		// サービス契約番号
		if (isEmptyKey(inMap, "svc_kei_no"))
		{
			template.setNull("key_svc_kei_no");
		}
		else
		{
			template.set("key_svc_kei_no", inMap.get("svc_kei_no"));
		}

		// 異動区分
		if (isEmptyKey(inMap, "ido_div"))
		{
			template.setNull("key_ido_div");
		}
		else
		{
			template.set("key_ido_div", inMap.get("ido_div"));
		}

		// ソート項目
		if (isEmptyKey(inMap, "sort_item"))
		{
			template.setNull("key_sort_item");
		}
		else
		{
			template.set("key_sort_item", inMap.get("sort_item"));
		}

		// ソート順
		if (isEmptyKey(inMap, "sort_order"))
		{
			template.setNull("key_sort_order");
		}
		else
		{
			template.set("key_sort_order", inMap.get("sort_order"));
		}

		template.set("display_num", "99999");
		template.set("display_page_num", "1");

		// リクエスト用クラスの設定
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, new CAANMsg[]
		{
			template
		});

		/* ◇ＳＣ呼出実行 */
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない。
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		Map<?, ?> result = scCall.run(paramMap, handle);

		CAANMsg[] resultTemplates = (CAANMsg[])result.get(JCMConstants.TEMPLATE_LIST_KEY);
		return resultTemplates[0].getCAANMsgList(templateId + SAF);
	}

	/**
	 * @param list
	 * @param fromIndex
	 * @param toIndex
	 * @return List<Map<String, String>>
	 */
	private List<Map<String, String>> subList(List<Map<String, String>> list, int fromIndex, int toIndex)
	{
		boolean isTop = true;
		boolean isOdd = false;
		List<Map<String, String>> ret = new ArrayList<Map<String, String>>();
		for (int i = 0; i < list.size(); i++)
		{
			if (i >= fromIndex && toIndex >= i)
			{
				if (isTop)
				{
					list.get(i).put("record_type", "p");
				}

				isTop = false;

				// TAI-2012-0000081 2012/11/07 DEL START
				// リストの網掛け表示を修正
				//if ("p".equals(list.get(i).get("record_type")))
				//{
				// TAI-2012-0000081 2012/11/07 DEL END
					isOdd = !isOdd;
				// TAI-2012-0000081 2012/11/07 DEL START
				//}
				// TAI-2012-0000081 2012/11/07 DEL END

				if (isOdd)
				{
					list.get(i).put("record_style", "odd");
				}
				else
				{
					list.get(i).put("record_style", "even");
				}

				ret.add(list.get(i));
			}
		}
		return ret;
	}


	// ANK-4427-00-00 ADD START
	/**
	 * TypeNの文言を化かす
	 * 
	 * @param handle
	 * @param param
	 * @param dataMapKey
	 * @param tmpMap
	 */
	private void modTypeN(SessionHandle handle, 
			IRequestParameterReadWrite param, 
			String dataMapKey,
			Map<String, List<Map<String, String>>> tmpMap) throws Exception
	{
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		// 業務パラメータ一覧照会を実行する
		Object[][] ezm0321b010In = {
				{EZM0321B010CBSMsg.TEMPLATEID, TEMPLATE_ID_EZM0321B010},
				{EZM0321B010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
				{EZM0321B010CBSMsg.KEY_WORK_PARAM_ID, JKKStrConst.KK_TYPEN_C_PRGMGN}
		};
		
		// サービスI/F実行
		CAANMsg[] workEZM0321B010 = callSC(handle, scCall, param, dataMapKey, ezm0321b010In).getCAANMsgList(EZM0321B010CBSMsg.EZM0321B010CBSMSG1LIST);
		
		// 化かし対応が必要なものリスト
		ArrayList modList = new ArrayList();
		
		for (int i = 0; i < workEZM0321B010.length; i++)
		{
			CAANMsg childTemplate = new CAANMsg();
			childTemplate = workEZM0321B010[i];
			
			String workParamSetteValue = childTemplate.getString(EZM0321B010CBSMsg1List.WORK_PARAM_SETTE_VALUE);
			String[] workSplit = workParamSetteValue.split(",");
			
			String prgStatBefore = "";
			String prgTkjk1Before = "";
			String prgStatAfter = "";
			
			if (workSplit.length >= 3)
			{
				// 化かし前進捗ステータス
				prgStatBefore = workSplit[0];
				// 化かし前進捗特記事項1
				prgTkjk1Before = workSplit[1];
				// 化かし後進捗ステータス
				prgStatAfter = workSplit[2];
			}
			
			Map<String,Object> modMap = new HashMap<String,Object>();
			modMap.put(PRG_STAT_BEFORE, prgStatBefore);
			modMap.put(PRG_TKJK1_BEFORE, prgTkjk1Before);
			modMap.put(PRG_STAT_AFTER, prgStatAfter);
			
			modList.add(modMap);
		}
		
		Iterator<String> iter = tmpMap.keySet().iterator();
		while (iter.hasNext())
		{
			String key = iter.next();
			// keyの異動区分がオプション設定でない場合、continue
			if (!key.startsWith(JKKStrConst.CD00576_00031))
			{
				continue;
			}
			
			List<Map<String, String>> workList = tmpMap.get(key);
			
			for (int j = 0; j < workList.size(); j++)
			{
				Map<String, String> workMap = workList.get(j);
				
				// 進捗ステータス
				String prgStat = workMap.get("prg_stat");
				// 進捗特記事項1
				String prgTkjk1 = workMap.get("tkjk_1");
				
				for (int k = 0; k < modList.size(); k++)
				{
					Map<String,Object> modMap = (Map<String,Object>)modList.get(k);
					// 化かし前進捗ステータス
					String prgStatBefore = (String)modMap.get(PRG_STAT_BEFORE);
					// 化かし前進捗特記事項1
					String prgTkjk1Before = (String)modMap.get(PRG_TKJK1_BEFORE);
					// 化かし後進捗ステータス
					String prgStatAfter = (String)modMap.get(PRG_STAT_AFTER);
					
					// 進捗一覧で取得した値が化かし前の値と一致した場合、化かし対応を行う
					if (!JKKStringUtil.isNullBlank(prgStatBefore) && prgStatBefore.equals(prgStat)
							&& !JKKStringUtil.isNullBlank(prgTkjk1Before) && prgTkjk1Before.equals(prgTkjk1)
							&& !JKKStringUtil.isNullBlank(prgStatAfter))
					{
						// コード名称管理一意照会を実行して化かし後進捗特記事項1
						Object[][] ezm0171a010In = {
								{EZM0171A010CBSMsg.TEMPLATEID, TEMPLATE_ID_EZM0171A010},
								{EZM0171A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
								{EZM0171A010CBSMsg.KEY_CD_SBT_CD, JKKStrConst.CD_SBT_CD_CD00647},
								{EZM0171A010CBSMsg.KEY_CD_DIV, prgStatAfter},
						};
						
						// サービスI/F実行
						CAANMsg[] workEZM0171A010 = callSC(handle, scCall, param, dataMapKey, ezm0171a010In).getCAANMsgList(EZM0171A010CBSMsg.EZM0171A010CBSMSG1LIST);
						String prgStatNmAfter = workEZM0171A010[0].getString(EZM0171A010CBSMsg1List.CD_DIV_NM);
						
						workMap.put("prg_stat", prgStatAfter);
						workMap.put("prg_stat_nm", prgStatNmAfter);
						break;
					}
				}
			}
		}
	}

	/**
	 * SC(サービスインターフェイス）を呼び出す。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param dataMapKey
	 * @param mappingData
	 * @return CAANMsg
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private CAANMsg callSC(SessionHandle handle, 
							ServiceComponentRequestInvoker scCall, 
							IRequestParameterReadWrite param, 
							String dataMapKey,
							Object[][] mappingData) throws Exception
	{
		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);
		
		//エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>)param.getControlMapData(SCControlMapKeys.ERROR_INFO);
		
		/* エラー情報のマップないとき、新しいエラー情報をイニシャライズする*/
		if (errList == null)
		{
			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++)
		{
			/* CAANMsg[]の場合 */
			if (mappingData[i][1] instanceof CAANMsg[])
			{
				 template.set((String)mappingData[i][0], (CAANMsg[])mappingData[i][1]);
			}
			/* CAANMsg[]の以外 */
			else
			{
				/* nullの場合*/
				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 リクエストパラメータの操作でエラーが発生した場合
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editErrorInfoCom(IRequestParameterReadWrite param,
														CAANMsg[] templates, 
														int returnCode,
														String dataMapKey,
														Object[][] mappingData) throws RequestParameterException
	{
		// 本来はサービスインターフェイス分の処理が必要
		CAANMsg template = templates[0];
		int templateStatus = template.getInt(JCMConstants.STATUS_INT_KEY);
		
		/* 0以外のとき */
		if (returnCode != 0)
		{
			templateStatus = 9000;
		}
		
		/* nullのとき */
		if (JCMAPLConstMgr.getString("RETURN_MESSAGE_" + String.format("%1$04d", templateStatus)) == null)
		{
			templateStatus = 0;
		}

		int bpStatus = 0;
		Object obj = param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		/* nullの場合 */
		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, String> inMap = null;

		// ユーザデータ情報
		inMap = (HashMap<String, String>)param.getData(dataMapKey);
		
		for (int i = 0; i < mappingData.length; i++)
		{
			/* nullチェック　*/
			if (!template.isNull(mappingData[i][0] + "_err"))
			{
				/* ユーザデータ情報にエラーを確認する　*/
				if (!inMap.containsKey(mappingData[i][0] + "_err"))
				{
					inMap.put(mappingData[i][0] + "_err", template.getString(mappingData[i][0] + "_err"));
				}
			}
		}
		return param;
	}
	// ANK-4427-00-00 ADD END

}
