#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：コンテンツ決済
#
# シェル名      ：コンテンツレプリカ情報更新処理
#
# 機能          ：コンテンツレプリカ情報ファイルからコンテンツ管理システムで変更された内容をコンテンツ決済内部スキーマへ反映する。
#
# コマンド形式  ：EO4090250J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v29.00.00      2017/03/03   FJ)貝本     【ANK-3050-00-00】コンテンツレプリカ連携　遅延対応
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1
#---運用日の指定がない場合、運用日付を取得する。
#v29.00.00 MOD START
#if ["${OPD}" = ""]; then
if [ "${OPD}" = "" ]; then
#v29.00.00 MOD END
  . EOK010310J0.sh "NDATE"
  OPD="${RSLT_OPEDATE}"
fi

#
#---システム日付取得(yyyyMMddHHmmss)
#
. EOK010410J0.sh 2
RSLT_SYS_DATETIME=$RSLT_SYSDATE

#v29.00.00 ADD START
#---システム日時取得(yyyyMMddHHmmssSSS)
. EOK010410J0.sh "1"
SYSDATE=${RSLT_SYSDATE}
#v29.00.00 ADD END

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

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

P1="OPD=$OPD,"
P2="SVCCTL=JBSbatUnitServiceControl,"
P3="JOB=EO4090250J0,"
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=,"
#v29.00.00 MOD START
#P18="FREE=${GAIBU_RECEIVE_DIR_CN}/CNIFE002/CNIFE002.csv;${GAIBU_SEND_DIR_CN}/CNIFE018/CNIFE018.csv"
P18="FREE=${GAIBU_RECEIVE_DIR_CN}/CNIFE002/CNIFE002.csv;${GAIBU_SEND_DIR_CN}/CNIFE018/CNIFE018.csv;${MID_DIR_CN}/CNIFM010001.tsv"
#v29.00.00 MOD END
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

#
#--- ファイル定義
#
SOURCEFILE=${GAIBU_RECEIVE_DIR_CN}/CNIFE002/CNIFE002.csv
TARGETDIR=${GAIBU_RECEIVE_DIR_CN}/CNIFE002/bk/CNIFE002_$RSLT_SYS_DATETIME.csv

#v29.00.00 ADD START
#-- ロード各定義
SQL_CONTROL=${SQL_LOADER_CTL_DIR}/CN_T_CONT_ISP_CHRG_01.ctl
SQL_CONTROL_WK=${SQL_LOADER_CTL_DIR}/CN_T_CONT_ISP_CHRG_01_WK.ctl
INSERT_FILE=${MID_DIR_CN}/CNIFM010001.tsv
LOG_FILE=${SQL_LOADER_LOG_DIR}/${JOBNAME}_${SYSDATE}.log
BAD_FILE=${SQL_LOADER_BAD_DIR}/${JOBNAME}_${SYSDATE}.bad
#v29.00.00 ADD END

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

#v29.00.00 ADD START
# ctlファイルの存在チェック
if [ ! -r $SQL_CONTROL ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist($SQL_CONTROL) "
    echo $JOBNAME " File is nonexist($SQL_CONTROL) "
    exit ${G_RTN_ERROR}
fi

# insファイルの初期化
cat /dev/null > $INSERT_FILE
#v29.00.00 ADD END

#
#---ＡＰＬ起動
#

java ${JAVA_OPTION_16384} -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

#
#
#---エラー発生時はバックアップ処理
#

if [ $ERR_FLG -ne 0 ]
then
    mv -f $SOURCEFILE $TARGETDIR
    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 " MV Error($SVC mv:rc=$rc) "
                    echo $JOBNAME " MV Error($SVC mv:rc=$rc) "
                    exit ${G_RTN_ERROR}
                fi
            fi
        fi
    fi
fi

exit_rc=$rc
#v29.00.00 ADD START
cp -f ${SQL_CONTROL} ${SQL_CONTROL_WK}
sed -i -e "s%:UNYO_YMD%${OPD}%g" ${SQL_CONTROL_WK}
sed -i -e "s%:SHELL_ID%${SVC}%g" ${SQL_CONTROL_WK}
#
#---データロード
#
sqlldr ${ORACLEUSER}/${ORACLEPASS}@${SID_S} CONTROL=${SQL_CONTROL_WK} DATA=${INSERT_FILE} LOG=${LOG_FILE} BAD=${BAD_FILE}
rc=$?
if [ $rc -ne 0 ]
then
    ERRMSG=" データロードに失敗しました：${LOAD_SCHEMA}($SVC load:rc=$rc) ログを確認してください。ログファイル：${LOG_FILE}、不良ファイル：${BAD_FILE} "
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME ${ERRMSG}
    echo $JOBNAME ${ERRMSG}
    exit_rc=${G_RTN_ERROR}
fi
#ワークファイルの削除
rm -f ${SQL_CONTROL_WK}
#v29.00.00 ADD END


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

exit $exit_rc
