Author: supun
Date: Mon Mar 28 09:09:20 2011
New Revision: 1086160
URL: http://svn.apache.org/viewvc?rev=1086160&view=rev
Log:
adding the template deployer
Added:
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/TemplateDeployer.java
Modified:
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/SynapseConfiguration.java
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/mediators/template/TemplateMediator.java
synapse/trunk/java/repository/conf/axis2.xml
Modified:
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/SynapseConfiguration.java
URL:
http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/SynapseConfiguration.java?rev=1086160&r1=1086159&r2=1086160&view=diff
==============================================================================
---
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/SynapseConfiguration.java
(original)
+++
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/config/SynapseConfiguration.java
Mon Mar 28 09:09:20 2011
@@ -194,6 +194,21 @@ public class SynapseConfiguration implem
}
}
+ /**
+ * Update a sequence-template into the local registry. If a template
already exists
+ * by the specified key a runtime exception is thrown.
+ *
+ * @param key the name for the sequence
+ * @param mediator a Sequence mediator
+ */
+ public synchronized void updateSequenceTemplate(String key,
TemplateMediator mediator) {
+ localRegistry.put(key, mediator);
+
+ for (SynapseObserver o : observers) {
+ o.sequenceTemplateAdded(mediator);
+ }
+ }
+
public synchronized void updateSequence(String key, Mediator mediator) {
localRegistry.put(key, mediator);
for (SynapseObserver o : observers) {
@@ -1532,6 +1547,19 @@ public class SynapseConfiguration implem
localRegistry.put(name, template);
}
+ public void updateEndpointTemplate(String name, Template template) {
+ localRegistry.put(name, template);
+ }
+
+ public void removeEndpointTemplate(String name) {
+ Object sequence = localRegistry.get(name);
+ if (sequence instanceof Template) {
+ localRegistry.remove(name);
+ } else {
+ handleException("No template exists by the key/name : " + name);
+ }
+ }
+
public Template getEndpointTemplate(String key) {
Object o = getEntry(key);
if (o instanceof Template) {
Added:
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/TemplateDeployer.java
URL:
http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/TemplateDeployer.java?rev=1086160&view=auto
==============================================================================
---
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/TemplateDeployer.java
(added)
+++
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/deployers/TemplateDeployer.java
Mon Mar 28 09:09:20 2011
@@ -0,0 +1,287 @@
+/*
+ * 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.Mediator;
+import org.apache.synapse.SynapseConstants;
+import org.apache.synapse.config.xml.MediatorFactoryFinder;
+import org.apache.synapse.config.xml.MultiXMLConfigurationBuilder;
+import org.apache.synapse.config.xml.TemplateMediatorSerializer;
+import org.apache.synapse.config.xml.endpoints.TemplateSerializer;
+import org.apache.synapse.endpoints.Template;
+import org.apache.synapse.mediators.template.TemplateMediator;
+
+import javax.xml.namespace.QName;
+import java.io.File;
+import java.util.Properties;
+
+public class TemplateDeployer extends AbstractSynapseArtifactDeployer {
+ private static Log log = LogFactory.getLog(TemplateDeployer.class);
+
+ @Override
+ public String deploySynapseArtifact(OMElement artifactConfig, String
fileName, Properties properties) {
+
+ if (log.isDebugEnabled()) {
+ log.debug("Template Deployment from file : " + fileName + " :
Started");
+ }
+
+ try {
+
+ OMElement element = artifactConfig.getFirstChildWithName(
+ new QName(SynapseConstants.SYNAPSE_NAMESPACE, "endpoint"));
+ if (element != null) {
+ org.apache.synapse.config.xml.endpoints.TemplateFactory
templateFactory =
+ new
org.apache.synapse.config.xml.endpoints.TemplateFactory();
+
+ Template tm =
templateFactory.createEndpointTemplate(artifactConfig, properties);
+
+ tm.setName(new File(fileName).getName());
+ if (log.isDebugEnabled()) {
+ log.debug("Sequence Template named '" + tm.getName()
+ + "' has been built from the file " + fileName);
+ }
+
+ getSynapseConfiguration().addEndpointTemplate(tm.getName(),
tm);
+ if (log.isDebugEnabled()) {
+ log.debug("Template Deployment from file : " + fileName +
" : Completed");
+ }
+ log.info("Template named '" + tm.getName()
+ + "' has been deployed from file : " + fileName);
+
+ return tm.getName();
+ } else {
+ element = artifactConfig.getFirstChildWithName(
+ new QName(SynapseConstants.SYNAPSE_NAMESPACE,
"sequence"));
+ if (element != null) {
+ Mediator mediator = MediatorFactoryFinder.getInstance().
+ getMediator(artifactConfig, properties);
+ if (mediator instanceof TemplateMediator) {
+ TemplateMediator tm = (TemplateMediator) mediator;
+
+ tm.setFileName((new File(fileName)).getName());
+ if (log.isDebugEnabled()) {
+ log.debug("Sequence Template named '" +
tm.getName()
+ + "' has been built from the file " +
fileName);
+ }
+
+ tm.init(getSynapseEnvironment());
+ if (log.isDebugEnabled()) {
+ log.debug("Initialized the Template : " +
tm.getName());
+ }
+
+
getSynapseConfiguration().addSequenceTemplate(tm.getName(), tm);
+ if (log.isDebugEnabled()) {
+ log.debug("Template Deployment from file : " +
fileName + " : Completed");
+ }
+ log.info("Template named '" + tm.getName()
+ + "' has been deployed from file : " +
fileName);
+
+ return tm.getName();
+ }
+ }
+ }
+
+ } catch (Exception e) {
+ handleSynapseArtifactDeploymentError(
+ "Template 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("Template update from file : " + fileName + " has
started");
+ }
+
+ try {
+ OMElement element = artifactConfig.getFirstChildWithName(
+ new QName(SynapseConstants.SYNAPSE_NAMESPACE, "endpoint"));
+ if (element != null) {
+ org.apache.synapse.config.xml.endpoints.TemplateFactory
templateFactory =
+ new
org.apache.synapse.config.xml.endpoints.TemplateFactory();
+
+ Template tm =
templateFactory.createEndpointTemplate(artifactConfig, properties);
+
+ tm.setName(new File(fileName).getName());
+ if (log.isDebugEnabled()) {
+ log.debug("Sequence Template named '" + tm.getName()
+ + "' has been built from the file " + fileName);
+ }
+
+ Template existingSt = getSynapseConfiguration().
+ getEndpointTemplate(existingArtifactName);
+
+ if (existingArtifactName.equals(tm.getName())) {
+
getSynapseConfiguration().updateEndpointTemplate(tm.getName(), existingSt);
+ } else {
+
getSynapseConfiguration().addEndpointTemplate(tm.getName(), tm);
+
getSynapseConfiguration().removeEndpointTemplate(existingSt.getName());
+ log.info("Template: " + existingArtifactName + " has been
undeployed");
+ }
+
+ log.info("Template: " + tm.getName() + " has been updated from
the file: " + fileName);
+ return tm.getName();
+ } else {
+ element = artifactConfig.getFirstChildWithName(
+ new QName(SynapseConstants.SYNAPSE_NAMESPACE,
"sequence"));
+ if (element != null) {
+ Mediator mediator = MediatorFactoryFinder.getInstance().
+ getMediator(artifactConfig, properties);
+ if (mediator instanceof TemplateMediator) {
+ TemplateMediator tm = (TemplateMediator) mediator;
+
+ tm.setFileName((new File(fileName)).getName());
+ if (log.isDebugEnabled()) {
+ log.debug("Sequence Template named '" +
tm.getName()
+ + "' has been built from the file " +
fileName);
+ }
+
+ tm.init(getSynapseEnvironment());
+ if (log.isDebugEnabled()) {
+ log.debug("Initialized the Template : " +
tm.getName());
+ }
+
+ TemplateMediator existingSt =
getSynapseConfiguration().
+ getSequenceTemplate(existingArtifactName);
+
+ if (existingArtifactName.equals(tm.getName())) {
+
getSynapseConfiguration().updateSequenceTemplate(tm.getName(), existingSt);
+ } else {
+
getSynapseConfiguration().addSequenceTemplate(tm.getName(), tm);
+
getSynapseConfiguration().removeSequenceTemplate(existingSt.getName());
+ log.info("Template: " + existingArtifactName + "
has been undeployed");
+ }
+
+ existingSt.destroy();
+ log.info("Template: " + tm.getName() + " has been
updated from the file: " + fileName);
+ return tm.getName();
+ }
+ }
+ }
+
+ } catch (DeploymentException e) {
+ handleSynapseArtifactDeploymentError("Error while updating the
Template from the " +
+ "file: " + fileName);
+ }
+
+ return null;
+ }
+
+ @Override
+ public void undeploySynapseArtifact(String artifactName) {
+
+ if (log.isDebugEnabled()) {
+ log.debug("Template Undeployment of the Template named : "
+ + artifactName + " : Started");
+ }
+
+ try {
+ Template st =
getSynapseConfiguration().getEndpointTemplate(artifactName);
+ if (st != null) {
+ getSynapseConfiguration().removeEndpointTemplate(artifactName);
+ if (log.isDebugEnabled()) {
+ log.debug("Destroying the Template named : " +
artifactName);
+ }
+ if (log.isDebugEnabled()) {
+ log.debug("Template Undeployment of the template named : "
+ + artifactName + " : Completed");
+ }
+ log.info("Template named '" + st.getName() + "' has been
undeployed");
+ } else {
+ TemplateMediator tm =
getSynapseConfiguration().getSequenceTemplate(artifactName);
+ if (tm != null) {
+
getSynapseConfiguration().removeSequenceTemplate(artifactName);
+ if (log.isDebugEnabled()) {
+ log.debug("Destroying the Template named : " +
artifactName);
+ }
+ tm.destroy();
+ if (log.isDebugEnabled()) {
+ log.debug("Template Undeployment of the template named
: "
+ + artifactName + " : Completed");
+ }
+ log.info("Template named '" + st.getName() + "' has been
undeployed");
+ } else {
+ log.debug("Template task " + artifactName + " has already
been undeployed");
+ }
+ }
+ } catch (Exception e) {
+ handleSynapseArtifactDeploymentError(
+ "Template Undeployement of template named : " +
artifactName + " : Failed", e);
+ }
+ }
+
+ @Override
+ public void restoreSynapseArtifact(String artifactName) {
+
+ if (log.isDebugEnabled()) {
+ log.debug("Restoring the Template with name : " + artifactName + "
: Started");
+ }
+
+ try {
+ Template st =
getSynapseConfiguration().getEndpointTemplate(artifactName);
+ if (st != null) {
+ TemplateSerializer ts = new TemplateSerializer();
+ OMElement stElem = ts.serializeEndpointTemplate(st, null);
+ if (st.getFileName() != null) {
+ String fileName =
getServerConfigurationInformation().getSynapseXMLLocation()
+ + File.separator +
MultiXMLConfigurationBuilder.TEMPLATES_DIR
+ + File.separator + st.getFileName();
+ writeToFile(stElem, fileName);
+ if (log.isDebugEnabled()) {
+ log.debug("Restoring the Endpoint Template with name :
" +
+ artifactName + " : Completed");
+ }
+ log.info("Template named '" + artifactName + "' has been
restored");
+ }
+ } else {
+ TemplateMediator mt =
getSynapseConfiguration().getSequenceTemplate(artifactName);
+ if (mt != null) {
+ TemplateMediatorSerializer ts = new
TemplateMediatorSerializer();
+ OMElement stElem = ts.serializeMediator(null, mt);
+ if (mt.getFileName() != null) {
+ String fileName =
getServerConfigurationInformation().getSynapseXMLLocation()
+ + File.separator +
MultiXMLConfigurationBuilder.TEMPLATES_DIR
+ + File.separator + st.getFileName();
+ writeToFile(stElem, fileName);
+ if (log.isDebugEnabled()) {
+ log.debug("Restoring the Sequence Template with
name : " +
+ artifactName + " : Completed");
+ }
+ log.info("Template named '" + artifactName + "' has
been restored");
+ }
+ } else {
+ handleSynapseArtifactDeploymentError("Couldn't restore the
Template named '"
+ + artifactName + "', filename cannot be found");
+ }
+ }
+ } catch (Exception e) {
+ handleSynapseArtifactDeploymentError(
+ "Restoring of the Template named '" + artifactName + "'
has failed", e);
+ }
+ }
+}
Modified:
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/mediators/template/TemplateMediator.java
URL:
http://svn.apache.org/viewvc/synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/mediators/template/TemplateMediator.java?rev=1086160&r1=1086159&r2=1086160&view=diff
==============================================================================
---
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/mediators/template/TemplateMediator.java
(original)
+++
synapse/trunk/java/modules/core/src/main/java/org/apache/synapse/mediators/template/TemplateMediator.java
Mon Mar 28 09:09:20 2011
@@ -24,6 +24,7 @@ import org.apache.synapse.SynapseLog;
import org.apache.synapse.core.SynapseEnvironment;
import org.apache.synapse.mediators.AbstractListMediator;
+import javax.sound.midi.Sequence;
import java.util.Collection;
import java.util.Stack;
Modified: synapse/trunk/java/repository/conf/axis2.xml
URL:
http://svn.apache.org/viewvc/synapse/trunk/java/repository/conf/axis2.xml?rev=1086160&r1=1086159&r2=1086160&view=diff
==============================================================================
--- synapse/trunk/java/repository/conf/axis2.xml (original)
+++ synapse/trunk/java/repository/conf/axis2.xml Mon Mar 28 09:09:20 2011
@@ -89,6 +89,7 @@
<deployer extension="xml" directory="conf/synapse-config/event-sources"
class="org.apache.synapse.deployers.EventSourceDeployer"/>
<deployer extension="xml" directory="conf/synapse-config/tasks"
class="org.apache.synapse.deployers.TaskDeployer"/>
<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"/>
<!-- Following parameter will set the host name for the epr-->
<!--<parameter name="hostname" locked="true">myhost.com</parameter>-->