#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：ＥＭ利用料金情報抽出（事業者間）
#
# 機能          ：ｅｏモバイル合計テーブルと課金対象従量サービス契約蓄積テーブルからデータを取得し、ＥＭ事業者間精算帳票作成用にＥＭ課金利用料金情報（事業者間）を作成する。
#
# コマンド形式  ：EO30S0323J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v6.00.00        2014/01/18  FJ) 狭間     【OM-2013-0005343】新規作成
# v8.00.00        2014/03/24  FJ) 後藤     【OM-2014-0001052】マッチングキー変更
#
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

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

#---ワークファイル削除モード
WK_RM=true

#---運用日付取得
if [ "${OPD}" = "" ]; then
   . EOK010310J0.sh "BDATE"
else
   RSLT_OPEDATE="${OPD}"
fi
TOGETU_YM=`expr ${RSLT_OPEDATE} / 100`
TARGET_DATE=${TOGETU_YM}01

#---前月取得
SEIKY_YM2=$(date +%Y%m --date "${TARGET_DATE} 1 month ago")

#- イベントコード（利用終了日）
EVENT_CD_USE_ENDYMD="02"

#- 前月末日取得
. EO3EVENTYMD.sh ${EVENT_CD_USE_ENDYMD} ${SEIKY_YM2} ${JOBNAME}
SEIKY_YM2_END_YMD=${EVENT_YMD}

#---マッチング処理でLeftjoinがNULL時に"を付けなくする（マッチング使用時は必須）
export ZTLQUOTES=''

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

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

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


#
#--- ファイル定義
#

# 入力ファイル
IN_FILE_01=${MID_DIR_AC}/ACIFM170004.csv
IN_FILE_01_WK1=${MID_DIR_AC}/${JOBNAME}_ACIFM170004_WK_1.csv

# eモバイル合計アンロード定義ファイル
UL_AC_U_AC0371_01_DEF=${SQL_DIR}/AC_U_AC0371_01.sql
UL_AC_U_AC0371_01_DEF_WK1=${SQL_DIR}/${JOBNAME}_AC_U_AC0371_01_UNLOADER_WK_1.sql

# eモバイル合計アンロードファイル
UL_AC_U_AC0371_01_CSV_WK1=${MID_DIR_AC}/${JOBNAME}_AC_U_AC0371_01_UNLOAD_WK_1.csv

# マッチング定義ファイル（ＥＭ利用料金情報抽出（事業者間））
MC_AC_CM_0084_DEF=${G_TOOLSH}/util/def/AC_CM_0084.def
MC_AC_CM_0084_DEF_WK1=${G_TOOLSH}/util/def/${JOBNAME}_AC_CM_0084_MATCHING_WK_1.def

# マッチングファイル（ＥＭ利用料金情報抽出（事業者間））
MC_AC_CM_0084_CSV_WK1=${MID_DIR_AC}/${JOBNAME}_AC_CM_0084_MATCHING_WK_1.csv

# 出力ファイル
OUT_FILE_01=${MID_DIR_AC}/ACIFM084049.csv

#
#--- 各ファイルの存在チェックを行う
#
if [ ! -r ${IN_FILE_01} ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${IN_FILE_01}) "
    echo $JOBNAME " File is nonexist(${IN_FILE_01}) "
    exit ${G_RTN_ERROR}
fi
if [ ! -r ${UL_AC_U_AC0371_01_DEF} ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${UL_AC_U_AC0371_01_DEF}) "
    echo $JOBNAME " File is nonexist(${UL_AC_U_AC0371_01_DEF}) "
    exit ${G_RTN_ERROR}
fi
if [ ! -r ${MC_AC_CM_0084_DEF} ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${MC_AC_CM_0084_DEF}) "
    echo $JOBNAME " File is nonexist(${MC_AC_CM_0084_DEF}) "
    exit ${G_RTN_ERROR}
fi

#
#--- SQLバインド変数マッピング
#

#- eモバイル合計
cp -f ${UL_AC_U_AC0371_01_DEF}                  ${UL_AC_U_AC0371_01_DEF_WK1}
sed -i -e "s/:SEIKY_YM/'${SEIKY_YM2}'/"         ${UL_AC_U_AC0371_01_DEF_WK1} 
sed -i -e "s/:OPE_DATE/'${SEIKY_YM2_END_YMD}'/" ${UL_AC_U_AC0371_01_DEF_WK1} 

#-------------------------------------------------------------------------------
#--- 入力ファイル編集
#- サービス契約番号のみに編集しサマリする。ついでに改行コード変換（CRLF→LF）も行う。
#-------------------------------------------------------------------------------
bsortex \
  -sort key="3.10asca" \
  -record recform=txtcsv \
  -input reclen=400 file=${IN_FILE_01} \
  -summary suppress first \
  -output file=${IN_FILE_01_WK1} linedlmt=lf \
   reconst="3.10"
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " bsortex Error(${OUTFILE}.csv:rc=$rc) "
    echo $JOBNAME " bsortex Error(${OUTFILE}.csv:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#-------------------------------------------------------------------------------
#--- UNLOAD処理
#-------------------------------------------------------------------------------

#- eモバイル合計
sh ${G_TOOLSH}/EOKULD03.sh ${UL_AC_U_AC0371_01_DEF_WK1} ${UL_AC_U_AC0371_01_CSV_WK1}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " UNLOAD Error($SVC ${UL_AC_U_AC0371_01_DEF_WK1}:rc=$rc) "
    echo $JOBNAME " UNLOAD Error($SVC ${UL_AC_U_AC0371_01_DEF_WK1}:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#-------------------------------------------------------------------------------
#--- AC_U_AC0391_01とeモバイル合計をマッチングして絞り込む
#-------------------------------------------------------------------------------

#- マッチング定義更新
cp -f ${MC_AC_CM_0084_DEF}                                  ${MC_AC_CM_0084_DEF_WK1}
sed -i -e "s%:AC_U_AC0371_01%${UL_AC_U_AC0371_01_CSV_WK1}%" ${MC_AC_CM_0084_DEF_WK1}
sed -i -e "s%:ACIFM170%${IN_FILE_01_WK1}%"                  ${MC_AC_CM_0084_DEF_WK1}

#
#- マッチング
#
ZTLOUTFILE=${MC_AC_CM_0084_CSV_WK1}
export ZTLOUTFILE
${G_TOOLSH}/util/bin/ZTLMAT01 ${MC_AC_CM_0084_DEF_WK1}
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " Matching_AC_CM_0084 Error($SVC matching_AC_CM_0084:rc=$rc) "
    echo $JOBNAME " Matching_AC_CM_0084 Error($SVC matching_AC_CM_0084:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#-------------------------------------------------------------------------------
#--- 出力ファイル改行コード変換（LF→CRLF）
#-------------------------------------------------------------------------------
bsortex \
  -copy \
  -record recform=txtcsv \
  -input reclen=400 file=${MC_AC_CM_0084_CSV_WK1} \
  -output file=${OUT_FILE_01} linedlmt=crlf \
   reconst="0.END,EMPTY"
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " bsortex Error(${OUT_FILE_01}.csv:rc=$rc) "
    echo $JOBNAME " bsortex Error(${OUT_FILE_01}.csv:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#ワーク削除
if [ $WK_RM = "true" ]
then
    rm -f ${IN_FILE_01_WK1}
    rm -f ${UL_AC_U_AC0371_01_DEF_WK1}
    rm -f ${UL_AC_U_AC0371_01_CSV_WK1}
    rm -f ${MC_AC_CM_0084_DEF_WK1}
    rm -f ${MC_AC_CM_0084_CSV_WK1}
fi

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

exit ${G_RTN_NORMAL}
