/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKHgwRepTgWkAdd
*	ソースファイル名	：JBSbatKKHgwRepTgWkAdd.java
*	作成者				：富士通　
*	作成日				：2025年04月22日
*＜機能概要＞
*　ＨＧＷ機器付替対象ワーク登録部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v75.00.00	2025/04/22   FJ)王		【ANK-4677-00-00】【eo】HGW導入対応フォロー７
*********************************************************************/
package eo.business.service;

import java.util.HashSet;
import java.util.Set;

import eo.business.common.JBSbatBusinessService;
import eo.common.constant.JKKStrConst;
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;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatKKHgwRepTgWkAdd extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(HGW機器付け替え対象ワーク)*/
	private static final String D_TBL_NAME_KK_T_HGW_KKREP_TG_WK = "KK_T_HGW_KKREP_TG_WK";

	/** テーブル(配送)*/
	private static final String D_TBL_NAME_DK_T_HAISO = "DK_T_HAISO";

	/** SQL定義キー(KK_DELETE_001)*/
	private static final String KK_T_HGW_KKREP_TG_WK_KK_DELETE_001 = "KK_DELETE_001";

	/** SQL定義キー(KK_SELECT_025)*/
	private static final String DK_T_HAISO_KK_SELECT_025 = "KK_SELECT_025";

	/** テーブルアクセスクラス(HGW機器付け替え対象ワーク)*/
	private JBSbatSQLAccess db_KK_T_HGW_KKREP_TG_WK = null;

	/** テーブルアクセスクラス(配送)*/
	private JBSbatSQLAccess db_DK_T_HAISO = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/**
	 * バッチ用ＨＧＷ機器付替登録対象情報
	 */
	private Set<String> hgwRepTgSet = new HashSet<String>();
	
	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KK_T_HGW_KKREP_TG_WK = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_HGW_KKREP_TG_WK);
		db_DK_T_HAISO = new JBSbatSQLAccess(commonItem, D_TBL_NAME_DK_T_HAISO);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
		
		//HGW機器付け替え対象ワークを全件物理削除する
		this.executeKK_T_HGW_KKREP_TG_WK_KK_DELETE_001();
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// 工事案件番号が重複の場合処理しない
		if(hgwRepTgSet.contains(inMap.getString("KOJIAK_NO")))
		{
			return null;
		}
		
		// 機器提供サービス契約番号と機器変更番号を取得する
		String onuKktkSvcNo = inMap.getString("KKTK_SVC_KEI_NO");
		String onuKkChgNo = inMap.getString("KIKI_CHG_NO");
		
		// 配送対象物品番号
		String haisoTaiBpinNo = "";
		
		// 登録フラグ
		boolean addFlag = false;
		
		// 配送対象物品.機器提供サービス契約番号と機器変更番号で検索条件を設定
		String[] paramSql = new String[]{
			onuKktkSvcNo, 
			onuKkChgNo
		};
		this.executeDK_T_HAISO_KK_SELECT_025(paramSql);
		JBSbatCommonDBInterface resultMap = db_DK_T_HAISO.selectNext();
		
		// 配送が未作成の場合、登録対象とする
		if(resultMap == null)
		{
			addFlag = true;
		}
		else
		{
			// 配送作成済みの場合は配送ステータスと配送元倉庫コードを取得する
			String haisoStat = resultMap.getString("HAISO_STAT");
			String haisoMotoSokoCD = resultMap.getString("HAISO_MOTO_SOKO_CD");
			haisoTaiBpinNo = resultMap.getString("HAISO_TAIBPIN_NO");
			
			// 配送ステータスが"001"(受付済)かつ配送元倉庫コードが"000001"(大阪みなとロジシスセンター)の場合、登録対象とする
			if(JKKStrConst.HAISO_STAT_UK_ZM.equals(haisoStat) && JKKStrConst.MINATO_SOKO_CD.equals(haisoMotoSokoCD))
			{
				addFlag = true;
			}
		}
		
		if(addFlag)
		{
			String[] strParam = new String[20];
			
			strParam[0] = inMap.getString("KOJIAK_NO");					// 工事案件番号
			strParam[1] = inMap.getString("KOJIAK_SBT_CD");				// 工事案件種別コード
			strParam[2] = inMap.getString("KOJI_UK_OPTNTY_IDO_DIV");	// 工事受付契機異動区分
			strParam[3] = inMap.getString("KKTK_SVC_KEI_NO");			// 機器提供サービス契約番号
			strParam[4] = inMap.getString("GENE_ADD_DTM");				// 機器提供サービス契約世代登録年月日時分秒
			strParam[5] = inMap.getString("SVC_KEI_KAISEN_UCWK_NO");	// サービス契約回線内訳番号
			strParam[6] = haisoTaiBpinNo;								// 配送対象物品番号
			strParam[7] = "";											// 登録年月日時分秒
			strParam[8] = "";											// 登録オペレータアカウント
			strParam[9] = "";											// 更新年月日時分秒
			strParam[10] = "";											// 更新オペレータアカウント
			strParam[11] = "";											// 削除年月日時分秒
			strParam[12] = "";											// 削除オペレータアカウント
			strParam[13] = "";											// 無効フラグ
			strParam[14] = "";											// 登録運用年月日
			strParam[15] = "";											// 登録処理ID
			strParam[16] = "";											// 更新運用年月日
			strParam[17] = "";											// 更新処理ID
			strParam[18] = "";											// 削除運用年月日
			strParam[19] = "";											// 削除処理ID
			
			//ＨＧＷ機器付替対象を登録する
			this.executeKK_T_HGW_KKREP_TG_WK_PKINSERT(strParam);
			
			// 工事案件番号を追加する
			hgwRepTgSet.add(inMap.getString("KOJIAK_NO"));
		}
		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KK_T_HGW_KKREP_TG_WK.close();
		db_DK_T_HAISO.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 * SQLKEY(KK_DELETE_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_HGW_KKREP_TG_WK_KK_DELETE_001() throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();

		// DBアクセスを実行します
		db_KK_T_HGW_KKREP_TG_WK.executeBySqlDefine(paramList, KK_T_HGW_KKREP_TG_WK_KK_DELETE_001);
	}

	/**
	 * SQLKEY(KK_SELECT_025)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	機器提供サービス契約番号
	 *		 	機器変更番号
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeDK_T_HAISO_KK_SELECT_025(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());

		// DBアクセスを実行します
		db_DK_T_HAISO.selectBySqlDefine(paramList, DK_T_HAISO_KK_SELECT_025);
	}

	/**
	 * PK(全項目登録)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で設定項目マップを作ります。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		setParam:設定したい項目の(項目、値)を(key、value)として、setParamマップに入れます。項目キーは以下に説明します。
	 *		 	工事案件番号				KOJIAK_NO
	 *		 	工事案件種別コード				KOJIAK_SBT_CD
	 *		 	工事受付契機異動区分				KOJI_UK_OPTNTY_IDO_DIV
	 *		 	機器提供サービス契約番号				KKTK_SVC_KEI_NO
	 *		 	機器提供サービス契約世代登録年月日時分秒				KKTSVKEI_GADTM
	 *		 	サービス契約回線内訳番号				SVC_KEI_KAISEN_UCWK_NO
	 *		 	配送対象物品番号				HAISO_TAIBPIN_NO
	 *		 	登録年月日時分秒				ADD_DTM
	 *		 	登録オペレータアカウント				ADD_OPEACNT
	 *		 	更新年月日時分秒				UPD_DTM
	 *		 	更新オペレータアカウント				UPD_OPEACNT
	 *		 	削除年月日時分秒				DEL_DTM
	 *		 	削除オペレータアカウント				DEL_OPEACNT
	 *		 	無効フラグ				MK_FLG
	 *		 	登録運用年月日				ADD_UNYO_YMD
	 *		 	登録処理ID				ADD_TRN_ID
	 *		 	更新運用年月日				UPD_UNYO_YMD
	 *		 	更新処理ID				UPD_TRN_ID
	 *		 	削除運用年月日				DEL_UNYO_YMD
	 *		 	削除処理ID				DEL_TRN_ID
	 * </pre>
	 * <p>
	 * @param setParam 設定項目の値。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_HGW_KKREP_TG_WK_PKINSERT(Object[] setParam) throws Exception
	{
		// 設定値のマップを作成します
		JBSbatCommonDBInterface setMap = new JBSbatCommonDBInterface();
		setMap.setValue("KOJIAK_NO", setParam[0]);
		setMap.setValue("KOJIAK_SBT_CD", setParam[1]);
		setMap.setValue("KOJI_UK_OPTNTY_IDO_DIV", setParam[2]);
		setMap.setValue("KKTK_SVC_KEI_NO", setParam[3]);
		setMap.setValue("KKTSVKEI_GADTM", setParam[4]);
		setMap.setValue("SVC_KEI_KAISEN_UCWK_NO", setParam[5]);
		setMap.setValue("HAISO_TAIBPIN_NO", setParam[6]);
		setMap.setValue("ADD_DTM", setParam[7]);
		setMap.setValue("ADD_OPEACNT", setParam[8]);
		setMap.setValue("UPD_DTM", setParam[9]);
		setMap.setValue("UPD_OPEACNT", setParam[10]);
		setMap.setValue("DEL_DTM", setParam[11]);
		setMap.setValue("DEL_OPEACNT", setParam[12]);
		setMap.setValue("MK_FLG", setParam[13]);
		setMap.setValue("ADD_UNYO_YMD", setParam[14]);
		setMap.setValue("ADD_TRN_ID", setParam[15]);
		setMap.setValue("UPD_UNYO_YMD", setParam[16]);
		setMap.setValue("UPD_TRN_ID", setParam[17]);
		setMap.setValue("DEL_UNYO_YMD", setParam[18]);
		setMap.setValue("DEL_TRN_ID", setParam[19]);
	
		// DBアクセスを実行します
		db_KK_T_HGW_KKREP_TG_WK.insertByPrimaryKeys(setMap);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
