NAME
Catalyst::TraitFor::Controller::Ping - Provides a ping action for consuming controllers
VERSION
version 0.001
SYNOPSIS
package MyApp::Controller::Foo;
use Moose;
use namespace::autoclean;
BEGIN { extends 'Catalyst::Controller' }
with 'Catalyst::TraitFor::Controller::Ping';
__PACKAGE__->config
(
{
model_name => 'SomeModel',
model_method => 'some_method',
model_method_arguments => [qw/ one two three /],
}
);
...
DESCRIPTION
Ever wanted to monitor a web app? With this simple role, you can easily add an action to "ping" to test if the app is up and running. You can even define a "model_name" and a "model_method" to call so it perihperally tests the app's connection to the database (or some other resource). Simply add exceptions for "ping" in your ACL, and you're good to go.
PUBLIC_ATTRIBUTES
model_name
isa: Str, is: ro
Define a model name to access via $c->model();
model_method
isa: Str, is: ro
Define a method name to call upon the model
model_method_arguments
isa: ArrayRef, is: ro
Define arguments to pass to the method upon the model
PUBLIC_METHODS
ping
:Local
ping is an action added to which ever controller consumes this role that simply returns. If a "model_name" is configured, the model will be gathered via $c->model(). If "model_method" is configured, that method will be called upon the retrived model. If "model_method_arguments" are provided, they will be passed to the model method. The return value is discarded. Only that the method executed without exception matters for ping. Ping will return no content so it doesn't forward to views or anything else.
AUTHOR
Nicholas Perez <nperez@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2010 by Infinity Interactive, Inc..
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.