| OLD | NEW |
| 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 "content/browser/bluetooth/bluetooth_device_chooser_controller.h" | 5 #include "content/browser/bluetooth/bluetooth_device_chooser_controller.h" |
| 6 | 6 |
| 7 #include <set> | 7 #include <set> |
| 8 #include <string> | 8 #include <string> |
| 9 #include <unordered_set> | 9 #include <unordered_set> |
| 10 | 10 |
| 11 #include "base/bind.h" | 11 #include "base/bind.h" |
| 12 #include "base/bind_helpers.h" | 12 #include "base/bind_helpers.h" |
| 13 #include "base/metrics/histogram_macros.h" | 13 #include "base/metrics/histogram_macros.h" |
| 14 #include "base/strings/string_util.h" | 14 #include "base/strings/string_util.h" |
| 15 #include "base/strings/utf_string_conversions.h" | 15 #include "base/strings/utf_string_conversions.h" |
| 16 #include "content/browser/bluetooth/bluetooth_blacklist.h" | 16 #include "content/browser/bluetooth/bluetooth_blocklist.h" |
| 17 #include "content/browser/bluetooth/bluetooth_metrics.h" | 17 #include "content/browser/bluetooth/bluetooth_metrics.h" |
| 18 #include "content/browser/bluetooth/web_bluetooth_service_impl.h" | 18 #include "content/browser/bluetooth/web_bluetooth_service_impl.h" |
| 19 #include "content/public/browser/browser_thread.h" | 19 #include "content/public/browser/browser_thread.h" |
| 20 #include "content/public/browser/content_browser_client.h" | 20 #include "content/public/browser/content_browser_client.h" |
| 21 #include "content/public/browser/render_frame_host.h" | 21 #include "content/public/browser/render_frame_host.h" |
| 22 #include "content/public/browser/web_contents.h" | 22 #include "content/public/browser/web_contents.h" |
| 23 #include "content/public/browser/web_contents_delegate.h" | 23 #include "content/public/browser/web_contents_delegate.h" |
| 24 #include "device/bluetooth/bluetooth_adapter.h" | 24 #include "device/bluetooth/bluetooth_adapter.h" |
| 25 #include "device/bluetooth/bluetooth_common.h" | 25 #include "device/bluetooth/bluetooth_common.h" |
| 26 #include "device/bluetooth/bluetooth_discovery_session.h" | 26 #include "device/bluetooth/bluetooth_discovery_session.h" |
| (...skipping 234 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 261 | 261 |
| 262 // The renderer should never send empty filters. | 262 // The renderer should never send empty filters. |
| 263 if (HasEmptyOrInvalidFilter(options->filters)) { | 263 if (HasEmptyOrInvalidFilter(options->filters)) { |
| 264 web_bluetooth_service_->CrashRendererAndClosePipe( | 264 web_bluetooth_service_->CrashRendererAndClosePipe( |
| 265 bad_message::BDH_EMPTY_OR_INVALID_FILTERS); | 265 bad_message::BDH_EMPTY_OR_INVALID_FILTERS); |
| 266 return; | 266 return; |
| 267 } | 267 } |
| 268 options_ = std::move(options); | 268 options_ = std::move(options); |
| 269 LogRequestDeviceOptions(options_); | 269 LogRequestDeviceOptions(options_); |
| 270 | 270 |
| 271 // Check blacklist to reject invalid filters and adjust optional_services. | 271 // Check blocklist to reject invalid filters and adjust optional_services. |
| 272 if (BluetoothBlacklist::Get().IsExcluded(options_->filters)) { | 272 if (BluetoothBlocklist::Get().IsExcluded(options_->filters)) { |
| 273 RecordRequestDeviceOutcome( | 273 RecordRequestDeviceOutcome( |
| 274 UMARequestDeviceOutcome::BLACKLISTED_SERVICE_IN_FILTER); | 274 UMARequestDeviceOutcome::BLOCKLISTED_SERVICE_IN_FILTER); |
| 275 PostErrorCallback( | 275 PostErrorCallback( |
| 276 blink::mojom::WebBluetoothResult::REQUEST_DEVICE_WITH_BLACKLISTED_UUID); | 276 blink::mojom::WebBluetoothResult::REQUEST_DEVICE_WITH_BLOCKLISTED_UUID); |
| 277 return; | 277 return; |
| 278 } | 278 } |
| 279 BluetoothBlacklist::Get().RemoveExcludedUUIDs(options_.get()); | 279 BluetoothBlocklist::Get().RemoveExcludedUUIDs(options_.get()); |
| 280 | 280 |
| 281 const url::Origin requesting_origin = | 281 const url::Origin requesting_origin = |
| 282 render_frame_host_->GetLastCommittedOrigin(); | 282 render_frame_host_->GetLastCommittedOrigin(); |
| 283 const url::Origin embedding_origin = | 283 const url::Origin embedding_origin = |
| 284 web_contents_->GetMainFrame()->GetLastCommittedOrigin(); | 284 web_contents_->GetMainFrame()->GetLastCommittedOrigin(); |
| 285 | 285 |
| 286 // TODO(crbug.com/518042): Enforce correctly-delegated permissions instead of | 286 // TODO(crbug.com/518042): Enforce correctly-delegated permissions instead of |
| 287 // matching origins. When relaxing this, take care to handle non-sandboxed | 287 // matching origins. When relaxing this, take care to handle non-sandboxed |
| 288 // unique origins. | 288 // unique origins. |
| 289 if (!embedding_origin.IsSameOriginWith(requesting_origin)) { | 289 if (!embedding_origin.IsSameOriginWith(requesting_origin)) { |
| (...skipping 265 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 555 | 555 |
| 556 void BluetoothDeviceChooserController::PostErrorCallback( | 556 void BluetoothDeviceChooserController::PostErrorCallback( |
| 557 blink::mojom::WebBluetoothResult error) { | 557 blink::mojom::WebBluetoothResult error) { |
| 558 if (!base::ThreadTaskRunnerHandle::Get()->PostTask( | 558 if (!base::ThreadTaskRunnerHandle::Get()->PostTask( |
| 559 FROM_HERE, base::Bind(error_callback_, error))) { | 559 FROM_HERE, base::Bind(error_callback_, error))) { |
| 560 LOG(WARNING) << "No TaskRunner."; | 560 LOG(WARNING) << "No TaskRunner."; |
| 561 } | 561 } |
| 562 } | 562 } |
| 563 | 563 |
| 564 } // namespace content | 564 } // namespace content |
| OLD | NEW |