/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKOpChannelDlydReqStku
*	ソースファイル名	：JBSbatKKOpChannelDlydReqStku.java
*	作成者				：富士通　
*	作成日				：2014年06月12日
*＜機能概要＞
*　オプションチャンネル受付履歴一覧作成処理依頼情報取得部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2014/06/12   FJ)澁谷	新規作成
*********************************************************************/
package eo.business.service;

import java.util.ArrayList;
import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.business.common.JKKBatConst;
import eo.common.constant.JPCBatchMessageConstant;
import eo.common.util.JKKCommonUtil;
import eo.framework.application.JBSbatBusinessException;
import eo.framework.file.JBSbatDefFileUtil;
import eo.framework.file.JBSbatOutputFileUtil;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.util.JBSbatAplConst;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatKKOpChannelDlydReqStku extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/

	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/** オプションチャンネル受付履歴ファイル作成_ジョブID */
	private static final String JOB_ID = "EO2EG0110J0";
	
	/** ディレイド処理依頼情報ファイル定義 */
	private static final String DEF_OPCHANNEL_DLYD_IRAI = "KKIFM618.def";
	
	/** ディレイド処理依頼情報ファイルパス */
	private String midFilePath = "";

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
		
		// ファイルパスの取得
		if(super.freeItem != null && !"".equals(super.freeItem)){
			// ディレイド処理依頼情報ファイルパス
			this.midFilePath = super.freeItem;
			
		} else {
			throw new JBSbatBusinessException("EKKB0740CE", new String[]{"フリーパラメータ異常"});
			
		}
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		
		super.logPrint.printDebugLog("execute_start");
		
		// ディレイド処理依頼取得
		ArrayList<HashMap<String, Object>> dlydShoriIraiList = JCCBatCommon.getShoriIraiInfo(commonItem, JOB_ID);
		
		// ディレイド処理依頼が存在しなかった場合
		if (JKKCommonUtil.isNull(dlydShoriIraiList))
		{
			// ディレイド処理依頼情報取得を終了する。
			commonItem.getLogPrint().printDebugLog("ディレイド処理依頼情報がないため終了します");
			return null;
		}
		
		// ディレイド処理依頼情報ファイルを作成
		JBSbatOutputFileUtil dlydInfoFile = new JBSbatOutputFileUtil(midFilePath);
		dlydInfoFile.setEncode(JKKBatConst.SJIS);		// 文字コード
		dlydInfoFile.setLine("LF");						// 改行コード
		
		JBSbatDefFileUtil defData = null;
		try{
			// ディレイド処理依頼情報ファイルを作成する
			dlydInfoFile.createWriter();
			
			String defFilePath = rnktPath(JBSbatAplConst.getAplConstValue("IND"), DEF_OPCHANNEL_DLYD_IRAI);
			defData = new JBSbatDefFileUtil(defFilePath, dlydInfoFile);
			
		} catch(Exception ex){
			
			// ディレイド処理依頼情報ファイル作成失敗
			commonItem.getLogPrint().printBusinessErrorLog(JPCBatchMessageConstant.EDKB0030CE, new String[] {midFilePath});
			throw ex;
		}
		
		try
		{
			for (int i = dlydShoriIraiList.size() - 1; i > -1; i--)
			{
				// ディレイド処理依頼情報からHashMapを取得する。
				HashMap<String, Object> dlydMap = dlydShoriIraiList.get(i);
	
				// ディレイド処理依頼情報ファイル内容設定
				JBSbatServiceInterfaceMap outDataMap = new JBSbatServiceInterfaceMap();
				
				// ディレイド処理依頼番号
				outDataMap.set("DLYD_TRN_REQ_NO", dlydMap.get("DLYD_TRN_REQ_NO").toString());
				// 電子ファイル管理番号
				outDataMap.set("INPUT_EFILE_KANRI_NO", dlydMap.get("INPUT_EFILE_KANRI_NO").toString());
				
				// ファイル出力
				dlydInfoFile.print(outDataMap, defData);
			}
		}
		catch (Exception ex)
		{
			// ディレイド処理依頼情報ファイル書込失敗
			commonItem.getLogPrint().printBusinessErrorLog(JPCBatchMessageConstant.EDKB0050CE, new String[] {midFilePath});
			throw ex;
		}
		finally
		{
			// ファイルのクローズ
			try
			{
				dlydInfoFile.close();
			}
			catch (Exception ex2)
			{
				super.logPrint.printDebugLog("ファイル書込みオブジェクトのクローズ失敗:" + midFilePath);
			}
		}
		
		super.logPrint.printDebugLog("execute_end");

		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/

		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/

	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/

	/**
	 * パス文字列の連結
	 * 連結するパス文字列にパス区切り文字の設定を制御する。
	 * @param path1 パス文字列
	 * @param path2 パス文字列
	 * @return 連結したパス文字列
	 */
	private String rnktPath(String path1, String path2)
	{
		String pathDlmt = "/";
		if (path1.indexOf("\\") > -1 || path2.indexOf("\\") > -1)
		{
			pathDlmt = "\\";
		}
		if (!path1.endsWith(pathDlmt))
		{
			return path1 + pathDlmt + path2;
		}
		return path1 + path2;
	}

}
