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

Side by Side Diff: chrome/browser/usb/usb_tab_helper.cc

Issue 2815003005: Integrate WebUSB with Feature Policy (Closed)
Patch Set: Fixed usb-allowed-by-feature-policy.https.sub.html Created 3 years, 7 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 #include "chrome/browser/usb/usb_tab_helper.h" 5 #include "chrome/browser/usb/usb_tab_helper.h"
6 6
7 #include <memory> 7 #include <memory>
8 #include <utility> 8 #include <utility>
9 9
10 #include "chrome/browser/ui/browser_finder.h" 10 #include "chrome/browser/ui/browser_finder.h"
11 #include "chrome/browser/ui/tabs/tab_strip_model.h" 11 #include "chrome/browser/ui/tabs/tab_strip_model.h"
12 #include "chrome/browser/usb/web_usb_permission_provider.h" 12 #include "chrome/browser/usb/web_usb_permission_provider.h"
13 #include "content/public/browser/render_frame_host.h"
14 #include "content/public/common/content_features.h"
13 #include "device/usb/mojo/device_manager_impl.h" 15 #include "device/usb/mojo/device_manager_impl.h"
16 #include "mojo/public/cpp/bindings/message.h"
17 #include "third_party/WebKit/public/platform/WebFeaturePolicy.h"
14 18
15 #if defined(OS_ANDROID) 19 #if defined(OS_ANDROID)
16 #include "chrome/browser/android/usb/web_usb_chooser_service_android.h" 20 #include "chrome/browser/android/usb/web_usb_chooser_service_android.h"
17 #else 21 #else
18 #include "chrome/browser/usb/web_usb_chooser_service.h" 22 #include "chrome/browser/usb/web_usb_chooser_service.h"
19 #endif // defined(OS_ANDROID) 23 #endif // defined(OS_ANDROID)
20 24
21 using content::RenderFrameHost; 25 using content::RenderFrameHost;
22 using content::WebContents; 26 using content::WebContents;
23 27
28 namespace {
29
30 // The renderer performs its own feature policy checks so a request that gets
31 // to the browser process indicates malicous code.
32 const char kFeaturePolicyViolation[] =
33 "Feature policy blocks access to WebUSB.";
34
35 } // namespace
36
24 DEFINE_WEB_CONTENTS_USER_DATA_KEY(UsbTabHelper); 37 DEFINE_WEB_CONTENTS_USER_DATA_KEY(UsbTabHelper);
25 38
26 struct FrameUsbServices { 39 struct FrameUsbServices {
27 std::unique_ptr<WebUSBPermissionProvider> permission_provider; 40 std::unique_ptr<WebUSBPermissionProvider> permission_provider;
28 #if defined(OS_ANDROID) 41 #if defined(OS_ANDROID)
29 std::unique_ptr<WebUsbChooserServiceAndroid> chooser_service; 42 std::unique_ptr<WebUsbChooserServiceAndroid> chooser_service;
30 #else 43 #else
31 std::unique_ptr<WebUsbChooserService> chooser_service; 44 std::unique_ptr<WebUsbChooserService> chooser_service;
32 #endif // defined(OS_ANDROID) 45 #endif // defined(OS_ANDROID)
33 int device_connection_count_ = 0; 46 int device_connection_count_ = 0;
34 }; 47 };
35 48
36 // static 49 // static
37 UsbTabHelper* UsbTabHelper::GetOrCreateForWebContents( 50 UsbTabHelper* UsbTabHelper::GetOrCreateForWebContents(
38 WebContents* web_contents) { 51 WebContents* web_contents) {
39 UsbTabHelper* tab_helper = FromWebContents(web_contents); 52 UsbTabHelper* tab_helper = FromWebContents(web_contents);
40 if (!tab_helper) { 53 if (!tab_helper) {
41 CreateForWebContents(web_contents); 54 CreateForWebContents(web_contents);
42 tab_helper = FromWebContents(web_contents); 55 tab_helper = FromWebContents(web_contents);
43 } 56 }
44 return tab_helper; 57 return tab_helper;
45 } 58 }
46 59
47 UsbTabHelper::~UsbTabHelper() {} 60 UsbTabHelper::~UsbTabHelper() {}
48 61
49 void UsbTabHelper::CreateDeviceManager( 62 void UsbTabHelper::CreateDeviceManager(
50 RenderFrameHost* render_frame_host, 63 RenderFrameHost* render_frame_host,
51 mojo::InterfaceRequest<device::mojom::UsbDeviceManager> request) { 64 mojo::InterfaceRequest<device::mojom::UsbDeviceManager> request) {
52 DCHECK(WebContents::FromRenderFrameHost(render_frame_host) == web_contents()); 65 if (!AllowedByFeaturePolicy(render_frame_host)) {
66 mojo::ReportBadMessage(kFeaturePolicyViolation);
67 return;
68 }
53 device::usb::DeviceManagerImpl::Create( 69 device::usb::DeviceManagerImpl::Create(
54 GetPermissionProvider(render_frame_host), std::move(request)); 70 GetPermissionProvider(render_frame_host), std::move(request));
55 } 71 }
56 72
57 void UsbTabHelper::CreateChooserService( 73 void UsbTabHelper::CreateChooserService(
58 content::RenderFrameHost* render_frame_host, 74 content::RenderFrameHost* render_frame_host,
59 mojo::InterfaceRequest<device::mojom::UsbChooserService> request) { 75 mojo::InterfaceRequest<device::mojom::UsbChooserService> request) {
76 if (!AllowedByFeaturePolicy(render_frame_host)) {
77 mojo::ReportBadMessage(kFeaturePolicyViolation);
78 return;
79 }
60 GetChooserService(render_frame_host, std::move(request)); 80 GetChooserService(render_frame_host, std::move(request));
61 } 81 }
62 82
63 void UsbTabHelper::IncrementConnectionCount( 83 void UsbTabHelper::IncrementConnectionCount(
64 RenderFrameHost* render_frame_host) { 84 RenderFrameHost* render_frame_host) {
65 auto it = frame_usb_services_.find(render_frame_host); 85 auto it = frame_usb_services_.find(render_frame_host);
66 DCHECK(it != frame_usb_services_.end()); 86 DCHECK(it != frame_usb_services_.end());
67 it->second->device_connection_count_++; 87 it->second->device_connection_count_++;
68 NotifyTabStateChanged(); 88 NotifyTabStateChanged();
69 } 89 }
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after
137 #if !defined(OS_ANDROID) 157 #if !defined(OS_ANDROID)
138 Browser* browser = chrome::FindBrowserWithWebContents(web_contents()); 158 Browser* browser = chrome::FindBrowserWithWebContents(web_contents());
139 if (browser) { 159 if (browser) {
140 TabStripModel* tab_strip_model = browser->tab_strip_model(); 160 TabStripModel* tab_strip_model = browser->tab_strip_model();
141 tab_strip_model->UpdateWebContentsStateAt( 161 tab_strip_model->UpdateWebContentsStateAt(
142 tab_strip_model->GetIndexOfWebContents(web_contents()), 162 tab_strip_model->GetIndexOfWebContents(web_contents()),
143 TabStripModelObserver::ALL); 163 TabStripModelObserver::ALL);
144 } 164 }
145 #endif 165 #endif
146 } 166 }
167
168 bool UsbTabHelper::AllowedByFeaturePolicy(
169 RenderFrameHost* render_frame_host) const {
170 DCHECK(WebContents::FromRenderFrameHost(render_frame_host) == web_contents());
171 if (base::FeatureList::IsEnabled(features::kFeaturePolicy)) {
172 return render_frame_host->IsFeatureEnabled(
173 blink::WebFeaturePolicyFeature::kUsb);
174 }
175 return web_contents()->GetMainFrame() == render_frame_host;
176 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698