All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jboss.jca.deployers.fungal.external.RemoteDeployer Maven / Gradle / Ivy

The newest version!
/*
 * IronJacamar, a Java EE Connector Architecture implementation
 * Copyright 2012, Red Hat Inc, and individual contributors
 * as indicated by the @author tags. See the copyright.txt file 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.jboss.jca.deployers.fungal.external;

import org.jboss.jca.deployers.DeployersLogger;
import org.jboss.jca.deployers.fungal.RAActivator;

import java.io.File;
import java.io.IOException;

import org.jboss.logging.Logger;

import com.github.fungal.api.Kernel;
import com.github.fungal.api.deployer.MainDeployer;
import com.github.fungal.api.remote.Communicator;

/**
 *
 * @author Jesper Pedersen
 */
public class RemoteDeployer
{
   /** The logger */
   private static DeployersLogger log = Logger.getMessageLogger(DeployersLogger.class, RemoteDeployer.class.getName());

   private Kernel kernel;
   private Communicator communicator;
   private String directory;

   private RemoteDeploy remoteDeploy;
   private RemoteUndeploy remoteUndeploy;
   private RemoteList remoteList;

   /**
    * Constructor
    */
   public RemoteDeployer()
   {
      this.kernel = null;
      this.communicator = null;
      this.directory = null;

      this.remoteDeploy = null;
      this.remoteUndeploy = null;
      this.remoteList = null;
   }

   /**
    * Set the kernel
    * @param v The value
    */
   public void setKernel(Kernel v)
   {
      kernel = v;
   }

   /**
    * Set the remote directory
    * @param v The value
    */
   public void setDirectory(String v)
   {
      directory = v;
   }

   /**
    * Start
    * @exception Throwable Thrown in case of an error
    */
   public void start() throws Throwable
   {
      communicator = kernel.getBean("Communicator", Communicator.class);

      if (directory == null || directory.trim().equals(""))
         throw new IllegalStateException("Directory must be defined");

      File rd = new File(directory);
      if (!rd.exists())
      {
         if (!rd.mkdirs())
            throw new IOException("Directory couldn't be created");
      }

      MainDeployer mainDeployer = kernel.getMainDeployer();
      RAActivator activator = kernel.getBean("RAActivator", RAActivator.class);

      remoteDeploy = new RemoteDeploy(mainDeployer, activator, rd);
      remoteUndeploy = new RemoteUndeploy(mainDeployer, activator, rd);
      remoteList = new RemoteList(rd);

      communicator.registerCommand(remoteDeploy);
      communicator.registerCommand(remoteUndeploy);
      communicator.registerCommand(remoteList);
   }

   /**
    * Stop
    * @exception Throwable Thrown in case of an error
    */
   public void stop() throws Throwable
   {
      if (communicator != null)
      {
         if (remoteList != null)
            communicator.unregisterCommand(remoteList);

         if (remoteUndeploy != null)
            communicator.unregisterCommand(remoteUndeploy);

         if (remoteDeploy != null)
            communicator.unregisterCommand(remoteDeploy);
      }

      // Clean up directory
      File rd = new File(directory);
      if (rd.exists())
      {
         File[] files = rd.listFiles();
         if (files != null)
         {
            MainDeployer mainDeployer = kernel.getMainDeployer();

            for (File deployment : files)
            {
               try
               {
                  mainDeployer.undeploy(deployment.toURI().toURL());
               }
               catch (Throwable t)
               {
                  log.warn("Exception during undeploy: " + t.getMessage(), t);
               }
            }
         }
      }
   }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy