![JAR search and dependency download from the Maven repository](/logo.png)
org.microbean.microprofile.config.cdi.ConfigBean Maven / Gradle / Ivy
The newest version!
/* -*- mode: Java; c-basic-offset: 2; indent-tabs-mode: nil; coding: utf-8-unix -*-
*
* Copyright © 2018–2019 microBean™.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package org.microbean.microprofile.config.cdi;
import java.lang.annotation.Annotation;
import java.lang.reflect.Type;
import java.util.Collections;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Set;
import javax.enterprise.context.spi.CreationalContext;
import javax.enterprise.inject.Instance;
import javax.enterprise.inject.spi.Bean;
import javax.enterprise.inject.spi.CDI;
import javax.enterprise.inject.spi.InjectionPoint;
import javax.enterprise.inject.spi.PassivationCapable;
import javax.enterprise.util.TypeLiteral;
import javax.inject.Singleton;
import org.eclipse.microprofile.config.Config;
import org.eclipse.microprofile.config.ConfigProvider;
import org.eclipse.microprofile.config.spi.ConfigBuilder;
import org.eclipse.microprofile.config.spi.ConfigProviderResolver;
import org.eclipse.microprofile.config.spi.ConfigSource;
import org.eclipse.microprofile.config.spi.Converter;
final class ConfigBean implements Bean, PassivationCapable {
private static final Set onlyDefaultQualifier = Collections.singleton(DefaultLiteral.INSTANCE);
private static final Set defaultQualifiers = new HashSet<>();
static {
defaultQualifiers.add(DefaultLiteral.INSTANCE);
defaultQualifiers.add(AnyLiteral.INSTANCE);
}
private static final Set emptyInjectionPointSet = Collections.emptySet();
private static final Set> emptyStereotypesSet = Collections.emptySet();
private static final Set configTypes = Collections.singleton(Config.class);
private final String id;
private final Set qualifiers;
ConfigBean() {
this(null);
}
ConfigBean(final Set qualifiers) {
super();
final Set myQualifiers;
if (qualifiers == null || qualifiers.isEmpty()) {
myQualifiers = new HashSet<>();
} else {
myQualifiers = new HashSet<>(qualifiers);
}
this.qualifiers = Collections.unmodifiableSet(myQualifiers);
this.id = new StringBuilder(this.getClass().getName()).append(";t:").append(this.getTypes()).append(";q:").append(this.getQualifiers()).toString();
}
@Override
public final Config create(final CreationalContext cc) {
final Set myQualifiers = this.getQualifiers();
assert myQualifiers != null;
final Config returnValue;
if (myQualifiers.equals(onlyDefaultQualifier) || myQualifiers.equals(defaultQualifiers)) {
// The specification requires that we do this, or at least that
// we produce a result indistinguishable from the result of
// doing this.
returnValue = ConfigProvider.getConfig();
assert returnValue != null;
} else {
// With non-default qualifiers, we are free to do the right and
// proper thing, which is to build a Config without registering
// it anywhere, and to rely on CDI's qualifiers to select the
// proper configuration sources.
final ConfigBuilder builder = ConfigProviderResolver.instance().getBuilder();
assert builder != null;
builder.addDefaultSources();
builder.addDiscoveredSources();
builder.addDiscoveredConverters();
builder.forClassLoader(Thread.currentThread().getContextClassLoader());
final Instance
© 2015 - 2025 Weber Informatics LLC | Privacy Policy