Author: rfeng
Date: Thu Jul 26 18:20:29 2012
New Revision: 1366125
URL: http://svn.apache.org/viewvc?rev=1366125&view=rev
Log:
Add the remoteEndpoints configuration for node.xml to define
statically-configured remote endpoints
Added:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpoints.java
(with props)
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpointsProcessor.java
(with props)
Modified:
tuscany/sca-java-2.x/trunk/modules/assembly-xml/src/main/java/org/apache/tuscany/sca/assembly/xml/BaseAssemblyProcessor.java
tuscany/sca-java-2.x/trunk/modules/node-impl/META-INF/MANIFEST.MF
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/NodeConfigurationProcessor.java
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/resources/META-INF/services/org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessor
tuscany/sca-java-2.x/trunk/modules/node-impl/src/test/resources/org/apache/tuscany/sca/node/configuration/node1.xml
Modified:
tuscany/sca-java-2.x/trunk/modules/assembly-xml/src/main/java/org/apache/tuscany/sca/assembly/xml/BaseAssemblyProcessor.java
URL:
http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/modules/assembly-xml/src/main/java/org/apache/tuscany/sca/assembly/xml/BaseAssemblyProcessor.java?rev=1366125&r1=1366124&r2=1366125&view=diff
==============================================================================
---
tuscany/sca-java-2.x/trunk/modules/assembly-xml/src/main/java/org/apache/tuscany/sca/assembly/xml/BaseAssemblyProcessor.java
(original)
+++
tuscany/sca-java-2.x/trunk/modules/assembly-xml/src/main/java/org/apache/tuscany/sca/assembly/xml/BaseAssemblyProcessor.java
Thu Jul 26 18:20:29 2012
@@ -94,7 +94,7 @@ import org.w3c.dom.Node;
*
* @version $Rev$ $Date$
*/
-abstract class BaseAssemblyProcessor extends BaseStAXArtifactProcessor {
+public abstract class BaseAssemblyProcessor extends BaseStAXArtifactProcessor {
protected AssemblyFactory assemblyFactory;
protected PolicyFactory policyFactory;
Modified: tuscany/sca-java-2.x/trunk/modules/node-impl/META-INF/MANIFEST.MF
URL:
http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/modules/node-impl/META-INF/MANIFEST.MF?rev=1366125&r1=1366124&r2=1366125&view=diff
==============================================================================
--- tuscany/sca-java-2.x/trunk/modules/node-impl/META-INF/MANIFEST.MF (original)
+++ tuscany/sca-java-2.x/trunk/modules/node-impl/META-INF/MANIFEST.MF Thu Jul
26 18:20:29 2012
@@ -12,6 +12,7 @@ Import-Package: javax.management;resolut
javax.xml.stream,
org.apache.tuscany.sca.assembly;version="2.0.0",
org.apache.tuscany.sca.assembly.builder;version="2.0.0",
+ org.apache.tuscany.sca.assembly.xml;version="2.0.0",
org.apache.tuscany.sca.common.java.io;version="2.0.0",
org.apache.tuscany.sca.common.xml.stax;version="2.0.0",
org.apache.tuscany.sca.context;version="2.0.0",
@@ -34,6 +35,7 @@ Import-Package: javax.management;resolut
org.apache.tuscany.sca.node.configuration;version="2.0.0",
org.apache.tuscany.sca.node.extensibility,
org.apache.tuscany.sca.node.impl;version="2.0.0",
+ org.apache.tuscany.sca.policy;version="2.0.0",
org.apache.tuscany.sca.runtime;version="2.0.0",
org.apache.tuscany.sca.work;version="2.0.0",
org.oasisopen.sca;version="2.0.0",
Modified:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/NodeConfigurationProcessor.java
URL:
http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/NodeConfigurationProcessor.java?rev=1366125&r1=1366124&r2=1366125&view=diff
==============================================================================
---
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/NodeConfigurationProcessor.java
(original)
+++
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/NodeConfigurationProcessor.java
Thu Jul 26 18:20:29 2012
@@ -69,8 +69,7 @@ public class NodeConfigurationProcessor
private NodeConfigurationFactory nodeConfigurationFactory;
private StAXHelper helper;
- public NodeConfigurationProcessor(ExtensionPointRegistry registry,
- StAXArtifactProcessor processor) {
+ public NodeConfigurationProcessor(ExtensionPointRegistry registry,
StAXArtifactProcessor processor) {
FactoryExtensionPoint modelFactories =
registry.getExtensionPoint(FactoryExtensionPoint.class);
this.nodeConfigurationFactory =
modelFactories.getFactory(NodeConfigurationFactory.class);
this.processor = processor;
@@ -87,7 +86,8 @@ public class NodeConfigurationProcessor
return NodeConfiguration.class;
}
- public NodeConfiguration read(XMLStreamReader reader, ProcessorContext
context) throws ContributionReadException, XMLStreamException {
+ public NodeConfiguration read(XMLStreamReader reader, ProcessorContext
context) throws ContributionReadException,
+ XMLStreamException {
NodeConfiguration node = null;
ContributionConfiguration contribution = null;
@@ -136,7 +136,7 @@ public class NodeConfigurationProcessor
if (contribution != null) {
contribution.getDeploymentComposites().add(composite);
}
- } else if(BASE_URI.equals(name)) {
+ } else if (BASE_URI.equals(name)) {
// We also support <baseURI> element
String baseURI = reader.getElementText();
if (baseURI != null && binding != null) {
@@ -159,7 +159,9 @@ public class NodeConfigurationProcessor
composite.setContent(sw.toString());
} else {
Object ext = processor.read(reader, context);
- if (ext instanceof Endpoint) {
+ if (ext instanceof RemoteEndpoints) {
+
node.getEndpointDescriptions().addAll((RemoteEndpoints)ext);
+ } else if (ext instanceof Endpoint) {
node.getEndpointDescriptions().add((Endpoint)ext);
} else {
node.getExtensions().add(ext);
@@ -189,11 +191,12 @@ public class NodeConfigurationProcessor
return node;
}
- public void resolve(NodeConfiguration node, ModelResolver resolver,
ProcessorContext context) throws ContributionResolveException {
+ public void resolve(NodeConfiguration node, ModelResolver resolver,
ProcessorContext context)
+ throws ContributionResolveException {
}
- public void write(NodeConfiguration node, XMLStreamWriter writer,
ProcessorContext context) throws ContributionWriteException,
- XMLStreamException {
+ public void write(NodeConfiguration node, XMLStreamWriter writer,
ProcessorContext context)
+ throws ContributionWriteException, XMLStreamException {
writeStart(writer,
NODE.getNamespaceURI(),
@@ -243,13 +246,13 @@ public class NodeConfigurationProcessor
new XAttr("baseURIs", baseURIs));
writeEnd(writer);
}
-
+
// FIXME: The composite processor assumes that composite is root
element
-// for (Endpoint o : node.getEndpointDescriptions()) {
-// processor.write(o, writer, context);
-// }
-
- for(Object o: node.getExtensions()) {
+ // for (Endpoint o : node.getEndpointDescriptions()) {
+ // processor.write(o, writer, context);
+ // }
+
+ for (Object o : node.getExtensions()) {
processor.write(o, writer, context);
}
Added:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpoints.java
URL:
http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpoints.java?rev=1366125&view=auto
==============================================================================
---
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpoints.java
(added)
+++
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpoints.java
Thu Jul 26 18:20:29 2012
@@ -0,0 +1,29 @@
+/*
+ * 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.tuscany.sca.node.configuration.xml;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.apache.tuscany.sca.assembly.Endpoint;
+
+public class RemoteEndpoints extends ArrayList<Endpoint> {
+ private static final long serialVersionUID = -9045949145596529956L;
+}
Propchange:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpoints.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpoints.java
------------------------------------------------------------------------------
svn:keywords = Rev Date
Added:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpointsProcessor.java
URL:
http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpointsProcessor.java?rev=1366125&view=auto
==============================================================================
---
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpointsProcessor.java
(added)
+++
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpointsProcessor.java
Thu Jul 26 18:20:29 2012
@@ -0,0 +1,134 @@
+/*
+ * 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.tuscany.sca.node.configuration.xml;
+
+import javax.xml.namespace.QName;
+import javax.xml.stream.XMLStreamConstants;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.XMLStreamWriter;
+
+import org.apache.tuscany.sca.assembly.Binding;
+import org.apache.tuscany.sca.assembly.Component;
+import org.apache.tuscany.sca.assembly.ComponentService;
+import org.apache.tuscany.sca.assembly.Composite;
+import org.apache.tuscany.sca.assembly.Endpoint;
+import org.apache.tuscany.sca.assembly.xml.BaseAssemblyProcessor;
+import org.apache.tuscany.sca.assembly.xml.Constants;
+import org.apache.tuscany.sca.contribution.processor.ContributionReadException;
+import
org.apache.tuscany.sca.contribution.processor.ContributionResolveException;
+import
org.apache.tuscany.sca.contribution.processor.ContributionWriteException;
+import org.apache.tuscany.sca.contribution.processor.ProcessorContext;
+import org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessor;
+import org.apache.tuscany.sca.contribution.processor.StAXAttributeProcessor;
+import org.apache.tuscany.sca.contribution.resolver.ModelResolver;
+import org.apache.tuscany.sca.core.ExtensionPointRegistry;
+import org.apache.tuscany.sca.core.FactoryExtensionPoint;
+import org.apache.tuscany.sca.policy.PolicySet;
+
+/**
+ * A StaX processor for remote endpoints
+ */
+public class RemoteEndpointsProcessor extends BaseAssemblyProcessor implements
StAXArtifactProcessor<RemoteEndpoints> {
+ private final static String ENDPOINT = "remoteEndpoints";
+ private final static QName ENDPOINT_QNAME = new
QName(Constants.SCA11_TUSCANY_NS, ENDPOINT);
+
+ private ExtensionPointRegistry registry;
+
+ public RemoteEndpointsProcessor(ExtensionPointRegistry registry,
+ StAXArtifactProcessor extensionProcessor,
+ StAXAttributeProcessor
extensionAttributeProcessor) {
+
+ super(modelFactories(registry), extensionProcessor);
+ this.registry = registry;
+ }
+
+ /**
+ * Returns the model factory extension point to use.
+ *
+ * @param extensionPoints
+ * @return
+ */
+ private static FactoryExtensionPoint modelFactories(ExtensionPointRegistry
extensionPoints) {
+ return extensionPoints.getExtensionPoint(FactoryExtensionPoint.class);
+ }
+
+ public QName getArtifactType() {
+ return ENDPOINT_QNAME;
+ }
+
+ public RemoteEndpoints read(XMLStreamReader reader, ProcessorContext
context) throws ContributionReadException,
+ XMLStreamException {
+ RemoteEndpoints endpoints = new RemoteEndpoints();
+ if (reader.getEventType() == XMLStreamConstants.START_DOCUMENT) {
+ reader.nextTag();
+ }
+ if (reader.getEventType() == XMLStreamConstants.START_ELEMENT &&
ENDPOINT_QNAME.equals(reader.getName())) {
+ // Skip the "endpoint" element wrapper
+ reader.nextTag();
+ }
+ Object model = extensionProcessor.read(reader, context);
+ if (model instanceof Composite) {
+ Composite composite = (Composite)model;
+ for (Component component : composite.getComponents()) {
+ if (component.getURI() == null) {
+ // Default to the component name as the uri
+ component.setURI(component.getName());
+ }
+ for (ComponentService service : component.getServices()) {
+ for (Binding binding : service.getBindings()) {
+ Endpoint endpoint = assemblyFactory.createEndpoint();
+ endpoint.setComponent(component);
+ endpoint.setService(service);
+ endpoint.setBinding(binding);
+
+ // retrieve the stash of intents and policy sets from
the component
+
endpoint.getRequiredIntents().addAll(component.getRequiredIntents());
+
endpoint.getPolicySets().addAll(component.getPolicySets());
+
+ endpoints.add(endpoint);
+ }
+ }
+ }
+ }
+ return endpoints;
+ }
+
+ public void write(RemoteEndpoints model, XMLStreamWriter writer,
ProcessorContext context)
+ throws ContributionWriteException, XMLStreamException {
+
+ }
+
+ public Class<RemoteEndpoints> getModelType() {
+ return RemoteEndpoints.class;
+ }
+
+ public void resolve(RemoteEndpoints model, ModelResolver resolver,
ProcessorContext context)
+ throws ContributionResolveException {
+ // the only thing we'll resolve here is the policy model as the
endpoint
+ // matching algorithm needs to look inside the policy model
+
+ for (Endpoint endpoint : model) {
+ for (PolicySet policySet : endpoint.getPolicySets()) {
+ extensionProcessor.resolve(policySet, resolver, context);
+ }
+ }
+ }
+}
Propchange:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpointsProcessor.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/configuration/xml/RemoteEndpointsProcessor.java
------------------------------------------------------------------------------
svn:keywords = Rev Date
Modified:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/resources/META-INF/services/org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessor
URL:
http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/resources/META-INF/services/org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessor?rev=1366125&r1=1366124&r2=1366125&view=diff
==============================================================================
---
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/resources/META-INF/services/org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessor
(original)
+++
tuscany/sca-java-2.x/trunk/modules/node-impl/src/main/resources/META-INF/services/org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessor
Thu Jul 26 18:20:29 2012
@@ -15,4 +15,6 @@
# specific language governing permissions and limitations
# under the License.
org.apache.tuscany.sca.node.configuration.xml.NodeConfigurationProcessor;qname=http://tuscany.apache.org/xmlns/sca/1.1#node,model=org.apache.tuscany.sca.node.configuration.NodeConfiguration
+org.apache.tuscany.sca.node.configuration.xml.RemoteEndpointsProcessor;qname=http://tuscany.apache.org/xmlns/sca/1.1#remoteEndpoints,model=org.apache.tuscany.sca.node.configuration.xml.RemoteEndpoints
+
Modified:
tuscany/sca-java-2.x/trunk/modules/node-impl/src/test/resources/org/apache/tuscany/sca/node/configuration/node1.xml
URL:
http://svn.apache.org/viewvc/tuscany/sca-java-2.x/trunk/modules/node-impl/src/test/resources/org/apache/tuscany/sca/node/configuration/node1.xml?rev=1366125&r1=1366124&r2=1366125&view=diff
==============================================================================
---
tuscany/sca-java-2.x/trunk/modules/node-impl/src/test/resources/org/apache/tuscany/sca/node/configuration/node1.xml
(original)
+++
tuscany/sca-java-2.x/trunk/modules/node-impl/src/test/resources/org/apache/tuscany/sca/node/configuration/node1.xml
Thu Jul 26 18:20:29 2012
@@ -59,9 +59,29 @@
<sca:composite name="endpoint">
<sca:component name="Component1"> <!-- first component -->
<sca:service name="Service1">
- <tuscany:binding.rest
uri="http://localhost:8080/services/myResource" />
+ <binding.ws
uri="http://localhost:8080/services/myResource" />
</sca:service>
</sca:component>
</sca:composite>
</endpoint>
+ <remoteEndpoints>
+ <sca:composite name="endpoint">
+ <sca:component name="Component2"> <!-- first component -->
+ <sca:service name="Service1">
+ <sca:binding.ws name="ws"
uri="http://localhost:8080/services/myResource1" />
+ </sca:service>
+ <sca:service name="Service2">
+ <sca:binding.ws
uri="http://localhost:8080/services/myResource2" />
+ </sca:service>
+ </sca:component>
+ <sca:component name="Component3"> <!-- first component -->
+ <sca:service name="Service1">
+ <sca:binding.ws
uri="http://localhost:8080/services/myResource1" />
+ </sca:service>
+ <sca:service name="Service2">
+ <sca:binding.ws
uri="http://localhost:8080/services/myResource2" />
+ </sca:service>
+ </sca:component>
+ </sca:composite>
+ </remoteEndpoints>
</node>
\ No newline at end of file