/*********************************************************************
 *	All Rights reserved,Copyright (c) K-Opticom
 **********************************************************************
 *＜プログラム内容＞
 *   システム名      ：eo顧客基幹システム
 *   モジュール名    ：JCHSaikenSyokyakuAddCC
 *   ソースファイル名：JCHSaikenSyokyakuAddCC.java
 *   作成者          ：富士通
 *   日付            ：2012年07月09日
 *＜機能概要＞
 *   債権償却登CC部品です。
 *＜修正履歴＞
 *	バージョン	修正日		修正者		修正内容
 *	v1.00.00	2011/09/09	富士通		新規作成
 *
 **********************************************************************/
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.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 eo.common.util.JCRUtilCommon;
import eo.ejb.cbs.cbsmsg.ECH0011C014CBSMsg;
import eo.ejb.cbs.cbsmsg.ECH0011C014CBSMsg1List;

/**
 * 債権償却登CC部品です。
 * <p>
 * <BR>
 * 
 * @author 富士通
 */
public class JCHSaikenSyokyakuAddCC extends AbstractCommonComponent {

	/** テンプレートID(会計異動登録) */
	private static final String TEMPLATE_ID_ECH0011C014 = "ECH0011C014";

	/** 債権償却登録マップID */
	private static final String MAP_SAIKENSYOKYAKUADDCC = "SAIKENSYOKYAKUADDCC";
	
	/** 債権会計異動情報マップ */
	private static final String MAP_SAIKENKAIKIDOINFOCC = "SAIKENKAIKIDOINFOCC";

	/**
	 * 債権償却登録処理チェック処理.<br>
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException RequestParameterException
	 */
	public HashMap<String, Object> getInvokeCBS(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws RequestParameterException 
	{
		// 共通領域の設定
		HashMap<String, Object> paramMap = editInMsg(param);

		HashMap<String, Object> resultMap = null;
		CAANMsg[] templates = null;
		List<CAANMsg> list = new ArrayList<CAANMsg>();
		
		// 入力データ情報
		HashMap<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_SAIKENSYOKYAKUADDCC);

		// 機能コード
		String funcCode = inMap.get(JCMConstants.FUNC_CODE_KEY).toString();
		
		ArrayList<HashMap<String, Object>> SaikenSyokyakuAddList = (ArrayList<HashMap<String, Object>>)inMap.get("saiken_syokyaku_list");
		
		if (SaikenSyokyakuAddList == null || SaikenSyokyakuAddList.size() == 0)
		{
			return paramMap;
		}
		
		// 債権償却登録リストの件数分繰り返す
		for (HashMap<String, Object> SaikenSyokyakuAddMap : SaikenSyokyakuAddList)
		{
			// 債権償却登録の実行
			resultMap = editInMsgECH0011C014(param, SaikenSyokyakuAddMap, funcCode);
			list.addAll(Arrays.asList((CAANMsg[])paramMap.get(JCMConstants.TEMPLATE_LIST_KEY)));
		}
		
		templates = list.toArray(new CAANMsg[list.size()]);
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);
		
		return paramMap;
	}
	
	/**
	 * 債権償却登録マップに指定されたリストを基に債権償却登録を行います。 <br>
	 * 
	 * @param handle セッションハンドルJCRAddHotVoicCC
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return リクエストパラメータ
	 * @throws Exception 例外が発生した場合
	 */
	public IRequestParameterReadWrite addSaikenSyokyaku(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Exception 
	{
		// 上りマッピングの処理結果を取得するためのマップを生成
		HashMap<String, Object> paramMap = new HashMap<String, Object>();
		// SC実行結果を格納するマップ
		Map<?, ?> result = null;
		
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		
		// 入力データ情報
		HashMap<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_SAIKENSYOKYAKUADDCC);

		// 機能コード
		String funcCode = inMap.get(JCMConstants.FUNC_CODE_KEY).toString();
		
		ArrayList resultList = new ArrayList();
		
		ArrayList<HashMap<String, Object>> SaikenSyokyakuAddList = (ArrayList<HashMap<String, Object>>)inMap.get("saiken_syokyaku_list");
		if (SaikenSyokyakuAddList == null || SaikenSyokyakuAddList.size() == 0)
		{
			return param;
		}
		
		// 債権償却登録リストの件数分繰り返す
		for (HashMap<String, Object> SaikenSyokyakuAddMap : SaikenSyokyakuAddList)
		{
			// 債権償却登録の実行
			paramMap = editInMsgECH0011C014(param, SaikenSyokyakuAddMap, funcCode);
			result = scCall.run(paramMap, handle);
			editOutMsgECH0011C014(result, param, SaikenSyokyakuAddMap, resultList);
		}
		
		/* 業務データ設定 */
		HashMap<String, Object> dataHikitugiMap = (HashMap<String, Object>)param.getData(MAP_SAIKENKAIKIDOINFOCC);
		if (dataHikitugiMap == null)
		{
			dataHikitugiMap = new HashMap<String, Object>();
			param.setData(MAP_SAIKENKAIKIDOINFOCC, dataHikitugiMap);
		}
		
		// 債権会計異動情報明細リスト
		dataHikitugiMap.put("saiken_kaik_ido_list", resultList);

		// 結果を返却する。
		return param;
	}

	/**
	 * 共通領域の設定
	 * 
	 * @param param
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	private HashMap<String, Object> editInMsg(IRequestParameterReadWrite param) 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));

		return paramMap;
	}
	
	/**
	 * 債権償却登録サービスインターフェイス用メッセージ設定処理<br>
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	private HashMap<String, Object> editInMsgECH0011C014(IRequestParameterReadWrite param, HashMap<String, Object> inMap, String funcCode) throws RequestParameterException 
	{
		// 共通領域の設定
		HashMap<String, Object> paramMap = editInMsg(param);

		CAANMsg template = new CAANMsg(ECH0011C014CBSMsg.class.getName());
		
		// テンプレートID
		template.set(ECH0011C014CBSMsg.TEMPLATEID, TEMPLATE_ID_ECH0011C014);

		// 機能コード
		template.set(ECH0011C014CBSMsg.FUNC_CODE, funcCode);

		// オペレータID
		Object operatorId = param.getControlMapData(SCControlMapKeys.OPERATOR_ID);
		template.set(JCMConstants.OPERATOR_ID_KEY, operatorId);

		// 運用日付
		Object operateDate = param.getControlMapData(SCControlMapKeys.OPE_DATE);
		template.set(JCMConstants.OPERATE_DATE_KEY, operateDate);

		// 運用日時
		Object operateDateTime = param.getControlMapData(SCControlMapKeys.OPE_TIME);
		template.set(JCMConstants.OPERATE_DATETIME_KEY, operateDateTime);

		// 債権償却登録マップ.債権番号 → 債権番号
		if (JCRUtilCommon.isNull(inMap.get("saiken_no")))
		{
			template.setNull(ECH0011C014CBSMsg.SAIKEN_NO);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.SAIKEN_NO, (String) inMap.get("saiken_no"));
		}

		// 債権償却登録マップ.債権ステータス → 債権ステータス
		if (JCRUtilCommon.isNull(inMap.get("saiken_stat"))) 
		{
			template.setNull(ECH0011C014CBSMsg.SAIKEN_STAT);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.SAIKEN_STAT, (String) inMap.get("saiken_stat"));
		}

		//  債権償却登録マップ.債権償却年月日 → 債権償却年月日
		if (JCRUtilCommon.isNull(inMap.get("saiken_shokyaku_ymd"))) 
		{
			template.setNull(ECH0011C014CBSMsg.SAIKEN_SHOKYAKU_YMD);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.SAIKEN_SHOKYAKU_YMD, (String) inMap.get("saiken_shokyaku_ymd"));
		}

		//  債権償却登録マップ.償却理由コード → 償却理由コード
		if (JCRUtilCommon.isNull(inMap.get("shokyaku_rsn_cd"))) 
		{
			template.setNull(ECH0011C014CBSMsg.SHOKYAKU_RSN_CD);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.SHOKYAKU_RSN_CD, (String) inMap.get("shokyaku_rsn_cd"));
		}

		// 債権償却登録マップ.更新年月日時分秒(更新前) → 更新年月日時分秒(更新前)
		if (JCRUtilCommon.isNull(inMap.get("upd_dtm_bf"))) 
		{
			template.setNull(ECH0011C014CBSMsg.UPD_DTM_BF);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.UPD_DTM_BF, (String) inMap.get("upd_dtm_bf"));
		}

		// 債権償却登録マップ.システムパラメータ分類コード → システムパラメータ分類コード
		if (JCRUtilCommon.isNull(inMap.get("sys_param_bunrui_cd"))) 
		{
			template.setNull(ECH0011C014CBSMsg.SYS_PARAM_BUNRUI_CD);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.SYS_PARAM_BUNRUI_CD, (String) inMap.get("sys_param_bunrui_cd"));
		}

		// 債権償却登録マップ.システムパラメータID1 → システムパラメータID1
		if (JCRUtilCommon.isNull(inMap.get("sys_param_id_1"))) 
		{
			template.setNull(ECH0011C014CBSMsg.SYS_PARAM_ID_1);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.SYS_PARAM_ID_1, (String) inMap.get("sys_param_id_1"));
		}

		// 債権償却登録マップ.システムパラメータID2 → システムパラメータID2
		if (JCRUtilCommon.isNull(inMap.get("sys_param_id_2"))) 
		{
			template.setNull(ECH0011C014CBSMsg.SYS_PARAM_ID_2);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.SYS_PARAM_ID_2, (String) inMap.get("sys_param_id_2"));
		}

		// 債権償却登録マップ.システムパラメータID3 → システムパラメータID3
		if (JCRUtilCommon.isNull(inMap.get("sys_param_id_3"))) 
		{
			template.setNull(ECH0011C014CBSMsg.SYS_PARAM_ID_3);
		} 
		else 
		{
			template.set(ECH0011C014CBSMsg.SYS_PARAM_ID_3, (String) inMap.get("sys_param_id_3"));
		}
		
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	/**
	 * 債権償却登録サービスインターフェイス用メッセージ取得処理<br>
	 * 
	 * @param msgList メッセージリスト
	 * @param param リクエストパラメータ
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editOutMsgECH0011C014(Map<?, ?> msgList,IRequestParameterReadWrite param,HashMap<String, Object> dataMap, ArrayList resultList) throws Exception
	{
		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[]) msgList.get(JCMConstants.TEMPLATE_LIST_KEY);

		// リターンコード取得
		Object returnCode = msgList.get(JCMConstants.RET_CD_INT_KEY);

		CAANMsg kaikIdo = templates[0];

		// 更新年月日時分秒 ← 更新年月日時分秒
		if (kaikIdo.isNull(ECH0011C014CBSMsg.UPD_DTM)) 
		{
			dataMap.put("upd_dtm", "");
		} 
		else 
		{
			dataMap.put("upd_dtm", kaikIdo.getString(ECH0011C014CBSMsg.UPD_DTM));
		}

		// 更新オペレータアカウント ← 更新オペレータアカウント
		if (kaikIdo.isNull(ECH0011C014CBSMsg.UPD_OPEACNT)) 
		{
			dataMap.put("upd_opeacnt", "");
		} 
		else 
		{
			dataMap.put("upd_opeacnt", kaikIdo.getString(ECH0011C014CBSMsg.UPD_OPEACNT));
		}

		CAANMsg[] saikenUcwkList = templates[0].getCAANMsgList(ECH0011C014CBSMsg.ECH0011C014CBSMSG1LIST);

		if (saikenUcwkList != null && saikenUcwkList.length != 0)
		{
			for (CAANMsg msgsaikenUcwk : saikenUcwkList)
			{
				HashMap resultMap = new HashMap();
				resultList.add(resultMap);
				
				// 債権番号(内訳) ← 債権内訳登録明細.債権番号(内訳)
				resultMap.put(ECH0011C014CBSMsg1List.SAIKEN_NO_UW, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.SAIKEN_NO_UW));
				// 料金グループコード ← 債権内訳登録明細.料金グループコード
				resultMap.put(ECH0011C014CBSMsg1List.PRC_GRP_CD, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.PRC_GRP_CD));
				// 料金コースコード ← 債権内訳登録明細.料金コースコード
				resultMap.put(ECH0011C014CBSMsg1List.PCRS_CD, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.PCRS_CD));
				// 料金サービスコード ← 債権内訳登録明細.料金サービスコード
				resultMap.put(ECH0011C014CBSMsg1List.PRC_SVC_CD, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.PRC_SVC_CD));
				// 料金項目コード ← 債権内訳登録明細.料金項目コード
				resultMap.put(ECH0011C014CBSMsg1List.PRC_KMK_CD, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.PRC_KMK_CD));
				// 金額 ← 債権内訳登録明細.金額
				resultMap.put(ECH0011C014CBSMsg1List.AMNT, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.AMNT));
				// 債権確定年月 ← 債権内訳登録明細.債権確定年月
				resultMap.put(ECH0011C014CBSMsg1List.SAIKEN_FIX_YM, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.SAIKEN_FIX_YM));
				// 請求契約番号 ← 債権内訳登録明細.請求契約番号
				resultMap.put(ECH0011C014CBSMsg1List.SEIKY_KEI_NO, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.SEIKY_KEI_NO));
				// 債権年月 ← 債権内訳登録明細.債権年月
				resultMap.put(ECH0011C014CBSMsg1List.SAIKEN_YM, msgsaikenUcwk.getString(ECH0011C014CBSMsg1List.SAIKEN_YM));
			}
		}

		// エラー情報の設定
		IRequestParameterReadWrite retParam = this.editErrorInfoECH0011C014(param, dataMap, templates, (Integer)returnCode);
		
		//エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>)retParam.getControlMapData(SCControlMapKeys.ERROR_INFO);
		if (errList == null)
		{
			errList = new ArrayList<Object>();
		}
		
		// コントロールマップに設定
		retParam.setControlMapData(SCControlMapKeys.ERROR_INFO, TemplateErrorUtil.getErrorInfo(msgList, errList));
		
		/* ◇処理結果の判定 */
		//取得したリターンコード、ステータスの内容を見て異常かどうかの判断をする。
		String rtnCode = msgList.get(JCMConstants.RET_CD_INT_KEY).toString();
		String status = (String)param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		
		// 異常の場合、SCCallExceptionを生成してスローする
		if(!("0".equals(rtnCode) && 0 == Integer.parseInt(status))) 
		{
			SCCallException scCallEx = new SCCallException("INVALID_RETURN_MESSAGE", rtnCode, Integer.parseInt(status));
			throw scCallEx;
		}
		
		return retParam;
	}

	/**
	 * 債権償却登録サービスIF実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param templates テンプレート
	 * @param returnCode リターンコード
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException RequestParameterException
	 */
	public IRequestParameterReadWrite editErrorInfoECH0011C014(IRequestParameterReadWrite param, HashMap<String, Object> inMap, CAANMsg[] templates, int returnCode) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(ECH0011C014CBSMsg.STATUS);
		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);
		}
		
		// 債権番号エラー → 債権償却登録明細.債権番号エラー
		if (!template.isNull(ECH0011C014CBSMsg.SAIKEN_NO_ERR)) 
		{
			if (!inMap.containsKey("saiken_no_err")) 
			{
				inMap.put("saiken_no_err", template.getString(ECH0011C014CBSMsg.SAIKEN_NO_ERR));
			}
		}

		// 債権ステータスエラー → 債権償却登録明細.債権ステータスエラー
		if (!template.isNull(ECH0011C014CBSMsg.SAIKEN_STAT_ERR)) 
		{
			if (!inMap.containsKey("saiken_stat_err")) 
			{
				inMap.put("saiken_stat_err", template.getString(ECH0011C014CBSMsg.SAIKEN_STAT_ERR));
			}
		}

		// 債権償却年月日エラー → 債権償却登録明細.債権償却年月日エラー
		if (!template.isNull(ECH0011C014CBSMsg.SAIKEN_SHOKYAKU_YMD_ERR)) 
		{
			if (!inMap.containsKey("saiken_shokyaku_ymd_err")) 
			{
				inMap.put("saiken_shokyaku_ymd_err", template.getString(ECH0011C014CBSMsg.SAIKEN_SHOKYAKU_YMD_ERR));
			}
		}

		// 償却理由コードエラー → 債権償却登録明細.償却理由コードエラー
		if (!template.isNull(ECH0011C014CBSMsg.SHOKYAKU_RSN_CD_ERR)) 
		{
			if (!inMap.containsKey("shokyaku_rsn_cd_err")) 
			{
				inMap.put("shokyaku_rsn_cd_err", template.getString(ECH0011C014CBSMsg.SHOKYAKU_RSN_CD_ERR));
			}
		}

		// 更新年月日時分秒(更新前)エラー → 債権償却登録明細.更新年月日時分秒(更新前)エラー
		if (!template.isNull(ECH0011C014CBSMsg.UPD_DTM_BF_ERR)) 
		{
			if (!inMap.containsKey("upd_dtm_bf_err")) 
			{
				inMap.put("upd_dtm_bf_err", template.getString(ECH0011C014CBSMsg.UPD_DTM_BF_ERR));
			}

		}

		return param;
	}

}
