/* * Copyright (c) 2018-2020, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include #include #include #include #include #include namespace Requests { class Request; class RequestClient final : public IPC::ConnectionToServer , public RequestClientEndpoint { C_OBJECT_ABSTRACT(RequestClient) public: using InitTransport = Messages::RequestServer::InitTransport; explicit RequestClient(IPC::Transport); virtual ~RequestClient() override; RefPtr start_request(ByteString const& method, URL::URL const&, HTTP::HeaderMap const& request_headers = {}, ReadonlyBytes request_body = {}, Core::ProxyData const& = {}); RefPtr websocket_connect(const URL::URL&, ByteString const& origin = {}, Vector const& protocols = {}, Vector const& extensions = {}, HTTP::HeaderMap const& request_headers = {}); void ensure_connection(URL::URL const&, ::RequestServer::CacheLevel); bool stop_request(Badge, Request&); bool set_certificate(Badge, Request&, ByteString, ByteString); private: virtual void die() override; virtual void request_started(i32, IPC::File) override; virtual void request_finished(i32, u64, RequestTimingInfo, Optional) override; virtual void certificate_requested(i32) override; virtual void headers_became_available(i32, HTTP::HeaderMap, Optional, Optional) override; virtual void websocket_connected(i64 websocket_id) override; virtual void websocket_received(i64 websocket_id, bool, ByteBuffer) override; virtual void websocket_errored(i64 websocket_id, i32) override; virtual void websocket_closed(i64 websocket_id, u16, ByteString, bool) override; virtual void websocket_ready_state_changed(i64 websocket_id, u32 ready_state) override; virtual void websocket_subprotocol(i64 websocket_id, ByteString subprotocol) override; virtual void websocket_certificate_requested(i64 websocket_id) override; HashMap> m_requests; HashMap> m_websockets; i64 m_next_websocket_id { 0 }; }; }