From 20c53e0d85dd6ae1cb3628a745e28af1f0ef1a2b Mon Sep 17 00:00:00 2001 From: Roland Haeder 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 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