1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
/* * @(#)DynamicMBean.java 4.17 05/11/17 * * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */ package javax.management; /** * Defines the methods that should be implemented by * a Dynamic MBean (MBean that exposes a dynamic management interface). * * @since 1.5 */ public interface DynamicMBean { /** * Obtain the value of a specific attribute of the Dynamic MBean. * * @param attribute The name of the attribute to be retrieved * * @return The value of the attribute retrieved. * * @exception AttributeNotFoundException * @exception MBeanException Wraps a <CODE>java.lang.Exception</CODE> thrown by the MBean's getter. * @exception ReflectionException Wraps a <CODE>java.lang.Exception</CODE> thrown while trying to invoke the getter. * * @see #setAttribute */ public Object getAttribute(String attribute) throws AttributeNotFoundException, MBeanException, ReflectionException; /** * Set the value of a specific attribute of the Dynamic MBean. * * @param attribute The identification of the attribute to * be set and the value it is to be set to. * * @exception AttributeNotFoundException * @exception InvalidAttributeValueException * @exception MBeanException Wraps a <CODE>java.lang.Exception</CODE> thrown by the MBean's setter. * @exception ReflectionException Wraps a <CODE>java.lang.Exception</CODE> thrown while trying to invoke the MBean's setter. * * @see #getAttribute */ public void setAttribute(Attribute attribute) throws AttributeNotFoundException, InvalidAttributeValueException, MBeanException, ReflectionException ; /** * Get the values of several attributes of the Dynamic MBean. * * @param attributes A list of the attributes to be retrieved. * * @return The list of attributes retrieved. * * @see #setAttributes */ public AttributeList getAttributes(String[] attributes); /** * Sets the values of several attributes of the Dynamic MBean. * * @param attributes A list of attributes: The identification of the * attributes to be set and the values they are to be set to. * * @return The list of attributes that were set, with their new values. * * @see #getAttributes */ public AttributeList setAttributes(AttributeList attributes); /** * Allows an action to be invoked on the Dynamic MBean. * * @param actionName The name of the action to be invoked. * @param params An array containing the parameters to be set when the action is * invoked. * @param signature An array containing the signature of the action. The class objects will * be loaded through the same class loader as the one used for loading the * MBean on which the action is invoked. * * @return The object returned by the action, which represents the result of * invoking the action on the MBean specified. * * @exception MBeanException Wraps a <CODE>java.lang.Exception</CODE> thrown by the MBean's invoked method. * @exception ReflectionException Wraps a <CODE>java.lang.Exception</CODE> thrown while trying to invoke the method */ public Object invoke(String actionName, Object params[], String signature[]) throws MBeanException, ReflectionException ; /** * Provides the exposed attributes and actions of the Dynamic MBean using an MBeanInfo object. * * @return An instance of <CODE>MBeanInfo</CODE> allowing all attributes and actions * exposed by this Dynamic MBean to be retrieved. * */ public MBeanInfo getMBeanInfo(); }