Author: charith
Date: Wed May  4 16:39:07 2011
New Revision: 1099511

URL: http://svn.apache.org/viewvc?rev=1099511&view=rev
Log:
adding message processor deployer

Added:
    
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/MessageProcessorDeployer.java
Modified:
    
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/xml/MultiXMLConfigurationBuilder.java
    
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/AbstractMessageProcessor.java
    
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/MessageProcessor.java
    
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/forward/ScheduledMessageForwardingProcessor.java
    synapse/trunk/java/repository/conf/axis2.xml

Modified: 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/xml/MultiXMLConfigurationBuilder.java
URL: 
http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/xml/MultiXMLConfigurationBuilder.java?rev=1099511&r1=1099510&r2=1099511&view=diff
==============================================================================
--- 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/xml/MultiXMLConfigurationBuilder.java
 (original)
+++ 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/xml/MultiXMLConfigurationBuilder.java
 Wed May  4 16:39:07 2011
@@ -30,6 +30,7 @@ import org.apache.synapse.SynapseConstan
 import org.apache.synapse.endpoints.Template;
 import org.apache.synapse.mediators.template.TemplateMediator;
 import org.apache.synapse.SynapseException;
+import org.apache.synapse.message.processors.MessageProcessor;
 import org.apache.synapse.message.store.MessageStore;
 import org.apache.synapse.commons.executors.PriorityExecutor;
 import org.apache.synapse.config.Entry;
@@ -84,6 +85,7 @@ public class MultiXMLConfigurationBuilde
     public static final String EVENTS_DIR          = "event-sources";
     public static final String EXECUTORS_DIR       = "priority-executors";
     public static final String MESSAGE_STORE_DIR   = "message-stores";
+    public static final String MESSAGE_PROCESSOR_DIR   = "message-processors";
 
     public static final String REGISTRY_FILE       = "registry.xml";
 
@@ -126,6 +128,7 @@ public class MultiXMLConfigurationBuilde
         createEventSources(synapseConfig, root, properties);
         createExecutors(synapseConfig, root, properties);
         createMessageStores(synapseConfig, root, properties);
+        createMessageProcessors(synapseConfig,root,properties);
 
         return synapseConfig;
     }
@@ -411,6 +414,32 @@ public class MultiXMLConfigurationBuilde
         }
     }
 
+
+    private static void createMessageProcessors(SynapseConfiguration 
synapseConfig,
+                                            String rootDirPath, Properties 
properties) {
+
+        File messageProcessorDir = new File(rootDirPath, 
MESSAGE_PROCESSOR_DIR);
+        if (messageProcessorDir.exists()) {
+            if (log.isDebugEnabled()) {
+                log.debug("Loading Message Processors from :" + 
messageProcessorDir.getPath());
+            }
+
+            Iterator messageProcessors = 
FileUtils.iterateFiles(messageProcessorDir, extensions, false);
+            while (messageProcessors.hasNext()) {
+                File file = (File) messageProcessors.next();
+                OMElement document = getOMElement(file);
+                MessageProcessor messageProcessor = 
SynapseXMLConfigurationFactory.defineMessageProcessor(
+                        synapseConfig, document, properties);
+                if (messageProcessor != null) {
+                    messageProcessor.setFileName(file.getName());
+                    
synapseConfig.getArtifactDeploymentStore().addArtifact(file.getAbsolutePath(),
+                            messageProcessor.getName());
+                }
+            }
+        }
+    }
+
+
     private static OMElement getOMElement(File file) {
         FileInputStream is;
         OMElement document = null;

Added: 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/MessageProcessorDeployer.java
URL: 
http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/MessageProcessorDeployer.java?rev=1099511&view=auto
==============================================================================
--- 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/MessageProcessorDeployer.java
 (added)
+++ 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/MessageProcessorDeployer.java
 Wed May  4 16:39:07 2011
@@ -0,0 +1,184 @@
+/*
+ *  Licensed to the Apache Software Foundation (ASF) under one
+ *  or more contributor license agreements.  See the NOTICE file
+ *  distributed with this work for additional information
+ *  regarding copyright ownership.  The ASF licenses this file
+ *  to you under the Apache License, Version 2.0 (the
+ *  "License"); you may not use this file except in compliance
+ *  with the License.  You may obtain a copy of the License at
+ *
+ *   http://www.apache.org/licenses/LICENSE-2.0
+ *
+ *  Unless required by applicable law or agreed to in writing,
+ *  software distributed under the License is distributed on an
+ *   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ *  KIND, either express or implied.  See the License for the
+ *  specific language governing permissions and limitations
+ *  under the License.
+ */
+package org.apache.synapse.deployers;
+
+import org.apache.axiom.om.OMElement;
+import org.apache.axis2.deployment.DeploymentException;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.apache.synapse.config.xml.MessageProcessorFactory;
+import org.apache.synapse.config.xml.MessageStoreSerializer;
+import org.apache.synapse.config.xml.MultiXMLConfigurationBuilder;
+import org.apache.synapse.message.processors.MessageProcessor;
+import org.apache.synapse.message.store.MessageStore;
+
+import java.io.File;
+import java.util.Properties;
+
+public class MessageProcessorDeployer extends AbstractSynapseArtifactDeployer {
+
+    private static Log log = LogFactory.getLog(MessageProcessorDeployer.class);
+
+    @Override
+    public String deploySynapseArtifact(OMElement artifactConfig, String 
fileName, Properties properties) {
+        if (log.isDebugEnabled()) {
+            log.debug("Message Processor Deployment from file : " + fileName + 
" : Started");
+        }
+
+        try{
+
+            MessageProcessor mp = 
MessageProcessorFactory.createMessageProcessor(artifactConfig);
+            if(mp != null) {
+                mp.setFileName((new File(fileName)).getName());
+                 if (log.isDebugEnabled()) {
+                    log.debug("Message Processor named '" + mp.getName()
+                            + "' has been built from the file " + fileName);
+                }
+                mp.init(getSynapseEnvironment());
+                if (log.isDebugEnabled()) {
+                    log.debug("Initialized the Message Processor : " + 
mp.getName());
+                }
+                getSynapseConfiguration().addMessageProcessor(mp.getName(), 
mp);
+                if (log.isDebugEnabled()) {
+                    log.debug("Message Processor Deployment from file : " + 
fileName +
+                            " : Completed");
+                }
+                log.info("Message Processor named '" + mp.getName()
+                        + "' has been deployed from file : " + fileName);
+                return mp.getName();
+            } else {
+                handleSynapseArtifactDeploymentError("Message Processor 
Deployment from the file : "
+                    + fileName + " : Failed. The artifact " +
+                        "described in the file  is not a Message Processor");
+            }
+
+        } catch (Exception e) {
+            handleSynapseArtifactDeploymentError("Message Processor Deployment 
from the file : "
+                    + fileName + " : Failed.", e);
+        }
+
+        return null;
+    }
+
+    @Override
+    public String updateSynapseArtifact(OMElement artifactConfig, String 
fileName,
+                                        String existingArtifactName, 
Properties properties) {
+       if (log.isDebugEnabled()) {
+            log.debug("Message Processor update from file : " + fileName + " 
has started");
+        }
+
+        try {
+            MessageProcessor mp = 
MessageProcessorFactory.createMessageProcessor(artifactConfig);
+            if (mp == null) {
+                handleSynapseArtifactDeploymentError("Message Processor update 
failed. The artifact " +
+                        "defined in the file: " + fileName + " is not valid");
+                return null;
+            }
+            mp.setFileName(new File(fileName).getName());
+
+            if (log.isDebugEnabled()) {
+                log.debug("MessageProcessor: " + mp.getName() + " has been 
built from the file: "
+                        + fileName);
+            }
+
+            mp.init(getSynapseEnvironment());
+            MessageStore existingMs = 
getSynapseConfiguration().getMessageStore(existingArtifactName);
+
+            // We should add the updated MessageProcessor as a new 
MessageProcessor
+            // and remove the old one
+            getSynapseConfiguration().addMessageProcessor(mp.getName(), mp);
+            getSynapseConfiguration().removeMessageStore(existingArtifactName);
+            log.info("MessageProcessor: " + existingArtifactName + " has been 
undeployed");
+
+
+            log.info("MessageProcessor: " + mp.getName() + " has been updated 
from the file: " + fileName);
+
+            waitForCompletion();
+            existingMs.destroy();
+            return mp.getName();
+
+        } catch (DeploymentException e) {
+            handleSynapseArtifactDeploymentError("Error while updating the 
MessageProcessor from the " +
+                    "file: " + fileName);
+        }
+
+        return null;
+    }
+
+    @Override
+    public void undeploySynapseArtifact(String artifactName) {
+         if (log.isDebugEnabled()) {
+            log.debug("MessageProcessor Undeployment of the MessageProcessor 
named : "
+                    + artifactName + " : Started");
+        }
+
+        try {
+            MessageProcessor mp =
+                    
getSynapseConfiguration().getMessageProcessors().get(artifactName);
+            if (mp != null) {
+                getSynapseConfiguration().removeMessageStore(artifactName);
+                if (log.isDebugEnabled()) {
+                    log.debug("Destroying the MessageProcessor named : " + 
artifactName);
+                }
+                mp.destroy();
+                if (log.isDebugEnabled()) {
+                    log.debug("MessageProcessor Undeployment of the endpoint 
named : "
+                            + artifactName + " : Completed");
+                }
+                log.info("MessageProcessor named '" + mp.getName() + "' has 
been undeployed");
+            } else if (log.isDebugEnabled()) {
+                log.debug("MessageProcessor " + artifactName + " has already 
been undeployed");
+            }
+        } catch (Exception e) {
+            handleSynapseArtifactDeploymentError(
+                    "MessageProcessor Undeployement of MessageProcessor named 
: "
+                    + artifactName + " : Failed", e);
+        }
+    }
+
+    @Override
+    public void restoreSynapseArtifact(String artifactName) {
+        if (log.isDebugEnabled()) {
+            log.debug("Restoring the MessageProcessor with name : " + 
artifactName + " : Started");
+        }
+
+        try {
+            MessageStore ms
+                    = getSynapseConfiguration().getMessageStore(artifactName);
+            OMElement msElem = 
MessageStoreSerializer.serializeMessageStore(null, ms);
+            if (ms.getFileName() != null) {
+                String fileName = 
getServerConfigurationInformation().getSynapseXMLLocation()
+                        + File.separator + 
MultiXMLConfigurationBuilder.MESSAGE_PROCESSOR_DIR
+                        + File.separator + ms.getFileName();
+                writeToFile(msElem, fileName);
+                if (log.isDebugEnabled()) {
+                    log.debug("Restoring the MessageProcessor with name : "
+                            + artifactName + " : Completed");
+                }
+                log.info("MessageProcessor named '" + artifactName + "' has 
been restored");
+            } else {
+                handleSynapseArtifactDeploymentError("Couldn't restore the 
MessageProcessor named '"
+                        + artifactName + "', filename cannot be found");
+            }
+        } catch (Exception e) {
+            handleSynapseArtifactDeploymentError(
+                    "Restoring of the MessageProcessor named '" + artifactName 
+ "' has failed", e);
+        }
+    }
+}

Modified: 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/AbstractMessageProcessor.java
URL: 
http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/AbstractMessageProcessor.java?rev=1099511&r1=1099510&r2=1099511&view=diff
==============================================================================
--- 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/AbstractMessageProcessor.java
 (original)
+++ 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/AbstractMessageProcessor.java
 Wed May  4 16:39:07 2011
@@ -45,6 +45,8 @@ public abstract class AbstractMessagePro
 
     protected String name;
 
+    protected String fileName;
+
     protected SynapseConfiguration configuration;
 
     protected enum State {
@@ -107,4 +109,12 @@ public abstract class AbstractMessagePro
     public String getDescription() {
         return description;
     }
+
+    public void setFileName(String filename) {
+        this.fileName = filename;
+    }
+
+    public String getFileName() {
+        return fileName;
+    }
 }
\ No newline at end of file

Modified: 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/MessageProcessor.java
URL: 
http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/MessageProcessor.java?rev=1099511&r1=1099510&r2=1099511&view=diff
==============================================================================
--- 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/MessageProcessor.java
 (original)
+++ 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/MessageProcessor.java
 Wed May  4 16:39:07 2011
@@ -71,4 +71,18 @@ public interface MessageProcessor extend
      * @return
      */
     public boolean isStarted();
+
+     /**
+     * Set the name of the file that the Message Processor is configured
+     *
+     * @param filename Name of the file where this artifact is defined
+     */
+    public void setFileName(String filename);
+
+    /**
+     * get the file name that the message processor is configured
+     *
+     * @return Name of the file where this artifact is defined
+     */
+    public String getFileName();
 }

Modified: 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/forward/ScheduledMessageForwardingProcessor.java
URL: 
http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/forward/ScheduledMessageForwardingProcessor.java?rev=1099511&r1=1099510&r2=1099511&view=diff
==============================================================================
--- 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/forward/ScheduledMessageForwardingProcessor.java
 (original)
+++ 
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/message/processors/forward/ScheduledMessageForwardingProcessor.java
 Wed May  4 16:39:07 2011
@@ -138,5 +138,14 @@ public class ScheduledMessageForwardingP
         }
         state = State.DESTROY;
     }
+
+
+    /**
+     * Return the JMS view of Message Processor
+     * @return
+     */
+    public MessageForwardingProcessorView getView() {
+        return view;
+    }
 }
 

Modified: synapse/trunk/java/repository/conf/axis2.xml
URL: 
http://svn.apache.org/viewvc/synapse/trunk/java/repository/conf/axis2.xml?rev=1099511&r1=1099510&r2=1099511&view=diff
==============================================================================
--- synapse/trunk/java/repository/conf/axis2.xml (original)
+++ synapse/trunk/java/repository/conf/axis2.xml Wed May  4 16:39:07 2011
@@ -91,6 +91,7 @@
     <deployer extension="xml" 
directory="conf/synapse-config/priority-executors" 
class="org.apache.synapse.deployers.PriorityExecutorDeployer"/>
     <deployer extension="xml" directory="conf/synapse-config/templates" 
class="org.apache.synapse.deployers.TemplateDeployer"/>
     <deployer extension="xml" directory="conf/synapse-config/message-stores" 
class="org.apache.synapse.deployers.MessageStoreDeployer"/>
+    <deployer extension="xml" 
directory="conf/synapse-config/message-processors" 
class="org.apache.synapse.deployers.MessageProcessorDeployer"/>
 
     <!-- Following parameter will set the host name for the epr-->
     <!--<parameter name="hostname" locked="true">myhost.com</parameter>-->


Reply via email to