2 * Copyright 2001-2007 Internet2
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 * @file xmltooling/io/HTTPRequest.h
20 * Interface to HTTP requests
23 #ifndef __xmltooling_httpreq_h__
24 #define __xmltooling_httpreq_h__
26 #include <xmltooling/io/GenericRequest.h>
31 namespace xmltooling {
33 #if defined (_MSC_VER)
34 #pragma warning( push )
35 #pragma warning( disable : 4251 )
39 * Interface to HTTP requests.
41 * <p>To supply information from the surrounding web server environment,
42 * a shim must be supplied in the form of this interface to adapt the
43 * library to different proprietary server APIs.
45 * <p>This interface need not be threadsafe.
47 class XMLTOOL_API HTTPRequest : public GenericRequest {
51 virtual ~HTTPRequest() {}
53 bool isSecure() const {
54 return strcmp(getScheme(),"https")==0;
58 * Returns the HTTP method of the request (GET, POST, etc.)
60 * @return the HTTP method
62 virtual const char* getMethod() const=0;
65 * Returns the request URI.
67 * @return the request URI
69 virtual const char* getRequestURI() const=0;
72 * Returns the complete request URL, including scheme, host, port, and URI.
74 * @return the request URL
76 virtual const char* getRequestURL() const=0;
79 * Returns the HTTP query string appened to the request. The query
80 * string is returned without any decoding applied, everything found
81 * after the ? delimiter.
83 * @return the query string
85 virtual const char* getQueryString() const=0;
88 * Returns a request header value.
90 * @param name the name of the header to return
91 * @return the header's value, or an empty string
93 virtual std::string getHeader(const char* name) const=0;
96 * Get a cookie value supplied by the client.
98 * @param name name of cookie
99 * @return cookie value or NULL
101 virtual const char* getCookie(const char* name) const;
104 mutable std::map<std::string,std::string> m_cookieMap;
107 #if defined (_MSC_VER)
108 #pragma warning( pop )
113 #endif /* __xmltooling_httpreq_h__ */