Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(984)

Side by Side Diff: content/browser/renderer_host/pepper_tcp_server_socket.cc

Issue 9283022: Exposed Listen and Accept methods to plugin. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Changed type of tcp_socket_buffer_ field of PPB_TCPServerSocket_Private class. Created 8 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
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.
4
5 #include "content/browser/renderer_host/pepper_tcp_server_socket.h"
6
7 #include <cstddef>
8
9 #include "base/logging.h"
10 #include "content/browser/renderer_host/pepper_message_filter.h"
11 #include "content/public/browser/browser_thread.h"
12 #include "content/public/browser/browser_thread.h"
yzshen1 2012/02/09 02:31:50 duplicate.
ygorshenin1 2012/02/09 15:00:10 Done.
13 #include "net/base/ip_endpoint.h"
14 #include "net/base/net_errors.h"
15 #include "net/socket/tcp_client_socket.h"
16 #include "net/socket/tcp_server_socket.h"
17 #include "ppapi/proxy/ppapi_messages.h"
18 #include "ppapi/shared_impl/private/net_address_private_impl.h"
19
20 using content::BrowserThread;
21 using ppapi::NetAddressPrivateImpl;
22
23 PepperTCPServerSocket::PepperTCPServerSocket(
24 PepperMessageFilter* manager,
25 int32 routing_id,
26 uint32 plugin_dispatcher_id,
27 uint32 socket_id)
28 : manager_(manager),
29 routing_id_(routing_id),
30 plugin_dispatcher_id_(plugin_dispatcher_id),
31 socket_id_(socket_id),
32 state_(BEFORE_LISTENING) {
33 DCHECK(manager);
34 }
35
36 PepperTCPServerSocket::~PepperTCPServerSocket() {
37 }
38
39 void PepperTCPServerSocket::SetAcceptCallback(
40 const AcceptCallback& accept_callback) {
41 accept_callback_ = accept_callback;
42 }
43
44 void PepperTCPServerSocket::Listen(const PP_NetAddress_Private& addr,
45 int32 backlog) {
46 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
47
48 net::IPEndPoint ip_end_point;
49 if (state_ != BEFORE_LISTENING ||
50 !NetAddressPrivateImpl::NetAddressToIPEndPoint(addr, &ip_end_point)) {
51 SendListenACKError();
52 return;
53 }
54
55 state_ = LISTEN_IN_PROGRESS;
56
57 socket_.reset(new net::TCPServerSocket(NULL, net::NetLog::Source()));
58 int result = socket_->Listen(ip_end_point, backlog);
59 if (result != net::ERR_IO_PENDING)
60 OnListenCompleted(result);
61 }
62
63 void PepperTCPServerSocket::Accept() {
64 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
65
66 if (state_ != LISTENING) {
67 SendAcceptACKError();
68 return;
69 }
70
71 state_ = ACCEPT_IN_PROGRESS;
72
73 int result = socket_->Accept(
yzshen1 2012/02/09 02:31:50 I think Accept() will DCHECK if the previous Accep
ygorshenin1 2012/02/09 15:00:10 I added a state_ check before DCHECK, but didn't u
yzshen1 2012/02/09 17:36:39 I mean: http://code.google.com/codesearch#OAMlx_jo
ygorshenin1 2012/02/10 13:27:40 OK, but in this case check that state_ == LISTENIN
yzshen1 2012/02/10 22:40:14 Ah, you are right. Thanks for pointing it out. On
74 &socket_buffer_,
75 base::Bind(&PepperTCPServerSocket::OnAcceptCompleted,
76 base::Unretained(this)));
77 if (result != net::ERR_IO_PENDING)
78 OnAcceptCompleted(result);
79 }
80
81 void PepperTCPServerSocket::SendListenACKError() {
82 manager_->Send(new PpapiMsg_PPBTCPServerSocket_ListenACK(
83 routing_id_, plugin_dispatcher_id_, socket_id_, false));
84 }
85
86 void PepperTCPServerSocket::SendAcceptACKError() {
87 manager_->Send(new PpapiMsg_PPBTCPServerSocket_AcceptACK(
88 routing_id_,
89 plugin_dispatcher_id_,
90 socket_id_,
91 0,
92 NetAddressPrivateImpl::kInvalidNetAddress,
93 NetAddressPrivateImpl::kInvalidNetAddress));
94 }
95
96 void PepperTCPServerSocket::OnListenCompleted(int result) {
97 DCHECK(state_ == LISTEN_IN_PROGRESS && socket_.get());
98
99 if (result != net::OK) {
100 SendListenACKError();
101 state_ = BEFORE_LISTENING;
102 } else {
103 manager_->Send(new PpapiMsg_PPBTCPServerSocket_ListenACK(
104 routing_id_, plugin_dispatcher_id_, socket_id_, true));
105 state_ = LISTENING;
106 }
107 }
108
109 void PepperTCPServerSocket::OnAcceptCompleted(int result) {
110 DCHECK(state_ == ACCEPT_IN_PROGRESS && socket_buffer_.get());
111
112 if (result != net::OK)
brettw 2012/02/09 00:13:48 Style nit: this needs {} since the other arm has t
ygorshenin1 2012/02/09 15:00:10 Done.
113 SendAcceptACKError();
114 else {
115 net::StreamSocket* socket = socket_buffer_.release();
116
117 net::IPEndPoint ip_end_point;
118 net::AddressList address_list;
119 PP_NetAddress_Private local_addr =
120 NetAddressPrivateImpl::kInvalidNetAddress;
121 PP_NetAddress_Private remote_addr =
122 NetAddressPrivateImpl::kInvalidNetAddress;
123
124 if (socket->GetLocalAddress(&ip_end_point) != net::OK ||
125 !NetAddressPrivateImpl::IPEndPointToNetAddress(ip_end_point,
126 &local_addr) ||
127 socket->GetPeerAddress(&address_list) != net::OK ||
128 !NetAddressPrivateImpl::AddressListToNetAddress(address_list,
129 &remote_addr)) {
130 SendAcceptACKError();
131 }
132
133 if (!accept_callback_.is_null()) {
134 BrowserThread::PostTask(BrowserThread::IO,
yzshen1 2012/02/09 02:31:50 The logic related to accept_callback_ is a little
ygorshenin1 2012/02/09 15:00:10 Done.
135 FROM_HERE,
136 base::Bind(&AcceptCallback::Run,
137 base::Unretained(&accept_callback_),
138 routing_id_,
139 plugin_dispatcher_id_,
140 socket_id_,
141 socket,
142 local_addr,
143 remote_addr));
144 } else {
145 delete socket;
brettw 2012/02/09 00:13:48 The ownership model of this is pretty complex. I t
ygorshenin1 2012/02/09 15:00:10 OK, now socket ownership is passed to PepperMessag
146 }
147 }
148
149 state_ = LISTENING;
150 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698