NAME

Mojolicious::Plugin::VHost - Mojolicious Plugin that adds VirtualHosts

SYNOPSIS

# Mojolicious
my $config = $self->plugin('JSONConfig', { file => "vhost.conf" });
$self->plugin('VHost', { config => $config });

DESCRIPTION

Mojolicious::Plugin::VHost adds virtualhosts to Mojolicious.

CONFIGURATION

One supported method of configuration is with the JSONConfig plugin. Add vhosts with a config such as:

{
    "host1":{"routes":["VHost::First::Controller"],"static":["public\/first"],"templates":["templates\/first"]},
    "host2":{"routes":["VHost::Another::Controller"],"static":["public\/another"],"templates":["templates\/another"]}
}

host1 and host2 are the Host: header field and must match exactly. The following route format has been tested:

$r->get('/')->to(controller => 'Index', action => 'slash');
$r->get('/:name')->to(controller => 'Index', action => 'slash');

For host1, "/" would route to lib/VHost/First/Index.pm; static files would be in public/first; and templates would be found in templates/first.

A full startup sub is:

sub startup {
  my $self = shift;

  my $config = $self->plugin('JSONConfig', { file => "vhost.conf" });
  $self->plugin('VHost', { config => $config });

  # Router
  my $r = $self->routes;

  $r->get('/')->to(controller => 'Index', action => 'slash');
  $r->get('/:name')->to(controller => 'Index', action => 'slash');
}

METHODS

Mojolicious::Plugin::VHost inherits all methods from Mojolicious::Plugin and implements the following new ones.

register

$plugin->register(Mojolicious->new);

Register plugin in Mojolicious application.

SEE ALSO

Mojolicious, Mojolicious::Guides, http://mojolicio.us.