/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatCHEsbSend
*	ソースファイル名	：JBSbatCHEsbSend.java
*	作成者				：富士通　
*	作成日				：2016年12月08日
*＜機能概要＞
*　料金請求ESB送信部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2016/12/08   富士通		新規作成
*********************************************************************/
package eo.business.service;

import java.util.ArrayList;
import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.common.constant.JPCBatchMessageConstant;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.application.JBSbatBusinessError;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.util.JBSbatCheckUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatCHEsbSend extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/** 記号(セミコロン) */
	private static final String DELIM  = ";";

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// フリー項目を区切る
		String[] param 	= super.freeItem.split(DELIM);
		
		// FTP転送依頼するインターフェイスID
		String interfaceId = param[0];
		
		ArrayList<String> fileNameList = new ArrayList<String>(3);
		
		String dataFile = param[1]; // dataファイル名
		String cntFile = param[2];  // cntファイル名
		String flgFile = param[3];  // flgファイル名
		fileNameList.add(dataFile); // データファイル
		fileNameList.add(cntFile);  // cntファイル
		fileNameList.add(flgFile);  // flgファイル

		// 結果を格納するMAPを生成
		HashMap<String, Object> resultMap = new HashMap<String, Object>();
		
		// FTP部品アクセッサを呼び出す
		boolean resultBln = JCCBatCommon.putFTP(commonItem, fileNameList, interfaceId, resultMap);
		
		// エラー発生時
		if (!resultBln)
		{
			String errKbn = resultMap.get("ERR_KBN").toString();	// エラー区分

			// 接続エラーの場合
			if ("1".equals(errKbn))
			{
				// 接続エラー情報を取得
				HashMap<?, ?> connectErr = (HashMap<?, ?>)resultMap.get("CONNECT_ERR");
				// エラーフラグを取得
				boolean errFlg = Boolean.valueOf(connectErr.get("ERR_FLG").toString()).booleanValue();
				// 接続エラーの判定処理
				if (!errFlg)
				{
					// エラーメッセージを取得
					String msg = connectErr.get("ERR_MESSAGE").toString();
					// 業務例外発生
					super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB1560CW, new String[]{msg});
					throw new JBSbatBusinessError();
				}
			}
			// ファイルエラーの場合
			if ("2".equals(errKbn))
			{
				// ファイルエラーリストの回数分繰り返す
				ArrayList<?> fileErrList = (ArrayList<?>)resultMap.get("FILE_ERR");
				for (int i = 0; i < fileErrList.size(); i++)
				{
					// ファイルエラー情報を取得
					HashMap<?, ?> fileErr = (HashMap<?, ?>)fileErrList.get(i);
					// エラーフラグを取得
					boolean errFlg = Boolean.valueOf(fileErr.get("ERR_FLG").toString()).booleanValue();
					// ファイルエラーの判定処理
					if (!errFlg)
					{
						// エラーメッセージを取得
						String msg = fileErr.get("ERR_MESSAGE").toString();
						// 業務例外発生
						super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB1560CW, new String[]{msg});
						throw new JBSbatBusinessError();
					}
				}
			}
		}
		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
