1 /* 2 * JBoss, Home of Professional Open Source 3 * Copyright 2005, JBoss Inc., and individual contributors as indicated 4 * by the @authors tag. See the copyright.txt in the distribution for a 5 * full listing of individual contributors. 6 * 7 * This is free software; you can redistribute it and/or modify it 8 * under the terms of the GNU Lesser General Public License as 9 * published by the Free Software Foundation; either version 2.1 of 10 * the License, or (at your option) any later version. 11 * 12 * This software is distributed in the hope that it will be useful, 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 15 * Lesser General Public License for more details. 16 * 17 * You should have received a copy of the GNU Lesser General Public 18 * License along with this software; if not, write to the Free 19 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 20 * 02110-1301 USA, or see the FSF site: http://www.fsf.org. 21 */ 22 package org.jboss.aop.microcontainer.aspects.jmx; 23 24 import java.lang.annotation.ElementType; 25 import java.lang.annotation.Retention; 26 import java.lang.annotation.RetentionPolicy; 27 import java.lang.annotation.Target; 28 29 /** 30 * A temporary home for this annotation interface 31 * 32 * @author <a HREF="kabir.khan@jboss.com">Kabir Khan</a> 33 * @author Brian Stansberry 34 * 35 * @version $Revision: 58352 $ 36 */ 37 @Retention(RetentionPolicy.RUNTIME) 38 @Target(ElementType.TYPE) 39 public @interface JMX 40 { 41 /** 42 * The mbean interface the annotated object should expose. Ignored if 43 * {@link #registerDirectly()} is <code>true</code>. 44 * 45 * @return the mbean interface 46 */ 47 Class exposedInterface(); 48 49 /** 50 * String form of the ObjectName for the mbean. 51 * 52 * @return the object name 53 */ 54 String name() default ""; 55 56 /** 57 * Should the annotated object itself be directly registered with 58 * the MBeanServer, or should a <code>javax.management.StandardMBean</code> 59 * be created using the object and the 60 * {@link #exposedInterface() exposed interface}? 61 * 62 * @return <code>true</code> if the object should be registered directly, 63 * <code>false</code> if a StandardMBean should be created. 64 */ 65 boolean registerDirectly() default false; 66 } 67