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

Unified Diff: chrome/browser/usb/usb_chooser_permission_context.h

Issue 1382783002: Store USB device permissions in website settings. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Remove UsbPermissionContext and add ChooserPermissionContext helper functions. Created 5 years, 2 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: chrome/browser/usb/usb_chooser_permission_context.h
diff --git a/chrome/browser/usb/usb_chooser_permission_context.h b/chrome/browser/usb/usb_chooser_permission_context.h
new file mode 100644
index 0000000000000000000000000000000000000000..d583cf0303baa2e629acd00dc37bbe83f59598af
--- /dev/null
+++ b/chrome/browser/usb/usb_chooser_permission_context.h
@@ -0,0 +1,48 @@
+// 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.
+
+#ifndef CHROME_BROWSER_USB_USB_CHOOSER_PERMISSION_CONTEXT_H_
+#define CHROME_BROWSER_USB_USB_CHOOSER_PERMISSION_CONTEXT_H_
+
+#include <map>
+#include <set>
+#include <string>
+
+#include "base/scoped_observer.h"
+#include "chrome/browser/permissions/chooser_permission_context_base.h"
+#include "device/usb/usb_service.h"
+
+class UsbChooserPermissionContext : public ChooserPermissionContextBase,
raymes 2015/10/14 02:07:04 I'm not sure inheritance is actually the right cho
Reilly Grant (use Gerrit) 2015/10/22 00:57:03 The idea of ChooserContextBase, like PermissionCon
raymes 2015/10/29 06:14:41 I don't think it's much like PermissionContextBase
raymes 2015/10/29 06:31:26 With that said, if there were other (non-UI specif
Reilly Grant (use Gerrit) 2015/10/29 20:59:59 In working on the UI I've added more (non-UI) virt
+ public device::UsbService::Observer {
+ public:
+ explicit UsbChooserPermissionContext(Profile* profile);
+ ~UsbChooserPermissionContext() override;
+
+ void GrantDevicePermission(const GURL& requesting_origin,
+ const GURL& embedding_origin,
+ const std::string& guid);
raymes 2015/10/14 02:07:04 Could you please document what the GUID is?
Reilly Grant (use Gerrit) 2015/10/22 00:57:03 Done.
+ void RevokeDevicePermission(const GURL& requesting_origin,
+ const GURL& embedding_origin,
+ const std::string& guid);
+ bool HasDevicePermission(const GURL& requesting_origin,
+ const GURL& embedding_origin,
+ const std::string& guid);
+
+ private:
+ // ChooserPermissionContextBase implementation.
+ bool IsValidObject(const base::DictionaryValue& object) override;
+ std::string GetStringToDisplayForObject(
+ const base::DictionaryValue& object) override;
+
+ // device::UsbService::Observer implementation.
+ void OnDeviceRemoved(scoped_refptr<device::UsbDevice> device) override;
+
+ std::map<GURL, std::set<std::string>> ephemeral_devices_;
+ device::UsbService* usb_service_;
+ ScopedObserver<device::UsbService, device::UsbService::Observer> observer_;
+
+ DISALLOW_COPY_AND_ASSIGN(UsbChooserPermissionContext);
+};
+
+#endif // CHROME_BROWSER_USB_USB_CHOOSER_PERMISSION_CONTEXT_H_

Powered by Google App Engine
This is Rietveld 408576698