Battery Status API: add UMA logging for Linux.
[chromium-blink-merge.git] / content / browser / renderer_host / socket_stream_host.h
blobda4716c00af2ea13f37c47fc2b75b29b3950e40b
1 // Copyright (c) 2012 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 CONTENT_BROWSER_RENDERER_HOST_SOCKET_STREAM_HOST_H_
6 #define CONTENT_BROWSER_RENDERER_HOST_SOCKET_STREAM_HOST_H_
8 #include <vector>
10 #include "base/memory/ref_counted.h"
11 #include "net/socket_stream/socket_stream.h"
13 class GURL;
15 namespace net {
16 class SocketStreamJob;
17 class URLRequestContext;
18 class SSLInfo;
19 } // namespace net
21 namespace content {
23 // Host of SocketStreamHandle. Each SocketStreamHandle will have an unique
24 // socket_id assigned by SocketStreamHost constructor. If socket id is
25 // kNoSocketId, there is no SocketStreamHost. Each SocketStreamHost has
26 // SocketStream to manage bi-directional communication over socket stream. The
27 // lifetime of an instance of this class is completely controlled by the
28 // SocketStreamDispatcherHost.
29 class SocketStreamHost {
30 public:
31 SocketStreamHost(net::SocketStream::Delegate* delegate,
32 int child_id,
33 int render_frame_id,
34 int socket_id);
35 ~SocketStreamHost();
37 // Gets socket_id associated with |socket|.
38 static int SocketIdFromSocketStream(const net::SocketStream* socket);
40 int render_frame_id() const { return render_frame_id_; }
41 int socket_id() const { return socket_id_; }
43 // Starts to open connection to |url|.
44 void Connect(const GURL& url, net::URLRequestContext* request_context);
46 // Sends |data| over the socket stream.
47 // socket stream must be open to send data.
48 // Returns true if the data is put in transmit buffer in socket stream.
49 // Returns false otherwise (transmit buffer exceeds limit, or socket
50 // stream is closed).
51 bool SendData(const std::vector<char>& data);
53 // Closes the socket stream.
54 void Close();
56 // Following CancelWithError, CancelWithSSLError, and ContinueDespiteError
57 // will be called by net::SocketStream::Delegate in OnSSLCertificateError.
58 // CancelWithError Cancels the connection because of an error.
59 // |error| is net::Error which represents the error.
60 void CancelWithError(int error);
62 // Cancels the connection because of receiving a certificate with an error.
63 void CancelWithSSLError(const net::SSLInfo& ssl_info);
65 // Continue to establish the connection in spite of an error.
66 void ContinueDespiteError();
68 private:
69 net::SocketStream::Delegate* delegate_;
70 int child_id_;
71 int render_frame_id_;
72 int socket_id_;
74 scoped_refptr<net::SocketStreamJob> job_;
76 DISALLOW_COPY_AND_ASSIGN(SocketStreamHost);
79 } // namespace content
81 #endif // CONTENT_BROWSER_RENDERER_HOST_SOCKET_STREAM_HOST_H_