/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatDKTkkikiMdlFixIktDl
*	ソースファイル名	：JBSbatDKTkkikiMdlFixIktDl.java
*	作成者				：富士通　
*	作成日				：2018年12月12日
*＜機能概要＞
*　宅内機器型式コード確定条件一括ダウンロード部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v40.00.00	2018/12/12	FJ)謝		【ANK-3412-02-00】【５ギガ・１０ギガ】型確定マスタメンテナンス機能追加 新規作成
*	v56.00.00	2021/09/02	GDC)J.Hortilano		【ANK-4038-00-00】光ローゼット化対応
*********************************************************************/
package eo.business.service;

import java.io.File;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.business.common.JCCbatShoriIraiUtil;
import eo.business.util.table.JBSbatCC_T_DLYD_TRN_REQ;
import eo.business.util.table.JBSbatDK_M_TKKIKI_MDL_FIX;
import eo.common.constant.JDKStrConst;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.util.JBSbatBusinessFileUtil;
import eo.framework.util.JBSbatDateUtil;
import eo.framework.util.JBSbatStringUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatDKTkkikiMdlFixIktDl extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(宅内機器型式コード確定条件)*/
	private static final String D_TBL_NAME_DK_M_TKKIKI_MDL_FIX = "DK_M_TKKIKI_MDL_FIX";

	/** テーブル(ダウンロードファイル管理)*/
	private static final String D_TBL_NAME_ZM_T_DL_FILE_KANRI = "ZM_T_DL_FILE_KANRI";

	/** SQL定義キー(DK_SELECT_016)*/
	private static final String DK_M_TKKIKI_MDL_FIX_DK_SELECT_016 = "DK_SELECT_016";

	/** SQL定義キー(DK_INSERT_003)*/
	private static final String ZM_T_DL_FILE_KANRI_DK_INSERT_003 = "DK_INSERT_003";

	/** テーブルアクセスクラス(宅内機器型式コード確定条件)*/
	private JBSbatSQLAccess db_DK_M_TKKIKI_MDL_FIX = null;

	/** テーブルアクセスクラス(ダウンロードファイル管理)*/
	private JBSbatSQLAccess db_ZM_T_DL_FILE_KANRI = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/** 宅内機器型式コード確定条件メンテナンスファイルのファイル名 */
	private static final String DKIFM116_FILE_NM = "DKIFM116.csv";
	
	/** ファイルコード */
	private static final String FILE_CD = "0000";
	
	/** 処理管理番号 */
	private static final String TRN_KANRI_NO = "000000000197";
	
	/** 出力ファイル名編集用 */
	private static final String DKLST024_FILE_NM = "DKLST024_DK_M_TKKIKI_MDL_FIX_yyyyMMddhhmmss.csv";
	
	/** ヘッダ編集用＿宅内機器型式コード確定条件番号 */
	private static final String H_TKKIKI_MDL_CD_FIX_NO = "宅内機器型式コード確定条件番号";
	
	/** ヘッダ編集用＿宅内機器型式コード確定グループコード */
	private static final String H_TAKNKIKI_MDL_CD_FIX_GRP_CD = "宅内機器型式コード確定グループコード";
	
	/** ヘッダ編集用＿メーカーコード */
	private static final String H_MAKER_CD = "メーカーコード";
	
	/** ヘッダ編集用＿料金コースPON条件コード */
	private static final String H_PCRS_PON_JOKEN_CD = "料金コースPON条件コード";
	
	/** ヘッダ編集用＿親PONバージョン識別コード */
	private static final String H_OYA_PON_VSN_SKCD = "親PONバージョン識別コード";
	
	// ANK-4038-00-00 ADD START
	/** ヘッダ編集用＿ローゼット設置状態コード */
	private static final String H_ROZETT_STC_STAT_CD = "ローゼット設置状態コード";
	// ANK-4038-00-00 ADD END
	
	/** ヘッダ編集用＿適用開始年月日 */
	private static final String H_TSTAYMD = "適用開始年月日";
	
	/** ヘッダ編集用＿適用終了年月日 */
	private static final String H_TENDYMD = "適用終了年月日";
	
	/** ヘッダ編集用＿宅内機器型式コード */
	private static final String H_TAKNKIKI_MODEL_CD = "宅内機器型式コード";
	
	/** ヘッダ編集用＿在庫比率 */
	private static final String H_ZAIKO_RT = "在庫比率";


	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_DK_M_TKKIKI_MDL_FIX = new JBSbatSQLAccess(commonItem, D_TBL_NAME_DK_M_TKKIKI_MDL_FIX);
		db_ZM_T_DL_FILE_KANRI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_ZM_T_DL_FILE_KANRI);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// ディレイド処理依頼情報リストを取得する
		List<HashMap<String, Object>> shoriIraiList = JCCbatShoriIraiUtil.getShoriIraiInfo(commonItem, this.jobid);
		
		// ディレイド処理依頼情報リストが取得できない場合、処理を終了する
		if (shoriIraiList == null || shoriIraiList.size() == 0)
		{
			return null;
		}
		
		// フリー項目を取得する
		String[] freeItems = freeItem.split(JDKStrConst.FREE_DLMT);
		
		// 宅内機器型式コード確定条件メンテナンスファイルのファイルパス
		String dkifm116FilePath = freeItems[0] + DKIFM116_FILE_NM;
		
		// ディレイド処理依頼情報リストの件数分繰り返す
		for (HashMap<String, Object> shoriIrai : shoriIraiList)
		{
			// 宅内機器型式コード確定条件メンテナンスファイルのファイルオブジェクト
			JBSbatBusinessFileUtil dkifm116FileObj = JCCBatCommon.createBusinessFileUtil(
					dkifm116FilePath, JDKStrConst.ENCODE_SJIS2, JDKStrConst.LINE_SEPARATOR, JDKStrConst.COMMA);
			
			// 宅内機器型式コード確定条件メンテナンスファイルの件数
			int dkifm116Cnt = 0;
			
			// ONU、多機能ルーターの宅内機器型式コード確定条件を取得する
			executeDK_M_TKKIKI_MDL_FIX_DK_SELECT_016(new Object[]{});
			JBSbatCommonDBInterface tkkikiMdlFixMap = db_DK_M_TKKIKI_MDL_FIX.selectNext();
			
			// 宅内機器型式コード確定条件メンテナンスファイルにヘッダ部を出力する
			ArrayList<String> headerInfo = new ArrayList<String>();
			// 宅内機器型式コード確定条件番号
			headerInfo.add(H_TKKIKI_MDL_CD_FIX_NO);
			// 宅内機器型式コード確定グループコード
			headerInfo.add(H_TAKNKIKI_MDL_CD_FIX_GRP_CD);
			// メーカーコード
			headerInfo.add(H_MAKER_CD);
			// 料金コースＰＯＮ条件コード
			headerInfo.add(H_PCRS_PON_JOKEN_CD);
			// 親ＰＯＮバージョン識別コード
			headerInfo.add(H_OYA_PON_VSN_SKCD);
			// ANK-4038-00-00 ADD START
			// ローゼット設置状態コード
			headerInfo.add(H_ROZETT_STC_STAT_CD);
			// ANK-4038-00-00 ADD END
			// 適用開始年月日
			headerInfo.add(H_TSTAYMD);
			// 適用終了年月日
			headerInfo.add(H_TENDYMD);
			// 宅内機器型式コード
			headerInfo.add(H_TAKNKIKI_MODEL_CD);
			// 在庫比率
			headerInfo.add(H_ZAIKO_RT);
			
			JCCBatCommon.printDoubleQuoteBusinessFileUtil(dkifm116FileObj, headerInfo);
			
			// 出力件数カウントアップ
			dkifm116Cnt++;
			
			// 宅内機器型式コード確定条件メンテナンスファイルにデータ部を出力する
			while(tkkikiMdlFixMap != null)
			{
				ArrayList<String> dataInfo = new ArrayList<String>();
				// 宅内機器型式コード確定条件番号
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.TKKIKI_MDL_CD_FIX_NO)));
				// 宅内機器型式コード確定グループコード
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.TAKNKIKI_MDL_CD_FIX_GRP_CD)));
				// メーカーコード
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.MAKER_CD)));
				// 料金コースＰＯＮ条件コード
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.PCRS_PON_JOKEN_CD)));
				// 親ＰＯＮバージョン識別コード
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.OYA_PON_VSN_SKCD)));
				// ANK-4038-00-00 ADD START
				// ローゼット設置状態コード
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.ROZETT_STC_STAT_CD)));
				// ANK-4038-00-00 ADD END
				// 適用開始年月日
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.TSTAYMD)));
				// 適用終了年月日
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.TENDYMD)));
				// 宅内機器型式コード
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.TAKNKIKI_MODEL_CD)));
				// 在庫比率
				dataInfo.add(JBSbatStringUtil.Rtrim(tkkikiMdlFixMap.getString(JBSbatDK_M_TKKIKI_MDL_FIX.ZAIKO_RT)));
				
				JCCBatCommon.printDoubleQuoteBusinessFileUtil(dkifm116FileObj, dataInfo);
				
				// 出力件数カウントアップ
				dkifm116Cnt++;
				
				// 次のレコードを取得する
				tkkikiMdlFixMap = db_DK_M_TKKIKI_MDL_FIX.selectNext();
			}
			
			// 宅内機器型式コード確定条件メンテナンスファイルを閉じる
			JCCBatCommon.closeBusinessFileUtil(dkifm116FileObj);
			
			// 電子ファイル管理登録処理
			JBSbatCommonItem arg0 = commonItem;								// 業務共通電文
			String arg1 = FILE_CD;											// ファイルコード
			String arg2 = dkifm116FilePath;									// ファイルパス
			String arg3 = JBSbatDateUtil.adjustMonth(super.opeDate, 1);		// ファイル削除年月日（運用日付 + 1ヶ月）
			String[] rc = JCCBatCommon.createDenshiFile(arg0, arg1, arg2, arg3);
			
			// ログ出力
			super.logPrint.printDebugLog("電子ファイル管理番号(" + rc[0] +  ")、世代登録年月日時分秒(" + rc[1] + ")");
			
			// システム日時を取得する
			String sysDateTime = JCCBatCommon.getSysDateTime();
			
			// ダウンロードファイル管理登録処理
			String[] setParam = new String[5];
			String dklst024FileName = DKLST024_FILE_NM.replaceAll(JDKStrConst.FILE_TIMESTAMP_FORMAT, sysDateTime);
			setParam[0] = TRN_KANRI_NO;							// 処理管理番号
			setParam[1] = dklst024FileName;						// ファイル名
			setParam[2] = String.valueOf(dkifm116Cnt);			// データ件数
			setParam[3] = rc[0];								// 電子ファイル管理番号
			setParam[4] = rc[1];								// 世代登録年月日時分秒
			executeZM_T_DL_FILE_KANRI_DK_INSERT_003(setParam);
			
			// 一時ファイルを削除する
			File dkifm116File = new File(dkifm116FilePath);
			if (dkifm116File.exists())
			{
				dkifm116File.delete();
			}
			
			// ディレイド処理依頼番号
			String shoriIraiNo = (String)shoriIrai.get(JBSbatCC_T_DLYD_TRN_REQ.DLYD_TRN_REQ_NO);
			
			// ディレイド処理依頼結果を「002(処理済)」に更新する
			JCCbatShoriIraiUtil.updateShoriIraiResult(commonItem, shoriIraiNo, JDKStrConst.DLYD_TRN_RSLT_CD_COMPLETE, null);
		}
		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_DK_M_TKKIKI_MDL_FIX.close();
		db_ZM_T_DL_FILE_KANRI.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 * SQLKEY(DK_SELECT_016)で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_M_TKKIKI_MDL_FIX_DK_SELECT_016(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();

		// DBアクセスを実行します
		db_DK_M_TKKIKI_MDL_FIX.selectBySqlDefine(paramList, DK_M_TKKIKI_MDL_FIX_DK_SELECT_016);
	}

	/**
	 * SQLKEY(DK_INSERT_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_T_DL_FILE_KANRI_DK_INSERT_003(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());

		// DBアクセスを実行します
		db_ZM_T_DL_FILE_KANRI.executeBySqlDefine(paramList, ZM_T_DL_FILE_KANRI_DK_INSERT_003);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
