/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatCHRiyoStpRlsCustHuryoGet
*	ソースファイル名	：JBSbatCHRiyoStpRlsCustHuryoGet.java
*	作成者				：富士通　
*	作成日				：2011年09月12日
*＜機能概要＞
*　利用停止解除・不良顧客データ抽出部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/09/12   富士通		新規作成
*********************************************************************/
package eo.business.service;

import eo.business.common.JACbatDebugLogUtil;
import eo.business.common.JBSbatBusinessService;
import eo.business.util.file.JBSbatCHIFM023;
import eo.business.util.file.JBSbatCHIFM096;
import eo.business.util.file.JBSbatKKIFI006;
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 JBSbatCHRiyoStpRlsCustHuryoGet 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, "[S][execute][inMap=" + inMap.getMap().toString() + "]");

		JBSbatOutputItem outputBean = new JBSbatOutputItem();

		// 料金対応記録種別詳細コード取得
		String prcTaioKirokSbtDtlCd = inMap.getString(JBSbatCHIFM096.PRC_TAIO_KIROK_SBT_DTL_CD);
		
		// 利用停止解除情報作成
		if (JACStrConst.TKRK_SBTD_USE_STP_CL.equals(prcTaioKirokSbtDtlCd))
		{
			outputBean.addOutMapList(makeRiyoStpRlsInfo(inMap));
		}
		// 不良顧客削除情報作成
		else if (JACStrConst.TKRK_SBTD_NG_CUST_DEL.equals(prcTaioKirokSbtDtlCd))
		{
			outputBean.addOutMapList_2(makeHuryoCustDelInfo(inMap));
		}
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][execute]");
		
		return outputBean;
		
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 利用停止解除情報を作成します。
	 * 
	 * @return JBSbatServiceInterfaceMap　出力情報
	 * @throws Exception  業務サービス内で発生した例外全般
	 */
	private JBSbatServiceInterfaceMap makeRiyoStpRlsInfo(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeRiyoStpRlsInfo]");

		// 利用停止解除情報
		JBSbatServiceInterfaceMap riyoStpRlsInfo = new JBSbatServiceInterfaceMap();
		
		// 請求契約番号
		riyoStpRlsInfo.set(JBSbatKKIFI006.SEIKY_KEI_NO, inMap.get(JBSbatCHIFM096.SEIKY_KEI_NO));
		// 依頼年月日
		riyoStpRlsInfo.set(JBSbatKKIFI006.REQ_YMD, super.opeDate);
		
		// 出力フラグON
		riyoStpRlsInfo.setOutFlg(true);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makeRiyoStpRlsInfo][riyoStpRlsInfo=" + riyoStpRlsInfo.getMap().toString() + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makeRiyoStpRlsInfo]");

		return riyoStpRlsInfo;
	}
	
	/**
	 * 不良顧客削除情報を作成します。
	 * 
	 * @return JBSbatServiceInterfaceMap　出力情報
	 * @throws Exception  業務サービス内で発生した例外全般
	 */
	private JBSbatServiceInterfaceMap makeHuryoCustDelInfo(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeHuryoCustDelInfo]");
		
		// 不良顧客削除情報
		JBSbatServiceInterfaceMap huryoCustDelInfo = new JBSbatServiceInterfaceMap();
		
		// 請求契約番号
		huryoCustDelInfo.set(JBSbatCHIFM023.SEIKY_KEI_NO, inMap.get(JBSbatCHIFM096.SEIKY_KEI_NO));
		
		// 出力フラグON
		huryoCustDelInfo.setOutFlg(true);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makeHuryoCustDelInfo][huryoCustDelInfo=" + huryoCustDelInfo.getMap().toString() + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makeHuryoCustDelInfo]");
		
		return huryoCustDelInfo;
	}
	
	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][terminal]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][terminal]");
		
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
