// Copyright 2014 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. #ifndef DEVICE_USB_USB_SERVICE_H_ #define DEVICE_USB_USB_SERVICE_H_ #include #include #include #include #include #include "base/bind_helpers.h" #include "base/logging.h" #include "base/macros.h" #include "base/memory/ref_counted.h" #include "base/observer_list.h" #include "base/sequenced_task_runner.h" #include "base/single_thread_task_runner.h" #include "base/task_scheduler/task_traits.h" #include "base/threading/non_thread_safe.h" namespace device { class UsbDevice; // The USB service handles creating and managing an event handler thread that is // used to manage and dispatch USB events. It is also responsible for device // discovery on the system, which allows it to re-use device handles to prevent // competition for the same USB device. class UsbService : public base::NonThreadSafe { public: using GetDevicesCallback = base::Callback>&)>; class Observer { public: virtual ~Observer(); // These events are delivered from the thread on which the UsbService object // was created. virtual void OnDeviceAdded(scoped_refptr device); virtual void OnDeviceRemoved(scoped_refptr device); // For observers that need to process device removal after others have run. // Should not depend on any other service's knowledge of connected devices. virtual void OnDeviceRemovedCleanup(scoped_refptr device); // Notifies the observer that the UsbService it depends on is shutting down. virtual void WillDestroyUsbService(); }; // These task traits are to be used for posting blocking tasks to the task // scheduler. static constexpr base::TaskTraits kBlockingTaskTraits = { base::MayBlock(), base::TaskPriority::USER_VISIBLE, base::TaskShutdownBehavior::CONTINUE_ON_SHUTDOWN}; // Returns nullptr when initialization fails. static std::unique_ptr Create(); // Creates a SequencedTaskRunner with kBlockingTaskTraits. static scoped_refptr CreateBlockingTaskRunner(); virtual ~UsbService(); scoped_refptr GetDevice(const std::string& guid); // Enumerates available devices. virtual void GetDevices(const GetDevicesCallback& callback); void AddObserver(Observer* observer); void RemoveObserver(Observer* observer); // Methods to add and remove devices for testing purposes. Only a device added // by this method can be removed by RemoveDeviceForTesting(). void AddDeviceForTesting(scoped_refptr device); void RemoveDeviceForTesting(const std::string& device_guid); void GetTestDevices(std::vector>* devices); protected: UsbService(scoped_refptr blocking_task_runner); void NotifyDeviceAdded(scoped_refptr device); void NotifyDeviceRemoved(scoped_refptr device); const scoped_refptr& task_runner() const { return task_runner_; } const scoped_refptr& blocking_task_runner() const { return blocking_task_runner_; } std::unordered_map>& devices() { return devices_; } private: scoped_refptr task_runner_; scoped_refptr blocking_task_runner_; std::unordered_map> devices_; std::unordered_set testing_devices_; base::ObserverList observer_list_; DISALLOW_COPY_AND_ASSIGN(UsbService); }; } // namespace device #endif // DEVICE_USB_USB_SERVICE_H_