/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：
*	モジュール名	：JFUMansTkJknShokaiCmpCC
*	ソースファイル名：JFUMansTkJknShokaiCmpCC.java
*	作成者			：GDC)ニール
*	日付			：2021年03月26日
*＜機能概要＞
*	お客様請求契約一覧情報を取得する
*＜修正履歴＞
*	バージョン		修正日		修正者				修正内容
*  v53.0.0		2021/03/26  GDC)ニール			【ANK-4009-00-00】CX戦略WG方針対応（フロントシェア分）
*  v54.0.0		2021/08/11  大島				ANK-4092-00-00_CX戦略WG方針対応STEP2
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

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.JFUStrConst;
import eo.common.constant.JKKStrConst;
import eo.common.constant.JPCModelConstant;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0881A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0881A010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0891A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0891A010CBSMsg1List;

/**
 * 
 * @author n.alcoseba
 *
 */
public class JFUMansTkJknShokaiCmpCC extends AbstractCommonComponent {

	/** エラー情報 **/
	private static final String ERROR_INFO = "ERROR_INFO";
	/** エラーコード **/
	private static final String ERROR_CODE = "errCode";
	/** エラーメッセージ **/
	private static final String ERROR_MESSAGE = "errMessage";
	
	/** 空白 */
	private static final String EMPTY = "";

	/** サービス契約番号 パラメータ名 */
	private static final String SVC_KEI_NO = "svc_kei_no";
	/** 提供方式パターンコード パラメータ名 **/
	private static final String TK_HOSHIKI_PATTERN_CD = "tk_hoshiki_pattern_cd";
	/** 通信速度コード パラメータ名 **/
	private static final String TUSHIN_SPEED_CD = "tushin_speed_cd";
	/** アクセス回線種別コード パラメータ名**/
	private static final String TK_HOSHIKI_NM = "tk_hoshiki_nm";
	/** アクセス回線種別コード パラメータ名**/
	private static final String ACCSS_KISN_SPEED_CD = "accss_kisn_speed_cd";
	/** 契約形態コード パラメータ名**/
	private static final String KEI_FORM_CD = "kei_form_cd";
	/**パターン パラメータ名**/
	private static final String PATTERN = "pattern";
	
	/** テンプレートID EKK0081A010 */
	private static final String TEMPLATE_ID_EKK0081A010 = "EKK0081A010";
	/** テンプレートID EKK0891A010 */
	private static final String TEMPLATE_ID_EKK0891A010 = "EKK0891A010";
	/** テンプレートID EKK0881A010 */
	private static final String TEMPLATE_ID_EKK0881A010 = "EKK0881A010";
	
	private static final String FU_MANSION_PATTERN_CODE_SETTING_XML_PATH = "FU_MANSION_PATTERN_CODE_SETTING_FILE";
	
	private static final String PLANCHG_XML_FILE = JCCBPCommon.getApplicationConst(FU_MANSION_PATTERN_CODE_SETTING_XML_PATH);

	private static final String PATTERN_ROOT = "PATTERN";
	
	private enum PATTERN_ATTRS {
		MANSION_ID("mansion_id"), TK_HOSHIKI_PATTERN_CD("tk_hoshiki_pattern_cd"), TONAI_SPEED_CD("tonai_speed_cd"), TK_HOSHIKI_CD("tk_hoshiki_cd"),
		ACCSS_KISN_SPEED_CD("accss_kisn_speed_cd"), KANYU_KEI_PAY_HOSHIKI_CD("kanyu_kei_pay_hoshiki_cd");
		
		private String name;
		
		private PATTERN_ATTRS(String name) {
			this.name = name;
		}
	}
	
	/**
	 * 取扱コード反映（営業支援）を行う。
	 * <br>
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return IRequestParameterReadWrite リクエストパラメータ
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite execute(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Throwable
	{
		Map<String, Object> ccMsg = (Map<String, Object>) param.getData(fixedText);
		// SC呼び出し部品のインスタンス生成（引数にはログに出力するクラス名を渡す。空文字を設定した場合はログに出力されない）
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		try {
			
			// データチェック
			/* 単項目チェック */
			if (!checkUnitParam(ccMsg))
			{
				
				param.setControlMapData(SCControlMapKeys.RETURN_CODE, JKKStrConst.RETURN_CD_5000);
				param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, null);
				return param;
			}
			
			String svcKeiNO = (String) ccMsg.get(SVC_KEI_NO);
			// サービス契約一意照会サービスIF実行
			CAANMsg[] ekk0081a010INcbsMsg1list = execEKK0081A010(handle, scCall, param, fixedText, svcKeiNO);
			
			// 関連チェック
			if (!checkUnitParamLink(ekk0081a010INcbsMsg1list, ccMsg))
			{
				param.setControlMapData(SCControlMapKeys.RETURN_CODE, JKKStrConst.RETURN_CD_5000);
				param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, null);
				return param;
			}
			
			CAANMsg ekk0081a010INCBS = ekk0081a010INcbsMsg1list[0];
			String tkHoshikiKeiNO = ekk0081a010INCBS.getString(EKK0081A010CBSMsg1List.TK_HOSHIKI_KEI_NO);
			// 提供方式契約一意照会サービスIF実行
			CAANMsg[] ekk0891a010INcbsMsg1list = execEKK0891A010(handle, scCall, param, fixedText, tkHoshikiKeiNO);
			CAANMsg[] ekk0881a010INcbsMsg1list = null;
			String tonaiSpeedCD = null;
			String tkHoshikiPatternCD = null;
			String tkHoshikiCD = null;
			String accssKisnSpeedCD = null;
			String keiFormCD = null;
			
			if (ekk0891a010INcbsMsg1list != null && ekk0891a010INcbsMsg1list.length != 0)
			{
				String kaisenUseKeiNO = ekk0891a010INcbsMsg1list[0].getString(EKK0891A010CBSMsg1List.KAISEN_USE_KEI_NO);
				tkHoshikiPatternCD = ekk0891a010INcbsMsg1list[0].getString(EKK0891A010CBSMsg1List.TK_HOSHIKI_PATTERN_CD);
				tonaiSpeedCD = ekk0891a010INcbsMsg1list[0].getString(EKK0891A010CBSMsg1List.TONAI_SPEED_CD);
				tkHoshikiCD = ekk0891a010INcbsMsg1list[0].getString(EKK0891A010CBSMsg1List.TK_HOSHIKI_CD);
				accssKisnSpeedCD = ekk0891a010INcbsMsg1list[0].getString(EKK0891A010CBSMsg1List.ACCSS_KISN_SPEED_CD);
				keiFormCD = ekk0891a010INcbsMsg1list[0].getString(EKK0891A010CBSMsg1List.KANYU_KEI_PAY_HOSHIKI_CD);
				// 回線使用契約一意照会サービスIF実行
				ekk0881a010INcbsMsg1list = execEKK0881A010(handle, scCall, param, fixedText, kaisenUseKeiNO);
			}
			
			String mansionID = null;

			if (ekk0881a010INcbsMsg1list != null && ekk0881a010INcbsMsg1list.length != 0) {
				mansionID = ekk0881a010INcbsMsg1list[0].getString(EKK0881A010CBSMsg1List.MANSION_ID);
				String hhs1GOnlyFLG = ekk0881a010INcbsMsg1list[0].getString(EKK0881A010CBSMsg1List.HHS_1GONLY_FLG);
				
				// ※提供方式契約一意照会.提供方式パターンコードが"50"(ONU) かつ
				// 回線使用契約一意照会.光配線1Gのみフラグが"1"(対象)の場合は"52"(ONU(1Gのみ))を設定する
				if ("50".equals(tkHoshikiPatternCD) && "1".equals(hhs1GOnlyFLG))
				{
					tkHoshikiPatternCD = "52";
				}
			}
			
			// パターン設定
			String patternCD = getPatternSettings(mansionID, tkHoshikiPatternCD, tonaiSpeedCD, tkHoshikiCD, accssKisnSpeedCD, keiFormCD);
			
			ccMsg.put(TUSHIN_SPEED_CD, nullToStr(tonaiSpeedCD));
			ccMsg.put(TK_HOSHIKI_PATTERN_CD, nullToStr(tkHoshikiPatternCD));
			ccMsg.put(TK_HOSHIKI_NM, nullToStr(tkHoshikiCD));
			ccMsg.put(ACCSS_KISN_SPEED_CD, nullToStr(accssKisnSpeedCD));
			ccMsg.put(KEI_FORM_CD, nullToStr(keiFormCD));
			ccMsg.put(PATTERN, nullToStr(patternCD));
						
			// 正常終了
			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;
	}
	
	/**
	 * 単項目チェックを行い、チェック結果を返しま。
	 * <br>
	 * @param ccMsg
	 * @return チェックの判定
	 * @throws Exception
	 */
	private boolean checkUnitParam(Map<String, Object> ccMsg) throws Exception 
	{
		// エラーリスト
		List<Map<String, String>> errList = new ArrayList<Map<String, String>>();

		// --機能コード パラメータ名 --
		String itemName = SVC_KEI_NO;
		String itemValue = (String) ccMsg.get(itemName);
		/* 必須チェック */
		if (itemValue == null || itemValue.trim().isEmpty())
		{
			// 必須チェックエラー
			errList.add(getReqErrInfMap(itemName));
		} 
		/*  属性チェック */
		else if (!HalfCharCheck.isEnNumber1Check(itemValue))
		{
			// 属性チェックエラー
			errList.add(getFormErrInfMap(itemName, itemValue));
		} 
		/* 桁数チェック */
		else if (!LengthCheck.isLength1Check(itemValue, 10))
		{
			// 桁数チェックエラー
			errList.add(getLenErrInfMap(itemName, itemValue));
		}
		
		/* エラーが存在する場合 */
		if (errList.size() > 0)
		{
			ccMsg.put(ERROR_INFO, errList);
			return false;
		}

		return true;
	}
	
	/**
	 * 単関連チェックを行い、チェック結果を返します。
	 * <br>
	 * @param ccMsg
	 * @return チェックの判定
	 * @throws Exception
	 */
	private boolean checkUnitParamLink(CAANMsg[] ekk0081a010INcbsMsg1list, Map<String, Object> ccMsg) throws Exception 
	{
		// エラーリスト
		List<Map<String, String>> errList = new ArrayList<Map<String, String>>();
		Map<String, String> returnMap = new HashMap<String, String>();

		if (ekk0081a010INcbsMsg1list == null || ekk0081a010INcbsMsg1list.length == 0)
		{
			// 請求契約存在チェックエラーの場合は以下のエラーコードとエラーメッセージを設定する。
			returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_2001);
			returnMap.put(ERROR_MESSAGE, "");
			errList.add(returnMap);
			ccMsg.put(ERROR_INFO, errList);
		} else if (ekk0081a010INcbsMsg1list.length != 0)
		{
			String prcGrpCD = ekk0081a010INcbsMsg1list[0].getString(EKK0081A010CBSMsg1List.PRC_GRP_CD);
			String svcKeiStat = ekk0081a010INcbsMsg1list[0].getString(EKK0081A010CBSMsg1List.SVC_KEI_STAT);

			if (!JFUStrConst.CD00133_04.equals(prcGrpCD) && !JFUStrConst.CD00133_10.equals(prcGrpCD))
			{
				// 請求契約存在チェックエラーの場合は以下のエラーコードとエラーメッセージを設定する。
				returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_2001);
				returnMap.put(ERROR_MESSAGE, "");
				errList.add(returnMap);
				ccMsg.put(ERROR_INFO, errList);
			}
			
			if (JFUStrConst.CD00037_910.equals(svcKeiStat) || JFUStrConst.CD00037_920.equals(svcKeiStat))
			{
				// 請求契約存在チェックエラーの場合は以下のエラーコードとエラーメッセージを設定する。
				returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_2002);
				returnMap.put(ERROR_MESSAGE, "");
				errList.add(returnMap);
				ccMsg.put(ERROR_INFO, errList);
			}
		}
		
		/* エラーが存在する場合 */
		if (errList.size() > 0)
		{
			ccMsg.put(ERROR_INFO, errList);
			return false;
		}

		return true;
	}
	
	/**
	 * 単項目チェックの必須エラーマップ作成メソッドです。
	 * <br>
	 * @param itemName 項目名
	 * @return 必須エラーマップ
	 */
	private Map<String, String> getReqErrInfMap(String itemName)
	{
		Map<String, String> returnMap = new HashMap<String, String>();

		returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_1001);
		returnMap.put(ERROR_MESSAGE, itemName);

		return returnMap;
	}
	
	
	/**
	 * 単項目チェックの桁数エラーマップ作成メソッドです。
	 * <br>
	 * @param itemName 項目名
	 * @return 数エラーマップ
	 */
	private Map<String, String> getLenErrInfMap(String itemName, String itemValue)
	{
		Map<String, String> returnMap = new HashMap<String, String>();

		returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_1003);
		returnMap.put(ERROR_MESSAGE, String.format("%s:%s", itemName, itemValue));

		return returnMap;
	}
	
	
	/**
	 * 単項目チェックの属性エラーマップ作成メソッドです。
	 * <br>
	 * @param itemName 項目名
	 * @return 属性エラーマップ
	 */
	private Map<String, String> getFormErrInfMap(String itemName, String itemValue)
	{
		Map<String, String> returnMap = new HashMap<String, String>();

		// エラーメッセージ設定
		returnMap.put(ERROR_CODE, JKKStrConst.RETURN_CD_1002);
		returnMap.put(ERROR_MESSAGE, String.format("%s:%s", itemName, itemValue));

		return returnMap;
	}
	
	/**
	 * @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
	 * @param returnCode
	 * @param fixedText
	 * @param mappingData
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editErrorInfoCom(IRequestParameterReadWrite param,
														CAANMsg[] templates, 
														int returnCode,
														String fixedText,
														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(fixedText);
		
		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;
	}
	
	
	/**
	 * SC(サービスインターフェイス）を呼び出す。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param fixedText
	 * @param mappingData
	 * @return CAANMsg
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private CAANMsg callSC(SessionHandle handle, 
							ServiceComponentRequestInvoker scCall, 
							IRequestParameterReadWrite param, 
							String fixedText,
							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, fixedText, 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;
	}
	
	
	private String nullToStr(String str)
	{
		/* 項目名がnullかチェック */
		if (str == null)
		{
			str = EMPTY;
		}
		return str;
	}

	/**
	 * 
	 * サービス契約一意照会サービスIF実行。サービス契約一意照会サービスIFを行う。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param fixedText
	 * @param svcKeiNO
	 * @return CAANMsg[]
	 * @throws Exception
	 */
	private CAANMsg[] execEKK0081A010(SessionHandle handle, 
			ServiceComponentRequestInvoker scCall, 
			IRequestParameterReadWrite param, 
			String fixedText,
			String svcKeiNO) throws Exception {
		
		// サービス請求契約一意照会の上りマッピング
		Object[][] ekk0081a010IN =
		{
			{EKK0081A010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0081A010},
			{EKK0081A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_2},
			{EKK0081A010CBSMsg.KEY_SVC_KEI_NO, nullToStr(svcKeiNO)},
			{EKK0081A010CBSMsg.KEY_RSV_APLY_YMD, JFUBPCommon.getOpeDate(null)}
		};
		
		// サービスIF実行
		CAANMsg ekk0081a010CBSMsg = callSC(handle, scCall, param, fixedText, ekk0081a010IN);
		CAANMsg[] result = ekk0081a010CBSMsg.getCAANMsgList(EKK0081A010CBSMsg.EKK0081A010CBSMSG1LIST);
		
		return result;
	}
	
	/**
	 * 
	 * 提供方式契約一意照会サービスIF実行。提供方式契約一意照会サービスIFを行う。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param fixedText
	 * @param tkHoshikiKeiNO
	 * @return CAANMsg[]
	 * @throws Exception
	 */
	private CAANMsg[] execEKK0891A010(SessionHandle handle, 
			ServiceComponentRequestInvoker scCall, 
			IRequestParameterReadWrite param, 
			String fixedText,
			String tkHoshikiKeiNO) throws Exception {
		
		// サービス請求契約一意照会の上りマッピング
		Object[][] ekk0891a010IN =
		{
			{EKK0891A010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0891A010},
			{EKK0891A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
			{EKK0891A010CBSMsg.KEY_TK_HOSHIKI_KEI_NO, nullToStr(tkHoshikiKeiNO)},
		};
		
		// サービスIF実行
		CAANMsg ekk0891a010CBSMsg = callSC(handle, scCall, param, fixedText, ekk0891a010IN);
		CAANMsg[] result = ekk0891a010CBSMsg.getCAANMsgList(EKK0891A010CBSMsg.EKK0891A010CBSMSG1LIST);
		
		return result;
	}

	/**
	 * 
	 * 回線使用契約一意照会サービスIF実行。回線使用契約一意照会サービスIFを行う。
	 * 
	 * @param handle
	 * @param scCall
	 * @param param
	 * @param fixedText
	 * @param kaisenUseKeiNO
	 * @return CAANMsg[]
	 * @throws Exception
	 */
	private CAANMsg[] execEKK0881A010(SessionHandle handle, 
			ServiceComponentRequestInvoker scCall, 
			IRequestParameterReadWrite param, 
			String fixedText,
			String kaisenUseKeiNO) throws Exception {
		
		// サービス請求契約一意照会の上りマッピング
		Object[][] ekk0881a010IN =
		{
			{EKK0881A010CBSMsg.TEMPLATEID, TEMPLATE_ID_EKK0881A010},
			{EKK0881A010CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1},
			{EKK0881A010CBSMsg.KEY_KAISEN_USE_KEI_NO, nullToStr(kaisenUseKeiNO)},
		};
		
		// サービスIF実行
		CAANMsg ekk0881a010CBSMsg = callSC(handle, scCall, param, fixedText, ekk0881a010IN);
		CAANMsg[] result = ekk0881a010CBSMsg.getCAANMsgList(EKK0881A010CBSMsg.EKK0881A010CBSMSG1LIST);
		
		return result;
	}

	/**
	 * 
	 * パターン設定。パターン設定処理を行う。
	 * 
	 * @param mansionID
	 * @param tkHoshikiPatternCD
	 * @param tonaiSpeedCD
	 * @param tkHoshikiCD
	 * @param accssKisnSpeedCD
	 * @param keiFormCD
	 * @return HashMap
	 * @throws ParserConfigurationException
	 * @throws SAXException
	 * @throws IOException
	 */
	private String getPatternSettings(String mansionID, String tkHoshikiPatternCD, String tonaiSpeedCD, String tkHoshikiCD, String accssKisnSpeedCD, String keiFormCD) throws ParserConfigurationException, SAXException, IOException {

		String pattern = null;
		
		// XMLパース
		DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
		Document doc = builder.parse(new File(PLANCHG_XML_FILE));
		NodeList fuMansionPatternCodeDefinitionRootList = doc.getDocumentElement().getElementsByTagName(PATTERN_ROOT);

		for (int i = 0; i < fuMansionPatternCodeDefinitionRootList.getLength(); i++)
		{
			Element fuMansionPatternCodeDefinitionElement = (Element) fuMansionPatternCodeDefinitionRootList.item(i);
			String mansionIDXML = fuMansionPatternCodeDefinitionElement.getAttribute(PATTERN_ATTRS.MANSION_ID.name);
			
			if (!"OTHERS".equals(mansionIDXML) && isAttributeValueEquals(mansionIDXML, mansionID))
			{
				pattern = fuMansionPatternCodeDefinitionElement.getTextContent();
				break;
			}
		}
		
		if(pattern == null)
		{
			for (int i = 0; i < fuMansionPatternCodeDefinitionRootList.getLength(); i++)
			{
				Element fuMansionPatternCodeDefinitionElement = (Element) fuMansionPatternCodeDefinitionRootList.item(i);
				String mansionIDXML = fuMansionPatternCodeDefinitionElement.getAttribute(PATTERN_ATTRS.MANSION_ID.name);
			
				if ("OTHERS".equals(mansionIDXML))
				{
					String val = fuMansionPatternCodeDefinitionElement.getAttribute(PATTERN_ATTRS.TK_HOSHIKI_PATTERN_CD.name);
	
					if (isAttributeValueEquals(val, tkHoshikiPatternCD))
					{
						val = fuMansionPatternCodeDefinitionElement.getAttribute(PATTERN_ATTRS.TONAI_SPEED_CD.name);
	
						if (isAttributeValueEquals(val, tonaiSpeedCD))
						{
							val = fuMansionPatternCodeDefinitionElement.getAttribute(PATTERN_ATTRS.TK_HOSHIKI_CD.name);
							
							if (isAttributeValueEquals(val, tkHoshikiCD))
							{
								val = fuMansionPatternCodeDefinitionElement.getAttribute(PATTERN_ATTRS.ACCSS_KISN_SPEED_CD.name);
								
								if (isAttributeValueEquals(val, accssKisnSpeedCD))
								{
									val = fuMansionPatternCodeDefinitionElement.getAttribute(PATTERN_ATTRS.KANYU_KEI_PAY_HOSHIKI_CD.name);
									
									if (isAttributeValueEquals(val, keiFormCD))
									{
										pattern = fuMansionPatternCodeDefinitionElement.getTextContent();
										break;
									}
								}
							}
						}
					}
				}
			}
		}
		
		return pattern;
	}
	
	/**
	 * 
	 * @param attributeValue
	 * @param valueToSearch
	 * @return boolean
	 */
	private boolean isAttributeValueEquals(String attributeValue, String valueToSearch)
	{
		if (attributeValue == null || attributeValue.trim().isEmpty())
		{
			return true;
		}
		
		boolean isAttributeValueEquals = Arrays.asList(attributeValue.split(",")).contains(valueToSearch);
		
		return isAttributeValueEquals;
	}
}
