SocketStreamHandleImpl.h [plain text]
#pragma once
#include "CurlStream.h"
#include "SocketStreamHandle.h"
#include <pal/SessionID.h>
#include <wtf/StreamBuffer.h>
namespace WebCore {
class SocketStreamHandleClient;
class StorageSessionProvider;
class SocketStreamHandleImpl : public SocketStreamHandle, public CurlStream::Client {
public:
static Ref<SocketStreamHandleImpl> create(const URL& url, SocketStreamHandleClient& client, PAL::SessionID, const String&, SourceApplicationAuditToken&&, const StorageSessionProvider* provider) { return adoptRef(*new SocketStreamHandleImpl(url, client, provider)); }
virtual ~SocketStreamHandleImpl();
WEBCORE_EXPORT void platformSend(const uint8_t* data, size_t length, Function<void(bool)>&&) final;
WEBCORE_EXPORT void platformSendHandshake(const uint8_t* data, size_t length, const Optional<CookieRequestHeaderFieldProxy>&, Function<void(bool, bool)>&&) final;
WEBCORE_EXPORT void platformClose() final;
private:
WEBCORE_EXPORT SocketStreamHandleImpl(const URL&, SocketStreamHandleClient&, const StorageSessionProvider*);
size_t bufferedAmount() final;
Optional<size_t> platformSendInternal(const uint8_t*, size_t);
bool sendPendingData();
void didOpen(CurlStreamID) final;
void didSendData(CurlStreamID, size_t) final;
void didReceiveData(CurlStreamID, const char*, size_t) final;
void didFail(CurlStreamID, CURLcode) final;
bool isStreamInvalidated() { return m_streamID == invalidCurlStreamID; }
void destructStream();
RefPtr<const StorageSessionProvider> m_storageSessionProvider;
StreamBuffer<uint8_t, 1024 * 1024> m_buffer;
static const unsigned maxBufferSize = 100 * 1024 * 1024;
CurlStreamScheduler& m_scheduler;
CurlStreamID m_streamID { invalidCurlStreamID };
unsigned m_totalSendDataSize { 0 };
};
}