OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "cloud_print/gcp20/prototype/privet_http_server.h" | 5 #include "cloud_print/gcp20/prototype/privet_http_server.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/json/json_writer.h" | 8 #include "base/json/json_writer.h" |
9 #include "base/strings/stringprintf.h" | 9 #include "base/strings/stringprintf.h" |
10 #include "cloud_print/gcp20/prototype/gcp20_switches.h" | 10 #include "cloud_print/gcp20/prototype/gcp20_switches.h" |
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
132 } | 132 } |
133 | 133 |
134 void PrivetHttpServer::OnHttpRequest(int connection_id, | 134 void PrivetHttpServer::OnHttpRequest(int connection_id, |
135 const net::HttpServerRequestInfo& info) { | 135 const net::HttpServerRequestInfo& info) { |
136 VLOG(1) << "Processing HTTP request: " << info.path; | 136 VLOG(1) << "Processing HTTP request: " << info.path; |
137 GURL url("http://host" + info.path); | 137 GURL url("http://host" + info.path); |
138 | 138 |
139 if (!ValidateRequestMethod(connection_id, url.path(), info.method)) | 139 if (!ValidateRequestMethod(connection_id, url.path(), info.method)) |
140 return; | 140 return; |
141 | 141 |
142 if (!CommandLine::ForCurrentProcess()->HasSwitch(switches::kDisableXTocken)) { | 142 if (!base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 143 switches::kDisableXTocken)) { |
143 net::HttpServerRequestInfo::HeadersMap::const_iterator iter = | 144 net::HttpServerRequestInfo::HeadersMap::const_iterator iter = |
144 info.headers.find("x-privet-token"); | 145 info.headers.find("x-privet-token"); |
145 if (iter == info.headers.end()) { | 146 if (iter == info.headers.end()) { |
146 server_->Send(connection_id, net::HTTP_BAD_REQUEST, | 147 server_->Send(connection_id, net::HTTP_BAD_REQUEST, |
147 "Missing X-Privet-Token header.\n" | 148 "Missing X-Privet-Token header.\n" |
148 "TODO: Message should be in header, not in the body!", | 149 "TODO: Message should be in header, not in the body!", |
149 "text/plain"); | 150 "text/plain"); |
150 return; | 151 return; |
151 } | 152 } |
152 | 153 |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
185 bool PrivetHttpServer::ValidateRequestMethod(int connection_id, | 186 bool PrivetHttpServer::ValidateRequestMethod(int connection_id, |
186 const std::string& request, | 187 const std::string& request, |
187 const std::string& method) { | 188 const std::string& method) { |
188 DCHECK(!IsGetMethod(request) || !IsPostMethod(request)); | 189 DCHECK(!IsGetMethod(request) || !IsPostMethod(request)); |
189 | 190 |
190 if (!IsGetMethod(request) && !IsPostMethod(request)) { | 191 if (!IsGetMethod(request) && !IsPostMethod(request)) { |
191 server_->Send404(connection_id); | 192 server_->Send404(connection_id); |
192 return false; | 193 return false; |
193 } | 194 } |
194 | 195 |
195 if (CommandLine::ForCurrentProcess()->HasSwitch("disable-method-check")) | 196 if (base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 197 "disable-method-check")) |
196 return true; | 198 return true; |
197 | 199 |
198 if ((IsGetMethod(request) && method != "GET") || | 200 if ((IsGetMethod(request) && method != "GET") || |
199 (IsPostMethod(request) && method != "POST")) { | 201 (IsPostMethod(request) && method != "POST")) { |
200 ReportInvalidMethod(connection_id); | 202 ReportInvalidMethod(connection_id); |
201 return false; | 203 return false; |
202 } | 204 } |
203 | 205 |
204 return true; | 206 return true; |
205 } | 207 } |
(...skipping 294 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
500 delegate_->GetRegistrationServerError(&description); | 502 delegate_->GetRegistrationServerError(&description); |
501 *current_response = CreateErrorWithDescription("server_error", | 503 *current_response = CreateErrorWithDescription("server_error", |
502 description); | 504 description); |
503 break; | 505 break; |
504 } | 506 } |
505 | 507 |
506 default: | 508 default: |
507 NOTREACHED(); | 509 NOTREACHED(); |
508 }; | 510 }; |
509 } | 511 } |
OLD | NEW |