public class InterfaceBasedMBeanInfoAssembler extends AbstractConfigurableMBeanInfoAssembler implements BeanClassLoaderAware, InitializingBean
AbstractReflectiveMBeanInfoAssembler
that allows for
the management interface of a bean to be defined using arbitrary interfaces.
Any methods or properties that are defined in those interfaces are exposed
as MBean operations and attributes.
By default, this class votes on the inclusion of each operation or attribute
based on the interfaces implemented by the bean class. However, you can supply an
array of interfaces via the managedInterfaces
property that will be
used instead. If you have multiple beans and you wish each bean to use a different
set of interfaces, then you can map bean keys (that is the name used to pass the
bean to the MBeanExporter
) to a list of interface names using the
interfaceMappings
property.
If you specify values for both interfaceMappings
and
managedInterfaces
, Spring will attempt to find interfaces in the
mappings first. If no interfaces for the bean are found, it will use the
interfaces defined by managedInterfaces
.
setManagedInterfaces(java.lang.Class<?>...)
,
setInterfaceMappings(java.util.Properties)
,
MethodNameBasedMBeanInfoAssembler
,
SimpleReflectiveMBeanInfoAssembler
,
MBeanExporter
ATTRIBUTE_OPERATION_VISIBILITY, FIELD_CLASS, FIELD_CURRENCY_TIME_LIMIT, FIELD_DEFAULT, FIELD_DISPLAY_NAME, FIELD_GET_METHOD, FIELD_LOG, FIELD_LOG_FILE, FIELD_METRIC_CATEGORY, FIELD_METRIC_TYPE, FIELD_PERSIST_LOCATION, FIELD_PERSIST_NAME, FIELD_PERSIST_PERIOD, FIELD_PERSIST_POLICY, FIELD_ROLE, FIELD_SET_METHOD, FIELD_UNITS, FIELD_VISIBILITY, ROLE_GETTER, ROLE_OPERATION, ROLE_SETTER
Constructor and Description |
---|
InterfaceBasedMBeanInfoAssembler() |
Modifier and Type | Method and Description |
---|---|
void |
afterPropertiesSet()
Invoked by the containing
BeanFactory after it has set all bean properties
and satisfied BeanFactoryAware , ApplicationContextAware etc. |
protected boolean |
includeOperation(java.lang.reflect.Method method,
java.lang.String beanKey)
Check to see if the
Method is declared in
one of the configured interfaces and that it is public. |
protected boolean |
includeReadAttribute(java.lang.reflect.Method method,
java.lang.String beanKey)
Check to see if the
Method is declared in
one of the configured interfaces and that it is public. |
protected boolean |
includeWriteAttribute(java.lang.reflect.Method method,
java.lang.String beanKey)
Check to see if the
Method is declared in
one of the configured interfaces and that it is public. |
void |
setBeanClassLoader(java.lang.ClassLoader beanClassLoader)
Callback that supplies the bean
class loader to
a bean instance. |
void |
setInterfaceMappings(java.util.Properties mappings)
Set the mappings of bean keys to a comma-separated list of interface names.
|
void |
setManagedInterfaces(java.lang.Class<?>... managedInterfaces)
Set the array of interfaces to use for creating the management info.
|
getNotificationInfo, setNotificationInfoMappings, setNotificationInfos
applyCurrencyTimeLimit, applyDefaultCurrencyTimeLimit, createModelMBeanOperationInfo, getAttributeDescription, getAttributeInfo, getClassForDescriptor, getDefaultCurrencyTimeLimit, getOperationDescription, getOperationInfo, getOperationParameters, getParameterNameDiscoverer, isExposeClassDescriptor, isUseStrictCasing, populateAttributeDescriptor, populateMBeanDescriptor, populateOperationDescriptor, setDefaultCurrencyTimeLimit, setExposeClassDescriptor, setParameterNameDiscoverer, setUseStrictCasing
checkManagedBean, getClassName, getClassToExpose, getClassToExpose, getConstructorInfo, getDescription, getMBeanInfo, getTargetClass
public void setManagedInterfaces(java.lang.Class<?>... managedInterfaces)
interfaceMappings
property.managedInterfaces
- an array of classes indicating the interfaces to use.
Each entry MUST be an interface.setInterfaceMappings(java.util.Properties)
public void setInterfaceMappings(java.util.Properties mappings)
The property key should match the bean key and the property value should match the list of interface names. When searching for interfaces for a bean, Spring will check these mappings first.
mappings
- the mappings of bean keys to interface namespublic void setBeanClassLoader(java.lang.ClassLoader beanClassLoader)
BeanClassLoaderAware
class loader
to
a bean instance.
Invoked after the population of normal bean properties but
before an initialization callback such as
InitializingBean's
InitializingBean.afterPropertiesSet()
method or a custom init-method.
setBeanClassLoader
in interface BeanClassLoaderAware
beanClassLoader
- the owning class loader; may be null
in
which case a default ClassLoader
must be used, for example
the ClassLoader
obtained via
ClassUtils.getDefaultClassLoader()
public void afterPropertiesSet()
InitializingBean
BeanFactory
after it has set all bean properties
and satisfied BeanFactoryAware
, ApplicationContextAware
etc.
This method allows the bean instance to perform validation of its overall configuration and final initialization when all bean properties have been set.
afterPropertiesSet
in interface InitializingBean
protected boolean includeReadAttribute(java.lang.reflect.Method method, java.lang.String beanKey)
Method
is declared in
one of the configured interfaces and that it is public.includeReadAttribute
in class AbstractReflectiveMBeanInfoAssembler
method
- the accessor Method
.beanKey
- the key associated with the MBean in the
beans
Map
.true
if the Method
is declared in one of the
configured interfaces, otherwise false
.protected boolean includeWriteAttribute(java.lang.reflect.Method method, java.lang.String beanKey)
Method
is declared in
one of the configured interfaces and that it is public.includeWriteAttribute
in class AbstractReflectiveMBeanInfoAssembler
method
- the mutator Method
.beanKey
- the key associated with the MBean in the
beans
Map
.true
if the Method
is declared in one of the
configured interfaces, otherwise false
.protected boolean includeOperation(java.lang.reflect.Method method, java.lang.String beanKey)
Method
is declared in
one of the configured interfaces and that it is public.includeOperation
in class AbstractReflectiveMBeanInfoAssembler
method
- the operation Method
.beanKey
- the key associated with the MBean in the
beans
Map
.true
if the Method
is declared in one of the
configured interfaces, otherwise false
.