#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：サービス契約蓄積前月アンロード
#
# 機能          ：サービス契約蓄積スキーマより前月の情報をファイルに出力する。
#
# コマンド形式  ：sh EO30101K0J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v11.00          2014/10/23  FJ)高橋      【ST4-2014-0000072】新規作成
#
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

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

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

#---ワークファイル削除モード
WK_RM=true

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

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

P1="OPD=,"
P2="SVCCTL=,"
P3="JOB=EO30101K0J0,"
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="
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

#-------------------------------------------------------------
# ディレクトリ定義
#-------------------------------------------------------------
#-------------------------------------------------------------
#--- サブルーチン（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
}

#
#--- ファイル定義
#
#--- 出力ファイル
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

#-------------------------------------------------------------
#--- 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_04=${SQL_DIR}/AC_U_AC0461_04.sql

SQLFILE_AC0461_WK_ZENGETU=${SQL_DIR}/${JOBNAME}_AC_U_AC0461_04_WK_1.sql

#
#--- MAIN
#
#-------------------------------------------------------------
#--- 0.出力ファイルクリア
#-------------------------------------------------------------
cat /dev/null > ${OUTFILE_ZENGETU}

#-------------------------------------------------------------
#--- 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`

#--- 前月取得
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

#-------------------------------------------------------------
#--- 1.サービス契約蓄積アンロード
#-------------------------------------------------------------
#--- 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=$!

wait ${pid_ZENGETU}
rc_ZENGETU=$?

if [ ${rc_ZENGETU} -ne 0 ]
then
    #- エラーメッセージ出力
    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

#-------------------------------------------------------------
#--- 2.サービス契約蓄積アンロード項目抜粋ファイル(ACUFM217002.csv)作成
#-------------------------------------------------------------
#- 回復年月日＝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

#-------------------------------------------------------------
#--- END.ワークファイル削除
#-------------------------------------------------------------
if [ ${WK_RM} = "true" ]
then
    rm -f ${SQLFILE_AC0461_WK_ZENGETU}
    rm -f ${OUTFILE_ZENGETU_RECONST_WK_1}
    rm -f ${OUTFILE_ZENGETU_RECONST_WK_2}
    rm -f ${CSVFILE_CH0501}
fi

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

exit ${G_RTN_NORMAL}
