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

org.eclipse.jetty.plus.annotation.Injection Maven / Gradle / Ivy

There is a newer version: 12.1.0.alpha0
Show newest version
//
//  ========================================================================
//  Copyright (c) 1995-2022 Mort Bay Consulting Pty Ltd and others.
//  ------------------------------------------------------------------------
//  All rights reserved. This program and the accompanying materials
//  are made available under the terms of the Eclipse Public License v1.0
//  and Apache License v2.0 which accompanies this distribution.
//
//      The Eclipse Public License is available at
//      http://www.eclipse.org/legal/epl-v10.html
//
//      The Apache License v2.0 is available at
//      http://www.opensource.org/licenses/apache2.0.php
//
//  You may elect to redistribute this code under either of these licenses.
//  ========================================================================
//

package org.eclipse.jetty.plus.annotation;

import java.lang.reflect.Field;
import java.lang.reflect.Member;
import java.lang.reflect.Method;
import java.util.Locale;
import java.util.Objects;
import javax.naming.InitialContext;
import javax.naming.NamingException;

import org.eclipse.jetty.util.IntrospectionUtil;
import org.eclipse.jetty.util.log.Log;
import org.eclipse.jetty.util.log.Logger;

/**
 * Injection
 * 

* Represents the injection of a resource into a target (method or field). * The injection is performed by doing an ENC lookup using the jndi * name provided, and setting the object obtained on the target. */ public class Injection { private static final Logger LOG = Log.getLogger(Injection.class); private final Class _targetClass; private final String _jndiName; private final String _mappingName; private final Member _target; private final Class _paramClass; private final Class _resourceClass; public Injection(Class clazz, Field field, Class resourceType, String jndiName, String mappingName) { _targetClass = Objects.requireNonNull(clazz); _target = Objects.requireNonNull(field); _resourceClass = resourceType; _paramClass = null; _jndiName = jndiName; _mappingName = mappingName; } public Injection(Class clazz, Method method, Class arg, Class resourceType, String jndiName, String mappingName) { _targetClass = Objects.requireNonNull(clazz); _target = Objects.requireNonNull(method); _resourceClass = resourceType; _paramClass = arg; _jndiName = jndiName; _mappingName = mappingName; } public Injection(Class clazz, String target, Class resourceType, String jndiName, String mappingName) { _targetClass = Objects.requireNonNull(clazz); Objects.requireNonNull(target); _resourceClass = resourceType; _jndiName = jndiName; _mappingName = mappingName; Member tmpTarget = null; Class tmpParamClass = null; //first look for a javabeans style setter matching the targetName String setter = "set" + target.substring(0, 1).toUpperCase(Locale.ENGLISH) + target.substring(1); try { if (LOG.isDebugEnabled()) LOG.debug("Looking for method for setter: " + setter + " with arg {}", _resourceClass); tmpTarget = IntrospectionUtil.findMethod(clazz, setter, new Class[]{_resourceClass}, true, false); tmpParamClass = _resourceClass; } catch (NoSuchMethodException nsme) { //try as a field try { tmpTarget = IntrospectionUtil.findField(clazz, target, resourceType, true, false); tmpParamClass = null; } catch (NoSuchFieldException nsfe) { nsme.addSuppressed(nsfe); throw new IllegalArgumentException("No such field or method " + target + " on class " + _targetClass, nsme); } } _target = tmpTarget; _paramClass = tmpParamClass; } /** * @return the _className */ public Class getTargetClass() { return _targetClass; } public Class getParamClass() { return _paramClass; } public Class getResourceClass() { return _resourceClass; } public boolean isField() { return (Field.class.isInstance(_target)); } public boolean isMethod() { return (Method.class.isInstance(_target)); } /** * @return the jndiName */ public String getJndiName() { return _jndiName; } /** * @return the mappingName */ public String getMappingName() { return _mappingName; } /** * @return the target */ public Member getTarget() { return _target; } /** * Inject a value for a Resource from JNDI into an object * * @param injectable the object to inject */ public void inject(Object injectable) { if (isField()) injectField((Field)_target, injectable); else if (isMethod()) injectMethod((Method)_target, injectable); else throw new IllegalStateException("Neither field nor method injection"); } /** * The Resource must already exist in the ENC of this webapp. * * @return the injected valud * @throws NamingException if unable to lookup value */ public Object lookupInjectedValue() throws NamingException { InitialContext context = new InitialContext(); return context.lookup("java:comp/env/" + getJndiName()); } /** * Inject value from jndi into a field of an instance * * @param field the field to inject into * @param injectable the value to inject */ protected void injectField(Field field, Object injectable) { try { boolean accessibility = field.isAccessible(); field.setAccessible(true); field.set(injectable, lookupInjectedValue()); field.setAccessible(accessibility); } catch (Exception e) { LOG.warn(e); throw new IllegalStateException("Inject failed for field " + field.getName()); } } /** * Inject value from jndi into a setter method of an instance * * @param method the method to inject into * @param injectable the value to inject */ protected void injectMethod(Method method, Object injectable) { try { boolean accessibility = method.isAccessible(); method.setAccessible(true); method.invoke(injectable, lookupInjectedValue()); method.setAccessible(accessibility); } catch (Exception e) { LOG.warn(e); throw new IllegalStateException("Inject failed for method " + method.getName()); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy