NAME
perfSONAR_PS::Request - A module that provides an object to interact with for each client request.
DESCRIPTION
This module is to be treated as an object representing a request from a user. The object can be used to get the users request in DOM format as well as set and send the response.
SYNOPSIS
DETAILS
API
new ($package, $call, $http_request)
The 'call' argument is the resonse from HTTP::Daemon->accept(). The request is the actual http request from the user. In general, it can be obtained from the call variable specified above using the '->get_request' function. If it is unspecified, new will try to obtain the request from $call directly.
getURI($self)
Returns the URI of the given request
setRequest($self, $request)
(Re-)Sets the request from the client. The request must be a HTT::Daemon::ClientConn object.
getURI($self)
Returns the URI for the specified request.
getRawRequest($self)
Returns the request as it was given to the object(i.e. the underlying HTTP::Daemon::ClientConn object).
getRequest($self)
Returns the request from the client as a DOM tree rooted at the 'nmwg:message' element.
getRequestAsXPath($self)
Gets and returns the request as an XPath object.
getRequestDOM($self)
Gets and returns the contents of the request as a DOM object.
setResponse($self, $content)
Sets the response to the content.
setResponseAsXPath($self, $xpath)
Sets the response as an XPath object.
getResponse($self)
Gets and returns the response as a string.
setNamespaces($self,\%ns)
(Re-)Sets the the namespaces in the request.
getNamespaces($self)
Gets and returns the hash containing the namespaces for the given request.
parse($self, $ns, $error)
Parses the request and remaps the elements in the request according to the specified namespaces. It returns -1 on error and 0 if everything parsed.
remapRequest($self, $ns)
Remaps the given request according to the prefix/uri pairs specified in the $ns hash.
finish($self)
Sends the response to the client and closes the connection
SEE ALSO
Exporter, HTTP::Daemon, Log::Log4perl, perfSONAR_PS::Transport XML::XPath, perfSONAR_PS::Common, perfSONAR_PS::Messages
To join the 'perfSONAR-PS' mailing list, please visit:
https://mail.internet2.edu/wws/info/i2-perfsonar
The perfSONAR-PS subversion repository is located at:
https://svn.internet2.edu/svn/perfSONAR-PS
Questions and comments can be directed to the author, or the mailing list. Bugs, feature requests, and improvements can be directed here:
https://bugs.internet2.edu/jira/browse/PSPS
VERSION
$Id:$
AUTHOR
Aaron Brown, aaron@internet2.edu, Jason Zurawski, zurawski@internet2.edu
LICENSE
You should have received a copy of the Internet2 Intellectual Property Framework along with this software. If not, see <http://www.internet2.edu/membership/ip.html>
COPYRIGHT
Copyright (c) 2004-2007, Internet2 and the University of Delaware
All rights reserved.