/* * JBoss, Home of Professional Open Source * Copyright 2011, Red Hat, Inc. and individual contributors * by the @authors tag. See the copyright.txt in the distribution for a * full listing of individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.mobicents.smsc.server.bootstrap; import java.io.File; import java.io.FileFilter; import java.io.IOException; import java.net.URL; import org.apache.log4j.Logger; import org.jboss.kernel.Kernel; import org.jboss.kernel.plugins.deployment.xml.BasicXMLDeployer; import org.jboss.kernel.spi.deployment.KernelDeployment; /** * Simplified deployement framework designed for hot deployement of endpoints and media components. * * Deployement is represented by tree of folders. Each folder may contains one or more deployement descriptors. The most * top deployment directory is referenced as root. Maindeployer creates recursively HDScanner for root and each nested * directoty. The HDScanner corresponding to the root directory is triggered periodicaly by local timer and in it order * starts nested scanners recursively. * * @author kulikov * @author amit bhayani */ public class MainDeployer { /** JBoss microconatiner kernel */ private Kernel kernel; /** Basic deployer */ private BasicXMLDeployer kernelDeployer; private KernelDeployment deployment; /** Filter for selecting descriptors */ private FileFilter fileFilter; /** Root deployment directory as string */ private String path; /** Root deployment directory as file object */ private File root; /** Logger instance */ private Logger logger = Logger.getLogger(MainDeployer.class); /** * Creates new instance of deployer. */ public MainDeployer() { } /** * Gets the path to the to the root deployment directory. * * @return path to deployment directory. */ public String getPath() { return path; } /** * Modify the path to the root deployment directory * * @param path */ public void setPath(String path) { this.path = path; root = new File(path); } /** * Gets the filter used by Deployer to select files for deployement. * * @return the file filter object. */ public FileFilter getFileFilter() { return fileFilter; } /** * Assigns file filter used for selection files for deploy. * * @param fileFilter * the file filter object. */ public void setFileFilter(FileFilter fileFilter) { this.fileFilter = fileFilter; } /** * Starts main deployer. * * @param kernel * the jboss microntainer kernel instance. * @param kernelDeployer * the jboss basic deployer. */ public void start(Kernel kernel, BasicXMLDeployer kernelDeployer) throws Throwable { TestVersion version = TestVersion.instance; this.kernel = kernel; this.kernelDeployer = kernelDeployer; try { Configuration d = new Configuration("root", root); URL url = d.getConfig(); deployment = kernelDeployer.deploy(url); kernelDeployer.validate(); } catch (IOException e) { e.printStackTrace(); } logger.info("[[[[[[[[[ " + version.toString() + " Started " + "]]]]]]]]]"); } /** * Shuts down deployer. */ public void stop() { kernelDeployer.undeploy(deployment); logger.info("Stopped"); } }