1

私は zabbix を使用しており、zabbix API とやり取りするためのインターフェイスを作成しています。zabbix は jsonrpc インターフェイスを公開しているので、MojoX::JSON::RPC::Service を使用することにしました。私が直面している問題は、Mojolicious::Controller オブジェクトを期待している Mojolicious::Controllers を使用して記述された他のサービスとの対話に直面していることです。MojoX::JSON::RPC::Service を使用する場合、利用可能な Mojolicious::Controller オブジェクトはありません。

my $obj = $rpc_obj->register(
               'retrieve',
               sub {
                    # do stuff
               },
               { with_mojo_tx => 1 }
);

それは「検索」と呼ばれるルートを登録します。ルートがアクセスされ、匿名サブルーチンが実行されると、サブルーチンは Mojo::Transaction::HTTP オブジェクトにのみアクセスできます。

そのため、プラグインやスタッシュ、Mojolicious が提供するその他のものを使用するためのアプリにアクセスすることはできません。Mojolicious::Controller を MojoX::JSON::RPC::Service に組み込む方法はありますか?

Mojolicious::Controller を使用するように書き直すこともできますが、可能であればそれを避けようとしています。

4

1 に答える 1

1

Mojolicious::Controllerからすべての属性を継承するため、MojoX::JSON::RPC::Dispatcherの使用を検討する必要があります。

あらすじ:

# lib/your-application.pm

use base 'Mojolicious';
use MojoX::JSON::RPC::Service;

sub startup {
    my $self = shift;
    my $svc = MojoX::JSON::RPC::Service->new;

    $svc->register(
        'sum',
        sub {
            my @params = @_;
            my $sum = 0;
            $sum += $_ for @params;
            return $sum;
        }
    );

    $self->plugin(
        'json_rpc_dispatcher',
        services => {
           '/jsonrpc' => $svc
        }
    );
}

[更新] フックの例:

package Application;
use Mojo::Base 'Mojolicious';
use Application::Firewall;

# This method will run once at server start
sub startup {
    my $app = shift;

    # Routes
    my $r = $app->routes;

    # Validation Middleware
    $app->hook(
        before_dispatch => sub {
            my $self = shift;
            my $data = $self->req->params->to_hash;
            my $vald = Application::Firewall->new($data);

            # mojolicious bug at the time of coding
            delete $data->{""} if defined $data->{""};

            $app->{input} = {};

            if ( keys %{$data} ) {

                # validation the submitted data
                unless ( $vald->validate( keys %{$data} ) ) {
                    $self->render(
                        text   => join( "", @{ $vald->errors } ),
                        status => 500
                    );
                    return 0;
                }

                # Helper (optional)
                # create a helper to get access to the transformed data
                # if your validation rules had/has filters
                # Note! due to a bug in the params function we must do this
                # (... i know, so what)
                $app->{input} = {
                    map { $_ => $vald->{fields}->{$_}->{value} }
                      keys %{ $vald->{fields} }
                };

            }

            return 1;
        }
    );

    # Normal route to controller * with auto-matic input validation *
    $r->route('/')->to(
        cb => sub {
            my $self = shift;
            $self->render(
                text => 'Hello ' . ( $app->{input}->{foobar} || 'World' ),
                status => 200
            );
        }
    );
}

1;
于 2012-05-10T20:34:16.517 に答える