#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：割引料金情報集計前後マージソート２
#
# 機能          ：料金情報（ファイル区分含む）、利用料金情報を以下のキーでマージソートする。
#割引料金情報に１、利用料金譲歩に２のファイル区分を付与する。
#ソートキー：請求先番号(昇順) ＞ サービス番号(昇順) ＞ファイル区分(降順)
#
# コマンド形式  ：EO3013403J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v4.00           2013/05/28  FJ) 早崎     【残課題No.6対応】新規作成
# v8.00.00        2013/12/26  FJ）柴田     【ANK-1794-00-00】bsortパラメータの指定サイズを変更
# v9.00.00        2014/06/17  FJ）酒井     【IT2-2014-0000259】サービス詳細識別コードを追加
# v57.00.00       2022/03/09  FJ）上村     【OM-2021-0001807】ＣＰ不正終了について
##############################################################

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

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

INPUTFILE1=${MID_DIR_AC}/ACIFM103002.csv
INPUTFILE1_TMP=${MID_DIR_AC}/ACIFM103002_TMP_${JOBNAME}.csv

INPUTFILE2=${MID_DIR_AC}/ACIFI016031.csv
INPUTFILE2_TMP=${MID_DIR_AC}/ACIFI016031_TMP_${JOBNAME}.csv

OUTPUTFILE=${MID_DIR_AC}/ACIFM227002.csv

# 料金情報（ファイル区分含む）
# 出力ファイルにフォーマットを合わせる
# ファイルレコードの先頭にファイル区分１を割り振る
bsortex -copy -record recform=txtcsv \
 -input reclen=300 file=${INPUTFILE1} \
 -output file=${INPUTFILE1_TMP} \
 reconst="'1'.1asc,1.10,2.6,EMPTY,EMPTY,3.20,4.1,5.3,6.12,7.11,EMPTY,8.12,9.8,10.8,EMPTY,EMPTY,EMPTY,EMPTY,EMPTY,EMPTY,EMPTY,11.1,12.2,EMPTY,13.30" \


# 利用料金情報ファイル
# 出力ファイルにフォーマットを合わせる
# ファイルレコードの先頭にファイル区分２を割り振る
#v57.00.00 MOD START
#bsortex -copy -record recform=txtcsv \
# -input reclen=300 file=${INPUTFILE2} \
# -output file=${INPUTFILE2_TMP} \
#reconst"='2'.1asc,0.10,1.6,3.12,4.11,5.20,7.1,9.3,10.12,11.11,12.2,13.12,14.8,15.8,16.8,17.8,18.8,19.2,20.8,21.2,22.2,23.1,24.2,27.4,30.30"
bsortex -copy -record recform=txtcsv \
 -input reclen=300 file=${INPUTFILE2} \
 -output file=${INPUTFILE2_TMP} \
 reconst"='2'.1asc,0.10,1.6,3.12,4.11,5.20,7.1,9.3,10.12,11.11,12.2,13.12,14.8,15.8,16.8,17.8,18.8,19.2,20.8,21.2,22.2,23.1,24.2,27.13,30.30"
#v57.00.00 MOD END

#
#---ＳＯＲＴ
#
bsortex -sort key=1.10asca,5.20asca,24.30asca,0.1ascr -record recform=txtflt fldsep=, \
 -input reclen=300 file=${INPUTFILE1_TMP},${INPUTFILE2_TMP} \
 -output file=${OUTPUTFILE} \

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


# 中間ファイルの削除
rm ${INPUTFILE1_TMP}
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 ${INPUTFILE2_TMP} 
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


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

exit ${G_RTN_NORMAL}
