#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：ＶＢ料金ファミリーパック減額（再計算分）
#
# 機能          ：VB料金ファミリーパック減額(取込未分)と同プログラムにて再計算分の減額処理を行う。
#
#
# コマンド形式  ：EO30110B0J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v5.00           2013/06/25  FJ) 早崎    【TG1-2013-0000647】請求契約番号によるソート処理追加
# v5.01           2013/08/09  FJ) 狭間    【TG1-2013-0000976】性能改善の為、java内部でのDB読込をアンローダー化
# v36.00.00       2018/03/12  FJ) 謝      【ANK-3388-00-00】夜間バッチジョブ多重度・SQL最適化による実行時間の改善対応
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

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

# ANK-3388-00-00 ADD START
#
#--- クエリ編集(マッチング)
#       p1：ＳＱＬ定義ファイル名
#       p2：バインド変数置換文字
EDIT_MATCHING_QUERY()
{
    MATCHING_FILE=$1
    MATCHING_QUERY_WORK=${ULD_WORK_DIR}/${JOBNAME}_MATCH_QUERY.tmp

    cat /dev/null > ${MATCHING_QUERY_WORK}

    # SQL定義ファイルの編集
    if [ ! -r ${MATCHING_FILE} ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${MATCHING_FILE}:rc=$rc) "
        echo $JOBNAME " File is nonexist(${MATCHING_FILE}:rc=$rc) "
        exit ${G_RTN_ERROR}
    fi

    # バインド変数を置き換える
    cat ${MATCHING_FILE} > ${MATCHING_QUERY_WORK}

    for bind in $2
    do
        bind_escape=`echo $bind | sed "s/\//\\\\\\\\\//g"`
        sed -i, -e 0,/#FILE#/s/#FILE#/$bind_escape/ ${MATCHING_QUERY_WORK}
    done

    export MATCHING_QUERY_WORK
}

#
#--- クエリ編集(アンロード)
#       p1：ＳＱＬ定義ファイル名
#       p2：バインド変数置換文字
EDIT_ULD_QUERY()
{
    SQL_FILE=$1
    SQL_WORK_FILE=${ULD_WORK_DIR}/${JOBNAME}_QUERY.tmp
    cat /dev/null > ${SQL_WORK_FILE}

    # SQL定義ファイルの編集
    if [ ! -r ${SQL_FILE} ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${SQL_FILE}:rc=$rc) "
        echo $JOBNAME " File is nonexist(${SQL_FILE}:rc=$rc) "
        exit ${G_RTN_ERROR}
    fi

    # バインド変数を置き換える
    cat ${SQL_FILE} > ${SQL_WORK_FILE}

    for bind in $2
    do
        sed -i, -e 0,/?/s/?/"'"$bind"'"/ ${SQL_WORK_FILE}
    done

    export SQL_WORK_FILE
}

#
#--- マッチング処理
#      p1：出力ファイルパス
#      p2：マッチングクエリファイルパス
EXEC_MATCHING()
{
    # 出力ファイルの初期化
    OUTFILE=$1
    cat /dev/null > ${OUTFILE}
    rc=$?
    if [ $rc -ne 0 ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File cat error(${OUTFILE}:rc=$rc) "
        echo $JOBNAME " File cat error(${OUTFILE}:rc=$rc) "
        exit ${G_RTN_ERROR}
    fi

    # マッチング実行
    export ZTLOUTFILE=${OUTFILE}
    ${G_TOOLSH}/util/bin/ZTLMAT01 $2
    rc=$?
    if [ $rc -ne 0 ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " matching error($2:rc=$rc) "
        echo $JOBNAME " matching error($2:rc=$rc) "
        exit ${G_RTN_ERROR}
    fi
}

#
#--- アンロード関数
#       p1：テーブル名／クエリファイル名
#       p2：出力ファイル名
EXEC_UNLOAD()
{
    # 出力ファイルの初期化
    cat /dev/null > $2
    rc=$?
    if [ $rc -ne 0 ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File cat error($2:rc=$rc) "
        echo $JOBNAME " File cat error($2:rc=$rc) "
        exit ${G_RTN_ERROR}
    fi

    # unload
    sh ${G_TOOLSH}/EOKULD03.sh $1 $2

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

#
#--- ファイル定義
#
# 定額料金
FILE_AC0281=${MID_DIR_AC}/EO30110B0J0_AC0281.csv
# 料金項目抽出変換
FILE_CH0401=${MID_DIR_AC}/EO30110B0J0_CH0401.csv
# VBの業務機能識別コード
FILE_VB_SKBT_CD=${MID_DIR_AC}/EO30110B0J0_VB_SKBT_CD.csv
# VBMの業務機能識別コード
FILE_VBM_SKBT_CD=${MID_DIR_AC}/EO30110B0J0_VBM_SKBT_CD.csv
# VB、VBMの料金項目
FILE_VBVBM_PRC_KMK=${MID_DIR_AC}/EO30110B0J0_VBVBM_PRC_KMK.csv
# 一時金情報(VB、VBM)
FILE_ACIFM043_WK_1=${MID_DIR_AC}/EO30110B0J0_ACIFM043_WK_1.csv
# 一時金情報(VB、VBM以外)
FILE_ACIFM043_WK_2=${MID_DIR_AC}/EO30110B0J0_ACIFM043_WK_2.csv
# マッチングファイル定義
DEFFILE_AC_CM_0134=${G_TOOLSH}/util/def/AC_CM_0134.def
DEFFILE_AC_CM_0135=${G_TOOLSH}/util/def/AC_CM_0135.def
DEFFILE_AC_CM_0136=${G_TOOLSH}/util/def/AC_CM_0136.def
# アンロードSQL定義
SQLFILE_AC_U_AC0281_02=${SQL_DIR}/AC_U_AC0281_02.sql
SQLFILE_AC_U_CH0401_06=${SQL_DIR}/AC_U_CH0401_06.sql
SQLFILE_AC_U_ZM0321_02=${SQL_DIR}/AC_U_ZM0321_02.sql

#
#--- 定数定義
#
# イベントコード（料金計算日）
EVENT_CD="03"
# イベントコード（利用終了日）
EVENT_CD_USE_ENDYMD="02"
# 業務パラメータID（VB）
WORK_PARAM_ID_VB="AC_WKS_VB_USE_AMNT"
# 業務パラメータID（VBM）
WORK_PARAM_ID_VBM="AC_WKS_VBM_USE_AMNT"

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

#
#--- 請求年月取得
#
. EO3SEIKYYM.sh ${EVENT_CD} ${RSLT_OPEDATE} ${JOBNAME}

#
#--- 請求年月末日取得
#
. EO3EVENTYMD.sh ${EVENT_CD_USE_ENDYMD} ${SEIKY_YM} ${JOBNAME}
SEIKY_YM_ENDDAY=${EVENT_YMD}

#
#--- VBの業務機能識別コードを取得する(アンロード)
#
EDIT_ULD_QUERY ${SQLFILE_AC_U_ZM0321_02} "${WORK_PARAM_ID_VB}"
EXEC_UNLOAD ${SQL_WORK_FILE} ${FILE_VB_SKBT_CD}
VB_SKBT_CD=`cat ${FILE_VB_SKBT_CD}`

#
#--- VBMの業務機能識別コードを取得する(アンロード)
#
EDIT_ULD_QUERY ${SQLFILE_AC_U_ZM0321_02} "${WORK_PARAM_ID_VBM}"
EXEC_UNLOAD ${SQL_WORK_FILE} ${FILE_VBM_SKBT_CD}
VBM_SKBT_CD=`cat ${FILE_VBM_SKBT_CD}`

#
#--- 定額料金を取得する(アンロード)
#
EDIT_ULD_QUERY ${SQLFILE_AC_U_AC0281_02} "${SEIKY_YM_ENDDAY}"
EXEC_UNLOAD ${SQL_WORK_FILE} ${FILE_AC0281}

#
#--- 料金項目抽出変換を取得する(アンロード)
#
EDIT_ULD_QUERY ${SQLFILE_AC_U_CH0401_06} "${VB_SKBT_CD} ${VBM_SKBT_CD} ${SEIKY_YM_ENDDAY}"
EXEC_UNLOAD ${SQL_WORK_FILE} ${FILE_CH0401}

#
#--- VB、VBMの料金項目を取得する(マッチング)
#    結合条件:
#        定額料金.料金コースコード = 料金項目抽出変換.料金コースコード
#        AND 定額料金.料金サービスコード = 料金項目抽出変換.料金サービスコード
#        AND 定額料金.料金項目コード = 料金項目抽出変換.料金項目コード
EDIT_MATCHING_QUERY ${DEFFILE_AC_CM_0134} "${FILE_CH0401} ${FILE_AC0281}"
EXEC_MATCHING ${FILE_VBVBM_PRC_KMK} ${MATCHING_QUERY_WORK}

#
#--- 一時金情報(VB、VBM)を取得する(マッチング)
#    結合条件:
#        一時金情報.料金項目コード = VB、VBMの料金項目.料金項目コード
#    抽出条件:
#        VB、VBMの料金項目.料金項目コード IS NOT NULL
EDIT_MATCHING_QUERY ${DEFFILE_AC_CM_0135} "${MID_DIR_AC}/ACIFM043011.csv ${FILE_VBVBM_PRC_KMK}"
EXEC_MATCHING ${FILE_ACIFM043_WK_1} ${MATCHING_QUERY_WORK}

#
#--- 一時金情報(VB、VBM以外)を取得する(マッチング)
#    結合条件:
#        一時金情報.料金項目コード = VB、VBMの料金項目.料金項目コード
#    抽出条件:
#        VB、VBMの料金項目.料金項目コード IS NULL
EDIT_MATCHING_QUERY ${DEFFILE_AC_CM_0136} "${MID_DIR_AC}/ACIFM043011.csv ${FILE_VBVBM_PRC_KMK}"
EXEC_MATCHING ${FILE_ACIFM043_WK_2} ${MATCHING_QUERY_WORK}
# ANK-3388-00-00 ADD END

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

P1="OPD=,"
P2="SVCCTL=JBSbatMultiServiceControl,"
P3="JOB=EO30110B0J0,"
P4="IND1=ACIFM043.def,"
P5="INF1=${MID_DIR_AC}/ACIFM043025.csv,"
P6="IND2=,"
P7="INF2=,"
P8="OTD1=ACIFM043.def,"
P9="OTF1=${MID_DIR_AC}/ACIFM043012.csv,"
P10="OTD2=,"
P11="OTF2=,"
P12="TABLENAME=,"
P13="SQLKEY=,"
P14="SQLPARAM=,"
P15="ERRFILE=,"
P16="RECOVERY=,"
P17="BREAKPTN=,"
P18="FREE=${MID_DIR_AC}/ACIFM242001.csv;ACIFM242.def"
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

#
#---ＳＯＲＴ
#
# ANK-3388-00-00 MOD START
#bsortex -sort key=2.10asca -record recform=txtflt fldsep=, \
# -input reclen=300 file=${MID_DIR_AC}/ACIFM043011.csv \
# -output file=${MID_DIR_AC}/ACIFM043025.csv 
bsortex -sort key=2.10asca -record recform=txtflt fldsep=, \
 -input reclen=300 file=${FILE_ACIFM043_WK_1} \
 -output file=${MID_DIR_AC}/ACIFM043025.csv 
# ANK-3388-00-00 MOD END

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


#
#---ＡＰＬ起動
#

java ${JAVA_OPTION} -jar ${JAR_DIR}/koptBatch.jar $PARA

rc=$?
ERR_FLG=0
if [ $rc -ne 0 ]
then
   if [ $rc -ne 4 ]
   then
       if [ $rc -ne 8 ]
       then
           if [ $rc -ne 127 ]
           then
              sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " PROGRAM Error($SVC program:rc=$rc) "
              echo $JOBNAME " PROGRAM Error($SVC program:rc=$rc) "
              exit ${G_RTN_ERROR}
           fi
       fi
    fi
    ERR_FLG=1
fi

exit_rc=$rc

# ANK-3388-00-00 ADD START
#
#--- 処理結果と一時金情報(VB、VBM以外)をマージする
#
cat ${FILE_ACIFM043_WK_2} >> ${MID_DIR_AC}/ACIFM043012.csv

#
#--- 一時ファイルの削除を行う
#
rm -f ${FILE_AC0281}
rm -f ${FILE_CH0401}
rm -f ${FILE_VB_SKBT_CD}
rm -f ${FILE_VBM_SKBT_CD}
rm -f ${FILE_VBVBM_PRC_KMK}
rm -f ${FILE_ACIFM043_WK_1}
rm -f ${FILE_ACIFM043_WK_2}
# ANK-3388-00-00 ADD END

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

exit $exit_rc
