/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JFUAddSvcEnqtCC
*   ソースファイル名：JFUAddSvcEnqtCC.java
*   作成者          ：富士通(西井
*   日付            ：2011年12月05日
*＜機能概要＞
*   アンケート回答登録部品です。
*＜修正履歴＞
*   v1.01.00    2013/04/23   FJ)大塚     No708 エラー情報マッピング不備対応
*
**********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.util.ArrayList;
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.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.CCException;
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.ejb.cbs.cbsmsg.EKK0051D010CBSMsg;

/**
 * アンケート回答登録部品
 * <br>
 * @author 富士通
 */
public class JFUAddSvcEnqtCC extends AbstractCommonComponent
{
	/**
	 * テンプレートID
	 */
	final String RETURN_MESSAGE_STRING = "RETURN_MESSAGE_";
	final String RETURN_MESSAGE_FORMAT = "%1$04d";
	final String CC_WORK_AREA_NAME = "JFUAddSvcKeiTelOpCCWork";
	/** 作業マップ名 */
	private static final String CC_WORK_AREA_NAME_KEISHA = "JFUAddKeishaServiceCCWork";
	private static final String CC_WORK_AREA_NAME_MSKM = "JFUAddMskmSCWork";
	// No708 2013/04/24 Otsuka start
	/** エラー用 */
	private static final int TMCK_ERR_STATUS = 1000;
	private static final String SC_ERROR_STRING = "サービスコンポーネントエラー";
	// No708 2013/04/24 Otsuka end
	/**
	 * アンケート回答登録処理.<br>
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return リクエストパラメータ
	 * @throws Exception Exception
	 */
	public IRequestParameterReadWrite addEnqtAnswer(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Exception
	{

		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		HashMap<String, Object> paramMap = setSCInputCommonData(param, new HashMap<String, Object>());
		Map<?, ?> result = null;
		CAANMsg template = null;

		HashMap inMap = null;

		// アンケート回答情報登録
		int bnpCnt = 0;
		inMap = (HashMap)(param.getData("EKK0051D010"));
		// ***********マップがなければ、スルーする**Start****//
		if(inMap==null){
			return param;
		}
		// ***********マップがなければ、スルーする**End******//
		bnpCnt = ((ArrayList)inMap.get("EKK0051D010List")).size();
		for (int i = 0; i < bnpCnt; i++)
		{
			// 上りマッピング
			template = editInEKK0051D010(param, "EKK0051D010", i);
			paramMap = putParamMap(paramMap, template);
			
			// SC呼び出し
			result = scCall.run(putParamMap(paramMap, template), handle);
			
			// 下りマッピング
			editRetEKK0051D010(result, param, "EKK0051D010");
			// No708 2013/04/24 Otsuka start
			if (getReturnCode(param) >= TMCK_ERR_STATUS)
			{ // ステータスが単項目エラー以上であれば例外をスロー
				throw new CCException(SC_ERROR_STRING, new Exception());
			}
			// No708 2013/04/24 Otsuka end
		}

		return param;
	}

	/**
	 * アンケート回答情報登録処理.<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
	{
		ArrayList<CAANMsg> msgList = new ArrayList<CAANMsg>();
		int bnpCnt = 0;
		int telOpCnt = 0;
		HashMap inMap = null;

		// アンケート回答情報登録マップ取得
		inMap = (HashMap)param.getData("EKK0051D010");
		// ***********マップがなければ、スルーする**Start****//
		if(inMap==null){
			return null;
		}
		// ***********マップがなければ、スルーする**End******//
		bnpCnt = ((ArrayList)inMap.get("EKK0051D010List")).size();
		for (int i = 0; i < bnpCnt; i++)
		{
			msgList.add(editInEKK0051D010(param, "EKK0051D010", i)); 
		}

		int msgCnt = msgList.size();
		CAANMsg[] templates = new CAANMsg[msgCnt];
		for (int i = 0; i < msgCnt; i++)
		{
			templates[i] = msgList.get(i);
		}

		HashMap<String, Object> paramMap = setSCInputCommonData(param, new HashMap<String, Object>());
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	/**
	 * SCインプット共通データ設定処理
	 * <br>
	 * @param param
	 * @param paramMap
	 * @return
	 */
	private HashMap<String, Object> setSCInputCommonData(IRequestParameterReadWrite param, HashMap<String, Object> paramMap)
			throws RequestParameterException
	{
		/* SCインプット共通データ */
		// **********************************************
		// 【取得元：電文ヘッダ(ヘッダ)】
		// **********************************************
		// 電文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 param リクエストパラメータ
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	private CAANMsg editInEKK0051D010(IRequestParameterReadWrite param, String fixedText, int index) throws RequestParameterException
	{

		CAANMsg template = new CAANMsg(EKK0051D010CBSMsg.class.getName());

		HashMap inMap = null;
		ArrayList inList = null;

		// テンプレートID（機器提供サービス契約登録）
		//template.set(EKK0051D010CBSMsg.TEMPLATEID, "EKK0051D010");
		template.set(EKK0051D010CBSMsg.TEMPLATEID, fixedText);

		// オペレータ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);

		// 機能コード
		template.set(EKK0051D010CBSMsg.FUNC_CODE, "1");

		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData(fixedText);
		inMap = (HashMap)((ArrayList)inMap.get("EKK0051D010List")).get(index);
		inMap = (HashMap)inMap.get("data" + index);

		// SYSID → SYSID
		if ("".equals(inMap.get("sysid")))
		{
			//template.setNull(EKK0051D010CBSMsg.SYSID);
			template.set(EKK0051D010CBSMsg.SYSID,getKeishaWorkMapValue(param, "sysid"));
		}
		else
		{
			template.set(EKK0051D010CBSMsg.SYSID, (String)inMap.get("sysid"));
		}
		
		// 申込番号 → 申込番号
		if ("".equals(inMap.get("mskm_no")))
		{
			//template.setNull(EKK0051D010CBSMsg.MSKM_NO);
			template.set(EKK0051D010CBSMsg.MSKM_NO,getMskmWorkMapValue(param, "mskm_no"));
		}
		else
		{
			template.set(EKK0051D010CBSMsg.MSKM_NO, (String)inMap.get("mskm_no"));
		}
		
		// アンケート番号 → アンケート番号
		if ("".equals(inMap.get("enquete_no")))
		{
			template.setNull(EKK0051D010CBSMsg.ENQUETE_NO);
		}
		else
		{
			template.set(EKK0051D010CBSMsg.ENQUETE_NO, (String)inMap.get("enquete_no"));
		}
		
		// アンケートコード → アンケートコード
		if ("".equals(inMap.get("enquete_cd")))
		{
			template.setNull(EKK0051D010CBSMsg.ENQUETE_CD);
		}
		else
		{
			template.set(EKK0051D010CBSMsg.ENQUETE_CD, (String)inMap.get("enquete_cd"));
		}
		
		// アンケートフリー入力欄 → アンケートフリー入力欄
		if ("".equals(inMap.get("enquete_free_iptfield")))
		{
			template.setNull(EKK0051D010CBSMsg.ENQUETE_FREE_IPTFIELD);
		}
		else
		{
			template.set(EKK0051D010CBSMsg.ENQUETE_FREE_IPTFIELD, (String)inMap.get("enquete_free_iptfield"));
		}

		return template;
	}

	/**
	 * アンケート回答登録用下りマッピング処理
	 * <br>
	 * @param param
	 * @param fixedText
	 * @return
	 */
	private IRequestParameterReadWrite editRetEKK0051D010(Map<?, ?> msgList, IRequestParameterReadWrite param, String fixedText) throws Exception
	{

		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg template = templates[0];

		Object returnCode = msgList.get(JCMConstants.RET_CD_INT_KEY);

		// 作業領域のマップを取得
		Map workMap = param.getMappingWorkArea();
		if (workMap == null)
		{
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}
		HashMap workDataMap = (HashMap)workMap.get(CC_WORK_AREA_NAME);
		if (workDataMap == null)
		{
			workDataMap = new HashMap();
			workMap.put(CC_WORK_AREA_NAME, workDataMap);
		}

		HashMap dataMap = (HashMap)param.getData("EKK0051D010");
		if (dataMap == null)
		{
			dataMap = new HashMap();
			param.setData(fixedText, dataMap);
		}

		// アンケート回答番号 → アンケート回答番号
		if (template.isNull(EKK0051D010CBSMsg.ENQUETE_ANS_NO))
		{
			dataMap.put("enquete_ans_no", "");
		}
		else
		{
			dataMap.put("enquete_ans_no", template.getString(EKK0051D010CBSMsg.ENQUETE_ANS_NO));
		}
		
		// 登録年月日時分秒 → 登録年月日時分秒
		if (template.isNull(EKK0051D010CBSMsg.ADD_DTM))
		{
			dataMap.put("add_dtm", "");
		}
		else
		{
			dataMap.put("add_dtm", template.getString(EKK0051D010CBSMsg.ADD_DTM));
		}
		
		// 登録オペレータアカウント → 登録オペレータアカウント
		if (template.isNull(EKK0051D010CBSMsg.ADD_OPEACNT))
		{
			dataMap.put("add_opeacnt", "");
		}
		else
		{
			dataMap.put("add_opeacnt", template.getString(EKK0051D010CBSMsg.ADD_OPEACNT));
		}
		
		// 更新年月日時分秒 → 更新年月日時分秒
		if (template.isNull(EKK0051D010CBSMsg.UPD_DTM))
		{
			dataMap.put("kaitoubanngou", "");
		}
		else
		{
			dataMap.put("kaitoubanngou", template.getString(EKK0051D010CBSMsg.UPD_DTM));
		}
		
		// 更新オペレータアカウント → 更新オペレータアカウント
		if (template.isNull(EKK0051D010CBSMsg.UPD_OPEACNT))
		{
			dataMap.put("upd_opeacnt", "");
		}
		else
		{
			dataMap.put("upd_opeacnt", template.getString(EKK0051D010CBSMsg.UPD_OPEACNT));
		}
		
		// 無効フラグ → 無効フラグ
		if (template.isNull(EKK0051D010CBSMsg.MK_FLG))
		{
			dataMap.put("mk_flg", "");
		}
		else
		{
			dataMap.put("mk_flg", template.getString(EKK0051D010CBSMsg.MK_FLG));
		}

		param.setData(fixedText, dataMap);

		// エラー情報の設定
		param = editErrInfoEKK0051D010(param, template, (Integer)returnCode, fixedText);

		//エラー情報のマップを取得
		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;
	}

	/**
	 * アンケート回答情報登録のエラー情報マッピング処理
	 * <br>
	 */
	private IRequestParameterReadWrite editErrInfoEKK0051D010(IRequestParameterReadWrite param, CAANMsg template, int returnCode, String fixedText)
			throws RequestParameterException
	{
		int templateStatus = template.getInt(EKK0051D010CBSMsg.STATUS);
		if (returnCode != 0)
		{
			templateStatus = 9000;
		}
		if (JCMAPLConstMgr.getString(RETURN_MESSAGE_STRING + String.format(RETURN_MESSAGE_FORMAT, 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)
		{
			String formatStatus = String.format(RETURN_MESSAGE_FORMAT, templateStatus);
			String message = JCMAPLConstMgr.getString(RETURN_MESSAGE_STRING + formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, message);
		}

		HashMap inMap = (HashMap<String, Object>)param.getData("EKK0051D010");

		return param;
	}


	/**
	 * 単一CAANMsgのマッピング処理
	 * <br>
	 * @param paramMap
	 * @param template
	 * @return
	 */
	private HashMap<String, Object> putParamMap(HashMap<String, Object> paramMap, CAANMsg template) throws RequestParameterException
	{
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	/**
	 * SCの実行ステータスの取得処理
	 * <br>
	 * @param param
	 * @return
	 */
	private int getReturnCode(IRequestParameterReadWrite param) throws Exception
	{
		return Integer.parseInt((String)param.getControlMapData(SCControlMapKeys.RETURN_CODE));
	}

	/**
	 * エラー情報のマッピング処理
	 * <br>
	 */
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param, CAANMsg[] templates, Integer returnCode)
			throws RequestParameterException
	{
		int i = 0;
		HashMap inMap = null;

		String fixedText = "";

		// アンケート回答情報登録
		int bnpCnt = 0;
		inMap = (HashMap)(param.getData("EKK0051D010"));
		// ***********マップがなければ、スルーする**Start****//
		if(inMap==null){
			return param;
		}
		// ***********マップがなければ、スルーする**End****//
		bnpCnt = ((ArrayList)inMap.get("EKK0051D010List")).size();
		for (i = 0; i < bnpCnt; i++)
		{
			editErrInfoEKK0051D010(param, templates[i], returnCode, fixedText);
		}

		return param;
	}
	
	private String getKeishaWorkMapValue(IRequestParameterReadWrite param,
			String key) throws RequestParameterException {
		// 作業領域の取得
		Map workMap = (Map) param.getMappingWorkArea();

		HashMap inMap = null;
		/* 契約者作業項目情報 */
		if (workMap != null) {
			inMap = (HashMap) param.getData("FUSV016501SC");
			if (inMap == null) {
				inMap = (HashMap) param.getData("FUSV016502SC");
			}
			if (inMap == null) {
				inMap = (HashMap) workMap.get(CC_WORK_AREA_NAME_KEISHA);
			}
		} else {
			inMap = null;
		}

		String result = null;
		if (inMap != null) {
			result = (String) inMap.get(key);
		}

		if ("".equals(result)) {
			result = null;
		}

		return result;
	}

	private String getMskmWorkMapValue(IRequestParameterReadWrite param,
			String key) throws RequestParameterException {
		// 作業領域の取得
		Map workMap = (Map) param.getMappingWorkArea();

		HashMap inMap = null;
		/* 申込作業項目情報 */
		if (workMap != null) {
			inMap = (HashMap) param.getData("FUSV016505SC");
			if (inMap == null) {
				inMap = (HashMap) workMap.get(CC_WORK_AREA_NAME_MSKM);
			}
		} else {
			inMap = null;
		}

		String result = null;
		if (inMap != null) {
			result = (String) inMap.get(key);
		}

		if ("".equals(result)) {
			result = null;
		}

		return result;
	}
	
}
