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/.