All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.caucho.config.j2ee.EjbHandler Maven / Gradle / Ivy

/*
 * Copyright (c) 1998-2018 Caucho Technology -- all rights reserved
 *
 * This file is part of Resin(R) Open Source
 *
 * Each copy or derived work must preserve the copyright notice and this
 * notice unmodified.
 *
 * Resin Open Source is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Resin Open Source is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
 * of NON-INFRINGEMENT.  See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Resin Open Source; if not, write to the
 *
 *   Free Software Foundation, Inc.
 *   59 Temple Place, Suite 330
 *   Boston, MA 02111-1307  USA
 *
 * @author Scott Ferguson
 */

package com.caucho.config.j2ee;

import java.lang.reflect.Field;
import java.lang.reflect.Method;

import javax.ejb.EJB;
import javax.ejb.EJBs;
import javax.enterprise.inject.spi.AnnotatedField;
import javax.enterprise.inject.spi.AnnotatedMethod;
import javax.enterprise.inject.spi.AnnotatedType;
import javax.enterprise.inject.spi.Bean;

import com.caucho.config.ConfigException;
import com.caucho.config.inject.InjectManager;
import com.caucho.config.program.BeanValueGenerator;
import com.caucho.config.program.ConfigProgram;
import com.caucho.config.program.FieldGeneratorProgram;
import com.caucho.config.program.MethodGeneratorProgram;
import com.caucho.config.program.NullProgram;
import com.caucho.config.program.ValueGenerator;
import com.caucho.util.L10N;

/**
 * Handles the @EJB annotation for JavaEE
 */
public class EjbHandler extends JavaeeInjectionHandler {
  private static final L10N L = new L10N(EjbHandler.class);
  
  public EjbHandler(InjectManager manager)
  {
    super(manager);
  }
  
  @Override
  public ConfigProgram introspectField(AnnotatedField field)
  {
    EJB ejb = field.getAnnotation(EJB.class);
    return generateContext(field, ejb);
  }
  
  @Override
  public ConfigProgram introspectMethod(AnnotatedMethod method)
  {
    EJB ejb = method.getAnnotation(EJB.class);
    
    return generateContext(method, ejb);
  }

  @Override
  public ConfigProgram introspectType(AnnotatedType type)
  {
    // ejb/123j
    for (Class parentClass = type.getJavaClass().getSuperclass();
         parentClass != null;
         parentClass = parentClass.getSuperclass()) {
      EJBs ejbs = parentClass.getAnnotation(EJBs.class);

      if (ejbs != null) {
        for (EJB ejb : ejbs.value()) {
          introspectClass(getClass().getName(), ejb);
        }
      }

      EJB ejb = parentClass.getAnnotation(EJB.class);

      if (ejb != null)
        introspectClass(getClass().getName(), ejb);
    }
    
    EJBs ejbs = type.getAnnotation(EJBs.class);

    if (ejbs != null) {
      for (EJB ejb : ejbs.value()) {
        introspectClass(getClass().getName(), ejb);
      }
    }

    EJB ejb = type.getAnnotation(EJB.class);

    if (ejb != null)
      introspectClass(getClass().getName(), ejb);
    
    return new NullProgram();
  }

  private void introspectClass(String location, EJB ejb)
  {
    String name = ejb.name();

    Class bindType = ejb.beanInterface();
    
    if ("".equals(name))
      throw new ConfigException(L.l("{0}: @EJB name() attribute is required for @EJB on a class.",
                                    location));
    
    if (Object.class.equals(bindType))
      throw new ConfigException(L.l("{0}: @EJB beanInterface() attribute is required for @EJB on a class.",
                                    location));
    
    ValueGenerator gen = bindGenerator(location, ejb, bindType);

    if (name != null && ! "".equals(name)) {
      bindJndi(name, gen, name);
    }
    
  }

  private ConfigProgram generateContext(AnnotatedField field,
                                        EJB ejb)
    throws ConfigException
  {
    String name = ejb.name();

    Field javaField = field.getJavaMember();
    
    String location = getLocation(javaField);

    Class bindType = javaField.getType();
    
    ValueGenerator gen = bindGenerator(location, ejb, bindType);

    if (name != null && ! "".equals(name))
      bindJndi(name, gen, name);
    
    bindJndi(javaField, gen);
    
    return new FieldGeneratorProgram(javaField, gen);
  }
  

  private ConfigProgram generateContext(AnnotatedMethod method,
                                        EJB ejb)
    throws ConfigException
  {
    String name = ejb.name();

    Method javaMethod = method.getJavaMember();
    
    String location = getLocation(javaMethod);

    Class bindType = javaMethod.getParameterTypes()[0];
    
    // ejb/2005
    if (! Object.class.equals(ejb.beanInterface())) {
      bindType = ejb.beanInterface();
    }
    
    ValueGenerator gen = bindGenerator(location, ejb, bindType);

    if (name != null && ! "".equals(name)) {
      bindJndi(name, gen, name);
    }
    
    bindJndi(javaMethod, gen);
    
    return new MethodGeneratorProgram(javaMethod, gen);
  }
  
  protected ValueGenerator bindGenerator(String location,
                                         EJB ejb,
                                         Class bindType)
  {
    String name = ejb.name();
    String mappedName = ejb.mappedName();
    String beanName = ejb.beanName();
    String lookupName = ejb.lookup();

    // ejb/2005
    if (! Object.class.equals(ejb.beanInterface())) {
      bindType = ejb.beanInterface();
    }
    
    if (lookupName != null && ! "".equals(lookupName)) {
      return new JndiValueGenerator(location, bindType, lookupName);
    }
    
    /*
    if (! "".equals(pContext.name()))
      jndiName = pContext.name();
      */

    Bean bean = null;

    if (! "".equals(beanName))
      bean = bind(location, bindType, new BeanNameLiteral(beanName));
    else
      bean = bind(location, bindType, EjbQualifierLiteral.QUALIFIER);
    
    if (bean == null)
      bean = bind(location, bindType, name);
    
    if (bean == null)
      bean = bind(location, bindType, mappedName);

    if (bean != null) {
      // valid bean
    }
    else if (! "".equals(name)) {
      throw new ConfigException(location + L.l("name='{0}' is an unknown @EJB.",
                                               name));
    }
    else if (! "".equals(mappedName)) {
      throw new ConfigException(location + L.l("mappedName='{0}' is an unknown @EJB.",
                                               mappedName));

    }
    else {
      throw new ConfigException(location + L.l("@EJB cannot find any defined EJBs.  No @EJB with type='{0}'",
                                               bindType));
    }

    return new BeanValueGenerator(location, bean);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy