/*******************************************************************************
*	 All Rights reserved,Copyright (c) K-Opticom 
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JSYejbCR0011ETDA
*	ソースファイル名：JSYejbCR0011ETDA.java
*	作成者			：EK907066
*	日付			：2021年08月24日
*＜機能概要＞
*	対応記録 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.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
 * execICR0011C001
 * execICR0011C003
 * execICR0011C004
 * execICR0011C005
 * execICR0011C006
 * execICR0011C007
 * execICR0011C009
 * execICR0011C010
 * execICR0011C011
 * execICR0011C012
 * execICR0011C013
 * execICR0011C014
 * execICR0011C015
 * execICR0011C016
 * execICR0011D003
 * 
 */
public class JSYejbCR0011ETDA implements ETMsgDBAccessHandler {

	/**
	 * コンストラクタ
	 */
	public JSYejbCR0011ETDA() {
	}

	/**
	 * 対応記録ETMsgDBアクセス部品のメイン処理です。
	 * ETMsgの振舞IDに従い、項目値設定後、LogicalEntityを呼出します。
	 * @param  inETMsg 処理を行うETMsg
	 * @exception CAANRuntimeException 例外発生時にthrowします。
	 */
	public void invoke(CAANMsg inETMsg, AgentDispatchContext inContext) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.invoke");

		// ETMsgチェック
		// 処理対象のETMsgでなければ処理をぬけます。
		if (inETMsg.equalsSchemaClass(CR0011ETMsg.class) == false) {
			return;
		}

		// 振舞ID
		String eventID;

		// 振舞ID取り出し
		eventID = inETMsg.getString(CR0011ETMsg.EVENTID);

		// イベントの振り分け
		if(eventID.equals(EventIDList.ICR0011C001)){
			// 対応記録キャンセル振舞内部
			execICR0011C001(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C003)){
			// 対応記録エスカレーションアクセプト振舞内部
			execICR0011C003(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C004)){
			// 対応記録内容変更振舞内部
			execICR0011C004(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C005)){
			// 対応記録エスカレーション開始(キューBOX)振舞内部
			execICR0011C005(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C006)){
			// 対応記録エスカレーション開始（ユーザー）振舞内部
			execICR0011C006(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C007)){
			// 対応記録エスカレーションリジェクト振舞内部
			execICR0011C007(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C009)){
			// 対応記録キャンセル再開振舞内部
			execICR0011C009(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C010)){
			// 対応記録クローズ振舞内部
			execICR0011C010(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C011)){
			// 対応記録強制取得振舞内部
			execICR0011C011(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C012)){
			// 対応記録クローズ再開振舞内部
			execICR0011C012(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C013)){
			// 対応記録簡易メモ変更振舞内部
			execICR0011C013(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C014)){
			// 対応記録問合せ客紐付振舞内部
			execICR0011C014(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C015)){
			// 対応記録変更(資料送付指示)振舞内部
			execICR0011C015(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011C016)){
			// 対応記録変更(SMS配信結果)
			execICR0011C016(inETMsg);
		}
		else if(eventID.equals(EventIDList.ICR0011D003)){
			// 対応記録登録振舞内部
			execICR0011D003(inETMsg);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.invoke");

	}

	/**
	 * 対応記録キャンセル振舞内部<ICR0011C001>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C001(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C001");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C001");

	}
	/**
	 * 対応記録エスカレーションアクセプト振舞内部<ICR0011C003>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C003(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C003");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C003");

	}
	/**
	 * 対応記録内容変更振舞内部<ICR0011C004>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C004(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C004");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C004");

	}
	/**
	 * 対応記録エスカレーション開始(キューBOX)振舞内部<ICR0011C005>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C005(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C005");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C005");

	}
	/**
	 * 対応記録エスカレーション開始（ユーザー）振舞内部<ICR0011C006>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C006(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C006");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C006");

	}
	/**
	 * 対応記録エスカレーションリジェクト振舞内部<ICR0011C007>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C007(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C007");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C007");

	}
	/**
	 * 対応記録キャンセル再開振舞内部<ICR0011C009>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C009(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C009");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C009");

	}
	/**
	 * 対応記録クローズ振舞内部<ICR0011C010>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C010(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C010");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C010");

	}
	/**
	 * 対応記録強制取得振舞内部<ICR0011C011>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C011(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C011");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C011");

	}
	/**
	 * 対応記録クローズ再開振舞内部<ICR0011C012>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C012(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C012");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C012");

	}
	/**
	 * 対応記録簡易メモ変更振舞内部<ICR0011C013>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C013(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C013");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C013");

	}
	/**
	 * 対応記録問合せ客紐付振舞内部<ICR0011C014>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C014(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C014");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C014");

	}
	/**
	 * 対応記録変更(資料送付指示)振舞内部<ICR0011C015>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C015(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C015");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C015");

	}
	/**
	 * 対応記録変更(SMS配信結果)<ICR0011C016>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011C016(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011C016");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011C016");

	}
	/**
	 * 対応記録登録振舞内部<ICR0011D003>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execICR0011D003(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbCR0011ETDA.ICR0011D003");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(CR0011ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(CR0011ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(CR0011ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		CR0011LE le = new CR0011LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(CR0011ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbCR0011ETDA.ICR0011D003");

	}

}
