/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom					 *
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKCrdtAuthoriChk
*	ソースファイル名	：JBSbatKKCrdtAuthoriChk.java
*	作成者				：富士通　
*	作成日				：2011年06月24日
*＜機能概要＞
*　クレジットオーソリチェック部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/06/24   富士通		新規作成
*	v58.00.00	2022/04/26   FJ)南		【ANK-3846-00-00】【クレカ】クリアパス→ペイジェント移行
*********************************************************************/
package eo.business.service;

import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.business.util.file.JBSbatKKIFM008;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.util.JBSbatCheckUtil;
import eo.framework.util.JBSbatStringUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatKKCrdtAuthoriChk extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(クレジットオーソリ実績)*/
	private static final String D_TBL_NAME_KK_T_CREDIT_AUTH_JSK = "KK_T_CREDIT_AUTH_JSK";

	/** SQL定義キー(KK_UPDATE_001)*/
	private static final String KK_T_CREDIT_AUTH_JSK_KK_UPDATE_001 = "KK_UPDATE_001";

	/** SQL定義キー(KK_UPDATE_002)*/
	private static final String KK_T_CREDIT_AUTH_JSK_KK_UPDATE_002 = "KK_UPDATE_002";

	/** テーブルアクセスクラス(クレジットオーソリ実績)*/
	private JBSbatSQLAccess db_KK_T_CREDIT_AUTH_JSK = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KK_T_CREDIT_AUTH_JSK = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_CREDIT_AUTH_JSK);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		
		// 入力データ保持Mapを生成
		HashMap<String, String> rs_Map = inMap.getMap();
		
		// 単項目チェック関数呼出
		if (!isSingleCheckKKIFM008_INF1(rs_Map, getItemvalueMap()))
		{
			// エラーフラグ設定
			super.commonItem.setErrFlg(true);
			// 出力情報を返却
			return new JBSbatOutputItem();
		}
		
		// 処理結果コードの先頭から３桁を取得
		String result_Code_Head = inMap.getString(JBSbatKKIFM008.CR_RESULTCODE).substring(0, 3);
		
		// 処理結果コード判定用フラグ(初期値として異常を設定)
		boolean resultCodeStatus = false;
		
		if ("000".equals(result_Code_Head) || "001".equals(result_Code_Head))
		{
			// 処理結果コードが正常
			resultCodeStatus = true;
		}
		
		if (resultCodeStatus)
		{
			// SQL発行 SQLKEY(KK_UPDATE_001)
			executeKK_T_CREDIT_AUTH_JSK_KK_UPDATE_001(getUpdate001Param(inMap));
		}
		else
		{
			// SQL発行 SQLKEY(KK_UPDATE_002)
			executeKK_T_CREDIT_AUTH_JSK_KK_UPDATE_002(getUpdate002Param(inMap));
		}
		
		return new JBSbatOutputItem();
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	} 

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KK_T_CREDIT_AUTH_JSK.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	
	/**
	 *入力情報（クレジットオーソリ回答ファイル）の単項目チェックを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.単項目チェックを行います。<br>
	 * 
	 * 2.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		rsMap:(項目、値)を(key、value)として、データをrsMapに入れます
	 *		itemvalueMap:埋め込み文字の値をitemvalueMapに入れます。キーの値は、以下に説明します。
	 *			 TXT-KKIFM008-INF1.CR_resultCode			クレジットオーソリ回答ファイル.処理結果コード
	 *			 TXT-KKIFM008-INF1.CR_resultCode			クレジットオーソリ回答ファイル.処理結果コード
	 *			 TXT-KKIFM008-INF1.CR_resultCode			クレジットオーソリ回答ファイル.処理結果コード
	 *			 TXT-KKIFM008-INF1.CR_orderId			クレジットオーソリ回答ファイル.取引ＩＤ
	 *			 TXT-KKIFM008-INF1.CR_orderId			クレジットオーソリ回答ファイル.取引ＩＤ
	 *			 TXT-KKIFM008-INF1.CR_brandCode			クレジットオーソリ回答ファイル.仕向先カード会社コード
	 *			 TXT-KKIFM008-INF1.CR_brandCode			クレジットオーソリ回答ファイル.仕向先カード会社コード
	 *			 TXT-KKIFM008-INF1.CR_slipNumber			クレジットオーソリ回答ファイル.伝票番号
	 *			 TXT-KKIFM008-INF1.CR_slipNumber			クレジットオーソリ回答ファイル.伝票番号
	 *			 TXT-KKIFM008-INF1.CR_authNumber			クレジットオーソリ回答ファイル.オーソリ承認番号
	 *			 TXT-KKIFM008-INF1.CR_authNumber			クレジットオーソリ回答ファイル.オーソリ承認番号
	 *			 TXT-KKIFM008-INF1.CR_paidAmount			クレジットオーソリ回答ファイル.決済が行われた金額
	 *			 TXT-KKIFM008-INF1.CR_paidAmount			クレジットオーソリ回答ファイル.決済が行われた金額
	 *			 TXT-KKIFM008-INF1.CR_seqNo			クレジットオーソリ回答ファイル.シーケンス番号
	 *			 TXT-KKIFM008-INF1.CR_seqNo			クレジットオーソリ回答ファイル.シーケンス番号
	 *			 TXT-KKIFM008-INF1.CR_seqNo			クレジットオーソリ回答ファイル.シーケンス番号
	 *			 TXT-KKIFM008-INF1.CR_recSakseiDtm			クレジットオーソリ回答ファイル.レコード作成年月日時分秒
	 *			 TXT-KKIFM008-INF1.CR_recSakseiDtm			クレジットオーソリ回答ファイル.レコード作成年月日時分秒
	 *			 TXT-KKIFM008-INF1.CR_recSakseiDtm			クレジットオーソリ回答ファイル.レコード作成年月日時分秒
	 *			 TXT-KKIFM008-INF1.CR_paymentId			クレジットオーソリ回答ファイル.決済ID
	 *			 TXT-KKIFM008-INF1.CR_paymentId			クレジットオーソリ回答ファイル.決済ID
	 *			 TXT-KKIFM008-INF1.CR_responseCode		クレジットオーソリ回答ファイル.レスポンスコード
	 *			 TXT-KKIFM008-INF1.CR_responseCode		クレジットオーソリ回答ファイル.レスポンスコード
	 *			 TXT-KKIFM008-INF1.CR_responseDetail	クレジットオーソリ回答ファイル.レスポンス詳細
	 * </pre>
	 * <p>
	 * @param rsMap 入力データ（TXT又はDB）を格納されたHashMap。
	 * @param itemvalueMap エラーメッセージに関する項目値を格納されたHashMap。
	 * @return  boolean trueである場合、エラーがありません。falseである場合、エラーを発生しました。
	 */
	private boolean isSingleCheckKKIFM008_INF1(HashMap rsMap, HashMap itemvalueMap)
	{
		// 単項目チェックを行います
		String strValue = null;

		// 処理結果コード項目チェック
		strValue = (String)rsMap.get("CR_resultCode");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_resultCode")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "7"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_resultCode")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_resultCode")});
			return false;
		}

		// 取引ＩＤ項目チェック
		strValue = (String)rsMap.get("CR_orderId");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "19"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_orderId")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_orderId")});
			return false;
		}

		// 仕向先カード会社コード項目チェック
		strValue = (String)rsMap.get("CR_brandCode");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "5"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_brandCode")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_brandCode")});
			return false;
		}

		// 伝票番号項目チェック
		strValue = (String)rsMap.get("CR_slipNumber");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "5"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_slipNumber")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_slipNumber")});
			return false;
		}

		// オーソリ承認番号項目チェック
		strValue = (String)rsMap.get("CR_authNumber");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "7"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_authNumber")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_authNumber")});
			return false;
		}

		// 決済が行われた金額項目チェック
		strValue = (String)rsMap.get("CR_paidAmount");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "12"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_paidAmount")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakusuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_paidAmount")});
			return false;
		}

		// シーケンス番号項目チェック
		strValue = (String)rsMap.get("CR_seqNo");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_seqNo")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "12"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_seqNo")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_seqNo")});
			return false;
		}

		// レコード作成年月日時分秒項目チェック
		strValue = (String)rsMap.get("CR_recSakseiDtm");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_recSakseiDtm")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "17"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_recSakseiDtm")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"day_hour1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_recSakseiDtm")});
			return false;
		}

		// ANK-3846-00-00 ADD START
		// 決済ID項目チェック
		strValue = (String)rsMap.get("CR_paymentId");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "18"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_paymentId")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_paymentId")});
			return false;
		}

		// レスポンスコード項目チェック
		strValue = (String)rsMap.get("CR_responseCode");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "5"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_responseCode")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_responseCode")});
			return false;
		}
		
		// レスポンス詳細項目チェック
		strValue = (String)rsMap.get("CR_responseDetail");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "100"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM008-INF1.CR_responseDetail")});
			return false;
		}
		// ANK-3846-00-00 ADD END
		return true;
	}

	/**
	 * SQLKEY(KK_UPDATE_001)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	オーソリフラグ
	 *		 	オーソリ承認番号
	 *		 	売上オーソリ金額
	 *		 	仕向先カード会社コード
	 *		 	処理フラグ
	 *		 	オーソリ審査結果
	 *		 	決済ID
	 *		 	クレジットオーソリ実績番号
	 *		 	世代登録年月日時分秒
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_CREDIT_AUTH_JSK_KK_UPDATE_001(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());
		paramList.setValue(param[4].toString());
		paramList.setValue(param[5].toString());
		paramList.setValue(param[6].toString());
		paramList.setValue(param[7].toString());
		// ANK-3846-00-00 ADD START
		paramList.setValue(param[8].toString());
		// ANK-3846-00-00 ADD END

		// DBアクセスを実行します
		db_KK_T_CREDIT_AUTH_JSK.executeBySqlDefine(paramList, KK_T_CREDIT_AUTH_JSK_KK_UPDATE_001);
	}

	/**
	 * SQLKEY(KK_UPDATE_002)で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_CREDIT_AUTH_JSK_KK_UPDATE_002(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());
		paramList.setValue(param[4].toString());
		// ANK-3846-00-00 ADD START
		paramList.setValue(param[5].toString());
		paramList.setValue(param[6].toString());
		// ANK-3846-00-00 ADD END

		// DBアクセスを実行します
		db_KK_T_CREDIT_AUTH_JSK.executeBySqlDefine(paramList, KK_T_CREDIT_AUTH_JSK_KK_UPDATE_002);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/

	/**
	 * エラーメッセージに関する項目値を格納された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> itemvalue_Map = new HashMap<String, String>();
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_resultCode", "クレジットオーソリ回答ファイル.処理結果コード");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_orderId", "クレジットオーソリ回答ファイル.取引ＩＤ");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_brandCode", "クレジットオーソリ回答ファイル.仕向先カード会社コード");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_slipNumber", "クレジットオーソリ回答ファイル.伝票番号");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_authNumber", "クレジットオーソリ回答ファイル.オーソリ承認番号");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_paidAmount", "クレジットオーソリ回答ファイル.決済が行われた金額");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_seqNo", "クレジットオーソリ回答ファイル.シーケンス番号");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_recSakseiDtm", "クレジットオーソリ回答ファイル.レコード作成年月日時分秒");
		// ANK-3846-00-00 ADD START
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_paymentId", "クレジットオーソリ回答ファイル.決済ID");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_responseCode", "クレジットオーソリ回答ファイル.レスポンスコード");
		itemvalue_Map.put("TXT-KKIFM008-INF1.CR_responseDetail", "クレジットオーソリ回答ファイル.レスポンス詳細");
		// ANK-3846-00-00 ADD END
		return itemvalue_Map;
	}

	/**
	 * SQLKEY(KK_UPDATE_001)でDBアクセスを実行する際に必要なパラメータを設定します。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.パラメータ設定処理。
	 * </pre>
	 * <p>
	 * @param inMap 入力電文
	 * @return param SQLKEY(KK_UPDATE_001)でDBアクセスを実行する際に必要なパラメータ
	 * @throws Exception 
	 */
	private Object[] getUpdate001Param(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		Object[] ret_Param = {
			"1",																	// 初回オーソリフラグ(有効)
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_AUTHNUMBER)),	// 承認番号
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_PAIDAMOUNT)),	// 売上オーソリ金額
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_BRANDCODE)),	// 仕向先カード会社コード
			"1",																	// 処理フラグ＝処理済
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_RESULTCODE)),	// 初回オーソリ審査結果コード
			// ANK-3846-00-00 ADD START
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_PAYMENTID)),	// 決済ID
			// ANK-3846-00-00 ADD END
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_SEQNO)),		// シーケンス番号
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_RECSAKSEIDTM))	// レコード作成年月日時分秒
		};
		return ret_Param;
	}
	
	/**
	 * SQLKEY(KK_UPDATE_002)でDBアクセスを実行する際に必要なパラメータを設定します。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.パラメータ設定処理。
	 * </pre>
	 * <p>
	 * @param inMap 入力電文
	 * @return param SQLKEY(KK_UPDATE_002)でDBアクセスを実行する際に必要なパラメータ
	 * @throws Exception 
	 */
	private Object[] getUpdate002Param(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		Object[] ret_Param = {
			"0",																	// 初回オーソリフラグ(無効)
			"1",																	// 処理フラグ(処理済)
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_RESULTCODE)),	// 初回オーソリ審査結果コード
			// ANK-3846-00-00 ADD START
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_RESPONSECODE)),		// レスポンスコード
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_RESPONSEDETAIL)),		// レスポンス詳細
			// ANK-3846-00-00 ADD END
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_SEQNO)),		// シーケンス番号
			JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKKIFM008.CR_RECSAKSEIDTM))	// レコード作成年月日時分秒
		};
		return ret_Param;
	}
	
}
