| /* |
| * Copyright (C) 2009 Google Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are |
| * met: |
| * |
| * * Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * * Redistributions in binary form must reproduce the above |
| * copyright notice, this list of conditions and the following disclaimer |
| * in the documentation and/or other materials provided with the |
| * distribution. |
| * * Neither the name of Google Inc. nor the names of its |
| * contributors may be used to endorse or promote products derived from |
| * this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #ifndef WebURLResponse_h |
| #define WebURLResponse_h |
| |
| #include "WebCommon.h" |
| #include "WebPrivateOwnPtr.h" |
| |
| #if WEBKIT_IMPLEMENTATION |
| namespace WebCore { class ResourceResponse; } |
| #endif |
| |
| namespace WebKit { |
| |
| class WebCString; |
| class WebHTTPHeaderVisitor; |
| class WebHTTPLoadInfo; |
| class WebString; |
| class WebURL; |
| class WebURLLoadTiming; |
| class WebURLResponsePrivate; |
| |
| class WebURLResponse { |
| public: |
| enum HTTPVersion { Unknown, HTTP_0_9, HTTP_1_0, HTTP_1_1 }; |
| |
| class ExtraData { |
| public: |
| virtual ~ExtraData() { } |
| }; |
| |
| ~WebURLResponse() { reset(); } |
| |
| WebURLResponse() : m_private(0) { } |
| WebURLResponse(const WebURLResponse& r) : m_private(0) { assign(r); } |
| WebURLResponse& operator=(const WebURLResponse& r) |
| { |
| assign(r); |
| return *this; |
| } |
| |
| explicit WebURLResponse(const WebURL& url) : m_private(0) |
| { |
| initialize(); |
| setURL(url); |
| } |
| |
| WEBKIT_EXPORT void initialize(); |
| WEBKIT_EXPORT void reset(); |
| WEBKIT_EXPORT void assign(const WebURLResponse&); |
| |
| WEBKIT_EXPORT bool isNull() const; |
| |
| WEBKIT_EXPORT WebURL url() const; |
| WEBKIT_EXPORT void setURL(const WebURL&); |
| |
| WEBKIT_EXPORT unsigned connectionID() const; |
| WEBKIT_EXPORT void setConnectionID(unsigned); |
| |
| WEBKIT_EXPORT bool connectionReused() const; |
| WEBKIT_EXPORT void setConnectionReused(bool); |
| |
| WEBKIT_EXPORT WebURLLoadTiming loadTiming(); |
| WEBKIT_EXPORT void setLoadTiming(const WebURLLoadTiming&); |
| |
| WEBKIT_EXPORT WebHTTPLoadInfo httpLoadInfo(); |
| WEBKIT_EXPORT void setHTTPLoadInfo(const WebHTTPLoadInfo&); |
| |
| WEBKIT_EXPORT double responseTime() const; |
| WEBKIT_EXPORT void setResponseTime(double); |
| |
| WEBKIT_EXPORT WebString mimeType() const; |
| WEBKIT_EXPORT void setMIMEType(const WebString&); |
| |
| WEBKIT_EXPORT long long expectedContentLength() const; |
| WEBKIT_EXPORT void setExpectedContentLength(long long); |
| |
| WEBKIT_EXPORT WebString textEncodingName() const; |
| WEBKIT_EXPORT void setTextEncodingName(const WebString&); |
| |
| WEBKIT_EXPORT WebString suggestedFileName() const; |
| WEBKIT_EXPORT void setSuggestedFileName(const WebString&); |
| |
| WEBKIT_EXPORT HTTPVersion httpVersion() const; |
| WEBKIT_EXPORT void setHTTPVersion(HTTPVersion); |
| |
| WEBKIT_EXPORT int httpStatusCode() const; |
| WEBKIT_EXPORT void setHTTPStatusCode(int); |
| |
| WEBKIT_EXPORT WebString httpStatusText() const; |
| WEBKIT_EXPORT void setHTTPStatusText(const WebString&); |
| |
| WEBKIT_EXPORT WebString httpHeaderField(const WebString& name) const; |
| WEBKIT_EXPORT void setHTTPHeaderField(const WebString& name, const WebString& value); |
| WEBKIT_EXPORT void addHTTPHeaderField(const WebString& name, const WebString& value); |
| WEBKIT_EXPORT void clearHTTPHeaderField(const WebString& name); |
| WEBKIT_EXPORT void visitHTTPHeaderFields(WebHTTPHeaderVisitor*) const; |
| |
| WEBKIT_EXPORT double lastModifiedDate() const; |
| WEBKIT_EXPORT void setLastModifiedDate(double); |
| |
| WEBKIT_EXPORT long long appCacheID() const; |
| WEBKIT_EXPORT void setAppCacheID(long long); |
| |
| WEBKIT_EXPORT WebURL appCacheManifestURL() const; |
| WEBKIT_EXPORT void setAppCacheManifestURL(const WebURL&); |
| |
| // A consumer controlled value intended to be used to record opaque |
| // security info related to this request. |
| WEBKIT_EXPORT WebCString securityInfo() const; |
| WEBKIT_EXPORT void setSecurityInfo(const WebCString&); |
| |
| #if WEBKIT_IMPLEMENTATION |
| WebCore::ResourceResponse& toMutableResourceResponse(); |
| const WebCore::ResourceResponse& toResourceResponse() const; |
| #endif |
| |
| // Flag whether this request was served from the disk cache entry. |
| WEBKIT_EXPORT bool wasCached() const; |
| WEBKIT_EXPORT void setWasCached(bool); |
| |
| // Flag whether this request was loaded via the SPDY protocol or not. |
| // SPDY is an experimental web protocol, see http://dev.chromium.org/spdy |
| WEBKIT_EXPORT bool wasFetchedViaSPDY() const; |
| WEBKIT_EXPORT void setWasFetchedViaSPDY(bool); |
| |
| // Flag whether this request was loaded after the TLS/Next-Protocol-Negotiation was used. |
| // This is related to SPDY. |
| WEBKIT_EXPORT bool wasNpnNegotiated() const; |
| WEBKIT_EXPORT void setWasNpnNegotiated(bool); |
| |
| // Flag whether this request was made when "Alternate-Protocol: xxx" |
| // is present in server's response. |
| WEBKIT_EXPORT bool wasAlternateProtocolAvailable() const; |
| WEBKIT_EXPORT void setWasAlternateProtocolAvailable(bool); |
| |
| // Flag whether this request was loaded via an explicit proxy (HTTP, SOCKS, etc). |
| WEBKIT_EXPORT bool wasFetchedViaProxy() const; |
| WEBKIT_EXPORT void setWasFetchedViaProxy(bool); |
| |
| // Flag whether this request is part of a multipart response. |
| WEBKIT_EXPORT bool isMultipartPayload() const; |
| WEBKIT_EXPORT void setIsMultipartPayload(bool); |
| |
| // This indicates the location of a downloaded response if the |
| // WebURLRequest had the downloadToFile flag set to true. This file path |
| // remains valid for the lifetime of the WebURLLoader used to create it. |
| WEBKIT_EXPORT WebString downloadFilePath() const; |
| WEBKIT_EXPORT void setDownloadFilePath(const WebString&); |
| |
| // Remote IP address of the socket which fetched this resource. |
| WEBKIT_EXPORT WebString remoteIPAddress() const; |
| WEBKIT_EXPORT void setRemoteIPAddress(const WebString&); |
| |
| // Remote port number of the socket which fetched this resource. |
| WEBKIT_EXPORT unsigned short remotePort() const; |
| WEBKIT_EXPORT void setRemotePort(unsigned short); |
| |
| // Extra data associated with the underlying resource response. Resource |
| // responses can be copied. If non-null, each copy of a resource response |
| // holds a pointer to the extra data, and the extra data pointer will be |
| // deleted when the last resource response is destroyed. Setting the extra |
| // data pointer will cause the underlying resource response to be |
| // dissociated from any existing non-null extra data pointer. |
| WEBKIT_EXPORT ExtraData* extraData() const; |
| WEBKIT_EXPORT void setExtraData(ExtraData*); |
| |
| protected: |
| void assign(WebURLResponsePrivate*); |
| |
| private: |
| WebURLResponsePrivate* m_private; |
| }; |
| |
| } // namespace WebKit |
| |
| #endif |