com.arjuna.webservices11.wsaddr.NativeEndpointReference Maven / Gradle / Ivy
package com.arjuna.webservices11.wsaddr;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.List;
import java.util.Map;
import javax.xml.bind.JAXBContext;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Marshaller;
import javax.xml.bind.annotation.XmlAnyAttribute;
import javax.xml.bind.annotation.XmlAnyElement;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlTransient;
import javax.xml.bind.annotation.XmlType;
import javax.xml.bind.annotation.XmlValue;
import javax.xml.namespace.QName;
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.ws.EndpointReference;
import javax.xml.ws.WebServiceException;
import org.w3c.dom.Element;
/**
* internal representation of endpoint reference
*/
// XmlRootElement allows this class to be marshalled on its own
@XmlRootElement(name = "EndpointReference", namespace = NativeEndpointReference.NS)
@XmlType(name = "EndpointReferenceType", namespace = NativeEndpointReference.NS)
public final class NativeEndpointReference extends EndpointReference
{
protected static final String NS = "http://www.w3.org/2005/08/addressing";
private final static JAXBContext jc = getJaxbContext();
// private but necessary properties for databinding
@XmlElement(name = "Address", namespace = NS)
private Address address;
@XmlElement(name = "ReferenceParameters", namespace = NS)
private Elements referenceParameters;
@XmlElement(name = "Metadata", namespace = NS)
private Elements metadata;
@XmlAnyAttribute
Map attributes;
@XmlAnyElement
List elements;
// not marshalled
private QName serviceName;
private QName endpointName;
private URL wsdlLocation;
public NativeEndpointReference()
{
}
/**
* Creates an EPR from infoset representation
*
* @param source A source object containing valid XmlInfoset
* instance consistent with the W3C WS-Addressing Core
* recommendation.
*
* @throws WebServiceException
* If the source does NOT contain a valid W3C WS-Addressing
* EndpointReference.
* @throws NullPointerException
* If the null
source
value is given
*/
public NativeEndpointReference(Source source)
{
try
{
NativeEndpointReference epr = jc.createUnmarshaller().unmarshal(source, NativeEndpointReference.class).getValue();
this.address = epr.address;
this.metadata = epr.metadata;
this.referenceParameters = epr.referenceParameters;
}
catch (JAXBException e)
{
throw new WebServiceException("Error unmarshalling NativeEndpointReference ", e);
}
catch (ClassCastException e)
{
throw new WebServiceException("Source did not contain NativeEndpointReference", e);
}
}
@XmlTransient
public String getAddress()
{
return address != null ? address.getUri() : null;
}
public void setAddress(String address)
{
this.address = new Address(address);
}
@XmlTransient
public QName getServiceName()
{
return serviceName;
}
public void setServiceName(QName serviceName)
{
this.serviceName = serviceName;
}
@XmlTransient
public QName getEndpointName()
{
return endpointName;
}
public void setEndpointName(QName endpointName)
{
this.endpointName = endpointName;
}
@XmlTransient
public List getMetadata()
{
return metadata != null ? metadata.getElements() : null;
}
public void setMetadata(List metadata)
{
this.metadata = new Elements(metadata);
}
@XmlTransient
public URL getWsdlLocation()
{
return wsdlLocation;
}
public void setWsdlLocation(String wsdlLocation)
{
try
{
this.wsdlLocation = wsdlLocation != null ? new URL(wsdlLocation) : null;
}
catch (MalformedURLException e)
{
throw new IllegalArgumentException("Invalid URL: " + wsdlLocation);
}
}
@XmlTransient
public List getReferenceParameters()
{
return referenceParameters != null ? referenceParameters.getElements() : null;
}
public void setReferenceParameters(List metadata)
{
this.referenceParameters = new Elements(metadata);
}
/**
* Directly read a NativeEndpointReference from the given source
* instead of leveraging the Provider's readEndpointReference method.
*
* @param eprInfoset
* @return
*/
public static EndpointReference readFrom(Source eprInfoset)
{
if (eprInfoset == null)
throw new NullPointerException("Provided eprInfoset cannot be null");
try
{
return new NativeEndpointReference(eprInfoset);
}
catch (Exception e)
{
throw new WebServiceException(e);
}
}
/**
* {@inheritDoc}
*/
public void writeTo(Result result)
{
try
{
Marshaller marshaller = jc.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FRAGMENT, true);
marshaller.marshal(this, result);
}
catch (JAXBException e)
{
throw new WebServiceException("Error marshalling NativeEndpointReference. ", e);
}
}
private static JAXBContext getJaxbContext()
{
try
{
return JAXBContext.newInstance(new Class[] { NativeEndpointReference.class });
}
catch (JAXBException ex)
{
throw new WebServiceException("Cannot obtain JAXB context", ex);
}
}
private static class Address
{
@XmlValue
String uri;
@XmlAnyAttribute
Map attributes;
protected Address()
{
}
public Address(String uri)
{
this.uri = uri;
}
@XmlTransient
public String getUri()
{
return uri;
}
public void setUri(String uri)
{
this.uri = uri;
}
@XmlTransient
public Map getAttributes()
{
return attributes;
}
public void setAttributes(Map attributes)
{
this.attributes = attributes;
}
}
private static class Elements
{
@XmlAnyElement
List elements;
@XmlAnyAttribute
Map attributes;
protected Elements()
{
}
public Elements(List elements)
{
this.elements = elements;
}
@XmlTransient
public List getElements()
{
return elements;
}
public void setElements(List elements)
{
this.elements = elements;
}
@XmlTransient
public Map getAttributes()
{
return attributes;
}
public void setAttributes(Map attributes)
{
this.attributes = attributes;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy