[Catalyst] Please Help: Aborting a Catalyst request in auto method
Rajesh Kumar Mallah
mallah at redgrape.tech
Sun Apr 16 06:15:00 GMT 2017
Hi ,
I want to return HTTP Status 401 along with a body indicating
the friendly description from my auto method.
so i have below in my auto:
=====================================================
sub auto :Private {
my ( $self, $c ) = @_;
my $path = $c->request->path ;
if ($path !~ /login.html/ && ! $c->session->{username}) {
$c->log->warn('*** Not logged in Authorized ****');
$c->response->status(401);
$c->response->body(qq{Sorry please login to access this
resource});
return 0;
}
return 1;
}
======================================================
However the request proceeds to other part of the chain
and does things which are not required.
===========================================================
[info] *** Request 1 (0.003/s) [839042] [Sun Apr 16 05:23:25 2017] ***
[debug] Path is "/api/rest/articlearticle/list_objects"
[debug] "GET" request for "api/rest/zingyhomes/article_article/" from
"127.0.0.1"
[debug] Query Parameters are:
.-------------------------------------+--------------------------------------.
| Parameter | Value
|
+-------------------------------------+--------------------------------------+
| _ | 1492317689850
|
| callback |
jQuery31001955130972547411_14923176- |
| | 89849
|
| list_count | 5
|
| list_offset | 0
|
'-------------------------------------+--------------------------------------'
[debug] Created session "37077cb431fb8502ac220d4c624b1db2b1217de7"
[warn] *** Not logged in Authorized ****
[debug] end subroutine.
[debug] Response Code: 401; Content-Type: unknown; Content-Length: unknown
[info] Request took 0.069336s (14.423/s)
.------------------------------------------------------------+-----------.
| Action | Time |
+------------------------------------------------------------+-----------+
| /api/rest/articlearticle/begin | 0.057763s |
| /auto | 0.005666s |
<---- I want to break
| /api/rest/articlearticle/end | 0.000543s |
here :-(
| -> /api/rest/articlearticle/serialize | 0.000162s |
'------------------------------------------------------------+-----------'
=================================================================================
Previous discussions has been there
but it did not help me:
http://grokbase.com/t/sc/catalyst/055r77h11s/returning-false-in-auto-action
http://grokbase.com/t/sc/catalyst/083ev978bd/again-die-in-an-action-chain-does-not-break-the-chain
is there anything to halt the request after the appropriate
HTTP Status and
Headers and
Body
as been setup.
Regds
Rajesh Kumar Mallah.
More information about the Catalyst
mailing list