NAME
Squatting::Controller - default controller class for Squatting
SYNOPSIS
package App::Controllers;
use Squatting ':controllers';
our @C = (
C(
Thread => [ '/forum/(\d+)/thread/(\d+)-(\w+)' ],
get => sub {
my ($self, $forum_id, $thread_id, $slug) = @_;
#
# get thread from database...
#
$self->render('thread');
},
post => sub {
my ($self, $forum_id, $thread_id, $slug) = @_;
#
# add post to thread
#
$self->redirect(R('Thread', $forum_id, $thread_id, $slug));
}
)
);
DESCRIPTION
Squatting::Controller is the default controller class for Squatting applications. Its job is to take HTTP requests and construct an appropriate response by setting up output headers and returning content.
API
Object Construction
Squatting::Controller->new($name => \@urls, %methods)
The constructor takes a name, an arrayref or URL patterns, and a hash of method definitions. There is a helper function called C() that makes this slightly less verbose.
$c->clone([ %opts ])
This will create a shallow copy of the controller. You may optionally pass in a hash of options that will be merged into the new clone.
$c->init($cr)
Given a Continuity::Request object, this method will initialize the controller.
HTTP Request Handlers
$c->get(@args)
This method is called when GET requests to the controller are made.
$c->post(@args)
This method is called when POST requests to the controller are made.
Attribute Accessors
The following methods are lvalue subroutines that contain information relevant to the current controller and current request/response cycle.
$c->name
This returns the name of the controller.
$c->urls
This returns the arrayref of URL patterns that the controller responds to.
$c->cr
This returns the Continuity::Request object for the current session.
$c->env
This returns a hashref populated with a CGI-like environment. This is where you'll find the incoming HTTP headers.
$c->input
This returns a hashref containing the incoming CGI parameters.
$c->cookies
This returns a hashref that holds both the incoming and outgoing cookies.
Incoming cookies are just simple scalar values, whereas outgoing cookies are hashrefs that can be passed to CGI::Cookie to construct a cookie string.
$c->state
If you've setup sessions, this method will return the current session data as a hashref.
$c->v
This returns a hashref that represents the outgoing variables for this request. This hashref will be passed to a view's templates when render() is called.
$c->status
This returns an integer representing the outgoing HTTP status code. See HTTP::Status for more details.
$c->headers
This returns a hashref representing the outgoing HTTP headers.
$c->view
This returns the name of the default view for the current request. If it's undefined, the first view in @App::Views::V will be considered the default.
Output
$c->render($template, [ $view ])
This method will return a string generated by the specified template and view. If a view is not specified, the first view object in @App::Views::V will be used.
$c->redirect($path, [ $status ])
This method is a shortcut for setting $c->status to 302 and $c->headers->{Location} to the specified URL. You may optionally pass in a different status code as the second parameter.