NAME
Jedi::Request - Request object
VERSION
version 1.004
DESCRIPTION
This object is pass through the route, as a second params. (self, request, response).
You can get data from it, to generate your response
ATTRIBUTES
env
The environment variable, as it received from PSGI. This is a HASH.
path
The end of the path_info, without the road.
Ex: road("/test"), route("/me") # so /test/me/ will give the path /me/
The $ENV{PATH_INFO} is untouch, you can use that method to get the relative PATH.
The path always end with '/'.
params
If method is POST or PUT, it will parse the body, and extract the params.
Otherwise it parse the QUERY_STRING.
It always return an HASH, with:
key => Scalar // [ARRAY of Values]
Ex:
a=1&a=2&a=3&b=4&b=5&b=6&c=1
You receive:
{
a => [1,2,3],
b => [4,5,6],
c => 1
}
uploads
Return the file uploads.
For a request like test@test.txt, the form is :
test => {
filename "test.txt",
headers {
Content-Disposition "form-data; name="test"; filename="test.txt"",
Content-Type "text/plain"
},
name "test",
size 13,
tempname "/var/folders/_1/097rrrdd2s5dwqgd7hp6nlx00000gn/T/X4me5HO7L_.txt"
}
Ex with curl :
curl -F 'test@test.txt' http://localhost:5000/post
You can read the tempname file to get the content. When the request is sent back, the file is automatically removed.
See <HTTP::Body> for more details.
cookies
Parse the HTTP_COOKIE, and return an HASH of ARRAY
Ex:
a=1&b&c; b=4&5&6; c=1
You receive:
{
a => [1,2,3],
b => [4,5,6],
c => [1]
}
remote_address
Try to find the real ip of the user and return the int number of it
METHODS
scheme
Return the scheme from proxied proto or main proto
port
Return server port
host
Return the proxied host or the main host
BUGS
Please report any bugs or feature requests on the bugtracker website https://github.com/celogeek/perl-jedi/issues
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
AUTHOR
celogeek <me@celogeek.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2013 by celogeek <me@celogeek.com>.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.