Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
  * Fabric3
  * Copyright (c) 2009 Metaform Systems
  *
  * Fabric3 is free software: you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as
  * published by the Free Software Foundation, either version 3 of
  * the License, or (at your option) any later version, with the
  * following exception:
 *
 * Linking this software statically or dynamically with other
 * modules is making a combined work based on this software.
 * Thus, the terms and conditions of the GNU General Public
 * License cover the whole combination.
 *
 * As a special exception, the copyright holders of this software
 * give you permission to link this software with independent
 * modules to produce an executable, regardless of the license
 * terms of these independent modules, and to copy and distribute
 * the resulting executable under terms of your choice, provided
 * that you also meet, for each linked independent module, the
 * terms and conditions of the license of that module. An
 * independent module is a module which is not derived from or
 * based on this software. If you modify this software, you may
 * extend this exception to your version of the software, but
 * you are not obligated to do so. If you do not wish to do so,
 * delete this exception statement from your version.
 *
 * Fabric3 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 for more details.
 *
 * You should have received a copy of the
 * GNU General Public License along with Fabric3.
 * If not, see <http://www.gnu.org/licenses/>.
 */
 package org.fabric3.federation.executor;
 
 import java.util.List;
 
 
A CommandExecutor that processes deployment commands on a participant node.

Version:
$Rev: 7441 $ $Date: 2009-07-26 14:38:08 +0200 (Sun, 26 Jul 2009) $
 
     private EventService eventService;
     private ScopeRegistry scopeRegistry;
     // indicates whether the runtime has been synchronized with the domain
     private boolean domainSynchronized;
 
                                             @Reference EventService eventService,
                                             @Reference ScopeRegistry scopeRegistry,
                                             @Reference ClassLoaderRegistry classLoaderRegistry,
                                             @Monitor RuntimeDeploymentCommandExecutorMonitor monitor) {
         this. = executorRegistry;
         this. = eventService;
         this. = scopeRegistry;
         this. = monitor;
         this. = classLoaderRegistry;
     }
 
     @Init
     public void init() {
         .register(RuntimeDeploymentCommand.classthis);
     }
 
     public void execute(RuntimeDeploymentCommand commandthrows ExecutionException {
         if ( && command.isSynchronization()) {
             // When a participant boots, it periodiclly issues synchronization requests to the zone manager until the first deployment command is
             // received. Since communications are asynchronous, it is possible multiple requests may be issued if a response is not received during
             // the elapsed time period. If this happens, only the first deployment command should be processed.
            return;
        }
        String id = command.getId();
        // execute the extension commands first before deserializing the other commands as they may contain extension-specific metadata classes
        byte[] serializedExtensionCommands = command.getExtensionCommands();
        List<CommandextensionCommands = deserialize(serializedExtensionCommands);
        for (Command cmd : extensionCommands) {
            .execute(cmd);
        }
        try {
        } catch (InstanceLifecycleException e) {
            throw new ExecutionException(e);
        }
        byte[] serializedCommands = command.getCommands();
        List<Commandcommands = deserialize(serializedCommands);
        for (Command cmd : commands) {
            .execute(cmd);
        }
        try {
        } catch (InstanceLifecycleException e) {
            throw new ExecutionException(e);
        }
         = true;
    }
    @SuppressWarnings({"unchecked"})
    private List<Commanddeserialize(byte[] commandsthrows ExecutionException {
        MultiClassLoaderObjectInputStream ois = null;
        try {
            InputStream stream = new ByteArrayInputStream(commands);
            // Deserialize the command set. As command set classes may be loaded in an extension classloader, use a MultiClassLoaderObjectInputStream
            // to deserialize classes in the appropriate classloader.
            ois = new MultiClassLoaderObjectInputStream(stream);
            return (List<Command>) ois.readObject();
        } catch (IOException e) {
            throw new ExecutionException(e);
        } catch (ClassNotFoundException e) {
            throw new ExecutionException(e);
        } finally {
            try {
                if (ois != null) {
                    ois.close();
                }
            } catch (IOException e) {
                // ignore;
            }
        }
    }
New to GrepCode? Check out our FAQ X