#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：請求収納
#
# シェル名      ：パーフェクト口座債権充当関連ＤＢ更新
#
# 機能          ：1.債権充当関連ＤＢ更新
#
#(１)
#債権充当データを用いて、債権充当に関連している各スキーマを更新し、債権充当データを出力する。
#
#
#【FREE】
#NKIN_STAT："0"（債権充当）
#
# コマンド形式  ：EO60Y05F0J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v52.00          2020/11/24  FJ）吉田     【ANK-3838-00-00】窓口払い手数料の顧客負担方式導入
# v52.01          2021/01/28  FJ）吉田     【IT2-2021-0000006】過少入金時リスト表示不正
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#
#---OPD
#
OPD=$1

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

#
#---業務で必要な変数定義
#
#手修正あり
NKIN_STAT="0"
#---システム日時取得
. EOK010410J0.sh "2"
SYS_HMS=`echo ${RSLT_SYSDATE} | cut -c 9-`
OPEDATE=${RSLT_OPEDATE}${SYS_HMS}
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME


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

P1="OPD=${OPD},"
P2="SVCCTL=JBSbatMultiServiceControl,"
P3="JOB=EO60Y05F0J0,"
P4="IND1=CHIFM093.def,"
P5="INF1=${MID_DIR_CH}/CHIFM093028.csv,"
P6="IND2=,"
P7="INF2=,"
P8="OTD1=CHIFM097.def,"
P9="OTF1=${MID_DIR_CH}/CHIFM097022.csv,"
P10="OTD2=CHIFM154.def,"
P11="OTF2=${MID_DIR_CH}/CHIFM154009.csv,"
P12="TABLENAME=,"
P13="SQLKEY=,"
P14="SQLPARAM=,"
P15="ERRFILE=,"
P16="RECOVERY=,"
P17="BREAKPTN=,"
P18="FREE=${NKIN_STAT}"
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

#
#---ＡＰＬ起動
#

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

#
#---ファイルコピー
#

cp -f ${MID_DIR_CH}/CHIFM097022.csv ${MID_DIR_CH}/CHIFM097022_${OPEDATE}.csv

# v52.01 IT1-2021-0000006 ADD START
#
#---ワークファイル削除モード
#
WK_RM=true

#-------------------------------------------------------------
# サブルーチン
#-------------------------------------------------------------
#
#--- サブルーチン（UNLOAD）
#
UNLOAD(){

# 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

}


#
#--- サブルーチン（OUTPUTFILE）
#
OUTPUTFILE(){
    while read line1
    do
        PRC_KMK_CD=`echo ${line1}`
        bsortex -copy -record recform=txtcsv \
        -input reclen=600 file=$1 \
        -output case="11.11asc.eq.'${PRC_KMK_CD}'" >> $2
        
        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
    done < $3
}
#
#-- 充当額の料金項目コードを取得する
#
#-業務パラメータID
WK_PRM_ID_JUTO_GOKEI=CH_WKS_JUTO_GOKEI

#
#-- SQLファイル
#
SQLFILE_CH_U_CH0401_25=${SQL_DIR}/CH_U_CH0401_25.sql
SQLFILE_CH_U_CH0401_25_JUTO=${SQL_DIR}/${JOBNAME}_CH_U_CH0401_25_WK.sql

#
#-- アンロードファイル
#
CSVFILE_CH_U_CH0401_25_JUTO=${MID_DIR_CH}/${JOBNAME}_CH_U_CH0401_25_JUTO.csv

#
#-- 入力ファイル
#
INPUT_FILE=${MID_DIR_CH}/CHIFM093028.csv

#
#-- 出力ファイル
#
OUTPUT_FILE_JUTO=${MID_DIR_CH}/CHIFM093028_${OPEDATE}.csv

#--- SQL検索条件セット
#--- 料金項目抽出変換
cp -f ${SQLFILE_CH_U_CH0401_25} ${SQLFILE_CH_U_CH0401_25_JUTO}
sed -i -e "s%:WORK_PARAM_ID%'${WK_PRM_ID_JUTO_GOKEI}'%" ${SQLFILE_CH_U_CH0401_25_JUTO}
sed -i -e "s%:OPE_DATE%'${RSLT_OPEDATE}'%"    ${SQLFILE_CH_U_CH0401_25_JUTO}

#
#--- UNLOAD処理
#
#--- 料金項目抽出変換
UNLOAD ${SQLFILE_CH_U_CH0401_25_JUTO} ${CSVFILE_CH_U_CH0401_25_JUTO}

#
#パーフェクト口座入金結果リスト作成用に
#入力ファイルから充当情報を抜き出しておく
#
OUTPUTFILE ${INPUT_FILE} ${OUTPUT_FILE_JUTO} ${CSVFILE_CH_U_CH0401_25_JUTO}

#
#--- ワーク削除
#
if [ $WK_RM = "true" ]
then
    rm ${SQLFILE_CH_U_CH0401_25_JUTO}
    rm ${CSVFILE_CH_U_CH0401_25_JUTO}
fi

# v52.01 IT1-2021-0000006 ADD END

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

exit $exit_rc
