#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：サービス契約蓄積アンロード
#
# 機能          ：サービス契約蓄積スキーマより当月と前月の情報をそれぞれ別のファイルに出力する。
#
# コマンド形式  ：sh EO31J0110J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v1.00.00       2013/03/22  FJ）藤田     性能改善 新規作成
# v4.00.00       2013/04/16  FJ) 小柴     開始終了メッセージを出力するように修正
# v9.00.00       2014/07/18  FJ) 後藤     【ST4-2014-0000046】サービス契約蓄積レンジ化に伴い、当日異動分反映前のアンロード処理に変更
# v11.00.00      2014/10/08  FJ）高橋     【ST4-2014-0000068】アンロード処理見直しに伴い、前月分アンロードを廃止
##############################################################
#-------------------------------------------------------------
#---ワークファイル削除モード
#-------------------------------------------------------------
WK_RM=true
#
#---ツール格納場所
#
G_TOOLSH=.

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

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

#
#--- ジョブの開始メッセージを出力する
#
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME
sh ${G_TOOLSH}/EOK010210J0.sh CS00027I $JOBNAME

#-------------------------------------------------------------
# ディレクトリ定義
#-------------------------------------------------------------
#-------------------------------------------------------------
#--- サブルーチン（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
}
#-------------------------------------------------------------
#--- サブルーチン（SED）
#-------------------------------------------------------------
SED(){
    sed -i -e $1 $2
    rc=$?
    if [ $rc -ne 0 ]
    then
          sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " sed error($1 $2:rc=$rc) "
          echo $JOBNAME " sed error($1 $2:rc=$rc) "
          exit ${G_RTN_ERROR}
    fi
}

#
#--- ファイル定義
#
# ST4-2014-0000068 ADD START
#--- 入力ファイル
INFILE_ZENGETU=${MID_DIR_AC}/ACIFM179002.csv
# ST4-2014-0000068 ADD END

#--- 出力ファイル
OUTFILE_TOUGETU=${MID_DIR_AC}/ACIFM179004.csv
# ST4-2014-0000068 DEL START
#OUTFILE_ZENGETU=${MID_DIR_AC}/ACIFM179002.csv
#OUTFILE_ZENGETU_RECONST=${MID_DIR_AC}/ACIFM217002.csv

#OUTFILE_ZENGETU_RECONST_WK_1=${MID_DIR_AC}/${JOBNAME}_ACIFM217002_WK_1.csv
#OUTFILE_ZENGETU_RECONST_WK_2=${MID_DIR_AC}/${JOBNAME}_ACIFM217002_WK_2.csv
# ST4-2014-0000068 DEL END
#-------------------------------------------------------------
#--- 0.スケジュール定義CH_M_PRC_SCHDL_TEIGI
#-------------------------------------------------------------
#- 料金計算日イベントコード
EVENT_CD_RYOKIN_KEISAN_YMD="03"
#- スケジュール定義から請求年月（MIN）の当月取得
SQLFILE_CH0501_03=${SQL_DIR}/AC_U_CH0501_03.sql

SQLFIEL_CH0501_WK=${SQL_DIR}/${JOBNAME}_AC_U_CH0501_03WK_1.sql
CSVFILE_CH0501=${MID_DIR_AC}/${JOBNAME}_AC_U_CH0501_WK_1.csv

#-------------------------------------------------------------
#--- 1.サービス契約蓄積
#-------------------------------------------------------------
#- 当月
SQLFILE_AC0461_02=${SQL_DIR}/AC_U_AC0461_02.sql
#- 前月
# ST4-2014-0000068 DEL START
#SQLFILE_AC0461_04=${SQL_DIR}/AC_U_AC0461_04.sql
# ST4-2014-0000068 DEL END

SQLFILE_AC0461_WK_TOGETU=${SQL_DIR}/${JOBNAME}_AC_U_AC0461_02_WK_1.sql
# ST4-2014-0000068 DEL START
#SQLFILE_AC0461_WK_ZENGETU=${SQL_DIR}/${JOBNAME}_AC_U_AC0461_04_WK_1.sql
# ST4-2014-0000068 DEL END

#
#--- MAIN
#
#-------------------------------------------------------------
#--- 0.出力ファイルクリア
#-------------------------------------------------------------
cat /dev/null > ${OUTFILE_TOUGETU}
# ST4-2014-0000068 DEL START
#cat /dev/null > ${OUTFILE_ZENGETU}
# ST4-2014-0000068 DEL END

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

#-------------------------------------------------------------
#--- 0.1.請求年月取得処理
#-------------------------------------------------------------
cp ${SQLFILE_CH0501_03} ${SQLFIEL_CH0501_WK}
SED "s/:EVENT_CD/'${EVENT_CD_RYOKIN_KEISAN_YMD}'/g" ${SQLFIEL_CH0501_WK}
SED "s/:EVENT_YMD/'${RSLT_OPEDATE}'/g"              ${SQLFIEL_CH0501_WK}
UNLOAD ${SQLFIEL_CH0501_WK} ${CSVFILE_CH0501}
SEIKY_YM=`cat ${CSVFILE_CH0501}`
TOGETU_Y=`expr ${SEIKY_YM} / 100`
TOGETU_M=`expr ${SEIKY_YM} - ${TOGETU_Y} \* 100`
# ST4-2014-0000068 DEL START
##--- 前月取得
#if [ ${TOGETU_M} -eq 1 ];
#then
#  ZENGETU_Y=`expr ${TOGETU_Y} - 1`
#  ZENGETU_M=12
#else
#  ZENGETU_Y=${TOGETU_Y}
#  ZENGETU_M=`expr ${TOGETU_M} - 1`
#fi
#if [ ${ZENGETU_M} -lt 10 ];
#then
#  ZENGETU="${ZENGETU_Y}"0"${ZENGETU_M}"
#else
#  ZENGETU="${ZENGETU_Y}${ZENGETU_M}"
#fi
# ST4-2014-0000068 DEL END

#-------------------------------------------------------------
#--- 1.サービス契約蓄積アンロード
#-------------------------------------------------------------
#--- SQLに当月セット
(
  cp ${SQLFILE_AC0461_02} ${SQLFILE_AC0461_WK_TOGETU}
  SED "s/:SEIKY_YM/'${SEIKY_YM}'/g" ${SQLFILE_AC0461_WK_TOGETU}
  UNLOAD ${SQLFILE_AC0461_WK_TOGETU} ${OUTFILE_TOUGETU}
) &
pid_TOGETU=$!

# ST4-2014-0000068 DEL START
##--- SQLに前月セット
#(
#  cp ${SQLFILE_AC0461_04} ${SQLFILE_AC0461_WK_ZENGETU}
#  SED "s/:SEIKY_YM/'${ZENGETU}'/g" ${SQLFILE_AC0461_WK_ZENGETU}
#  UNLOAD ${SQLFILE_AC0461_WK_ZENGETU} ${OUTFILE_ZENGETU}
#) &
#pid_ZENGETU=$!
# ST4-2014-0000068 DEL END

wait ${pid_TOGETU}
rc_TOGETU=$?

# ST4-2014-0000068 DEL START
#wait ${pid_ZENGETU}
#rc_ZENGETU=$?
# ST4-2014-0000068 DEL END

# ST4-2014-0000068 MOD START
#if [ ${rc_TOGETU} -ne 0 ] || [ ${rc_ZENGETU} -ne 0 ]
if [ ${rc_TOGETU} -ne 0 ]
then
    #- エラーメッセージ出力
    if [ ${rc_TOGETU} -ne 0 ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " UNLOAD ERROR(TOGETU:rc=${rc_TOGETU}) "
        echo $JOBNAME "UNLOAD ERROR(TOGETU:rc=${rc_TOGETU}) "
    fi
#    if [ ${rc_ZENGETU} -ne 0 ]
#    then
#        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " UNLOAD ERROR(ZENGETU:rc=${rc_ZENGETU}) "
#        echo $JOBNAME "UNLOAD ERROR(ZENGETU:rc=${rc_ZENGETU}) "
#    fi
    #- 異常終了
    exit ${G_RTN_ERROR}
fi
# ST4-2014-0000068 MOD END

#-------------------------------------------------------------
#--- 2.サービス契約蓄積アンロード項目抜粋ファイル(ACUFM217002.csv)作成
#-------------------------------------------------------------
## ST4-2014-0000068 DEL START
##- 回復年月日＝null の場合、"NL"を設定
#bsortex \
#  -copy \
#  -record recform=txtcsv \
#  -input reclen=600 file=${OUTFILE_ZENGETU} \
#  -output file=${OUTFILE_ZENGETU_RECONST_WK_1} case="13.1asc.lt.'0'" \
#   reconst="7.10,6.20,3.2,4.3,5.12,19.8,21.8,12.4,10.8,'NL'.2asc" \
#  -output file=${OUTFILE_ZENGETU_RECONST_WK_2} case=other \
#   reconst="7.10,6.20,3.2,4.3,5.12,19.8,21.8,12.4,10.8,13.8" \
#
#rc=$?
#if [ $rc -ne 0 ]
#then
#      sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " bsort error(bsort:rc=$rc) "
#      echo $JOBNAME " bsort error(bsort:rc=$rc) "
#      exit ${G_RTN_ERROR}
#fi
#
##- マージ
#cat ${OUTFILE_ZENGETU_RECONST_WK_1} ${OUTFILE_ZENGETU_RECONST_WK_2} > ${OUTFILE_ZENGETU_RECONST}
#
#rc=$?
#if [ $rc -ne 0 ]
#then
#      sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " cat error(cat:rc=$rc) "
#      echo $JOBNAME " cat error(cat:rc=$rc) "
#      exit ${G_RTN_ERROR}
#fi
# ST4-2014-0000068 DEL END
#-------------------------------------------------------------
#--- END.ワークファイル削除
#-------------------------------------------------------------
if [ ${WK_RM} = "true" ]
then
    rm -f ${SQLFIEL_CH0501_WK}
    rm -f ${SQLFILE_AC0461_WK_TOGETU}
# ST4-2014-0000068 DEL START
#    rm -f ${SQLFILE_AC0461_WK_ZENGETU}
#    rm -f ${OUTFILE_ZENGETU_RECONST_WK_1}
#    rm -f ${OUTFILE_ZENGETU_RECONST_WK_2}
# ST4-2014-0000068 DEL END
    rm -f ${CSVFILE_CH0501}
fi

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

exit ${G_RTN_NORMAL}
