NAME

Dancer::Plugin::RPC::JSONRPC - Dancer Plugin to register jsonrpc2 methods.

SYNOPSIS

In the Controler-bit:

use Dancer::Plugin::RPC::JSONRPC;
jsonrpc '/endpoint' => {
    publish   => 'pod',
    arguments => ['MyProject::Admin']
};

and in the Model-bit (MyProject::Admin):

package MyProject::Admin;

=for jsonrpc rpc.abilities rpc_show_abilities

=cut

sub rpc_show_abilities {
    return {
        # datastructure
    };
}
1;

DESCRIPTION

This plugin lets one bind an endpoint to a set of modules with the new jsonrpc keyword.

jsonrpc '/endpoint' => \%publisher_arguments;

\%publisher_arguments

callback => $coderef [optional]

The callback will be called just before the actual rpc-code is called from the dispatch table. The arguments are positional: (full_request, method_name).

my $continue = $callback ? $callback->(request(), $method_name) : 1;

The callback should return a HashRef:

on_success

The HashRef should have 1 key:

- success => 1
on_failure

The HashRef should have 3 keys:

- success       => 0
- error_code    => <numeric_code>
- error_message => <error message>
code_wrapper => $coderef [optional]

The codewrapper will be called with these positional arguments:

1. $call_coderef
2. $method_name
3. @arguments

The default code_wrapper-sub is:

sub {
    my $code = shift;
    $code->(@_);
};
publisher => <pod | config | \&code_ref>

The publiser key determines the way one connects the rpc-method name with the actual code.

publisher => 'pod'

This way of publishing enables one to use a special POD directive =for jsonrpc to connect the rpc-method name to the actual code. The directive must be in the same file as where the code resides.

=for jsonrpc admin.someFunction rpc_admin_some_function_name

The POD-publisher needs the arguments value to be an arrayref with package names in it.

publisher => 'config'

This way of publishing requires you to create a dispatch-table in the app's config YAML:

plugins:
    "RPC::JSONRPC":
        '/endpoint':
            'MyProject::Admin':
                admin.someFunction: rpc_admin_some_function_name
            'MyProject::User':
                user.otherFunction: rpc_user_other_function_name

The Config-publisher doesn't use the arguments value of the %publisher_arguments hash.

publisher => \&code_ref

This way of publishing requires you to write your own way of building the dispatch-table. The code_ref you supply, gets the arguments value of the %publisher_arguments hash.

arguments => <anything>

The value of this key depends on the publisher-method chosen.

=for jsonrpc jsonrpc-method-name sub-name

This special POD-construct is used for coupling the jsonrpc-methodname to the actual sub-name in the current package.

INTERNAL

unjson

Deserializes the string as Perl-datastructure.

jsonrpc_error_response

Returns a jsonrpc error response as a hashref.

build_dispatcher_from_config

Creates a (partial) dispatch table from data passed from the (YAML)-config file.

build_dispatcher_from_pod

Creates a (partial) dispatch table from data provided in POD.

COPYRIGHT

(c) MMXIII-MMXVI - Abe Timmerman <abeltje@cpan.org>.