/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatACRenkRsltJudge
*	ソースファイル名	：JBSbatACRenkRsltJudge.java
*	作成者				：富士通　
*	作成日				：2013年02月22日
*＜機能概要＞
*　連携結果判定部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2013/02/22   富士通		新規作成
*	v5.00.00	2013/07/16   FJ) 前田	【IT1-2013-0001420】警告メッセージを出力するように修正
*********************************************************************/
package eo.business.service;


import eo.business.common.JBSbatBusinessService;
import eo.business.util.file.JBSbatACIFM197;
import eo.common.constant.JPCBatchMessageConstant;
import eo.framework.application.JBSbatBusinessException;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.util.JBSbatCheckUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatACRenkRsltJudge extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/** ヘッダー　処理結果コード　正常終了 */
	private static final String NORMAL_END = "0000";
	/** ヘッダー　レコード区分　 */
	private static final String REC_DIV_HEAD = "0";
	/** 通話料ファイル連携結果ファイル件数 */
	private int 	twFileRenkKekkaCnt = 0;
	/** エラーメッセージ */
	private String msg2 = null;
	/** エラーカウント */
	private int errCnt = 0;

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);
		// 通話料ファイル連携結果ファイル件数 初期化
		twFileRenkKekkaCnt = 0;
		
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/

		// 入力件数カウントアップ
		++twFileRenkKekkaCnt;

		// レコード件数チェック
		if(twFileRenkKekkaCnt >= 2)
		{
			String msg1 = inMap.getString(JBSbatACIFM197.FILE_TUBAN);
			String msg3 = inMap.getString(JBSbatACIFM197.REC_DIV);
			throw new JBSbatBusinessException(JPCBatchMessageConstant.EACB0580CE, new String[] {msg1, msg2, msg3});
		}
		else
		{
			msg2 = inMap.getString(JBSbatACIFM197.REC_DIV);
		}

		// ヘッダ部 ファイル通番 数値チェック
		if(!JBSbatCheckUtil.invoke(inMap.getString(JBSbatACIFM197.FILE_TUBAN), new String[]{"hannkakusuuji1"}))
		{
			String msg4 = "ファイル通番";
			String msg5 = inMap.getString(JBSbatACIFM197.FILE_TUBAN);
			throw new JBSbatBusinessException(JPCBatchMessageConstant.EACB0120TW, new String[] {msg4, msg5});
		}

		// ヘッダ部 レコード区分 チェック
		String recDiv = inMap.getString(JBSbatACIFM197.REC_DIV);
		if(!REC_DIV_HEAD.equals(recDiv))
		{
			throw new JBSbatBusinessException(JPCBatchMessageConstant.EACB0570CE, new String[] {});
		}

		
		// ヘッダ部 処理結果コード
		String syoriKekka = inMap.getString(JBSbatACIFM197.SYORI_KEKKA);
		if(!NORMAL_END.equals(syoriKekka))
		{
			errCnt++;
			// 警告終了 「【警告】エラー対象レコード＝（%1%）」
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EACB0340CW, new String[] {Integer.toString(errCnt)});
		}
		
		return null;
		
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/

		// レコード件数チェック
		if(twFileRenkKekkaCnt == 0)
		{
			throw new JBSbatBusinessException(JPCBatchMessageConstant.EACB0830CH, new String[] {});
		}
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
