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

Unified Diff: chrome/browser/ui/webui/bluetooth_internals/services/bluetooth_adapter_service.cc

Issue 2357383002: bluetooth: Add device list retrieval for chrome://bluetooth-internals (Closed)
Patch Set: Mojo interface and implementation fixes Created 4 years, 3 months 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/webui/bluetooth_internals/services/bluetooth_adapter_service.cc
diff --git a/chrome/browser/ui/webui/bluetooth_internals/services/bluetooth_adapter_service.cc b/chrome/browser/ui/webui/bluetooth_internals/services/bluetooth_adapter_service.cc
new file mode 100644
index 0000000000000000000000000000000000000000..942b9b6a620a97012a0172a3c2ba16d63086d152
--- /dev/null
+++ b/chrome/browser/ui/webui/bluetooth_internals/services/bluetooth_adapter_service.cc
@@ -0,0 +1,104 @@
+// 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 <utility>
+#include <vector>
+
+#include "chrome/browser/ui/webui/bluetooth_internals/services/bluetooth_adapter_service.h"
+#include "mojo/public/cpp/bindings/string.h"
+
+BluetoothAdapterService::BluetoothAdapterService(
+ bluetooth::mojom::AdapterClientPtr client)
+ : client_(std::move(client)), weak_ptr_factory_(this) {}
+
+BluetoothAdapterService::~BluetoothAdapterService() {
+ if (adapter_.get()) {
+ adapter_->RemoveObserver(this);
+ adapter_ = nullptr;
+ }
+}
+
+void BluetoothAdapterService::OnGetAdapter(
+ scoped_refptr<device::BluetoothAdapter> adapter) {
+ if (!adapter_.get()) {
+ VLOG(1) << "Adapter acquired in BluetoothAdapterService";
+ adapter_ = adapter;
+ adapter_->AddObserver(this);
+ }
+}
+
+void BluetoothAdapterService::GetDevices(const GetDevicesCallback& callback) {
+ if (!GetAdapter().get()) {
+ if (device::BluetoothAdapterFactory::IsBluetoothAdapterAvailable()) {
+ device::BluetoothAdapterFactory::GetAdapter(
+ base::Bind(&BluetoothAdapterService::GetDevicesImpl,
+ weak_ptr_factory_.GetWeakPtr(), callback));
+ return;
+ }
+ callback.Run(std::vector<bluetooth::mojom::DeviceInfoPtr>());
+ return;
+ }
+ GetDevicesImpl(callback, GetAdapter());
+}
+
+void BluetoothAdapterService::GetDevicesImpl(
+ const GetDevicesCallback& callback,
+ scoped_refptr<device::BluetoothAdapter> adapter) {
+ OnGetAdapter(adapter);
+ std::vector<bluetooth::mojom::DeviceInfoPtr> devices;
+
+ for (const device::BluetoothDevice* device : adapter->GetDevices()) {
+ addresses_.insert(device->GetAddress());
+ }
+
+ for (const std::string& address : addresses_) {
+ device::BluetoothDevice* device = adapter->GetDevice(address);
+ bluetooth::mojom::DeviceInfoPtr device_info =
+ ConstructDeviceInfoStruct(device);
+ devices.push_back(std::move(device_info));
+ }
+
+ callback.Run(std::move(devices));
+}
+
+scoped_refptr<device::BluetoothAdapter> BluetoothAdapterService::GetAdapter() {
+ return adapter_;
+}
+
+void BluetoothAdapterService::DeviceAdded(device::BluetoothAdapter* adapter,
+ device::BluetoothDevice* device) {
+ std::string device_address = device->GetAddress();
+
+ // If unknown address was added, alert client
+ if (addresses_.insert(device_address).second && client_) {
scheib 2016/09/26 19:37:27 Do we need this logic here? Why not pass through t
mbrunson 2016/09/28 02:18:22 Done.
+ auto device_info = ConstructDeviceInfoStruct(device);
+ client_->DeviceAdded(std::move(device_info));
+ }
+}
+
+void BluetoothAdapterService::DeviceRemoved(device::BluetoothAdapter* adapter,
+ device::BluetoothDevice* device) {
+ std::string device_address = device->GetAddress();
+
+ // If known address was removed, alert client
+ if (addresses_.erase(device_address) && client_) {
+ auto device_info = ConstructDeviceInfoStruct(device);
+ client_->DeviceRemoved(std::move(device_info));
+ }
+}
+
+bluetooth::mojom::DeviceInfoPtr
+BluetoothAdapterService::ConstructDeviceInfoStruct(
+ device::BluetoothDevice* device) {
+ bluetooth::mojom::DeviceInfoPtr device_info =
+ bluetooth::mojom::DeviceInfo::New();
+
+ device_info->name = device->GetName();
+ device_info->name_for_display =
+ base::UTF16ToUTF8(device->GetNameForDisplay());
+ device_info->id = device->GetIdentifier();
+ device_info->address = device->GetAddress();
+
+ return device_info;
+}

Powered by Google App Engine
This is Rietveld 408576698