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

Unified Diff: device/devices_app/usb/device_manager_impl.cc

Issue 1165223004: Introduce the devices Mojo app (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: move mojo USB sources into devices_app to keep mojo dependencies separated from device/usb Created 5 years, 6 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: device/devices_app/usb/device_manager_impl.cc
diff --git a/device/devices_app/usb/device_manager_impl.cc b/device/devices_app/usb/device_manager_impl.cc
new file mode 100644
index 0000000000000000000000000000000000000000..6776438c953a5e69620bd802e3d886ab49eef751
--- /dev/null
+++ b/device/devices_app/usb/device_manager_impl.cc
@@ -0,0 +1,159 @@
+// Copyright 2015 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 "device/devices_app/usb/device_manager_impl.h"
+
+#include "base/bind.h"
+#include "base/location.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/sequenced_task_runner.h"
+#include "base/thread_task_runner_handle.h"
+#include "device/core/device_client.h"
+#include "device/devices_app/usb/device_impl.h"
+#include "device/devices_app/usb/public/cpp/device_manager_delegate.h"
+#include "device/devices_app/usb/public/interfaces/device.mojom.h"
+#include "device/devices_app/usb/type_converters.h"
+#include "device/usb/usb_device.h"
+#include "device/usb/usb_device_filter.h"
+#include "device/usb/usb_service.h"
+#include "third_party/mojo/src/mojo/public/cpp/bindings/array.h"
+#include "third_party/mojo/src/mojo/public/cpp/bindings/interface_request.h"
+
+namespace device {
+namespace usb {
+
+namespace {
+
+void OnGetDevicesOnServiceThread(
+ const UsbService::GetDevicesCallback& callback,
+ scoped_refptr<base::TaskRunner> callback_task_runner,
+ const std::vector<scoped_refptr<UsbDevice>>& devices) {
+ callback_task_runner->PostTask(FROM_HERE, base::Bind(callback, devices));
+}
+
+void GetDevicesOnServiceThread(
+ const UsbService::GetDevicesCallback& callback,
+ scoped_refptr<base::TaskRunner> callback_task_runner) {
+ DCHECK(DeviceClient::Get());
+ UsbService* usb_service = DeviceClient::Get()->GetUsbService();
+ if (!usb_service) {
+ std::vector<scoped_refptr<UsbDevice>> no_devices;
+ callback_task_runner->PostTask(FROM_HERE, base::Bind(callback, no_devices));
+ return;
+ }
+ usb_service->GetDevices(
+ base::Bind(&OnGetDevicesOnServiceThread, callback, callback_task_runner));
+}
+
+void RunOpenDeviceCallback(const DeviceManager::OpenDeviceCallback& callback,
+ OpenDeviceError error) {
+ callback.Run(error);
+}
+
+void OnOpenDeviceOnServiceThread(
+ mojo::InterfaceRequest<Device> device_request,
+ const DeviceManager::OpenDeviceCallback& callback,
+ scoped_refptr<base::TaskRunner> callback_task_runner,
+ scoped_refptr<UsbDeviceHandle> device_handle) {
+ if (!device_handle) {
+ callback_task_runner->PostTask(FROM_HERE,
+ base::Bind(&RunOpenDeviceCallback, callback,
+ OPEN_DEVICE_ERROR_ACCESS_DENIED));
+ return;
+ }
+
+ // Owned by its MessagePipe.
+ new DeviceImpl(device_handle, device_request.Pass());
+
+ callback_task_runner->PostTask(
+ FROM_HERE,
+ base::Bind(&RunOpenDeviceCallback, callback, OPEN_DEVICE_ERROR_OK));
+}
+
+void OpenDeviceOnServiceThread(
+ const std::string& guid,
+ mojo::InterfaceRequest<Device> device_request,
+ const DeviceManager::OpenDeviceCallback& callback,
+ scoped_refptr<base::TaskRunner> callback_task_runner) {
+ DCHECK(DeviceClient::Get());
+ UsbService* usb_service = DeviceClient::Get()->GetUsbService();
+ if (!usb_service) {
+ callback_task_runner->PostTask(FROM_HERE,
+ base::Bind(&RunOpenDeviceCallback, callback,
+ OPEN_DEVICE_ERROR_NOT_FOUND));
+ return;
+ }
+ scoped_refptr<UsbDevice> device = usb_service->GetDevice(guid);
+ if (!device) {
+ callback_task_runner->PostTask(FROM_HERE,
+ base::Bind(&RunOpenDeviceCallback, callback,
+ OPEN_DEVICE_ERROR_NOT_FOUND));
+ return;
+ }
+ device->Open(base::Bind(&OnOpenDeviceOnServiceThread,
+ base::Passed(&device_request), callback,
+ callback_task_runner));
+}
+
+} // namespace
+
+DeviceManagerImpl::DeviceManagerImpl(
+ mojo::InterfaceRequest<DeviceManager> request,
+ scoped_ptr<DeviceManagerDelegate> delegate,
+ scoped_refptr<base::SequencedTaskRunner> service_task_runner)
+ : binding_(this, request.Pass()),
+ delegate_(delegate.Pass()),
+ service_task_runner_(service_task_runner),
+ weak_factory_(this) {
+}
+
+DeviceManagerImpl::~DeviceManagerImpl() {
+}
+
+void DeviceManagerImpl::set_error_handler(mojo::ErrorHandler* error_handler) {
+ binding_.set_error_handler(error_handler);
+}
+
+void DeviceManagerImpl::GetDevices(EnumerationOptionsPtr options,
+ const GetDevicesCallback& callback) {
+ auto get_devices_callback =
+ base::Bind(&DeviceManagerImpl::OnGetDevices, weak_factory_.GetWeakPtr(),
+ base::Passed(&options), callback);
+ service_task_runner_->PostTask(
+ FROM_HERE, base::Bind(&GetDevicesOnServiceThread, get_devices_callback,
+ base::ThreadTaskRunnerHandle::Get()));
+}
+
+void DeviceManagerImpl::OpenDevice(
+ const mojo::String& guid,
+ mojo::InterfaceRequest<Device> device_request,
+ const OpenDeviceCallback& callback) {
+ service_task_runner_->PostTask(
+ FROM_HERE, base::Bind(&OpenDeviceOnServiceThread, guid,
+ base::Passed(&device_request), callback,
+ base::ThreadTaskRunnerHandle::Get()));
+}
+
+void DeviceManagerImpl::OnGetDevices(
+ EnumerationOptionsPtr options,
+ const GetDevicesCallback& callback,
+ const std::vector<scoped_refptr<UsbDevice>>& devices) {
+ auto filters = options->filters.To<std::vector<UsbDeviceFilter>>();
+ mojo::Array<DeviceInfoPtr> device_infos(0);
+ for (size_t i = 0; i < devices.size(); ++i) {
+ DeviceInfoPtr device_info = DeviceInfo::From(*devices[i]);
+ if (UsbDeviceFilter::MatchesAny(devices[i], filters) &&
+ delegate_->IsDeviceAllowed(*device_info)) {
+ const UsbConfigDescriptor* config = devices[i]->GetConfiguration();
+ device_info->configurations = mojo::Array<ConfigurationInfoPtr>::New(0);
+ if (config)
+ device_info->configurations.push_back(ConfigurationInfo::From(*config));
+ device_infos.push_back(device_info.Pass());
+ }
+ }
+ callback.Run(device_infos.Pass());
+}
+
+} // namespace usb
+} // namespace device
« no previous file with comments | « device/devices_app/usb/device_manager_impl.h ('k') | device/devices_app/usb/device_manager_impl_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698