/*******************************************************************************
*	 All Rights reserved,Copyright (c) K-Opticom 
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JSYejbKK0491ETDA
*	ソースファイル名：JSYejbKK0491ETDA.java
*	作成者			：EK919112
*	日付			：2015年09月18日
*＜機能概要＞
*	請求契約 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
 * execIKK0491C001
 * execIKK0491C002
 * execIKK0491D001
 * execIKK0491D002
 * execIKK0491D003
 * execIKK0491D004
 * execIKK0491D005
 * execIKK0491D006
 * execIKK0491D007
 * execIKK0491D008
 * 
 */
public class JSYejbKK0491ETDA implements ETMsgDBAccessHandler {

	/**
	 * コンストラクタ
	 */
	public JSYejbKK0491ETDA() {
	}

	/**
	 * 請求契約ETMsgDBアクセス部品のメイン処理です。
	 * ETMsgの振舞IDに従い、項目値設定後、LogicalEntityを呼出します。
	 * @param  inETMsg 処理を行うETMsg
	 * @exception CAANRuntimeException 例外発生時にthrowします。
	 */
	public void invoke(CAANMsg inETMsg, AgentDispatchContext inContext) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.invoke");

		// ETMsgチェック
		// 処理対象のETMsgでなければ処理をぬけます。
		if (inETMsg.equalsSchemaClass(KK0491ETMsg.class) == false) {
			return;
		}

		// 振舞ID
		String eventID;

		// 振舞ID取り出し
		eventID = inETMsg.getString(KK0491ETMsg.EVENTID);

		// イベントの振り分け
		if(eventID.equals(EventIDList.IKK0491C001)){
			// 請求契約予約結果反映振舞内部
			execIKK0491C001(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491C002)){
			// 請求契約予約取消振舞内部
			execIKK0491C002(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491D001)){
			// 請求契約登録振舞内部
			execIKK0491D001(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491D002)){
			// クレジット有効性NG登録振舞内部
			execIKK0491D002(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491D003)){
			// 請求契約内容変更振舞内部
			execIKK0491D003(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491D004)){
			// 請求支払先変更振舞内部
			execIKK0491D004(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491D005)){
			// 請求契約解約振舞内部
			execIKK0491D005(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491D006)){
			// 請求契約登録（予約情報入力）振舞内部
			execIKK0491D006(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491D007)){
			// 請求契約お客様変更振舞内部
			execIKK0491D007(inETMsg);
		}
		else if(eventID.equals(EventIDList.IKK0491D008)){
			// 支払方法通知メール制御コード変更振舞内部
			execIKK0491D008(inETMsg);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.invoke");

	}

	/**
	 * 請求契約予約結果反映振舞内部<IKK0491C001>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491C001(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491C001");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491C001");

	}
	/**
	 * 請求契約予約取消振舞内部<IKK0491C002>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491C002(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491C002");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.update(inETMsg);

		}catch(CAANFinderException cfe){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.UPDATE_DB_ERR);
			throw new CAANRuntimeException(cfe);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491C002");

	}
	/**
	 * 請求契約登録振舞内部<IKK0491D001>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491D001(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491D001");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(KK0491ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491D001");

	}
	/**
	 * クレジット有効性NG登録振舞内部<IKK0491D002>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491D002(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491D002");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(KK0491ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491D002");

	}
	/**
	 * 請求契約内容変更振舞内部<IKK0491D003>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491D003(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491D003");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(KK0491ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491D003");

	}
	/**
	 * 請求支払先変更振舞内部<IKK0491D004>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491D004(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491D004");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(KK0491ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491D004");

	}
	/**
	 * 請求契約解約振舞内部<IKK0491D005>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491D005(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491D005");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(KK0491ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491D005");

	}
	/**
	 * 請求契約登録（予約情報入力）振舞内部<IKK0491D006>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491D006(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491D006");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(KK0491ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491D006");

	}
	/**
	 * 請求契約お客様変更振舞内部<IKK0491D007>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491D007(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491D007");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(KK0491ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491D007");

	}
	/**
	 * 支払方法通知メール制御コード変更振舞内部<IKK0491D008>です。
	 * @param inETMsg 処理を行うETMsg
	 */
	private void execIKK0491D008(CAANMsg inETMsg) {

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "call:JSYejbKK0491ETDA.IKK0491D008");

		// 項目値設定
		// 現在日時
		String nowTimestamp = inETMsg.getString(KK0491ETMsg.OPERATEDATETIME);

		// 登録日時
		inETMsg.set(KK0491ETMsg.ADD_DTM, nowTimestamp);

		// 更新日時
		inETMsg.set(KK0491ETMsg.UPD_DTM, nowTimestamp);

		// LogicalEntity呼び出し
		KK0491LE le = new KK0491LE();

		try{
			le.create(inETMsg);

		}catch(CAANCreateException cce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.CREATE_DB_ERR);
			throw new CAANRuntimeException(cce);
		}catch(CAANException ce){
			inETMsg.set(KK0491ETMsg.STATUS, StatusCodes.FATAL_ERR);
			throw new CAANRuntimeException(ce);
		}

		// ログ出力
		JSYejbLog.println(JSYejbLog.DEBUG, this.getClass(), "end:JSYejbKK0491ETDA.IKK0491D008");

	}

}
