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

Side by Side Diff: chrome/browser/usb/web_usb_permission_provider.h

Issue 1369643002: Add configuration and interface permission checks to DeviceImpl. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add new method ot Android USB mocks. Created 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_USB_WEB_USB_PERMISSION_PROVIDER_H_ 5 #ifndef CHROME_BROWSER_USB_WEB_USB_PERMISSION_PROVIDER_H_
6 #define CHROME_BROWSER_USB_WEB_USB_PERMISSION_PROVIDER_H_ 6 #define CHROME_BROWSER_USB_WEB_USB_PERMISSION_PROVIDER_H_
7 7
8 #include "device/devices_app/usb/public/interfaces/permission_provider.mojom.h" 8 #include "device/devices_app/usb/public/interfaces/permission_provider.mojom.h"
9 #include "mojo/common/weak_binding_set.h"
9 #include "third_party/mojo/src/mojo/public/cpp/bindings/array.h" 10 #include "third_party/mojo/src/mojo/public/cpp/bindings/array.h"
10 #include "third_party/mojo/src/mojo/public/cpp/bindings/interface_request.h" 11 #include "third_party/mojo/src/mojo/public/cpp/bindings/interface_request.h"
11 #include "third_party/mojo/src/mojo/public/cpp/bindings/strong_binding.h"
12 12
13 namespace content { 13 namespace content {
14 class RenderFrameHost; 14 class RenderFrameHost;
15 } 15 }
16 16
17 class WebUSBPermissionProvider : public device::usb::PermissionProvider { 17 class WebUSBPermissionProvider : public device::usb::PermissionProvider {
18 public: 18 public:
19 static void Create( 19 static void Create(
20 content::RenderFrameHost* render_frame_host, 20 content::RenderFrameHost* render_frame_host,
21 mojo::InterfaceRequest<device::usb::PermissionProvider> request); 21 mojo::InterfaceRequest<device::usb::PermissionProvider> request);
22 22
23 ~WebUSBPermissionProvider() override; 23 ~WebUSBPermissionProvider() override;
24 24
25 private: 25 private:
26 WebUSBPermissionProvider(content::RenderFrameHost* render_frame_host, 26 WebUSBPermissionProvider(content::RenderFrameHost* render_frame_host,
27 mojo::InterfaceRequest<PermissionProvider> request); 27 mojo::InterfaceRequest<PermissionProvider> request);
28 28
29 // device::usb::PermissionProvider implementation. 29 // device::usb::PermissionProvider implementation.
30 void HasDevicePermission( 30 void HasDevicePermission(
31 mojo::Array<device::usb::DeviceInfoPtr> requested_devices, 31 mojo::Array<device::usb::DeviceInfoPtr> requested_devices,
32 const HasDevicePermissionCallback& callback) override; 32 const HasDevicePermissionCallback& callback) override;
33 void HasConfigurationPermission(
34 uint8_t requested_configuration,
35 device::usb::DeviceInfoPtr device,
36 const HasInterfacePermissionCallback& callback) override;
37 void HasInterfacePermission(
38 uint8_t requested_interface,
39 uint8_t configuration_value,
40 device::usb::DeviceInfoPtr device,
41 const HasInterfacePermissionCallback& callback) override;
42 void Bind(
43 mojo::InterfaceRequest<device::usb::PermissionProvider> request) override;
33 44
34 mojo::StrongBinding<PermissionProvider> binding_; 45 void OnConnectionError();
46
47 mojo::WeakBindingSet<PermissionProvider> bindings_;
35 content::RenderFrameHost* const render_frame_host_; 48 content::RenderFrameHost* const render_frame_host_;
36 }; 49 };
37 50
38 #endif // CHROME_BROWSER_USB_WEB_USB_PERMISSION_PROVIDER_H_ 51 #endif // CHROME_BROWSER_USB_WEB_USB_PERMISSION_PROVIDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698