/*******************************************************************************
*	 All Rights reserved,Copyright (c) K-Opticom 
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JSYejbEKK0191D010TKCK
*	ソースファイル名：JSYejbEKK0191D010TKCK.java
*	作成者			：EKek0058
*	日付			：2013年03月15日
*＜機能概要＞
*	サービス契約内訳<eo光電話>登録の単関連チェック部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	ｖ1.00.00
*	ｖ72.00.00	2024/8/29	FJ)森		ANK-4494-00-00_【eo定期】 双方向番ポ対応
*
********************************************************************************/

package eo.ejb.check.itemrelation;

import java.sql.Connection;
import java.sql.Date;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Timestamp;
import java.util.ArrayList;

import com.fujitsu.futurity.model.base.CAANConnectionMgr;
import com.fujitsu.futurity.model.base.CAANJDBCUtil;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.base.CAANRuntimeException;
import com.fujitsu.futurity.model.ejb.common.JSYejbConnection;
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.TankanrenCheckHandler;

import eo.ejb.cbm.entity.KK2961ETMsg;
import eo.ejb.cbs.cbsmsg.EKK0191D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK2961D010CBSMsg;
import eo.ejb.common.JKKModelCommon;
import eo.ejb.common.JKKSoteiSwitchTimezChkUtil;
import eo.common.constant.JKKStrConst;

/**
 * <HR>
 * サービス契約内訳<eo光電話>登録CBSMsgの単関連チェック用クラス｡ <p>
 * 
 * 以下の機能をサポートする。
 * <ul>
 * <li>サービス契約内訳<eo光電話>登録CBSMsgの単関連をチェックする。
 * </ul>
 * <p>
 * <HR>
 * <p>
 */ 
public class JSYejbEKK0191D010TKCK implements TankanrenCheckHandler {

	/**
	 * JSYejbEKK0191D010TKCK単関連をチェックする。<br>
	 * 
	 * JSYejbEKK0191D010TKCK単関連をチェックする。
	 * <p>
	 * @param	inCBSMsg	CBSMsgメッセージ
	 * @param	inContext	Agent
	 */
	public void invoke(CAANMsg inCBSMsg, AgentDispatchContext inContext) {

		JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"invoke#Call");

		// チェックを行う
		int stRet = 0;

		//チェック条件：試用期間終了年月日がnullでない かつ 試用加入年月日がnullでない
		if(!inCBSMsg.isNull(EKK0191D010CBSMsg.FTRIAL_PRD_ENDYMD) && !inCBSMsg.isNull(EKK0191D010CBSMsg.FTRIAL_KANYU_YMD)){
			//試用加入年月日がテンプレート項目(試用期間終了年月日)より大きい ：エラー
			if( comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.FTRIAL_KANYU_YMD),inCBSMsg.getObject(EKK0191D010CBSMsg.FTRIAL_PRD_ENDYMD),"31","1") ){
				inCBSMsg.set(EKK0191D010CBSMsg.FTRIAL_KANYU_YMD_ERR, "E2");
				JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"ftrial_kanyu_ymd_err:E2");
				stRet = StatusCodes.ITEM_RELATION_ERR;
			}
		}

		//チェック条件：(解約・休止トーキ希望有無が固定値(1)と等しい かつ 解約・休止トーキ開始年月日がnullでない) かつ 解約・休止トーキ終了年月日がnullでない
		if(( comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.DSL_PAUSE_TOKI_KIBO_UM),"1","20","1")  && !inCBSMsg.isNull(EKK0191D010CBSMsg.DSL_PAUSE_TOKI_STA_YMD)) && !inCBSMsg.isNull(EKK0191D010CBSMsg.DSL_PAUSE_TOKI_END_YMD)){
			//解約・休止トーキ開始年月日がテンプレート項目(解約・休止トーキ終了年月日)より大きい ：エラー
			if( comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.DSL_PAUSE_TOKI_STA_YMD),inCBSMsg.getObject(EKK0191D010CBSMsg.DSL_PAUSE_TOKI_END_YMD),"31","1") ){
				inCBSMsg.set(EKK0191D010CBSMsg.DSL_PAUSE_TOKI_STA_YMD_ERR, "E2");
				JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"dsl_pause_toki_sta_ymd_err:E2");
				stRet = StatusCodes.ITEM_RELATION_ERR;
			}
		}

		//チェック条件：NTT契約者住所コードがnullでない かつ NTT契約者住所手動入力フラグが固定値(0)と等しい
		if(!inCBSMsg.isNull(EKK0191D010CBSMsg.NTT_KEISHA_AD_CD) &&  comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.NKYS_AD_MAN_INPUT_FLG),"0","20","1") ){
			//住所入力チェック（契約）の戻り値がfalseと等しい ：エラー
			if(JKKModelCommon.isKKAddressInputCheck(inCBSMsg, inContext , "E3", "ntt_keisha_ad_cd", "ntt_keisha_state_nm", "ntt_keisha_city_nm", "ntt_keisha_oaztsu_nm", "ntt_keisha_azcho_nm", "ntt_keisha_bnchigo" ) == false){
				inCBSMsg.set(EKK0191D010CBSMsg.NTT_KEISHA_AD_CD_ERR, "E3");
				JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"ntt_keisha_ad_cd_err:E3");
				stRet = StatusCodes.ITEM_RELATION_ERR;
			}
		}

		//チェック条件：緊急通報用住所コードがnullでない
		if(!inCBSMsg.isNull(EKK0191D010CBSMsg.EMG_AD_CD)){
			//住所入力チェック（契約）の戻り値がfalseと等しい ：エラー
			if(JKKModelCommon.isKKAddressInputCheck(inCBSMsg, inContext , "E4", "emg_ad_cd", "emg_state_nm", "emg_city_nm", "emg_oaztsu_nm", "emg_azcho_nm", "emg_bnchigo" ) == false){
				inCBSMsg.set(EKK0191D010CBSMsg.EMG_AD_CD_ERR, "E4");
				JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"emg_ad_cd_err:E4");
				stRet = StatusCodes.ITEM_RELATION_ERR;
			}
		}

		//チェック条件：電話番号必須チェック判定処理の戻り値がtrueと等しい
		if(JKKModelCommon.isTelNoChkJugdeKK0191(inCBSMsg, inContext  ) == true){
			//電話番号がnullでない ：正常
			if(!(!inCBSMsg.isNull(EKK0191D010CBSMsg.TELNO))){
				inCBSMsg.set(EKK0191D010CBSMsg.TELNO_ERR, "E5");
				JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"telno_err:E5");
				stRet = StatusCodes.ITEM_RELATION_ERR;
			}
		}

		//チェック条件：緊急通報用住所チェックレベルが固定値(1)と等しい または 緊急通報用住所チェックレベルが固定値(2)と等しい
		if( comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.EMG_AD_CHK_LV),"1","20","1")  ||  comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.EMG_AD_CHK_LV),"2","20","1") ){
			//緊急通報用住所コードがnull または 緊急通報用補正郵便番号がnull ：エラー
			if(inCBSMsg.isNull(EKK0191D010CBSMsg.EMG_AD_CD) || inCBSMsg.isNull(EKK0191D010CBSMsg.EMG_HOSEI_PCD)){
				inCBSMsg.set(EKK0191D010CBSMsg.EMG_AD_CD_ERR, "E6");
				JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"emg_ad_cd_err:E6");
				stRet = StatusCodes.ITEM_RELATION_ERR;
			}
		}

		//チェック条件：NTT契約者住所チェックレベルが固定値(1)と等しい または NTT契約者住所チェックレベルが固定値(2)と等しい
		if( comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.NTT_AD_CHK_LV),"1","20","1")  ||  comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.NTT_AD_CHK_LV),"2","20","1") ){
			//NTT契約者住所コードがnull または NTT契約者郵便番号がnull ：エラー
			if(inCBSMsg.isNull(EKK0191D010CBSMsg.NTT_KEISHA_AD_CD) || inCBSMsg.isNull(EKK0191D010CBSMsg.NTT_KEISHA_PCD)){
				inCBSMsg.set(EKK0191D010CBSMsg.NTT_KEISHA_AD_CD_ERR, "E7");
				JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"ntt_keisha_ad_cd_err:E7");
				stRet = StatusCodes.ITEM_RELATION_ERR;
			}
		}

		//チェック条件：継続後契約変更手続中フラグが固定値(1)と等しい
		if( comparison(inCBSMsg.getObject(EKK0191D010CBSMsg.KEIZK_AF_KEI_CHGECHU_FLG),"1","20","1") ){
			//継続元サービス契約内訳番号がnull ：エラー
			if(inCBSMsg.isNull(EKK0191D010CBSMsg.KEIZK_MT_SVC_KEI_UCWK_NO)){
				inCBSMsg.set(EKK0191D010CBSMsg.KEIZK_MT_SVC_KEI_UCWK_NO_ERR, "E8");
				JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"keizk_mt_svc_kei_ucwk_no_err:E8");
				stRet = StatusCodes.ITEM_RELATION_ERR;
			}
		}
		
		// v72.00.00 ANK-4994-00-00 ADD START
		//チェック条件：工事実施方法必須チェック判定処理の戻り値がtrueと等しい
		if(JKKSoteiSwitchTimezChkUtil.isKojiJssiWaynullChk(inCBSMsg, inContext,inCBSMsg.getString(EKK0191D010CBSMsg.SOTEI_SWITCH_TIMEZ), inCBSMsg.getString(EKK0191D010CBSMsg.KOJI_JSSI_WAY)))
		{
			inCBSMsg.set(EKK0191D010CBSMsg.KOJI_JSSI_WAY_ERR, "E9");
			JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(), "koji_jssi_way_err:E9");
			stRet = StatusCodes.ITEM_RELATION_ERR;
		}
		// v72.00.00 ANK-4994-00-00 ADD END
		
		JSYejbLog.println(JSYejbLog.DEBUG,this.getClass(),"invoke#End");

		//チェック結果によりステータスを設定する
		if (stRet > inCBSMsg.getInt(EKK0191D010CBSMsg.STATUS)) {
			inCBSMsg.set(EKK0191D010CBSMsg.STATUS,stRet);
		}
	}

	/**
	 * 比較処理
	 * 
	 * @param left_arg 		比較値（左辺）
	 * @param right_arg 	比較値（右辺）
	 * @param enzan_arg 	比較演算子
	 * @param checkType 	比較形式
	 * 
	 * 
	 */
	
	
	private boolean comparison(Object left_arg, Object right_arg, String enzan_arg, String checkType)
	{

		boolean booRet = true;

		String leftStr = new String();
		String rightStr = new String();

		if ( left_arg != null ){
			leftStr = left_arg.toString();
		}
		if ( right_arg != null ){
			rightStr = right_arg.toString();
		}

		// 文字比較
		if ( "1".equals(checkType) ) {

			//より小さい
			if ( "10".equals(enzan_arg) || "40".equals(enzan_arg) || "41".equals(enzan_arg) ) {
				if( (leftStr.compareTo(rightStr) < 0)){
					return true;
				}else{
					return false;
				}
			//以下
			} else if ( "11".equals(enzan_arg) || "50".equals(enzan_arg) || "51".equals(enzan_arg) ) {
				if( (leftStr.compareTo(rightStr) <= 0)){
					return true;
				}else{
					return false;
				}
			//等しい
			} else if ( "20".equals(enzan_arg) || "60".equals(enzan_arg) || "61".equals(enzan_arg) ) {
				if( (leftStr.compareTo(rightStr) == 0)){
					return true;
				}else{
					return false;
				}
			//等しくない
			} else if ( "21".equals(enzan_arg) || "70".equals(enzan_arg) || "71".equals(enzan_arg) ) {
				if( (leftStr.compareTo(rightStr) != 0)){
					return true;
				}else{
					return false;
				}
			//以上
			} else if ( "30".equals(enzan_arg) || "80".equals(enzan_arg) || "81".equals(enzan_arg) ) {
				if( (leftStr.compareTo(rightStr) >= 0)){
					return true;
				}else{
					return false;
				}
			//より大きい
			} else if ( "31".equals(enzan_arg) || "90".equals(enzan_arg) || "91".equals(enzan_arg) ) {
				if( (leftStr.compareTo(rightStr) > 0)){
					return true;
				}else{
					return false;
				}
			//該当無し
			} else {
				return false;
			}

		//数値比較
		} else if ( "2".equals(checkType) ) {

			try{
				Long l_left_arg = new Long(leftStr);
				Long l_right_arg = new Long(rightStr);

				//より小さい
				if ( "10".equals(enzan_arg) || "40".equals(enzan_arg) || "41".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) < 0)){
						return true;
					}else{
						return false;
					}
				//以下
				} else if ( "11".equals(enzan_arg) || "50".equals(enzan_arg) || "51".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) <= 0)){
						return true;
					}else{
						return false;
					}
				//等しい
				} else if ( "20".equals(enzan_arg) || "60".equals(enzan_arg) || "61".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) == 0)){
						return true;
					}else{
						return false;
					}
				//等しくない
				} else if ( "21".equals(enzan_arg) || "70".equals(enzan_arg) || "71".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) != 0)){
						return true;
					}else{
						return false;
					}
				//以上
				} else if ( "30".equals(enzan_arg) || "80".equals(enzan_arg) || "81".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) >= 0)){
						return true;
					}else{
						return false;
					}
				//より大きい
				} else if ( "31".equals(enzan_arg) || "90".equals(enzan_arg) || "91".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) > 0)){
						return true;
					}else{
						return false;
					}
				//該当無し
				} else {
					return false;
				}
			}catch(NumberFormatException e){
				return false;
			}

		//精度比較
		} else if ( "3".equals(checkType) ) {

			try{
				Double l_left_arg = new Double(leftStr);
				Double l_right_arg = new Double(rightStr);
				
				//より小さい
				if ( "10".equals(enzan_arg) || "40".equals(enzan_arg) || "41".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) < 0)){
						return true;
					}else{
						return false;
					}
				//以下
				} else if ( "11".equals(enzan_arg) || "50".equals(enzan_arg) || "51".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) <= 0)){
						return true;
					}else{
						return false;
					}
				//等しい
				} else if ( "20".equals(enzan_arg) || "60".equals(enzan_arg) || "61".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) == 0)){
						return true;
					}else{
						return false;
					}
				//等しくない
				} else if ( "21".equals(enzan_arg) || "70".equals(enzan_arg) || "71".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) != 0)){
						return true;
					}else{
						return false;
					}
				//以上
				} else if ( "30".equals(enzan_arg) || "80".equals(enzan_arg) || "81".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) >= 0)){
						return true;
					}else{
						return false;
					}
				//より大きい
				} else if ( "31".equals(enzan_arg) || "90".equals(enzan_arg) || "91".equals(enzan_arg) ) {
					if( (l_left_arg.compareTo(l_right_arg) > 0)){
						return true;
					}else{
						return false;
					}
				//該当無し
				} else {
					return false;
				}
			}catch(NumberFormatException e){
				return false;
			}
		}

		return booRet;

	}

}
