/*******************************************************************************
*	 All Rights reserved,Copyright (c) K-Opticom 
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JSYejbZM0111ETDA
*	ソースファイル名：JSYejbZM0111ETDA.java
*	作成者			：EK909396
*	日付			：2012年02月02日
*＜機能概要＞
*	エイジング ETMsgDBアクセス部品
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	ｖ1.00.00
*
********************************************************************************/

package eo.ejb.cbm.entity;

import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.base.CAANException;
import com.fujitsu.futurity.model.base.CAANCreateException;
import com.fujitsu.futurity.model.base.CAANFinderException;
import com.fujitsu.futurity.model.base.CAANRemoveException;
import com.fujitsu.futurity.model.base.CAANRuntimeException;
import com.fujitsu.futurity.model.ejb.common.StatusCodes;
import com.fujitsu.futurity.model.ejb.common.JSYejbLog;
import com.fujitsu.futurity.model.ejb.common.fw.AgentDispatchContext;
import com.fujitsu.futurity.model.ejb.common.fw.ETMsgDBAccessHandler;
import eo.ejb.common.EventIDList;

/**
 * エイジングETMsgDBアクセス部品です。
 * ＜メソッド一覧＞
 * invoke
 * execIZM0111C001
 * execIZM0111C002
 * execIZM0111C003
 * execIZM0111C005
 * execIZM0111C006
 * execIZM0111C007
 * execIZM0111D001
 * execIZM0111D002
 * execIZM0111E002
 * execIZM0111E003
 * 
 */
public class JSYejbZM0111ETDA implements ETMsgDBAccessHandler {

	/* ++++++++++ v1.0.0 追加開始 ++++++++++ */
	
	/** エラーメッセージ"MSG0010" */
	public static final String MSG00110 = "MSG00110";
	
	/** エラーコード"EA" */
	public static final String ERR_CD_EA = "EA";
	
	/* ++++++++++ v1.0.0 追加終了 ++++++++++ */
	
	/**
	 * コンストラクタ
	 */
	public JSYejbZM0111ETDA() {
	}

	/**
	 * エイジングETMsgDBアクセス部品のメイン処理です。
	 * ETMsgの振舞IDに従い、項目値設定後、LogicalEntityを呼出します。
	 * @param  inETMsg 処理を行うETMsg
	 * @exception CAANRuntimeException 例外発生時にthrowします。
	 */
	public void invoke(CAANMsg inETMsg, AgentDispatchContext inContext) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.invoke");

		// ETMsgチェック
		// 処理対象のETMsgでなければ処理をぬけます。
		if (inETMsg.equalsSchemaClass(ZM0111ETMsg.class) == false) {
			return;
		}

		// 振舞ID
		String eventID;

		// 振舞ID取り出し
		eventID = inETMsg.getString(ZM0111ETMsg.EVENTID);

		// イベントの振り分け
		if(eventID.equals(EventIDList.IZM0111C001)){
			// エイジング対象使用終了振舞内部
			execIZM0111C001(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111C002)){
			// エイジング対象回復振舞内部
			execIZM0111C002(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111C003)){
			// 回復可能期間終了振舞内部
			execIZM0111C003(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111C005)){
			// エイジング対象使用終了(外部)振舞内部
			execIZM0111C005(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111C006)){
			// エイジング対象回復(外部)振舞内部
			execIZM0111C006(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111C007)){
			// 回復可能期間終了(外部)振舞内部
			execIZM0111C007(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111D001)){
			// エイジング対象登録振舞内部
			execIZM0111D001(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111D002)){
			// エイジング対象登録(外部)振舞内部
			execIZM0111D002(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111E002)){
			// エイジング削除振舞内部
			execIZM0111E002(inETMsg);
		}
		else if(eventID.equals(EventIDList.IZM0111E003)){
			// エイジング削除(外部)振舞内部
			execIZM0111E003(inETMsg);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.invoke");

	}

	/**
	 * エイジング対象使用終了振舞内部<IZM0111C001>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111C001(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111C001");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(ZM0111ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(ZM0111ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111C001");

	}
	/**
	 * エイジング対象回復振舞内部<IZM0111C002>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111C002(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111C002");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(ZM0111ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(ZM0111ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111C002");

	}
	/**
	 * 回復可能期間終了振舞内部<IZM0111C003>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111C003(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111C003");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(ZM0111ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(ZM0111ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111C003");

	}
	/**
	 * エイジング対象使用終了(外部)振舞内部<IZM0111C005>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111C005(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111C005");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(ZM0111ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(ZM0111ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111C005");

	}
	/**
	 * エイジング対象回復(外部)振舞内部<IZM0111C006>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111C006(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111C006");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(ZM0111ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(ZM0111ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111C006");

	}
	/**
	 * 回復可能期間終了(外部)振舞内部<IZM0111C007>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111C007(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111C007");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(ZM0111ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(ZM0111ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111C007");

	}
	/**
	 * エイジング対象登録振舞内部<IZM0111D001>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111D001(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111D001");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(ZM0111ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(ZM0111ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(ZM0111ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			
			/* ++++++++++ v1.0.0 追加開始 ++++++++++ */
			
			// 排他制御
			String errorResult = cce.getResult();
			
			if(MSG00110.equals(errorResult))
			{
				inETMsg.set(ZM0111ETMsg.AGING_TG_VALUE_ERR, ERR_CD_EA);
				inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.RELATION_ERR);
			}
			else
			{
				inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
				throw new CAANRuntimeException(cce);
			}
			
			/* ++++++++++ v1.0.0 追加終了 ++++++++++ */
			
		}catch(CAANException ce){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111D001");

	}
	/**
	 * エイジング対象登録(外部)振舞内部<IZM0111D002>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111D002(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111D002");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(ZM0111ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(ZM0111ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(ZM0111ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			
			/* ++++++++++ v1.0.0 追加開始 ++++++++++ */
			
			// 排他制御
			String errorResult = cce.getResult();
			
			if(MSG00110.equals(errorResult)) 
			{
				inETMsg.set(ZM0111ETMsg.AGING_TG_VALUE_ERR, ERR_CD_EA);
				inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.RELATION_ERR);
			}
			else
			{
				inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
				throw new CAANRuntimeException(cce);	
			}
			
			/* ++++++++++ v1.0.0 追加終了 ++++++++++ */
			
		}catch(CAANException ce){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111D002");

	}
	/**
	 * エイジング削除振舞内部<IZM0111E002>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111E002(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111E002");
		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.remove(inETMsg);

		}catch(CAANRemoveException cre){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.REMOVE_DB_ERR);
			throw new CAANRuntimeException(cre);
		}catch(CAANException e){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(e);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111E002");

	}
	/**
	 * エイジング削除(外部)振舞内部<IZM0111E003>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIZM0111E003(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbZM0111ETDA.IZM0111E003");
		// LogicalEntity呼び出し
		ZM0111LE le = new ZM0111LE();

		try{
			le.remove(inETMsg);

		}catch(CAANRemoveException cre){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.REMOVE_DB_ERR);
			throw new CAANRuntimeException(cre);
		}catch(CAANException e){
			inETMsg.set(ZM0111ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(e);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbZM0111ETDA.IZM0111E003");

	}

}
