5 use lib '/srv/MojoX-Gearman/lib';
8 use Data::Dump qw(dump);
10 # Documentation browser under "/perldoc" (this plugin requires Perl 5.10)
11 plugin 'pod_renderer';
15 $self->render('index');
18 get '/ping_http' => sub {
20 my $gearman = $self->client;
21 my $pong = $gearman->post( "http://localhost:4780/ping" => { Connection => 'close' } => "some data" )->res->body;
23 $self->render( 'ping', pong => $pong );
26 my $gearman = MojoX::Gearman->new; #( ioloop => Mojo::IOLoop->singleton );
27 $gearman->server( $ENV{GEARMAN} || 'localhost:4730' );
29 get '/ping_g' => sub {
31 my $pong = $gearman->req( 'SUBMIT_JOB', 'ping', '', "some data 2" );
33 $self->render( 'ping', pong => $pong );
37 my ( $self, $json ) = @_;
38 #my $data = $self->render( json => $json, partial => 1 );
40 if ( my $callback = $self->param('callback') ) {
41 $data = "$callback($data)";
43 $self->render( data => $data, format => 'js' );
47 get '/g/:call/:args' => [ args => qr/.*/ ] => sub {
49 my $ret = $gearman->req( 'SUBMIT_JOB', $self->param('call'), '', $self->param('args') );
50 warn $self->param('call'), " = ", dump($ret), "\n";
51 die "no result for ", $self->param('call'), ' args: ', $self->param('args') unless defined $ret;
52 _render_jsonp( $self, $ret );
59 % title 'Gearman demo';
60 Welcome to Mojolicious Gearman integration demo!
62 <%= link_to 'HTTP ping' => 'ping_http' %>
63 <%= link_to 'Gearman ping' => 'ping_g' %>
67 pong: <tt><%= $pong %>
71 <pre><%= $dump %></pre>
73 @@ layouts/default.html.ep
75 <head><title><%= title %></title></head>
76 <body><%= content %></body>