/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKStbUseCustInfoShkCC
*	ソースファイル名：JKKStbUseCustInfoShkCC.java
*	作成者			：FJ
*	日付			：2021年02月03日
*＜機能概要＞
*	STB利用お客さま情報照会の共通コンポーネント
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v52.00.00	2021/02/03	FJ)謝		【ANK-3904-00-00】TV VOD用お客さま情報取得APIの開発
*	v52.00.01	2021/02/18	FJ)謝		【IT1-2021-0000016】対応
**********************************************************************/
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.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 com.fujitsu.futurity.model.common.check.HalfCharCheck;
import com.fujitsu.futurity.model.common.check.LengthCheck;

import eo.common.constant.JKKStrConst;
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.ECKA9010002CBSMsg;
import eo.ejb.cbs.cbsmsg.ECKA9010002CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0241B001CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0241B001CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0341B041CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0341B041CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EWCA0010001CBSMsg;
import eo.ejb.cbs.cbsmsg.EWCA0010001CBSMsg1List;

/**
 * STB利用お客さま情報照会の共通コンポーネントクラスです。
 * <br>
 * @author 富士通
 *
 */
public class JKKStbUseCustInfoShkCC extends AbstractCommonComponent
{
	/** テンプレートID(EWCA0010001) 宅内機器一覧照会(3) */
	private static final String TEMPLATE_ID_EWCA0010001 = "EWCA0010001";
	/** テンプレートID(EKK0341B041) 機器情報取得（型番号・製造番号） */
	private static final String TEMPLATE_ID_EKK0341B041 = "EKK0341B041";
	/** テンプレートID(EKK0081A010) サービス契約一意照会 */
	private static final String TEMPLATE_ID_EKK0081A010 = "EKK0081A010";
	/** テンプレートID(ECK0011A010) お客様一意照会 */
	private static final String TEMPLATE_ID_ECK0011A010 = "ECK0011A010";
	/** テンプレートID(ECKA9010002) AXM会員情報更新依頼（検索） */
	private static final String TEMPLATE_ID_ECKA9010002 = "ECKA9010002";
	/** テンプレートID(EKK0241B001) サービス契約回線内訳一覧照会 */
	private static final String TEMPLATE_ID_EKK0241B001 = "EKK0241B001";

	/** リクエスト STB-ID */
	private static final String REQ_STBID = "stbid";

// IT1-2021-0000016 ADD START
	/** CCパラメータ ボディ情報 */
	private static final String BODY_INFO = "BODY_INFO";
// IT1-2021-0000016 ADD END
	/** レスポンス SYSID */
	private static final String RES_SYSID = "sysid";
	/** レスポンス 会員種別 */
	private static final String RES_KIIN_SHUBT = "kiin_shubt";
	/** レスポンス 登録フラグ */
	private static final String RES_TURK_FLG = "turk_flg";
	/** レスポンス 利用場所郵便番号 */
	private static final String RES_KAISEN_PLACE_PCD = "kaisen_place_pcd";

	/** CCパラメータ エラー情報 */
	private static final String ERROR_INFO = "ERROR_INFO";
	/** CCパラメータ エラーコード */
	private static final String ERROR_CODE = "errCode";
	/** CCパラメータ エラーメッセージ */
	private static final String ERROR_MESSAGE = "errMessage";

	/** エラーメッセージ 必須チェックエラー */
	private static final String ERR_MSG_REQ = "必須チェックエラー";
	/** エラーメッセージ 属性チェックエラー */
	private static final String ERR_MSG_FORM = "属性チェックエラー";
	/** エラーメッセージ 桁数チェックエラー */
	private static final String ERR_MSG_LEN = "桁数チェックエラー";

	/**
	 * STB利用お客さま情報照会を行う。
	 * <br>
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText ユーザ定義文字列
	 * @return リクエストパラメータ
	 * @throws Throwable 例外が発生した場合
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite execute(SessionHandle handle, IRequestParameterReadWrite param, String fixedText)
	throws Throwable
	{
		String dataMapKey = fixedText;

		// STB利用お客さま情報照会CCマップ
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(dataMapKey);
		// レスポンス
		HashMap<String, Object> responseMsg = new HashMap<String,Object>();
		// STB-ID
		String stbid = (String)ccMsg.get(REQ_STBID);
		// SYSID
		String sysid = "";
		// 会員種別
		String kiinShubt = "";
		// 登録フラグ
		String turkFlg = "";
		// 利用場所郵便番号
		String kaisenPlacePcd = "";
// IT1-2021-0000016 ADD START
		// レスポンス SYSID
		responseMsg.put(RES_SYSID, sysid);
		// レスポンス 会員種別
		responseMsg.put(RES_KIIN_SHUBT, kiinShubt);
		// レスポンス 登録フラグ
		responseMsg.put(RES_TURK_FLG, turkFlg);
		// レスポンス 利用場所郵便番号
		responseMsg.put(RES_KAISEN_PLACE_PCD, kaisenPlacePcd);
		ccMsg.put(BODY_INFO, responseMsg);
// IT1-2021-0000016 ADD END

		try
		{
			// 単項目チェック
			if (!checkUnitParam(ccMsg))
			{
				param.setControlMapData(SCControlMapKeys.RETURN_CODE, JKKStrConst.RETURN_CD_5000);
				param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, null);
				return param;
			}

			// 件数結果チェックフラグ(false:チェックOK、true:チェックNG)
			boolean resultCntFlg = false;

			// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
			ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();

			// 宅内機器一覧照会(3)サービスIF実行
			CAANMsg taknkikiInfo = getEWCA0010001(ccMsg, handle, scCall, param, dataMapKey, stbid);

			if (taknkikiInfo == null)
			{
				// 件数結果チェックエラー
				resultCntFlg = true;
			}
			else
			{
				// 宅内機器型式コード
				String taknkikiModelCd = getNullToStr(taknkikiInfo.getString(EWCA0010001CBSMsg1List.STB_TK_MDL_CD));
				// 機器製造番号
				String kikiSeizoNo = getNullToStr(taknkikiInfo.getString(EWCA0010001CBSMsg1List.STB_KK_SEIZO_NO));
				
				// 機器情報取得（型番号・製造番号）サービスIF実行
				CAANMsg kikiInfo = getEKK0341B041(ccMsg, handle, scCall, param, dataMapKey, taknkikiModelCd, kikiSeizoNo);
				
				if (kikiInfo == null)
				{
					// 件数結果チェックエラー
					resultCntFlg = true;
				}
				else
				{
					// サービス契約番号
					String svcKeiNo = getNullToStr(kikiInfo.getString(EKK0341B041CBSMsg1List.SVC_KEI_NO));
					
					// サービス契約一意照会サービスIF実行
					CAANMsg svckeiInfo = getEKK0081A010(ccMsg, handle, scCall, param, dataMapKey, svcKeiNo);
					
					if (svckeiInfo != null)
					{
						// SYSID
						sysid = getNullToStr(svckeiInfo.getString(EKK0081A010CBSMsg1List.SYSID));
						
						// お客様一意照会サービスIF実行
						CAANMsg custInfo = getECK0011A010(ccMsg, handle, scCall, param, dataMapKey, sysid);
						
						if (custInfo != null)
						{
							// 会員種別
							kiinShubt = getNullToStr(custInfo.getString(ECK0011A010CBSMsg1List.MEMBER_SBT_CD));
						}
						
						// AXM会員情報更新依頼（検索）サービスIF実行
						CAANMsg axmMmbInfo = getECKA9010002(ccMsg, handle, scCall, param, dataMapKey, sysid);
						
						if (axmMmbInfo != null)
						{
							// 登録フラグ
							turkFlg = getNullToStr(axmMmbInfo.getString(ECKA9010002CBSMsg1List.TURK_FLG));
						}
					}
					
					// 登録フラグが取得できない場合
					if (JKKStringUtil.isNullBlank(turkFlg))
					{
						// 件数結果チェックエラー
						resultCntFlg = true;
					}
					
					// 件数結果チェックOKの場合のみ処理する
					if (!resultCntFlg)
					{
						// サービス契約回線内訳一覧照会サービスIF実行
						CAANMsg kaisenInfo = getEKK0241B001(ccMsg, handle, scCall, param, dataMapKey, svcKeiNo);
						
						if (kaisenInfo != null)
						{
							// 利用場所郵便番号
							kaisenPlacePcd = getNullToStr(kaisenInfo.getString(EKK0241B001CBSMsg1List.KAISEN_PLACE_PCD));
						}
					}
				}
			}

			// 件数結果チェックエラーの場合
			if (resultCntFlg) 
			{
				// 業務エラーリスト
				List<Map<String, String>> errList = new ArrayList<Map<String, String>>();
				Map<String, String> resultErrMap = new HashMap<String, String>();
				resultErrMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_2001);
				resultErrMap.put(ERROR_MESSAGE, "");
				errList.add(resultErrMap);

				// エラー情報
				ccMsg.put(ERROR_INFO, errList);

				param.setControlMapData(SCControlMapKeys.RETURN_CODE, JKKStrConst.RETURN_CD_5000);
				param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, null);

				return param;
			}

			// レスポンス SYSID
			responseMsg.put(RES_SYSID, sysid);
			// レスポンス 会員種別
			responseMsg.put(RES_KIIN_SHUBT, kiinShubt);
			// レスポンス 登録フラグ
			responseMsg.put(RES_TURK_FLG, turkFlg);
			// レスポンス 利用場所郵便番号
			responseMsg.put(RES_KAISEN_PLACE_PCD, kaisenPlacePcd);

// IT1-2021-0000016 DEL START
//			// レスポンスを設定する
//			param.setData(dataMapKey, responseMsg);
// IT1-2021-0000016 DEL END

			// 正常終了
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, JKKStrConst.RETURN_CD_0000);
			param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, null);
		}
		// サービスインターフェース呼び出しでエラーが発生した場合
		catch (SCCallException scCallEx)
		{
			// システムエラーを設定する
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, JKKStrConst.RETURN_CD_9000);
			param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, JKKStrConst.RETURN_MESSAGE_SYSTEM_ERROR);
		}
		return param;
	}

	/**
	 * SC(サービスインターフェイス）を呼び出す。
	 * @param handle セッションハンドル
	 * @param scCall SC呼び出し部品
	 * @param param リクエストパラメータ
	 * @param dataMapKey パラメータキー
	 * @param mappingData マッピングデータ
	 * @param contents CAANMsgのコンテンツ
	 * @return CAANMsg
	 * @throws Throwable 例外が発生した場合
	 */
	@SuppressWarnings("unchecked")
	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);

		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はスローしない

		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 リクエストパラメータの操作でエラーが発生した場合
	 */
	@SuppressWarnings("unchecked")
	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);
		}

		Map<String, String> inMap = null;

		// ユーザデータ情報
		inMap = (Map<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;
	}

	/**
	 * 宅内機器一覧照会(3)を行う。
	 * @param ccMsg 識別コードマップ
	 * @param handle セッションハンドル
	 * @param scCall SC呼出
	 * @param param パラメーター
	 * @param dataMapKey データマップキー
	 * @param stbid STB-ID
	 * @return CAANMsg
	 * @throws Throwable 
	 */
	private CAANMsg getEWCA0010001(HashMap<String, Object> ccMsg,
								SessionHandle handle,
								ServiceComponentRequestInvoker scCall,
								IRequestParameterReadWrite param,
								String dataMapKey,
								String stbid) throws Throwable
	{
		// 戻り値
		CAANMsg result = null;

		// 上りマッピング
		Object[][] ewca0010001In = {
				{EWCA0010001CBSMsg.TEMPLATEID, TEMPLATE_ID_EWCA0010001},
				{EWCA0010001CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
				{EWCA0010001CBSMsg.KEY_TK_MDL_CD, ""},
				{EWCA0010001CBSMsg.KEY_KK_SEIZO_NO, ""},
				{EWCA0010001CBSMsg.KEY_STBID, stbid},
				{EWCA0010001CBSMsg.KEY_TK_SBT_CD, JKKStrConst.TAKNKIKI_SBT_CD_STB}
		};

		// サービスI/F実行
		CAANMsg[] ewca0010001MsgList = callSC(handle, scCall, param, dataMapKey, ewca0010001In,  new EWCA0010001CBSMsg().getContents()).getCAANMsgList(EWCA0010001CBSMsg.EWCA0010001CBSMSG1LIST);

		if (ewca0010001MsgList != null && ewca0010001MsgList.length > 0)
		{
			result = ewca0010001MsgList[0];
		}

		return result;
	}

	/**
	 * 機器情報取得（型番号・製造番号）を行う。
	 * @param ccMsg 識別コードマップ
	 * @param handle セッションハンドル
	 * @param scCall SC呼出
	 * @param param パラメーター
	 * @param dataMapKey データマップキー
	 * @param taknkikiModelCd 宅内機器型式コード
	 * @param kikiSeizoNo 機器製造番号
	 * @return CAANMsg
	 * @throws Throwable 
	 */
	private CAANMsg getEKK0341B041(HashMap<String, Object> ccMsg,
								SessionHandle handle,
								ServiceComponentRequestInvoker scCall,
								IRequestParameterReadWrite param,
								String dataMapKey,
								String taknkikiModelCd,
								String kikiSeizoNo) throws Throwable
	{
		// 戻り値
		CAANMsg result = null;

		// 上りマッピング
		Object[][] ekk0341b041In1 = {
				{EKK0341B041CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0341B041},
				{EKK0341B041CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
				{EKK0341B041CBSMsg.KEY_TAKNKIKI_MODEL_CD, taknkikiModelCd},
				{EKK0341B041CBSMsg.KEY_KIKI_SEIZO_NO, kikiSeizoNo}
		};

		// サービスI/F実行
		CAANMsg[] ekk0341b041MsgList1 = callSC(handle, scCall, param, dataMapKey, ekk0341b041In1, new EKK0341B041CBSMsg().getContents()).getCAANMsgList(EKK0341B041CBSMsg.EKK0341B041CBSMSG1LIST);

		if (ekk0341b041MsgList1 != null && ekk0341b041MsgList1.length > 0)
		{
			result = ekk0341b041MsgList1[0];
		}
		else
		{
			// 上りマッピング
			Object[][] ekk0341b041In2 = {
					{EKK0341B041CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0341B041},
					{EKK0341B041CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2},
					{EKK0341B041CBSMsg.KEY_TAKNKIKI_MODEL_CD, taknkikiModelCd},
					{EKK0341B041CBSMsg.KEY_KIKI_SEIZO_NO, kikiSeizoNo}
			};

			// サービスI/F実行
			CAANMsg[] ekk0341b041MsgList2 = callSC(handle, scCall, param, dataMapKey, ekk0341b041In2, new EKK0341B041CBSMsg().getContents()).getCAANMsgList(EKK0341B041CBSMsg.EKK0341B041CBSMSG1LIST);

			if (ekk0341b041MsgList2 != null && ekk0341b041MsgList2.length > 0)
			{
				result = ekk0341b041MsgList2[0];
			}
		}

		return result;
	}

	/**
	 * サービス契約一意照会を行う。
	 * @param ccMsg 識別コードマップ
	 * @param handle セッションハンドル
	 * @param scCall SC呼出
	 * @param param パラメーター
	 * @param dataMapKey データマップキー
	 * @param svcKeiNo サービス契約番号
	 * @return CAANMsg
	 * @throws Throwable 
	 */
	private CAANMsg getEKK0081A010(HashMap<String, Object> ccMsg,
								SessionHandle handle,
								ServiceComponentRequestInvoker scCall,
								IRequestParameterReadWrite param,
								String dataMapKey,
								String svcKeiNo) throws Throwable
	{
		// 戻り値
		CAANMsg result = null;

		// 上りマッピング
		Object[][] ekk0081a010In = {
				{EKK0081A010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0081A010},
				{EKK0081A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2},
				{EKK0081A010CBSMsg.KEY_SVC_KEI_NO, svcKeiNo},
				{EKK0081A010CBSMsg.KEY_GENE_ADD_DTM, ""},
				{EKK0081A010CBSMsg.KEY_RSV_APLY_YMD, JCCBPCommon.getOpeDate(null)}
		};

		// サービスI/F実行
		CAANMsg[] ekk0081a010MsgList = callSC(handle, scCall, param, dataMapKey, ekk0081a010In, new EKK0081A010CBSMsg().getContents()).getCAANMsgList(EKK0081A010CBSMsg.EKK0081A010CBSMSG1LIST);

		if (ekk0081a010MsgList != null && ekk0081a010MsgList.length > 0)
		{
			result = ekk0081a010MsgList[0];
		}

		return result;
	}

	/**
	 * お客様一意照会を行う。
	 * @param ccMsg 識別コードマップ
	 * @param handle セッションハンドル
	 * @param scCall SC呼出
	 * @param param パラメーター
	 * @param dataMapKey データマップキー
	 * @param sysid SYSID
	 * @return CAANMsg
	 * @throws Throwable 
	 */
	private CAANMsg getECK0011A010(HashMap<String, Object> ccMsg,
								SessionHandle handle,
								ServiceComponentRequestInvoker scCall,
								IRequestParameterReadWrite param,
								String dataMapKey,
								String sysid) throws Throwable
	{
		// 戻り値
		CAANMsg result = null;

		// 上りマッピング
		Object[][] eck0011a010In = {
				{ECK0011A010CBSMsg.TEMPLATEID, TEMPLATE_ID_ECK0011A010},
				{ECK0011A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2},
				{ECK0011A010CBSMsg.KEY_SYSID, sysid},
				{ECK0011A010CBSMsg.KEY_GENE_ADD_DTM, ""},
				{ECK0011A010CBSMsg.KEY_RSV_APLY_YMD, JCCBPCommon.getOpeDate(null)}
		};

		// サービスI/F実行
		CAANMsg[] eck0011a010MsgList = callSC(handle, scCall, param, dataMapKey, eck0011a010In, new ECK0011A010CBSMsg().getContents()).getCAANMsgList(ECK0011A010CBSMsg.ECK0011A010CBSMSG1LIST);

		if (eck0011a010MsgList != null && eck0011a010MsgList.length > 0)
		{
			result = eck0011a010MsgList[0];
		}

		return result;
	}

	/**
	 * AXM会員情報更新依頼（検索）を行う。
	 * @param ccMsg 識別コードマップ
	 * @param handle セッションハンドル
	 * @param scCall SC呼出
	 * @param param パラメーター
	 * @param dataMapKey データマップキー
	 * @param sysid SYSID
	 * @return CAANMsg
	 * @throws Throwable 
	 */
	private CAANMsg getECKA9010002(HashMap<String, Object> ccMsg,
								SessionHandle handle,
								ServiceComponentRequestInvoker scCall,
								IRequestParameterReadWrite param,
								String dataMapKey,
								String sysid) throws Throwable
	{
		// 戻り値
		CAANMsg result = null;

		// 上りマッピング
		Object[][] ecka9010002In = {
				{ECKA9010002CBSMsg.TEMPLATEID, TEMPLATE_ID_ECKA9010002},
				{ECKA9010002CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
				{ECKA9010002CBSMsg.KEY_SYSID, sysid}
		};

		// サービスI/F実行
		CAANMsg[] ecka9010002MsgList = callSC(handle, scCall, param, dataMapKey, ecka9010002In, new ECKA9010002CBSMsg().getContents()).getCAANMsgList(ECKA9010002CBSMsg.ECKA9010002CBSMSG1LIST);

		if (ecka9010002MsgList != null && ecka9010002MsgList.length > 0)
		{
			result = ecka9010002MsgList[0];
		}

		return result;
	}

	/**
	 * サービス契約回線内訳一覧照会を行う。
	 * @param ccMsg 識別コードマップ
	 * @param handle セッションハンドル
	 * @param scCall SC呼出
	 * @param param パラメーター
	 * @param dataMapKey データマップキー
	 * @param svcKeiNo サービス契約番号
	 * @return CAANMsg
	 * @throws Throwable 
	 */
	private CAANMsg getEKK0241B001(HashMap<String, Object> ccMsg,
								SessionHandle handle,
								ServiceComponentRequestInvoker scCall,
								IRequestParameterReadWrite param,
								String dataMapKey,
								String svcKeiNo) throws Throwable
	{
		// 戻り値
		CAANMsg result = null;

		// 上りマッピング
		Object[][] ekk0241b001In = {
				{EKK0241B001CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0241B001},
				{EKK0241B001CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
				{EKK0241B001CBSMsg.KEY_SVC_KEI_NO, svcKeiNo}
		};

		// サービスI/F実行
		CAANMsg[] ekk0241b001MsgList = callSC(handle, scCall, param, dataMapKey, ekk0241b001In, new EKK0241B001CBSMsg().getContents()).getCAANMsgList(EKK0241B001CBSMsg.EKK0241B001CBSMSG1LIST);

		if (ekk0241b001MsgList != null && ekk0241b001MsgList.length > 0)
		{
			result = ekk0241b001MsgList[0];
		}

		return result;
	}

	/**
	 * 単項目チェックを行う。
	 * @param ccMsg 識別コードマップ
	 * @return チェックの判定
	 * @throws Exception
	 */
	private boolean checkUnitParam(HashMap<String, Object> ccMsg)
	throws Exception
	{
		// 業務エラーリスト
		List<Map<String, String>> errList = new ArrayList<Map<String, String>>();

		// STB-ID
		String stbid = (String)ccMsg.get(REQ_STBID);

		if (stbid == null || "".equals(stbid))
		{
			// 必須チェックエラー
			errList.add(getReqErrInfMap());
		}
		else if (!HalfCharCheck.isEnNumber1Check(stbid))
		{
			// 属性チェックエラー
			errList.add(getFormErrInfMap());
		}
		else if (!LengthCheck.isLength1Check(stbid, 12))
		{
			// 桁数チェックエラー
			errList.add(getLenErrInfMap());
		}

		// エラーが存在する場合
		if (errList.size() > 0)
		{
			// エラー情報
			ccMsg.put(ERROR_INFO, errList);
			return false;
		}

		return true;
	}

	/**
	 * 単項目チェックの必須エラーマップ作成メソッドです。
	 * @return
	 */
	private Map<String, String> getReqErrInfMap()
	{
		Map<String, String> returnMap = new HashMap<String, String>();

		returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_1001);
		returnMap.put(ERROR_MESSAGE, ERR_MSG_REQ);

		return returnMap;
	}

	/**
	 * 単項目チェックの属性エラーマップ作成メソッドです。
	 * @return
	 */
	private Map<String, String> getFormErrInfMap()
	{
		Map<String, String> returnMap = new HashMap<String, String>();

		returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_1002);
		returnMap.put(ERROR_MESSAGE, ERR_MSG_FORM);

		return returnMap;
	}

	/**
	 * 単項目チェックの桁数エラーマップ作成メソッドです。
	 * @return
	 */
	private Map<String, String> getLenErrInfMap()
	{
		Map<String, String> returnMap = new HashMap<String, String>();

		returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_1003);
		returnMap.put(ERROR_MESSAGE, ERR_MSG_LEN);

		return returnMap;
	}

	/**
	 * パラメタがNullの場合空白を返却する。
	 * @param str 文字列
	 * @return str
	 */
	private String getNullToStr(String str)
	{
		if (str == null || "".equals(str.trim()))
		{
			return "";
		}
		return str;
	}
}