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

Side by Side Diff: components/ui_devtools/devtools_server.cc

Issue 2455833002: Pass task_runner_ to server and send 404 when incorrect url (Closed)
Patch Set: Make a default create method (without task_runner) Created 4 years, 1 month 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
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "components/ui_devtools/devtools_server.h" 5 #include "components/ui_devtools/devtools_server.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/command_line.h" 9 #include "base/command_line.h"
10 #include "base/format_macros.h" 10 #include "base/format_macros.h"
(...skipping 10 matching lines...) Expand all
21 21
22 namespace ui { 22 namespace ui {
23 namespace devtools { 23 namespace devtools {
24 24
25 namespace { 25 namespace {
26 const char kChromeDeveloperToolsPrefix[] = 26 const char kChromeDeveloperToolsPrefix[] =
27 "chrome-devtools://devtools/bundled/inspector.html?ws="; 27 "chrome-devtools://devtools/bundled/inspector.html?ws=";
28 } // namespace 28 } // namespace
29 29
30 UiDevToolsServer::UiDevToolsServer() 30 UiDevToolsServer::UiDevToolsServer()
31 : thread_(new base::Thread("UiDevToolsServerThread")) {} 31 : thread_(new base::Thread("UiDevToolsServerThread")) {
32 base::Thread::Options options;
33 options.message_loop_type = base::MessageLoop::TYPE_IO;
34 CHECK(thread_->StartWithOptions(options));
35 task_runner_ = thread_->task_runner();
36 }
37
38 UiDevToolsServer::UiDevToolsServer(
39 scoped_refptr<base::SingleThreadTaskRunner> task_runner)
40 : task_runner_(task_runner) {
41 DCHECK(task_runner_);
42 }
32 43
33 UiDevToolsServer::~UiDevToolsServer() {} 44 UiDevToolsServer::~UiDevToolsServer() {}
34 45
35 // static 46 // static
36 std::unique_ptr<UiDevToolsServer> UiDevToolsServer::Create() { 47 std::unique_ptr<UiDevToolsServer> UiDevToolsServer::Create() {
48 return Create(nullptr);
49 }
50
51 // static
52 std::unique_ptr<UiDevToolsServer> UiDevToolsServer::Create(
53 scoped_refptr<base::SingleThreadTaskRunner> task_runner) {
37 std::unique_ptr<UiDevToolsServer> server; 54 std::unique_ptr<UiDevToolsServer> server;
38 if (base::CommandLine::ForCurrentProcess()->HasSwitch(kEnableUiDevTools)) { 55 if (base::CommandLine::ForCurrentProcess()->HasSwitch(kEnableUiDevTools)) {
39 // TODO(mhashmi): Change port if more than one inspectable clients 56 // TODO(mhashmi): Change port if more than one inspectable clients
40 int port = 9223; // Default port is 9223 57 int port = 9223; // Default port is 9223
41 base::StringToInt( 58 base::StringToInt(
42 base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( 59 base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII(
43 kEnableUiDevTools), 60 kEnableUiDevTools),
44 &port); 61 &port);
45 server.reset(new UiDevToolsServer()); 62 server.reset(task_runner ? new UiDevToolsServer(task_runner)
63 : new UiDevToolsServer());
46 server->Start("127.0.0.1", port); 64 server->Start("127.0.0.1", port);
47 } 65 }
48 return server; 66 return server;
49 } 67 }
50 68
51 void UiDevToolsServer::AttachClient(std::unique_ptr<UiDevToolsClient> client) { 69 void UiDevToolsServer::AttachClient(std::unique_ptr<UiDevToolsClient> client) {
52 clients_.push_back(std::move(client)); 70 clients_.push_back(std::move(client));
53 } 71 }
54 72
55 void UiDevToolsServer::SendOverWebSocket(int connection_id, 73 void UiDevToolsServer::SendOverWebSocket(int connection_id,
56 const String& message) { 74 const String& message) {
57 thread_->task_runner()->PostTask( 75 task_runner_->PostTask(
58 FROM_HERE, 76 FROM_HERE,
59 base::Bind(&net::HttpServer::SendOverWebSocket, 77 base::Bind(&net::HttpServer::SendOverWebSocket,
60 base::Unretained(server_.get()), connection_id, message)); 78 base::Unretained(server_.get()), connection_id, message));
61 } 79 }
62 80
63 void UiDevToolsServer::Start(const std::string& address_string, uint16_t port) { 81 void UiDevToolsServer::Start(const std::string& address_string, uint16_t port) {
64 if (thread_ && thread_->IsRunning()) 82 task_runner_->PostTask(
65 return; 83 FROM_HERE, base::Bind(&UiDevToolsServer::StartServer,
66 84 base::Unretained(this), address_string, port));
67 // Start IO thread upon which all the methods will run
68 base::Thread::Options options;
69 options.message_loop_type = base::MessageLoop::TYPE_IO;
70 if (thread_->StartWithOptions(options)) {
71 thread_->task_runner()->PostTask(
72 FROM_HERE, base::Bind(&UiDevToolsServer::StartServer,
73 base::Unretained(this), address_string, port));
74 }
75 } 85 }
76 86
77 void UiDevToolsServer::StartServer(const std::string& address_string, 87 void UiDevToolsServer::StartServer(const std::string& address_string,
78 uint16_t port) { 88 uint16_t port) {
79 std::unique_ptr<net::ServerSocket> socket( 89 std::unique_ptr<net::ServerSocket> socket(
80 new net::TCPServerSocket(nullptr, net::NetLogSource())); 90 new net::TCPServerSocket(nullptr, net::NetLogSource()));
81 constexpr int kBacklog = 1; 91 constexpr int kBacklog = 1;
82 if (socket->ListenWithAddressAndPort(address_string, port, kBacklog) != 92 if (socket->ListenWithAddressAndPort(address_string, port, kBacklog) !=
83 net::OK) 93 net::OK)
84 return; 94 return;
(...skipping 17 matching lines...) Expand all
102 "them:</h3>"; 112 "them:</h3>";
103 net::IPEndPoint ip; 113 net::IPEndPoint ip;
104 server_->GetLocalAddress(&ip); 114 server_->GetLocalAddress(&ip);
105 for (ClientsList::size_type i = 0; i != clients_.size(); i++) { 115 for (ClientsList::size_type i = 0; i != clients_.size(); i++) {
106 clientHTML += base::StringPrintf( 116 clientHTML += base::StringPrintf(
107 "<p><strong>%s</strong> (%s%s/%" PRIuS ")</p>", 117 "<p><strong>%s</strong> (%s%s/%" PRIuS ")</p>",
108 clients_[i]->name().c_str(), kChromeDeveloperToolsPrefix, 118 clients_[i]->name().c_str(), kChromeDeveloperToolsPrefix,
109 ip.ToString().c_str(), i); 119 ip.ToString().c_str(), i);
110 } 120 }
111 clientHTML += "</html>"; 121 clientHTML += "</html>";
112 thread_->task_runner()->PostTask( 122 task_runner_->PostTask(
113 FROM_HERE, 123 FROM_HERE,
114 base::Bind(&net::HttpServer::Send200, base::Unretained(server_.get()), 124 base::Bind(&net::HttpServer::Send200, base::Unretained(server_.get()),
115 connection_id, clientHTML, "text/html")); 125 connection_id, clientHTML, "text/html"));
126 return;
116 } 127 }
128 task_runner_->PostTask(
129 FROM_HERE, base::Bind(&net::HttpServer::Send404,
130 base::Unretained(server_.get()), connection_id));
117 } 131 }
118 132
119 void UiDevToolsServer::OnWebSocketRequest( 133 void UiDevToolsServer::OnWebSocketRequest(
120 int connection_id, 134 int connection_id,
121 const net::HttpServerRequestInfo& info) { 135 const net::HttpServerRequestInfo& info) {
122 size_t target_id = 0; 136 size_t target_id = 0;
123 if (info.path.empty() || 137 if (info.path.empty() ||
124 !base::StringToSizeT(info.path.substr(1), &target_id) || 138 !base::StringToSizeT(info.path.substr(1), &target_id) ||
125 target_id > clients_.size()) 139 target_id > clients_.size())
126 return; 140 return;
127 141
128 UiDevToolsClient* client = clients_[target_id].get(); 142 UiDevToolsClient* client = clients_[target_id].get();
129 // Only one user can inspect the client at a time 143 // Only one user can inspect the client at a time
130 if (client->connected()) 144 if (client->connected())
131 return; 145 return;
132 client->set_connection_id(connection_id); 146 client->set_connection_id(connection_id);
133 connections_[connection_id] = client; 147 connections_[connection_id] = client;
134 thread_->task_runner()->PostTask( 148 task_runner_->PostTask(
135 FROM_HERE, 149 FROM_HERE,
136 base::Bind(&net::HttpServer::AcceptWebSocket, 150 base::Bind(&net::HttpServer::AcceptWebSocket,
137 base::Unretained(server_.get()), connection_id, info)); 151 base::Unretained(server_.get()), connection_id, info));
138 } 152 }
139 153
140 void UiDevToolsServer::OnWebSocketMessage(int connection_id, 154 void UiDevToolsServer::OnWebSocketMessage(int connection_id,
141 const std::string& data) { 155 const std::string& data) {
142 ConnectionsMap::iterator it = connections_.find(connection_id); 156 ConnectionsMap::iterator it = connections_.find(connection_id);
143 DCHECK(it != connections_.end()); 157 DCHECK(it != connections_.end());
144 UiDevToolsClient* client = it->second; 158 UiDevToolsClient* client = it->second;
145 DCHECK(client); 159 DCHECK(client);
146 thread_->task_runner()->PostTask( 160 task_runner_->PostTask(FROM_HERE, base::Bind(&UiDevToolsClient::Dispatch,
147 FROM_HERE, 161 base::Unretained(client), data));
148 base::Bind(&UiDevToolsClient::Dispatch, base::Unretained(client), data));
149 } 162 }
150 163
151 void UiDevToolsServer::OnClose(int connection_id) { 164 void UiDevToolsServer::OnClose(int connection_id) {
152 ConnectionsMap::iterator it = connections_.find(connection_id); 165 ConnectionsMap::iterator it = connections_.find(connection_id);
153 DCHECK(it != connections_.end()); 166 if (it == connections_.end())
167 return;
154 UiDevToolsClient* client = it->second; 168 UiDevToolsClient* client = it->second;
155 DCHECK(client); 169 DCHECK(client);
156 client->set_connection_id(UiDevToolsClient::kNotConnected); 170 client->set_connection_id(UiDevToolsClient::kNotConnected);
157 connections_.erase(it); 171 connections_.erase(it);
158 } 172 }
159 173
160 } // namespace devtools 174 } // namespace devtools
161 } // namespace ui 175 } // namespace ui
OLDNEW
« components/ui_devtools/devtools_server.h ('K') | « components/ui_devtools/devtools_server.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698