View on
MetaCPAN
search.cpan.org is shutting down
For details read Perl NOC. After June 25th this page will redirect to MetaCPAN.org
Jan Henning Thorsen > Toadfarm > Toadfarm::Manual::DSL

Download:
Toadfarm-0.78.tar.gz

Annotate this POD

Website

View/Report Bugs
Source  

NAME ^

Toadfarm::Manual::DSL - Domain specific language for Toadfarm

DESCRIPTION ^

This manual gives an overview of which functions are available when building a Toadfarm script.

FUNCTIONS ^

These functions are exported to the caller namespace by default. See "SYNOPSIS" for example usage.

app

  $app = app;

Used to fetch the Toadfarm / Mojolicious instance that the rest of the functions below are using.

change_root

  change_root qw(--userspec www-data:www-data /path/to/jail);

Used to change user/group and root directory. Note that this require the Toadfarm script to be started as "root", but it also requires that the underlying "chroot" command result in changing the user. Not changing the effective user from "root" (UID=0) will result in an infinite loop.

This function is experimental and subject to change.

See also "sudo".

logging

  logging {
    combined => 0,
    path     => "/path/to/log/file.log",
    level    => "info",
  };

Used to set up Mojo::Log. See "path" in Mojo::Log and "level" in Mojo::Log for details on the accepted values. combined can be set to true to make all the mounted apps use the same Mojo::Log object.

mount

  mount "/path/to/mojo-app" => \%config;
  mount "My::Mojo::App" => \%config;
  mount "My::Mojo::App";

This function will mount a Mojolicious application in the Toadfarm application. An application can either be a full path to the application or a class name. The apps are processed in the order they are defined. This means that the first app that match a given rule will receive the request.

See Toadfarm::Manual::Config for details on %config.

An application without %config is considered to be a "catch all" application, meaning that it will get all the requests that do not match any of the above.

plugin

  plugin "My::Mojo::Plugin" => \%config;
  plugin "AccessLog";

Used to load a Mojolicious::Plugin. In addition to the default Mojolicious::Plugin namespace, this application will also search in the Toadfarm::Plugin:: namespace.

run_as

  run_as $uid;
  run_as $username;

Use "sudo" (might change) to force the script to be run as a given user.

See also "change_root".

secrets

  secrets @str;

Used to set application "secrets" in Mojolicious. A random secret will be set if none is specified.

Note: This function is experimental and might be removed in future release.

start

  start;
  start \@listen, %config;
  start %config;

Used to start the application. Both @listen and %config are optional, but will be used to specify the "SETTINGS" in Mojo::Server::Hypnotoad.

These three examples do the same thing:

  # 1.
  start proxy => 1;
  # 2.
  start ["http://*:8080"], {proxy => 1};
  # 3.
  start {listen => ["http://*:8080"], proxy => 1};

SEE ALSO ^

See also Toadfarm::Manual::Intro.

AUTHOR ^

Jan Henning Thorsen - jhthorsen@cpan.org

syntax highlighting: