#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：請求収納
#
# シェル名      ：請求情報ソート
#
# 機能          ：請求情報のソートを行う。
#ソートキー：請求契約番号＞請求年月
#
#
# コマンド形式  ：EO6010280J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v3.00           2012/08/02  FJ）冨井     【ST2-2012-0001614】ファイルID変更（CHIFM143003.csv→CHIFM143005.csv）
# v5.00           2013/10/10  FJ）後藤     【OM-2012-0002850】請求債権関連のLeftJoin処理追加
# v20.00          2015/11/04  FJ) 山裾     【ANK-2565-00-00】クレジットカード番号預かりサービス導入（Step3：預かり番号化）
# v37.00.00       2013/12/16  FJ)酒井       ANK-3366-00-00
#
##############################################################

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

#
#---ツール格納場所
#
G_TOOLSH=.

#
#---環境変数定義Shell呼び出し
#
. EOK010110J0.sh

#
#---ＪＯＢ名
#
JOBNAME=`basename $0 | sed -e "s/\.sh//g"`

#
#---サービス（業務プロセス）
#
SVC=$JOBNAME

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
#---マッチング処理でLeftjoinがNULL時に"を付けなくする（マッチング使用時は必須）
export ZTLQUOTES=''


#---ワークファイル削除モード
WK_RM=true ;

##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

#
#---パラメタ定義
#

P1="OPD=,"
P2="SVCCTL=,"
P3="JOB=EO6010280J0,"
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

#
#---ファイル定義
#
#-- 入力ファイル
# 請求契約情報
INFILE_CHIFM143=${MID_DIR_CH}/CHIFM143001.csv

# 請求債権関連情報
INFILE_CHIFM218=${MID_DIR_CH}/CHIFM218001.csv

#-- 出力ファイル
OUTFILE=${MID_DIR_CH}/CHIFM219001.csv

#-- マッチングdef
CH_CM_0105=${G_TOOLSH}/util/def/CH_CM_0105.def

#-- ワークファイル
INFILE_CHIFM143_WK=${MID_DIR_CH}/${JOBNAME}_CHIFM143001_WK.csv
OUTFILE_WK=${MID_DIR_CH}/${JOBNAME}_CHIFM219001_WK.csv
CH_CM_0105_WK=${G_TOOLSH}/util/def/${JOBNAME}_CH_CM_0105_WK.def

#
#---改行コード変換
# 請求契約情報をCRLF→LFに変換
tr -d "\r" < ${INFILE_CHIFM143} > ${INFILE_CHIFM143_WK}

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

#
#---ＭＡＴＣＨＩＮＧ
#
cp ${CH_CM_0105} ${CH_CM_0105_WK}

sed -i -e "s%:CHIFM143%${INFILE_CHIFM143_WK}%" ${CH_CM_0105_WK}
sed -i -e "s%:CHIFM218%${INFILE_CHIFM218}%"    ${CH_CM_0105_WK}

ZTLOUTFILE=${OUTFILE_WK}
export ZTLOUTFILE
${G_TOOLSH}/util/bin/ZTLMAT01 ${CH_CM_0105_WK}

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

#
#---ＳＯＲＴ
#
# v37.00.00 ANK-3366-00-00 MOD STA
## 2015/11/04 ANK-2565-00-00 Mod Start
##bsortex -sort key="0.10asc,4.6asc" -record recform=txtcsv \
##    -input reclen=2600 file=${OUTFILE_WK} \
##    -output file=${OUTFILE} linedlmt=crlf
#bsortex -sort key="0.10asc,4.6asc" -record recform=txtcsv \
#    -input reclen=2650 file=${OUTFILE_WK} \
#    -output file=${OUTFILE} linedlmt=crlf
## 2015/11/04 ANK-2565-00-00 Mod End
bsortex -sort key="0.10asc,4.6asc" -record recform=txtcsv \
    -input reclen=2800 file=${OUTFILE_WK} \
    -output file=${OUTFILE} linedlmt=crlf
# v37.00.00 ANK-3366-00-00 MOD END

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

# ワーク削除
if [ ${WK_RM} = "true" ] ;then 
    rm -f ${INFILE_CHIFM143_WK}
    rm -f ${OUTFILE_WK}
    rm -f ${CH_CM_0105_WK}
fi

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

exit ${G_RTN_NORMAL}
