Provided by: liblemonldap-ng-common-perl_1.9.16-2_all bug

NAME

       Lemonldap::NG::Common::PSGI::Request - HTTP request object for Lemonldap::NG PSGIs

SYNOPSIS

         package My::PSGI;

         use base Lemonldap::NG::Common::PSGI;

         # See Lemonldap::NG::Common::PSGI
         ...

         sub handler {
           my ( $self, $req ) = @_;
           # Do something and return a PSGI response
           # NB: $req is a Lemonldap::NG::Common::PSGI::Request object
           if ( $req->accept eq 'text/plain' ) { ... }

           return [ 200, [ 'Content-Type' => 'text/plain' ], [ 'Body lines' ] ];
         }

DESCRIPTION

       This package provides HTTP request objects used by Lemonldap::NG PSGIs. It contains common
       accessors to work with request

METHODS

   Accessors
       accept

       'Accept' header content.

       encodings

       'Accept-Encoding' header content.

       languages

       'Accept-Language header content.

       cookies

       'Cookie' header content.

       hostname

       'Host' header content.

       remote_ip

       Client IP address.

       port

       Client TCP port.

       method

       HTTP method asked by client (GET/POST/PUT/DELETE).

       scriptname

       SCRIPT_NAME environment variable provided by HTTP server.

       get_server_port

       Server port.

       path

       PATH_INFO content which has been subtracted `scriptname`. So it's the relative path_info
       for REST calls.

       uri

       REQUEST_URI environment variable.

       unparsed_uri

       Same as `uri` but without decoding.

       user

       REMOTE_USER environment variable. It contains username when a server authentication is
       done.

       userData

       Hash reference to be used by Lemonldap::NG::Handler::PSGI. If a server authentication is
       done, it contains:

         { _whatToTrace => `user()` }

       params

       GET parameters.

       body

       Content of POST requests

       error

       Set if an error occurs

       contentType

       Content type of posted datas.

       contentLength

       Length of posted datas.

   Private accessors
       _psgixBuffered

       PSGI psgix.input.buffered variable.

       _psgiInput

       PSGI psgix.input variable.

   Methods
       jsonBodyToObj()

       Get the content of a JSON POST request as Perl object.

SEE ALSO

       <http://lemonldap-ng.org/>, Lemonldap::NG::Portal, Lemonldap::NG::Handler, Plack, PSGI,
       Lemonldap::NG::Common::PSGI, Lemonldap::NG::Common::PSGI::Router, HTML::Template,

AUTHORS

       Clement Oudot, <clem.oudot@gmail.com>
       François-Xavier Deltombe, <fxdeltombe@gmail.com.>
       Xavier Guimard, <x.guimard@free.fr>
       Thomas Chemineau, <thomas.chemineau@gmail.com>

BUG REPORT

       Use OW2 system to report bug or ask for features:
       <https://gitlab.ow2.org/lemonldap-ng/lemonldap-ng/issues>

DOWNLOAD

       Lemonldap::NG is available at
       <http://forge.objectweb.org/project/showfiles.php?group_id=274>

COPYRIGHT AND LICENSE

       Copyright (C) 2015-2016 by Xavier Guimard, <x.guimard@free.fr>
       Copyright (C) 2015-2016 by Clément Oudot, <clem.oudot@gmail.com>

       This library is free software; you can redistribute it and/or modify it under the terms of
       the GNU General Public License as published by the Free Software Foundation; either
       version 2, or (at your option) any later version.

       This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
       without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
       See the GNU General Public License for more details.

       You should have received a copy of the GNU General Public License along with this program.
       If not, see <http://www.gnu.org/licenses/>.