/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JKKGlobalIpAddCfmCCMapper
*   ソースファイル名：JKKGlobalIpAddCfmCCMapper.java
*   作成者          ：FJ
*   日付            ：2013年12月05日
*＜機能概要＞
*   割引解約新規作成部品
*＜修正履歴＞
*   バージョン  修正日      修正者      修正内容
*	v6.00.00	2013/12/05	FJ			新規作成
*  v25.00.00	2016/07/26	FJ)江藤		【OM-2016-0000890】認証IDが変わるコース変更の場合、旧認証IDに対して固定IPを払い出す対応
*  v25.01.00	2016/08/01  FJ)江藤		【OM-2016-0000890】認証IDが変わるコース変更の場合、一時金が2重で登録される不具合対応
*
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
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.parameter.IRequestParameterReadWrite;
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.ejb.common.JSYejbLog;

import eo.ejb.cbs.cbsmsg.ECK0011A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0011D020CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0011D020CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK0021C060CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0081A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0161B001CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0171A010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0321B002CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0361C010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0361C030CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0361C040CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK0361D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1081D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg1List;
import eo.ejb.cbs.cbsmsg.EKK1551D010CBSMsg;
import eo.ejb.common.JCCModelCommon;

/**
 * 
 * マッピングクラス
 * 
 * @author 富士通
 */
public class JKKGlobalIpAddCfmCCMapper {
	
	/** SC呼び出し部品 */
	private ServiceComponentRequestInvoker scCall = null;
	/** セッションハンドル */
	private SessionHandle handle = null;
	/** 業務データ取得用I/F */
	private IRequestParameterReadWrite param = null;
	/** オンライン運用日付 */
	private String opeDate = null;
	
	/** サービス契約内訳＜eo光ネット＞一意照会 */
	private String EKK0171A010 = "EKK0171A010";
	/** サービス契約一意照会 */
	private String EKK0081A010 = "EKK0081A010";
	/** お客様一意照会 */
	private String ECK0011A010 = "ECK0011A010";
	/** サービス契約内訳一覧照会 */
	private String EKK0161B001 = "EKK0161B001";
	
	/** 申込内容承認登録 */
	private String EKK0011D020 = "EKK0011D020";
	/** オプションサービス契約＜ISP＞登録 */
	private String EKK0361D010 = "EKK0361D010";
	/** オプションサービス契約＜ISP＞照査 */
	private String EKK0361C010 = "EKK0361C010";
	/** オプションサービス契約＜ISP＞締結済 */
	private String EKK0361C030 = "EKK0361C030";
	/** オプションサービス契約＜ISP＞開始 */
	private String EKK0361C040 = "EKK0361C040";
	/** 承認登録後続処理 */
	private String EKK0021C060 = "EKK0021C060";
	/** 進捗登録 */
	private String EKK1091D010 = "EKK1091D010";
	/** オーダ発行条件登録 */
	private String EKK1081D010 = "EKK1081D010";
	/** オーダ情報作成ワーク登録 */
	private String EKK1551D010 = "EKK1551D010";
	/** 課金先一覧照会 */
	private String EKK0321B002 = "EKK0321B002";
	
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>コンストラクタ<br>
	 * <dt>処理補足：
	 * <dd>フィールド変数の値を設定する<br>
	 * </dl>
	 * 
	 * @param iCmnHandle セッションハンドル
	 * @param iCmnParam 業務データ取得用I/F
	 * @param iOpeDate オンライン運用日付
	 */
	public JKKGlobalIpAddCfmCCMapper(SessionHandle iCmnHandle,
										IRequestParameterReadWrite iCmnParam,
										String iOpeDate) {
		this.handle  = iCmnHandle;
		this.param   = iCmnParam;
		this.opeDate = iOpeDate;
		this.scCall  = new ServiceComponentRequestInvoker();
	}

	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>デバッグログを出力する<br>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param dumpObj 出力するオブジェクト
	 */
	@SuppressWarnings("static-access")
	private void printlnEjbLog(Object dumpObj) {
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), dumpObj, null, null, null);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>持ちうるフィールドにNullマッピングで埋める<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param msg 対象クラス
	 * @param contents 対応クラスのフィールド列挙
	 */
	private void fillCAANMSGNullMapping(CAANMsg msg, Object[][] contents) {
		
		// 要素ごとのループ
		for (int i = 0; i < contents.length; i++) {

			Object element = null;

			// キーに該当する箇所の取得
			element = contents[i][0];
			// Nullでマッピング
			msg.setNull((String) element);
		}
	}

	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>S/IF呼出時の共通情報を設定する<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param template 条件の設定先
	 * @throws Throwable
	 */
	private void templateCommonInfo(CAANMsg template) throws Throwable {
		
		// オペレータID
		Object operatorId = this.param.getControlMapData(SCControlMapKeys.OPERATOR_ID);
		template.set(JCMConstants.OPERATOR_ID_KEY, operatorId);

		// 運用日付
		Object operateDate = this.param.getControlMapData(SCControlMapKeys.OPE_DATE);
		template.set(JCMConstants.OPERATE_DATE_KEY, operateDate);

		// 運用日時
		Object operateDateTime = this.param.getControlMapData(SCControlMapKeys.OPE_TIME);
		template.set(JCMConstants.OPERATE_DATETIME_KEY, operateDateTime);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>SCインプット共通データ設定処理です。<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param inMap
	 * @return パラメータマップ
	 * @throws Throwable
	 */
	private HashMap<String, Object> setSCInputCommonData(HashMap<String, Object> inMap) throws Throwable {
		
		/* SCインプット共通データ */
		// **********************************************
		// 【取得元：電文ヘッダ(ヘッダ)】
		// **********************************************
		// 電文ID
		inMap.put(JCMConstants.TRANZACTION_ID_KEY, this.param.getTelegramID());
		// ユースケースID
		inMap.put(JCMConstants.USECASE_ID_KEY, this.param.getUsecaseID());
		// オペレーションID
		inMap.put(JCMConstants.OPERATION_ID_KEY, this.param.getOperationID());
		// サービス呼び出し区分
		inMap.put(JCMConstants.CALL_TYPE_KEY, this.param.getCallType());

		// **********************************************
		// 【取得元：ユーザエリア(コントロールマップ)】
		// **********************************************
		// 依頼先ホスト名
		inMap.put(JCMConstants.CLIENT_HOST_NAME_KEY, this.param.getControlMapData(SCControlMapKeys.REQ_HOSTNAME));
		// 依頼元IPアドレス
		inMap.put(JCMConstants.CLIENT_IP_ADDRESS_KEY, this.param.getControlMapData(SCControlMapKeys.REQ_HOSTIP));
		// 依頼元画面ID
		inMap.put(JCMConstants.INVOKE_GAMEN_ID_KEY, this.param.getControlMapData(SCControlMapKeys.REQ_VIEWID));
		// オペレータID
		inMap.put(JCMConstants.OPERATOR_ID_KEY, this.param.getControlMapData(SCControlMapKeys.OPERATOR_ID));

		return inMap;
	}

	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>呼び出したサービスIFの処理結果を判定する.<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param result
	 * @throws Throwable
	 */
	@SuppressWarnings("boxing")
	private void checkExecutionResult(Map<?, ?> result) throws Throwable {
		
		// 取得したリターンコード、ステータスの内容を見て異常かどうかの判断をする。
		String rtnCode = result.get(JCMConstants.RET_CD_INT_KEY).toString();
		CAANMsg[] templates = (CAANMsg[])result.get(JCMConstants.TEMPLATE_LIST_KEY);
		Integer status = templates[0].getInt(JCMConstants.STATUS_INT_KEY);
		
		// 異常の場合、SCCallExceptionを生成してスローする
		if (!("0".equals(rtnCode) && 0 == status.intValue()))
		{
			SCCallException scCallEx = new SCCallException("戻り値不正", rtnCode, status);
			throw scCallEx;
		}
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービスIFの結果を取得する<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param rsltMap サービスIFリスト
	 * @return templateList 結果が格納されたリスト
	 * @throws Throwable 
	 */
	private ArrayList<CAANMsg> getRsltList(Map<?, ?> rsltMap) {
		
		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[])rsltMap.get(JCMConstants.TEMPLATE_LIST_KEY);
		ArrayList<CAANMsg> resultList = new ArrayList<CAANMsg>(Arrays.asList(templates));
		return resultList;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービスコンポーネント実行後に、IRequestParameterReadWriteに必要なデータをマッピングする<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param   msgList 
	 * @param   param 
	 * @param   mapName
	 * @return 
	 * @throws Throwable 
	 */
	@SuppressWarnings({ "unchecked", "cast", "boxing" })
	public IRequestParameterReadWrite editResultRP(Map<?, ?> msgList,
													@SuppressWarnings("hiding") IRequestParameterReadWrite param,
													String mapName) throws Throwable {
		
		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[]) msgList.get(JCMConstants.TEMPLATE_LIST_KEY);

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);
		
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		
		// 結果を詰めるマップを取得。
		HashMap dataMap = null;

		/* 業務データ設定 */
		dataMap = (HashMap)param.getData(mapName);
		if (dataMap == null) {
			dataMap = new HashMap();
			param.setData(mapName, dataMap);
		}

		// エラー情報の設定
		param = editErrorInfo(param, templates, (Integer)return_code, mapName);

		//エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>)param.getControlMapData(SCControlMapKeys.ERROR_INFO);
		if (errList == null)
		{
			errList = new ArrayList<Object>();
		}
		// コントロールマップに設定
		param.setControlMapData(SCControlMapKeys.ERROR_INFO, TemplateErrorUtil.getErrorInfo(msgList, errList));

		return param;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービス契約内訳＜eo光ネット＞一意照会サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd
	 * @param  svcKeiNo
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg[] callEKK0171A010(String funcCd, String svcKeiNo) throws Throwable {
		
		printlnEjbLog("callEKK0171A010 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// サービス契約内訳＜eo光ネット＞一意照会サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0171A010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0171A010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0171A010CBSMsg.TEMPLATEID, this.EKK0171A010);
		// 機能コード
		template.set(EKK0171A010CBSMsg.FUNC_CODE, funcCd);

		// サービス契約内訳
		template.set(EKK0171A010CBSMsg.KEY_SVC_KEI_UCWK_NO, svcKeiNo);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0171A010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0171List = getRsltList(result);
		
		CAANMsg kk0171 = kk0171List.get(0);
		CAANMsg[] ret  = kk0171.getCAANMsgList(EKK0171A010CBSMsg.EKK0171A010CBSMSG1LIST);
		
		printlnEjbLog("callEKK0171A010 end");
		return ret;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービス契約一意照会サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd
	 * @param  svcKeiNo
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg[] callEKK0081A010(String funcCd, String svcKeiNo) throws Throwable {
		
		printlnEjbLog("callEKK0081A010 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// サービス契約一意照会サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0081A010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0081A010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0081A010CBSMsg.TEMPLATEID, this.EKK0081A010);
		// 機能コード
		template.set(EKK0081A010CBSMsg.FUNC_CODE, funcCd);

		// 割引サービス契約番号
		template.set(EKK0081A010CBSMsg.KEY_SVC_KEI_NO, svcKeiNo);
		// 予約適用年月日
		template.set(EKK0081A010CBSMsg.KEY_RSV_APLY_YMD, this.opeDate);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0081A010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0081List = getRsltList(result);
		
		CAANMsg kk0081 = kk0081List.get(0);
		CAANMsg[] ret  = kk0081.getCAANMsgList(EKK0081A010CBSMsg.EKK0081A010CBSMSG1LIST);
		
		printlnEjbLog("callEKK0081A010 end");
		return ret;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>お客様一意照会サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd
	 * @param  sysid
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg[] callECK0011A010(String funcCd, String sysid) throws Throwable {
		
		printlnEjbLog("callECK0011A010 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// お客様一意照会サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(ECK0011A010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new ECK0011A010CBSMsg().getContents());

		// テンプレートID
		template.set(ECK0011A010CBSMsg.TEMPLATEID, this.ECK0011A010);
		// 機能コード
		template.set(ECK0011A010CBSMsg.FUNC_CODE, funcCd);

		// 割引サービス契約番号
		template.set(ECK0011A010CBSMsg.KEY_SYSID, sysid);
		// 予約適用年月日
		template.set(ECK0011A010CBSMsg.KEY_RSV_APLY_YMD, this.opeDate);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.ECK0011A010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0081List = getRsltList(result);
		
		CAANMsg kk0081 = kk0081List.get(0);
		CAANMsg[] ret  = kk0081.getCAANMsgList(ECK0011A010CBSMsg.ECK0011A010CBSMSG1LIST);
		
		printlnEjbLog("callECK0011A010 end");
		return ret;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>申込内容承認登録サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @return 
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public CAANMsg callEKK0011D020(String funcCd, Map<String, Object> ccMapWork) throws Throwable {
		
		printlnEjbLog("callEKK0011D020 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 申込内容承認登録サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0011D020CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0011D020CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0011D020CBSMsg.TEMPLATEID, this.EKK0011D020);
		// 機能コード
		template.set(EKK0011D020CBSMsg.FUNC_CODE, funcCd);
		
		// SYSID
		template.set(EKK0011D020CBSMsg.SYSID, ccMapWork.get("key_sysid"));
		// 申込種別コード
		template.set(EKK0011D020CBSMsg.MSKM_SBT_CD, ccMapWork.get("mskm_sbt_cd"));
		// 運用年月日時分秒
		template.set(EKK0011D020CBSMsg.MSKM_YMD, ccMapWork.get("key_rsv_aply_ymd"));
		// 運用年月日
		template.set(EKK0011D020CBSMsg.MSKM_UK_DTM, ccMapWork.get("mskm_uk_dtm"));
		// 営業用申込状態識別コード
		template.set(EKK0011D020CBSMsg.CONSMBSN_MSKM_STAT_SKBT_CD, ccMapWork.get("consmbsn_mskm_stat_skbt_cd"));
		
		// 申込内容承認登録明細
		ArrayList<HashMap> kk0011List = (ArrayList<HashMap>) ccMapWork.get("EKK0011D020CBSMsg1List");
		
		CAANMsg[] templateArray = template.getCAANMsgList(EKK0011D020CBSMsg.EKK0011D020CBSMSG1LIST);
		
		if (templateArray == null) 
			templateArray = new CAANMsg[kk0011List.size()];
		
		int i = 0;
		for (HashMap map : kk0011List) {
			
			CAANMsg childTemplate = templateArray[i];
			
			if (childTemplate == null) 
				childTemplate = new CAANMsg(EKK0011D020CBSMsg1List.class.getName());
			
			// 申込形態コード
			childTemplate.set(EKK0011D020CBSMsg1List.MSKM_FORM_CD, map.get("mskm_form_cd"));
			// 申込明細種別コード
			childTemplate.set(EKK0011D020CBSMsg1List.MSKM_DTL_SBT_CD, map.get("mskm_dtl_sbt_cd"));
			
			// 申込経路コードは,現状未設定
			
			templateArray[i] = childTemplate;
			i++;
		}
		
		// 申込内容承認登録明細
		template.set(EKK0011D020CBSMsg.EKK0011D020CBSMSG1LIST, templateArray);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0011D020);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> retKk0011List = getRsltList(result);
		
		printlnEjbLog("callEKK0011D020 end");
		return retKk0011List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>オプションサービス契約＜ISP＞登録サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  svcKeiUcwkNo
	 * @param  kk0081Dtm
	 * @param  seikyKeiNo
	 * @param  mskmDtlNo
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK0361D010(String funcCd,
									Map<String, Object> ccMapWork,
									String svcKeiUcwkNo,
									String kk0081Dtm,
									String seikyKeiNo,
									String mskmDtlNo) throws Throwable {
		
		printlnEjbLog("callEKK0361D010 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// オプションサービス契約＜ISP＞登録サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0361D010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0361D010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0361D010CBSMsg.TEMPLATEID, this.EKK0361D010);
		// 機能コード
		template.set(EKK0361D010CBSMsg.FUNC_CODE, funcCd);
		
		// オプションサービスコード
		template.set(EKK0361D010CBSMsg.OP_SVC_CD, ccMapWork.get("op_svc_cd"));
		// 料金コースコード
		template.set(EKK0361D010CBSMsg.PCRS_CD, ccMapWork.get("pcrs_cd"));
		// 料金プランコード
		template.set(EKK0361D010CBSMsg.PPLAN_CD, ccMapWork.get("pplan_cd"));
		// 親契約識別コード
		template.set(EKK0361D010CBSMsg.OYA_KEI_SKBT_CD, ccMapWork.get("oya_kei_skbt_cd"));
		// サービス契約番号
		template.set(EKK0361D010CBSMsg.SVC_KEI_NO, ccMapWork.get("key_svc_kei_no"));
		// サービス契約内訳番号
		template.set(EKK0361D010CBSMsg.SVC_KEI_UCWK_NO, svcKeiUcwkNo);
		// SYSID
		template.set(EKK0361D010CBSMsg.SYSID, ccMapWork.get("key_sysid"));
		// 利用開始年月日
		template.set(EKK0361D010CBSMsg.SVC_USE_STA_KIBO_YMD, ccMapWork.get("svc_use_sta_kibo_ymd"));
		// 異動区分ido_div
		template.set(EKK0361D010CBSMsg.IDO_DIV, ccMapWork.get("ido_div"));
		// 固定IPアドレス
		// OM-2016-0000890 ワークの固定IPアドレスを設定するよう変更 2016/08/01 MOD START
//		template.set(EKK0361D010CBSMsg.KOTEI_IP_AD, ccMapWork.get("kotei_ip_ad"));
		template.set(EKK0361D010CBSMsg.KOTEI_IP_AD, ccMapWork.get("wk_kotei_ip_ad"));
		// OM-2016-0000890 ワークの固定IPアドレスを設定するよう変更 2016/08/01 MOD END
		// サブネットマスク
		// OM-2016-0000890 ワークの固定IPアドレスを設定するよう変更 2016/08/01 MOD START
//		template.set(EKK0361D010CBSMsg.NETMASK, ccMapWork.get("netmask"));
		template.set(EKK0361D010CBSMsg.NETMASK, ccMapWork.get("wk_netmask"));
		// OM-2016-0000890 ワークの固定IPアドレスを設定するよう変更 2016/08/01 MOD END
		// 請求契約番号
		template.set(EKK0361D010CBSMsg.SEIKY_KEI_NO, seikyKeiNo);
		// 更新年月日（前）
		template.set(EKK0361D010CBSMsg.UPD_DTM_BF, kk0081Dtm);
		// 申込明細番号
		template.set(EKK0361D010CBSMsg.MSKM_DTL_NO, mskmDtlNo);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0361D010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0361List = getRsltList(result);
		
		printlnEjbLog("callEKK0361D010 end");
		return kk0361List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービス契約内訳一覧照会サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  svcKeiNo
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg[] callEKK0161B001(String funcCd, String svcKeiNo) throws Throwable {
		
		printlnEjbLog("callEKK0161B001 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// サービス契約内訳一覧照会サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0161B001CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0161B001CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0161B001CBSMsg.TEMPLATEID, this.EKK0161B001);
		// 機能コード
		template.set(EKK0161B001CBSMsg.FUNC_CODE, funcCd);
		
		// サービス契約番号
		template.set(EKK0161B001CBSMsg.KEY_SVC_KEI_NO, svcKeiNo);

		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0161B001);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0161List = getRsltList(result);
		
		CAANMsg kk0161 = kk0161List.get(0);
		CAANMsg[] ret  = kk0161.getCAANMsgList(EKK0161B001CBSMsg.EKK0161B001CBSMSG1LIST);
		
		printlnEjbLog("callEKK0161B001 end");
		return ret;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>課金先一覧照会サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  svcKeiNo
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg[] callEKK0321B002(String funcCd, String svcKeiNo) throws Throwable {
		
		printlnEjbLog("callEKK0321B002 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 課金先一覧照会サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0321B002CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0321B002CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0321B002CBSMsg.TEMPLATEID, this.EKK0321B002);
		// 機能コード
		template.set(EKK0321B002CBSMsg.FUNC_CODE, funcCd);
		
		// サービス契約番号
		template.set(EKK0321B002CBSMsg.KEY_SVC_KEI_NO, svcKeiNo);

		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0321B002);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0321List = getRsltList(result);
		
		CAANMsg kk0321 = kk0321List.get(0);
		CAANMsg[] ret  = kk0321.getCAANMsgList(EKK0321B002CBSMsg.EKK0321B002CBSMSG1LIST);
		
		printlnEjbLog("callEKK0321B002 end");
		return ret;
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>オプションサービス契約＜ISP＞照査サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  opSvcKeiNo
	 * @param  dtm
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK0361C010(String funcCd, Map<String, Object> ccMapWork, String opSvcKeiNo, String dtm) throws Throwable {
		
		printlnEjbLog("callEKK0361C010 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// オプションサービス契約＜ISP＞照査サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0361C010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0361C010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0361C010CBSMsg.TEMPLATEID, this.EKK0361C010);
		// 機能コード
		template.set(EKK0361C010CBSMsg.FUNC_CODE, funcCd);
		
		// オプションサービス契約番号
		template.set(EKK0361C010CBSMsg.OP_SVC_KEI_NO, opSvcKeiNo);
		// 異動区分
		template.set(EKK0361C010CBSMsg.IDO_DIV, ccMapWork.get("ido_div"));
		// 更新年月日時分秒(更新前)
		template.set(EKK0361C010CBSMsg.UPD_DTM_BF, dtm);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0361C010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0361List = getRsltList(result);
		
		printlnEjbLog("callEKK0361C010 end");
		return kk0361List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>オプションサービス契約＜ISP＞締結済サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  opSvcKeiNo
	 * @param  dtm
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK0361C030(String funcCd, Map<String, Object> ccMapWork, String opSvcKeiNo, String dtm) throws Throwable {
		
		printlnEjbLog("callEKK0361C030 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// オプションサービス契約＜ISP＞締結済サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0361C030CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0361C030CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0361C030CBSMsg.TEMPLATEID, this.EKK0361C030);
		// 機能コード
		template.set(EKK0361C030CBSMsg.FUNC_CODE, funcCd);
		
		// オプションサービス契約番号
		template.set(EKK0361C030CBSMsg.OP_SVC_KEI_NO, opSvcKeiNo);
		// 異動区分
		template.set(EKK0361C030CBSMsg.IDO_DIV, ccMapWork.get("ido_div"));
		// 更新年月日時分秒(更新前)
		template.set(EKK0361C030CBSMsg.UPD_DTM_BF, dtm);
		// OM-2016-0000890 コース変更中の新認証側の場合、一時金を登録しないよう修正 2016/08/01 MOD START
		// 事務手数料自動適用要否
//		template.set(EKK0361C030CBSMsg.RULE0059_AUTO_APLY, ccMapWork.get("rule0059_auto_aply"));
		template.set(EKK0361C030CBSMsg.RULE0059_AUTO_APLY, ccMapWork.get("wk_rule0059_auto_aply"));
		// OM-2016-0000890 コース変更中の新認証側の場合、一時金を登録しないよう修正 2016/08/01 MOD END
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0361C030);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0361List = getRsltList(result);
		
		printlnEjbLog("callEKK0361C030 end");
		return kk0361List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>オプションサービス契約＜ISP＞開始サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  opSvcKeiNo
	 * @param  dtm
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK0361C040(String funcCd, Map<String, Object> ccMapWork, String opSvcKeiNo, String dtm) throws Throwable {
		printlnEjbLog("callEKK0361C040 start");
		
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// オプションサービス契約＜ISP＞開始サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0361C040CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0361C040CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0361C040CBSMsg.TEMPLATEID, this.EKK0361C040);
		// 機能コード
		template.set(EKK0361C040CBSMsg.FUNC_CODE, funcCd);
		
		// オプションサービス契約番号
		template.set(EKK0361C040CBSMsg.OP_SVC_KEI_NO, opSvcKeiNo);
		// サービス開始年月日
		template.set(EKK0361C040CBSMsg.SVC_STAYMD, ccMapWork.get("use_stat_ymd"));
		// サービス課金開始年月日
		template.set(EKK0361C040CBSMsg.SVC_CHRG_STAYMD, ccMapWork.get("svc_chrg_staymd"));
		// 固定IPアドレス
		// OM-2016-0000890 ワークの固定IPアドレスを設定するよう変更 2016/08/01 MOD START
//		template.set(EKK0361C040CBSMsg.KOTEI_IP_AD, ccMapWork.get("kotei_ip_ad"));
		template.set(EKK0361C040CBSMsg.KOTEI_IP_AD, ccMapWork.get("wk_kotei_ip_ad"));
		// OM-2016-0000890 ワークの固定IPアドレスを設定するよう変更 2016/08/01 MOD END
		// サブネットマスク
		// OM-2016-0000890 ワークの固定IPアドレスを設定するよう変更 2016/08/01 MOD START
//		template.set(EKK0361C040CBSMsg.NETMASK, ccMapWork.get("netmask"));
		template.set(EKK0361C040CBSMsg.NETMASK, ccMapWork.get("wk_netmask"));
		// OM-2016-0000890 ワークの固定IPアドレスを設定するよう変更 2016/08/01 MOD END
		// 異動区分
		template.set(EKK0361C040CBSMsg.IDO_DIV, ccMapWork.get("ido_div"));
		// 更新年月日時分秒(更新前)
		template.set(EKK0361C040CBSMsg.UPD_DTM_BF, dtm);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0361C040);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0361List = getRsltList(result);
		
		printlnEjbLog("callEKK0361C040 end");
		return kk0361List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>承認登録後続処理サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  mskmDtlNo
	 * @param  dtm
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK0021C060(String funcCd, Map<String, Object> ccMapWork, String mskmDtlNo, String dtm) throws Throwable {
		
		printlnEjbLog("callEKK0021C060 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 承認登録後続処理サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK0021C060CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK0021C060CBSMsg().getContents());

		// テンプレートID
		template.set(EKK0021C060CBSMsg.TEMPLATEID, this.EKK0021C060);
		// 機能コード
		template.set(EKK0021C060CBSMsg.FUNC_CODE, funcCd);
		
		// 後続依頼年月日時分秒
		template.set(EKK0021C060CBSMsg.KZKWRK_REQYMD, ccMapWork.get("key_rsv_aply_ymd"));
		// 異動区分
		template.set(EKK0021C060CBSMsg.IDO_DIV, ccMapWork.get("ido_div"));
		// 更新年月日時分秒（更新前）
		template.set(EKK0021C060CBSMsg.UPD_DTM_BF, dtm);
		
		// 申込明細番号
		template.set(EKK0021C060CBSMsg.MSKM_DTL_NO, mskmDtlNo);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK0021C060);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk0011List = getRsltList(result);
		
		printlnEjbLog("callEKK0021C060 end");
		return kk0011List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>進捗登録サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  mskmDtlNo
	 * @param  svcKeiUcwkNo
	 * @param  opSvcKeiNo
	 * @return 
	 * @throws Throwable
	 */
	@SuppressWarnings("unchecked")
	public CAANMsg callEKK1091D010(String funcCd, Map<String, Object> ccMapWork, String mskmDtlNo, String svcKeiUcwkNo, String opSvcKeiNo) throws Throwable {
		
		printlnEjbLog("callEKK1091D010 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// 進捗登録サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK1091D010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK1091D010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK1091D010CBSMsg.TEMPLATEID, this.EKK1091D010);
		// 機能コード
		template.set(EKK1091D010CBSMsg.FUNC_CODE, funcCd);
		
		// 申込明細番号
		template.set(EKK1091D010CBSMsg.MSKM_DTL_NO, mskmDtlNo);
		// オプションサービスコード
		template.set(EKK1091D010CBSMsg.OP_SVC_KEI_NO, opSvcKeiNo);
		// サービス契約番号
		template.set(EKK1091D010CBSMsg.SVC_KEI_NO, ccMapWork.get("key_svc_kei_no"));
		// サービス内訳契約番号
		template.set(EKK1091D010CBSMsg.SVC_KEI_UCWK_NO, svcKeiUcwkNo);
		// サービス契約回線内訳番号
		template.set(EKK1091D010CBSMsg.SVC_KEI_KAISEN_UCWK_NO, ccMapWork.get("svc_kei_kaisen_ucwk_no"));
		// 進捗ステータス
		template.set(EKK1091D010CBSMsg.PRG_STAT, ccMapWork.get("prg_stat"));
		// 進捗特記事項１
		template.set(EKK1091D010CBSMsg.PRG_TKJK_1, ccMapWork.get("prg_tkjk_1"));
		// 異動区分
		template.set(EKK1091D010CBSMsg.IDO_DIV, ccMapWork.get("ido_div"));
		//異動年月日時分秒
		template.set(EKK1091D010CBSMsg.IDO_DTM, JCCModelCommon.getSysDateTimeStamp());
		
		// 異動理由明細
		ArrayList<HashMap> kk1091SetList = (ArrayList<HashMap>) ccMapWork.get("EKK1091D010CBSMsg1List");
		
		CAANMsg[] templateArray = template.getCAANMsgList(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST);
		
		if (templateArray == null) 
			templateArray = new CAANMsg[kk1091SetList.size()];
		
		int i = 0;
		for (HashMap map : kk1091SetList) {
			
			CAANMsg childTemplate = templateArray[i];
			
			if (childTemplate == null) 
				childTemplate = new CAANMsg(EKK1091D010CBSMsg1List.class.getName());
			
			// 異動理由コード
			childTemplate.set(EKK1091D010CBSMsg1List.IDO_RSN_CD, map.get("ido_rsn_cd"));
			// 異動理由メモ
			childTemplate.set(EKK1091D010CBSMsg1List.IDO_RSN_MEMO, map.get("ido_rsn_memo"));
			
			templateArray[i] = childTemplate;
			i++;
		}
		
		// 進捗明細
		template.set(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST, templateArray);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK1091D010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk1091List = getRsltList(result);
		
		printlnEjbLog("callEKK1091D010 end");
		return kk1091List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>オーダ発行条件登録サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK1081D010(String funcCd, Map<String, Object> ccMapWork) throws Throwable {
		printlnEjbLog("callEKK1081D010 start");
		
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// オーダ発行条件登録サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK1081D010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK1081D010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK1081D010CBSMsg.TEMPLATEID, this.EKK1081D010);
		// 機能コード
		template.set(EKK1081D010CBSMsg.FUNC_CODE, funcCd);
		
		// サービス契約番号
		template.set(EKK1081D010CBSMsg.SVC_KEI_NO, ccMapWork.get("key_svc_kei_no"));
		// オーダ種別コード
		template.set(EKK1081D010CBSMsg.ORDER_SBT_CD, "1");
		// サービスオーダコード
		template.set(EKK1081D010CBSMsg.SVC_ORDER_CD, "06");
		// 要求種別コード
		template.set(EKK1081D010CBSMsg.YOKYU_SBT_CD, "04");
		// オーダ発行条件コード
		template.set(EKK1081D010CBSMsg.ODR_HAKKO_JOKEN_CD, "01");
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK1081D010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk1091List = getRsltList(result);
		
		printlnEjbLog("callEKK1081D010 end");
		return kk1091List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>オーダ情報作成ワーク登録サービスIFを呼び出す<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param  funcCd 
	 * @param  ccMapWork
	 * @param  odrjokenNo
	 * @param  svcDtm
	 * @param  opSvcKeiNo
	 * @param  opDtm
	 * @param  svcKeiUcwkNo
	 * @param  svcKeiUcwkGeneDtm
	 * @return 
	 * @throws Throwable
	 */
	public CAANMsg callEKK1551D010(String funcCd,
									Map<String, Object> ccMapWork,
									String odrjokenNo,
									String svcDtm,
									String opSvcKeiNo,
									String opDtm,
									String svcKeiUcwkNo,
									String svcKeiUcwkGeneDtm) throws Throwable {
		
		printlnEjbLog("callEKK1551D010 start");
		/* --------------------------------------------------
		 * CC項目 -> SC項目 上りマッピング
		 * -------------------------------------------------- */
		HashMap<String, Object> inMap = new HashMap<String, Object>();

		// オーダ情報作成ワーク登録サービスインターフェイスを作成
		CAANMsg template = new CAANMsg(EKK1551D010CBSMsg.class.getName());

		// nullを設定
		fillCAANMSGNullMapping(template, new EKK1551D010CBSMsg().getContents());

		// テンプレートID
		template.set(EKK1551D010CBSMsg.TEMPLATEID, this.EKK1551D010);
		// 機能コード
		template.set(EKK1551D010CBSMsg.FUNC_CODE, funcCd);
		
		// オーダ発行条件番号
		template.set(EKK1551D010CBSMsg.ODR_HAKKO_JOKEN_NO, odrjokenNo);
		// サービス契約世代登録年月日時分秒
		template.set(EKK1551D010CBSMsg.SVKEI_GADTM, svcDtm);
		// オプションサービス契約番号
		template.set(EKK1551D010CBSMsg.OP_SVC_KEI_NO, opSvcKeiNo);
		// オプションサービス契約世代登録年月日時分秒
		template.set(EKK1551D010CBSMsg.OPSVKEI_GADTM, opDtm);

		// オーダ内容コード
		template.set(EKK1551D010CBSMsg.ODR_NAIYO_CD, "152");
		// サービス契約番号
		template.set(EKK1551D010CBSMsg.SVC_KEI_NO, ccMapWork.get("key_svc_kei_no"));
		// サービス契約内訳番号
		template.set(EKK1551D010CBSMsg.SVC_KEI_UCWK_NO, svcKeiUcwkNo);
		// サービス契約内訳世代登録年月日時分秒
		template.set(EKK1551D010CBSMsg.SVKEIUW_GADTM, svcKeiUcwkGeneDtm);
		
		// 共通情報設定処理
		templateCommonInfo(template);
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		inMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// SCインプット共通データ設定処理
		setSCInputCommonData(inMap);
		
		printlnEjbLog("inMap="  + inMap.toString());
		printlnEjbLog("handle=" + this.handle.toString());
		
		/* --------------------------------------------------
		 * サービスIF実行
		 * -------------------------------------------------- */
		Map<?, ?> result = this.scCall.run(inMap, this.handle);
		
        // エラー情報の設定
		this.param = editResultRP(result, this.param, this.EKK1551D010);
		
		checkExecutionResult(result);
		
		/* --------------------------------------------------
		 * CC項目 <- SC項目 下りマッピング
		 * -------------------------------------------------- */
		// 結果をリストで取得
		ArrayList<CAANMsg> kk1091List = getRsltList(result);
		
		printlnEjbLog("callEKK1551D010 end");
		return kk1091List.get(0);
	}
	
	/**
	 * 
	 * <dl>
	 * <dt>処理概要：
	 * <dd>サービスコンポーネント実行後に、IRequestParameterReadWriteにエラー情報をマッピングする<BR>
	 * <dt>処理補足：
	 * <dd>
	 * </dl>
	 * 
	 * @param param      業務データ取得・書込用I/F
	 * @param templates  CAANMsgクラス配列
	 * @param returnCode リターンコード
	 * @param mapName    SCマップ名
	 * 
	 * @return 業務データ取得・書込用I/F
	 */
	@SuppressWarnings({ "unchecked", "cast", "boxing", "null" })
	public IRequestParameterReadWrite editErrorInfo(@SuppressWarnings("hiding") IRequestParameterReadWrite param,
													 CAANMsg[] templates,
													 int returnCode,
													 String mapName) throws Throwable {
		int templateStatus = 0;
		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 (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 inMap = null;
		
		// 作業項目領域
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null) {
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		
		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData(mapName);
		if (inMap == null) {
			inMap = new HashMap();
			param.setData(mapName, inMap);
		}

		String svcIf = null;
		if (svcIf == null) {
			return param;
			
		}
		
		return param;
	}
}
