#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：契約管理
#
# シェル名      ：保存期間経過データ物理削除
#
# 機能          ：保存期間経過データ物理削除
#「個人情報削除ワーク」に書き込まれている保存期間を経過した削除対象情報のキーを基に削除処理を実施する。
#上記削除キーに関連して削除される各スキーマについては、各スキーマの削除キー情報を取得し、該当のスキーマの削除処理を行う。
#
#
# コマンド形式  ：EO2240610J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
#                 2012/12/13  FJ           IT2-2012-0002060
#                 2014/02/25  FJ           ANK-1655-00-00
# v14.00.00       2015/05/07  FJ)小島      IT1-2015-0000052
# v14.00.01       2015/06/22  FJ)小島      IT1-2015-0000052 バックアップフォルダ移動処理を削除
# v28.00.00       2017/01/24  FJ)原田      ANK-3141-00-00
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
# ▼▼▼IT1-2015-0000052 ADD START▼▼▼
. EOK010410J0.sh 1
SYSDATE=$RSLT_SYSDATE
# ▲▲▲IT1-2015-0000052 ADD END▲▲▲

#▼▼▼ANK-1655-00-00 20140225 村田 ADD START▼▼▼
#
#---運用日付取得
#
# ANK-3141-00-00 MOD START
#if [ "${OPD}" = "" ]; then
if [ "${OPD}" = "" -o "${OPD}" = "20991231" ]; then
# ANK-3141-00-00 MOD END
# ▼▼▼IT1-2015-0000052 MOD START▼▼▼
#   . EOK010310J0.sh "BDATE"
   . EOK010310J0.sh "ODATE"
# ▲▲▲IT1-2015-0000052 MOD END▲▲▲
else
   RSLT_OPEDATE="${OPD}"
fi

# ANK-3141-00-00 ADD START
#---第2引数取得（走行回数）
RUNCNT=$2
# ANK-3141-00-00 ADD END

#---削除抑止コード(デバッグ用)
#   0：通常処理
#   1：DBへの追加・更新・削除を全て抑止し、物理削除CSVのみ出力
#
DELSTOPCD=0

#
#--- 各ファイルの存在チェックを行う
#
if [ ! -r ${MID_DIR_KK}/KKIFM273001.csv ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${MID_DIR_KK}/KKIFM273001.csv) "
    echo $JOBNAME " File is nonexist(${MID_DIR_KK}/KKIFM273001.csv) "
    exit ${G_RTN_ERROR}
fi
#▲▲▲ANK-1655-00-00 20140225 村田 ADD END  ▲▲▲

#
#ファイルの読み込み
#
while read LINE;
do
READ_FILE=$LINE
done < ${MID_DIR_KK}/KKIFM273001.csv

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

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

#多重起動処理番号分、ループする。
#$READ_FILE：多重起動処理番号
for i in $(seq 1 $READ_FILE)
do

#▼▼▼ANK-1655-00-00 20140225 村田 MOD START▼▼▼
#---物理削除レコード出力CSV
#
# ▼▼▼IT1-2015-0000052 MOD START▼▼▼
HMS=`echo $SYSDATE | cut -c 9-17`
#DELETEFILE=${MID_DIR_KK}/delRecordFile_${RSLT_OPEDATE}_$i.csv
DELETEFILE=${MID_DIR_KK}/KKIFM636_${RSLT_OPEDATE}${HMS}_$i.csv
# ▲▲▲IT1-2015-0000052 MOD END▲▲▲

# ▼▼▼IT1-2015-0000052 MOD START▼▼▼
#   P1="OPD=$OPD,"
   P1="OPD=$RSLT_OPEDATE,"
# ▲▲▲IT1-2015-0000052 MOD END▲▲▲
   P2="SVCCTL=JBSbatUnitServiceControl,"
   P3="JOB=EO2240610J0,"
   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=$i"
#  ANK-3141-00-00 MOD START
#   P18="FREE=$i;$DELSTOPCD;$DELETEFILE"
   P18="FREE=$i;$DELSTOPCD;$DELETEFILE;${RUNCNT}"
# ANK-3141-00-00 MOD END
   PARA="$P1$P2$P3$P4$P5$P6$P7$P8$P9$P10$P11$P12$P13$P14$P15$P16$P17$P18"
#▲▲▲ANK-1655-00-00 20140225 村田 MOD END  ▲▲▲

   sh ${G_TOOLSH}/EOK010210J0.sh CS00027I $JOBNAME

   #--- プログラムの起動を行う(バックグラウンド実行)
   java ${JAVA_OPTION} -jar ${JAR_DIR}/koptBatch.jar $PARA &
   
   PID=$!
   ARRAY_PID[${i}]=$PID

done

ERR_FLG=0
for ARRAY_PID in "${ARRAY_PID[@]}";
do
   #バックグラウンドの処理が終わるまで待機する。
   wait $ARRAY_PID
   #終了コードのチェック
   rc=$?

   #バッチプログラムのリターンコードからエラー処理を行う。※
   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
done

exit_rc=$rc

# ▼▼▼IT1-2015-0000052 DEL START▼▼▼
##▼▼▼ANK-1655-00-00 20140225 村田 ADD START▼▼▼
##---前月出力の物理削除レコード出力CSVをバックアップフォルダに移動する。
##    OPEDATE_YYYYMM：運用年月
##    OPEDATE_STADAY：運用年月01日
##    PREDATE_ENDDAY：運用年月01日－1日（前月末日）
##    PREDATE_YYYYMM：運用年月前月
#OPEDATE_YYYYMM=`echo ${RSLT_OPEDATE} |cut -c 1-6`
#OPEDATE_STADAY=${OPEDATE_YYYYMM}"01"
#PREDATE_ENDDAY=`date -d "1 day ago ${OPEDATE_STADAY}" +'%Y%m%d'`
#PREDATE_YYYYMM=`echo ${PREDATE_ENDDAY} |cut -c 1-6`
## 前月の物理削除レコード出力CSV存在チェック
## ▼▼▼IT1-2015-0000052 MOD START▼▼▼
##for csv_file in `find ${MID_DIR_KK} -maxdepth 1 -name "delRecordFile_${PREDATE_YYYYMM}*"`
#for csv_file in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM636_${PREDATE_YYYYMM}*"`
## ▲▲▲IT1-2015-0000052 MOD END▲▲▲
#do
#    # 中間ファイルをバックアップフォルダへ移動
#    mv ${csv_file} ${BK_DIR_1YEAR}/KK/
#    rc=$?
#    if [ $rc -ne 0 ]
#    then
#        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " DELETE Error($SVC temp-move:rc=$rc) "
#        echo $JOBNAME " DELETE Error($SVC temp-move:rc=$rc) "
#        exit ${G_RTN_ERROR}
#    fi
#done
##▲▲▲ANK-1655-00-00 20140225 村田 ADD END  ▲▲▲
# ▲▲▲IT1-2015-0000052 DEL END▲▲▲

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

if [ $ERR_FLG -ne 0 ]
then
   exit ${G_RTN_ERROR}
else
   exit ${G_RTN_NORMAL}
fi
