[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