#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：インセンティブ料金情報作成
#
# 機能          ：「インセンティブ料金（新規申込料金）」と「インセンティブ料金（債権譲渡手数料）」
#                 をもとに「インセンティブ料金情報」を作成する。
#
#
#
# コマンド形式  ：EO31N0160J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v37.00.00        2018/4/2  FJ)鈴木     ANK-3366-00-00 新規作成 ｅｏ光設備卸対応
# v39.00.00        2018/9/25 FJ)寺園     ANK-3478-00-00 新規作成 ｅｏ光設備卸対応(サービス開始対応)
# v39.00.01        2018/10/04 FJ)原田     ANK-3478-00-00 ｅｏ光設備卸対応(サービス開始対応)
#
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1



#
#--- システム日付取得(年月日時分秒)
#
. EOK010410J0.sh 2


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

#--- 入力ファイル

# 卸先事業者共通アンロード（全件）
INDEF1=ACIFM305.def
INFILE1=${MID_DIR_CC}/CCIFM046001.csv
# 設備卸請求料金情報ファイル
INDEF2=ACIFM301.def
INFILE2=${MID_DIR_AC}/ACIFM301001.csv
# インセンティブ料金計算（新規申込料金）
INDEF3=ACIFM300.def
INFILE3=${MID_DIR_AC}/ACIFM300001.csv
# インセンティブ料金計算（債権譲渡手数料）
INDEF4=ACIFM302.def
INFILE4=${MID_DIR_AC}/ACIFM302001.csv
#v39.00.00 ADD START
# インセンティブ料金（継続利用契約料金）
INDEF5=ACIFM320.def
INFILE5=${MID_DIR_AC}/ACIFM320001.csv
# インセンティブ料金（年間獲得数料金）
INDEF6=ACIFM318.def
INFILE6=${MID_DIR_AC}/ACIFM318001.csv
# インセンティブ料金（月間獲得数料金）
INDEF7=ACIFM314.def
INFILE7=${MID_DIR_AC}/ACIFM314001.csv
#v39.00.00 ADD END

#--- 一時ファイル

# 卸先事業者共通アンロード（全件）複製
ORSJGS_ALD_CP=${MID_DIR_AC}/CCIFM046001_cp.csv
# 卸先事業者抽出対象（適用終了含む）ソート
ORSJGS_ALD_ALL_SORT=${MID_DIR_AC}/CCIFM046001_sort1_EO31N0160J0.csv
# 卸先事業者抽出対象（適用終了含む）ファイル
ORSJGS_ALD_ALL=${MID_DIR_AC}/CCIFM046001_1_EO31N0160J0.csv
# 卸先事業者抽出対象ファイル ソート
ORSJGS_ALD_CURRENT_SORT=${MID_DIR_AC}/CCIFM046001_sort2_EO31N0160J0.csv
# 卸先事業者抽出対象ファイル
ORSJGS_ALD_CURRENT=${MID_DIR_AC}/CCIFM046001_2_EO31N0160J0.csv


#--- データ作成ファイル
# インセンティブ料金計算情報
OUTDEF1=ACIFM303.def
OUTFILE1=${MID_DIR_AC}/ACIFM303001.csv


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


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

#---前月末日を取得
NOW_MONTH_ONEDAY=`date -d "${RSLT_OPEDATE}" +'%Y%m'`01
PREV_MONTH_LASTDAY=`date -d "-1 day ${NOW_MONTH_ONEDAY}" +'%Y%m%d'`
#---前月1日を取得
PREV_MONTH_ONEDAY=`date -d "-1 month ${RSLT_OPEDATE}" +'%Y%m'`01
#---翌月1日を取得
NEXT_MONTH_ONEDAY=`date -d "1 month ${RSLT_OPEDATE}" +'%Y%m'`01

#---請求年月を取得
SEIKY_YM=`echo ${PREV_MONTH_ONEDAY} | cut -c 1-6`


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

P1="OPD=$OPD,"
P2="SVCCTL=JBSbatUnitServiceControl,"
P3="JOB=EO31N0160J0,"
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=,"
#v39.00.00 MOD START
#P18="FREE=${INDEF1};${ORSJGS_ALD_ALL};${ORSJGS_ALD_CURRENT};${INDEF2};${INFILE2};${INDEF3};${INFILE3};${INDEF4};${INFILE4};${OUTDEF1};${OUTFILE1};"
P18="FREE=${INDEF1};${ORSJGS_ALD_ALL};${ORSJGS_ALD_CURRENT};${INDEF2};${INFILE2};${INDEF3};${INFILE3};${INDEF4};${INFILE4};${OUTDEF1};${OUTFILE1};${INDEF5};${INFILE5};${INDEF6};${INFILE6};${INDEF7};${INFILE7};"
#v39.00.00 MOD END
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


#
#--- ファイルの存在チェックを行う
#
#--- 設備卸請求料金情報ファイル
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


#--- インセンティブ料金計算（債権譲渡手数料）
if [ ! -r ${INFILE4} ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${INFILE4}) "
    echo $JOBNAME " File is nonexist(${INFILE4}) "
    exit ${G_RTN_ERROR}
fi

#v39.00.00 ADD START
#--- インセンティブ料金（継続利用契約料金）
if [ ! -r ${INFILE5} ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${INFILE5}) "
    echo $JOBNAME " File is nonexist(${INFILE5}) "
    exit ${G_RTN_ERROR}
fi

#--- インセンティブ料金（年間獲得数料金）
if [ ! -r ${INFILE6} ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${INFILE6}) "
    echo $JOBNAME " File is nonexist(${INFILE6}) "
    exit ${G_RTN_ERROR}
fi

#--- インセンティブ料金（月間獲得数料金）
if [ ! -r ${INFILE7} ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${INFILE7}) "
    echo $JOBNAME " File is nonexist(${INFILE7}) "
    exit ${G_RTN_ERROR}
fi
#v39.00.00 ADD END

#
#--- 卸先事業者共通アンロード（全件）ファイルの複製
#
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
cp -fp ${INFILE1} ${ORSJGS_ALD_CP}



#
#--- 卸先事業者共通アンロード編集１
#    キー項目毎に世代登録年月日時分秒でソート
# 抽出条件
#    卸先事業者適用開始年月日 ≦ 請求年月の月末日
#    卸先事業者適用終了年月日 が最大
# 
bsortex -sort key=0.2asc,1.17asc,4.8asc -record recform=txtcsv \
  -input file=${ORSJGS_ALD_CP} reclen=328 \
   include="3.8asc.le.'${PREV_MONTH_LASTDAY}'"\
  -output file=${ORSJGS_ALD_ALL_SORT} \
  reconst="0.2,1.17,2.242"

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

#
#--- マージ（各キー項目毎のカレントレコードのみを残す）
#
bsortex -merge key=0.2asc -record recform=txtcsv \
        -input file=${ORSJGS_ALD_ALL_SORT} reclen=328 \
        -summary suppress last \
        -output file=${ORSJGS_ALD_ALL} \
        reconst="0.2,2.242"

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



#
#--- 卸先事業者共通アンロード編集２
#    キー項目毎に世代登録年月日時分秒でソート
# 抽出条件
#    卸先事業者適用開始年月日 ≦ 請求年月の月末日
#    卸先事業者適用終了年月日 ≧ 請求年月の月末日
# 
bsortex -sort key=0.2asc,1.17asc -record recform=txtcsv \
  -input file=${ORSJGS_ALD_CP} reclen=328 \
   include="3.8asc.le.'${PREV_MONTH_LASTDAY}',4.8asc.ge.'${PREV_MONTH_LASTDAY}'"\
  -output file=${ORSJGS_ALD_CURRENT_SORT} \
  reconst="0.2,1.17,2.242"

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

#
#--- マージ（各キー項目毎のカレントレコードのみを残す）
#    世代年月日時分秒が最大のレコードを取得する
bsortex -merge key=0.2asc -record recform=txtcsv \
        -input file=${ORSJGS_ALD_CURRENT_SORT} reclen=328 \
        -summary suppress last \
        -output file=${ORSJGS_ALD_CURRENT} \
         reconst="0.2,2.242"

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



#
#---ＡＰＬ起動
#

java ${JAVA_OPTION} -jar ${JAR_DIR}/koptBatch.jar $PARA

rc=$?
ERR_FLG=0
if [ $rc -ne 0 ]
then
   if [ $rc -ne 4 ]
   then
       if [ $rc -ne 8 ]
       then
           if [ $rc -ne 127 ]
           then
              sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " PROGRAM Error($SVC program:rc=$rc) "
              echo $JOBNAME " PROGRAM Error($SVC program:rc=$rc) "
              exit ${G_RTN_ERROR}
           fi
       fi
    fi
    ERR_FLG=1
fi

exit_rc=$rc



# 卸先事業者インセンティブ料金情報 ファイル名
ACLST09201_YYYYMMDDhhmmss=${MID_DIR_AC}/ACLST09201_${RSLT_SYSDATE}.csv

# 卸先事業者インセンティブ料金情報ファイルのヘッダ部を作成する
echo "\"対象年月\",\"${SEIKY_YM}\"" > ${ACLST09201_YYYYMMDDhhmmss}
#v39.00.01 MOD START
##v39.00.00 MOD START
##echo "\"卸先事業者コード\",\"卸先事業社名\",\"サービス名\",\"新規申込件数\",\"新規申込料金\",\"継続利用契約数\",\"継続利用料金\",\"年間獲得件数\",\"年間獲得料金\",\"債権譲渡金額\",\"債権譲渡手数料\"" >> ${ACLST09201_YYYYMMDDhhmmss}
#echo "\"卸先事業者コード\",\"卸先事業者名\",\"サービス名\",\"新規申込件数\",\"新規申込料金\",\"継続利用契約数\",\"継続利用料金\",\"月間獲得件数\",\"月間獲得料金\",\"年間獲得件数\",\"年間獲得料金\",\"債権譲渡金額\",\"債権譲渡手数料\"" >> ${ACLST09201_YYYYMMDDhhmmss}
##v39.00.00 MOD END
echo "\"卸先事業者コード\",\"卸先事業者名\",\"サービス名\",\"新規開通件数\",\"新規販売奨励金（ネット）/販売手数料（電話・テレビ）\",\"継続利用契約数\",\"継続達成販売奨励金\",\"月間開通件数\",\"特別達成販売奨励金(月間)\",\"年間開通件数\",\"特別達成販売奨励金(年間)\",\"債権譲渡金額\",\"債権譲渡手数料\"" >> ${ACLST09201_YYYYMMDDhhmmss}
#v39.00.01 MOD END

# 卸先事業者インセンティブ料金情報ファイルを追記する
cat ${OUTFILE1} >> ${ACLST09201_YYYYMMDDhhmmss}

 nkf -Lw --overwrite ${ACLST09201_YYYYMMDDhhmmss}
 nkf -x -s --overwrite ${ACLST09201_YYYYMMDDhhmmss}

if [ $rc -eq 0 ]
then
#
#---ファイル削除を行う
#
    rm -f ${ORSJGS_ALD_CP}
    rm -f ${ORSJGS_ALD_ALL_SORT}
    rm -f ${ORSJGS_ALD_CURRENT_SORT}
    rm -f ${ORSJGS_ALD_ALL}
    rm -f ${ORSJGS_ALD_CURRENT}
    rm -f ${OUTFILE1}


fi


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

exit ${G_RTN_NORMAL}
