NAME
XML::Compile::SOAP11::Operation - defines a SOAP11 interaction
INHERITANCE
XML::Compile::SOAP11::Operation
is a XML::Compile::SOAP::Operation
SYNOPSIS
# object created by XML::Compile::WSDL*
my $op = $wsdl->operation('GetStockPrices');
$op->explain($wsdl, PERL => 'INPUT', recurse => 1);
DESCRIPTION
Objects of this type define one possible SOAP11 interaction, either client side or server side.
METHODS
Constructors
- XML::Compile::SOAP11::Operation->new(OPTIONS)
-
input_def
,output_def
andfault_def
are HASHes which contain the input and output message header, body and fault-header definitions in WSDL1.1 style.-Option --Defined in --Default action XML::Compile::SOAP::Operation undef endpoints XML::Compile::SOAP::Operation [] fault_def <undef> input_def <undef> kin XML::Compile::SOAP::Operation <required> nam XML::Compile::SOAP::Operation <required> output_def <undef> schemas XML::Compile::SOAP::Operation <required> style 'document' transport XML::Compile::SOAP::Operation 'HTTP'
Accessors
- $obj->bindingName()
- $obj->clientClass()
- $obj->endPoints()
- $obj->kind()
- $obj->name()
- $obj->portName()
- $obj->schemas()
- $obj->serverClass()
- $obj->serviceName()
- $obj->soapAction()
- $obj->style()
- $obj->version()
- $obj->wsaAction('INPUT'|'OUTPUT')
Modify
Operations are often modified by SOAP extensions. See XML::Compile::SOAP::WSA, for instance. Also demonstrated in the FAQ, XML::Compile::SOAP::FAQ.
- $obj->addHeader(('INPUT'|'OUTPUT'|'FAULT'), LABEL, ELEMENT, OPTIONS)
-
Add a header definitions. Many protocols on top of SOAP, like WSS, add headers to the operations which are not specified in the WSDL.
[2.31] When you add a header with same LABEL again, it will get silently ignored unless the ELEMENT type differs.
-Option --Default destination undef mustUnderstand undef
Handlers
- $obj->compileClient(OPTIONS)
-
Returns one CODE reference which handles the processing for this operation. Options
transporter
,transport_hook
, andendpoint
are passed to compileTransporter().You pass that CODE reference an input message of the correct type, as pure Perl HASH structure. An 'request-response' operation will return then answer, or
undef
in case of failure. An 'one-way' operation with returnundef
in case of failure, and a true value when successfull.You cannot pass options for XML::Compile::Schema::compile(), like
<sloppy_integers =
0>>, hooks or typemaps this way. Provide these to the::WSDL
or other::Cache
object which defines the types, vianew
optionopts_rw
and friends. - $obj->compileHandler(OPTIONS)
-
Prepare the routines which will decode the request and encode the answer, as will be run on the server. The XML::Compile::SOAP::Server will connect these. All OPTIONS will get passed to XML::Compile::SOAP11::Server::compileHandler()
-Option --Default callback <required> selector <from input def>
- $obj->compileTransporter(OPTIONS)
Helpers
- $obj->explain(WSDL, FORMAT, DIRECTION, OPTIONS)
-
[since 2.13]
Dump an annotated structure showing how the operation works, helping developers to understand the schema. FORMAT is
PERL
. (XML
is not yet supported)The DIRECTION is
INPUT
, it will return the message which the client sends to the server (input for the server). TheOUTPUT
message is sent as response by the server.All OPTIONS besides those described here are passed to XML::Compile::Schema::template(), when
recurse
is enabled.-Option --Default recurse <false> skip_header <false>
- $obj->parsedWSDL()
-
[2.29] For some purposes, it is useful to get access to the parsed WSDL structure.
Be aware that the structure returned is consided "internal" and strongly influenced by behavior of XML::Compile; backwards compatibility will not be maintained at all cost.
You can use XML::Compile::Schema::template() format
TREE
to get more details about the element types mentioned in this structure.example:
use Data::Dumper; $Data::Dumper::Indent = 1; $Data::Dumper::Quotekeys = 0; print Dumper $op->parsedWSDL;
- XML::Compile::SOAP11::Operation->register(URI, ENVNS)
SEE ALSO
This module is part of XML-Compile-SOAP distribution version 2.34, built on December 21, 2012. Website: http://perl.overmeer.net/xml-compile/
Other distributions in this suite: XML::Compile, XML::Compile::SOAP, XML::Compile::SOAP12, XML::Compile::SOAP::Daemon, XML::Compile::SOAP::WSA, XML::Compile::C14N, XML::Compile::WSS, XML::Compile::WSS::Signature, XML::Compile::Tester, XML::Compile::Cache, XML::Compile::Dumper, XML::Compile::RPC, XML::Rewrite, XML::eXistDB, and XML::LibXML::Simple.
Please post questions or ideas to the mailinglist at http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/xml-compile
For live contact with other developers, visit the #xml-compile
channel on irc.perl.org
.
LICENSE
Copyrights 2007-2012 by [Mark Overmeer]. For other contributors see ChangeLog.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See http://www.perl.com/perl/misc/Artistic.html