/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatCHSknksitkcmNukinJutoRsltMatch
*	ソースファイル名	：JBSbatCHSknksitkcmNukinJutoRsltMatch.java
*	作成者				：富士通　
*	作成日				：2021年07月28日
*＜機能概要＞
*　債権回収委託会社入金充当結果マッチデータ作成部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v54.00.00	2021/07/28	FJ)吉田		【ANK-4079-00-00】債権委託先会社からの入金処理システム化対応
*********************************************************************/
package eo.business.service;

import eo.business.common.JACbatDebugLogUtil;
import eo.business.common.JBSbatBusinessService;
import eo.business.common.JBSbatMatchServiceInterface;
import eo.business.util.file.JBSbatCHIFM097;
import eo.business.util.file.JBSbatCHIFM400;
import eo.business.util.file.JBSbatCHIFM401;
import eo.common.constant.JACStrConst;
import eo.common.constant.JPCBatchMessageConstant;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatServiceInterfaceMap;

/**
* 債権回収委託会社入金充当結果マッチング <p>
*<BR>
* @author 富士通
*/
public class JBSbatCHSknksitkcmNukinJutoRsltMatch extends JBSbatBusinessService implements JBSbatMatchServiceInterface
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** キーマッチ処理フラグ*/
	private boolean matchProcFlg;

	/** マスタファイル処理フラグ*/
	private boolean mastProcFlg;

	/** トランファイル処理フラグ*/
	private boolean tranProcFlg;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	// ログ出力用ファイル名
	/** マスタファイル名 */ 
	private static final String MAST_FILE_NAME = "入金結果";
	
	/** トランファイル名 */
	private static final String TRAN_FILE_NAME = "債権充当結果";
	
	// 退避
	/** 退避．入金番号  */
	private String prcNyukinNo = JACStrConst.KARA_MOJI;

	/**
	 * 初期処理
	 * @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, "[S][initial][opeDate=" + super.opeDate + "]");

	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param mastMap　入力電文
	 * @param tranMap　入力電文
	 * @param outputInItem  入力情報
	 * @return JBSbatOutputItem 出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap mastMap, JBSbatServiceInterfaceMap tranMap, JBSbatOutputItem outputInItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute]");
		assert mastMap != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute][mastMap=" + mastMap.getMap().toString() + "]") : true;
		assert tranMap != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute][tranMap=" + tranMap.getMap().toString() + "]") : true;
		
		// 入力Ｍのみ存在する
		if (mastMap != null && tranMap == null)
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍのみ存在する]");
			
			// マスタ処理フラグ→true
			this.setMastProcFlg(true);
			
			String mastKey = mastMap.getString(JBSbatCHIFM400.NYUKIN_NO);
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][mastKey = " + mastKey + "]");
			
			// 退避.入金番号 ≠ 入力Ｍ.入金番号の場合
			if(!mastKey.equals(prcNyukinNo))
			{
				// マイナーアラームを呼動する
				super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB1470KW, new String[] {MAST_FILE_NAME, TRAN_FILE_NAME});
				super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB0350CW, new String[] {mastMap.getMap().toString()});
			}
		}
		// 入力Ｔのみ存在する
		else if (mastMap == null && tranMap != null)
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｔのみ存在する]");
			
			// トラン処理フラグ→true
			this.setTranProcFlg(true);
			
			String tranKey = tranMap.getString(JBSbatCHIFM097.NYUKIN_NO);
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][tranKey = " + tranKey + "]");
			
			// マイナーアラームを呼動する
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB1470KW, new String[] {TRAN_FILE_NAME, MAST_FILE_NAME});
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB0350CW, new String[] {tranMap.getMap().toString()});
		}
		// 入力Ｍ、入力Ｔともに存在する
		else
		{
			String mastKey = mastMap.getString(JBSbatCHIFM400.NYUKIN_NO);
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][mastKey = " + mastKey + "]");
			
			String tranKey = tranMap.getString(JBSbatCHIFM097.NYUKIN_NO);
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][tranKey = " + tranKey + "]");
			
			// 入力Ｍ＝入力Ｔ（マッチ）
			if (mastKey.compareTo(tranKey) == 0)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍ、入力Ｔともに存在する][入力Ｍ＝入力Ｔ（マッチ）]");
				
				// トラン処理フラグ→true
				this.setTranProcFlg(true);
				
				// 出力
				makeOutputData(mastMap, tranMap, outputInItem);
				
				 //処理した入金番号を退避
				prcNyukinNo = tranKey;
				
			}
			// 入力Ｍ＜入力Ｔ
			else if (mastKey.compareTo(tranKey) < 0)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍ、入力Ｔともに存在する][入力Ｍ＜入力Ｔ]");
				
				// マスタ処理フラグ→true
				this.setMastProcFlg(true);
				
				// 退避.入金番号 ≠ 入力Ｔ.入金番号の場合
				if(!mastKey.equals(prcNyukinNo))
				{
					// マイナーアラームを呼動する
					super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB1470KW, new String[] {MAST_FILE_NAME, TRAN_FILE_NAME});
					super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB0350CW, new String[] {mastMap.getMap().toString()});
				}
			}
			// 入力Ｍ＞入力Ｔ
			else
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍ、入力Ｔともに存在する][入力Ｍ＞入力Ｔ]");
				// トラン処理フラグ→true
				this.setTranProcFlg(true);
				
				// マイナーアラームを呼動する
				super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB1470KW, new String[] {TRAN_FILE_NAME, MAST_FILE_NAME});
				super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB0350CW, new String[] {tranMap.getMap().toString()});
			}
		}
		
		assert outputInItem != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][execute][outputInItem=" + outputInItem.getOutMapList().toString() + "]") : true;
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][execute]");
		
		return outputInItem;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 出力データを作成します。
	 * 
	 * @param mastMap 入力電文
	 * @param tranMap 入力電文
	 * @param outputInItem  出力電文
	 * @param kagenSkbtCd 加減識別コード
	 * @throws Exception
	 */
	private void makeOutputData(JBSbatServiceInterfaceMap mastMap, JBSbatServiceInterfaceMap tranMap, JBSbatOutputItem outputInItem) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeOutputData]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][makeOutputData][mastMap=" + mastMap.getMap().toString() + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][makeOutputData][tranMap=" + tranMap.getMap().toString() + "]");

		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();
		
		// 請求契約番号
		outMap.setString(JBSbatCHIFM401.SEIKY_KEI_NO, tranMap.getString(JBSbatCHIFM097.SEIKY_KEI_NO));
		// 入金番号
		outMap.setString(JBSbatCHIFM401.NYUKIN_NO, tranMap.getString(JBSbatCHIFM097.NYUKIN_NO));
		// 請求番号
		outMap.setString(JBSbatCHIFM401.SEIKY_NO, tranMap.getString(JBSbatCHIFM097.SEIKY_NO));
		// 請求年月
		outMap.setString(JBSbatCHIFM401.SEIKY_YM, tranMap.getString(JBSbatCHIFM097.SEIKY_YM));
		// 債権番号
		outMap.setString(JBSbatCHIFM401.SAIKEN_NO, tranMap.getString(JBSbatCHIFM097.SAIKEN_NO));
		// 整理番号
		outMap.setString(JBSbatCHIFM401.SEIRI_NO, tranMap.getString(JBSbatCHIFM097.SEIRI_NO));
		// サービス番号
		outMap.setString(JBSbatCHIFM401.SVC_NO, tranMap.getString(JBSbatCHIFM097.SVC_NO));
		// サービス識別
		outMap.setString(JBSbatCHIFM401.SVC_SKBT, tranMap.getString(JBSbatCHIFM097.SVC_SKBT));
		// 料金グループコード
		outMap.setString(JBSbatCHIFM401.PRC_GRP_CD, tranMap.getString(JBSbatCHIFM097.PRC_GRP_CD));
		// 料金コースコード
		outMap.setString(JBSbatCHIFM401.PCRS_CD, tranMap.getString(JBSbatCHIFM097.PCRS_CD));
		// 料金サービスコード
		outMap.setString(JBSbatCHIFM401.PRC_SVC_CD, tranMap.getString(JBSbatCHIFM097.PRC_SVC_CD));
		// 料金項目コード
		outMap.setString(JBSbatCHIFM401.PRC_KMK_CD, tranMap.getString(JBSbatCHIFM097.PRC_KMK_CD));
		// 金額
		outMap.setString(JBSbatCHIFM401.AMNT, tranMap.getString(JBSbatCHIFM097.AMNT));
		// 加減識別コード
		outMap.setString(JBSbatCHIFM401.KAGEN_SKBT_CD, tranMap.getString(JBSbatCHIFM097.KAGEN_SKBT_CD));
		// 入金ステータス
		outMap.setString(JBSbatCHIFM401.NYUKIN_STAT, tranMap.getString(JBSbatCHIFM097.NYUKIN_STAT));
		// 入金経路コード
		outMap.setString(JBSbatCHIFM401.NYUKIN_ROUTE_CD, tranMap.getString(JBSbatCHIFM097.NYUKIN_ROUTE_CD));
		// 入金対象債権年月
		outMap.setString(JBSbatCHIFM401.NYUKIN_TG_SAIKEN_YM, tranMap.getString(JBSbatCHIFM097.NYUKIN_TG_SAIKEN_YM));
		// 入金処理年月日
		outMap.setString(JBSbatCHIFM401.NYUKIN_TRN_YMD, tranMap.getString(JBSbatCHIFM097.NYUKIN_TRN_YMD));
		// コンビニエンスストアコード
		outMap.setString(JBSbatCHIFM401.CVSTORE_CD, tranMap.getString(JBSbatCHIFM097.CVSTORE_CD));
		// コンビニリアル速報通知年月日
		outMap.setString(JBSbatCHIFM401.CVSTORE_REAL_SOKHO_TCH_YMD, tranMap.getString(JBSbatCHIFM097.CVSTORE_REAL_SOKHO_TCH_YMD));
		// コンビニ速報通知年月日
		outMap.setString(JBSbatCHIFM401.CVSTORE_SOKHO_TCH_YMD, tranMap.getString(JBSbatCHIFM097.CVSTORE_SOKHO_TCH_YMD));
		// 督促番号
		outMap.setString(JBSbatCHIFM401.TOKUSOKU_NO, tranMap.getString(JBSbatCHIFM097.TOKUSOKU_NO));
		// 督促異動番号
		outMap.setString(JBSbatCHIFM401.TOKUSOKU_IDO_NO, tranMap.getString(JBSbatCHIFM097.TOKUSOKU_IDO_NO));
		// 変更前督促ステータス
		outMap.setString(JBSbatCHIFM401.TOKUSOKU_STAT_BF, tranMap.getString(JBSbatCHIFM097.TOKUSOKU_STAT_BF));
		// 変更後督促ステータス
		outMap.setString(JBSbatCHIFM401.TOKUSOKU_STAT_AF, tranMap.getString(JBSbatCHIFM097.TOKUSOKU_STAT_AF));
		// 督促ステータス変更フラグ
		outMap.setString(JBSbatCHIFM401.TOKUSOKU_STAT_CHG_FLG, tranMap.getString(JBSbatCHIFM097.TOKUSOKU_STAT_CHG_FLG));
		// 金庫番号
		outMap.setString(JBSbatCHIFM401.KNK_NO, tranMap.getString(JBSbatCHIFM097.KNK_NO));
		// 結果
		outMap.setString(JBSbatCHIFM401.RSLT, tranMap.getString(JBSbatCHIFM097.RSLT));
		// データ種類
		outMap.setString(JBSbatCHIFM401.DATA, tranMap.getString(JBSbatCHIFM097.DATA));
		// エラー内容
		outMap.setString(JBSbatCHIFM401.ERR_NAIYO, tranMap.getString(JBSbatCHIFM097.ERR_NAIYO));
		// 領収日
		outMap.setString(JBSbatCHIFM401.RECEIPT_YMD, mastMap.getString(JBSbatCHIFM400.RECEIPT_YMD));
		// 入金額
		outMap.setString(JBSbatCHIFM401.NYUKIN_AMNT, mastMap.getString(JBSbatCHIFM400.NYUKIN_AMNT));
		// 債権回収委託会社コード
		outMap.setString(JBSbatCHIFM401.SKNKSITKCM_CD, mastMap.getString(JBSbatCHIFM400.SKNKSITKCM_CD));
		// 記事
		outMap.setString(JBSbatCHIFM401.KIJI, mastMap.getString(JBSbatCHIFM400.KIJI));
		
		outMap.setOutFlg(true);
		
		// 出力レコード作成
		outputInItem.addOutMapList(outMap);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][selectPrcKmkCd][outputInItem=" + outputInItem.getOutMapList().toString() + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][selectPrcKmkCd]");
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][terminal]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][terminal]");
		
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	
	/**
	 * @return mastProcFlg を戻します。
	 */
	public boolean isMastProcFlg()
	{
		return mastProcFlg;
	}

	/**
	 * @return matchProcFlg を戻します。
	 */
	public boolean isMatchProcFlg()
	{
		return matchProcFlg;
	}

	/**
	 * @return tranProcFlg を戻します。
	 */
	public boolean isTranProcFlg()
	{
		return tranProcFlg;
	}

	/**
	 * @param mast_ProcFlg 設定する mastProcFlg。
	 */
	public void setMastProcFlg(boolean mast_ProcFlg)
	{
		this.mastProcFlg = mast_ProcFlg;
	}

	/**
	 * @param match_ProcFlg 設定する matchProcFlg。
	 */
	public void setMatchProcFlg(boolean match_ProcFlg)
	{
		this.matchProcFlg = match_ProcFlg;
	}

	/**
	 * @param tran_ProcFlg 設定する tranProcFlg。
	 */
	public void setTranProcFlg(boolean tran_ProcFlg)
	{
		this.tranProcFlg = tran_ProcFlg;
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
