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

org.eclipse.microprofile.config.inject.ConfigProperty Maven / Gradle / Ivy

/*
 * Copyright (c) 2016-2019 Contributors to the Eclipse Foundation
 *
 * See the NOTICE file(s) distributed with this work for additional
 * information regarding copyright ownership.
 *
 * 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.eclipse.microprofile.config.inject;

import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.PARAMETER;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

import java.lang.annotation.Retention;
import java.lang.annotation.Target;

import javax.enterprise.util.Nonbinding;
import javax.inject.Qualifier;

/**
 * 

* Binds the injection point with a configured value. * Can be used to annotate injection points of type {@code TYPE}, {@code Optional} or {@code javax.inject.Provider}, * where {@code TYPE} can be {@code String} and all types which have appropriate converters. *

* Injected values are the same values that would be retrieved from an injected {@link org.eclipse.microprofile.config.Config} instance * or from the instance retrieved from {@link org.eclipse.microprofile.config.ConfigProvider#getConfig()} * *

Examples

* *

Injecting Native Values

* * The first sample injects the configured value of the {@code my.long.property} property. * The injected value does not change even if the underline * property value changes in the {@link org.eclipse.microprofile.config.Config}. * *

Injecting a native value is recommended for a mandatory property and its value does not change at runtime or used by a bean with RequestScoped. *

A further recommendation is to use the built in {@code META-INF/microprofile-config.properties} file mechanism * to provide default values inside an Application. * If no configured value exists for this property, a {@code DeploymentException} will be thrown during startup. *

 * @Inject
 * @ConfigProperty(name="my.long.property")
 * private Long injectedLongValue;
 * 
* * *

Injecting Optional Values

* * * Contrary to natively injecting, if the property is not specified, this will not lead to a DeploymentException. * The following code injects a Long value to the {@code my.optional.long.property}. * If the property does not exist, the value {@code 123} will be assigned. * to {@code injectedLongValue}. *
 * @Inject
 * @ConfigProperty(name="my.optional.long.property", defaultValue="123")
 * private Long injectedLongValue;
 * 
* The following code injects an Optional value of {@code my.optional.int.property}. *
 * @Inject
 * @ConfigProperty(name = "my.optional.int.property")
 * private Optional<Integer> intConfigValue;
 * 
* *

Injecting Dynamic Values

* * The next sample injects a Provider for the value of {@code my.long.property} property to resolve the property dynamically. * Each invocation to {@code Provider#get()} will resolve the latest value from underlying {@link org.eclipse.microprofile.config.Config} again. * The existence of configured values will get checked during startup. * Instances of {@code Provider} are guaranteed to be Serializable. *
 * @Inject
 * @ConfigProperty(name = "my.long.property" defaultValue="123")
 * private Provider<Long> longConfigValue;
 * 
* *

If {@code ConfigProperty} is used with a type where no {@link org.eclipse.microprofile.config.spi.Converter} exists, * a deployment error will be thrown. * * @author Ondrej Mihalyi * @author Emily Jiang * @author Mark Struberg */ @Qualifier @Retention(RUNTIME) @Target({METHOD, FIELD, PARAMETER, TYPE}) public @interface ConfigProperty { String UNCONFIGURED_VALUE="org.eclipse.microprofile.config.configproperty.unconfigureddvalue"; /** * Provide a way to specify {@code null} value for a property. * e.g. The following example is to set the default value of {@code my.port} to null if the property is not specified in any config sources. *

     * @Inject
     * @ConfigProperty(name="my.port" defaultValue=ConfigProperty.NULL_VALUE)
     * String value;
     * 
*/ String NULL_VALUE="org.eclipse.microprofile.config.configproperty.nullvalue"; /** * The key of the config property used to look up the configuration value. * If it is not specified, it will be derived automatically as {@code .}, * where {@code injection_point_name} is the field name or parameter name, * {@code class_name} is the fully qualified name of the class being injected to. * If one of the {@code class_name} or {@code injection_point_name} cannot be determined, the value has to be provided. * * @return Name (key) of the config property to inject */ @Nonbinding String name() default ""; /** *

The default value if the configured property value does not exist. * *

If the target Type is not String a proper {@link org.eclipse.microprofile.config.spi.Converter} will get applied. * That means that any default value string should follow the formatting rules of the registered Converters. * * * @return the default value as a string */ @Nonbinding String defaultValue() default UNCONFIGURED_VALUE; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy