| Index: content/browser/bluetooth/bluetooth_blacklist.cc
|
| diff --git a/content/browser/bluetooth/bluetooth_blacklist.cc b/content/browser/bluetooth/bluetooth_blacklist.cc
|
| deleted file mode 100644
|
| index a3c551e03348827e4ca9018cfe532e23b96a28d5..0000000000000000000000000000000000000000
|
| --- a/content/browser/bluetooth/bluetooth_blacklist.cc
|
| +++ /dev/null
|
| @@ -1,189 +0,0 @@
|
| -// Copyright 2016 The Chromium Authors. All rights reserved.
|
| -// Use of this source code is governed by a BSD-style license that can be
|
| -// found in the LICENSE file.
|
| -
|
| -#include "content/browser/bluetooth/bluetooth_blacklist.h"
|
| -
|
| -#include "base/logging.h"
|
| -#include "base/metrics/histogram_macros.h"
|
| -#include "base/optional.h"
|
| -#include "base/strings/string_split.h"
|
| -#include "content/public/browser/content_browser_client.h"
|
| -
|
| -using device::BluetoothUUID;
|
| -
|
| -namespace {
|
| -
|
| -static base::LazyInstance<content::BluetoothBlacklist>::Leaky g_singleton =
|
| - LAZY_INSTANCE_INITIALIZER;
|
| -
|
| -void RecordUMAParsedNonEmptyString(bool success) {
|
| - UMA_HISTOGRAM_BOOLEAN("Bluetooth.Web.Blacklist.ParsedNonEmptyString",
|
| - success);
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -namespace content {
|
| -
|
| -BluetoothBlacklist::~BluetoothBlacklist() {}
|
| -
|
| -// static
|
| -BluetoothBlacklist& BluetoothBlacklist::Get() {
|
| - return g_singleton.Get();
|
| -}
|
| -
|
| -void BluetoothBlacklist::Add(const BluetoothUUID& uuid, Value value) {
|
| - CHECK(uuid.IsValid());
|
| - auto insert_result = blacklisted_uuids_.insert(std::make_pair(uuid, value));
|
| - bool inserted = insert_result.second;
|
| - if (!inserted) {
|
| - Value& stored = insert_result.first->second;
|
| - if (stored != value)
|
| - stored = Value::EXCLUDE;
|
| - }
|
| -}
|
| -
|
| -void BluetoothBlacklist::Add(base::StringPiece blacklist_string) {
|
| - if (blacklist_string.empty())
|
| - return;
|
| - base::StringPairs kv_pairs;
|
| - bool parsed_values = false;
|
| - bool invalid_values = false;
|
| - SplitStringIntoKeyValuePairs(blacklist_string,
|
| - ':', // Key-value delimiter
|
| - ',', // Key-value pair delimiter
|
| - &kv_pairs);
|
| - for (const auto& pair : kv_pairs) {
|
| - BluetoothUUID uuid(pair.first);
|
| - if (uuid.IsValid() && pair.second.size() == 1u) {
|
| - switch (pair.second[0]) {
|
| - case 'e':
|
| - Add(uuid, Value::EXCLUDE);
|
| - parsed_values = true;
|
| - continue;
|
| - case 'r':
|
| - Add(uuid, Value::EXCLUDE_READS);
|
| - parsed_values = true;
|
| - continue;
|
| - case 'w':
|
| - Add(uuid, Value::EXCLUDE_WRITES);
|
| - parsed_values = true;
|
| - continue;
|
| - }
|
| - }
|
| - invalid_values = true;
|
| - }
|
| - RecordUMAParsedNonEmptyString(parsed_values && !invalid_values);
|
| -}
|
| -
|
| -bool BluetoothBlacklist::IsExcluded(const BluetoothUUID& uuid) const {
|
| - CHECK(uuid.IsValid());
|
| - const auto& it = blacklisted_uuids_.find(uuid);
|
| - if (it == blacklisted_uuids_.end())
|
| - return false;
|
| - return it->second == Value::EXCLUDE;
|
| -}
|
| -
|
| -bool BluetoothBlacklist::IsExcluded(
|
| - const mojo::Array<blink::mojom::WebBluetoothScanFilterPtr>& filters) {
|
| - for (const blink::mojom::WebBluetoothScanFilterPtr& filter : filters) {
|
| - for (const base::Optional<BluetoothUUID>& service : filter->services) {
|
| - if (IsExcluded(service.value())) {
|
| - return true;
|
| - }
|
| - }
|
| - }
|
| - return false;
|
| -}
|
| -
|
| -bool BluetoothBlacklist::IsExcludedFromReads(const BluetoothUUID& uuid) const {
|
| - CHECK(uuid.IsValid());
|
| - const auto& it = blacklisted_uuids_.find(uuid);
|
| - if (it == blacklisted_uuids_.end())
|
| - return false;
|
| - return it->second == Value::EXCLUDE || it->second == Value::EXCLUDE_READS;
|
| -}
|
| -
|
| -bool BluetoothBlacklist::IsExcludedFromWrites(const BluetoothUUID& uuid) const {
|
| - CHECK(uuid.IsValid());
|
| - const auto& it = blacklisted_uuids_.find(uuid);
|
| - if (it == blacklisted_uuids_.end())
|
| - return false;
|
| - return it->second == Value::EXCLUDE || it->second == Value::EXCLUDE_WRITES;
|
| -}
|
| -
|
| -void BluetoothBlacklist::RemoveExcludedUUIDs(
|
| - blink::mojom::WebBluetoothRequestDeviceOptions* options) {
|
| - mojo::Array<base::Optional<BluetoothUUID>>
|
| - optional_services_blacklist_filtered;
|
| - for (const base::Optional<BluetoothUUID>& uuid : options->optional_services) {
|
| - if (!IsExcluded(uuid.value())) {
|
| - optional_services_blacklist_filtered.push_back(uuid);
|
| - }
|
| - }
|
| - options->optional_services = std::move(optional_services_blacklist_filtered);
|
| -}
|
| -
|
| -void BluetoothBlacklist::ResetToDefaultValuesForTest() {
|
| - blacklisted_uuids_.clear();
|
| - PopulateWithDefaultValues();
|
| - PopulateWithServerProvidedValues();
|
| -}
|
| -
|
| -BluetoothBlacklist::BluetoothBlacklist() {
|
| - PopulateWithDefaultValues();
|
| - PopulateWithServerProvidedValues();
|
| -}
|
| -
|
| -void BluetoothBlacklist::PopulateWithDefaultValues() {
|
| - blacklisted_uuids_.clear();
|
| -
|
| - // Testing from Layout Tests Note:
|
| - //
|
| - // Random UUIDs for object & exclude permutations that do not exist in the
|
| - // standard blacklist are included to facilitate integration testing from
|
| - // Layout Tests. Unit tests can dynamically modify the blacklist, but don't
|
| - // offer the full integration test to the Web Bluetooth Javascript bindings.
|
| - //
|
| - // This is done for simplicity as opposed to exposing a testing API that can
|
| - // add to the blacklist over time, which would be over engineered.
|
| - //
|
| - // Remove testing UUIDs if the specified blacklist is updated to include UUIDs
|
| - // that match the specific permutations.
|
| - DCHECK(BluetoothUUID("00001800-0000-1000-8000-00805f9b34fb") ==
|
| - BluetoothUUID("1800"));
|
| -
|
| - // Blacklist UUIDs updated 2016-09-01 from:
|
| - // https://github.com/WebBluetoothCG/registries/blob/master/gatt_blacklist.txt
|
| - // Short UUIDs are used for readability of this list.
|
| - //
|
| - // Services:
|
| - Add(BluetoothUUID("1812"), Value::EXCLUDE);
|
| - Add(BluetoothUUID("00001530-1212-efde-1523-785feabcd123"), Value::EXCLUDE);
|
| - Add(BluetoothUUID("f000ffc0-0451-4000-b000-000000000000"), Value::EXCLUDE);
|
| - Add(BluetoothUUID("00060000"), Value::EXCLUDE);
|
| - Add(BluetoothUUID("fffd"), Value::EXCLUDE);
|
| - // Characteristics:
|
| - Add(BluetoothUUID("2a02"), Value::EXCLUDE_WRITES);
|
| - Add(BluetoothUUID("2a03"), Value::EXCLUDE);
|
| - Add(BluetoothUUID("2a25"), Value::EXCLUDE);
|
| - // Characteristics for Layout Tests:
|
| - Add(BluetoothUUID("bad1c9a2-9a5b-4015-8b60-1579bbbf2135"),
|
| - Value::EXCLUDE_READS);
|
| - // Descriptors:
|
| - Add(BluetoothUUID("2902"), Value::EXCLUDE_WRITES);
|
| - Add(BluetoothUUID("2903"), Value::EXCLUDE_WRITES);
|
| - // Descriptors for Layout Tests:
|
| - Add(BluetoothUUID("bad2ddcf-60db-45cd-bef9-fd72b153cf7c"), Value::EXCLUDE);
|
| - Add(BluetoothUUID("bad3ec61-3cc3-4954-9702-7977df514114"),
|
| - Value::EXCLUDE_READS);
|
| -}
|
| -
|
| -void BluetoothBlacklist::PopulateWithServerProvidedValues() {
|
| - // DCHECK to maybe help debug https://crbug.com/604078.
|
| - DCHECK(GetContentClient());
|
| - Add(GetContentClient()->browser()->GetWebBluetoothBlacklist());
|
| -}
|
| -
|
| -} // namespace content
|
|
|