package Mojolicious::Plugin::Mount; use Mojo::Base 'Mojolicious::Plugin'; use Mojo::Server; sub register { my ($self, $app, $conf) = @_; my $path = (keys %$conf)[0]; my $embed = Mojo::Server->new->load_app($conf->{$path})->secrets($app->secrets)->log($app->log); # Extract host my $host; ($host, $path) = ($1 ? qr/^(?:.*\.)?\Q$2\E$/i : qr/^\Q$2\E$/i, $3) if $path =~ m!^(\*\.)?([^/]+)(/.*)?$!; my $route = $app->routes->any($path)->partial(1)->to(app => $embed); return $host ? $route->requires(host => $host) : $route; } 1; =encoding utf8 =head1 NAME Mojolicious::Plugin::Mount - Application mount plugin =head1 SYNOPSIS # Mojolicious my $route = $app->plugin(Mount => {'/prefix' => '/home/sri/foo/script/foo'}); # Mojolicious::Lite my $route = plugin Mount => {'/prefix' => '/home/sri/myapp.pl'}; # Adjust the generated route and mounted application my $example = plugin Mount => {'/example' => '/home/sri/example.pl'}; $example->to(message => 'It works great!'); my $app = $example->pattern->defaults->{app}; $app->config(foo => 'bar'); $app->log(app->log); # Mount application with host plugin Mount => {'example.com' => '/home/sri/myapp.pl'}; # Host and path plugin Mount => {'example.com/myapp' => '/home/sri/myapp.pl'}; # Or even hosts with wildcard subdomains plugin Mount => {'*.example.com/myapp' => '/home/sri/myapp.pl'}; =head1 DESCRIPTION L is a plugin that allows you to mount whole L applications. The code of this plugin is a good example for learning to build new plugins, you're welcome to fork it. See L for a list of plugins that are available by default. =head1 METHODS L inherits all methods from L and implements the following new ones. =head2 register my $route = $plugin->register(Mojolicious->new, {'/foo' => '/some/app.pl'}); Mount L application and return the generated route, which is usually a L object. =head1 SEE ALSO L, L, L. =cut