| // Copyright 2019 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 CHROME_BROWSER_UI_HID_HID_CHOOSER_CONTROLLER_H_ |
| #define CHROME_BROWSER_UI_HID_HID_CHOOSER_CONTROLLER_H_ |
| |
| #include <map> |
| #include <string> |
| #include <vector> |
| |
| #include "base/memory/weak_ptr.h" |
| #include "base/scoped_observer.h" |
| #include "base/strings/string16.h" |
| #include "chrome/browser/chooser_controller/chooser_controller.h" |
| #include "chrome/browser/hid/hid_chooser_context.h" |
| #include "content/public/browser/hid_chooser.h" |
| #include "services/device/public/mojom/hid.mojom-forward.h" |
| #include "third_party/blink/public/mojom/hid/hid.mojom.h" |
| #include "url/origin.h" |
| |
| namespace content { |
| class RenderFrameHost; |
| } // namespace content |
| |
| class HidChooserContext; |
| |
| // HidChooserController provides data for the WebHID API permission prompt. |
| class HidChooserController : public ChooserController, |
| public HidChooserContext::DeviceObserver { |
| public: |
| // Construct a chooser controller for Human Interface Devices (HID). |
| // |render_frame_host| is used to initialize the chooser strings and to access |
| // the requesting and embedding origins. |callback| is called when the chooser |
| // is closed, either by selecting an item or by dismissing the chooser dialog. |
| // The callback is called with the selected device, or nullptr if no device is |
| // selected. |
| HidChooserController(content::RenderFrameHost* render_frame_host, |
| std::vector<blink::mojom::HidDeviceFilterPtr> filters, |
| content::HidChooser::Callback callback); |
| HidChooserController(HidChooserController&) = delete; |
| HidChooserController& operator=(HidChooserController&) = delete; |
| ~HidChooserController() override; |
| |
| // ChooserController: |
| bool ShouldShowHelpButton() const override; |
| base::string16 GetNoOptionsText() const override; |
| base::string16 GetOkButtonLabel() const override; |
| std::pair<base::string16, base::string16> GetThrobberLabelAndTooltip() |
| const override; |
| size_t NumOptions() const override; |
| base::string16 GetOption(size_t index) const override; |
| bool IsPaired(size_t index) const override; |
| void Select(const std::vector<size_t>& indices) override; |
| void Cancel() override; |
| void Close() override; |
| void OpenHelpCenterUrl() const override; |
| |
| // HidChooserContext::DeviceObserver: |
| void OnDeviceAdded(const device::mojom::HidDeviceInfo& device_info) override; |
| void OnDeviceRemoved( |
| const device::mojom::HidDeviceInfo& device_info) override; |
| void OnHidManagerConnectionError() override; |
| void OnHidChooserContextShutdown() override; |
| |
| private: |
| void OnGotDevices(std::vector<device::mojom::HidDeviceInfoPtr> devices); |
| bool DisplayDevice(const device::mojom::HidDeviceInfo& device) const; |
| bool FilterMatchesAny(const device::mojom::HidDeviceInfo& device) const; |
| |
| // Add |device_info| to |device_map_|. The device is added to the chooser item |
| // representing the physical device. If the chooser item does not yet exist, a |
| // new item is appended. Returns true if an item was appended. |
| bool AddDeviceInfo(const device::mojom::HidDeviceInfo& device_info); |
| |
| // Remove |device_info| from |device_map_|. The device info is removed from |
| // the chooser item representing the physical device. If this would cause the |
| // item to be empty, the chooser item is removed. Does nothing if the device |
| // is not in the chooser item. Returns true if an item was removed. |
| bool RemoveDeviceInfo(const device::mojom::HidDeviceInfo& device_info); |
| |
| std::vector<blink::mojom::HidDeviceFilterPtr> filters_; |
| content::HidChooser::Callback callback_; |
| const url::Origin requesting_origin_; |
| const url::Origin embedding_origin_; |
| const int frame_tree_node_id_; |
| |
| // The lifetime of the chooser context is tied to the browser context used to |
| // create it, and may be destroyed while the chooser is still active. |
| base::WeakPtr<HidChooserContext> chooser_context_; |
| |
| // Information about connected devices and their HID interfaces. A single |
| // physical device may expose multiple HID interfaces. Keys are physical |
| // device IDs, values are collections of HidDeviceInfo objects representing |
| // the HID interfaces hosted by the physical device. |
| std::map<std::string, std::vector<device::mojom::HidDeviceInfoPtr>> |
| device_map_; |
| |
| // An ordered list of physical device IDs that determines the order of items |
| // in the chooser. |
| std::vector<std::string> items_; |
| |
| ScopedObserver<HidChooserContext, |
| HidChooserContext::DeviceObserver, |
| &HidChooserContext::AddDeviceObserver, |
| &HidChooserContext::RemoveDeviceObserver> |
| observer_{this}; |
| |
| base::WeakPtrFactory<HidChooserController> weak_factory_{this}; |
| }; |
| |
| #endif // CHROME_BROWSER_UI_HID_HID_CHOOSER_CONTROLLER_H_ |