/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKMansRsvIfCheckCamp
*	ソースファイル名	：JBSbatKKMansRsvIfCheckCamp.java
*	作成者				：富士通　
*	作成日				：2012年05月23日
*＜機能概要＞
*　マンション受信情報チェック部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2012/05/23   富士通		新規作成
*	v46.00.00	2019/10/02   FJ)西窪	【ANK-3731-00-00】マンション光配線切替対応
*********************************************************************/
package eo.business.service;

import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.util.file.JBSbatKKIFM202;
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;
import eo.framework.util.JBSbatStringUtil;


/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatKKMansRsvIfCheckCamp extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(オーナー契約)*/
	private static final String D_TBL_NAME_KK_T_OWNR_KEI = "KK_T_OWNR_KEI";

	/** テーブル(回線使用契約)*/
	private static final String D_TBL_NAME_KK_T_KAISEN_USE_KEI = "KK_T_KAISEN_USE_KEI";

	/** テーブル(提供方式契約)*/
	private static final String D_TBL_NAME_KK_T_TK_HOSHIKI_KEI = "KK_T_TK_HOSHIKI_KEI";

	/** テーブル(コード名称管理)*/
	private static final String D_TBL_NAME_ZM_M_CD_NM_KANRI = "ZM_M_CD_NM_KANRI";

	/** テーブル(マンション割引サービス契約)*/
	private static final String D_TBL_NAME_KK_T_MANS_WRIBSVK = "KK_T_MANS_WRIBSVK";

	/** SQL定義キー(KK_SELECT_006)*/
	private static final String KK_T_OWNR_KEI_KK_SELECT_006 = "KK_SELECT_006";

	/** SQL定義キー(KK_SELECT_008)*/
	private static final String KK_T_KAISEN_USE_KEI_KK_SELECT_008 = "KK_SELECT_008";

	/** SQL定義キー(KK_SELECT_009)*/
	private static final String KK_T_KAISEN_USE_KEI_KK_SELECT_009 = "KK_SELECT_009";

	/** SQL定義キー(KK_SELECT_004)*/
	private static final String KK_T_TK_HOSHIKI_KEI_KK_SELECT_004 = "KK_SELECT_004";

	/** SQL定義キー(KK_SELECT_005)*/
	private static final String KK_T_TK_HOSHIKI_KEI_KK_SELECT_005 = "KK_SELECT_005";

	/** SQL定義キー(KK_SELECT_003)*/
	private static final String ZM_M_CD_NM_KANRI_KK_SELECT_003 = "KK_SELECT_003";

	/** SQL定義キー(KK_SELECT_001)*/
	private static final String KK_T_MANS_WRIBSVK_KK_SELECT_001 = "KK_SELECT_001";

	/** テーブルアクセスクラス(オーナー契約)*/
	private JBSbatSQLAccess db_KK_T_OWNR_KEI = null;

	/** テーブルアクセスクラス(回線使用契約)*/
	private JBSbatSQLAccess db_KK_T_KAISEN_USE_KEI = null;

	/** テーブルアクセスクラス(提供方式契約)*/
	private JBSbatSQLAccess db_KK_T_TK_HOSHIKI_KEI = null;

	/** テーブルアクセスクラス(コード名称管理)*/
	private JBSbatSQLAccess db_ZM_M_CD_NM_KANRI = null;

	/** テーブルアクセスクラス(マンション割引サービス契約)*/
	private JBSbatSQLAccess db_KK_T_MANS_WRIBSVK = null;
	
	// ANK-3731-00-00 ADD START
	/** 提供方式パターンコード（50 光配線） */
	private static final String TK_HSK_PTN_CD_50 = "50";
	/** 提供方式パターンコード（52 光配線 1Gのみ） */
	private static final String TK_HSK_PTN_CD_52 = "52";
	/** 退避_提供方式パターンコード */
	private String tiH_tkHskPtnCd = "";
	// ANK-3731-00-00 ADD END

	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KK_T_OWNR_KEI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_OWNR_KEI);
		db_KK_T_KAISEN_USE_KEI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_KAISEN_USE_KEI);
		db_KK_T_TK_HOSHIKI_KEI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_TK_HOSHIKI_KEI);
		db_ZM_M_CD_NM_KANRI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_ZM_M_CD_NM_KANRI);
		db_KK_T_MANS_WRIBSVK = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_MANS_WRIBSVK);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// 出力共通電文を生成する。
		JBSbatOutputItem outputBean = new JBSbatOutputItem();
		
		// ANK-3731-00-00 ADD START
		// 置換前の提供方式パターンコードを退避_提供方式パターンコードに格納し、
		// 提供方式パターンコードを'52'の場合'50'に置換する
		tiH_tkHskPtnCd = inMap.getString(JBSbatKKIFM202.TK_HSK_PTN_CD);
		String tkHskPtnCd = inMap.getString(JBSbatKKIFM202.TK_HSK_PTN_CD);
		if (TK_HSK_PTN_CD_52.equals(tkHskPtnCd))
		{	
			inMap.set(JBSbatKKIFM202.TK_HSK_PTN_CD, TK_HSK_PTN_CD_50); 
		}
		// ANK-3731-00-00 ADD END
		
		// 単項目チェック(レイアウトチェック)
		if(!isSingleCheckKKIFM202_INF1(inMap.getMap(), getItemvalueMap()))
		{
			outputBean.addOutMapList_2(setRcvInfo(inMap));
			return outputBean;
		}
		//存在チェック
		if(!checkExist(inMap))
		{
			outputBean.addOutMapList_2(setRcvInfo(inMap));
			return outputBean;
		}
		//相関チェック
		if(!checkCorrelation(inMap))
		{
			outputBean.addOutMapList_2(setRcvInfo(inMap));
			return outputBean;
		}

		outputBean.addOutMapList(setRcvInfo(inMap));
		return outputBean;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KK_T_OWNR_KEI.close();
		db_KK_T_KAISEN_USE_KEI.close();
		db_KK_T_TK_HOSHIKI_KEI.close();
		db_ZM_M_CD_NM_KANRI.close();
		db_KK_T_MANS_WRIBSVK.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 *入力情報（マンションキャンペーン情報作成）の単項目チェックを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.単項目チェックを行います。<br>
	 * 
	 * 2.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		rsMap:(項目、値)を(key、value)として、データをrsMapに入れます
	 *		itemvalueMap:埋め込み文字の値をitemvalueMapに入れます。キーの値は、以下に説明します。
	 *			 TXT-KKIFM202-INF1.TRAN_DIV			マンションキャンペーン情報作成.処理区分
	 *			 TXT-KKIFM202-INF1.TRAN_DIV			マンションキャンペーン情報作成.処理区分
	 *			 TXT-KKIFM202-INF1.TRAN_DIV			マンションキャンペーン情報作成.処理区分
	 *			 TXT-KKIFM202-INF1.P_ID			マンションキャンペーン情報作成.Ｐ−ＩＤ
	 *			 TXT-KKIFM202-INF1.P_ID			マンションキャンペーン情報作成.Ｐ−ＩＤ
	 *			 TXT-KKIFM202-INF1.P_ID			マンションキャンペーン情報作成.Ｐ−ＩＤ
	 *			 TXT-KKIFM202-INF1.BKN_KNRI_NO			マンションキャンペーン情報作成.物件管理番号
	 *			 TXT-KKIFM202-INF1.BKN_KNRI_NO			マンションキャンペーン情報作成.物件管理番号
	 *			 TXT-KKIFM202-INF1.BKN_KNRI_NO			マンションキャンペーン情報作成.物件管理番号
	 *			 TXT-KKIFM202-INF1.M_ID			マンションキャンペーン情報作成.Ｍ−ＩＤ
	 *			 TXT-KKIFM202-INF1.M_ID			マンションキャンペーン情報作成.Ｍ−ＩＤ
	 *			 TXT-KKIFM202-INF1.M_ID			マンションキャンペーン情報作成.Ｍ−ＩＤ
	 *			 TXT-KKIFM202-INF1.PAIR_ID			マンションキャンペーン情報作成.ペアＩＤ
	 *			 TXT-KKIFM202-INF1.PAIR_ID			マンションキャンペーン情報作成.ペアＩＤ
	 *			 TXT-KKIFM202-INF1.PAIR_ID			マンションキャンペーン情報作成.ペアＩＤ
	 *			 TXT-KKIFM202-INF1.CAT_M_KANRI_NO			マンションキャンペーン情報作成.Ｃａｔ−Ｍ管理番号
	 *			 TXT-KKIFM202-INF1.CAT_M_KANRI_NO			マンションキャンペーン情報作成.Ｃａｔ−Ｍ管理番号
	 *			 TXT-KKIFM202-INF1.CAT_M_KANRI_NO			マンションキャンペーン情報作成.Ｃａｔ−Ｍ管理番号
	 *			 TXT-KKIFM202-INF1.TK_HSK_PTN_CD			マンションキャンペーン情報作成.提供方式パターンコード
	 *			 TXT-KKIFM202-INF1.TK_HSK_PTN_CD			マンションキャンペーン情報作成.提供方式パターンコード
	 *			 TXT-KKIFM202-INF1.TK_HSK_PTN_CD			マンションキャンペーン情報作成.提供方式パターンコード
	 *			 TXT-KKIFM202-INF1.CMP_NM			マンションキャンペーン情報作成.キャンペーン名
	 *			 TXT-KKIFM202-INF1.CMP_NM			マンションキャンペーン情報作成.キャンペーン名
	 *			 TXT-KKIFM202-INF1.CMP_PTN_NM			マンションキャンペーン情報作成.キャンペーンパターン名
	 *			 TXT-KKIFM202-INF1.CMP_PTN_NM			マンションキャンペーン情報作成.キャンペーンパターン名
	 *			 TXT-KKIFM202-INF1.CMP_PTN_CD			マンションキャンペーン情報作成.キャンペーンパターンコード
	 *			 TXT-KKIFM202-INF1.CMP_PTN_CD			マンションキャンペーン情報作成.キャンペーンパターンコード
	 *			 TXT-KKIFM202-INF1.CMP_SBT_NM			マンションキャンペーン情報作成.キャンペーン種別名
	 *			 TXT-KKIFM202-INF1.CMP_SBT_NM			マンションキャンペーン情報作成.キャンペーン種別名
	 *			 TXT-KKIFM202-INF1.MKM_JKN			マンションキャンペーン情報作成.申込条件
	 *			 TXT-KKIFM202-INF1.MKM_JKN			マンションキャンペーン情報作成.申込条件
	 *			 TXT-KKIFM202-INF1.MKM_STA_DAY			マンションキャンペーン情報作成.申込開始日付
	 *			 TXT-KKIFM202-INF1.MKM_STA_DAY			マンションキャンペーン情報作成.申込開始日付
	 *			 TXT-KKIFM202-INF1.MKM_END_DAY			マンションキャンペーン情報作成.申込終了日付
	 *			 TXT-KKIFM202-INF1.MKM_END_DAY			マンションキャンペーン情報作成.申込終了日付
	 *			 TXT-KKIFM202-INF1.PPLN_KAITORI_CP_CD			マンションキャンペーン情報作成.料金プラン（買取）ＣＰコード
	 *			 TXT-KKIFM202-INF1.PPLN_KAITORI_CP_CD			マンションキャンペーン情報作成.料金プラン（買取）ＣＰコード
	 *			 TXT-KKIFM202-INF1.PPLN_RENT_CP_CD			マンションキャンペーン情報作成.料金プラン（レンタル）ＣＰコード
	 *			 TXT-KKIFM202-INF1.PPLN_RENT_CP_CD			マンションキャンペーン情報作成.料金プラン（レンタル）ＣＰコード
	 *			 TXT-KKIFM202-INF1.CMP_CD			マンションキャンペーン情報作成.キャンペーンコード
	 *			 TXT-KKIFM202-INF1.CMP_CD			マンションキャンペーン情報作成.キャンペーンコード
	 * </pre>
	 * <p>
	 * @param rsMap 入力データ（TXT又はDB）を格納されたHashMap。
	 * @param itemvalueMap エラーメッセージに関する項目値を格納されたHashMap。
	 * @return  boolean trueである場合、エラーがありません。falseである場合、エラーを発生しました。
	 */
	private boolean isSingleCheckKKIFM202_INF1(HashMap rsMap, HashMap itemvalueMap)
	{
		// 単項目チェックを行います
		String strValue = null;
		String row = String.valueOf(commonItem.getInputCount());	//行数取得
		String pid = (String)rsMap.get("P-ID");	//PID
		boolean rslt = true;
		// 処理区分項目チェック
		strValue = (String)rsMap.get("TRAN_DIV");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			outErrLog(1, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.TRAN_DIV"));
  			rslt = false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "1"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.TRAN_DIV"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakusuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.TRAN_DIV"));
  			rslt = false;
		}

		// Ｐ−ＩＤ項目チェック
		strValue = (String)rsMap.get("P-ID");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			outErrLog(1, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.P_ID"));
  			rslt = false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "10"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.P_ID"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.P_ID"));
  			rslt = false;
		}

		// 物件管理番号項目チェック
		strValue = (String)rsMap.get("BKN_KNRI_NO");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			outErrLog(1, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.BKN_KNRI_NO"));
  			rslt = false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "6"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.BKN_KNRI_NO"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.BKN_KNRI_NO"));
  			rslt = false;
		}

		// Ｍ−ＩＤ項目チェック
		strValue = (String)rsMap.get("M-ID");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "10"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.M-ID"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.M-ID"));
  			rslt = false;
		}

		// ペアＩＤ項目チェック
		strValue = (String)rsMap.get("PAIR_ID");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "10"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.PAIR_ID"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.PAIR_ID"));
  			rslt = false;
		}

		// Ｃａｔ−Ｍ管理番号項目チェック
		strValue = (String)rsMap.get("CAT_M_KANRI_NO");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "10"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CAT_M_KANRI_NO"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CAT_M_KANRI_NO"));
  			rslt = false;
		}

		// 提供方式パターンコード項目チェック
		strValue = (String)rsMap.get("TK_HSK_PTN_CD");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			outErrLog(1, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.TK_HSK_PTN_CD"));
  			rslt = false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "2"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.TK_HSK_PTN_CD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.TK_HSK_PTN_CD"));
  			rslt = false;
		}

		// キャンペーン名項目チェック
		strValue = (String)rsMap.get("CMP_NM");
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"zenkaku"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CMP_NM"));
  			rslt = false;
		}

		// キャンペーンパターン名項目チェック
		strValue = (String)rsMap.get("CMP_PTN_NM");
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"zenkaku"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CMP_PTN_NM"));
  			rslt = false;
		}

		// キャンペーンパターンコード項目チェック
		strValue = (String)rsMap.get("CMP_PTN_CD");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "3"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CMP_PTN_CD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CMP_PTN_CD"));
  			rslt = false;
		}

		// キャンペーン種別名項目チェック
		strValue = (String)rsMap.get("CMP_SBT_NM");
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"zenkaku"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CMP_SBT_NM"));
  			rslt = false;
		}

		// 申込条件項目チェック
		strValue = (String)rsMap.get("MKM_JKN");
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"zenkaku"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.MKM_JKN"));
  			rslt = false;
		}

		// 申込開始日付項目チェック
		strValue = (String)rsMap.get("MKM_STA_DAY");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "8"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.MKM_STA_DAY"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"year_month_day1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.MKM_STA_DAY"));
  			rslt = false;
		}

		// 申込終了日付項目チェック
		strValue = (String)rsMap.get("MKM_END_DAY");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "8"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.MKM_END_DAY"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"year_month_day1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.MKM_END_DAY"));
  			rslt = false;
		}

		// 料金プラン（買取）ＣＰコード項目チェック
		strValue = JBSbatStringUtil.trim((String)rsMap.get("PPLN_KAITORI_CP_CD"));
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "8"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.PPLN_KAITORI_CP_CD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.PPLN_KAITORI_CP_CD"));
  			rslt = false;
		}

		// 料金プラン（レンタル）ＣＰコード項目チェック
		strValue = (String)rsMap.get("PPLN_RENT_CP_CD");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "8"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.PPLN_RENT_CP_CD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.PPLN_RENT_CP_CD"));
  			rslt = false;
		}

		// キャンペーンコード項目チェック
		strValue = (String)rsMap.get("CMP_CD");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "8"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CMP_CD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM202-INF1.CMP_CD"));
  			rslt = false;
		}

		return rslt;
	}

	/**
	 * エラーメッセージに関する項目値を格納されたHashMap<String, String>を生成します。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.エラーメッセージに関する項目値を格納されたHashMapを生成する。<br>
	 *
	 * 2.エラーメッセージに関する項目値を格納されたHashMapに値を設定する。<br>
	 * </pre>
	 * <p>
	 * @return itemvalueMap エラーメッセージに関する項目値を格納されたHashMap
	 */
	private HashMap<String, String> getItemvalueMap()
	{
		// エラーメッセージに関する項目値が格納されたHashMapを設定
		HashMap<String, String> itemvalueMap = new HashMap<String, String>();
		itemvalueMap.put("TXT-KKIFM202-INF1.TRAN_DIV", "処理区分");
		itemvalueMap.put("TXT-KKIFM202-INF1.P_ID", "Ｐ−ＩＤ");
		itemvalueMap.put("TXT-KKIFM202-INF1.BKN_KNRI_NO", "物件管理番号");
		itemvalueMap.put("TXT-KKIFM202-INF1.M-ID", "Ｍ−ＩＤ");
		itemvalueMap.put("TXT-KKIFM202-INF1.PAIR_ID", "ペアＩＤ");
		itemvalueMap.put("TXT-KKIFM202-INF1.CAT_M_KANRI_NO", "Cat-ID");
		itemvalueMap.put("TXT-KKIFM202-INF1.TK_HSK_PTN_CD", "提供方式パターンコード");
		itemvalueMap.put("TXT-KKIFM202-INF1.CMP_NM", "キャンペーン名");
		itemvalueMap.put("TXT-KKIFM202-INF1.CMP_PTN_NM", "キャンペーンパターン名");
		itemvalueMap.put("TXT-KKIFM202-INF1.CMP_PTN_CD", "キャンペーンパターンコード");

		itemvalueMap.put("TXT-KKIFM202-INF1.CMP_NYO", "キャンペーン内容");
		itemvalueMap.put("TXT-KKIFM202-INF1.CMP_SBT_NM", "キャンペーン種別名");
		itemvalueMap.put("TXT-KKIFM202-INF1.MKM_JKN", "申込条件");
		itemvalueMap.put("TXT-KKIFM202-INF1.MKM_STA_DAY", "申込開始日付");
		itemvalueMap.put("TXT-KKIFM202-INF1.MKM_END_DAY", "申込終了日付");
		itemvalueMap.put("TXT-KKIFM202-INF1.MKM_TKJK", "申込特記事項");
		itemvalueMap.put("TXT-KKIFM202-INF1.PPLN_KAITORI_CP_CD", "料金プラン（買取）ＣＰコード");
		itemvalueMap.put("TXT-KKIFM202-INF1.PPLN_RENT_CP_CD", "料金プラン（レンタル）ＣＰコード");
		itemvalueMap.put("TXT-KKIFM202-INF1.CMP_CD", "キャンペーンコード");

		return itemvalueMap;
	}

	/**
	 * SQLKEY(KK_SELECT_003)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	コード種別コード
	 *		 	コード区分
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeZM_M_CD_NM_KANRI_KK_SELECT_003(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());

		// DBアクセスを実行します
		db_ZM_M_CD_NM_KANRI.selectBySqlDefine(paramList, ZM_M_CD_NM_KANRI_KK_SELECT_003);
	}

	/**
	 * SQLKEY(KK_SELECT_001)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	マンションキャンぺーンコード
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_MANS_WRIBSVK_KK_SELECT_001(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());
		paramList.setValue(param[2].toString());
		// DBアクセスを実行します
		db_KK_T_MANS_WRIBSVK.selectBySqlDefine(paramList, KK_T_MANS_WRIBSVK_KK_SELECT_001);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/

	//処理区分の整合性チェック
	private boolean checkExist(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		if("2".equals(inMap.getString(JBSbatKKIFM202.TRAN_DIV))||
				"3".equals(inMap.getString(JBSbatKKIFM202.TRAN_DIV)))
		{
			//更新・削除はマンション割引サービス契約の存在チェック
			if(!checkManWrbkSvcCnt(inMap))
			{
				return notFoundError(inMap, "マンション割引サービス契約");
			}
		}
		return true;
	}

	//P-IDに紐づくマンション割引サービス契約の存在チェック
	private boolean checkManWrbkSvcCnt(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		String pid = inMap.getString(JBSbatKKIFM202.P_ID);
		//キャンペーンCD DBは８桁
		String campCd = JBSbatStringUtil.adjustCharSize(
				inMap.getString(JBSbatKKIFM202.CMP_CD), 8, "");
		String campPtn = inMap.getString(JBSbatKKIFM202.CMP_PTN_CD);

		executeKK_T_MANS_WRIBSVK_KK_SELECT_001(new String[]{pid, campCd, campPtn});
		JBSbatCommonDBInterface dataMap = db_KK_T_MANS_WRIBSVK.selectNext();
		if (null == dataMap || 1 > Integer.parseInt(dataMap.getString("CNT")))
		{
			return false;
		}
		return true;
	}

	//相関チェック
	private boolean checkCorrelation(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		//提供方式パターンコード 2桁  0717
		if(!checkCdNmKnrCnt(inMap.getString(JBSbatKKIFM202.P_ID),
				"CD01213", inMap.getString(JBSbatKKIFM202.TK_HSK_PTN_CD), "提供方式パターンコード"))
		{
			return false;
		}

		if(!checkMansWrbkSvcCnt(inMap.getString(JBSbatKKIFM202.CMP_CD)))
		{
			return false;
		}
		return true;
	}

	//コード名称管理 件数検索
	private boolean checkCdNmKnrCnt(String key, String cdSbt, 
			String cdDiv, String cdSbtNm) throws Exception
	{
		String[] param = {cdSbt, cdDiv};
		executeZM_M_CD_NM_KANRI_KK_SELECT_003(param);
		JBSbatCommonDBInterface dataMap = db_ZM_M_CD_NM_KANRI.selectNext();

		if (null == dataMap || 1 > Integer.parseInt(dataMap.getString("CNT")))
		{
			//送信されたコード値の値に誤りがあります。（key：%1%　コード名：%2%　値：%3%）
			commonItem.getLogPrint().printBusinessErrorLog(
					"EKKB0610NW", new String[]{key, cdSbtNm, cdDiv});
			return false;
		}
		return true;
	}

	//マンション割引サービス 件数検索
	private boolean checkMansWrbkSvcCnt(String campCd) throws Exception
	{
		if(campCd == null || "".equals(campCd))
		{
			return true;
		}

		//コメントでok 仕様確認中 8/8
//		executeKK_T_MANS_WRIBSVK_KK_SELECT_001(new String[]{campCd});
//		JBSbatCommonDBInterface dataMap = db_KK_T_MANS_WRIBSVK.selectNext();

//		if ( null == dataMap|| 1 > Integer.parseInt(dataMap.getString("CNT")))
//		{
//			return false;
//		}

		return true;
	}

	//ファイル情報をセット
	private JBSbatServiceInterfaceMap setRcvInfo(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();
		outMap.set(JBSbatKKIFM202.TRAN_DIV, inMap.getString(JBSbatKKIFM202.TRAN_DIV));
		outMap.set(JBSbatKKIFM202.P_ID, inMap.getString(JBSbatKKIFM202.P_ID));
		outMap.set(JBSbatKKIFM202.BKN_KNRI_NO, inMap.getString(JBSbatKKIFM202.BKN_KNRI_NO));
		outMap.set(JBSbatKKIFM202.M_ID, inMap.getString(JBSbatKKIFM202.M_ID));
		outMap.set(JBSbatKKIFM202.PAIR_ID, inMap.getString(JBSbatKKIFM202.PAIR_ID));
		outMap.set(JBSbatKKIFM202.CAT_M_KANRI_NO, inMap.getString(JBSbatKKIFM202.CAT_M_KANRI_NO));
		outMap.set(JBSbatKKIFM202.TK_HSK_PTN_CD, inMap.getString(JBSbatKKIFM202.TK_HSK_PTN_CD));
		outMap.set(JBSbatKKIFM202.CMP_NM, subStringTrgt(121, inMap.getString(JBSbatKKIFM202.CMP_NM)));
		outMap.set(JBSbatKKIFM202.CMP_PTN_NM, subStringTrgt(121, inMap.getString(JBSbatKKIFM202.CMP_PTN_NM)));
		outMap.set(JBSbatKKIFM202.CMP_PTN_CD, inMap.getString(JBSbatKKIFM202.CMP_PTN_CD));

		outMap.set(JBSbatKKIFM202.CMP_NYO, subStringTrgt(2000, inMap.getString(JBSbatKKIFM202.CMP_NYO)));
		outMap.set(JBSbatKKIFM202.CMP_SBT_NM, subStringTrgt(121, inMap.getString(JBSbatKKIFM202.CMP_SBT_NM)));
		outMap.set(JBSbatKKIFM202.MKM_JKN, subStringTrgt(240, inMap.getString(JBSbatKKIFM202.MKM_JKN)));
		outMap.set(JBSbatKKIFM202.MKM_STA_DAY, inMap.getString(JBSbatKKIFM202.MKM_STA_DAY));
		outMap.set(JBSbatKKIFM202.MKM_END_DAY, inMap.getString(JBSbatKKIFM202.MKM_END_DAY));
		outMap.set(JBSbatKKIFM202.MKM_TKJK, subStringTrgt(2000, inMap.getString(JBSbatKKIFM202.MKM_TKJK)));
		outMap.set(JBSbatKKIFM202.PPLN_KAITORI_CP_CD, inMap.getString(JBSbatKKIFM202.PPLN_KAITORI_CP_CD));
		outMap.set(JBSbatKKIFM202.PPLN_RENT_CP_CD, inMap.getString(JBSbatKKIFM202.PPLN_RENT_CP_CD));
		outMap.set(JBSbatKKIFM202.CMP_CD, inMap.getString(JBSbatKKIFM202.CMP_CD));
		// ANK-3731-00-00 ADD START
		outMap.set(JBSbatKKIFM202.TAIHI_TK_HSK_PTN_CD, tiH_tkHskPtnCd);
		// ANK-3731-00-00 ADD END
		outMap.setOutFlg(true);
		return outMap;
	}

	//指定文字数以上の場合、切り捨てる
	private String subStringTrgt(int length, String target) {
		String rslt = target;

		if(target == null)
		{
			return rslt;
		}
		
		if(length < target.length())
		{
			rslt = target.substring(0, length);
		}
		return rslt;
	}

	//エラーログ出力
	private boolean existError(JBSbatServiceInterfaceMap inMap, String tblNm) throws Exception
	{
		//処理区分の値とDBの内容に不整合があります。（テーブル名：%1%　行数：%2%　key：%3%）
		commonItem.getLogPrint().printBusinessErrorLog("EKKB0570NW", 
				new String[]{tblNm, String.valueOf(commonItem.getInputCount()), 
				getKeyLog(inMap, tblNm) + " P-ID:" + inMap.getString(JBSbatKKIFM202.P_ID)});
		return false;
	}

	//エラーログ出力
	private boolean notFoundError(JBSbatServiceInterfaceMap inMap, String tblNm) throws Exception
	{
		//%1%テーブルに%2%が存在しません。（key：%3%）
		commonItem.getLogPrint().printBusinessErrorLog("EKKB0630NW", 
				new String[]{tblNm, getKeyLog(inMap, tblNm), 
				"P-ID:" + inMap.getString(JBSbatKKIFM202.P_ID) +
				" 処理区分:" + inMap.getString(JBSbatKKIFM202.TRAN_DIV)});
		return false;
	}

	//ログ出力用
	private String getKeyLog(JBSbatServiceInterfaceMap inMap, String tblNm) throws Exception
	{
		String key = "";
		if("オーナー契約".equals(tblNm))
		{
			key = "P-ID:" + inMap.getString(JBSbatKKIFM202.P_ID);
		}
		else if("回線使用契約".equals(tblNm))
		{
			key = "物件管理番号:" +  inMap.getString(JBSbatKKIFM202.BKN_KNRI_NO);
		}else if("マンション割引サービス契約".equals(tblNm))
		{
			key = "キャンペーンCD:" + inMap.getString(JBSbatKKIFM202.CMP_CD) +
			" キャンペーンパターンCD:" + inMap.getString(JBSbatKKIFM202.CMP_PTN_CD);
		}
		else
		{
			if(!"".equals(inMap.getString(JBSbatKKIFM202.M_ID)))
			{
				key = "M-ID:" + inMap.getString(JBSbatKKIFM202.M_ID); 
			}
			else if(!"".equals(inMap.getString(JBSbatKKIFM202.CAT_M_KANRI_NO)))
			{
				key = "Cat-ID:" + inMap.getString(JBSbatKKIFM202.CAT_M_KANRI_NO);
			}

			if("提供方式契約".equals(tblNm))
			{
				key = key + " 提供方式パターンコード:" 
						+ inMap.getString(JBSbatKKIFM202.TK_HSK_PTN_CD);
			}
		}
		return key;
	}

	//エラーログ出力
	private void outErrLog(int mode, String row, String key)
	{
		String[] err = new String[]{row, "P-ID:" + key};
		if(1 == mode)//必須
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0580TW", err);
		}
		else if(2 == mode)//桁数
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0590TW", err);
		}else if(3 == mode)//属性
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0600TW", err);
		}
	}
}
