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

Unified Diff: chrome/browser/permissions/chooser_permission_context_base.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/permissions/chooser_permission_context_base.h
diff --git a/chrome/browser/permissions/chooser_permission_context_base.h b/chrome/browser/permissions/chooser_permission_context_base.h
new file mode 100644
index 0000000000000000000000000000000000000000..921bc478daed1772217acdf97b4db0fd881c1ee9
--- /dev/null
+++ b/chrome/browser/permissions/chooser_permission_context_base.h
@@ -0,0 +1,60 @@
+// 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_PERMISSIONS_CHOOSER_PERMISSION_CONTEXT_BASE_H_
+#define CHROME_BROWSER_PERMISSIONS_CHOOSER_PERMISSION_CONTEXT_BASE_H_
+
+#include <string>
+
+#include "base/memory/scoped_ptr.h"
+#include "base/memory/scoped_vector.h"
+#include "components/content_settings/core/common/content_settings_types.h"
+#include "components/keyed_service/core/keyed_service.h"
+
+namespace base {
+class DictionaryValue;
+class ListValue;
raymes 2015/10/14 02:07:04 nit: unused
Reilly Grant (use Gerrit) 2015/10/22 00:57:02 Done.
+class Value;
+}
+
+class GURL;
+class HostContentSettingsMap;
+class Profile;
+
+class ChooserPermissionContextBase : public KeyedService {
raymes 2015/10/14 02:07:04 Since this is quite different from a PermissionCon
Reilly Grant (use Gerrit) 2015/10/22 00:57:02 Done.
+ public:
raymes 2015/10/14 02:07:04 I think these should mostly be protected
Reilly Grant (use Gerrit) 2015/10/22 00:57:02 UI code will be calling these.
+ using ObjectList = ScopedVector<base::DictionaryValue>;
raymes 2015/10/14 02:07:04 nit: I'm not sure if this adds a lot (someone read
Reilly Grant (use Gerrit) 2015/10/22 00:57:02 Done.
+
+ ChooserPermissionContextBase(Profile* profile,
+ ContentSettingsType permission_type,
+ ContentSettingsType chooser_settings_type);
+ ~ChooserPermissionContextBase() override;
+
+ ObjectList GetPreviouslyChosenObjects(const GURL& requesting_origin,
+ const GURL& embedding_origin);
+ void GrantObjectPermission(const GURL& requesting_origin,
+ const GURL& embedding_origin,
+ scoped_ptr<base::DictionaryValue> object);
+ void RevokeObjectPermission(const GURL& requesting_origin,
+ const GURL& embedding_origin,
+ const base::DictionaryValue& object);
+
+ virtual bool IsValidObject(const base::DictionaryValue& object) = 0;
+ virtual std::string GetStringToDisplayForObject(
raymes 2015/10/14 02:07:04 Is this for UI? - I think it would be better to se
Reilly Grant (use Gerrit) 2015/10/22 00:57:02 I would rather keep all the knowledge about what a
raymes 2015/10/29 06:14:40 I disagree - I left an extended comment in usb_cho
Reilly Grant (use Gerrit) 2015/10/29 20:59:59 Done.
+ const base::DictionaryValue& object) = 0;
+
+ private:
+ scoped_ptr<base::DictionaryValue> GetWebsiteSetting(
+ const GURL& requesting_origin,
+ const GURL& embedding_origin);
+ void SetWebsiteSetting(const GURL& requesting_origin,
+ const GURL& embedding_origin,
+ scoped_ptr<base::Value> value);
+
+ HostContentSettingsMap* const host_content_settings_map_;
+ const ContentSettingsType permission_type_;
+ const ContentSettingsType chooser_settings_type_;
+};
+
+#endif // CHROME_BROWSER_PERMISSIONS_CHOOSER_PERMISSION_CONTEXT_BASE_H_

Powered by Google App Engine
This is Rietveld 408576698