public class DefaultApplicationContext extends DefaultBeanContext implements ApplicationContext
ApplicationContext
interface.initializing, LOG, LOG_LIFECYCLE, running, terminating
EMPTY
DEFAULT
Constructor and Description |
---|
DefaultApplicationContext(ApplicationContextConfiguration configuration)
Construct a new ApplicationContext for the given environment name and classloader.
|
DefaultApplicationContext(ClassPathResourceLoader resourceLoader,
java.lang.String... environmentNames)
Construct a new ApplicationContext for the given environment name and classloader.
|
DefaultApplicationContext(java.lang.String... environmentNames)
Construct a new ApplicationContext for the given environment name.
|
Modifier and Type | Method and Description |
---|---|
boolean |
containsProperties(java.lang.String name)
Whether the given property or any nested properties exist for the key given key within this resolver.
|
boolean |
containsProperty(java.lang.String name)
Whether the given property is contained within this resolver.
|
protected ConversionService |
createConversionService()
Creates the default conversion service.
|
protected Environment |
createEnvironment(ApplicationContextConfiguration configuration)
Creates the default environment for the given environment name.
|
protected <T> java.util.Collection<BeanDefinition<T>> |
findBeanCandidates(BeanResolutionContext resolutionContext,
java.lang.Class<T> beanType,
BeanDefinition<?> filter,
boolean filterProxied)
Find bean candidates for the given type.
|
protected <T> BeanDefinition<T> |
findConcreteCandidate(java.lang.Class<T> beanType,
Qualifier<T> qualifier,
java.util.Collection<BeanDefinition<T>> candidates)
Fall back method to attempt to find a candidate for the given definitions.
|
ConversionService<?> |
getConversionService() |
Environment |
getEnvironment() |
java.util.Map<java.lang.String,java.lang.Object> |
getProperties(java.lang.String name,
StringConvention keyFormat)
Return all the properties under the given key.
|
<T> java.util.Optional<T> |
getProperty(java.lang.String name,
ArgumentConversionContext<T> conversionContext)
Resolve the given property for the given name, type and generic type arguments.
|
java.util.Collection<java.lang.String> |
getPropertyEntries(java.lang.String name)
Returns a collection of properties entries under the given key.
|
protected void |
initializeContext(java.util.List<BeanDefinitionReference> contextScopeBeans,
java.util.List<BeanDefinitionReference> processedBeans,
java.util.List<BeanDefinitionReference> parallelBeans)
Initialize the context with the given
Context scope beans. |
protected void |
initializeTypeConverters(BeanContext beanContext) |
protected void |
registerConfiguration(BeanConfiguration configuration)
Registers an active configuration.
|
<T> ApplicationContext |
registerSingleton(java.lang.Class<T> type,
T singleton,
Qualifier<T> qualifier,
boolean inject)
Registers a new singleton bean at runtime.
|
protected java.lang.Iterable<BeanConfiguration> |
resolveBeanConfigurations()
Resolves the
BeanConfiguration class instances. |
protected java.util.List<BeanDefinitionReference> |
resolveBeanDefinitionReferences()
Resolves the
BeanDefinitionReference class instances. |
java.util.Optional<java.lang.String> |
resolvePlaceholders(java.lang.String str)
Resolve the placeholders and return an Optional String if it was possible to resolve them.
|
java.lang.String |
resolveRequiredPlaceholders(java.lang.String str)
Resolve the placeholders and return an Optional String if it was possible to resolve them.
|
ApplicationContext |
start()
The start method will read all bean definition classes found on the classpath and initialize any pre-required
state.
|
protected void |
startEnvironment()
Start the environment.
|
ApplicationContext |
stop()
The close method will shut down the context calling
PreDestroy hooks on loaded
singletons. |
protected <T> java.util.Collection<BeanDefinition<T>> |
transformIterables(BeanResolutionContext resolutionContext,
java.util.Collection<BeanDefinition<T>> candidates,
boolean filterProxied)
Method that transforms iterable candidates if possible.
|
containsBean, createBean, createBean, createBean, createBean, createExecutionHandle, destroyBean, doCreateBean, doCreateBean, findBean, findBean, findBeanCandidates, findBeanCandidatesForInstance, findBeanConfiguration, findBeanDefinition, findBeanRegistration, findExecutableMethod, findExecutionHandle, findExecutionHandle, findExecutionHandle, findProxyBeanDefinition, findProxyTargetBeanDefinition, findProxyTargetMethod, findProxyTargetMethod, getActiveBeanRegistration, getActiveBeanRegistrations, getActiveBeanRegistrations, getAllBeanDefinitions, getAttribute, getAttribute, getAttributes, getBean, getBean, getBean, getBean, getBean, getBeanDefinitionReferences, getBeanDefinitions, getBeanDefinitions, getBeanDefinitions, getBeanProvider, getBeanProvider, getBeanRegistrations, getBeansOfType, getBeansOfType, getBeansOfType, getBeansOfType, getBeanValidator, getClassLoader, getProxyTargetBean, initializeEventListeners, inject, inject, invalidateCaches, isRunning, processParallelBeans, publishEvent, publishEventAsync, refreshBean, removeAttribute, resolveMetadata, setAttribute, streamOfType, streamOfType
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
build, build, build, build, build, builder, builder, builder, builder, builder, environment, registerSingleton, registerSingleton, registerSingleton, registerSingleton, run, run, run, run, run, run, run, run
build, createBean, createBean, createBean, createBean, createBean, createBean, destroyBean, getBeanValidator, getClassLoader, inject, refreshBean, run
createExecutionHandle, findExecutableMethod, findExecutionHandle, findExecutionHandle, findExecutionHandle, findProxyTargetMethod, findProxyTargetMethod, getExecutableMethod, getExecutionHandle, getExecutionHandle, getProxyTargetMethod, getProxyTargetMethod
findBean, findBean, findOrInstantiateBean, getBean, getBean, getBean, getBeansOfType, getBeansOfType, getProxyTargetBean, streamOfType, streamOfType
containsBean, containsBean, findBeanConfiguration, findBeanDefinition, findBeanDefinition, findBeanRegistration, findProxyBeanDefinition, findProxyTargetBeanDefinition, getActiveBeanRegistrations, getActiveBeanRegistrations, getAllBeanDefinitions, getBeanDefinition, getBeanDefinition, getBeanDefinitionReferences, getBeanDefinitions, getBeanDefinitions, getBeanDefinitions, getBeanRegistrations, getProxyTargetBeanDefinition
publishEvent, publishEventAsync
resolveMetadata, resolveMetadata
getAttributes, removeAttribute, setAttribute
getAttribute, getAttribute
get, getProperties, getProperty, getProperty, getProperty, getProperty, getRequiredProperty, nameOf
get, get, get
getPrefix, resolveRequiredPlaceholder
public DefaultApplicationContext(@NonNull java.lang.String... environmentNames)
environmentNames
- The environment namespublic DefaultApplicationContext(@NonNull ClassPathResourceLoader resourceLoader, @NonNull java.lang.String... environmentNames)
environmentNames
- The environment namesresourceLoader
- The class loaderpublic DefaultApplicationContext(@NonNull ApplicationContextConfiguration configuration)
configuration
- The application context configuration@NonNull public <T> ApplicationContext registerSingleton(@NonNull java.lang.Class<T> type, @NonNull T singleton, @Nullable Qualifier<T> qualifier, boolean inject)
BeanDefinitionRegistry
Registers a new singleton bean at runtime. This method expects that the bean definition data will have been compiled ahead of time.
If bean definition data is found the method will perform dependency injection on the instance followed by
invoking any PostConstruct
hooks.
If no bean definition data is found the bean is registered as is.
registerSingleton
in interface ApplicationContext
registerSingleton
in interface BeanContext
registerSingleton
in interface BeanDefinitionRegistry
registerSingleton
in class DefaultBeanContext
T
- The concrete typetype
- The bean typesingleton
- The singleton beanqualifier
- The bean qualifierinject
- Whether the singleton should be injected (defaults to true)@NonNull protected java.lang.Iterable<BeanConfiguration> resolveBeanConfigurations()
DefaultBeanContext
BeanConfiguration
class instances. Default implementation uses ServiceLoader pattern.resolveBeanConfigurations
in class DefaultBeanContext
@NonNull protected java.util.List<BeanDefinitionReference> resolveBeanDefinitionReferences()
DefaultBeanContext
BeanDefinitionReference
class instances. Default implementation uses ServiceLoader pattern.resolveBeanDefinitionReferences
in class DefaultBeanContext
@NonNull protected Environment createEnvironment(@NonNull ApplicationContextConfiguration configuration)
configuration
- The application context configuration@NonNull protected ConversionService createConversionService()
@NonNull public ConversionService<?> getConversionService()
getConversionService
in interface ApplicationContext
@NonNull public Environment getEnvironment()
getEnvironment
in interface ApplicationContext
@NonNull public ApplicationContext start()
DefaultBeanContext
start
in interface ApplicationContext
start
in interface LifeCycle<BeanContext>
start
in class DefaultBeanContext
@NonNull public ApplicationContext stop()
DefaultBeanContext
PreDestroy
hooks on loaded
singletons.stop
in interface ApplicationContext
stop
in interface LifeCycle<BeanContext>
stop
in class DefaultBeanContext
public boolean containsProperty(java.lang.String name)
PropertyResolver
Whether 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.bar this method will
return false for: resolver.containsProperty("foo")
To check for nested properties using PropertyResolver.containsProperties(String)
instead.
containsProperty
in interface PropertyResolver
name
- The name of the propertypublic boolean containsProperties(java.lang.String name)
PropertyResolver
containsProperties
in interface PropertyResolver
name
- The name of the propertypublic <T> java.util.Optional<T> getProperty(java.lang.String name, ArgumentConversionContext<T> conversionContext)
PropertyResolver
Resolve 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.
getProperty
in interface PropertyResolver
T
- The concrete typename
- The nameconversionContext
- The conversion context@NonNull public java.util.Collection<java.lang.String> getPropertyEntries(@NonNull java.lang.String name)
PropertyResolver
datasource.default.url=localhost
datasource.another.url=someother
Calling getPropertyEntries(String)
with a value of datasource
will result in a collection
containing default
and other
.getPropertyEntries
in interface PropertyResolver
name
- The name to resolve@NonNull public java.util.Map<java.lang.String,java.lang.Object> getProperties(@Nullable java.lang.String name, @Nullable StringConvention keyFormat)
PropertyResolver
StringConvention.RAW
.getProperties
in interface PropertyResolver
name
- The namekeyFormat
- The key format to use for the keys. Default is kebab-case.protected void registerConfiguration(BeanConfiguration configuration)
DefaultBeanContext
registerConfiguration
in class DefaultBeanContext
configuration
- The configuration to registerprotected void startEnvironment()
protected void initializeContext(java.util.List<BeanDefinitionReference> contextScopeBeans, java.util.List<BeanDefinitionReference> processedBeans, java.util.List<BeanDefinitionReference> parallelBeans)
DefaultBeanContext
Context
scope beans.initializeContext
in class DefaultBeanContext
contextScopeBeans
- The context scope beansprocessedBeans
- The beans that require ExecutableMethodProcessor
handlingparallelBeans
- The parallel bean definitionsprotected <T> java.util.Collection<BeanDefinition<T>> findBeanCandidates(BeanResolutionContext resolutionContext, java.lang.Class<T> beanType, BeanDefinition<?> filter, boolean filterProxied)
DefaultBeanContext
findBeanCandidates
in class DefaultBeanContext
T
- The bean generic typeresolutionContext
- The current resolution contextbeanType
- The bean typefilter
- A bean definition to filter outfilterProxied
- Whether to filter out bean proxy targetsprotected <T> java.util.Collection<BeanDefinition<T>> transformIterables(BeanResolutionContext resolutionContext, java.util.Collection<BeanDefinition<T>> candidates, boolean filterProxied)
DefaultBeanContext
transformIterables
in class DefaultBeanContext
T
- The bean typeresolutionContext
- The resolution contextcandidates
- The candidates.filterProxied
- Whether to filter proxied.protected <T> BeanDefinition<T> findConcreteCandidate(java.lang.Class<T> beanType, Qualifier<T> qualifier, java.util.Collection<BeanDefinition<T>> candidates)
DefaultBeanContext
findConcreteCandidate
in class DefaultBeanContext
T
- The generic timebeanType
- The bean typequalifier
- The qualifiercandidates
- The candidatespublic java.util.Optional<java.lang.String> resolvePlaceholders(java.lang.String str)
PropertyPlaceholderResolver
resolvePlaceholders
in interface PropertyPlaceholderResolver
str
- The placeholder to resolveOptional.empty()
if resolution was not possiblepublic java.lang.String resolveRequiredPlaceholders(java.lang.String str) throws ConfigurationException
PropertyPlaceholderResolver
resolveRequiredPlaceholders
in interface PropertyPlaceholderResolver
str
- The placeholder to resolveOptional.empty()
if resolution was not possibleConfigurationException
- If the placeholders could not be resolvedprotected void initializeTypeConverters(BeanContext beanContext)
beanContext
- The bean context