#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：割引料金情報ソート１
#
# 機能          ：集計前反映後割引適用結果情報ファイルと課金対象サービス契約情報ファイル・課金対象サービス契約情報(マンション)ファイルをマージし、ソート処理を行う。
#マージを行う際に課金対象サービス契約情報ファイル・課金対象サービス契約情報(マンション)ファイルを割引料金情報の形にフォーマット変換を行い、各々のデータにファイル区分を設定する。
#なお、パラメータにより処理対象ファイルを切り替える。
#
#＜ソート＞
#以下のキーでソートする。
#ソートキー：請求契約番号、ファイル区分
#
#＜ファイル区分＞
#集計前反映後割引適用結果情報ファイル："1"
#課金対象サービス契約情報："2"
#課金対象サービス契約情報（マンション）："2"
#
# コマンド形式  ：EO3010810J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v3.00           2012/05/27  FJ）冨井     【it1ac01_040】ファイル項目追加
# v3.00           2012/06/27  FJ）冨井     【IT2-2012-0001109】再編成修正
# v3.00           2012/08/09  FJ) 田辺     【IT2-2012-0001516】UI残No.830対応
# v4.00           2013/03/15  FJ）指原     【ST4-2013-0000198】性能改善 bsortパラメータの指定サイズ最適化
# v4.01           2013/04/12  FJ）黒木     【ST2-2013-0001721】割引サービス契約番号桁数不正対応
# v4.02           2013/05/09  FJ) 小柴     【SG1-2013-0000082】引数ファイル１つを変更
# v5.00           2013/06/28  FJ) 藤田     【ST4-2013-0000479】性能改善 nkfの使用を廃止する。
# v9.00           2013/04/25  FJ)狭間      【ANK-2054-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=EO3010810J0,"
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}/ACIFM226001.csv
INPUTFILE2=${MID_DIR_AC}/ACIFI015009.csv
INPUTFILE3=${MID_DIR_AC}/ACIFM053001.csv
OUTPUTFILE=${MID_DIR_AC}/ACIFM060001.csv
INPUTFILE1_TMP=${MID_DIR_AC}/ACIFM226001_TMP_EO3010810J0.csv
INPUTFILE2_TMP=${MID_DIR_AC}/ACIFI015009_TMP_EO3010810J0.csv
INPUTFILE3_TMP=${MID_DIR_AC}/ACIFM053001_TMP_EO3010810J0.csv

# 入力ファイルの整形を行う
#
bsortex \
  -sort \
  -record recform=txtflt fldsep=, \
  -input  file=${INPUTFILE1} \
          reclen=200 \
          reconst="'1'.1asc,0.10,1.6,2.12,3.11,4.20,5.1,6.3,7.12,8.11,9.2,10.12,11.8,12.8,13.8,14.8,15.8,16.2,17.8,18.2,19.2,20.1,21.2,' '.1asc,' '.1asc,22.4,' '.1asc,' '.1asc,' '.1asc" \
  -output file=${INPUTFILE1_TMP} \
          linedlmt=lf ;
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT step1 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " SORT step1 Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi
#
#---課金対象サービス契約情報、
#---課金対象サービス契約情報（マンション）をマージする

##再編成（マンション項目を削除※課金対象サービス契約情報のフォーマットに合わせる）
bsortex -sort -record recform=txtflt fldsep=, \
 -input reclen=400 file=${INPUTFILE3} \
 -output file=${INPUTFILE3_TMP} \
 reconst=0.14,1.1,2.2,3.3,4.12,5.20,6.12,7.10,8.6,9.12,10.11,11.8,12.8,13.2,14.8,15.8,16.8,17.8,18.8,19.8,20.2,21.2,22.8,23.8,24.8,25.3,26.5,27.3,28.5,29.7,30.7,31.1,32.2,37.30

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

bsortex \
  -sort \
  -record recform=txtflt fldsep=, \
  -input  reclen=400 \
          file=${INPUTFILE2},${INPUTFILE3_TMP} \
          reconst="'2'.1asc,7.10,8.6,9.12,10.11,5.20,' '.1asc,3.3,4.12,' '.1asc,' '.1asc,' '.1asc,18.8,19.8,11.8,23.8,12.8,13.4,14.8,20.2,21.2,31.1,32.2,' '.1asc,' '.1asc,' '.1asc,0.14,' '.1asc,' '.1asc" \
  -output file=${INPUTFILE2_TMP} \
          linedlmt=lf ;
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT step2 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " SORT step2 Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#
#---ＳＯＲＴ
#
bsortex \
  -sort   key="1.12asca,5.20asca,7.3asca,8.12asca,0.1asca" \
  -record recform=txtflt fldsep=, \
  -input  file=${INPUTFILE1_TMP},${INPUTFILE2_TMP} \
          reclen=200 \
  -output file=${OUTPUTFILE} \
          linedlmt=crlf ;
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT step3 Error($SVC sort:rc=$rc) "
    echo $JOBNAME " SORT step3 Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi


# ワークファイルの削除
if [ -f ${INPUTFILE1_TMP} ]; then
	rm ${INPUTFILE1_TMP}
	echo $JOBNAME " Remove File ${INPUTFILE1_TMP} "
fi

if [ -f ${INPUTFILE2_TMP} ]; then
	rm ${INPUTFILE2_TMP}
	echo $JOBNAME " Remove File ${INPUTFILE2_TMP} "
fi

if [ -f ${INPUTFILE3_TMP} ]; then
	rm ${INPUTFILE3_TMP}
	echo $JOBNAME " Remove File ${INPUTFILE3_TMP} "
fi


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

exit ${G_RTN_NORMAL}
