/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKFindKeiStatCC
*	ソースファイル名：JKKFindKeiStatCC.java
*	作成者			：FJ)柳
*	日付			：2017年02月15日
*＜機能概要＞
*	契約状態照会の共通コンポーネントクラスです。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v29.00.00	2017/02/15	FJ)柳		【ANK-2963-00-00】社長室アンケートWeb化に伴うAPI作成
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.Arrays;
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.ErrorLevel;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadWrite;
import com.fujitsu.futurity.bp.x21.bpm.parameter.StatusArea;
import com.fujitsu.futurity.bp.x21.bpm.parameter.StatusInfo;
import com.fujitsu.futurity.bp.x21.cc.AbstractCommonComponent;
import com.fujitsu.futurity.bp.x21.cc.exception.SCCallException;
import com.fujitsu.futurity.bp.x21.values.OUTBREAK_AREA;
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.CharacterCheck;
import com.fujitsu.futurity.model.common.check.HalfCharCheck;
import com.fujitsu.futurity.model.common.check.LengthCheck;
import com.fujitsu.futurity.model.ejb.common.JSYejbLog;

import eo.common.constant.JKKStrConst;
import eo.common.constant.JPCModelConstant;
import eo.common.util.JKKCommonUtil;
import eo.common.util.JKKStringUtil;
import eo.ejb.cbs.cbsmsg.EKK0251A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0251A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKU0011A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKU0011A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKU0081B010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKU0081B010CBSMsg1List;

/**
 * 契約状態照会の共通コンポーネントクラスです。
 * <br>
 * @author FJ
 */
public class JKKFindKeiStatCC extends AbstractCommonComponent
{
	/** テンプレートID 工事案件一意照会 */
	private static final String TEMPLATE_ID_EKU0011A010 = "EKU0011A010";
	
	/** テンプレートID サービス契約_工事案件一覧照会 */
	private static final String TEMPLATE_ID_EKU0081B010 = "EKU0081B010";
	
	/** テンプレートID サービス契約回線内訳一意照会 */
	private static final String TEMPLATE_ID_EKK0251A010 = "EKK0251A010";
	
	/** IN 機能コード */
	private static final String IN_FUNC_CD = "func_code";
	
	/** IN 申込番号 */
	private static final String IN_MSKM_NO = "mskm_no";
	
	/** IN 郵便番号 */
	private static final String IN_PCD = "pcd";
	
	/** OUT リターンコード */
	private static final String OUT_RETURN_CODE = "return_code";
	
	/** 機能コード 桁数 1桁 */
	private static final int FUNC_CODE_LEN = 1;
	
	/** 申込番号 桁数 10桁 */
	private static final int MSKM_NO_LEN = 10;
	
	/** 郵便番号 桁数 7桁 */
	private static final int PCD_LEN = 7;
	
	/** 結果コード 該当契約あり */
	private static final String RETURN_CD_00 = "00";
	
	/** 結果コード 該当契約なし */
	private static final String RETURN_CD_01 = "01";
	
	/** 結果コード パラメータ不正エラー */
	private static final String RETURN_CD_92 = "92";
	
	/** 契約状態 該当契約あり */
	private static final String KEI_STAT_00 = "該当契約あり";
	
	/** 契約状態 該当契約なし */
	private static final String KEI_STAT_01 = "該当契約なし";
	
	/** 契約状態 パラメータ不正エラー */
	private static final String KEI_STAT_92 = "パラメータ不正エラー";
	
	/** エラー項目の末尾文字列 */
	private static final String ITEM_ERR_END = "_err";
	
	/** 必須チェックエラーフラグ */
	private static final String INDI_ERR = "E1";
	
	/** ドメインチェックエラーフラグ */
	private static final String DMN_ERR = "E2";
	
	/** 桁数チェックエラーフラグ  */
	private static final String KETA_ERR = "E3";
	
	/** 正常 */
	private static final String NORMAL = "0000";
	
	/** 単項目チェックエラー */
	private static final String SINGLE_ITEM_ERR = "1000";
	
	/** エラーメッセージ 単項目チェックエラー */
	private static final String MSG_SINGLE_ITEM_ERR = "単項目チェックエラー";
	
	/**
	 * 指定された申込番号と郵便番号を使用し、eo顧客基幹システムの契約有無を取得する。
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText ユーザ定義文字列
	 * @return IRequestParameterReadWrite
	 * @throws Throwable 例外が発生した場合
	 */
	public IRequestParameterReadWrite findKeiStat(SessionHandle handle,
			IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
		/** パラメータ取得 */
		// 契約状態照会CCマップの取得
		HashMap<String, Object> ccMsg = (HashMap<String, Object>)param.getData(fixedText);
		if (null == ccMsg)
		{
			ccMsg = new HashMap<String, Object>();
			param.setData(fixedText, ccMsg);
		}
		
		// SC呼び出し部品のインスタンス生成(引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない)
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		// 結果格納マップを作成
		Map<String, Object> resultMap = new HashMap<String, Object>();
		
		// 機能コードの取得
		String funcCode = "";
		if (ccMsg.containsKey(IN_FUNC_CD))
		{
			funcCode = (String)ccMsg.get(IN_FUNC_CD);
			resultMap.put(IN_FUNC_CD, funcCode);
		}
		
		// 申込番号の取得
		String mskmNo = "";
		if (ccMsg.containsKey(IN_MSKM_NO))
		{
			mskmNo = (String)ccMsg.get(IN_MSKM_NO);
			resultMap.put(IN_MSKM_NO, mskmNo);
		}
		
		// 郵便番号の取得
		String pcd = "";
		if (ccMsg.containsKey(IN_PCD))
		{
			pcd = (String)ccMsg.get(IN_PCD);
			resultMap.put(IN_PCD, pcd);
		}
		
		/** 単項目チェック */
		if (!isErrInParam(funcCode, mskmNo, pcd, resultMap))
		{
			/** 工事案件一意照会 */
			// 工事案件一意照会の上りマッピング
			Object[][] eku0011a010In = {
					{EKU0011A010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKU0011A010},
					{EKU0011A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
					{EKU0011A010CBSMsg.KEY_KOJIAK_NO, mskmNo}};
			
			// サービスIF実行
			CAANMsg[] eku0011a010Msg1List = callSC(handle, scCall, param, eku0011a010In,
					fixedText, new EKU0011A010CBSMsg().getContents()).getCAANMsgList(EKU0011A010CBSMsg.EKU0011A010CBSMSG1LIST);
			
			if (eku0011a010Msg1List != null && 0 < eku0011a010Msg1List.length)
			{
				// 工事案件ステータスを取得
				String kojiakStat = eku0011a010Msg1List[0].getString(EKU0011A010CBSMsg1List.KOJIAK_STAT);
				
				// マンション工事案件状態コードを取得
				String mansKojiakStatCd = eku0011a010Msg1List[0].getString(EKU0011A010CBSMsg1List.MANS_KOJIAK_STAT_CD);
				
				// 工事案件ステータスが900：中止である場合
				if (JKKStrConst.CD00474_900.equals(kojiakStat))
				{
					// 該当契約なし
					returnNonexistence(resultMap);
				}
				// 工事案件ステータスが120：登録済 かつ マンション工事案件状態コードが900：中止である場合
				else if (JKKStrConst.CD00474_120.equals(kojiakStat) &&
						JKKStrConst.CD01651_KJCANCEL.equals(mansKojiakStatCd))
				{
					// 該当契約なし
					returnNonexistence(resultMap);
				}
				else
				{
					/** サービス契約_工事案件一覧照会 */
					// サービス契約_工事案件一覧照会の上りマッピング
					Object[][] eku0081b010In = {
							{EKU0081B010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKU0081B010},
							{EKU0081B010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2},
							{EKU0081B010CBSMsg.KEY_KOJIAK_NO, mskmNo}};
					
					// サービスIF実行
					CAANMsg[] eku0081b010Msg1List = callSC(handle, scCall, param, eku0081b010In,
							fixedText, new EKU0081B010CBSMsg().getContents()).getCAANMsgList(EKU0081B010CBSMsg.EKU0081B010CBSMSG1LIST);
					
					if (eku0081b010Msg1List != null && 0 < eku0081b010Msg1List.length)
					{
						// サービス契約回線内訳番号を取得
						// (サービス契約工事案件一覧照会明細には複数のデータが取得される場合もあるが、
						//  先頭行を固定で取得する)
						String svcKeiKaisenUcwkNo = eku0081b010Msg1List[0].getString(EKU0081B010CBSMsg1List.SVC_KEI_KAISEN_UCWK_NO);
						
						if (!JKKCommonUtil.isNull(svcKeiKaisenUcwkNo))
						{
							/** サービス契約回線内訳一意照会 */
							// サービス契約回線内訳一意照会の上りマッピング
							Object[][] ekk0251a010In = {
									{EKK0251A010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0251A010},
									{EKK0251A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2},
									{EKK0251A010CBSMsg.KEY_SVC_KEI_KAISEN_UCWK_NO, svcKeiKaisenUcwkNo}};
							
							// サービスIF実行
							CAANMsg[] ekk0251a010Msg1List = callSC(handle, scCall, param, ekk0251a010In,
									fixedText, new EKK0251A010CBSMsg().getContents()).getCAANMsgList(EKK0251A010CBSMsg.EKK0251A010CBSMSG1LIST);
							
							if (ekk0251a010Msg1List != null && 0 < ekk0251a010Msg1List.length)
							{
								// 回線場所郵便番号を取得
								String kaisenPlacePcd = ekk0251a010Msg1List[0].getString(EKK0251A010CBSMsg1List.KAISEN_PLACE_PCD);
								
								// 郵便番号と回線場所郵便番号が同じ場合
								if (pcd.equals(kaisenPlacePcd))
								{
									// 該当契約あり
									resultMap.put(OUT_RETURN_CODE, RETURN_CD_00);
									// ログ出力(該当契約あり)
									outputBusLog(resultMap, KEI_STAT_00);
								}
								else
								{
									// 該当契約なし
									returnNonexistence(resultMap);
								}
							}
							else
							{
								// 該当契約なし
								returnNonexistence(resultMap);
							}
						}
						else
						{
							// 該当契約なし
							returnNonexistence(resultMap);
						}
					}
					else
					{
						// 該当契約なし
						returnNonexistence(resultMap);
					}
				}
			}
			else
			{
				// 該当契約なし
				returnNonexistence(resultMap);
			}
			
			// ステータスエリア編集
			StatusArea sa = param.getStatusArea();
			StatusInfo si = new StatusInfo(ErrorLevel.EL000, OUTBREAK_AREA.CC);
			sa.setCurrent(si);
			
			// リターンコード編集
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, NORMAL);
		}
		else
		{
			// パラメータ不正エラーを設定
			resultMap.put(OUT_RETURN_CODE, RETURN_CD_92);
			// ログ出力(パラメータ不正エラー)
			outputBusLog(resultMap, KEI_STAT_92);
			
			// ステータスエリア編集
			StatusArea sa = param.getStatusArea();
			StatusInfo si = new StatusInfo(ErrorLevel.EL888, OUTBREAK_AREA.CC);
			sa.setCurrent(si);
			
			// リターンコード編集
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, SINGLE_ITEM_ERR);
			
			// リターンメッセージ編集
			param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, MSG_SINGLE_ITEM_ERR);
		}
		
		// リクエストパラメータに結果を格納
		param.removeData(fixedText);
		param.setData(fixedText, resultMap);
		
		return param;
	}
	
	/**
	 * チェック処理です。
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText ユーザ定義文字列
	 * @return HashMap<String, Object>
	 */
	@SuppressWarnings("unchecked")
	public HashMap<String, Object> getInvokeCBS(SessionHandle handle, IRequestParameterReadWrite param, String fixedText)
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();
		List<CAANMsg> templates = new ArrayList<CAANMsg>();
		
		// チェック用サービスインターフェイス
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, Arrays.asList(templates));
		
		return paramMap;
	}
	
	/**
	 * エラー情報を設定します。
	 * @param param リクエストパラメータ
	 * @param templates CAANMsgクラス
	 * @param returnCode リターンコード
	 * @param fixedText ユーザ定義文字列
	 * @param contents CAANMsgのコンテンツ
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException リクエストパラメータの操作でエラーが発生した場合
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param,
			CAANMsg[] templates, int returnCode, String fixedText, Object[][] contents) throws RequestParameterException
	{
		CAANMsg template = templates[0];
		int templateStatus = template.getInt(JCMConstants.STATUS_INT_KEY);
		
		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 (bpStatus < templateStatus)
		{
			// 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 = (HashMap<String, String>)param.getData(fixedText);

		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;
	}
	
	/**
	 * SC(サービスインターフェイス）を呼び出す。
	 * @param handle セッションハンドル
	 * @param scCall SC呼び出し部品
	 * @param param リクエストパラメータ
	 * @param mappingData マッピングデータ
	 * @param fixedText ユーザ定義文字列
	 * @param contents CAANMsgのコンテンツ
	 * @return CAANMsg
	 * @throws Throwable 例外が発生した場合
	 */
	@SuppressWarnings("unchecked")
	private CAANMsg callSC(SessionHandle handle, ServiceComponentRequestInvoker scCall, 
			IRequestParameterReadWrite param, Object[][] mappingData,
			String fixedText, Object[][] contents) throws Throwable
	{
		// 上りマッピング処理
		HashMap<String, Object> paramMap = editInMsg(param, mappingData);
		
		// サービスI/F呼出し実行
		Map<?, ?> result = scCall.run(paramMap, handle);
		
		// SCからの戻り値からCAANMsgを取得
		CAANMsg[] templates = (CAANMsg[])result.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg msg = templates[0];
		
		// リターンコード取得
		Object returnCode = result.get(JCMConstants.RET_CD_INT_KEY);
		// ステータス取得
		int status = msg.getInt(JCMConstants.STATUS_INT_KEY);
		
		// エラー情報の設定
		editErrorInfo(param, templates, (Integer)returnCode, fixedText, contents);
		
		// エラー情報のマップを取得
		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(returnCode.toString()) && 0 == status))
		{
			throw new SCCallException("戻り値不正", returnCode.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));
		
		// サービスインターフェイス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 funcCode 機能コード
	 * @param mskmNo 申込番号
	 * @param pcd 郵便番号
	 * @param resultMap 結果格納マップ
	 * @return true パラメータ不正エラー
	 */
	private boolean isErrInParam(String funcCode, String mskmNo, String pcd,
			Map<String, Object> resultMap) {
		/** 必須チェック */
		// 機能コード
		if (!CharacterCheck.isNotNullCheck(funcCode))
		{
			resultMap.put(IN_FUNC_CD + ITEM_ERR_END, INDI_ERR);
			
			return true;
		}
		
		// 申込番号
		if (!CharacterCheck.isNotNullCheck(mskmNo))
		{
			resultMap.put(IN_MSKM_NO + ITEM_ERR_END, INDI_ERR);
			
			return true;
		}
		
		// 郵便番号
		if (!CharacterCheck.isNotNullCheck(pcd))
		{
			resultMap.put(IN_PCD + ITEM_ERR_END, INDI_ERR);
			
			return true;
		}
		
		/** 属性チェック */
		// 機能コード
		if (!HalfCharCheck.isEnNumber1Check(funcCode))
		{
			resultMap.put(IN_FUNC_CD + ITEM_ERR_END, DMN_ERR);
			
			return true;
		}
		
		// 申込番号
		if (!HalfCharCheck.isEnNumber1Check(mskmNo))
		{
			resultMap.put(IN_MSKM_NO + ITEM_ERR_END, DMN_ERR);
			
			return true;
		}
		
		// 郵便番号
		if (!HalfCharCheck.isNumber1Check(pcd))
		{
			resultMap.put(IN_PCD + ITEM_ERR_END, DMN_ERR);
			
			return true;
		}
		
		/** 桁数チェック */
		// 機能コード
		if (!LengthCheck.isLength1Check(funcCode, FUNC_CODE_LEN))
		{
			resultMap.put(IN_FUNC_CD + ITEM_ERR_END, KETA_ERR);
			
			return true;
		}
		
		// 申込番号
		if (!LengthCheck.isLength1Check(mskmNo, MSKM_NO_LEN))
		{
			resultMap.put(IN_MSKM_NO + ITEM_ERR_END, KETA_ERR);
			
			return true;
		}
		
		// 郵便番号
		if (!LengthCheck.isLength1Check(pcd, PCD_LEN))
		{
			resultMap.put(IN_PCD + ITEM_ERR_END, KETA_ERR);
			
			return true;
		}
		
		return false;
	}
	
	/**
	 * 該当契約なしを返却する。
	 * 
	 * @param resultMap 結果格納マップ
	 */
	private void returnNonexistence(Map<String, Object> resultMap)
	{
		// 該当契約なしを設定
		resultMap.put(OUT_RETURN_CODE, RETURN_CD_01);
		// ログ出力(該当契約なし)
		outputBusLog(resultMap, KEI_STAT_01);
	}
	/**
	 * ビジネスログを出力する。
	 *
	 * @param resultMap 結果格納マップ
	 * @param keiStat 契約状態
	 */
	private void outputBusLog(Map<String, Object> resultMap, String keiStat)
	{
		// ログメッセージの組み立て
		String logMsg = "--- 契約状態照会CC " + keiStat + " 機能コード：" + resultMap.get(IN_FUNC_CD)
				+ " 申込番号：" + resultMap.get(IN_MSKM_NO) + " 郵便番号：" + resultMap.get(IN_PCD)
				+ " リターンコード：" + resultMap.get(OUT_RETURN_CODE);
		// ログ出力
		JSYejbLog.println(JSYejbLog.EXECUTION, this.getClass(), logMsg);
	}
}
