NAME
XML::Compile::SOAP::Daemon::Dancer2 - simple implementation of a WSDL server within Dancer2
SYNOPSIS
package MyDancer2App;
use Dancer2;
use XML::Compile::SOAP::Daemon::Dancer2;
wsdl_endpoint '/calculator', {
wsdl => 'calculator.wsdl',
xsd => [],
implementation_class => 'Calculator',
operations => {
add => sub {
my ( $soap, $data, $dsl ) = @_;
$dsl->error( $dsl->to_dumper( $data ) );
return +{
Result => $data->{parameters}->{x} + $data->{parameters}->{y},
};
},
}
};
DESCRIPTION
XML::Compile::SOAP::Daemon::Dancer2 is a plugin to add a SOAP endpoint to a Dancer2 app
The plugin is Heavily inspired by XML::Compile::SOAP::Daemon::PSGI
The plugin export a keyword wsdl_endpoint, that takes 2 arguments, a route path and an options hashref.
Options available are: * wsdl: name of the wsdl file (under appdir/wsdl) * xsd: an arrayref of xsd file (under appdir/wsdl) * implementation_class: name of class to implement the operations * operations: hashref with soap operation name as key, sub as value * implementation_class : the class needs to do the role XML::Compile::SOAP::Daemon::Dancer2::Role::Implementation
For each operation, define a sub in the implementation class, soapaction_{operation_name}, each sub will be called with the following parameters: $soap, $data, $dsl
operations: each sub will be called with parameters: $soap, $data, $dsl
AUTHOR
Pierre VIGIER <pierre.vigier@gmail.com>
COPYRIGHT
Copyright 2016- Pierre VIGIER
LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.