#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：請求収納
#
# シェル名      ：自社利用請求情報（サービス未設定分情報）付与
#
# 機能          ：自社利用請求情にサービス未設定分情報を付与する。
#
# コマンド形式  ：EO30Q0660J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v35.00.00       2017/10/24  FJ)寺園      ANK-3243-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"
   OPD="${RSLT_OPEDATE}"
else
   RSLT_OPEDATE="${OPD}"
fi

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

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

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

#-------------------------------------------------------------
#--- 入出力ファイル定義
#-------------------------------------------------------------
IN1FILE=${MID_DIR_AC}/ACIFM289002.csv
OUTFILE=${MID_DIR_AC}/ACIFM289003.csv
DEFFILE1=${G_TOOLSH}/util/def/AC_CM_0130.def

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

if [ ! -r ${DEFFILE1} ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${DEFFILE1}) "
    echo $JOBNAME " File is nonexist($DEFFILE1) "
    exit ${G_RTN_ERROR}
fi

#-------------------------------------------------------------
#--- ワークファイル定義
#-------------------------------------------------------------
DEFFILE1_WK1=${MID_DIR_AC}/${JOBNAME}_AC_CM_0130_WK1.def
IN1FILE_WK1=${MID_DIR_AC}/${JOBNAME}_OUT1_SORT.csv
IN1FILE_WK2=${MID_DIR_AC}/${JOBNAME}_OUT2_SORT.csv
IN1FILE_WK3=${MID_DIR_AC}/${JOBNAME}_OUT3_SORT.csv
MATCHFILE1_WK1=${MID_DIR_AC}/${JOBNAME}_OUT4_MATCHING.csv
MATCHFILE1_WK2=${MID_DIR_AC}/${JOBNAME}_OUT5_MATCHING.csv

#ワークファイルの削除
cat /dev/null > ${DEFFILE1_WK1}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

cat /dev/null > ${IN1FILE_WK1}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

cat /dev/null > ${IN1FILE_WK2}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

cat /dev/null > ${IN1FILE_WK3}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

cat /dev/null > ${MATCHFILE1_WK1}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

cat /dev/null > ${MATCHFILE1_WK2}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#-------------------------------------------------------------
#---出力ファイルの削除
#-------------------------------------------------------------
cat /dev/null > ${OUTFILE}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    exit ${G_RTN_ERROR}
fi


#-------------------------------------------------------------
#--- 自社利用請求情報ファイルを請求契約番号、料金グループコード、サービス契約番号でソートし、
#--- サービス契約番号未設定分と設定分に振り分ける
#-------------------------------------------------------------
bsortex \
     -sort key="0.10asc,2.2asc,0.10asc" \
     -record recform=txtcsv \
     -input file=${IN1FILE} \
            reclen=1100 \
     -output file=${IN1FILE_WK1} case="1.10asc.eq.'          '" \
     -output file=${IN1FILE_WK2} case=other \

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

#-------------------------------------------------------------
#--- 自社利用請求情報ファイル（サービス契約番号設定分）を同一料金グループ内で先頭のみに集約する
#-------------------------------------------------------------
bsortex -merge key=0.10asc,2.2asc -record recform=txtcsv -input file=${IN1FILE_WK2} reclen=1100 -summary suppress first -output file=${IN1FILE_WK3}

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

#-------------------------------------------------------------
#--- バインド変数設定
#-------------------------------------------------------------
cp -f ${DEFFILE1} ${DEFFILE1_WK1}
sed -i -e "s%:CH0101_MAST%${IN1FILE_WK1}%" ${DEFFILE1_WK1}
sed -i -e "s%:CH0101_TRAN%${IN1FILE_WK3}%" ${DEFFILE1_WK1}

#-------------------------------------------------------------
#--- マッチング
#-------------------------------------------------------------
export ZTLOUTFILE=${MATCHFILE1_WK1}
${G_TOOLSH}/util/bin/ZTLMAT01 ${DEFFILE1_WK1}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " MATCHING UTIL Error($SVC util:rc=$rc ${DEFFILE1_WK1}) "
    echo $JOBNAME " MATCHING UTIL Error($SVC util:rc=$rc ${DEFFILE1_WK1}) "
    exit ${G_RTN_ERROR}
fi

#-------------------------------------------------------------
#--- 自社利用請求情報ファイルをグループ組織コード、チーム組織コード、請求契約番号、サービス契約番号毎に請求金額を集計する
#-------------------------------------------------------------
cat ${MATCHFILE1_WK1} ${IN1FILE_WK2} > ${MATCHFILE1_WK2}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

bsortex -sort key=8.10asca,10.10asca,0.10asca,1.10asca \
    -record recform=txtcsv -summary field=4.12ascd first \
    -input reclen=1100 file=${MATCHFILE1_WK2} \
    -output file=${OUTFILE}

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

#-------------------------------------------------------------
#---ワークファイル削除
#-------------------------------------------------------------
rm -f ${DEFFILE1_WK1}
rm -f ${IN1FILE_WK1}
rm -f ${IN1FILE_WK2}
rm -f ${IN1FILE_WK3}
rm -f ${MATCHFILE1_WK1}
rm -f ${MATCHFILE1_WK2}

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

exit ${G_RTN_NORMAL}
