/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：料金コース_オプションサービス照会可否判定部品
*   ソースファイル名：JFUFUSV008101ReqChk.java
*   作成者          ：富士通
*   日付            ：2011年11月08日
*＜機能概要＞
*	eo光電話サービス契約情報一覧照会サービスインターフェイスの処理結果を元に、
*	料金コース_オプションサービス一覧照会の実行可否判定を行なう。
*
*	eo光電話サービス契約情報一覧照会サービスインターフェイスの処理結果が0件の場合は、
*	料金コース_オプションサービス一覧照会の検索キーとなる料金コースコードが取得できない為、
*	本実行判定部品にて料金コース_オプションサービス一覧照会の実行をスキップさせる。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/11/08	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;

/**
 * FUSV0042_2番号サービスお申し込み(申込)：番ポ可否判定部品
 * <br>
 * @author 富士通
 */
public class JFUFUSV008101ReqChk extends AbstractCustomReqChk
{

	/**
	 * 料金コース_オプションサービス照会可否判定処理
	 * <br/>
	 * @param  irp            (I)リクエストパラメータ操作クラス
	 * @param  conditionvalue (I)判定値格納クラス
	 * @return 料金コース_オプションサービスの照会が可能であればtrueを返す。
	 * @throws ReqChkException
	 */
	@Override
	public boolean checkExecution(IRequestParameterReadOnly irp, IConditionValue conditionvalue) throws ReqChkException
	{
		try
		{
			// eo光電話サービス契約情報一覧照会マップを取得
			HashMap<String, Object> parentMap = (HashMap<String, Object>)irp.getData("FUSV008101SC");

			if (parentMap == null)
			{
				return false;
			}

			// 検索エラーフラグを取得
			if (parentMap.containsKey("search_err_flg"))
			{
				String searchErrFlg = (String)parentMap.get("search_err_flg");

				// 検索件数が0件の場合は料金コース_オプションサービス照会不可とみなす。
				if ("1".equals(searchErrFlg))
				{
					return false;
				}
			}

			// 番ポ可能エリア一意照会明細を取得
			if (parentMap.containsKey("EKK0081B508CBSMsg1List"))
			{
				ArrayList msgList = (ArrayList)parentMap.get("EKK0081B508CBSMsg1List");

				// 検索結果レコードが1件以上ある場合は、料金コース_オプションサービス照会可とみなす。
				if (msgList.size() > 0)
				{
					return true;
				}
			}

			// その他は料金コース_オプションサービス照会不可とみなす。
			return false;

		}
		catch (RequestParameterException e)
		{
			throw new ReqChkException(e.getMessage(), e);
		}
	}
}
