#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：うち消費税相当額抽出（工事遅延）
#
# 機能          ：入力情報より、うち消費税相当額の内訳のみを抽出・編成することを目的とする。
#対象となる料金項目コードは業務パラメータ管理より”AC_TAX_PRC_KMK_CD”（うち消費税相当額料金項目コード）にて取得する。
#
# コマンド形式  ：EO30133A0J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v8.00.00        2014/02/05  FJ) 伊藤     【ANK-1589-00-00】新規作成
#
##############################################################

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

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

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

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

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

#
#---OPD
#
read OPD <${MID_DIR_AC}/ACIFM037001.csv

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

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

#--- 業務パラメータID(うち消費税相当額料金項目コード)
WORK_PARAM="AC_TAX_PRC_KMK_CD"

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

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

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

P1="OPD=,"
P2="SVCCTL=JBSbatMultiServiceControl,"
P3="JOB=EO30133A0J0,"
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}/ACIFM048020.csv
IN_FILE_01_WK1=${MID_DIR_AC}/${JOBNAME}_ACIFM048020_WK_1.csv

# 業務パラメータアンロード定義ファイル
UL_AC_U_ZM0321_01_DEF=${SQL_DIR}/AC_U_ZM0321_01.sql
UL_AC_U_ZM0321_01_DEF_WK1=${SQL_DIR}/${JOBNAME}_AC_U_ZM0321_01_UNLOADER_WK_1.sql

UL_AC_U_ZM0321_01_CSV_WK1=${MID_DIR_AC}/${JOBNAME}_AC_U_ZM0321_01_UNLOAD_WK_1.csv
UL_AC_U_ZM0321_01_CSV_WK2=${MID_DIR_AC}/${JOBNAME}_AC_U_ZM0321_01_UNLOAD_WK_2.csv

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

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

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

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

#
#--- SQLバインド変数マッピング
#

#- 業務パラメータ
cp -f ${UL_AC_U_ZM0321_01_DEF}             ${UL_AC_U_ZM0321_01_DEF_WK1}
sed -i -e "s/:WORK_PARAM/'${WORK_PARAM}'/" ${UL_AC_U_ZM0321_01_DEF_WK1}
sed -i -e "s/:OPE_DATE/'${RSLT_OPEDATE}'/" ${UL_AC_U_ZM0321_01_DEF_WK1}

#-------------------------------------------------------------------------------
#--- 入力ファイル編集
#- 改行コード変換（CRLF→LF）を行う。
#-------------------------------------------------------------------------------
tr -d "\r" < ${IN_FILE_01} > ${IN_FILE_01_WK1}

#-------------------------------------------------------------------------------
#--- 業務パラメータ管理から料金項目コード取得処理
#-------------------------------------------------------------------------------

#- 業務パラメータUNLOAD
sh ${G_TOOLSH}/EOKULD03.sh ${UL_AC_U_ZM0321_01_DEF_WK1} ${UL_AC_U_ZM0321_01_CSV_WK1}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " UNLOAD Error($SVC ${UL_AC_U_ZM0321_01_DEF_WK1}:rc=$rc) "
    echo $JOBNAME " UNLOAD Error($SVC ${UL_AC_U_ZM0321_01_DEF_WK1}:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#- カンマ区切りの業務パラメータ設定値を行に変換
cp  -f ${UL_AC_U_ZM0321_01_CSV_WK1} ${UL_AC_U_ZM0321_01_CSV_WK2}
sed -i -e "s/,/\n/g"    ${UL_AC_U_ZM0321_01_CSV_WK2}

#-------------------------------------------------------------------------------
#--- 入力ファイルと料金項目コードをマッチングして絞り込む
#-------------------------------------------------------------------------------

#- マッチング定義更新
cp -f ${MC_AC_CM_0085_DEF}                                  ${MC_AC_CM_0085_DEF_WK1}
sed -i -e "s%:ACIFM084%${IN_FILE_01_WK1}%"                  ${MC_AC_CM_0085_DEF_WK1}
sed -i -e "s%:AC_U_ZM0321_01%${UL_AC_U_ZM0321_01_CSV_WK2}%" ${MC_AC_CM_0085_DEF_WK1}

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

#-------------------------------------------------------------------------------
#--- 出力ファイル改行コード変換（LF→CRLF）
#-------------------------------------------------------------------------------
bsortex \
  -copy \
  -record recform=txtcsv \
  -input reclen=200 file=${MC_AC_CM_0085_CSV_WK1} \
  -output file=${OUT_FILE_01} linedlmt=crlf reconst="0.END,EMPTY"
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 ${UL_AC_U_ZM0321_01_DEF_WK1}
    rm -f ${UL_AC_U_ZM0321_01_CSV_WK1}
    rm -f ${UL_AC_U_ZM0321_01_CSV_WK2}
    rm -f ${MC_AC_CM_0085_DEF_WK1}
    rm -f ${MC_AC_CM_0085_CSV_WK1}
fi

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

exit ${G_RTN_NORMAL}

