NAME

CGI::Application::Dispatch::Server - A simple HTTP server for developing with CGI::Application::Dispatch

SYNOPSIS

use CGI::Application::Dispatch::Server;

my $server = CGI::Application::Dispatch::Server->new( 
           class    => 'MyClass::Dispatch' 
           root_dir => '/home/project/www',
 );
$server->run;

DESCRIPTION

This is a simple HTTP server for for use during development with CGI::Application::Dispatch.

It's a helpful tool for working on a private copy of a website on a personal computer. It's especially useful for working offline when you don't have easy access to a full-blown webserver.

If you have customized dispatch args, it's recommended that you put them in their own class, as described in the CGI::Application::Dispatch docs. That way, they can be accessed directly through CGI::Application::Dispatch, or through here.

METHODS

new()

my $server = CGI::Application::Dispatch::Server->new( 
      port     => '80',                # optional, defaults to 8080
      class    => 'MyClass::Dispatch', # optional, defaults CGI::Application::Dispatch
      root_dir => './alphasite',       # optional, defaults to "."
);
 

Initialize the server. If you've subclassed CGI::Application::Dispatch to provide your own dispatch_args(), let us know that here.

If you are also serving some static content, define "root_dir" with the root directory of this content.

Other Methods You Probably Don't Need to Know About

dispatch_args()

$server->dispatch_args(\%override_args);

This accepts a hashref of arguments and merges it into CGI::Application::Dispatch's dispatch() arguments.

Be aware that this is a shallow merge, so a top level key name in the new hash will completely replace one in the old hash with the same name.

It is recommended that you put your dispatch args in a separate class instead, as mentioned in the DESCRIPTION.

handle_request()

$self->handle_request($cgi);

This will check the request URI and handle it appropriately, printing to STDOUT upon success. There's generally no reason to call this directly.

CAVEATS

This is a subclass of HTTP::Server::Simple and all of its caveats apply here as well.

BUGS

If you are not sure the behavior is a bug, please discuss it on the cgiapp mailing list ( cgiapp@lists.erlbaum.net ). If you feel certain if you have found a bug, please report it through rt.cpan.org.

ACKNOWLEDGEMENTS

This module was cloned from CGI::Application::Server, which in turn borrowed significant parts from HTTP::Request::AsCGI.

CONTRIBUTORS

George Hartzell <hartzell@alerce.com> Mark Stosberg

COPYRIGHT AND LICENSE

Copyright 2006 by George Hartzell

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.