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.varia.deployment; 23 24 import org.jboss.system.ServiceMBeanSupport; 25 26 /** 27 * Various methods that may be implemented by a bean shell script. 28 * 29 * Service lifecycle methods such as <code>start</code> and <code>stop</code>, 30 * if available, are also called at service deployment and undeployment. 31 * 32 * @see BeanShellSubDeployer 33 * 34 * @author <a HREF="mailto:sacha.labourey@cogito-info.ch">Sacha Labourey</a>. 35 * @version $Revision: 41504 $ 36 */ 37 public interface ScriptService 38 extends org.jboss.system.Service 39 { 40 /** 41 * Returns a list of <code>ObjectName</code>s as strings that 42 * this service depends on. 43 */ 44 String[] dependsOn() throws Exception; 45 46 /** 47 * Returns the <code>ObjectName</code> of this service. 48 */ 49 String objectName() throws Exception; 50 51 /** 52 * Returns any MBean interfaces implemented by this script. 53 */ 54 Class[] getInterfaces() throws Exception; 55 56 /** 57 * Called before <code>create</code> is called. 58 * @param wrapper ServiceMBeanSupport wrapper that is controlling 59 * this service 60 */ 61 void setCtx(ServiceMBeanSupport wrapper) throws Exception; 62 63 } 64