package ojo; use Mojo::Base -strict; use Mojo::ByteStream 'b'; use Mojo::Collection 'c'; use Mojo::DOM; use Mojo::JSON 'j'; use Mojo::UserAgent; use Mojo::Util qw(dumper monkey_patch); # Silent one-liners $ENV{MOJO_LOG_LEVEL} ||= 'fatal'; # Singleton user agent for one-liners my $UA = Mojo::UserAgent->new; sub import { # Mojolicious::Lite my $caller = caller; eval "package $caller; use Mojolicious::Lite;"; my $server = $UA->server->app($caller->app); $server->app->hook(around_action => sub { local $_ = $_[1]; $_[0]->() }); $UA->max_redirects(10) unless defined $ENV{MOJO_MAX_REDIRECTS}; $UA->proxy->detect unless defined $ENV{MOJO_PROXY}; # The ojo DSL monkey_patch $caller, a => sub { $caller->can('any')->(@_) and return $UA->server->app }, b => \&b, c => \&c, d => sub { _request($UA->build_tx(DELETE => @_)) }, g => sub { _request($UA->build_tx(GET => @_)) }, h => sub { _request($UA->build_tx(HEAD => @_)) }, j => \&j, o => sub { _request($UA->build_tx(OPTIONS => @_)) }, p => sub { _request($UA->build_tx(POST => @_)) }, r => \&dumper, t => sub { _request($UA->build_tx(PATCH => @_)) }, u => sub { _request($UA->build_tx(PUT => @_)) }, x => sub { Mojo::DOM->new(@_) }; } sub _request { my $tx = $UA->start(@_); my ($err, $code) = $tx->error; warn qq/Problem loading URL "@{[$tx->req->url->to_abs]}". ($err)\n/ if $err && !$code; return $tx->res; } 1; =encoding utf8 =head1 NAME ojo - Fun one-liners with Mojo! =head1 SYNOPSIS $ perl -Mojo -E 'say g("mojolicio.us")->dom->at("title")->text' =head1 DESCRIPTION A collection of automatically exported functions for fun Perl one-liners. Ten redirects will be followed by default, you can change this behavior with the MOJO_MAX_REDIRECTS environment variable. $ MOJO_MAX_REDIRECTS=0 perl -Mojo -E 'say g("example.com")->code' Proxy detection is enabled by default, but you can disable it with the MOJO_PROXY environment variable. $ MOJO_PROXY=0 perl -Mojo -E 'say g("example.com")->body' =head1 FUNCTIONS L implements the following functions. =head2 a my $app = a('/hello' => sub { $_->render(json => {hello => 'world'}) }); Create a route with L and return the current L object. The current controller object is also available to actions as C<$_>. See also the L tutorial for more argument variations. $ perl -Mojo -E 'a("/hello" => {text => "Hello Mojo!"})->start' daemon =head2 b my $stream = b('lalala'); Turn string into a L object. $ perl -Mojo -E 'b(g("mojolicio.us")->body)->html_unescape->say' =head2 c my $collection = c(1, 2, 3); Turn list into a L object. =head2 d my $res = d('example.com'); my $res = d('http://example.com' => {DNT => 1} => 'Hi!'); Perform DELETE request with L and return resulting L object. =head2 g my $res = g('example.com'); my $res = g('http://example.com' => {DNT => 1} => 'Hi!'); Perform GET request with L and return resulting L object. $ perl -Mojo -E 'say g("mojolicio.us")->dom("h1, h2, h3")->text' =head2 h my $res = h('example.com'); my $res = h('http://example.com' => {DNT => 1} => 'Hi!'); Perform HEAD request with L and return resulting L object. =head2 j my $bytes = j({foo => 'bar'}); my $array = j($bytes); my $hash = j($bytes); Encode Perl data structure or decode JSON with L. $ perl -Mojo -E 'b(j({hello => "world!"}))->spurt("hello.json")' =head2 o my $res = o('example.com'); my $res = o('http://example.com' => {DNT => 1} => 'Hi!'); Perform OPTIONS request with L and return resulting L object. =head2 p my $res = p('example.com'); my $res = p('http://example.com' => {DNT => 1} => 'Hi!'); Perform POST request with L and return resulting L object. =head2 r my $perl = r({data => 'structure'}); Dump a Perl data structure with L. perl -Mojo -E 'say r(g("example.com")->headers->to_hash)' =head2 t my $res = t('example.com'); my $res = t('http://example.com' => {DNT => 1} => 'Hi!'); Perform PATCH request with L and return resulting L object. =head2 u my $res = u('example.com'); my $res = u('http://example.com' => {DNT => 1} => 'Hi!'); Perform PUT request with L and return resulting L object. =head2 x my $dom = x('
Hello!
'); Turn HTML/XML input into L object. $ perl -Mojo -E 'say x(b("test.html")->slurp)->at("title")->text' =head1 SEE ALSO L, L, L. =cut