which handles YAML-serialized messages. A top-level "type" key in the
YAML determines the action dispatched to.
+=head1 METHODS
+
+=head2 begin
+
+Deserializes the request into C<< $c->stash->{request} >>
+
+=head2 default
+
+Dispatches to method named by the key C<< $c->stash->{request}->{type} >>
+
+=head2 end
+
+Serializes the response from C<< $c->stash->{response} >>
+
=cut
__PACKAGE__->config( serializer => 'YAML' );
# Custom error handler - steal errors from catalyst and dump them into
# the stash, to get them serialized out as the reply.
if (scalar @{$c->error}) {
- my $error = join "\n", @{$c->error};
- $c->stash->{response} = { status => 'ERROR', error => $error };
+ $c->log->error($_) for @{$c->error}; # Log errors in Catalyst
+ my $error = join "\n", @{$c->error};
+ $c->stash->{response} = { status => 'ERROR', error => $error };
$output = $s->serialize( $c->stash->{response} );
$c->clear_errors;
$c->response->status(400);