You are viewing a plain text version of this content. The canonical link for it is here.
Posted to wsrf-dev@ws.apache.org by ip...@apache.org on 2005/01/06 20:55:43 UTC

svn commit: r124426 - /incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceCapability.java /incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceDefinition.java /incubator/apollo/trunk/src/java/org/apache/ws/resource/impl/ResourceDefinitionImpl.java

Author: ips
Date: Thu Jan  6 11:55:43 2005
New Revision: 124426

URL: http://svn.apache.org/viewcvs?view=rev&rev=124426
Log:
now exposes endpoint URL and gets name from the last part of the endpoint URL isntead of the port element's name

Modified:
   incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceCapability.java
   incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceDefinition.java
   incubator/apollo/trunk/src/java/org/apache/ws/resource/impl/ResourceDefinitionImpl.java

Modified: incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceCapability.java
Url: http://svn.apache.org/viewcvs/incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceCapability.java?view=diff&rev=124426&p1=incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceCapability.java&r1=124425&p2=incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceCapability.java&r2=124426
==============================================================================
--- incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceCapability.java	(original)
+++ incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceCapability.java	Thu Jan  6 11:55:43 2005
@@ -21,7 +21,7 @@
 import java.util.Map;
 
 /**
- * A WSRF Web service definition.
+ * A WSRF resource capability (i.e. set of operations and properties).
  *
  * @author Ian Springer
  */

Modified: incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceDefinition.java
Url: http://svn.apache.org/viewcvs/incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceDefinition.java?view=diff&rev=124426&p1=incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceDefinition.java&r1=124425&p2=incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceDefinition.java&r2=124426
==============================================================================
--- incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceDefinition.java	(original)
+++ incubator/apollo/trunk/src/java/org/apache/ws/resource/ResourceDefinition.java	Thu Jan  6 11:55:43 2005
@@ -18,15 +18,17 @@
 import javax.wsdl.Service;
 
 /**
- * TODO
+ * A WSRF resource definition.
  *
  * @author Ian Springer (ian DOT springer AT hp DOT com)
  */
 public interface ResourceDefinition extends ResourceCapability
 {
 
+    Service getService();
+
     String getName();
 
-    Service getService();        
+    String getEndpointURL();
 
 }

Modified: incubator/apollo/trunk/src/java/org/apache/ws/resource/impl/ResourceDefinitionImpl.java
Url: http://svn.apache.org/viewcvs/incubator/apollo/trunk/src/java/org/apache/ws/resource/impl/ResourceDefinitionImpl.java?view=diff&rev=124426&p1=incubator/apollo/trunk/src/java/org/apache/ws/resource/impl/ResourceDefinitionImpl.java&r1=124425&p2=incubator/apollo/trunk/src/java/org/apache/ws/resource/impl/ResourceDefinitionImpl.java&r2=124426
==============================================================================
--- incubator/apollo/trunk/src/java/org/apache/ws/resource/impl/ResourceDefinitionImpl.java	(original)
+++ incubator/apollo/trunk/src/java/org/apache/ws/resource/impl/ResourceDefinitionImpl.java	Thu Jan  6 11:55:43 2005
@@ -15,14 +15,17 @@
  *=============================================================================*/
 package org.apache.ws.resource.impl;
 
-import org.apache.ws.resource.ResourceDefinition;
 import org.apache.ws.resource.InvalidWsrfWsdlException;
+import org.apache.ws.resource.ResourceDefinition;
 import org.apache.ws.util.WsdlUtils;
 
-import javax.wsdl.Service;
 import javax.wsdl.Definition;
-import javax.wsdl.PortType;
 import javax.wsdl.Port;
+import javax.wsdl.PortType;
+import javax.wsdl.Service;
+import javax.wsdl.extensions.ExtensibilityElement;
+import javax.wsdl.extensions.soap.SOAPAddress;
+import java.util.List;
 import java.util.Map;
 
 /**
@@ -35,14 +38,15 @@
 
     private Service m_service;
     private String m_name;
+    private String m_endpointURL;
 
     public ResourceDefinitionImpl( Definition def, Service service )
             throws InvalidWsrfWsdlException
     {
         super( def, getResourcePortType( service ) );
         m_service = service;
-        Port port = (Port) m_service.getPorts().values().iterator().next();
-        m_name = port.getName();
+        m_endpointURL = extractEndpointURL( m_service );
+        m_name = extractName( m_endpointURL );
     }
 
     private static PortType getResourcePortType( Service service ) throws InvalidWsrfWsdlException
@@ -50,11 +54,15 @@
         Map portTypes = WsdlUtils.getPortTypes( service );
         if ( portTypes.isEmpty() )
         {
-            throw new InvalidWsrfWsdlException( "WSDL service " + service.getQName() + " is not a valid service, as it does not contain any ports." );
+            throw new InvalidWsrfWsdlException(
+                    "WSDL service " + service.getQName() +
+                    " is not a valid service, as it does not contain any ports." );
         }
         if ( portTypes.size() > 1 )
         {
-            throw new InvalidWsrfWsdlException( "WSDL service " + service.getQName() + " is not a valid WSRF service, as it contains more than one port." );
+            throw new InvalidWsrfWsdlException(
+                    "WSDL service " + service.getQName() +
+                    " is not a valid WSRF service, as it contains more than one port." );
         }
         return (PortType) portTypes.values().iterator().next();
     }
@@ -67,6 +75,45 @@
     public String getName()
     {
         return m_name;
+    }
+
+    public String getEndpointURL()
+    {
+        return null;  //To change body of implemented methods use File | Settings | File Templates.
+    }
+
+    private String extractName( String endpointURL )
+    {
+        if ( endpointURL.endsWith( "/" ) )
+        {
+            endpointURL = endpointURL.substring( 0, endpointURL.length() - 1 );
+        }
+        String name = endpointURL.substring( endpointURL.lastIndexOf( "/" ) + 1 );
+        return name;
+    }
+
+    private String extractEndpointURL( Service service ) throws InvalidWsrfWsdlException
+    {
+        String endpointURL = null;
+        Port port = (Port) service.getPorts().values().iterator().next();
+        List extElems = port.getExtensibilityElements();
+        for ( int i = 0; i < extElems.size(); i++ )
+        {
+            ExtensibilityElement extElem = (ExtensibilityElement) extElems.get( i );
+            if ( extElem instanceof SOAPAddress )
+            {
+                SOAPAddress soapAddr = (SOAPAddress) extElem;
+                endpointURL = soapAddr.getLocationURI();
+                break;
+            }
+        }
+        if ( endpointURL == null )
+        {
+            throw new InvalidWsrfWsdlException(
+                    "Failed to obtain service endpoint URL from " + m_service.getQName() +
+                    " service's wsdl:port/soap:address/@location attribute" );
+        }
+        return endpointURL;
     }
 
 }

---------------------------------------------------------------------
To unsubscribe, e-mail: apollo-dev-unsubscribe@ws.apache.org
For additional commands, e-mail: apollo-dev-help@ws.apache.org