#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：通信量補正情報ソート
#
# 機能          ：(1)ソート実行判定
#　(1)-1.ディレイド処理依頼情報　＞　0Byte（有件）
#　　　　　かつ、ディレイド処理依頼情報．処理結果コード 　≠　 "3"（システムエラー）の場合
#　　(2)ソートを実行する。
#　(1)-2.上記以外の場合
#　　処理終了（戻り値：正常）
#
#(2)ソート実行
#　(2)-1.FTTH通信量補正を以下のキーにて、昇順ソートする。
#           キー：サービス契約番号，請求契約番号，請求年月
#
#(3)ソート実行結果判定
#　ディレイド処理依頼情報．処理結果コードを以下の通り更新する（同ファイル名で出力する）。
#　(3)-1.ソートの戻り値　＝　異常の場合
#　　(3)-2-1.ディレイド処理結果ファイル　＞　0Byte（有件）の場合
#　　　ディレイド処理依頼情報．処理結果コード ← "3"（システムエラー）
#　　(3)-2-2.ディレイド処理結果ファイル　＝　0Byte　または　存在しない　場合
#　　　処理なし
#　(3)-2. Javaの戻り値　≠　異常の場合
#　　処理なし
#
#(4)処理終了（戻り値：ソートの戻り値）
#
# コマンド形式  ：EO31D0212D0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
#
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
DLYD_TRN_REQ_NO=
DLYD_TRN_RSLT_CD=
FN1=${MID_DIR_AC}/ACIFM099003.csv
FN2=${MID_DIR_AC}/ACIFM161001_${SYSDATE}.csv
FN1_TMP1=${MID_DIR_AC}/ACIFM099003_TMP_EO31D0212D0_1.csv
FN1_TMP2=${MID_DIR_AC}/ACIFM099003_TMP_EO31D0212D0_2.csv
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

# ファイルが存在する場合
if [ -f ${FN1} ] ; then
    nkf -Lu < ${FN1} > ${FN1_TMP1}
    # ディレイド処理依頼情報が0バイトなら終了
    if [ `wc -c ${FN1_TMP1} | awk '{print $1}'` -eq 0 ] ; then
        rm -f ${FN1_TMP1}
        sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME
        exit ${G_RTN_NORMAL}
    fi
     # 処理結果 ≠ 1 なら終了
    if [ `head -1 ${FN1_TMP1} | awk -F, '{print $2}'` -ne '1' ] ; then
        rm -f ${FN1_TMP1}
        sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME
        exit ${G_RTN_NORMAL}
    fi
# ファイルが存在しない場合終了
else
    sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME
    exit ${G_RTN_NORMAL}
fi
# ディレイド処理依頼番号取得
DLYD_TRN_REQ_NO=`head -1 ${FN1_TMP1} | awk -F, '{print $1}'`

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

P1="OPD=,"
P2="SVCCTL=,"
P3="JOB=EO31D0212D0,"
P4="IND1=ACIFM160.def,"
P5="INF1=${MID_DIR_AC}/ACIFM160001.csv,"
P6="IND2=,"
P7="INF2=,"
P8="OTD1=ACIFM160.def,"
P9="OTF1=${MID_DIR_AC}/ACIFM160002.csv,"
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 -z300 -0.99asca -4.99asca -5.99asca -Tflt -t, -o ${MID_DIR_AC}/ACIFM160002.csv ${MID_DIR_AC}/ACIFM160001.csv 

rc=$?

#ディレイド処理依頼情報更新フラグ
flg=0

# 処理結果判定
if [ ${rc} -ne 0 ] ; then
    # ディレイド処理結果ファイル　＞　0Byte（有件）の場合
    if [ -s ${FN1_TMP1} ] ; then
        DLYD_TRN_RSLT_CD="3"
        flg=1
    fi
fi

# 処理結果コードに値が設定された場合、ディレイド処理依頼情報の処理結果コード更新
if [ ${flg} -eq 1 ] ; then
    echo ${DLYD_TRN_REQ_NO}","${DLYD_TRN_RSLT_CD} > ${FN1_TMP2}

    # 改行コードをCRLFにする
    nkf -Lw  < ${FN1_TMP2} > ${FN1}
    rm -f ${FN1_TMP2}
fi
rm -f ${FN1_TMP1}

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

exit ${G_RTN_NORMAL}
