 Chromium Code Reviews
 Chromium Code Reviews Issue 10827390:
  Implement chrome.socket.bind/listen/accept for TCP server socket.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src
    
  
    Issue 10827390:
  Implement chrome.socket.bind/listen/accept for TCP server socket.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src| OLD | NEW | 
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include "chrome/browser/extensions/api/socket/socket_api.h" | 5 #include "chrome/browser/extensions/api/socket/socket_api.h" | 
| 6 | 6 | 
| 7 #include "base/bind.h" | 7 #include "base/bind.h" | 
| 8 #include "chrome/common/extensions/permissions/socket_permission.h" | 8 #include "chrome/common/extensions/permissions/socket_permission.h" | 
| 9 #include "chrome/browser/browser_process.h" | 9 #include "chrome/browser/browser_process.h" | 
| 10 #include "chrome/browser/extensions/api/dns/host_resolver_wrapper.h" | 10 #include "chrome/browser/extensions/api/dns/host_resolver_wrapper.h" | 
| (...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 140 result->SetInteger(kSocketIdKey, manager_->Add(socket)); | 140 result->SetInteger(kSocketIdKey, manager_->Add(socket)); | 
| 141 SetResult(result); | 141 SetResult(result); | 
| 142 } | 142 } | 
| 143 | 143 | 
| 144 bool SocketDestroyFunction::Prepare() { | 144 bool SocketDestroyFunction::Prepare() { | 
| 145 EXTENSION_FUNCTION_VALIDATE(args_->GetInteger(0, &socket_id_)); | 145 EXTENSION_FUNCTION_VALIDATE(args_->GetInteger(0, &socket_id_)); | 
| 146 return true; | 146 return true; | 
| 147 } | 147 } | 
| 148 | 148 | 
| 149 void SocketDestroyFunction::Work() { | 149 void SocketDestroyFunction::Work() { | 
| 150 manager_->Remove(socket_id_); | 150 manager_->Remove(socket_id_); | 
| 
Peng
2012/09/11 14:01:18
Could we check if the listen port is release after
 
justinlin
2012/09/12 07:29:42
I think the only way is to bind() again, but there
 
Peng
2012/09/12 19:49:49
That's fine. I think we could file an issue to rem
 | |
| 151 } | 151 } | 
| 152 | 152 | 
| 153 SocketConnectFunction::SocketConnectFunction() | 153 SocketConnectFunction::SocketConnectFunction() | 
| 154 : socket_id_(0), | 154 : socket_id_(0), | 
| 155 port_(0) { | 155 port_(0) { | 
| 156 } | 156 } | 
| 157 | 157 | 
| 158 SocketConnectFunction::~SocketConnectFunction() { | 158 SocketConnectFunction::~SocketConnectFunction() { | 
| 159 } | 159 } | 
| 160 | 160 | 
| (...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 258 error_ = kPermissionError; | 258 error_ = kPermissionError; | 
| 259 SetResult(Value::CreateIntegerValue(result)); | 259 SetResult(Value::CreateIntegerValue(result)); | 
| 260 return; | 260 return; | 
| 261 } | 261 } | 
| 262 } | 262 } | 
| 263 | 263 | 
| 264 result = socket->Bind(address_, port_); | 264 result = socket->Bind(address_, port_); | 
| 265 SetResult(Value::CreateIntegerValue(result)); | 265 SetResult(Value::CreateIntegerValue(result)); | 
| 266 } | 266 } | 
| 267 | 267 | 
| 268 SocketListenFunction::SocketListenFunction() | |
| 269 : params_(NULL) { | |
| 270 } | |
| 271 | |
| 272 SocketListenFunction::~SocketListenFunction() {} | |
| 273 | |
| 274 bool SocketListenFunction::Prepare() { | |
| 275 params_ = api::socket::Listen::Params::Create(*args_); | |
| 276 EXTENSION_FUNCTION_VALIDATE(params_.get()); | |
| 277 return true; | |
| 278 } | |
| 279 | |
| 280 void SocketListenFunction::Work() { | |
| 281 int result = -1; | |
| 282 Socket* socket = manager_->Get(params_->socket_id); | |
| 283 if (socket) { | |
| 284 result = socket->Listen(params_->backlog, error_); | |
| 285 } else { | |
| 286 error_ = kSocketNotFoundError; | |
| 287 } | |
| 288 | |
| 289 SetResult(Value::CreateIntegerValue(result)); | |
| 290 } | |
| 291 | |
| 292 SocketAcceptFunction::SocketAcceptFunction() | |
| 293 : params_(NULL) { | |
| 294 } | |
| 295 | |
| 296 SocketAcceptFunction::~SocketAcceptFunction() {} | |
| 297 | |
| 298 bool SocketAcceptFunction::Prepare() { | |
| 299 params_ = api::socket::Accept::Params::Create(*args_); | |
| 300 EXTENSION_FUNCTION_VALIDATE(params_.get()); | |
| 301 return true; | |
| 302 } | |
| 303 | |
| 304 void SocketAcceptFunction::AsyncWorkStart() { | |
| 305 Socket* socket = manager_->Get(params_->socket_id); | |
| 306 if (socket) { | |
| 307 socket->Accept(base::Bind(&SocketAcceptFunction::OnAccept, this)); | |
| 308 } else { | |
| 309 error_ = kSocketNotFoundError; | |
| 310 OnAccept(-1, NULL); | |
| 311 } | |
| 312 } | |
| 313 | |
| 314 void SocketAcceptFunction::OnAccept(int result_code, | |
| 315 net::TCPClientSocket *socket) { | |
| 316 DCHECK(socket); | |
| 317 // TODO(justinlin): This socket won't have an event notifier, but it's not | |
| 318 // used for anything right now. | |
| 319 Socket *client_socket = new TCPSocket(socket, NULL, true); | |
| 320 | |
| 321 DictionaryValue* result = new DictionaryValue(); | |
| 322 result->SetInteger(kResultCodeKey, result_code); | |
| 323 result->SetInteger(kSocketIdKey, manager_->Add(client_socket)); | |
| 324 SetResult(result); | |
| 325 | |
| 326 AsyncWorkCompleted(); | |
| 327 } | |
| 328 | |
| 268 SocketReadFunction::SocketReadFunction() | 329 SocketReadFunction::SocketReadFunction() | 
| 269 : params_(NULL) { | 330 : params_(NULL) { | 
| 270 } | 331 } | 
| 271 | 332 | 
| 272 SocketReadFunction::~SocketReadFunction() {} | 333 SocketReadFunction::~SocketReadFunction() {} | 
| 273 | 334 | 
| 274 bool SocketReadFunction::Prepare() { | 335 bool SocketReadFunction::Prepare() { | 
| 275 params_ = api::socket::Read::Params::Create(*args_); | 336 params_ = api::socket::Read::Params::Create(*args_); | 
| 276 EXTENSION_FUNCTION_VALIDATE(params_.get()); | 337 EXTENSION_FUNCTION_VALIDATE(params_.get()); | 
| 277 return true; | 338 return true; | 
| (...skipping 278 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 556 new std::string(localAddress.ToStringWithoutPort())); | 617 new std::string(localAddress.ToStringWithoutPort())); | 
| 557 info.local_port.reset(new int(localAddress.port())); | 618 info.local_port.reset(new int(localAddress.port())); | 
| 558 } | 619 } | 
| 559 } else { | 620 } else { | 
| 560 error_ = kSocketNotFoundError; | 621 error_ = kSocketNotFoundError; | 
| 561 } | 622 } | 
| 562 SetResult(info.ToValue().release()); | 623 SetResult(info.ToValue().release()); | 
| 563 } | 624 } | 
| 564 | 625 | 
| 565 } // namespace extensions | 626 } // namespace extensions | 
| OLD | NEW |