SupplierInstanceBean.java
/*
* Copyright (c) 2017, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package org.glassfish.jersey.inject.cdi.se.bean;
import java.lang.annotation.Annotation;
import java.lang.reflect.Type;
import java.util.HashSet;
import java.util.Set;
import java.util.function.Supplier;
import javax.enterprise.context.spi.CreationalContext;
import org.glassfish.jersey.inject.cdi.se.ParameterizedTypeImpl;
import org.glassfish.jersey.internal.inject.DisposableSupplier;
import org.glassfish.jersey.internal.inject.SupplierInstanceBinding;
/**
* Creates an implementation of {@link javax.enterprise.inject.spi.Bean} interface using Jersey's {@link SupplierInstanceBinding}.
* Binding provides the information about the bean also called {@link javax.enterprise.inject.spi.BeanAttributes} information.
* The {@code Bean} does not use {@link org.glassfish.jersey.inject.cdi.se.injector.JerseyInjectionTarget} because serves already
* created supplier instance, therefore the create operation just return provided instance without any other contextual operation
* (produce, inject, destroy). Client has to manage the instance alone.
* <p>
* Inject example:
* <pre>
* AbstractBinder {
* @Override
* protected void configure() {
* bindFactory(new MyBeanFactory())
* .to(MyBean.class)
* .in(Singleton.class);
* }
* }
* </pre>
* Register example:
* <pre>
* @Path("/")
* public class MyResource {
* @Inject
* private Supplier<MyBean> myBean;
* }
* </pre>
*
* @author Petr Bouda
*/
class SupplierInstanceBean<T> extends JerseyBean<Supplier<T>> {
private final Set<Type> contracts = new HashSet<>();
private final Supplier<T> supplier;
/**
* Creates a new Jersey-specific {@link javax.enterprise.inject.spi.Bean} instance.
*
* @param binding {@link javax.enterprise.inject.spi.BeanAttributes} part of the bean.
*/
SupplierInstanceBean(SupplierInstanceBinding<T> binding) {
super(binding);
this.supplier = binding.getSupplier();
for (Type contract: binding.getContracts()) {
this.contracts.add(new ParameterizedTypeImpl(Supplier.class, contract));
if (DisposableSupplier.class.isAssignableFrom(binding.getSupplier().getClass())) {
this.contracts.add(new ParameterizedTypeImpl(DisposableSupplier.class, contract));
}
}
}
@Override
public Set<Type> getTypes() {
return contracts;
}
@Override
public Set<Annotation> getQualifiers() {
return DEFAULT_QUALIFIERS;
}
@Override
public Supplier<T> create(CreationalContext<Supplier<T>> context) {
return supplier;
}
@Override
public Class<?> getBeanClass() {
return supplier.getClass();
}
}