/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom  					 *
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatCHYoksiInfoMake
*	ソースファイル名	：JBSbatCHYoksiInfoMake.java
*	作成者				：富士通　
*	作成日				：2011年07月13日
*＜機能概要＞
*　抑止情報作成部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/07/13   富士通		新規作成
*********************************************************************/
package eo.business.service;

import eo.business.common.JACbatDebugLogUtil;
import eo.business.common.JBSbatBusinessService;
import eo.business.util.file.JBSbatCHIFM065;
import eo.business.util.file.JBSbatCHIFM066;
import eo.common.constant.JACStrConst;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatServiceInterfaceMap;

/**
 * 抑止情報作成 <p>
 *<BR>
 * @author 富士通
 */
public class JBSbatCHYoksiInfoMake extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
		
		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 + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][initial]");
	
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][inMap=" + inMap.getMap().toString() + "]");
		
		// 抑止情報作成
		JBSbatOutputItem outputItem = makeYoksiInfo(inMap);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][execute]");
		
		return outputItem;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 抑止情報を作成します。
	 * 
	 * オーソリチェック結果情報．抑止請求先一覧出力対象フラグ ＝ "1"(対象)
	 * の情報に対し、「抑止情報」を出力する。
	 * 
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception　業務サービス内で発生した例外全般
	 */
	private JBSbatOutputItem makeYoksiInfo(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeYoksiInfo]");
		
		JBSbatOutputItem outputItem = null;
		
		// オーソリチェック結果情報．抑止請求先一覧出力対象フラグ ＝ "1"(対象)
		if(JACStrConst.YOKSI_SIKY_SK_TG_FLG_TRGT.equals(inMap.getString(JBSbatCHIFM066.YOKSI_SIKY_SK_TG_FLG)))
		{
			outputItem = new JBSbatOutputItem();
			
			// 抑止情報
			JBSbatServiceInterfaceMap yoksiInfo = new JBSbatServiceInterfaceMap();
			
			// 請求契約番号
			yoksiInfo.set(JBSbatCHIFM065.SEIKY_KEI_NO, inMap.get(JBSbatCHIFM066.SEIKY_KEI_NO));
			// 請求年月
			yoksiInfo.set(JBSbatCHIFM065.SEIKY_YM, inMap.get(JBSbatCHIFM066.SEIKY_YM));
			// 発行抑止コード
			yoksiInfo.set(JBSbatCHIFM065.HAK_YOKSI_CD, JACStrConst.SEIKY_YOKSI_CD_KYOSEI_MDGC);
			
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][makeYoksiInfo][yoksiInfo=" + yoksiInfo.getMap().toString() + "]");
			
			// 出力フラグON
			yoksiInfo.setOutFlg(true);
			
			// 出力共通電文設定
			outputItem.addOutMapList(yoksiInfo);
		}
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makeYoksiInfo]");
		
		return outputItem;
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][terminal]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][terminal]");
	
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
