/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatACTrgtJrSvcKeiAddChk
*	ソースファイル名	：JBSbatACTrgtJrSvcKeiAddChk.java
*	作成者				：富士通　
*	作成日				：2013年05月28日
*＜機能概要＞
*　前月課金対象従量サービス契約追加判定部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2013/05/28   富士通		新規作成
*	v25.00.00	2016/07/04   FJ) 中山	【OM-2016-0001645】シーケンスの桁あふれ対応
*********************************************************************/
package eo.business.service;

import java.util.ArrayList;

import eo.business.common.JACBatCommon;
import eo.business.common.JACbatDebugLogUtil;
import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.business.util.file.JBSbatACIFM062;
import eo.common.constant.JACStrConst;
import eo.common.util.JPCUtilCommon;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.file.JBSbatDefFileUtil;
import eo.framework.file.JBSbatOutputFileUtil;
import eo.framework.util.JBSbatAplConst;
import eo.framework.util.JBSbatBusinessFileUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatACTrgtJrSvcKeiAddChk extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/


	/** 出力ファイル定義 */
	private static final String PRM_OTD 	= "OTD";

	/** 対象キーワークシーケンス更新用ファイル */
	private JBSbatBusinessFileUtil trgtKeyWkSeqFile = null;

	/** フリー項目(カンマsplit済み) */
	private String[] freeItems = null;

	/*▼ シーケンス採番用定義変数 ▼*/
	/** シーケンス名（対象キーワーク番号） */
	private static final String SEQ_NAME_SEQ_CHRG_JSVKEI_CKS_NO = "SEQ_CHRG_JSVKEI_CKS_NO";

	/** シーケンス接頭辞（対象キーワーク番号） */
	private static final String SEQ_PREFIX_SEQ_NAME_SEQ_CHRG_JSVKEI_CKS_NO = "";

	/** シーケンス桁数（対象キーワーク番号） */
	private static final int SEQ_LEN_SEQ_CHRG_JSVKEI_CKS_NO = 20;

//OM-2016-0001645 MOD START
//	/** 対象キーワーク番号（処理前（シーケンスから取得）） */
//	private int seqChrgJsvkeiCksNoBef = 0;
//	
//	/** 対象キーワーク番号（シーケンスから取得） */
//	private int seqChrgJsvkeiCksNo = 0;
	/** 対象キーワーク番号（処理前（シーケンスから取得）） */
	private long seqChrgJsvkeiCksNoBef = 0;
	
	/** 対象キーワーク番号（シーケンスから取得） */
	private long seqChrgJsvkeiCksNo = 0;
//OM-2016-0001645 MOD END

	 /** フリー項目(0)：ファイル項目定義ファイル(ACIFM106) */
	private final int FREEITEM_ACIFM106 = 0;

	/** フリー項目(1)：対象キーワーク更新数ファイル */
	private final int FREEITEM_SEQFILE_TRGT_KEY_WK = 1;
	
	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/

		// FREEITEMの取得
		freeItems = super.freeItem.split(JACStrConst.SEMI_COLON);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][initial]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][opeDate=" + super.opeDate + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][freeItem=" + super.freeItem + "]");

		// シーケンスからサービス契約蓄積番号を取得
//OM-2016-0001645 MOD START
//		this.seqChrgJsvkeiCksNoBef = Integer.parseInt(JCCBatCommon.getFormatedNextSeq(super.commonItem, SEQ_NAME_SEQ_CHRG_JSVKEI_CKS_NO, SEQ_PREFIX_SEQ_NAME_SEQ_CHRG_JSVKEI_CKS_NO, SEQ_LEN_SEQ_CHRG_JSVKEI_CKS_NO));
		this.seqChrgJsvkeiCksNoBef = Long.parseLong(JCCBatCommon.getFormatedNextSeq(super.commonItem, SEQ_NAME_SEQ_CHRG_JSVKEI_CKS_NO, SEQ_PREFIX_SEQ_NAME_SEQ_CHRG_JSVKEI_CKS_NO, SEQ_LEN_SEQ_CHRG_JSVKEI_CKS_NO));
//OM-2016-0001645 MOD END
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][シーケンス番号（対象キーワーク）" + this.seqChrgJsvkeiCksNoBef + "]");
		
		this.seqChrgJsvkeiCksNo = this.seqChrgJsvkeiCksNoBef;

		// サービス契約蓄積シーケンス更新用ファイル
		this.trgtKeyWkSeqFile = createFile(freeItems[FREEITEM_SEQFILE_TRGT_KEY_WK], freeItems[FREEITEM_ACIFM106]);
		
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @param outputInItem 入力情報
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap, JBSbatOutputItem outputInItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		if(inMap == null)
		{
			// 処理終了
			return outputInItem;
		}

		this.seqChrgJsvkeiCksNo = getNextSeq(this.seqChrgJsvkeiCksNo, 1);
		inMap.setString(JBSbatACIFM062.CHRG_JSVKEI_CKS_NO,			JPCUtilCommon.fillZero(String.valueOf(this.seqChrgJsvkeiCksNo), SEQ_LEN_SEQ_CHRG_JSVKEI_CKS_NO, false)); 		// 課金対象従量サービス契約蓄積番号
		inMap.setOutFlg(true);

		outputInItem.addOutMapList(inMap);

		return outputInItem;

	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][terminal]");
		// サービス契約シーケンス更新用ファイル出力
		this.outSeqNo();

		// サービス契約蓄積シーケンス更新用ファイルクローズ
		JCCBatCommon.closeBusinessFileUtil(this.trgtKeyWkSeqFile);
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][terminal]");
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
	/**

	/**
	 * 更新用シーケンス番号をファイル出力します
	 * 
	 * @throws Exception
	 */
	private void outSeqNo() throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][outSeqNo]");
		
		// シーケンスを100進める
		this.seqChrgJsvkeiCksNo = getNextSeq(this.seqChrgJsvkeiCksNo, 100);
		
		// 処理前との差分を算出
//OM-2016-0001645 MOD START
//		int updSeikyNoCnt = this.seqChrgJsvkeiCksNo - this.seqChrgJsvkeiCksNoBef;
		long updSeikyNoCnt = this.seqChrgJsvkeiCksNo - this.seqChrgJsvkeiCksNoBef;
//OM-2016-0001645 MOD END
		
		// 請求シーケンス更新用ファイル出力
		ArrayList<Object> updSeikyNoList = new ArrayList<Object>();
		updSeikyNoList.add(updSeikyNoCnt);
		JCCBatCommon.printBusinessFileUtil(this.trgtKeyWkSeqFile, updSeikyNoList);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][outSeqNo]");
	}

//OM-2016-0001645 MOD START
//	/**
//	 * シーケンスを引数分加算します。
//	 * 
//	 * @param seqNo 加算対象シーケンス番号
//	 * @param num 加算数
//	 * @return int 加算済シーケンス番号
//	 * @throws Exception
//	 */
//	private int getNextSeq(int seqNo, int num) throws Exception
//	{
//		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][getNextSeq]");
//		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getNextSeq][" + seqNo + " ＋ " + num + " ＝ " + seqNo + num + "]");
//		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][getNextSeq]");
//		
//		//引数分加算する
//		return seqNo + num;
//	}
	
	/**
	 * シーケンスを引数分加算します。
	 * 
	 * @param seqNo 加算対象シーケンス番号
	 * @param num 加算数
	 * @return 加算済シーケンス番号
	 * @throws Exception
	 */
	private long getNextSeq(long seqNo, long num) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][getNextSeq]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getNextSeq][" + seqNo + " ＋ " + num + " ＝ " + seqNo + num + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][getNextSeq]");
		
		//引数分加算する
		return seqNo + num;
	}
//OM-2016-0001645 MOD END

	/**
	 * ファイル出力
	 * 
	 * @param  filePath  ファイルパス
	 * @param  fileDef   ファイル定義
	 * @return fileUtil  ファイルインスタンス
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private JBSbatBusinessFileUtil createFile(String filePath, String fileDef) throws Exception 
	{
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][createFile]");
		JBSbatOutputFileUtil trailerFile 	= new JBSbatOutputFileUtil(filePath);
		String tempFileDefName 				= JBSbatAplConst.getAplConstValue(PRM_OTD) + fileDef;
		JBSbatDefFileUtil trailerFileDef 	= new JBSbatDefFileUtil(tempFileDefName, trailerFile);
		
		// ファイルの生成
		JBSbatBusinessFileUtil fileUtil = JCCBatCommon.createBusinessFileUtil(filePath
																			, JACStrConst.ENCODE_MS932
																			, JACBatCommon.chgKaigyo(JACStrConst.LINE_CRLF)
																			, trailerFileDef.getDelimiter());
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][createFile]");
		return fileUtil;
	}
}
