calaxb_2.13.1.12.1.source-code.soap11_async.scala.template Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scalaxb_2.13 Show documentation
Show all versions of scalaxb_2.13 Show documentation
scalaxb is an XML data-binding tool for Scala that supports W3C XML Schema (xsd) and wsdl.
The newest version!
package scalaxb
import scala.concurrent.{ Future, ExecutionContext }
case class Soap11Fault[+A](original: Any, detail: Option[A], headers: scala.xml.NodeSeq) extends Exception {
def asFault[B: scalaxb.XMLFormat]: Soap11Fault[B] = Soap11Fault(original, detail map {
case soapenvelope11.Detail(dataRecord :: _, _) => dataRecord.value match {
case node: scala.xml.Node => scalaxb.fromXML[B](node)
case _ => sys.error("unsupported fault: " + toString)
}
case _ => sys.error("unsupported fault: " + toString)
}, headers)
def asNillableFault[B: scalaxb.XMLFormat]: Soap11Fault[Option[B]] = Soap11Fault(original, detail map {
case soapenvelope11.Detail(dataRecord :: _, _) => dataRecord.value match {
case node: scala.xml.Node if scalaxb.Helper.isNil(node) => None
case node: scala.xml.Node => Some(scalaxb.fromXML[B](node))
case _ => sys.error("unsupported fault: " + toString)
}
case _ => sys.error("unsupported fault: " + toString)
}, headers)
override def toString: String = s"""Soap11Fault($original, $detail, $headers)"""
}
trait Soap11ClientsAsync {
this: HttpClientsAsync =>
lazy val soapClient: Soap11ClientAsync = new Soap11ClientAsync {}
def baseAddress: java.net.URI
trait Soap11ClientAsync {
import soapenvelope11._
val SOAP_ENVELOPE11_URI = "http://schemas.xmlsoap.org/soap/envelope/"
def soapRequest(in: Option[Envelope], scope: scala.xml.NamespaceBinding,
address: java.net.URI, webMethod: String, action: Option[java.net.URI])
(implicit ec: ExecutionContext): Future[Envelope] = {
val merged = scalaxb.toScope(((Some("soap11") -> SOAP_ENVELOPE11_URI) ::
scalaxb.fromScope(scope)).distinct: _*)
val r = in map { scalaxb.toXML(_, Some(SOAP_ENVELOPE11_URI), Some("Envelope"), merged) match {
case elem: scala.xml.Elem => elem
case x => sys.error("unexpected non-elem: " + x.toString)
}}
val headers = scala.collection.mutable.Map[String, String]("Content-Type" -> "text/xml; charset=utf-8") ++
(action map { x => "SOAPAction" -> """"%s"""".format(x)})
val ftr: Future[String] = httpClient.request(r map {_.toString} getOrElse {""}, address, headers.toMap)
ftr map { (s: String) =>
try {
val response = scala.xml.XML.loadString(s)
scalaxb.fromXML[Envelope](response)
}
catch {
case e: Exception => sys.error(e.toString + ": " + s)
}
}
}
def requestResponse(body: scala.xml.NodeSeq, headers: scala.xml.NodeSeq, scope: scala.xml.NamespaceBinding,
address: java.net.URI, webMethod: String, action: Option[java.net.URI])
(implicit ec: ExecutionContext):
Future[(scala.xml.NodeSeq, scala.xml.NodeSeq)] = {
val bodyRecords = body.toSeq map { DataRecord(None, None, _) }
val headerOption = headers.toSeq.headOption map { _ =>
Header(headers.toSeq map {DataRecord(None, None, _)}, Map())
}
val envelope = Envelope(headerOption, Body(bodyRecords, Map()), Nil, Map())
buildResponse(soapRequest(Some(envelope), scope, address, webMethod, action))
}
def soapResponse(location: Option[String], params: Map[String, Any],
address: java.net.URI, webMethod: String, action: Option[java.net.URI])
(implicit ec: ExecutionContext):
Future[(scala.xml.NodeSeq, scala.xml.NodeSeq)] = {
buildResponse(soapRequest(None, scala.xml.TopScope, address, webMethod, action))
}
def buildResponse(futureSoapResponse: Future[Envelope])(implicit ec: ExecutionContext):
Future[(scala.xml.NodeSeq, scala.xml.NodeSeq)] = {
futureSoapResponse.map( soapResponse => {
val header: scala.xml.NodeSeq =
soapResponse.Header.toSeq flatMap { header =>
header.any collect {
case DataRecord(_, _, x: scala.xml.Node) => x
}
}
soapResponse.Body.any.headOption match {
case Some(DataRecord(_, _, x: scala.xml.Elem)) if (x.label == "Fault") &&
(x.scope.getURI(x.prefix) == SOAP_ENVELOPE11_URI) =>
val fault = scalaxb.fromXML[soapenvelope11.Fault](x)
throw Soap11Fault(fault, fault.detail, header)
case _ =>
(header, soapResponse.Body.any collect {
case DataRecord(_, _, x: scala.xml.Node) => x
})
}
})
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy