/*******************************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JEKK0341C230TPMA
*	ソースファイル名：JEKK0341C230TPMA.java
*	作成者			：富士通
*	日付			：2011年11月25日
*＜機能概要＞
*	機器提供サービス契約情報変更の副次処理を呼び出す部品。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/11/25	富士通
*   v4.00.00    2013/02/08  FJ)坂本		ST3-2013-0000040
*   v4.00.01    2013/02/21  FJ)坂本		ST3-2013-0000040
 *  v5.00.00    2013/10/03  FJ)寺園     OM-2013-0002733
*   v8.00.00	2014/05/16	FJ)宇野		OM-2014-0001528
*
********************************************************************************/

package eo.ejb.cbs.mainproc;

import com.fujitsu.futurity.common.JCMConstants;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.ejb.common.JSYejbLog;
import com.fujitsu.futurity.model.ejb.common.StatusCodes;
import com.fujitsu.futurity.model.ejb.common.fw.AgentDispatchContext;
import com.fujitsu.futurity.model.ejb.common.fw.TemplateMainHandler;

import eo.ejb.cbs.cbsmsg.EKK0341C230CBSMsg;
import eo.ejb.common.JKKModelCommon;
import eo.ejb.common.entity.JKKejbAdChecker;
import eo.ejb.common.entity.JKKejbKK0341KRCK;

/**
 * <p>
 * 機器提供サービス契約情報変更顧客独自処理部品クラスです。
 * </p>
 * @author 富士通
 */
public class JEKK0341C230TPMA implements TemplateMainHandler
{

	/**
	 * <p>
	 * 住所チェック共通処理の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void adCheck(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 機器送付先住所チェック
		// 機器送付先住所が変更されている場合のみチェックを行う
		if(JKKModelCommon.isKikiSohusAdChgKK0341(inCBSMsg, inContext, inCBSMsg.getString(EKK0341C230CBSMsg.KKTK_SVC_KEI_NO), 
				inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_SOHUS_AD_CD), inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_SOHUS_PCD)))
		{
			if (kikiSohusAdCheck(inCBSMsg) > StatusCodes.WARNING)
			{
				return;
			}
		}

		// 機器設置先住所チェック
		if (kikiStcAdCheck(inCBSMsg) > StatusCodes.WARNING)
		{
			return;
		}
	}

	/**
	 * <p>
	 * 機器送付先住所チェックを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @return true：正常 , false：エラー
	*/
	private int kikiSohusAdCheck(CAANMsg inCBSMsg)
	{
		// 住所チェック共通処理部品
		JKKejbAdChecker adCheck = new JKKejbAdChecker();

		// 住所コード
		adCheck.setAdCd(inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_SOHUS_AD_CD));
		// 郵便番号
		adCheck.setPCd(inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_SOHUS_PCD));
		// 手動入力フラグ
		adCheck.setManInputFlg(inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_SHS_AD_MAN_INPUT_FLG));
		// 住所チェックレベル
		adCheck.setAdChkLv(inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_SOHUS_AD_CHK_LV));
		// 機能コード
		adCheck.setFuncCode(inCBSMsg.getString(EKK0341C230CBSMsg.FUNC_CODE));

		/*
		 * 住所チェック
		 */
		int rtnStCd = 0;
		if (!adCheck.isAdCheck(inCBSMsg))
		{
			// エラー情報を設定
			inCBSMsg.set(EKK0341C230CBSMsg.KIKI_SOHUS_AD_CHK_LV_ERR, adCheck.getErrFlg());
			if ("W".equals(adCheck.getErrFlg().substring(0, 1)))
			{
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.WARNING);
				rtnStCd = StatusCodes.WARNING;
			}
			else
			{
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
				rtnStCd = StatusCodes.RELATION_ERR;
			}
		}
		return rtnStCd;
	}


	/**
	 * <p>
	 * 機器設置先住所チェックを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @return true：正常 , false：エラー
	*/
	private int kikiStcAdCheck(CAANMsg inCBSMsg)
	{
		// 住所チェック共通処理部品
		JKKejbAdChecker adCheck = new JKKejbAdChecker();

		// 住所コード
		adCheck.setAdCd(inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_STC_SAKI_AD_CD));
		// 郵便番号
		adCheck.setPCd(inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_STC_SAKI_PCD));
		// 手動入力フラグ
		adCheck.setManInputFlg("0");
		// 住所チェックレベル
		adCheck.setAdChkLv(inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_STC_AD_CHK_LV));
		// 機能コード
		adCheck.setFuncCode(inCBSMsg.getString(EKK0341C230CBSMsg.FUNC_CODE));

		/*
		 * 住所チェック
		 */
		int rtnStCd = 0;
		if (!adCheck.isAdCheck(inCBSMsg))
		{
			// エラー情報を設定
			inCBSMsg.set(EKK0341C230CBSMsg.KIKI_STC_AD_CHK_LV_ERR, adCheck.getErrFlg());
			if ("W".equals(adCheck.getErrFlg().substring(0, 1)))
			{
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.WARNING);
				rtnStCd = StatusCodes.WARNING;
			}
			else
			{
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
				rtnStCd = StatusCodes.RELATION_ERR;
			}
		}
		return rtnStCd;
	}
	
	/**
	 * <p>
	 * 機器提供サービス契約情報変更の関連制約部品の呼び出しを行います。
	 * </p>
	 * @param inCBSMsg 処理対象のメッセージキャリア
	 * @param inContext Agentから渡されたAgentDispatchContext
	*/
	public void execKRCK(CAANMsg inCBSMsg, AgentDispatchContext inContext)
	{
		// 開始ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JEKK0341C230TPMA#execKRCK");
		
		boolean chkFlg = true;
		
		JKKejbKK0341KRCK kk0341Chk = new JKKejbKK0341KRCK();
		
		// 工事会社棚存在チェック（関連制約No14）
		String kktkSvcKeiNo = inCBSMsg.getString(EKK0341C230CBSMsg.KKTK_SVC_KEI_NO);
		String kikiStiJiKocompCd = inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_STI_JI_KOCOMP_CD);
		String kikiStiJiKocompSlfCd = inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_STI_JI_KOCOMP_SLF_CD);
		
		chkFlg = kk0341Chk.isKikiStiCompChk(inCBSMsg, inContext, kktkSvcKeiNo, null, kikiStiJiKocompCd, kikiStiJiKocompSlfCd);
		
		if (!chkFlg)
		{
			inCBSMsg.set(EKK0341C230CBSMsg.KIKI_STI_JI_KOCOMP_CD_ERR, "EA");
			inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
		}
		else
		{
			// 預託先オフィス棚存在チェック（関連制約No15）
			String kikiStiJiYtkskofCd = inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_STI_JI_YTKSKOF_CD);
			String kikiStiJiYtkskofSlfCd = inCBSMsg.getString(EKK0341C230CBSMsg.KIKI_STI_JI_YTKSKOF_SLF_CD);
			
			chkFlg = kk0341Chk.isKikiStiYtkskofChk(inCBSMsg, inContext, kktkSvcKeiNo, null, kikiStiJiYtkskofCd, kikiStiJiYtkskofSlfCd);

			if (!chkFlg)
			{
				inCBSMsg.set(EKK0341C230CBSMsg.KIKI_STI_JI_YTKSKOF_CD_ERR, "EA");
				inCBSMsg.set(JCMConstants.STATUS_INT_KEY, StatusCodes.RELATION_ERR);
			}
		}
		
		// 終了ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JEKK0341C230TPMA#execKRCK");
	}

}