#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：税率変換後料金情報蓄積
#
# 機能          ：日次作成される税率変換後料金情報ファイルを請求年月＋請求契約番号単位で差し替え最新化する。
#※過渡期のみ発生する情報であり、古月調整による会計計上にも使用するため蓄積クリア処理は実装しない。
#
# コマンド形式  ：EO30113C0J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v8.00.00        2014/01/18  FJ) 狭間     【ANK-1589-00-00】新規作成
#
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
#---ワークファイル削除モード
WK_RM=true

#---マッチング処理でLeftjoinがNULL時に"を付けなくする（マッチング使用時は必須）
export ZTLQUOTES=''

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

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

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

#
#--- ファイル定義
#
# 入力ファイル（税率変換後料金情報蓄積）
IN_FILE_01=${MID_DIR_AC}/ACIFM261001.csv
IN_FILE_01_WK1=${MID_DIR_AC}/${JOBNAME}_ACIFM261001_WK_1.csv

# 入力ファイル（税率変換後料金情報日次）
IN_FILE_02=${MID_DIR_AC}/ACIFM261008.csv
IN_FILE_02_WK1=${MID_DIR_AC}/${JOBNAME}_ACIFM261008_WK_1.csv
BS_IN_FILE_02_WK1=${MID_DIR_AC}/${JOBNAME}_ACIFM261008_BSORT_WK_1.csv

# マッチング定義ファイル（うち消費税相当額抽出）
MC_AC_CM_0086_DEF=${G_TOOLSH}/util/def/AC_CM_0086.def
MC_AC_CM_0086_DEF_WK1=${G_TOOLSH}/util/def/${JOBNAME}_AC_CM_0086_MATCHING_WK_1.def

# マッチングファイル（うち消費税相当額抽出）
MC_AC_CM_0086_CSV_WK1=${MID_DIR_AC}/${JOBNAME}_AC_CM_0086_MATCHING_WK_1.csv
BS_AC_CM_0086_CSV_WK1=${MID_DIR_AC}/${JOBNAME}_AC_CM_0086_BSORT_WK_1.csv

# 出力ファイル
OUT_FILE_01=${MID_DIR_AC}/ACIFM261001.csv

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

#-------------------------------------------------------------------------------
#--- 入力ファイル（税率変換後料金情報蓄積）編集
#- 改行コード変換（CRLF→LF）を行う。
#-------------------------------------------------------------------------------
tr -d "\r" < ${IN_FILE_01} > ${IN_FILE_01_WK1} &
pid_TR_ACIFM261004=$!

#-------------------------------------------------------------------------------
#--- 入力ファイル（税率変換後料金情報日次）編集
#- 請求契約番号、請求年月のみに編集しサマリする。ついでに改行コード変換（CRLF→LF）も行う。
#-------------------------------------------------------------------------------
(
#- 改行コード変換（CRLF→LF）
tr -d "\r" < ${IN_FILE_02} > ${IN_FILE_02_WK1}

#- 請求契約番号、請求年月のみに編集しサマリして、差し替え対象ファイルを作成する
bsortex \
  -sort key="0.10asca,1.6asca" \
  -record recform=txtcsv \
  -input reclen=200 file=${IN_FILE_02_WK1} \
  -summary suppress first \
  -output file=${BS_IN_FILE_02_WK1} \
   reconst="0.10,1.6"
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " bsortex Error(${IN_FILE_02}.csv:rc=$rc) "
    echo $JOBNAME " bsortex Error(${IN_FILE_02}.csv:rc=$rc) "
    exit ${G_RTN_ERROR}
fi
) &
pid_TR_ACIFM261003=$!

#-------------------------------------------------------------------------------
#--- 先行プロセスを待ち受け
#-------------------------------------------------------------------------------

#--- 入力ファイル（税率変換後料金情報蓄積）編集をwait
wait ${pid_TR_ACIFM261004}
rc_TR_ACIFM261004=$?

#--- 入力ファイル（税率変換後料金情報日次）編集をwait
wait ${pid_TR_ACIFM261003}
rc_TR_ACIFM261003=$?

#- エラー処理
if [ ${rc_TR_ACIFM261004} -ne 0 ] || [ ${rc_TR_ACIFM261003} -ne 0 ]
then
    #- エラーメッセージ出力
    if [ ${rc_TR_ACIFM261004} -ne 0 ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " TR ERROR(TR_ACIFM261004:rc=${rc_TR_ACIFM261004}) "
        echo $JOBNAME "TR ERROR(TR_ACIFM261004:rc=${rc_TR_ACIFM261004}) "
    fi
    if [ ${rc_TR_ACIFM261003} -ne 0 ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " TR ERROR(TR_ACIFM261003:rc=${rc_TR_ACIFM261003}) "
        echo $JOBNAME "TR ERROR(TR_ACIFM261003:rc=${rc_TR_ACIFM261003}) "
    fi
    #- 異常終了
    exit ${G_RTN_ERROR}
fi

#-------------------------------------------------------------------------------
#--- 税率変換後料金情報蓄積と差し替え対象ファイルをマッチング
#-------------------------------------------------------------------------------

#- マッチング定義更新
cp -f ${MC_AC_CM_0086_DEF}                       ${MC_AC_CM_0086_DEF_WK1}
sed -i -e "s%:ACIFM261004%${IN_FILE_01_WK1}%"    ${MC_AC_CM_0086_DEF_WK1}
sed -i -e "s%:ACIFM261003%${BS_IN_FILE_02_WK1}%" ${MC_AC_CM_0086_DEF_WK1}

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

#- 税率変換後料金情報蓄積から差し替え対象のレコードを削除する
bsortex \
  -copy \
  -record recform=txtcsv \
  -input reclen=200 file=${MC_AC_CM_0086_CSV_WK1} \
  -output file=${BS_AC_CM_0086_CSV_WK1} \
   include="0.10asc.lt.'0'" \
   reconst="1.END"
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " bsortex Error(${MC_AC_CM_0086_CSV_WK1}.csv:rc=$rc) "
    echo $JOBNAME " bsortex Error(${MC_AC_CM_0086_CSV_WK1}.csv:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#-------------------------------------------------------------------------------
#--- 税率変換後料金情報蓄積（編集済）と税率変換後料金情報日次を結合する
#-------------------------------------------------------------------------------

#- 税率変換後料金情報蓄積から差し替え対象のレコードを削除する
bsortex \
  -sort key="0.10asca,3.20asca,8.11asca" \
  -record recform=txtcsv \
  -input reclen=200 file=${BS_AC_CM_0086_CSV_WK1},${IN_FILE_02_WK1} \
  -output file=${OUT_FILE_01} linedlmt=crlf
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " bsortex Error(${OUT_FILE_01}.csv:rc=$rc) "
    echo $JOBNAME " bsortex Error(${OUT_FILE_01}.csv:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#ワーク削除
if [ $WK_RM = "true" ]
then
    rm -f ${IN_FILE_01_WK1}
    rm -f ${IN_FILE_02_WK1}
    rm -f ${BS_IN_FILE_02_WK1}
    rm -f ${MC_AC_CM_0086_DEF_WK1}
    rm -f ${MC_AC_CM_0086_CSV_WK1}
    rm -f ${BS_AC_CM_0086_CSV_WK1}
fi

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

exit ${G_RTN_NORMAL}
