#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：当月分サービス契約情報作成（名称付加）
#
# 機能          ：当月分サービス契約情報に料金項目名称を付加する。
#
# コマンド形式  ：EO30A10D0J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v48.00.00       2020/01/27  FJ) 寺園     【ANK-3796-00-00】  テレビリースサービス導入対応
# v48.00.01       2020/02/20  FJ) 寺園     【IT2-2020-0000005】  テレビリースサービス導入対応
# v52.00.00       2021/03/01  FJ) 鈴木     【ANK-3910-00-00】  定額サービスリース品追加対応
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1
#
#---運用日付取得
#
if [ "${OPD}" = "" ]; then
   . EOK010310J0.sh "BDATE"
else
   RSLT_OPEDATE="${OPD}"
fi

#
#---業務で必要な変数定義
#
#手修正あり
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

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

P1="OPD=,"
P2="SVCCTL=,"
P3="JOB=EO30A10D0J0,"
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

#
#---ファイル定義
#
INFILE1=${MID_DIR_AC}/ACIFM344001.csv
INFILE2=${MID_DIR_AC}/ACIFM340001.csv
INFILE3=${MID_DIR_AC}/ACIFM341001.csv
OUTFILE=${MID_DIR_AC}/ACIFM342001.csv
INFILE1_WK1=${MID_DIR_AC}/${JOBNAME}_OUT1.csv
INFILE1_WK2=${MID_DIR_AC}/${JOBNAME}_OUT2.csv
#v48.00.01 DEL START
#INFILE1_WK3=${MID_DIR_AC}/${JOBNAME}_OUT3.csv
#INFILE1_WK4=${MID_DIR_AC}/${JOBNAME}_OUT4.csv
#v48.00.01 DEL END
INFILE1_WK5=${MID_DIR_AC}/${JOBNAME}_OUT5.csv
INFILE1_WK6=${MID_DIR_AC}/${JOBNAME}_OUT6.csv
INFILE1_WK7=${MID_DIR_AC}/${JOBNAME}_OUT7.csv
INFILE1_WK8=${MID_DIR_AC}/${JOBNAME}_OUT8.csv


#---マッチング定義
DEF_DIR=${G_TOOLSH}/util/def
DEF_CM0172=${DEF_DIR}/AC_CM_0172.def
DEF_CM0173=${DEF_DIR}/AC_CM_0173.def
DEF_CM0174=${DEF_DIR}/AC_CM_0174.def

##############################################################
#--- MATCHING
##############################################################
MATCHING(){
    export ZTLOUTFILE=$2
    ${G_TOOLSH}/util/bin/ZTLMAT01 $1
    rc=$?
    if [ $rc -ne 0 ]
    then
          sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " matching error(matching:$1=$rc) "
          echo $JOBNAME " matching error(matching:$1=$rc) "
          exit ${G_RTN_ERROR}
    fi
}


#
#---ＳＯＲＴ
#当月分サービス契約情報を料金グループコード、料金コースコード、料金プランコード、料金項目コードでソートする
#

bsortex -sort key="2.2asc,3.3asc,4.12asc,8.11asc" -record recform=txtcsv -input file=${INFILE1} reclen=150 -output file=${INFILE1_WK1}

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

#
#--- ファイルマッチング処理
#当月分サービス契約情報と料金項目出力名称アンロードをマッチングする
#
export INPUTFILE1_MAST=${INFILE1_WK1}
export INPUTFILE2_TRAN=${INFILE2}
MATCHING ${DEF_CM0172} ${INFILE1_WK2}

#v48.00.01 DEL START
##- 料金項目名称が取得出来なかったものと取得出来たものに振り分ける
#bsortex \
#  -copy \
#  -record recform=txtcsv \
#  -input reclen=300 file=${INFILE1_WK2} \
#  -output file=${INFILE1_WK3} case="9.1asc.lt.'0'" \
#  -output file=${INFILE1_WK4} case=other reconst=0.END,EMPTYA \
#
#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
#v48.00.01 DEL END

#
#---ＳＯＲＴ
#アンマッチファイルを料金グループコード、料金コースコード、料金プランコード（内訳）、料金項目コードでソートする。
#

#v48.00.01 MOD START
#bsortex -sort key="2.2asc,3.3asc,7.12asc,8.11asc" -record recform=txtcsv -input file=${INFILE1_WK3} reclen=150 -output file=${INFILE1_WK5}
#v52.00.00 MOD START
#bsortex -sort key="2.2asc,3.3asc,7.12asc,8.11asc" -record recform=txtcsv -input file=${INFILE1_WK2} reclen=150 -output file=${INFILE1_WK5}
bsortex -sort key="2.2asc,3.3asc,7.12asc,8.11asc" -record recform=txtcsv -input file=${INFILE1_WK2} reclen=200 -output file=${INFILE1_WK5}
#v52.00.00 MOD END

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

#
#--- ファイルマッチング処理
#当月分サービス契約情報（アンマッチ分）と料金項目出力名称アンロードをマッチングする
#
export INPUTFILE1_MAST=${INFILE1_WK5}
export INPUTFILE2_TRAN=${INFILE2}
MATCHING ${DEF_CM0173} ${INFILE1_WK6}

#
#---ＳＯＲＴ
#サービス契約番号、料金項目コード、料金項目名称（内訳）、料金項目名称でソートする
#

#v48.00.01 MOD START
#bsortex -sort key="0.10asc,8.11asc,9.80asc,10.80asc" -record recform=txtcsv -input file=${INFILE1_WK4},${INFILE1_WK6} reclen=300 -output file=${INFILE1_WK7}
bsortex -sort key="0.10asc,8.11asc,10.80asc,9.80asc" -record recform=txtcsv -input file=${INFILE1_WK6} reclen=300 -output file=${INFILE1_WK7}
#v48.00.01 MOD END

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


#
#--- サービス契約番号、料金項目コードで集約する
#
bsortex \
    -merge key=0.10asc,8.11asc -record recform=txtcsv \
    -input file=${INFILE1_WK7} \
        reclen=300 \
    -summary suppress last \
    -output file=${INFILE1_WK8}

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

#
#--- ファイルマッチング処理
#当月分サービス契約情報と課金先アンロードをマッチングする
#
export INPUTFILE1_MAST=${INFILE1_WK8}
export INPUTFILE2_TRAN=${INFILE3}
MATCHING ${DEF_CM0174} ${OUTFILE}

#
#--- ワークファイル削除
#
rm ${INFILE1_WK1}
rm ${INFILE1_WK2}
#v48.00.01 DEL START
#rm ${INFILE1_WK3}
#rm ${INFILE1_WK4}
#v48.00.01 DEL END
rm ${INFILE1_WK5}
rm ${INFILE1_WK6}
rm ${INFILE1_WK7}
rm ${INFILE1_WK8}

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

exit ${G_RTN_NORMAL}
