在使用MojoX :: JSON :: RPC :: Service时,为什么我的Mojo测试与FF rest客户端的工作方式不同?

时间:2012-06-15 14:15:57

标签: perl json-rpc mojolicious

我的Mojolicious应用程序模块中有以下代码。当我运行这个时 Test :: Mojo $ t-> post_ok('hosts',encode_json($ json_string)) - > status_is(200),应用程序运行正常。当我使用Firefox休息客户端时,我永远不会通过 add_condition路由修饰符'access'。我抛弃了$ can的结果(在add_condition块中)并且它是'1'。因此,在我看来,这应该继续到控制器(就像我运行测试时那样)。当使用FF rest客户端时 返回404,因为访问条件返回1后没有任何反应。

知道为什么应用程序在这两种情况下会有不同的运作方式吗?

$self->plugin(
    'json_rpc_dispatcher',
    services => {
        '/auth'      => Package::Controller::Auth->new,
        '/user'      => Package::Controller::User->new,
        '/hosts'     => Package::Controller::Hosts->new,
    }   
);  

$self->app->routes->add_condition(
    access => sub {
        my ($rt, $cntrlr, $stuff) = @_; 
        my $sess = $cntrlr->stash('mojo.session');

        my $path = $cntrlr->req->url->path->parts;

        my $can = $self->can_access({ 
            route => $path->[0],
            args  => $sess,
        }); 

        $can && return 1;


        $cntrlr->render_json({
            error => 'Not Authorized',
            ok    => 0,
        }); 
    }   
); 

$self->hook( before_dispatch => sub {

    my $this = shift;

    my $params = $this->tx->req->json;

    if( !$this->session('auth') ) {
    my $login = $self->login({
            user     => $params->{params}{user},
            password => $params->{params}{password},
    });

        return { error => 'Invalid Username or password' } if $login->{error}; 
        my $access = $self->has_access( 
            $params->{params}{user}, $params->{params}{password}
        );

        return { error => 'Invalid credentials' } unless keys %{ $access };

        $this->session( auth => { dn => $params->{params}{user}, perms => $access } );

    }

    else {
        $r->find('auth' )->over('access');
        $r->find('user' )->over('access');
        $r->find('hosts')->over('access');
    }

} );  # hook

1 个答案:

答案 0 :(得分:0)

对不起。这个问题与应用程序或Mojolicious无关(或者甚至perl)。主机名无法正确解析。

好吧,我不知道问题究竟在哪里。使用启动服务器     morbo脚本/ app守护进程-l my.host.name.domain.com无效。

我用的时候     morbo script / app daemon -l 192.168.1.11(其中192.168.1.11是my.host.name.domain.com的ip)。事情开始按预期运作。

现在这些都不起作用。 :(