#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：契約管理
#
# シェル名      ：対象割引サービス対象契約抽出
#
# 機能          ：「割引サービス契約」の「割引サービス契約番号」に紐付く「割引サービス対象契約」および「割引サービスコード」に紐付く「割引サービス」を抽出する。紹介者であれば、被紹介者の「割引サービス対象契約」も抽出する。
#
# コマンド形式  ：EO2090920J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
#
##############################################################

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

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

# ******************** 分割起動の準備 ********************

MATCH_OUT_FILE=${MID_DIR_KK}/KKIFM068001.csv


# ダミー処理
# cp ${MID_DIR_KK}/KKIFM068001.csv.work ${MATCH_OUT_FILE}

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

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

FILE_REC_NUM=`cat ${MATCH_OUT_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} ${MATCH_OUT_FILE} ${MID_DIR_KK}/KKIFM068001_
	
	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 "KKIFM068001_*"`; do
		mv $FILE ${MID_DIR_KK}/KKIFM068001_0$CNT.csv
		echo "ファイル_0${CNT}："`cat ${MID_DIR_KK}/KKIFM068001_0$CNT.csv | wc -l`
		CNT=`expr $CNT + 1`
	done
else
	# 初期ファイルの生成
	cat /dev/null > ${MID_DIR_KK}/KKIFM068001_01.csv
fi

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

CNT=1
for filename in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM068001_*.csv"  | sort`; do
	
	ARRAY_FILES[$CNT]=$filename
	
	#
	#---パラメタ定義
	#
	P1="OPD=$OPD,"
	P2="SVCCTL=JBSbatMultiServiceControl,"
	P3="JOB=EO2090920J0,"
	P4="IND1=KKIFM068.def,"
	P5="INF1=${filename},"
	P6="IND2=,"
	P7="INF2=,"
	P8="OTD1=KKIFM068.def,"
	P9="OTF1=${MID_DIR_KK}/KKIFM068002_$CNT.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"

	#
	#---ＡＰＬ起動
	#
	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}

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

# エラーが発生した場合は、以下の処理は行わない
if [ $exit_rc -ne 127 ]
then

	#
	# **** ファイルマージ ****
	#

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

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

exit $exit_rc
