Index: content/browser/renderer_host/pepper/pepper_tcp_socket_message_filter.h |
diff --git a/content/browser/renderer_host/pepper/pepper_tcp_socket_message_filter.h b/content/browser/renderer_host/pepper/pepper_tcp_socket_message_filter.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..27393c0c4ee27e20ba9952a4fc41d185397787f1 |
--- /dev/null |
+++ b/content/browser/renderer_host/pepper/pepper_tcp_socket_message_filter.h |
@@ -0,0 +1,182 @@ |
+// Copyright 2013 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 CONTENT_BROWSER_RENDERER_HOST_PEPPER_PEPPER_TCP_SOCKET_MESSAGE_FILTER_H_ |
+#define CONTENT_BROWSER_RENDERER_HOST_PEPPER_PEPPER_TCP_SOCKET_MESSAGE_FILTER_H_ |
+ |
+#include <string> |
+#include <vector> |
+ |
+#include "base/basictypes.h" |
+#include "base/compiler_specific.h" |
+#include "base/memory/ref_counted.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "content/browser/renderer_host/pepper/ssl_context_helper.h" |
+#include "content/common/content_export.h" |
+#include "net/base/address_list.h" |
+#include "ppapi/c/pp_instance.h" |
+#include "ppapi/c/ppb_tcp_socket.h" |
+#include "ppapi/host/resource_message_filter.h" |
+ |
+struct PP_NetAddress_Private; |
+ |
+namespace net { |
+class DrainableIOBuffer; |
+class IOBuffer; |
+class SingleRequestHostResolver; |
+class StreamSocket; |
+} |
+ |
+namespace ppapi { |
+class SocketOptionData; |
+ |
+namespace host { |
+struct ReplyMessageContext; |
+} |
+} |
+ |
+namespace content { |
+ |
+class BrowserPpapiHostImpl; |
+class ResourceContext; |
+ |
+class CONTENT_EXPORT PepperTCPSocketMessageFilter |
+ : public ppapi::host::ResourceMessageFilter { |
+ public: |
+ PepperTCPSocketMessageFilter( |
+ BrowserPpapiHostImpl* host, |
+ PP_Instance instance, |
+ bool private_api, |
+ const scoped_refptr<SSLContextHelper>& ssl_context_helper); |
+ |
+ // Used for creation already connected sockets. Takes ownership of |
yzshen1
2013/08/16 20:40:42
nit: creation -> creating
ygorshenin1
2013/08/19 14:33:35
Done.
|
+ // |socket|. |
+ PepperTCPSocketMessageFilter( |
+ BrowserPpapiHostImpl* host, |
+ PP_Instance instance, |
+ bool private_api, |
+ const scoped_refptr<SSLContextHelper>& ssl_context_helper, |
+ net::StreamSocket* socket); |
+ |
+ static size_t GetNumInstances(); |
+ |
+ protected: |
+ virtual ~PepperTCPSocketMessageFilter(); |
+ |
+ private: |
+ enum ConnectionState { |
+ // Before a connection is successfully established (including a previous |
+ // connect request failed). |
+ BEFORE_CONNECT, |
+ // There is a connect request that is pending. |
+ CONNECT_IN_PROGRESS, |
+ // A connection has been successfully established. |
+ CONNECTED, |
+ // There is an SSL handshake request that is pending. |
+ SSL_HANDSHAKE_IN_PROGRESS, |
+ // An SSL connection has been successfully established. |
+ SSL_CONNECTED, |
+ // An SSL handshake has failed. |
+ SSL_HANDSHAKE_FAILED |
+ }; |
+ |
+ // ppapi::host::ResourceMessageFilter overrides. |
+ virtual scoped_refptr<base::TaskRunner> OverrideTaskRunnerForMessage( |
+ const IPC::Message& message) OVERRIDE; |
+ virtual int32_t OnResourceMessageReceived( |
+ const IPC::Message& msg, |
+ ppapi::host::HostMessageContext* context) OVERRIDE; |
+ |
+ int32_t OnMsgConnect(const ppapi::host::HostMessageContext* context, |
+ const std::string& host, |
+ uint16_t port); |
+ int32_t OnMsgConnectWithNetAddress( |
+ const ppapi::host::HostMessageContext* context, |
+ const PP_NetAddress_Private& net_addr); |
+ int32_t OnMsgSSLHandshake( |
+ const ppapi::host::HostMessageContext* context, |
+ const std::string& server_name, |
+ uint16_t server_port, |
+ const std::vector<std::vector<char> >& trusted_certs, |
+ const std::vector<std::vector<char> >& untrusted_certs); |
+ int32_t OnMsgRead(const ppapi::host::HostMessageContext* context, |
+ int32_t bytes_to_read); |
+ int32_t OnMsgWrite(const ppapi::host::HostMessageContext* context, |
+ const std::string& data); |
+ int32_t OnMsgDisconnect(const ppapi::host::HostMessageContext* context); |
+ int32_t OnMsgSetOption(const ppapi::host::HostMessageContext* context, |
+ PP_TCPSocket_Option name, |
+ const ppapi::SocketOptionData& value); |
+ |
+ void DoConnect(const ppapi::host::ReplyMessageContext& context, |
+ const std::string& host, |
+ uint16_t port, |
+ ResourceContext* resource_context); |
+ void DoConnectWithNetAddress( |
+ const ppapi::host::ReplyMessageContext& context, |
+ const PP_NetAddress_Private& net_addr); |
+ void DoWrite(const ppapi::host::ReplyMessageContext& context); |
+ |
+ void OnResolveCompleted(const ppapi::host::ReplyMessageContext& context, |
+ int net_result); |
+ void StartConnect(const ppapi::host::ReplyMessageContext& context); |
+ |
+ void OnConnectCompleted(const ppapi::host::ReplyMessageContext& context, |
+ int net_result); |
+ void OnSSLHandshakeCompleted(const ppapi::host::ReplyMessageContext& context, |
+ int net_result); |
+ void OnReadCompleted(const ppapi::host::ReplyMessageContext& context, |
+ int net_result); |
+ void OnWriteCompleted(const ppapi::host::ReplyMessageContext& context, |
+ int net_result); |
+ |
+ void SendConnectReply(const ppapi::host::ReplyMessageContext& context, |
+ int32_t pp_result, |
+ const PP_NetAddress_Private& local_addr, |
+ const PP_NetAddress_Private& remote_addr); |
+ void SendConnectError(const ppapi::host::ReplyMessageContext& context, |
+ int32_t pp_error); |
+ void SendSSLHandshakeReply(const ppapi::host::ReplyMessageContext& context, |
+ int32_t pp_result); |
+ void SendReadReply(const ppapi::host::ReplyMessageContext& context, |
+ int32_t pp_result, |
+ const std::string& data); |
+ void SendReadError(const ppapi::host::ReplyMessageContext& context, |
+ int32_t pp_error); |
+ void SendWriteReply(const ppapi::host::ReplyMessageContext& context, |
+ int32_t pp_result); |
+ |
+ bool IsConnected() const; |
+ bool IsSsl() const; |
+ |
+ bool external_plugin_; |
+ bool private_api_; |
+ |
+ int render_process_id_; |
+ int render_view_id_; |
+ |
+ ConnectionState connection_state_; |
+ bool end_of_file_reached_; |
+ |
+ scoped_ptr<net::SingleRequestHostResolver> resolver_; |
+ net::AddressList address_list_; |
+ |
+ scoped_ptr<net::StreamSocket> socket_; |
+ |
+ scoped_refptr<net::IOBuffer> read_buffer_; |
+ |
+ // |StreamSocket::Write()| may not always write the full buffer, but we would |
+ // rather have our |Write()| do so whenever possible. To do this, we may have |
yzshen1
2013/08/16 20:40:42
Please update the comment, we don't have a method
ygorshenin1
2013/08/19 14:33:35
Done.
|
+ // to call the former multiple times for each of the latter. This entails |
+ // using a |DrainableIOBuffer|, which requires an underlying base |IOBuffer|. |
+ scoped_refptr<net::IOBuffer> write_buffer_base_; |
+ scoped_refptr<net::DrainableIOBuffer> write_buffer_; |
+ scoped_refptr<SSLContextHelper> ssl_context_helper_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(PepperTCPSocketMessageFilter); |
+}; |
+ |
+} // namespace content |
+ |
+#endif // CONTENT_BROWSER_RENDERER_HOST_PEPPER_PEPPER_TCP_SOCKET_MESSAGE_FILTER_H_ |