#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：契約管理
#
# シェル名      ：買取機器情報ファイル作成
#
# 機能          ：運用日当日に解約、回復が行われた機器情報を抽出し、CSV出力する。
#
# コマンド形式  ：EO2B40110J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v5.0.0        2013/03/27    FJ)井熊     【ST3-2013-000825】アンローダ化対応
# v6.0.0        2013/11/26    FJ)鈴木     【OM-2013-0004278】日中のディレイドで送信したファイルを参照するように修正
# v8.0.0        2014/03/25    FJ)鈴木     【OM-2014-0001207】bsortの-zオプションの桁数を修正
# v28.0.0       2017/01/31    FJ)江藤     【OM-2016-0001720】買取機器情報送信（ディレイド用）バッチ廃止
#
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#

#-- 運用日付を引数で受け取る
if [ "${OPD}" = "" ]; then
   # 通常起動
   . EOK010310J0.sh "BDATE"
   OPD="${RSLT_OPEDATE}"
else
   # 運用日指定
   RSLT_OPEDATE="${OPD}"
fi
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

#
#--- ファイル定義
#
SQLFILE=${SQL_DIR}/KK_U_KK0341_10.sql
MYSQLFILE=${SQL_DIR}/KK_${JOBNAME}.sql
UNLOAD_FILE=${MID_DIR_KK}/KKIFM434001.csv
SORT_FILE=${MID_DIR_KK}/KKIFM434002.csv
OUT_FILE=${GAIBU_SEND_DIR_KK}/KKIFE187/KKIFE187.csv

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

#
#--- アンロードファイルのクリアを行う
#
cat /dev/null > $UNLOAD_FILE
cat /dev/null > $MYSQLFILE

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

#
#--- 運用日用SQLファイr作成
#
while read LINE
do
  echo ${LINE/ZZZZZ/"'"$RSLT_OPEDATE"'"} >> $MYSQLFILE
done < $SQLFILE

#
#--- UNLOAD処理
#
sh ${G_TOOLSH}/EOKULD02.sh $MYSQLFILE $UNLOAD_FILE $JOBNAME

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

#
#---ＳＯＲＴ
#
# 2014.03.25 OM-2014-0001207 mod start
#bsort -s -z168 -0.14asca,2.10asca,1.19asca -Tflt -t, -o ${SORT_FILE} ${UNLOAD_FILE} 
bsort -s -z400 -0.14asca,2.10asca,1.19asca -Tflt -t, -o ${SORT_FILE} ${UNLOAD_FILE} 
# 2014.03.25 OM-2014-0001207 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

# OM-2016-0001720 DELL START
## 2013.11.26 OM-2013-0004278 add start
#
## 日中のディレイド処理でのファイルをマージしたファイル
#DLYD_SUM_FILE=${GAIBU_SEND_DIR_KK}/KKIFE187/KKIFE187_${RSLT_OPEDATE}_DLYD.csv
#if [ -f ${DLYD_SUM_FILE} ]; then
#  rm -f ${DLYD_SUM_FILE} > /dev/null 2>&1
#fi
#touch ${DLYD_SUM_FILE}
#
#if [ 0 -ne `ls ${GAIBU_SEND_DIR_KK}/KKIFE187/${RSLT_OPEDATE}*_DLYD_KKIFE187.csv 2> /dev/null | wc -l` ]
#then
#    for FILE in `ls -1tr ${GAIBU_SEND_DIR_KK}/KKIFE187/${RSLT_OPEDATE}*_DLYD_KKIFE187.csv`
#    do
#        # 追加書きする
#        cat ${FILE} >> ${DLYD_SUM_FILE}
#    done
#fi
#
## 2013.11.26 OM-2013-0004278 add end
# OM-2016-0001720 DELL END

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

P1="OPD=$OPD,"
P2="SVCCTL=JBSbatMultiServiceControl,"
P3="JOB=EO2B40110J0,"
P4="IND1=KKIFM434.def,"
P5="INF1=${SORT_FILE},"
P6="IND2=,"
P7="INF2=,"
P8="OTD1=KKIFE187.def,"
P9="OTF1=${OUT_FILE},"
P10="OTD2=,"
P11="OTF2=,"
P12="TABLENAME=,"
P13="SQLKEY=,"
P14="SQLPARAM=,"
P15="ERRFILE=,"
P16="RECOVERY=,"
P17="BREAKPTN=,"
# OM-2016-0001720 MOD START
## 2013.11.26 OM-2013-0004278 mod start
##P18="FREE="
#P18="FREE=${DLYD_SUM_FILE}"
## 2013.11.26 OM-2013-0004278 mod end
P18="FREE="
# OM-2016-0001720 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

#
#---ＡＰＬ起動
#

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

rc=$?
ERR_FLG=0
if [ $rc -ne 0 ]
then
   rm -f $OUT_FILE
   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
else
   rm -f $MYSQLFILE
   rm -f $UNLOAD_FILE
# 2013.11.26 OM-2013-0004278 del start
#   rm -f $SORT_FILE
# 2013.11.26 OM-2013-0004278 del end
# OM-2016-0001720 DEL START
## 2013.11.26 OM-2013-0004278 add start
#   mv -f ${DLYD_SUM_FILE} ${GAIBU_SEND_DIR_KK}/KKIFE187/bk > /dev/null 2>&1
#   mv -f ${GAIBU_SEND_DIR_KK}/KKIFE187/${RSLT_OPEDATE}*_DLYD_KKIFE187.csv ${GAIBU_SEND_DIR_KK}/KKIFE187/bk > /dev/null 2>&1
## 2013.11.26 OM-2013-0004278 add end
# OM-2016-0001720 DEL END

fi

exit_rc=$rc

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

exit $exit_rc
