/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKKoshumoTlnMatCfm
*	ソースファイル名	：JBSbatKKKoshumoTlnMatCfm.java
*	作成者				：富士通　
*	作成日				：2011年10月14日
*＜機能概要＞
*　公衆網電話番号整合性確認部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/10/14   富士通		新規作成
*********************************************************************/
package eo.business.service;

import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.util.file.JBSbatKKIFE021;
import eo.business.util.file.JBSbatKKIFM153;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.util.JBSbatCheckUtil;

/**
* ＳＩＰ情報（公衆網電話番号）とeo顧客基幹システムの登録情報を元に登録者の整合性確認処理を行う。<br>
*<BR>
* @author 富士通
*/
public class JBSbatKKKoshumoTlnMatCfm extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(オプションサービス契約)*/
	private static final String D_TBL_NAME_KK_T_OP_SVC_KEI = "KK_T_OP_SVC_KEI";

	/** SQL定義キー(KK_SELECT_033)*/
	private static final String KK_T_OP_SVC_KEI_KK_SELECT_033 = "KK_SELECT_033";

	/** テーブルアクセスクラス(オプションサービス契約)*/
	private JBSbatSQLAccess db_KK_T_OP_SVC_KEI = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/** エラー内容（公衆網電話番号登録状態にて不整合） */
	private static final String ERR_NAIYO_MESSAGE = "公衆網電話番号登録状態にて不整合";

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KK_T_OP_SVC_KEI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_OP_SVC_KEI);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// 入力レコードに異常があった場合
		if (inMap.isInputErrorFlg())
		{
			// 業務エラーログ出力
			super.logPrint.printBusinessErrorLog("EKKB0100AE", new String[] {"公衆網電話番号履歴情報ファイル"});
			// エラーフラグ設定
			super.commonItem.setErrFlg(true);
			return null;
		}
		// 単項目チェック関数呼出
		if (!isSingleCheckKKIFE021_INF1(inMap.getMap(), getItemvalueMapForKKIFE021()))
		{
			// エラーフラグ設定
			super.commonItem.setErrFlg(true);
			// 出力情報を返却
			return new JBSbatOutputItem();
		}

		// 整合性チェックエラーログ用
		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();

		// ファイル出力アイテム
		JBSbatOutputItem outItem = new JBSbatOutputItem();

		// 公衆網電話番号
		String koshumoTelno = inMap.getString(JBSbatKKIFE021.KOSHUMO_TELNO);
		
		// サービス契約番号
		String svcKeiNo = inMap.getString(JBSbatKKIFE021.SVC_KEI_NO);

		// VoIPユーザID
		String voipUserId = inMap.getString(JBSbatKKIFE021.VOIP_USER_ID);

		// 運用日（予約適用年月日との比較）
		String useDate = super.opeDate;

		Object[] opSvcKeiParam = {
				voipUserId,
				koshumoTelno,
				svcKeiNo,
				useDate
		};

		executeKK_T_OP_SVC_KEI_KK_SELECT_033(opSvcKeiParam);

		JBSbatCommonDBInterface opSvcKeiMap = db_KK_T_OP_SVC_KEI.selectNext();

		// 当該キーがオプションサービス契約／オプションサービス契約＜ＩＳＰ＞に存在しない場合
		if(opSvcKeiMap == null)
		{
			// サービス契約番号
			outMap.setString(JBSbatKKIFM153.SVC_KEI_NO, inMap.getString(JBSbatKKIFE021.SVC_KEI_NO));

			// VoIPユーザID
			outMap.setString(JBSbatKKIFM153.VOIP_USER_ID, inMap.getString(JBSbatKKIFE021.VOIP_USER_ID));

			// 登録状態
			outMap.setString(JBSbatKKIFM153.ADD_STAT, "");

			// eoオプション
			outMap.setString(JBSbatKKIFM153.EO_OP, "");

			// エラー内容
			outMap.setString(JBSbatKKIFM153.ERR_NAIYO, ERR_NAIYO_MESSAGE);

			// 処理日時
			outMap.setString(JBSbatKKIFM153.TRAN_DATE, inMap.getString(JBSbatKKIFE021.SHR_DTM));

			// １レコードを保存
			outMap.setOutFlg(true);
			outItem.addOutMapList(outMap);

			return outItem;
		}

		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KK_T_OP_SVC_KEI.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/

	/**
	 *入力情報（公衆網電話番号履歴情報ファイル）の単項目チェックを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.単項目チェックを行います。<br>
	 * 
	 * 2.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		rsMap:(項目、値)を(key、value)として、データをrsMapに入れます
	 *		itemvalueMap:埋め込み文字の値をitemvalueMapに入れます。キーの値は、以下に説明します。
	 *			 TXT-KKIFE021-INF1.SVC_KEI_NO			公衆網電話番号履歴情報ファイル.サービス契約番号
	 *			 TXT-KKIFE021-INF1.SVC_KEI_NO			公衆網電話番号履歴情報ファイル.サービス契約番号
	 *			 TXT-KKIFE021-INF1.SVC_KEI_NO			公衆網電話番号履歴情報ファイル.サービス契約番号
	 *			 TXT-KKIFE021-INF1.VOIP_USER_ID			公衆網電話番号履歴情報ファイル.ＶｏＩＰユーザＩＤ
	 *			 TXT-KKIFE021-INF1.VOIP_USER_ID			公衆網電話番号履歴情報ファイル.ＶｏＩＰユーザＩＤ
	 *			 TXT-KKIFE021-INF1.KOSHUMO_TELNO			公衆網電話番号履歴情報ファイル.公衆網電話番号
	 *			 TXT-KKIFE021-INF1.KOSHUMO_TELNO			公衆網電話番号履歴情報ファイル.公衆網電話番号
	 *			 TXT-KKIFE021-INF1.KOSHUMO_TELNO			公衆網電話番号履歴情報ファイル.公衆網電話番号
	 * </pre>
	 * <p>
	 * @param rsMap 入力データ（TXT又はDB）を格納されたHashMap。
	 * @param itemvalueMap エラーメッセージに関する項目値を格納されたHashMap。
	 * @return  boolean trueである場合、エラーがありません。falseである場合、エラーを発生しました。
	 */
	private boolean isSingleCheckKKIFE021_INF1(HashMap rsMap, HashMap itemvalueMap)
	{
		// 単項目チェックを行います
		String strValue = null;

		// サービス契約番号項目チェック
		strValue = (String)rsMap.get("SVC_KEI_NO");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFE021-INF1.SVC_KEI_NO")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "10"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFE021-INF1.SVC_KEI_NO")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFE021-INF1.SVC_KEI_NO")});
			return false;
		}

		// ＶｏＩＰユーザＩＤ項目チェック
		strValue = (String)rsMap.get("VOIP_USER_ID");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "16"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFE021-INF1.VOIP_USER_ID")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFE021-INF1.VOIP_USER_ID")});
			return false;
		}

		// 公衆網電話番号項目チェック
		strValue = (String)rsMap.get("KOSHUMO_TELNO");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFE021-INF1.KOSHUMO_TELNO")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "11"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFE021-INF1.KOSHUMO_TELNO")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"tel2"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFE021-INF1.KOSHUMO_TELNO")});
			return false;
		}

		return true;
	}

	/**
	 * SQLKEY(KK_SELECT_033)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	VoIPユーザーID
	 *		 	公衆網電話番号
	 *		 	サービス契約番号
	 *		 	予約適用年月日
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_OP_SVC_KEI_KK_SELECT_033(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());
		paramList.setValue(param[2].toString());
		paramList.setValue(param[3].toString());

		// DBアクセスを実行します
		db_KK_T_OP_SVC_KEI.selectBySqlDefine(paramList, KK_T_OP_SVC_KEI_KK_SELECT_033);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/

	/**
	 * 入力情報（公衆網電話番号履歴情報ファイル）の単項目チェック用<br>
	 * エラーメッセージに関する項目値を格納されたHashMap<String, String>を生成します。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.エラーメッセージに関する項目値を格納されたHashMapを生成する。<br>
	 *
	 * 2.エラーメッセージに関する項目値を格納されたHashMapに値を設定する。<br>
	 * </pre>
	 * <p>
	 * @return itemvalueMap エラーメッセージに関する項目値を格納されたHashMap
	 */
	private HashMap<String, String> getItemvalueMapForKKIFE021()
	{
		// エラーメッセージに関する項目値が格納されたHashMapを設定
		HashMap<String, String> itemvalue_Map = new HashMap<String, String>();
		itemvalue_Map.put("TXT-KKIFE021-INF1.SVC_KEI_NO",		"公衆網電話番号履歴情報ファイル.サービス契約番号");
		itemvalue_Map.put("TXT-KKIFE021-INF1.VOIP_USER_ID",		"公衆網電話番号履歴情報ファイル.ＶｏＩＰユーザＩＤ");
		itemvalue_Map.put("TXT-KKIFE021-INF1.KOSHUMO_TELNO",	"公衆網電話番号履歴情報ファイル.公衆網電話番号");

		return itemvalue_Map;
	}
}
