1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_EXTENSIONS_API_SOCKET_TLS_SOCKET_H_
6 #define CHROME_BROWSER_EXTENSIONS_API_SOCKET_TLS_SOCKET_H_
10 #include "extensions/browser/api/socket/socket.h"
11 #include "extensions/browser/api/socket/socket_api.h"
12 #include "extensions/browser/api/socket/tcp_socket.h"
13 #include "net/ssl/ssl_config_service.h"
18 class TransportSecurityState
;
21 namespace extensions
{
25 // TLS Sockets from the chrome.socket and chrome.sockets.tcp APIs. A regular
26 // TCPSocket is converted to a TLSSocket via chrome.socket.secure() or
27 // chrome.sockets.tcp.secure(). The inheritance here is for interface API
28 // compatibility, not for the implementation that comes with it. TLSSocket
29 // does not use its superclass's socket state, so all methods are overridden
30 // here to prevent any access of ResumableTCPSocket's socket state. Except
31 // for the implementation of a write queue in Socket::Write() (a super-super
32 // class of ResumableTCPSocket). That implementation only queues and
33 // serializes invocations to WriteImpl(), implemented here, and does not
34 // touch any socket state.
35 class TLSSocket
: public ResumableTCPSocket
{
37 typedef base::Callback
<void(scoped_ptr
<TLSSocket
>, int)> SecureCallback
;
39 TLSSocket(scoped_ptr
<net::StreamSocket
> tls_socket
,
40 const std::string
& owner_extension_id
);
42 ~TLSSocket() override
;
44 // Most of these methods either fail or forward the method call on to the
45 // inner net::StreamSocket. The remaining few do actual TLS work.
48 void Connect(const std::string
& address
,
50 const CompletionCallback
& callback
) override
;
52 void Disconnect() override
;
54 // Attempts to read |count| bytes of decrypted data from the TLS socket,
55 // invoking |callback| with the actual number of bytes read, or a network
56 // error code if an error occurred.
57 void Read(int count
, const ReadCompletionCallback
& callback
) override
;
59 // Fails. This should have been called on the TCP socket before secure() was
61 bool SetKeepAlive(bool enable
, int delay
) override
;
63 // Fails. This should have been called on the TCP socket before secure() was
65 bool SetNoDelay(bool no_delay
) override
;
67 // Fails. TLSSocket is only a client.
68 int Listen(const std::string
& address
,
71 std::string
* error_msg
) override
;
73 // Fails. TLSSocket is only a client.
74 void Accept(const AcceptCompletionCallback
& callback
) override
;
77 bool IsConnected() override
;
80 bool GetPeerAddress(net::IPEndPoint
* address
) override
;
82 bool GetLocalAddress(net::IPEndPoint
* address
) override
;
85 SocketType
GetSocketType() const override
;
87 // Convert |socket| to a TLS socket. |socket| must be an open TCP client
88 // socket. |socket| must not have a pending read. UpgradeSocketToTLS() must
89 // be invoked in the IO thread. |callback| will always be invoked. |options|
91 // Note: |callback| may be synchronously invoked before
92 // UpgradeSocketToTLS() returns. Currently using the older chrome.socket
93 // version of SecureOptions, to avoid having the older API implementation
94 // depend on the newer one.
95 static void UpgradeSocketToTLS(
97 scoped_refptr
<net::SSLConfigService
> config_service
,
98 net::CertVerifier
* cert_verifier
,
99 net::TransportSecurityState
* transport_security_state
,
100 const std::string
& extension_id
,
101 core_api::socket::SecureOptions
* options
,
102 const SecureCallback
& callback
);
105 int WriteImpl(net::IOBuffer
* io_buffer
,
107 const net::CompletionCallback
& callback
) override
;
109 void OnReadComplete(const scoped_refptr
<net::IOBuffer
>& io_buffer
,
112 scoped_ptr
<net::StreamSocket
> tls_socket_
;
113 ReadCompletionCallback read_callback_
;
116 } // namespace extensions
118 #endif // CHROME_BROWSER_EXTENSIONS_API_SOCKET_TLS_SOCKET_H_