#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：利用料金情報マージ・ソート３
#
# 機能          ：各連携もとの利用料金情報をマージし、以下のキー情報にてソートする。
#ソートキー：請求年月（昇順）＞料金コースコード（昇順）＞料金サービスコード（昇順）＞
#料金項目コード（昇順）＞請求先番号（昇順）＞サービス番号（昇順）
#
#
# コマンド形式  ：EO3013140J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v3.00           2012/04/27  FJ）冨井     【ANK-0024-04-00】ファイル項目追加
# v4.00           2013/03/21  FJ）浜口     【IT2-2013-0000288/287】割引適用開始終了の補正対応
# v4.01           2013/03/23  FJ）今井     【契約障害対応】マンションオーナー向け利用不可期間減処理の追加対応
# v8.00           2013/12/26  FJ) 黒木     【ANK-1794-00-00】サービス詳細識別番号の追加対応
##############################################################

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

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


##入力ファイルの改行コード変換(CRLF→LF)
nkf -Lu  < ${MID_DIR_AC}/ACIFI016019.csv > ${MID_DIR_AC}/ACIFI016019_LF_EO3013140J0.csv

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

nkf -Lu  < ${MID_DIR_AC}/ACIFI016104.csv > ${MID_DIR_AC}/ACIFI016104_LF_EO3013140J0.csv

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

nkf -Lu  < ${MID_DIR_AC}/ACIFI016023.csv > ${MID_DIR_AC}/ACIFI016023_LF_EO3013140J0.csv

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

nkf -Lu  < ${MID_DIR_AC}/ACIFM042002.csv > ${MID_DIR_AC}/ACIFM042002_LF_EO3013140J0_1.csv

rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " nkf Step4 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " nkf Step4 Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi
    
nkf -Lu  < ${MID_DIR_AC}/ACIFI016018.csv > ${MID_DIR_AC}/ACIFI016018_LF_EO3013140J0.csv

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

nkf -Lu  < ${MID_DIR_AC}/ACIFM084047.csv > ${MID_DIR_AC}/ACIFM084047_LF_EO3013140J0.csv

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

#
#---ＳＯＲＴ
#
# フォーマットを揃えるため単独で再編成を行う
bsort -s -z400 -Tflt -t, -11.99asca  \
 -e0.99,1.99,2.99,3.99,4.99,5.99,6.99,7.99,8.99,9.99,10.99,11.99,\'\ \'.1asc,12.99,13.99,14.99,15.99,16.99,17.99,18.99,19.99,20.99,21.99,22.99,23.99,\'\ \'.1asc,\'\ \'.1asc,\'\ \'.1asc,24.99,25.99,26.99 \
 -o ${MID_DIR_AC}/ACIFM042002_LF_EO3013140J0_2.csv \
 ${MID_DIR_AC}/ACIFM042002_LF_EO3013140J0_1.csv

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


bsort -s -z400 -Tflt -t, \
  -1.6ascaN,9.3asca,10.12asca,11.11asca,0.10asca,5.20asca,6.24asca,20.8asca,14.8asca,15.8asca \
    -e0.99,1.99,2.99,3.99,4.99,5.99,6.99,7.99,8.99,9.99,10.99,11.99,12.99,13.99,14.99,15.99,16.99,17.99,18.99,19.99,20.99,21.99,22.99,23.99,24.99,25.99,26.99,27.99,28.99,29.99,30.99 \
    -o ${MID_DIR_AC}/ACIFI016029_LF_EO3013140J0.csv \
	${MID_DIR_AC}/ACIFI016019_LF_EO3013140J0.csv \
	${MID_DIR_AC}/ACIFI016104_LF_EO3013140J0.csv \
	${MID_DIR_AC}/ACIFI016023_LF_EO3013140J0.csv \
	${MID_DIR_AC}/ACIFM042002_LF_EO3013140J0_2.csv \
	${MID_DIR_AC}/ACIFI016018_LF_EO3013140J0.csv \
	${MID_DIR_AC}/ACIFM084047_LF_EO3013140J0.csv 

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


##出力ファイルの改行コード変換(LF→CRLF)
nkf -Lw  < ${MID_DIR_AC}/ACIFI016029_LF_EO3013140J0.csv > ${MID_DIR_AC}/ACIFI016029.csv

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

##中間ファイルの削除
rm ${MID_DIR_AC}/ACIFI016019_LF_EO3013140J0.csv
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " rm Step1 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " rm Step1 Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi


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


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


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


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


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


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


rm ${MID_DIR_AC}/ACIFM042002_LF_EO3013140J0_2.csv
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " rm Step9 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " rm Step9 Error($SVC sort: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}
