| // Copyright 2015 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef NET_HTTP_HTTP_PROXY_CLIENT_SOCKET_WRAPPER_H_ |
| #define NET_HTTP_HTTP_PROXY_CLIENT_SOCKET_WRAPPER_H_ |
| |
| #include <memory> |
| #include <string> |
| |
| #include "base/macros.h" |
| #include "base/memory/ref_counted.h" |
| #include "base/time/time.h" |
| #include "base/timer/timer.h" |
| #include "net/base/completion_callback.h" |
| #include "net/base/completion_once_callback.h" |
| #include "net/base/host_port_pair.h" |
| #include "net/base/load_timing_info.h" |
| #include "net/http/http_auth_controller.h" |
| #include "net/http/proxy_client_socket.h" |
| #include "net/log/net_log_with_source.h" |
| #include "net/quic/quic_stream_factory.h" |
| #include "net/socket/next_proto.h" |
| #include "net/socket/ssl_client_socket.h" |
| #include "net/socket/ssl_client_socket_pool.h" |
| #include "net/socket/transport_client_socket_pool.h" |
| #include "net/spdy/spdy_session.h" |
| #include "net/traffic_annotation/network_traffic_annotation.h" |
| #include "starboard/types.h" |
| |
| namespace net { |
| |
| class ClientSocketHandle; |
| class IOBuffer; |
| class HttpAuthCache; |
| class HttpResponseInfo; |
| class HttpStream; |
| class IOBuffer; |
| class SpdySessionPool; |
| class SSLClientSocketPool; |
| class TransportClientSocketPool; |
| |
| // Class that establishes connections by calling into the lower layer socket |
| // pools, creates a HttpProxyClientSocket, SpdyProxyClientSocket, or |
| // QuicProxyClientSocket, and then wraps the resulting socket. |
| // |
| // This class is needed to handle auth state across multiple connection. On |
| // auth challenge, this class retains auth state in its AuthController, and can |
| // either send the auth response to the old connection, or establish a new |
| // connection and send the response there. |
| // |
| // TODO(mmenke): Ideally, we'd have a central location store auth state across |
| // multiple connections to the same server instead. |
| class NET_EXPORT_PRIVATE HttpProxyClientSocketWrapper |
| : public ProxyClientSocket { |
| public: |
| HttpProxyClientSocketWrapper( |
| const std::string& group_name, |
| RequestPriority priority, |
| const SocketTag& socket_tag, |
| ClientSocketPool::RespectLimits respect_limits, |
| base::TimeDelta connect_timeout_duration, |
| base::TimeDelta proxy_negotiation_timeout_duration, |
| TransportClientSocketPool* transport_pool, |
| SSLClientSocketPool* ssl_pool, |
| const scoped_refptr<TransportSocketParams>& transport_params, |
| const scoped_refptr<SSLSocketParams>& ssl_params, |
| quic::QuicTransportVersion quic_version, |
| const std::string& user_agent, |
| const HostPortPair& endpoint, |
| HttpAuthCache* http_auth_cache, |
| HttpAuthHandlerFactory* http_auth_handler_factory, |
| SpdySessionPool* spdy_session_pool, |
| #if !defined(QUIC_DISABLED_FOR_STARBOARD) |
| QuicStreamFactory* quic_stream_factory, |
| #endif |
| bool is_trusted_proxy, |
| bool tunnel, |
| const NetworkTrafficAnnotationTag& traffic_annotation, |
| const NetLogWithSource& net_log); |
| |
| // On destruction Disconnect() is called. |
| ~HttpProxyClientSocketWrapper() override; |
| |
| // Returns load state while establishing a connection. Returns |
| // LOAD_STATE_IDLE at other times. |
| LoadState GetConnectLoadState() const; |
| |
| std::unique_ptr<HttpResponseInfo> GetAdditionalErrorState(); |
| |
| // ProxyClientSocket implementation. |
| const HttpResponseInfo* GetConnectResponseInfo() const override; |
| std::unique_ptr<HttpStream> CreateConnectResponseStream() override; |
| int RestartWithAuth(CompletionOnceCallback callback) override; |
| const scoped_refptr<HttpAuthController>& GetAuthController() const override; |
| bool IsUsingSpdy() const override; |
| NextProto GetProxyNegotiatedProtocol() const override; |
| |
| // StreamSocket implementation. |
| int Connect(CompletionOnceCallback callback) override; |
| void Disconnect() override; |
| bool IsConnected() const override; |
| bool IsConnectedAndIdle() const override; |
| const NetLogWithSource& NetLog() const override; |
| bool WasEverUsed() const override; |
| bool WasAlpnNegotiated() const override; |
| NextProto GetNegotiatedProtocol() const override; |
| bool GetSSLInfo(SSLInfo* ssl_info) override; |
| void GetConnectionAttempts(ConnectionAttempts* out) const override; |
| void ClearConnectionAttempts() override; |
| void AddConnectionAttempts(const ConnectionAttempts& attempts) override; |
| int64_t GetTotalReceivedBytes() const override; |
| void ApplySocketTag(const SocketTag& tag) override; |
| |
| // Socket implementation. |
| int Read(IOBuffer* buf, |
| int buf_len, |
| CompletionOnceCallback callback) override; |
| int ReadIfReady(IOBuffer* buf, |
| int buf_len, |
| CompletionOnceCallback callback) override; |
| int CancelReadIfReady() override; |
| int Write(IOBuffer* buf, |
| int buf_len, |
| CompletionOnceCallback callback, |
| const NetworkTrafficAnnotationTag& traffic_annotation) override; |
| int SetReceiveBufferSize(int32_t size) override; |
| int SetSendBufferSize(int32_t size) override; |
| int GetPeerAddress(IPEndPoint* address) const override; |
| int GetLocalAddress(IPEndPoint* address) const override; |
| |
| NetErrorDetails* quic_net_error_details() { return &quic_net_error_details_; } |
| |
| private: |
| enum State { |
| STATE_BEGIN_CONNECT, |
| STATE_TCP_CONNECT, |
| STATE_TCP_CONNECT_COMPLETE, |
| STATE_SSL_CONNECT, |
| STATE_SSL_CONNECT_COMPLETE, |
| STATE_HTTP_PROXY_CONNECT, |
| STATE_HTTP_PROXY_CONNECT_COMPLETE, |
| STATE_SPDY_PROXY_CREATE_STREAM, |
| STATE_SPDY_PROXY_CREATE_STREAM_COMPLETE, |
| STATE_QUIC_PROXY_CREATE_SESSION, |
| STATE_QUIC_PROXY_CREATE_STREAM, |
| STATE_QUIC_PROXY_CREATE_STREAM_COMPLETE, |
| STATE_RESTART_WITH_AUTH, |
| STATE_RESTART_WITH_AUTH_COMPLETE, |
| STATE_NONE, |
| }; |
| |
| void OnIOComplete(int result); |
| |
| // Runs the state transition loop. |
| int DoLoop(int result); |
| |
| // Determine if need to go through TCP or SSL path. |
| int DoBeginConnect(); |
| // Connecting to HTTP Proxy |
| int DoTransportConnect(); |
| int DoTransportConnectComplete(int result); |
| // Connecting to HTTPS Proxy |
| int DoSSLConnect(); |
| int DoSSLConnectComplete(int result); |
| |
| int DoHttpProxyConnect(); |
| int DoHttpProxyConnectComplete(int result); |
| |
| int DoSpdyProxyCreateStream(); |
| int DoSpdyProxyCreateStreamComplete(int result); |
| |
| #if !defined(QUIC_DISABLED_FOR_STARBOARD) |
| int DoQuicProxyCreateSession(); |
| int DoQuicProxyCreateStream(int result); |
| int DoQuicProxyCreateStreamComplete(int result); |
| #endif |
| |
| int DoRestartWithAuth(); |
| int DoRestartWithAuthComplete(int result); |
| |
| void SetConnectTimer(base::TimeDelta duration); |
| void ConnectTimeout(); |
| |
| const HostResolver::RequestInfo& GetDestination(); |
| |
| State next_state_; |
| |
| const std::string group_name_; |
| RequestPriority priority_; |
| const SocketTag initial_socket_tag_; |
| ClientSocketPool::RespectLimits respect_limits_; |
| const base::TimeDelta connect_timeout_duration_; |
| const base::TimeDelta proxy_negotiation_timeout_duration_; |
| |
| TransportClientSocketPool* const transport_pool_; |
| SSLClientSocketPool* const ssl_pool_; |
| const scoped_refptr<TransportSocketParams> transport_params_; |
| const scoped_refptr<SSLSocketParams> ssl_params_; |
| |
| quic::QuicTransportVersion quic_version_; |
| |
| const std::string user_agent_; |
| const HostPortPair endpoint_; |
| SpdySessionPool* const spdy_session_pool_; |
| |
| bool has_restarted_; |
| const bool tunnel_; |
| |
| bool using_spdy_; |
| bool is_trusted_proxy_; |
| NextProto negotiated_protocol_; |
| |
| std::unique_ptr<HttpResponseInfo> error_response_info_; |
| |
| std::unique_ptr<ClientSocketHandle> transport_socket_handle_; |
| std::unique_ptr<ProxyClientSocket> transport_socket_; |
| |
| // Called when a connection is established. Also used when restarting with |
| // AUTH, which will invoke this when ready to restart, after reconnecting |
| // if necessary. |
| CompletionOnceCallback connect_callback_; |
| |
| SpdyStreamRequest spdy_stream_request_; |
| |
| #if !defined(QUIC_DISABLED_FOR_STARBOARD) |
| QuicStreamRequest quic_stream_request_; |
| std::unique_ptr<QuicChromiumClientSession::Handle> quic_session_; |
| #endif |
| |
| scoped_refptr<HttpAuthController> http_auth_controller_; |
| |
| NetLogWithSource net_log_; |
| |
| NetErrorDetails quic_net_error_details_; |
| |
| base::OneShotTimer connect_timer_; |
| |
| // Network traffic annotation for handshaking and setup. |
| const NetworkTrafficAnnotationTag traffic_annotation_; |
| |
| // Time when the connection to the proxy was started. |
| base::TimeTicks connect_start_time_; |
| |
| DISALLOW_COPY_AND_ASSIGN(HttpProxyClientSocketWrapper); |
| }; |
| |
| } // namespace net |
| |
| #endif // NET_HTTP_HTTP_PROXY_CLIENT_SOCKET_WRAPPER_H_ |