#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：コンテンツ利用呼情報集計コンテンツ通話料（上限通知）集計
#
# 機能          ：SQLローダー用明細情報（コンテンツ通話明細(上限通知)）を以下のキーで集計する
#集計キー:課金対象年月、SYSID、コンテンツ契約番号、課金先電話番号、課税非課税コード
#             ソートキーは集計キーと同一（全て昇順）
#※ 課金可否が"否"のレコードは集計対象外とする
#※ bsortで集計する
#(bsortexで小数点を含む集約は出来ない為、集計前に小数点を除外し、集計後に再度付与する)
#
# コマンド形式  ：EO3091410J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v35.00.00       2017/11/14  FJ) 貝本    【ANK-3192-00-00】LaLaCallの通話明細情報の取得タイミング変更
#
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
#xxx=xxxxxxx
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

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

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

#
#--- ファイル定義
#
# SQLローダー用明細情報(上限通知用)
INFILE1=${MID_DIR_AC}/ACIFM207004.csv
# コンテンツ通話合計.ソート(上限通知用)
OUTFILE1=${MID_DIR_AC}/ACIFM201003.csv
# コンテンツ通話合計.料金100倍(上限通知用)
OUTFILE_TEMP1=${MID_DIR_AC}/ACIFM201003_TEMP1.csv
# コンテンツ通話合計.集計(上限通知用)
OUTFILE_TEMP2=${MID_DIR_AC}/ACIFM201003_TEMP2.csv
# コンテンツ通話合計.料金100分の1(上限通知用)
OUTFILE2=${MID_DIR_AC}/ACIFM201004.csv

#
#---ＳＯＲＴ
#
bsortex -sort key=3.6asca,0.10asca,2.12asca,1.12asca,15.1asca  \
    -record recform=txtflt fldsep=,                            \
    -input reclen=270 file=${INFILE1} include="28.1asc.eq.'1'" \
    -output file=${OUTFILE1}                                   \
     reconst"=0.10,2.12,3.6,1.12,15.1,'000000001'.9asc,13.12"

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

#---集計対象小数点考慮(料金*100)
awk -F, '{printf "%s,%s,%s,%s,%s,%s,%.0f\r\n", $1,$2,$3,$4,$5,$6,$7*100}' ${OUTFILE1} > ${OUTFILE_TEMP1}

#
#---集計
#
bsortex -sort key=0.10asca,1.12asca,2.6asca,3.12asca,4.1asca         \
    -record recform=txtflt fldsep=, -summary field=5.9ascz,6.12ascud \
    -input reclen=72 file=${OUTFILE_TEMP1}                           \
    -output file=${OUTFILE_TEMP2}                                    

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

#---集計対象小数点考慮(料金/100)
awk -F, '{printf "%s,%s,%s,%s,%s,%s,%.2f\r\n", $1,$2,$3,$4,$5,$6,$7/100}' ${OUTFILE_TEMP2} > ${OUTFILE2}

#---中間ファイルの削除
if [ -f ${OUTFILE_TEMP1} ]; then
	rm ${OUTFILE_TEMP1}
fi
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " rm1 Error($SVC remove:rc=$rc) "
    echo $JOBNAME " rm1 Error($SVC remove:rc:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

if [ -f ${OUTFILE_TEMP2} ]; then
	rm ${OUTFILE_TEMP2}
fi
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " rm2 Error($SVC remove:rc=$rc) "
    echo $JOBNAME " rm2 Error($SVC remove:rc:rc=$rc) "
    exit ${G_RTN_ERROR}
fi
#
#--- ジョブの終了メッセージを出力する
#
sh ${G_TOOLSH}/EOK010210J0.sh CS00028I $JOBNAME
sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME

exit ${G_RTN_NORMAL}
