#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：コンテンツ利用呼情報集計コンテンツ通話合計集約
#
# 機能          ：通話料超過チェックの為、コンテンツ通話料合計ファイルの通話料金合計を
#以下のキーでマージ・ソートする。
#キー:課金対象年月、SYSID、課金先電話番号（全て昇順）
#※ bsortで集計する
#(bsortexで小数点を含む集約は出来ない為、集計前に小数点を除外し、集計後に再度付与する)
#
# コマンド形式  ：EO3091150J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v5.00          2013/06/05   FJ) 小柴    【IKK-2013-0001168】料金計算の際、値が指数化して処理が停止する場合がある問題を修正
#
##############################################################

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

#
#---ツール格納場所
#
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=EO3091150J0,"
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
#
#--- ファイル定義
#
# コンテンツ通話合計（集計後）
INFILE1=${MID_DIR_AC}/ACIFM201002.csv
# コンテンツ通話合計（ワーク：ソート前料金100倍）
OUTFILE_TEMP1=${MID_DIR_AC}/ACIFM201002_TEMP1.csv
# コンテンツ通話合計（ワーク：ソート後100倍）
OUTFILE_TEMP2=${MID_DIR_AC}/ACIFM201002_TEMP2.csv

# 通話料超過チェック用ファイル
OUTFILE1=${MID_DIR_AC}/ACIFM202001.csv

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

#
#---ＳＯＲＴ
#
bsortex -sort key=2.6asca,0.10asca,3.12asca                    \
    -record recform=txtflt fldsep=, -summary field=6.12ascuz   \
    -input reclen=72 file=${OUTFILE_TEMP1}                           \
    -output file=${OUTFILE_TEMP2}                                   \
     reconst=0.10,2.6,3.12,6.14

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,%.2f\r\n", $1,$2,$3,$4/100}' ${OUTFILE_TEMP2} > ${OUTFILE1}

#---中間ファイルの削除
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}
