From 20c53e0d85dd6ae1cb3628a745e28af1f0ef1a2b Mon Sep 17 00:00:00 2001
From: Roland Haeder <roland@mxchange.org>
Date: Mon, 15 Feb 2016 23:07:10 +0100
Subject: [PATCH] Also here the logger and bean must be look up because no
 @Inject or @EJB is working here

---
 .../addressbook/AddressbookIdValidator.java   | 54 +++++++++++++------
 1 file changed, 37 insertions(+), 17 deletions(-)

diff --git a/src/org/mxchange/addressbook/validator/addressbook/AddressbookIdValidator.java b/src/org/mxchange/addressbook/validator/addressbook/AddressbookIdValidator.java
index 6d363bc..daccc42 100644
--- a/src/org/mxchange/addressbook/validator/addressbook/AddressbookIdValidator.java
+++ b/src/org/mxchange/addressbook/validator/addressbook/AddressbookIdValidator.java
@@ -17,21 +17,20 @@
 package org.mxchange.addressbook.validator.addressbook;
 
 import java.text.MessageFormat;
-import javax.ejb.EJB;
-import javax.enterprise.event.Event;
-import javax.enterprise.inject.Any;
 import javax.faces.application.FacesMessage;
 import javax.faces.component.UIComponent;
 import javax.faces.context.FacesContext;
 import javax.faces.validator.FacesValidator;
 import javax.faces.validator.ValidatorException;
-import javax.inject.Inject;
-import org.mxchange.addressbook.events.addressbook.AddressbookLoadedEvent;
-import org.mxchange.addressbook.events.addressbook.LoadedAddressbookEvent;
+import javax.naming.Context;
+import javax.naming.InitialContext;
+import javax.naming.NamingException;
 import org.mxchange.addressbook.exceptions.AddressbookNotFoundException;
 import org.mxchange.addressbook.model.addressbook.Addressbook;
 import org.mxchange.addressbook.model.addressbook.AddressbookSessionBeanRemote;
 import org.mxchange.jcoreee.validator.number.BaseLongValidator;
+import org.mxchange.jcoreeelogger.beans.local.logger.Log;
+import org.mxchange.jcoreeelogger.beans.local.logger.LoggerBeanLocal;
 
 /**
  * A validator for address book id verification
@@ -49,20 +48,18 @@ public class AddressbookIdValidator extends BaseLongValidator {
 	/**
 	 * Remote bean
 	 */
-	@EJB (mappedName = "ejb/stateless-addressbook")
 	private AddressbookSessionBeanRemote addressbookBean;
 
 	/**
-	 * An event for loading address book data loading
+	 * Logger instance
 	 */
-	@Inject
-	@Any
-	private Event<AddressbookLoadedEvent> loadedEvent;
+	@Log
+	private LoggerBeanLocal loggerBeanLocal;
 
 	@Override
 	public void validate (final FacesContext context, final UIComponent component, final Object value) throws ValidatorException {
 		// Trace message
-		//this.getLogger().logTrace(MessageFormat.format("validate: context={0},component={1},value={2} - CALLED!", context, component, value)); //NOI18N
+		this.loggerBeanLocal.logTrace(MessageFormat.format("validate: context={0},component={1},value={2} - CALLED!", context, component, value)); //NOI18N
 
 		// All accepted, required fields
 		String[] requiredFileds = {"addressbookId"}; //NOI18N
@@ -86,15 +83,38 @@ public class AddressbookIdValidator extends BaseLongValidator {
 		try {
 			// Get full data
 			addressbook = this.addressbookBean.getAddressbookById(addressbookId);
+
+			// Is it set?
+			if (addressbook == null) {
+				// Is null?!
+				throw new NullPointerException(MessageFormat.format("addressbook for id={0} is null", addressbookId)); //NOI18N
+			}
 		} catch (final AddressbookNotFoundException ex) {
 			// Continue to throw
-			throw new ValidatorException(new FacesMessage(MessageFormat.format("Cannot find address book with id {0}", addressbookId)), ex);
+			throw new ValidatorException(new FacesMessage(MessageFormat.format("Cannot find address book with id {0}", addressbookId)), ex); //NOI18N
 		}
 
-		// Fire event
-		this.loadedEvent.fire(new LoadedAddressbookEvent(addressbook));
-
 		// Trace message
-		//this.getLogger().logTrace("validate: EXIT!"); //NOI18N
+		this.loggerBeanLocal.logTrace("validate: EXIT!"); //NOI18N
+	}
+
+	/**
+	 * Public consutructor
+	 */
+	public AddressbookIdValidator () {
+		// Try to get it
+		try {
+			// Get initial context
+			Context context = new InitialContext();
+
+			// Lookup logger
+			this.loggerBeanLocal = (LoggerBeanLocal) context.lookup("java:global/jcore-logger-ejb/logger!org.mxchange.jcoreeelogger.beans.local.logger.LoggerBeanLocal"); //NOI18N
+
+			// ... and user controller
+			this.addressbookBean = (AddressbookSessionBeanRemote) context.lookup("java:global/addressbook-ejb/addressbook!org.mxchange.addressbook.model.addressbook.AddressbookSessionBeanRemote"); //NOI18N
+		} catch (final NamingException ex) {
+			// Continue to throw it
+			throw new RuntimeException("context.lookup() failed.", ex); //NOI18N
+		}
 	}
 }
-- 
2.39.5