#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：請求契約キャンセル情報抽出
#
# 機能          ：サービス契約情報インターフェースから、請求契約番号内で請求契約単位レコード
#（料金サービスコード＝"SEIKYU"）のみである情報を、請求内訳の削除対象として抽出する。
#
# コマンド形式  ：EO30101J0J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v5.00          2013/07/20   FJ) 小柴    【TG1-2013-0000709】新規作成
# v5.01          2013/07/24   FJ) 小柴    【TG1-2013-0000709】入力ファイルを引数によって決定する処理を追加
# v5.02          2013/07/29   FJ) 小柴    【TG1-2013-0000720】ケース文の条件エラー時にログ出力を行うように修正
# v5.03          2013/10/23   FJ) 小掠    【OM-2013-0003323】①外部料金取込削除データをサービス契約情報と契約番号でマージし重複データを除く処理を追加。②javaの起動箇所を削除。
# v6.00           2013/12/06  FJ) 狭間     【OM-2013-0004668】入力ファイルを変更
# v6.01           2013/12/17  FJ) 狭間     【OM-2013-0005187】解約異動が請求内訳に反映されていない修正
# v8.00           2014/04/30  FJ) 狭間     【ST4-2013-0000573】抽出元をサービス契約情報（異動契約）ACIFI002201からサービス契約情報（ソート済み）ACIFI001003へ変更
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#---運用日付取得
if [ "${OPD}" = "20991231"  ]; then
    OPD=""
fi
if [ "${OPD}" = "" ]; then
   . EOK010310J0.sh "BDATE"
else
   RSLT_OPEDATE="${OPD}"
fi
OPEDATE="${RSLT_OPEDATE}"

#
#---業務で必要な変数定義
#
#xxx=xxxxxxx

INPUTFILE=
INPUTFILE_WK=
INPUTFILE2=
INPUTFILE2_WK=
OUTPUTFILE=

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

INPUTFILE2=${MID_DIR_AC}/ACIFM050023.csv
INPUTFILE2_WK=${MID_DIR_AC}/${JOBNAME}_ACIFM050023_WK.csv
OUTPUTFILE=${SEND_DIR}/CHIFI002001.csv

INPUTFILE=${MID_DIR_AC}/ACIFI001003.csv
INPUTFILE_WK=${MID_DIR_AC}/${JOBNAME}_ACIFI001003_WK.csv

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

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

#--- サービス契約情報のソートを行う
bsortex \
    -sort key="6.10asc" \
    -input reclen=290 file=${INPUTFILE} \
    -record recform=txtcsv \
    -output reconst="6.10" file=${INPUTFILE_WK}

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

#--- 外部料金削除データのソートを行う
bsortex \
    -sort key="0.10asc" \
    -input reclen=50 file=${INPUTFILE2} \
    -record recform=txtcsv \
    -output file=${INPUTFILE2_WK}

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

#--- マージを行い重複データを削除する
bsortex \
    -merge key="0.10asc" \
    -input reclen=50 file=${INPUTFILE_WK},${INPUTFILE2_WK} \
    -record recform=txtcsv \
    -summary suppress first \
    -output reconst="0.10,'${RSLT_OPEDATE}'.8asc" file=${OUTPUTFILE}

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

exit_rc=$rc

#--- ワークファイルを削除する
rm -f ${INPUTFILE_WK}
rm -f ${INPUTFILE2_WK}

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

exit $exit_rc
