NAME
Data::Conveyor::Service::Methods - service method definitions
SYNOPSIS
package My::Service::Methods;
use warnings;
use strict;
use base 'Data::Conveyor::Service::Methods';
sub SERVICE_METHODS {
domain_tickets => {
object => 'ticket',
$_[0]->PARAMS(
"+domain|d=s Domain name.",
"?limit|l=s Limit number of rows returned.",
),
description => <<EODESC,
Show tickets for a domain.
This function respects the limit option and shows the most recent tickets for
the domain.
If the domain name starts with ':', you can use enhanced UTF-8 notation (see
the eutf2ace command) as well as HTML entities.
EODESC
examples => [
{ domain => 'foo.at' },
{ domain => 'xn--brse-5qa.at' },
{ domain => ':b\x{F6}rse.at' },
{ domain => ':börse.at' },
],
};
1;
DESCRIPTION
The service methods and interfaces make it possible to service the machinery while it is running.
WRITING A NEW SERVICE METHOD
As seen in the synopsis, you're probably going to have a separate class derived from Data::Conveyor::Service::Methods which you use to define your custom service methods in.
In the SERVICE_METHODS
hash, which will be collected using Data::Inherited's every_hash()
, you have to write the definition of your service methods.
You have to specify the method name and the object type - see the environment classes' GENERAL_CLASS_NAME_HASH
for details - on which the method is called. You also have to specify the number and types of parameters which the method takes. You can optionally give a description and examples of usage.
There are some shorthands which make that job easier. If you adhere to certain naming conventions, it gets easier still.
The example in the synopsis defines a service method called domain_tickets
, which is called on the ticket class, meaning the class implementing the ticket object type as defined in the environment. Because the method name is not defined, the method is expected to be called sif_domain_tickets
. If it was called something different, you could specify the name using the method
key within the specification hash.
As you can see from the description, it shows tickets regarding a certain domain - the service method is intended to be used within a domain registry. The method takes two paramaeters.
The first one specifies the domain name. It is mandatory, indicated by the plus sign at the beginning of the parameter specification. For service interfaces that support parameter name abbreviations (e.g., the shell service interface), the parameter can be abbreviated to d
. The =s
tells us that it takes a string argument.
The second argument is used to limit the number of resulting rows that is returned by the service method. It too has an abbreviation, l
, but it is optional, as indicated by the question mark at the beginning of the parameter specification. It too takes a string argument. Actually, only a numeric argument will make sense, but that's for the service method implementation to check.
Each service interface - shell and SOAP, for example - will, upon startup, ask the service methods object for the specifications of all the service methods it knows. This is, as has been noted, done by combining the output of all the SERVICE_METHODS()
down the class hierarchy. The service interface will then interpret these specifications according to its own design.
Therefore each service interface is just a wrapper around the service methods.
For example, for the shell service interface, there is a help
command giving details about the service methods. These details are taken directly from the specification. Parameters given to the service interface call are also checked against the service method's parameter specifications.
A service interface doesn't have to use all of the information contained in the specification. For example, the SOAP service interface does not support parameter name abbreviations, so it doesn't use them.
Let's look at the actual implementation of the service method. To continue the example given in the synopsis, here is a sample implementation of the domain_tickets
service method:
sub sif_domain_tickets {
my ($self, %opt) = @_;
assert_getopt $opt{domain}, 'Called without domain name.';
assert_getopt $opt{limit}, 'Called without limit.';
$self->delegate->make_obj('service_result_tabular')->set_from_rows(
limit => $limit,
fields => [ qw/ticket_no stage status ticket_type origin
real effective mdate/ ],
rows => scalar $self->storage->get_object_tickets(
normalize_to_ace($opt{domain}), $opt{limit},
),
);
}
The relevant things here are that the service method gets its arguments in a hash, first uses assert_getopt()
to check the existence of arguments, then it constructs a tabular service result object which it populates with the results from a storage call. Each service method gets its arguments in a hash. Each service method needs to construct a service result object (tabular or otherwise) in which it has to return the results. It needs to return this result object - here, the set_from_rows()
call returns the result object.
If anything goes wrong during the the service method call, the method should throw an exception. The service interface will then act upon the exception accordingly. For example, the shell service interface will print the exception's text. assert_getopt()
also throws a special exception, if necessary.
Here is a more detailed explanation of how to specify parameters. The specification given in the synopsis, repeated here:
$_[0]->PARAMS(
"+domain|d=s Domain name.",
"?limit|l=s Limit number of rows returned.",
),
is actually equivalent to:
params => [
{ name => 'domain',
short => 'd',
type => $self->delegate->SIP_STRING,
necessity => $self->delegate->SIP_MANDATORY,
description => 'Domain name.',
},
{ name => 'limit',
short => 'l',
type => $self->delegate->SIP_STRING,
necessity => $self->delegate->SIP_OPTIONAL,
description => 'Limit number of rows returned.',
},
],
You can also give set a default value for a parameter using the default
hash key. The short notation used in the synopsis can be defined as:
<necessity><name>|<short>[=<type>][><default>]
The necessity can be either +
(mandatory) or ?
(optional). 'name' and 'short' are the parameter names. The type can be =s
to indicate that the parameter takes a string value, or empty to indicate a boolean parameter. 'type' and 'default' are optional.
TAGS
If you talk about this module in blogs, on del.icio.us or anywhere else, please use the dataconveyor
tag.
BUGS AND LIMITATIONS
No bugs have been reported.
Please report any bugs or feature requests to bug-data-conveyor@rt.cpan.org
, or through the web interface at http://rt.cpan.org.
INSTALLATION
See perlmodinstall for information and options on installing Perl modules.
AVAILABILITY
The latest version of this module is available from the Comprehensive Perl Archive Network (CPAN). Visit <http://www.perl.com/CPAN/> to find a CPAN site near you. Or see <http://www.perl.com/CPAN/authors/id/M/MA/MARCEL/>.
AUTHORS
Marcel Grünauer, <marcel@cpan.org>
Florian Helmberger <fh@univie.ac.at>
Achim Adam <ac@univie.ac.at>
Mark Hofstetter <mh@univie.ac.at>
Heinz Ekker <ek@univie.ac.at>
COPYRIGHT AND LICENSE
Copyright 2007 by Marcel Grünauer
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.