#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：請求収納
#
# シェル名      ：料金対応記録登録情報マージ・ソート
#
# 機能          ：料金対応記録登録情報ファイルのソートを行う。
#
#SORT順
#対応年月日時分秒（昇順）
#
# コマンド形式  ：EO6230105J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v4.00           2013/06/07  FJ) 前田     入力ファイルをリネームして残すように修正
# v5.00           2013/11/20  FJ) 柴田     【ST4-2013-0000585】性能改善の為、多重化
# v13.00          2015/04/17  FJ) 岡田     【OM-2015-0000845】性能改善_料金対応記録登録切り分け
# v14.00          2015/05/15  FJ) 岡田     【OM-2015-0000998】機能改善対応 運）２５：００で呼び込むファイル名を変更
# v14.01          2015/05/20  FJ) 岡田     【OM-2015-0000998】機能改善対応 運）２５：００で呼び込むファイル名を変更
# v52.01          2020/11/20  FJ) 中原     【ANK-3838-00-00】窓口払い手数料の顧客負担方式導入
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#---運用日付取得
# v13.00 MOD START
#if [ "${OPD}" = "" ]; then
if [ "${OPD}" = "" -o "${OPD}" = "20991231" ]; then
# v13.00 MOD END
   . EOK010310J0.sh "BDATE"
else
   RSLT_OPEDATE="${OPD}"
fi

# v13.00 ADD START
#
#---業務で必要な変数定義
#
IN_PARAM=$2
# v13.00 ADD END

#
#---業務で必要な変数定義
#
#xxx=xxxxxxx
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

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

P1="OPD=,"
P2="SVCCTL=,"
P3="JOB=EO6230105J0,"
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は入力をテキスト固定長とした上で請求先番号が先頭なので
#--- ９桁目をバイト数で指定することによりファイルの分割を行っている。
#--- CHIFM096201はｖ52.00からファイル作成元が実行中止のため、ファイルが作成されないが、リカバリ用として処理を残す。
# v13.00 ADD START
if
	[ ${IN_PARAM} -eq 1 ]; then
	if
# v14.01 MOD START ※INFILEの名称のみ修正
# v14.00 MOD START ※INFILEの名称のみ修正
#		[ -r ${MID_DIR_CH}/CHIFM096020.csv ]; then
#			cat ${MID_DIR_CH}/CHIFM096020.csv \
#		[ -r ${MID_DIR_CH}/EO6B50130J0_CHIFM096020.csv ]; then
#			cat ${MID_DIR_CH}/EO6B50130J0_CHIFM096020.csv \
		[ -r ${MID_DIR_CH}/CHIFM096201.csv ]; then
			cat ${MID_DIR_CH}/CHIFM096201.csv \
			|bsortex \
			  -sort key="0.10asca,2.17asca,3.3asca,4.4asca" \
			  -record recform=txtcsv \
			  -input reclen=530 \
			|bsortex \
			  -record recform=txtfix \
			  -input reclen=530 \
			  -output file=${MID_DIR_CH}/CHIFM096101_0h.csv case="9.1asc.eq.'0h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_1h.csv case="9.1asc.eq.'1h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_2h.csv case="9.1asc.eq.'2h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_3h.csv case="9.1asc.eq.'3h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_4h.csv case="9.1asc.eq.'4h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_5h.csv case="9.1asc.eq.'5h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_6h.csv case="9.1asc.eq.'6h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_7h.csv case="9.1asc.eq.'7h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_8h.csv case="9.1asc.eq.'8h'" \
			  -output file=${MID_DIR_CH}/CHIFM096101_9h.csv case=other ;
# v14.00 MOD END
# v14.01 MOD END
# v52.00 ADD START
	else
		cat ${MID_DIR_CH}/CHIFM096401.csv \
		|bsortex \
		  -sort key="0.10asca,2.17asca,3.3asca,4.4asca" \
		  -record recform=txtcsv \
		  -input reclen=530 \
		|bsortex \
		  -record recform=txtfix \
		  -input reclen=530 \
		  -output file=${MID_DIR_CH}/CHIFM096101_0h.csv case="9.1asc.eq.'0h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_1h.csv case="9.1asc.eq.'1h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_2h.csv case="9.1asc.eq.'2h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_3h.csv case="9.1asc.eq.'3h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_4h.csv case="9.1asc.eq.'4h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_5h.csv case="9.1asc.eq.'5h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_6h.csv case="9.1asc.eq.'6h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_7h.csv case="9.1asc.eq.'7h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_8h.csv case="9.1asc.eq.'8h'" \
		  -output file=${MID_DIR_CH}/CHIFM096101_9h.csv case=other ;
	fi
# v52.00 ADD END
else
# v13.00 ADD END
cat ${MID_DIR_CH}/CHIFM0960*.csv \
|bsortex \
  -sort key="0.10asca,2.17asca,3.3asca,4.4asca" \
  -record recform=txtcsv \
  -input reclen=530 \
|bsortex \
  -record recform=txtfix \
  -input reclen=530 \
  -output file=${MID_DIR_CH}/CHIFM096101_0.csv case="9.1asc.eq.'0'" \
  -output file=${MID_DIR_CH}/CHIFM096101_1.csv case="9.1asc.eq.'1'" \
  -output file=${MID_DIR_CH}/CHIFM096101_2.csv case="9.1asc.eq.'2'" \
  -output file=${MID_DIR_CH}/CHIFM096101_3.csv case="9.1asc.eq.'3'" \
  -output file=${MID_DIR_CH}/CHIFM096101_4.csv case="9.1asc.eq.'4'" \
  -output file=${MID_DIR_CH}/CHIFM096101_5.csv case="9.1asc.eq.'5'" \
  -output file=${MID_DIR_CH}/CHIFM096101_6.csv case="9.1asc.eq.'6'" \
  -output file=${MID_DIR_CH}/CHIFM096101_7.csv case="9.1asc.eq.'7'" \
  -output file=${MID_DIR_CH}/CHIFM096101_8.csv case="9.1asc.eq.'8'" \
  -output file=${MID_DIR_CH}/CHIFM096101_9.csv case=other ;
# v13.00 ADD START
fi
# v13.00 ADD 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

#
#--- 入力で使用した中間ファイル名のバックアップ
#
# v13.00 ADD START
if
	[ ${IN_PARAM} -eq 1 ]; then
	if
# v14.01 MOD START
# v14.00 MOD START
#		[ -r ${MID_DIR_CH}/CHIFM096020.csv ]; then
#		mv -f ${MID_DIR_CH}/CHIFM096020.csv ${MID_DIR_CH}/CHIFM096020.csv_${RSLT_OPEDATE}
#		[ -r ${MID_DIR_CH}/EO6B50130J0_CHIFM096020.csv ]; then
#		mv -f ${MID_DIR_CH}/EO6B50130J0_CHIFM096020.csv ${MID_DIR_CH}/EO6B50130J0_CHIFM096020.csv_${RSLT_OPEDATE}
		[ -r ${MID_DIR_CH}/CHIFM096201.csv ]; then
		mv -f ${MID_DIR_CH}/CHIFM096201.csv ${MID_DIR_CH}/CHIFM096201.csv_${RSLT_OPEDATE}
# v14.00 MOD END
# v14.01 MOD END
    fi
# v52.00 ADD START
	if
		[ -r ${MID_DIR_CH}/CHIFM096401.csv ]; then
		mv -f ${MID_DIR_CH}/CHIFM096401.csv ${MID_DIR_CH}/CHIFM096401.csv_${RSLT_OPEDATE}
	fi
# v52.00 ADD END
else
# v13.00 ADD END
for FILE in `ls -1 ${MID_DIR_CH}/CHIFM0960*.csv`
do
    mv -f ${FILE} ${FILE}_${RSLT_OPEDATE}
    
    rc=$?
    if [ $rc -ne 0 ]
    then
        sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " MV Error($SVC mv:rc=$rc) "
        echo $JOBNAME " MV Error($SVC mv:rc=$rc) "
        exit ${G_RTN_ERROR}
    fi
done
# v13.00 ADD START
fi
# v13.00 ADD END

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

exit ${G_RTN_NORMAL}
