/* * Copyright 2007-2008 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Sun designates this * particular file as subject to the "Classpath" exception as provided * by Sun in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, * CA 95054 USA or visit www.sun.com if you need additional information or * have any questions. */ package javax.management; import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Inherited; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** *
Specifies the kinds of notification an MBean can emit. In both the * following examples, the MBean emits notifications of type * {@code "com.example.notifs.create"} and of type * {@code "com.example.notifs.destroy"}:
* ** // Example one: a Standard MBean * {@code @NotificationInfo}(types={"com.example.notifs.create", * "com.example.notifs.destroy"}) * public interface CacheMBean {...} * * public class Cache implements CacheMBean {...} ** *
* // Example two: an annotated MBean * {@link MBean @MBean} * {@code @NotificationInfo}(types={"com.example.notifs.create", * "com.example.notifs.destroy"}) * public class Cache {...} ** *
Each {@code @NotificationInfo} produces an {@link * MBeanNotificationInfo} inside the {@link MBeanInfo} of each MBean * to which the annotation applies.
* *If you need to specify different notification classes, or different * descriptions for different notification types, then you can group * several {@code @NotificationInfo} annotations into a containing * {@link NotificationInfos @NotificationInfos} annotation. * *
The {@code NotificationInfo} and {@code NotificationInfos} * annotations can be applied to the MBean implementation class, or to * any parent class or interface. These annotations on a class take * precedence over annotations on any superclass or superinterface. * If an MBean does not have these annotations on its class or any * superclass, then superinterfaces are examined. It is an error for * more than one superinterface to have these annotations, unless one * of them is a child of all the others.
*/ @Documented @Inherited @Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) public @interface NotificationInfo { /** *The {@linkplain Notification#getType() notification types} * that this MBean can emit.
*/ String[] types(); /** *The class that emitted notifications will have. It is recommended * that this be {@link Notification}, or one of its standard subclasses * in the JMX API.
*/ Class extends Notification> notificationClass() default Notification.class; /** *The description of this notification. For example: * *
* {@code @NotificationInfo}( * types={"com.example.notifs.create"}, * description={@code @Description}("object created")) **/ Description description() default @Description(""); /** *
Additional descriptor fields for the derived {@code * MBeanNotificationInfo}. They are specified in the same way as * for the {@link DescriptorFields @DescriptorFields} annotation, * for example:
** {@code @NotificationInfo}( * types={"com.example.notifs.create"}, * descriptorFields={"severity=6"}) **/ String[] descriptorFields() default {}; }