#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：サービス契約内訳抽出（当月分）
#
# 機能          ：サービス契約内訳アンロード（全件）より当月分を抽出する。
#
# コマンド形式  ：EO30A1080J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v48.00.00       2020/01/27  FJ) 寺園     【ANK-3796-00-00】  テレビリースサービス導入対応
#
##############################################################

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

#
#---ツール格納場所
#
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

#
#---業務で必要な変数定義
#
#手修正あり
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

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

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

#
#---ファイル定義
#
CH_M_PRC_SCHDL_TEIGI_ULD_FILE=${MID_DIR_AC}/ACIFM339001.csv
COMULD2_KK0161_ALL=${MID_DIR_CC}/CCIFM021001.csv
FILE_KK0161_ALL_SORT=${MID_DIR_AC}/${JOBNAME}_KK0161_ALL_SORT.csv
OUTFILE=${MID_DIR_AC}/ACIFM338003.csv

# 環境変数に挿入
# 料金スケジュール定義アンロードファイルより値(利用終了日)を変数に格納
eval YMD=`cat ${CH_M_PRC_SCHDL_TEIGI_ULD_FILE}`

#
#--- サービス契約内訳(全件)を以下のキーでソートする
#    ソートキー
#        ・サービス契約内訳.サービス契約番号(昇順)
#        ・サービス契約内訳.サービス契約内訳番号(昇順)
#        ・サービス契約内訳.世代登録年月日時分秒(昇順)
#    抽出条件
#        ・サービス契約内訳.料金プランコード ≠ NULL
#        ・サービス契約内訳.無効フラグ = '0'
#        ・サービス契約内訳.予約適用コード = "2"(予約確定)
#        ・サービス契約内訳.プラン課金開始年月日 <= 利用終了日
#        ・サービス契約内訳.プラン課金終了年月日 >= 利用終了日
#    - SELECT(reconst)項目は以下
#        0 - 3.10   ：サービス契約番号
#        1 - 0.12   ：サービス契約内訳番号
#        4 - 5.6    ：料金プランコード
#
bsortex \
    -sort key=3.10asc,0.12asc,1.17asc -record recform=txtcsv \
    -input file=${COMULD2_KK0161_ALL} \
        reclen=${ULD2_REC_LEN_KK0161} \
        include="5.1asc.gt.'0'.and.27.1asc.eq.'0'.and.8.1asc.eq.'2'.and.11.8asc.le.'${YMD}'.and.12.8asc.ge.'${YMD}'" \
    -output file=${FILE_KK0161_ALL_SORT} reconst="3.10,0.12,5.6"

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

#
#--- サービス契約内訳(最大世代)を取得する
#    各キー項目毎の最大世代のレコードのみを残す
#
bsortex \
    -merge key=3.10asc,0.12asc -record recform=txtcsv \
    -input file=${FILE_KK0161_ALL_SORT} \
        reclen=${ULD2_REC_LEN_KK0161} \
    -summary suppress last \
    -output file=${OUTFILE}

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

#
#--- ワークファイル削除
#
rm ${FILE_KK0161_ALL_SORT}
#
#--- ジョブの終了メッセージを出力する
#
sh ${G_TOOLSH}/EOK010210J0.sh CS00028I $JOBNAME
sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME

exit ${G_RTN_NORMAL}
