ResourceHandleInternal.h [plain text]
#ifndef ResourceHandleInternal_h
#define ResourceHandleInternal_h
#include "ResourceHandle.h"
#include "ResourceRequest.h"
#include "AuthenticationChallenge.h"
#include "Timer.h"
#if USE(CFNETWORK)
#include <CFNetwork/CFURLConnectionPriv.h>
#endif
#if USE(WININET) || (USE(CURL) && PLATFORM(WIN))
#include <winsock2.h>
#include <windows.h>
#endif
#if USE(CURL)
#include <curl/curl.h>
#include "FormDataStreamCurl.h"
#endif
#if USE(SOUP)
#include <GRefPtr.h>
#define LIBSOUP_USE_UNSTABLE_REQUEST_API
#include <libsoup/soup-request.h>
#include <libsoup/soup.h>
class Frame;
#endif
#if PLATFORM(QT)
class QWebNetworkJob;
namespace WebCore {
class QNetworkReplyHandler;
}
#endif
#if PLATFORM(MAC)
#ifdef __OBJC__
@class NSURLAuthenticationChallenge;
@class NSURLConnection;
#else
class NSURLAuthenticationChallenge;
class NSURLConnection;
#endif
#endif
#ifndef __OBJC__
class NSObject;
#endif
#if PLATFORM(ANDROID)
#include "ResourceLoaderAndroid.h"
#endif
namespace WebCore {
class ResourceHandleClient;
class ResourceHandleInternal {
WTF_MAKE_NONCOPYABLE(ResourceHandleInternal); WTF_MAKE_FAST_ALLOCATED;
public:
ResourceHandleInternal(ResourceHandle* loader, const ResourceRequest& request, ResourceHandleClient* c, bool defersLoading, bool shouldContentSniff)
: m_client(c)
, m_firstRequest(request)
, m_lastHTTPMethod(request.httpMethod())
, status(0)
, m_defersLoading(defersLoading)
, m_shouldContentSniff(shouldContentSniff)
#if USE(CFNETWORK)
, m_connection(0)
#endif
#if USE(WININET)
, m_fileLoadTimer(loader, &ResourceHandle::fileLoadTimer)
, m_internetHandle(0)
, m_connectHandle(0)
, m_requestHandle(0)
, m_sentEndRequest(false)
, m_bytesRemainingToWrite(0)
, m_loadSynchronously(false)
, m_hasReceivedResponse(false)
#endif
#if USE(CURL)
, m_handle(0)
, m_url(0)
, m_customHeaders(0)
, m_cancelled(false)
, m_formDataStream(loader)
#endif
#if USE(SOUP)
, m_cancelled(false)
, m_buffer(0)
, m_bodySize(0)
, m_bodyDataSent(0)
, m_gotChunkHandler(0)
#endif
#if PLATFORM(QT)
, m_job(0)
#endif
#if PLATFORM(MAC)
, m_startWhenScheduled(false)
, m_needsSiteSpecificQuirks(false)
, m_currentMacChallenge(nil)
#endif
, m_scheduledFailureType(ResourceHandle::NoFailure)
, m_failureTimer(loader, &ResourceHandle::fireFailure)
{
const KURL& url = m_firstRequest.url();
m_user = url.user();
m_pass = url.pass();
m_firstRequest.removeCredentials();
}
~ResourceHandleInternal();
ResourceHandleClient* client() { return m_client; }
ResourceHandleClient* m_client;
ResourceRequest m_firstRequest;
String m_lastHTTPMethod;
String m_user;
String m_pass;
Credential m_initialCredential;
int status;
bool m_defersLoading;
bool m_shouldContentSniff;
#if USE(CFNETWORK)
RetainPtr<CFURLConnectionRef> m_connection;
#endif
#if PLATFORM(MAC) && !USE(CFNETWORK)
RetainPtr<NSURLConnection> m_connection;
RetainPtr<WebCoreResourceHandleAsDelegate> m_delegate;
RetainPtr<id> m_proxy;
#endif
#if PLATFORM(MAC)
bool m_startWhenScheduled;
bool m_needsSiteSpecificQuirks;
#endif
#if USE(WININET)
Timer<ResourceHandle> m_fileLoadTimer;
HINTERNET m_internetHandle;
HINTERNET m_connectHandle;
HINTERNET m_requestHandle;
bool m_sentEndRequest;
Vector<char> m_formData;
size_t m_bytesRemainingToWrite;
bool m_loadSynchronously;
bool m_hasReceivedResponse;
String m_redirectUrl;
#endif
#if USE(CURL)
CURL* m_handle;
char* m_url;
struct curl_slist* m_customHeaders;
ResourceResponse m_response;
bool m_cancelled;
FormDataStream m_formDataStream;
Vector<char> m_postBytes;
#endif
#if USE(SOUP)
GRefPtr<SoupMessage> m_soupMessage;
ResourceResponse m_response;
bool m_cancelled;
GRefPtr<SoupRequest> m_soupRequest;
GRefPtr<GInputStream> m_inputStream;
GRefPtr<GCancellable> m_cancellable;
char* m_buffer;
unsigned long m_bodySize;
unsigned long m_bodyDataSent;
RefPtr<NetworkingContext> m_context;
gulong m_gotChunkHandler;
#endif
#if PLATFORM(QT)
QNetworkReplyHandler* m_job;
RefPtr<NetworkingContext> m_context;
#endif
#if PLATFORM(MAC)
NSURLAuthenticationChallenge *m_currentMacChallenge;
#endif
#if PLATFORM(ANDROID)
RefPtr<ResourceLoaderAndroid> m_loader;
#endif
AuthenticationChallenge m_currentWebChallenge;
ResourceHandle::FailureType m_scheduledFailureType;
Timer<ResourceHandle> m_failureTimer;
};
}
#endif // ResourceHandleInternal_h