/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JKKKikiHktgiAddReqChk
*	ソースファイル名：JKKKikiHktgiAddReqChk.java
*	作成者			：FJ
*	日付			：2011年11月16日
*＜機能概要＞
*	機器引継登録サービスで、機器引継登録の実行を判定するクラスです。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/11/16	FJ			新規作成
*
**********************************************************************/
package com.fujitsu.futurity.bp.custom.reqchk;

import java.util.ArrayList;
import java.util.HashMap;

import com.fujitsu.futurity.bp.x21.bpm.common.AbstractCustomReqChk;
import com.fujitsu.futurity.bp.x21.bpm.common.IConditionValue;
import com.fujitsu.futurity.bp.x21.bpm.exception.RequestParameterException;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadOnly;
import com.fujitsu.futurity.bp.x21.bpm.reqchk.exception.ReqChkException;

/**
 * 実行判定クラスです。
 * <BR>
 * @author 富士通
 */
public class JKKKikiHktgiAddReqChk extends AbstractCustomReqChk
{

	/**
	 * 実行判定処理
     * <BR>
     * @param irp
     * @param conditionvalue
	 * @return boolean
	 * @throws ReqChkException
	 */
	@Override
	public boolean checkExecution(IRequestParameterReadOnly irp, IConditionValue conditionvalue) throws ReqChkException
	{
		boolean blnRet = true;
		
		try
		{
			// ■接続機器情報チェック（ＯＮＵ機器）
			
			// 料金コース一意照会
			HashMap<String, Object> kksv041901_parentMap = (HashMap)irp.getData("KKSV041901SC");
			ArrayList ekk0791A010CBSMsg1List = (ArrayList)kksv041901_parentMap.get("EKK0791A010CBSMsg1List");
			
			// 料金コース一意照会を実行しなかった場合や、料金コース一意照会の検索結果が無しの場合
			if (ekk0791A010CBSMsg1List == null || ekk0791A010CBSMsg1List.size() == 0)
			{
				return true;
			}
			
			// サービス契約回線内訳一覧照会（現在利用中）
			HashMap<String, Object> kksv041902_parentMap = (HashMap)irp.getData("KKSV041902SC");
			ArrayList ekk0251B003CBSMsg1List = (ArrayList)kksv041902_parentMap.get("EKK0251B003CBSMsg1List");
			
			// サービス契約回線内訳一覧照会（現在利用中）を実行しなかった場合や、
			// サービス契約回線内訳一覧照会（現在利用中）の検索結果が無しの場合
			if (ekk0251B003CBSMsg1List == null || ekk0251B003CBSMsg1List.size() == 0)
			{
				return true;
			}
			
			HashMap<String, Object> ekk0791A010_childMap = (HashMap)ekk0791A010CBSMsg1List.get(0);
			HashMap<String, Object> ekk0251B003_childMap = (HashMap)ekk0251B003CBSMsg1List.get(0);
			
			// 料金コースPON条件コード
			String pcrs_pon_joken_cd = (String)ekk0791A010_childMap.get("pcrs_pon_joken_cd");
			
			// PON種別コード
			String pon_sbt_cd = (String)ekk0251B003_childMap.get("pon_sbt_cd");
			
			// 料金コースPON条件コードが、"1":E-PON/GE-PON併用 または "3":E-PONのみ の場合
			if ("1".equals(pcrs_pon_joken_cd) || "3".equals(pcrs_pon_joken_cd))
			{
				// PON種別コードが、"2":GE-PON の場合
				if ("2".equals(pon_sbt_cd))
				{
					return false;
				}
			}
			// 料金コースPON条件コードが、"2":GE-PONのみ の場合
			else if ("2".equals(pcrs_pon_joken_cd))
			{
				// PON種別コードが、"1":E-PON の場合
				if ("1".equals(pon_sbt_cd))
				{
					return false;
				}
			}
			
			
			// ■接続機器情報チェック（Ｖ−ＯＮＵ機器）
			
			// TVコースグループコード
			String tv_course_grp_cd = (String)ekk0791A010_childMap.get("tv_course_grp_cd");
			
			// TVコースグループコードが、"0":SD の場合
			if ("0".equals(tv_course_grp_cd))
			{
				// TODO 宅内機器形式マスタのＶＯＮＵＢＳパススルー可否の項目取得は無駄となるので、現状はペンディング
			}
			
			
			// ■契約状態チェック
			HashMap<String, Object> kksv041908_parentMap = (HashMap)irp.getData("KKSV041908SC");
			ArrayList ekk0081B006CBSMsg1List = (ArrayList)kksv041908_parentMap.get("EKK0081B006CBSMsg1List");
			
			// サービス契約ステータス
			String svc_kei_stat = "";
			if (ekk0081B006CBSMsg1List != null && ekk0081B006CBSMsg1List.size() != 0)
			{
				HashMap<String, Object> ekk0081B006_childMap = (HashMap)ekk0081B006CBSMsg1List.get(0);
				svc_kei_stat = (String)ekk0081B006_childMap.get("svc_kei_stat");
			}
			
			HashMap<String, Object> kksv0419work01_parentMap = (HashMap)irp.getData("KKSV0419WORK01");
			
			// 機器引継選択リスト
			ArrayList list = (ArrayList)kksv0419work01_parentMap.get("kiki_hktgi_select_list");
			
			// 引継元選択チェックボックスで選択された接続機器に対して、チェックを行う。
			for (int i = 0; i < list.size(); i++)
			{
				HashMap kksv0419work01_childMap = (HashMap)list.get(i);
				
				// 機器提供種別コード
				String kktk_sbt_cd = (String)kksv0419work01_childMap.get("kktk_sbt_cd");
				
				// 機器契約区分が”買取”（引継元の機器提供種別コードが"02":買取）で、
				// 契約状態が”キャンセル済”（引継元のサービス契約ステータスが"920":キャンセル済）の場合
				if("02".equals(kktk_sbt_cd) && "920".equals(svc_kei_stat))
				{
					return false;
				}
			}
			
		}
		catch (RequestParameterException e)
		{
			e.printStackTrace();
			throw new ReqChkException(e.getMessage(), e);
		}

		return blnRet;
	}

}
