public class InterfaceBasedMBeanInfoAssembler extends AbstractConfigurableMBeanInfoAssembler implements org.springframework.beans.factory.BeanClassLoaderAware, org.springframework.beans.factory.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, 
MBeanExporterATTRIBUTE_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() | 
| protected boolean | includeOperation(java.lang.reflect.Method method,
                java.lang.String beanKey)Check to see if the  Methodis 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  Methodis 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  Methodis declared in
 one of the configured interfaces and that it is public. | 
| void | setBeanClassLoader(java.lang.ClassLoader beanClassLoader) | 
| 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, setNotificationInfosapplyCurrencyTimeLimit, applyDefaultCurrencyTimeLimit, createModelMBeanOperationInfo, getAttributeDescription, getAttributeInfo, getClassForDescriptor, getDefaultCurrencyTimeLimit, getOperationDescription, getOperationInfo, getOperationParameters, getParameterNameDiscoverer, isExposeClassDescriptor, isUseStrictCasing, populateAttributeDescriptor, populateMBeanDescriptor, populateOperationDescriptor, setDefaultCurrencyTimeLimit, setExposeClassDescriptor, setParameterNameDiscoverer, setUseStrictCasingcheckManagedBean, getClassName, getClassToExpose, getClassToExpose, getConstructorInfo, getDescription, getMBeanInfo, getTargetClasspublic 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)
setBeanClassLoader in interface org.springframework.beans.factory.BeanClassLoaderAwarepublic void afterPropertiesSet()
afterPropertiesSet in interface org.springframework.beans.factory.InitializingBeanprotected 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 AbstractReflectiveMBeanInfoAssemblermethod - 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 AbstractReflectiveMBeanInfoAssemblermethod - 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 AbstractReflectiveMBeanInfoAssemblermethod - 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.