#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：契約管理
#
# シェル名      ：ループバックテスト完了年月日更新
#
# 機能          ：読み込んだ"ループバックテスト完了情報受信"の内容を元に対象の"サービス契約回線内訳"を抽出し「ループバックテスト完了年月日」の履歴更新を行う。
#
# コマンド形式  ：EO29D0310J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
#
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

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

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

# KKIFI024
cat /dev/null > ${MID_DIR_KK}/KKIFI024001_${SYSDATE}.csv

# 内部インターフェイスファイルの移動
for csv_file in `find ${SEND_DIR} -maxdepth 1 -name "KKIFI024*" | egrep "KKIFI024[0-9]{3}_[0-9]{14}\.csv"`
do
    # フラグファイル名の取得
    flg_file=`echo ${csv_file} | sed -e "s/\.csv/\.flg/"`
    # ＣＳＶファイル名の取得
    ctl_file=`echo ${csv_file} | sed -e "s/\.csv/\.ctl/"`
    
    if [ -f ${flg_file} ]
    then
    	mv -f ${flg_file} ${MID_DIR_KK}/
    fi
    
    if [ -f ${ctl_file} ]
    then
    	mv -f ${ctl_file} ${MID_DIR_KK}/
    fi
    
    mv -f ${csv_file} ${MID_DIR_KK}/
done

# ファイルのマージ
for csv_file in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFI024*.csv" | egrep "KKIFI024[0-9]{3}_[0-9]{14}\.csv"`
do
    # KKIFI024001_${SYSDATE}ファイルへ追記を行う。
    cat ${csv_file} >> ${MID_DIR_KK}/KKIFI024001_${SYSDATE}.csv
done

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

P1="OPD=$OPD,"
P2="SVCCTL=JBSbatMultiServiceControl,"
P3="JOB=EO29D0310J0,"
P4="IND1=KKIFI024.def,"
P5="INF1=${MID_DIR_KK}/KKIFI024001_${SYSDATE}.csv,"
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

#
#---ＡＰＬ起動
#

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
    
    # Programが異常終了である場合、処理に利用したファイルをバックアップする。
    for csv_file in `find ${MID_DIR_KK} -name "KKIFI024*.csv" | egrep "KKIFI024[0-9]{3}_[0-9]{14}\.csv"`
    do
        # フラグファイル名の取得
        flg_file=`echo ${csv_file} | sed -e "s/\.csv/\.flg/"`
        # ＣＳＶファイル名の取得
        ctl_file=`echo ${csv_file} | sed -e "s/\.csv/\.ctl/"`
        
        if [ -f ${flg_file} ]
        then
            # flg_fileのバックアップ
            file_name_base=`basename "${flg_file}" .flg`
            file_name=${file_name_base}_ABORT.flg
            cp -p -f ${flg_file} ${SEND_DIR}/bk/${file_name}
        fi
        
        if [ -f ${ctl_file} ]
        then
            # ctl_fileのバックアップ
            file_name_base=`basename "${ctl_file}" .ctl`
            file_name=${file_name_base}_ABORT.ctl
            cp -p -f ${ctl_file} ${SEND_DIR}/bk/${file_name}
        fi
        
        # csv_fileのバックアップ
        file_name_base=`basename "${csv_file}" .csv`
        file_name=${file_name_base}_ABORT.csv
        cp -p -f ${csv_file} ${SEND_DIR}/bk/${file_name}
    done
    
    ERR_FLG=1
else
    # Programが正常終了である場合、処理に利用したファイルを移動する。
    for csv_file in `find ${MID_DIR_KK} -name "KKIFI024*.csv" | egrep "KKIFI024[0-9]{3}_[0-9]{14}\.csv"`
    do
        # フラグファイル名の取得
        flg_file=`echo ${csv_file} | sed -e "s/\.csv/\.flg/"`
        # ＣＳＶファイル名の取得
        ctl_file=`echo ${csv_file} | sed -e "s/\.csv/\.ctl/"`
        
        if [ -f ${flg_file} ]
        then
            mv -f ${flg_file} ${SEND_DIR}/bk/
        fi
        
        if [ -f ${ctl_file} ]
        then
            mv -f ${ctl_file} ${SEND_DIR}/bk/
        fi
        
        # csv_fileの移動
        mv -f ${csv_file} ${SEND_DIR}/bk/
    done
fi

exit_rc=$rc

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

exit $exit_rc
