JSON::RPC::Server::Apache2 - JSON-RPC sever for mod_perl2 |
JSON::RPC::Server::Apache2 - JSON-RPC sever for mod_perl2
# In apache conf PerlRequire /your/path/start.pl PerlModule MyApp <Location /jsonrpc/API> SetHandler perl-script PerlResponseHandler JSON::RPC::Server::Apache PerlSetVar dispatch "MyApp" PerlSetVar return_die_message 0 </Location> #-------------------------- # In your application class package MyApp; use base qw(JSON::RPC::Procedure); # Perl 5.6 or more than sub echo : Public { # new version style. called by clients # first argument is JSON::RPC::Server object. return $_[1]; } sub sum : Public(a:num, b:num) { # sets value into object member a, b. my ($s, $obj) = @_; # return a scalar value or a hashref or an arryaref. return $obj->{a} + $obj->{b}; } sub a_private_method : Private { # ... can't be called by client } sub sum_old_style { # old version style. taken as Public my ($s, @arg) = @_; return $arg[0] + $arg[1]; }
Gets a client request.
Parses its JSON data.
Passes the server object and the object decoded from the JSON data to your procedure (method).
Takes your returned value (scalar or arrayref or hashref).
Sends a response.
Well, you write your procedure code only.
They are inherited from the the JSON::RPC::Server manpage methods basically. The below methods are implemented in JSON::RPC::Server::Apache2.
the JSON::RPC::Server manpage,
the JSON::RPC::Procedure manpage,
JSON,
http://json-rpc.org/wd/JSON-RPC-1-1-WD-20060807.html,
http://json-rpc.org/wiki/specification,
Makamaka Hannyaharamitu, <makamaka[at]cpan.org>
Copyright 2007-2008 by Makamaka Hannyaharamitu
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
JSON::RPC::Server::Apache2 - JSON-RPC sever for mod_perl2 |