#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：契約管理
#
# シェル名      ：対象サービス契約内訳抽出
#
# 機能          ：サービス契約内訳を基点として、サービス開始年月日を確定するサービスに関するサービス契約より、サービス開始対象のサービス契約/サービス契約内訳情報を抽出する。
#
#
# コマンド形式  ：EO2090120J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v8.00.01        2014/06/17  FJ)古内      TAI-2014-0000019（ＩＯ分散化）
# v20.00.00       2015/11/27  FJ)土井       OM-2015-0003006 ソート削除対応
#
##############################################################

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

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

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

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

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

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

#
#---業務で必要な変数定義
#
#xxx=xxxxxxx
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

#
#--- アンロード関数
#       p1：テーブル名／クエリファイル名
EXEC_UNLOAD()
{
	# 出力ファイルの初期化
	cat /dev/null > $2
	rc=$?
	if [ $rc -ne 0 ]
	then
		sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File cat error($2:rc=$rc) "
		echo $JOBNAME " File cat error($2:rc=$rc) "
		exit ${G_RTN_ERROR}
	fi
	
	# unload(KK_T_CRECARD)
	sh ${G_TOOLSH}/EOKULD02.sh $1 $2
	
	rc=$?
	if [ $rc -ne 0 ]
	then
		sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " unload error($2:rc=$rc) "
		echo $JOBNAME " unload error($2:rc=$rc) "
		exit ${G_RTN_ERROR}
	fi
}

#
#--- クエリ編集
#       p1：ＳＱＬ定義ファイル名
#       p2：バインド変数置換文字
EDIT_ULD_QUERY()
{
	SQL_FILE=$1
	SQL_WORK_FILE=${ULD_WORK_DIR}/${JOBNAME}_QUERY.tmp
	cat /dev/null > ${SQL_WORK_FILE}
	
	# SQL定義ファイルの編集
	if [ ! -r ${SQL_FILE} ]
	then
		sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${SQL_FILE}:rc=$rc) "
		echo $JOBNAME " File is nonexist(${SQL_FILE}:rc=$rc) "
		exit ${G_RTN_ERROR}
	fi

	# バインド変数を置き換える
	cat ${SQL_FILE} > ${SQL_WORK_FILE}
	
	for bind in $2
	do
		sed -i, -e 0,/?/s/?/"'"$bind"'"/ ${SQL_WORK_FILE}
	done
	
	export SQL_WORK_FILE
}

#
#--- クエリ編集
#       p1：ＳＱＬ定義ファイル名
#       p2：バインド変数置換文字
EDIT_MATCHING_QUERY()
{
	MATCHING_FILE=$1
	MATCHING_QUERY_WORK=${ULD_WORK_DIR}/${JOBNAME}_MATCH_QUERY.tmp
	
	cat /dev/null > ${MATCHING_QUERY_WORK}
	
	# SQL定義ファイルの編集
	if [ ! -r ${MATCHING_FILE} ]
	then
		sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist(${MATCHING_FILE}:rc=$rc) "
		echo $JOBNAME " File is nonexist(${MATCHING_FILE}:rc=$rc) "
		exit ${G_RTN_ERROR}
	fi

	# バインド変数を置き換える
	cat ${MATCHING_FILE} > ${MATCHING_QUERY_WORK}
	
	for bind in $2
	do
		bind_escape=`echo $bind | sed "s/\//\\\\\\\\\//g"`
		sed -i, -e 0,/#FILE#/s/#FILE#/$bind_escape/ ${MATCHING_QUERY_WORK}
	done
	
	export MATCHING_QUERY_WORK
}

#
#--- マッチング処理
#      p1：出力ファイルパス
#      p2：マッチングクエリファイルパス
EXEC_MATCHING()
{
	# 出力ファイルの初期化
	OUTFILE=$1
	cat /dev/null > ${OUTFILE}
	rc=$?
	if [ $rc -ne 0 ]
	then
		sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File cat error(${OUTFILE}:rc=$rc) "
		echo $JOBNAME " File cat error(${OUTFILE}:rc=$rc) "
		exit ${G_RTN_ERROR}
	fi

	# マッチング実行
	export ZTLOUTFILE=${OUTFILE}
	${G_TOOLSH}/util/bin/ZTLMAT01 $2
	rc=$?
	if [ $rc -ne 0 ]
	then
		sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " matching error($2:rc=$rc) "
		echo $JOBNAME " matching error($2:rc=$rc) "
		exit ${G_RTN_ERROR}
	fi
}

APL_IN_FILE=${MID_DIR_KK}/KKIFM501001.csv

# +++++++++++++++++++++ v8.00.01 mod start +++++++++++++++++++++
# 前ジョブからの引継ぎファイル（サービス契約カレント）
#KK_U_KK0081_39_CUR_OTF=${MID_DIR_KK}/KK_U_KK0081_39_CUR.csv
KK_U_KK0081_39_CUR_OTF=${LOC_DIR_KK}/KK_U_KK0081_39_CUR.csv
# +++++++++++++++++++++ v8.00.01 mod start +++++++++++++++++++++

# +++++++++++++++++++++ v8.00.01 mod start +++++++++++++++++++++
# 当ジョブのワークファイル
#KK0081_CUR=${MID_DIR_KK}/${JOBNAME}.KK0081_CUR.csv
#KK0161_CUR=${MID_DIR_KK}/${JOBNAME}.KK0161_CUR.csv
#KK0891_CUR=${MID_DIR_KK}/${JOBNAME}.KK0891_CUR.csv
#MATCH_WORK=${MID_DIR_KK}/${JOBNAME}.M_WORK.csv
KK0081_CUR=${TMP_DIR_KK}/${JOBNAME}.KK0081_CUR.csv
KK0161_CUR=${TMP_DIR_KK}/${JOBNAME}.KK0161_CUR.csv
KK0891_CUR=${TMP_DIR_KK}/${JOBNAME}.KK0891_CUR.csv
MATCH_WORK=${TMP_DIR_KK}/${JOBNAME}.M_WORK.csv
# +++++++++++++++++++++ v8.00.01 mod end +++++++++++++++++++++

# サービス契約内訳カレントの取得
KK0161_ULD_QUERY=${SQL_DIR}/KK_U_KK0161_11.sql
KK0891_ULD_QUERY=${SQL_DIR}/KK_U_KK0891_07.sql

# サービス契約内訳のアンロード
EDIT_ULD_QUERY ${KK0161_ULD_QUERY} "${RSLT_OPEDATE}"
EXEC_UNLOAD ${SQL_WORK_FILE} ${KK0161_CUR}

# 提供方式契約のアンロード
EXEC_UNLOAD ${KK0891_ULD_QUERY} ${KK0891_CUR}

# サービス契約のフィルタ
### OM-2015-0003006 2015/11/27 土井 MOD START
#bsortex -sort key="0.10asc" -record recform=txtcsv -input reclen=200 include="1.2asc.eq.'10'" < ${KK_U_KK0081_39_CUR_OTF} > ${KK0081_CUR}
bsortex -copy -record recform=txtcsv -input reclen=200 include="1.2asc.eq.'10'" < ${KK_U_KK0081_39_CUR_OTF} > ${KK0081_CUR}
### OM-2015-0003006 2015/11/27 土井 MOD END

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

# 各種契約のマッチング
EDIT_MATCHING_QUERY ${G_TOOLSH}/util/def/KK_CM_0447.def "${KK0161_CUR} ${KK0081_CUR} ${KK0891_CUR}"
EXEC_MATCHING ${MATCH_WORK} ${MATCHING_QUERY_WORK}

bsortex -sort key="0.10asc,1.12asc" -record recform=txtcsv -input reclen=200 < ${MATCH_WORK} | perl -pe 's/"//g' > ${APL_IN_FILE}

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

#
# ファイルの分割
#  多重で動作させる為に、ファイルを分割する。
#
SEP_CNT=5

# 一時ファイルの削除
for FILE in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM501001_*.csv"`; do
	rm ${FILE}
done

# 一時ファイルの削除
for FILE in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM050001_*.csv"`; do
	rm ${FILE}
done

# 一時ファイルの削除
for FILE in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM039003_*.csv"`; do
	rm ${FILE}
done

FILE_REC_NUM=`cat ${APL_IN_FILE} | wc -l`

if [ ${FILE_REC_NUM} -ne 0 ]
then
	echo "■ 入力ファイル分割実行(全行数：${FILE_REC_NUM})"
	
	# 分割行数：入力ファイル件数(余剰分は削除) / 5 + 入力ファイル件数/5の余剰分
	FILE_SEP_CNT=`expr ${FILE_REC_NUM} / ${SEP_CNT} + ${FILE_REC_NUM} % ${SEP_CNT}`
	
	echo "分割行数：${FILE_SEP_CNT}"
	
	split -l ${FILE_SEP_CNT} ${APL_IN_FILE} ${MID_DIR_KK}/KKIFM501001_
	
	rc=$?
	if [ $rc -ne 0 ]
	then
	    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " split Error($SVC split:rc=$rc) "
	    echo $JOBNAME " split Error($SVC split:rc=$rc) "
	    exit ${G_RTN_ERROR}
	fi
	
	# 分割後のファイル名をリネーム
	CNT=1
	for FILE in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM501001_*"`; do
		mv $FILE ${MID_DIR_KK}/KKIFM501001_0$CNT.csv
		echo "ファイル_0${CNT}："`cat ${MID_DIR_KK}/KKIFM501001_0$CNT.csv | wc -l`
		CNT=`expr $CNT + 1`
	done
else
	# 初期ファイルの生成
	cat /dev/null > ${MID_DIR_KK}/KKIFM501001_01.csv
fi

sh ${G_TOOLSH}/EOK010210J0.sh CS00027I $JOBNAME

CNT=1
for filename in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM501001_*.csv"  | sort`; do
	
	ARRAY_FILES[$CNT]=$filename
	
	#
	#---パラメタ定義
	#
	P1="OPD=$RSLT_OPEDATE,"
	P2="SVCCTL=JBSbatMultiServiceControl,"
	P3="JOB=EO2090120J0,"
	P4="IND1=KKIFM501.def,"
	P5="INF1=${filename},"
	P6="IND2=,"
	P7="INF2=,"
	P8="OTD1=KKIFM050.def,"
	P9="OTF1=${MID_DIR_KK}/KKIFM050001_0$CNT.csv,"
	P10="OTD2=KKIFM039.def,"
	P11="OTF2=${MID_DIR_KK}/KKIFM039003_0$CNT.csv,"
	P12="TABLENAME=,"
	P13="SQLKEY=,"
	P14="SQLPARAM=,"
	P15="ERRFILE=,"
	P16="RECOVERY=,"
	P17="BREAKPTN=,"
	P18="FREE=${MID_DIR_KK}/;KKIFM569006_01.csv"
	PARA="$P1$P2$P3$P4$P5$P6$P7$P8$P9$P10$P11$P12$P13$P14$P15$P16$P17$P18"

	#
	#---ＡＰＬ起動
	#
	java ${JAVA_OPTION} -jar ${JAR_DIR}/koptBatch.jar $PARA &
	
	PID=$!
	ARRAY_PID[$CNT]=$PID
	
	echo "処理対象ファイル：$filename @$PID"
	
	CNT=`expr $CNT + 1`
done

# 処理終了監視
RESULT=0
for PID in "${ARRAY_PID[@]}"; do
	
	wait $PID
	
	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
	
	echo "PID($PID) => エラーコード：$rc"
	
	# 処理結果の設定（処理結果コードの最大を残す）
	if [ ${RESULT} -lt $rc ]
	then
		RESULT=$rc
	fi
done 

exit_rc=${RESULT}

# 処理結果をマージする
cat /dev/null > ${MID_DIR_KK}/KKIFM050001.csv
for filename in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM050001_*.csv"  | sort`; do
	cat ${filename} >> ${MID_DIR_KK}/KKIFM050001.csv
	rm ${filename}
done

# 処理結果をマージする
cat /dev/null > ${MID_DIR_KK}/KKIFM039003.csv
for filename in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM039003_*.csv"  | sort`; do
	cat ${filename} >> ${MID_DIR_KK}/KKIFM039003.csv
	rm ${filename}
done

#
#---機器オプションサービス契約（ＶＡ）抽出ファイルをマージする
#
if [ -e ${MID_DIR_KK}/KKIFM569006_01.csv ]
then
    cat ${MID_DIR_KK}/KKIFM569006_01.csv >> ${MID_DIR_KK}/KKIFM569006.csv
    rm -f ${MID_DIR_KK}/KKIFM569006_01.csv
fi

rm -f ${KK0081_CUR}
rm -f ${KK0161_CUR}
rm -f ${KK0891_CUR}
rm -f ${MATCH_WORK}

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

exit $exit_rc
