#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：利用料金情報（契約項目情報）マージ・ソート
#
# 機能          ：利用料金情報（契約項目情報・違約金契約項目情報）を以下のキーでマージ・ソートする。
#・料金コース＞料金サービス＞相対番号＞料金項目コード＞サービス解約理由（昇順）
#
#なお、利用料金情報（ACIFI016075.csv）のファイルレイアウトが異なるため、末尾に項目を付加したのちマージソートを行う。
#
# コマンド形式  ：EO3010605J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v3.00           2012/08/20  FJ）岡田     【ST2-2012-0001464】マンション課題対応
# v4.01           2013/03/23  FJ）広野     【ST4-2013-0000405】性能改善 bsortパラメータの指定サイズ最適化
# v5.00           2013/10/12  FJ) 黒木     【ANK-1580-00-00】eoスマートリンク改修対応
# v48.00          2020/02/03  GDC) ニール     【ANK-3675-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=EO3010605J0,"
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

#
#---ＳＯＲＴ
#
bsort -s -Tflt -t, -z330 -9.3asca,10.12asca,23.1asca,11.11asca,19.2asca -o ${MID_DIR_AC}/ACIFM057003.csv ${MID_DIR_AC}/ACIFM057001.csv ${MID_DIR_AC}/ACIFM057002.csv ${MID_DIR_AC}/ACIFM057011.csv 

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

#  ANK-3675-00-00 ADD START
#
#後続のマッチング処理のために、ダブルクォート付 LF に変換
#
nkf -s -Lu ${MID_DIR_AC}/ACIFM057003.csv > ${MID_DIR_AC}/ACIFM057003_tmp.csv
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " nkf Error($SVC nkf:rc=$rc) " 
    echo $JOBNAME " BSORT Error($SVC nkf:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

sed -i -e "s/,/\",\"/g" ${MID_DIR_AC}/ACIFM057003_tmp.csv
sed -i -e "s/^/\"/g"    ${MID_DIR_AC}/ACIFM057003_tmp.csv
sed -i -e "s/$/\"/g"    ${MID_DIR_AC}/ACIFM057003_tmp.csv




MATCHDEF_AC_CM_0169=${G_TOOLSH}/util/def/AC_CM_0169.def
MATCHDEF_AC_CM_0169_WORK=${LOC_DIR_AC}/${JOBNAME}_AC_CM_0169_work.def
TMPFILE_AC_CM_0169_MATCH=${LOC_DIR_AC}/${JOBNAME}_AC_CM_0169_MATCH.csv
TMPFILE_AC_CM_0169_MATCH2=${LOC_DIR_AC}/${JOBNAME}_AC_CM_0169_MATCH2.csv
TMPFILE_AC_CM_0169_MATCH3=${LOC_DIR_AC}/${JOBNAME}_AC_CM_0169_MATCH3.csv

cp -f ${MATCHDEF_AC_CM_0169} ${MATCHDEF_AC_CM_0169_WORK}
# Change contents to CSV files used
sed -i -e s@':ACIFM057_csv'@${MID_DIR_AC}/ACIFM057003_tmp.csv@g ${MATCHDEF_AC_CM_0169_WORK}
sed -i -e s@':ACIFM335_csv'@${MID_DIR_AC}/ACIFM335001.csv@g ${MATCHDEF_AC_CM_0169_WORK}

cat /dev/null > ${TMPFILE_AC_CM_0169_MATCH}
export ZTLOUTFILE=$TMPFILE_AC_CM_0169_MATCH

# ファイルマッチング
${G_TOOLSH}/util/bin/ZTLMAT01 $MATCHDEF_AC_CM_0169_WORK

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

#
#マッチングが済んだらダブルクォート無 CR+LFに戻す
#
nkf -s -Lw $TMPFILE_AC_CM_0169_MATCH > $TMPFILE_AC_CM_0169_MATCH2
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " BSORT Error($SVC nkf:rc=$rc) " 
    echo $JOBNAME " BSORT Error($SVC nkf:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

sed s/\"//g $TMPFILE_AC_CM_0169_MATCH2 > $TMPFILE_AC_CM_0169_MATCH3
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " DEL_DQ Error($SVC del_dq:rc=$rc) " 
    echo $JOBNAME " DEL_DQ Error($SVC del_dq:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

cp -p -f $TMPFILE_AC_CM_0169_MATCH3 $TMPFILE_AC_CM_0169_MATCH



#
#---ＳＯＲＴ
#
bsort -s -Tflt -t, -z330 -9.3asca,10.12asca,23.1asca,11.11asca,19.2asca -o ${MID_DIR_AC}/ACIFM336001.csv ${TMPFILE_AC_CM_0169_MATCH}

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 -f ${MATCHDEF_AC_CM_0169_WORK}
rm -f ${TMPFILE_AC_CM_0169_MATCH}
rm -f ${MID_DIR_AC}/ACIFM057003_tmp.csv
rm -f ${TMPFILE_AC_CM_0169_MATCH2}
rm -f ${TMPFILE_AC_CM_0169_MATCH3}
#  ANK-3675-00-00 ADD END
#
#--- ジョブの終了メッセージを出力する
#
sh ${G_TOOLSH}/EOK010210J0.sh CS00028I $JOBNAME
sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME

exit ${G_RTN_NORMAL}
