Package io.micronaut.context.env
Class PropertySourcePropertyResolver
java.lang.Object
io.micronaut.context.env.PropertySourcePropertyResolver
- All Implemented Interfaces:
- PropertyResolver,- ValueResolver<String>,- AutoCloseable
- Direct Known Subclasses:
- DefaultEnvironment
public class PropertySourcePropertyResolver
extends Object
implements PropertyResolver, AutoCloseable
A PropertyResolver that resolves from one or many PropertySource instances.
- Since:
- 1.0
- Author:
- Graeme Rocher
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final ConversionServiceprotected org.slf4j.Loggerstatic final io.micronaut.context.env.DefaultPropertyEntryprotected final PropertyPlaceholderResolverprotected final Map<String,PropertySource> 
- 
Constructor SummaryConstructorsConstructorDescriptionCreates a new, initially empty,PropertySourcePropertyResolver.PropertySourcePropertyResolver(PropertySource... propertySources) Creates a newPropertySourcePropertyResolverfor the givenPropertySourceinstances.PropertySourcePropertyResolver(ConversionService conversionService) Creates a new, initially empty,PropertySourcePropertyResolverfor the givenConversionService.PropertySourcePropertyResolver(ConversionService conversionService, boolean logEnabled) Creates a new, initially empty,PropertySourcePropertyResolverfor the givenConversionService.
- 
Method SummaryModifier and TypeMethodDescriptionaddPropertySource(@Nullable PropertySource propertySource) Add aPropertySourceto this resolver.Add a property source for the given map.voidclose()booleanWhether the given property or any nested properties exist for the key given key within this resolver.booleancontainsProperty(@Nullable String name) Whether the given property is contained within this resolver.getAllProperties(StringConvention keyConvention, MapFormat.MapTransformation transformation) Returns a combined Map of all properties in the catalog.getProperties(String name, StringConvention keyFormat) Return all the properties under the given key.<T> Optional<T>getProperty(@NonNull String name, @NonNull ArgumentConversionContext<T> conversionContext) Resolve the given property for the given name, type and generic type arguments.getPropertyEntries(@NonNull String name) Returns a collection of properties entries under the given key.getPropertyEntries(@NonNull String name, PropertyCatalog propertyCatalog) Returns a collection of properties entries under the given key, but .getPropertyPathMatches(String pathPattern) Will return for a given pattern such asfoo.*.bar.*and array of arrays containing the variable names that match the pattern.protected voidprocessPropertySource(PropertySource properties, PropertySource.PropertyConvention convention) protected voidSubclasses can override to reset caches.resolveEntriesForKey(String name, boolean allowCreate, @Nullable PropertyCatalog propertyCatalog) resolveSubMap(String name, Map<String, io.micronaut.context.env.DefaultPropertyEntry> entries, ArgumentConversionContext<?> conversionContext) resolveSubMap(String name, Map<String, io.micronaut.context.env.DefaultPropertyEntry> entries, ArgumentConversionContext<?> conversionContext, @Nullable StringConvention keyConvention, MapFormat.MapTransformation transformation) Resolves a submap for the given name and parameters.protected PropertiesresolveSubProperties(String name, Map<String, io.micronaut.context.env.DefaultPropertyEntry> entries, ArgumentConversionContext<?> conversionContext) Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface io.micronaut.core.value.PropertyResolverget, getProperties, getProperty, getProperty, getProperty, getProperty, getRequiredPropertyMethods inherited from interface io.micronaut.core.value.ValueResolverget, get, get
- 
Field Details- 
NULL_ENTRYpublic static final io.micronaut.context.env.DefaultPropertyEntry NULL_ENTRY
- 
conversionService
- 
propertyPlaceholderResolver
- 
propertySources
- 
catalog
- 
rawCatalog
- 
nonGenerated
- 
logprotected org.slf4j.Logger log
 
- 
- 
Constructor Details- 
PropertySourcePropertyResolverCreates a new, initially empty,PropertySourcePropertyResolverfor the givenConversionService.- Parameters:
- conversionService- The- ConversionService
- logEnabled- flag to enable or disable logger
 
- 
PropertySourcePropertyResolverCreates a new, initially empty,PropertySourcePropertyResolverfor the givenConversionService.- Parameters:
- conversionService- The- ConversionService
 
- 
PropertySourcePropertyResolverpublic PropertySourcePropertyResolver()Creates a new, initially empty,PropertySourcePropertyResolver.
- 
PropertySourcePropertyResolverCreates a newPropertySourcePropertyResolverfor the givenPropertySourceinstances.- Parameters:
- propertySources- The- PropertySourceinstances
 
 
- 
- 
Method Details- 
addPropertySourcepublic PropertySourcePropertyResolver addPropertySource(@Nullable @Nullable PropertySource propertySource) Add aPropertySourceto this resolver.- Parameters:
- propertySource- The- PropertySourceto add
- Returns:
- This PropertySourcePropertyResolver
 
- 
addPropertySourcepublic PropertySourcePropertyResolver addPropertySource(String name, @Nullable @Nullable Map<String, ? super Object> values) Add a property source for the given map.- Parameters:
- name- The name of the property source
- values- The values
- Returns:
- This environment
 
- 
containsPropertyDescription copied from interface:PropertyResolverWhether the given property is contained within this resolver. Note that this method will return false for nested properties. In other words given a key of foo.barthis method will returnfalsefor:resolver.containsProperty("foo")To check for nested properties using PropertyResolver.containsProperties(String)instead.- Specified by:
- containsPropertyin interface- PropertyResolver
- Parameters:
- name- The name of the property
- Returns:
- True if it is
 
- 
containsPropertiesDescription copied from interface:PropertyResolverWhether the given property or any nested properties exist for the key given key within this resolver.- Specified by:
- containsPropertiesin interface- PropertyResolver
- Parameters:
- name- The name of the property
- Returns:
- True if it is
 
- 
getPropertyEntriesDescription copied from interface:PropertyResolverReturns a collection of properties entries under the given key. For example given the following keys:
 Callingdatasource.default.url=localhost datasource.another.url=someothergetPropertyEntries(String)with a value ofdatasourcewill result in a collection containingdefaultandother.- Specified by:
- getPropertyEntriesin interface- PropertyResolver
- Parameters:
- name- The name to resolve
- Returns:
- The property entries.
 
- 
getPropertyEntries@NonNull public @NonNull Collection<String> getPropertyEntries(@NonNull @NonNull String name, @NonNull PropertyCatalog propertyCatalog) Description copied from interface:PropertyResolverReturns a collection of properties entries under the given key, but . For example, if you setPropertyCatalog.RAWthen the following keys:
 Callingdatasource.MyDs-1.url=localhost datasource.MyDs-2.url=someothergetPropertyEntries(String)with a value ofdatasourcewill result in a collection containingMyDs-1andMyDs-2(without normalization).- Specified by:
- getPropertyEntriesin interface- PropertyResolver
- Parameters:
- name- The name to resolve
- propertyCatalog- property catalog to use
- Returns:
- The property entries.
 
- 
getPropertyPathMatchesDescription copied from interface:PropertyResolverWill return for a given pattern such asfoo.*.bar.*and array of arrays containing the variable names that match the pattern.- Specified by:
- getPropertyPathMatchesin interface- PropertyResolver
- Parameters:
- pathPattern- The path pattern
- Returns:
- An array of arrays.
 
- 
getPropertiesDescription copied from interface:PropertyResolverReturn all the properties under the given key. By default, Micronaut stores keys in keb-case, such that normalized lookups are more efficient. You can obtain the raw key values by passing inStringConvention.RAW.- Specified by:
- getPropertiesin interface- PropertyResolver
- Parameters:
- name- The name
- keyFormat- The key format to use for the keys. Default is kebab-case.
- Returns:
- The properties
 
- 
getPropertypublic <T> Optional<T> getProperty(@NonNull @NonNull String name, @NonNull @NonNull ArgumentConversionContext<T> conversionContext) Description copied from interface:PropertyResolverResolve the given property for the given name, type and generic type arguments. Implementers can choose to implement more intelligent type conversion by analyzing the typeArgument. - Specified by:
- getPropertyin interface- PropertyResolver
- Type Parameters:
- T- The concrete type
- Parameters:
- name- The name
- conversionContext- The conversion context
- Returns:
- An optional containing the property value if it exists
 
- 
getAllPropertiespublic Map<String,Object> getAllProperties(StringConvention keyConvention, MapFormat.MapTransformation transformation) Returns a combined Map of all properties in the catalog.- Parameters:
- keyConvention- The map key convention
- transformation- The map format
- Returns:
- Map of all properties
 
- 
resolveSubPropertiesprotected Properties resolveSubProperties(String name, Map<String, io.micronaut.context.env.DefaultPropertyEntry> entries, ArgumentConversionContext<?> conversionContext) - Parameters:
- name- The property name
- entries- The entries
- conversionContext- The conversion context
- Returns:
- The subproperties
 
- 
resolveSubMapprotected Map<String,Object> resolveSubMap(String name, Map<String, io.micronaut.context.env.DefaultPropertyEntry> entries, ArgumentConversionContext<?> conversionContext) - Parameters:
- name- The property name
- entries- The entries
- conversionContext- The conversion context
- Returns:
- The submap
 
- 
resolveSubMap@NonNull protected @NonNull Map<String,Object> resolveSubMap(String name, Map<String, io.micronaut.context.env.DefaultPropertyEntry> entries, ArgumentConversionContext<?> conversionContext, @Nullable @Nullable StringConvention keyConvention, MapFormat.MapTransformation transformation) Resolves a submap for the given name and parameters.- Parameters:
- name- The name
- entries- The entries
- conversionContext- The conversion context
- keyConvention- The key convention to use
- transformation- The map transformation to apply
- Returns:
- The resulting map
 
- 
processPropertySourceprotected void processPropertySource(PropertySource properties, PropertySource.PropertyConvention convention) - Parameters:
- properties- The property source
- convention- The property convention
 
- 
resolveEntriesForKeyprotected Map<String,io.micronaut.context.env.DefaultPropertyEntry> resolveEntriesForKey(String name, boolean allowCreate, @Nullable @Nullable PropertyCatalog propertyCatalog) - Parameters:
- name- The name
- allowCreate- Whether allows creation
- propertyCatalog- The string convention
- Returns:
- The map with the resolved entries for the name
 
- 
resetCachesprotected void resetCaches()Subclasses can override to reset caches.
- 
close- Specified by:
- closein interface- AutoCloseable
- Throws:
- Exception
 
 
-