#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：請求収納
#
# シェル名      ：貸倒れ対象者内訳分割（利不）
#
# 機能          ：利用不可減額明細を消し込むため、貸倒れ対象者内訳ファイルを
#利用不可減額明細とそれ以外に分割する。また、分割ファイルはソートして出力する。
#
# コマンド形式  ：EO61P0153J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v68.00         2023/10/25  FJ）森脇     【ANK-4475-00-00】インボイス対応 STEP2
##############################################################

##############################################################
# 環境変数定義
##############################################################

#
#---ツール格納場所
#
G_TOOLSH=.

#
#---環境変数定義Shell呼び出し
#
. EOK010110J0.sh

#
#---ＪＯＢ名
#
JOBNAME=`basename $0 | sed -e "s/\.sh//g"`

#
#---サービス（業務プロセス）
#
SVC=$JOBNAME

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
#xxx=xxxxxxx

#-- ワーク削除フラグ
WK_RM=true

#
#---ファイル分割キー
#
BNKT_VAL1=7

##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

#
#---パラメタ定義
#

P1="OPD=,"
P2="SVCCTL=,"
P3="JOB=EO61P0153J0,"
P4="IND1=,"
P5="INF1=,"
P6="IND2=,"
P7="INF2=,"
P8="OTD1=,"
P9="OTF1=,"
P10="OTD2=,"
P11="OTF2=,"
P12="TABLENAME=,"
P13="SQLKEY=,"
P14="SQLPARAM=,"
P15="ERRFILE=,"
P16="RECOVERY=,"
P17="BREAKPTN=,"
P18="FREE="
PARA="$P1$P2$P3$P4$P5$P6$P7$P8$P9$P10$P11$P12$P13$P14$P15$P16$P17$P18"

sh ${G_TOOLSH}/EOK010210J0.sh CS00027I $JOBNAME

#
#---ファイル定義
#
#-- 入力ファイル
#-- 貸倒れ対象者内訳ファイル
INFILE=${MID_DIR_CH}/CHIFM441001.csv

#-- 出力ファイル
#-- 貸倒れ対象者内訳ファイル（減額）
OUTFILE1=${MID_DIR_CH}/CHIFM441002.csv
TMPOUTFILE1=${MID_DIR_CH}/CHIFM441002.tmp.${JOBNAME}.csv
#-- 貸倒れ対象者内訳ファイル（引代）
OUTFILE2=${MID_DIR_CH}/CHIFM441003.csv
TMPOUTFILE2=${MID_DIR_CH}/CHIFM441003.tmp.${JOBNAME}.csv

#
#--- 各ファイルの存在チェックを行う
#
if [ ! -r $INFILE ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist($INFILE) "
    echo $JOBNAME " File is nonexist($INFILE) "
    exit ${G_RTN_ERROR}
fi

#----------------------------------------------------------------------------------------------------
#--- 料金項目コードの9桁目でファイル分割し、
#--- 請求契約番号、債権番号、処理順、不課税識別、料金項目コードでソートする。
#----------------------------------------------------------------------------------------------------
bsortex \
    -input reclen=210 file=${INFILE} \
    -record recform=txtfix \
    -output file=${TMPOUTFILE1} case="8.1asc.eq.'${BNKT_VAL1}'" \
    -output file=${TMPOUTFILE2} case=other

rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT1 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " SORT1 Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

bsortex -sort key=2.10asca,3.12asca,4.3ascaN,15.1asca,0.11asca \
    -record recform=txtcsv \
    -input reclen=210 file=${TMPOUTFILE1} \
    -output file=${OUTFILE1}

rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT2 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " SORT2 Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

bsortex -sort key=2.10asca,3.12asca,4.3ascaN,15.1asca,0.11asca \
    -record recform=txtcsv \
    -input reclen=210 file=${TMPOUTFILE2} \
    -output file=${OUTFILE2}

rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT3 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " SORT3 Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

if [ $WK_RM = "true" ]
then
    rm -f ${TMPOUTFILE1}
    rm -f ${TMPOUTFILE2}
fi

#
#--- ジョブの終了メッセージを出力する
#
sh ${G_TOOLSH}/EOK010210J0.sh CS00028I $JOBNAME
sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME

exit ${G_RTN_NORMAL}
