#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：契約管理
#
# シェル名      ：異動分機器ＯＰ情報集約１（無線ＲＴ／ＶＡ分割）（当月）
#
# 機能          ：機器オプションサービス契約の情報を料金サービスコードで分割する。
#
# コマンド形式  ：EO21E01FBJ0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v61.00.00       2023/07/11  FJ)渋谷      【ANK-4315-00-00】【eo定期】 eoホームゲートウェイ導入対応
#
##############################################################

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

#
#---ツール格納場所
#
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

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

# 当月を対象とする
OPEDATE_YYYYMM=`echo ${RSLT_OPEDATE} |cut -c 1-6`
OPEDATE_STADAY=${OPEDATE_YYYYMM}"01"
NDATE=`date -d "1 month ${OPEDATE_STADAY}" +'%Y%m%d'`
EDAY=`date -d "1 day ago ${NDATE}" +'%d'`
OPEDATE_ENDDAY=`echo ${OPEDATE_STADAY} |cut -c 1-6`${EDAY}

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

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

INFILE1=${MID_DIR_KK}/KKIFM020202_tmp.csv
INFILE2=${MID_DIR_KK}/KKIFM020202_KKOP_01_tmp.csv
INFILE3=${MID_DIR_KK}/KKIFM020202_KKOP_02_tmp.csv
OUTFILE1=${MID_DIR_KK}/KKIFM020202_00.csv
OUTFILE2=${MID_DIR_KK}/KKIFM020202_01.csv
OUTFILE3=${MID_DIR_KK}/KKIFM020202_02.csv
OUTFILE4=${MID_DIR_KK}/KKIFM020202_KKOP_01_sort.csv
OUTFILE5=${MID_DIR_KK}/KKIFM020202_KKOP_02_sort.csv
OUTFILE6=${MID_DIR_KK}/KKIFM020202_KKOP_01.csv
OUTFILE7=${MID_DIR_KK}/KKIFM020202_KKOP_02.csv

#
#--- 各ファイルの存在チェックを行う
#

if [ ! -r $INFILE1 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist($INFILE1) "
    echo $JOBNAME " File is nonexist($INFILE1) "
    exit ${G_RTN_ERROR}
fi

if [ ! -r $INFILE2 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist($INFILE2) "
    echo $JOBNAME " File is nonexist($INFILE2) "
    exit ${G_RTN_ERROR}
fi

if [ ! -r $INFILE3 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist($INFILE3) "
    echo $JOBNAME " File is nonexist($INFILE3) "
    exit ${G_RTN_ERROR}
fi

#
#--- 機器オプションサービス契約情報(無線ルーター（レンタル）)をソート
# 抽出条件
#   (料金サービスコードが無線ルーター（レンタル）)
#
bsortex -copy -record recform=txtcsv -input file=${INFILE1} reclen=380 include="2.12asc.eq.'PG0201'" -output file=${OUTFILE2}

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

#
#--- 機器オプションサービス契約情報(ＶＡ)をソート
# 抽出条件
#   (料金サービスコードがＶＡ)
#
bsortex -copy -record recform=txtcsv -input file=${INFILE1} reclen=380 include="2.12asc.eq.'PG0301'.or.2.12asc.eq.'PG0401'" -output file=${OUTFILE3}

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


#
#--- 機器オプションサービス契約情報(無線ルーター（レンタル）,ＶＡ以外)をソート
# 抽出条件
#   (料金サービスコードが無線ルーター（レンタル）,ＶＡ以外)
#
bsortex -copy -record recform=txtcsv -input file=${INFILE1} reclen=380 omit="2.12asc.eq.'PG0201'.or.2.12asc.eq.'PG0301'.or.2.12asc.eq.'PG0401'" -output file=${OUTFILE1}

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


#
#--- ソート
# ソートキー：従属サービス番号
#

bsortex -sort key=5.12asc,17.8asc -record recform=txtcsv -input file=${INFILE2} reclen=380 -output file=${OUTFILE4}

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

#
#--- マージ
# マージキー：従属サービス番号
#
bsortex -merge key=5.12asc -record recform=txtcsv -input file=${OUTFILE4} reclen=380 -summary suppress last -output file=${OUTFILE6}

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

#
#--- ソート
# ソートキー：従属サービス番号
#
bsortex -sort key=5.12asc,17.8asc -record recform=txtcsv -input file=${INFILE3} reclen=380 -output file=${OUTFILE5}

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

#
#--- マージ
# マージキー：従属サービス番号
#
bsortex -merge key=5.12asc -record recform=txtcsv -input file=${OUTFILE5} reclen=380 -summary suppress last -output file=${OUTFILE7}

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


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

exit ${G_RTN_NORMAL}
