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

Side by Side Diff: chrome/common/extensions/extension_set.h

Issue 8659009: Consider the origin when computing extension permissions (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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_COMMON_EXTENSIONS_EXTENSION_SET_H_ 5 #ifndef CHROME_COMMON_EXTENSIONS_EXTENSION_SET_H_
6 #define CHROME_COMMON_EXTENSIONS_EXTENSION_SET_H_ 6 #define CHROME_COMMON_EXTENSIONS_EXTENSION_SET_H_
7 #pragma once 7 #pragma once
8 8
9 #include <map> 9 #include <map>
10 #include <string> 10 #include <string>
11 #include <vector> 11 #include <vector>
12 12
13 #include "base/gtest_prod_util.h" 13 #include "base/gtest_prod_util.h"
14 #include "base/memory/ref_counted.h" 14 #include "base/memory/ref_counted.h"
15 #include "chrome/common/extensions/extension.h" 15 #include "chrome/common/extensions/extension.h"
16 #include "googleurl/src/gurl.h" 16 #include "googleurl/src/gurl.h"
17 #include "third_party/WebKit/Source/WebKit/chromium/public/WebSecurityOrigin.h"
17 18
18 // The one true extension container. Extensions are identified by their id. 19 // The one true extension container. Extensions are identified by their id.
19 // Only one extension can be in the set with a given ID. 20 // Only one extension can be in the set with a given ID.
20 class ExtensionSet { 21 class ExtensionSet {
21 public: 22 public:
22 typedef std::pair<FilePath, std::string> ExtensionPathAndDefaultLocale; 23 typedef std::pair<FilePath, std::string> ExtensionPathAndDefaultLocale;
23 typedef std::map<std::string, scoped_refptr<const Extension> > ExtensionMap; 24 typedef std::map<std::string, scoped_refptr<const Extension> > ExtensionMap;
24 typedef ExtensionMap::const_iterator const_iterator; 25 typedef ExtensionMap::const_iterator const_iterator;
25 26
26 ExtensionSet(); 27 ExtensionSet();
(...skipping 11 matching lines...) Expand all
38 39
39 // Adds the specified extension to the set. The set becomes an owner. Any 40 // Adds the specified extension to the set. The set becomes an owner. Any
40 // previous extension with the same ID is removed. 41 // previous extension with the same ID is removed.
41 void Insert(const scoped_refptr<const Extension>& extension); 42 void Insert(const scoped_refptr<const Extension>& extension);
42 43
43 // Removes the specified extension. 44 // Removes the specified extension.
44 void Remove(const std::string& id); 45 void Remove(const std::string& id);
45 46
46 // Returns the extension ID that the given URL is a part of, or empty if 47 // Returns the extension ID that the given URL is a part of, or empty if
47 // none. This includes web URLs that are part of an extension's web extent. 48 // none. This includes web URLs that are part of an extension's web extent.
48 std::string GetIdByURL(const GURL& url) const; 49 std::string GetIdByURL(WebKit::WebSecurityOrigin origin,
Aaron Boodman 2011/11/30 02:01:31 What about defining an ExtensionURLInfo struct or
Aaron Boodman 2011/11/30 02:04:45 And would at least ensure people think twice when
abarth-chromium 2011/11/30 02:04:49 Will do.
50 const GURL& url) const;
49 51
50 // Returns the Extension that the given URL is a part of, or NULL if none. 52 // Returns the Extension that the given URL is a part of, or NULL if none.
51 // This includes web URLs that are part of an extension's web extent. 53 // This includes web URLs that are part of an extension's web extent.
52 // NOTE: This can return NULL if called before UpdateExtensions receives 54 // NOTE: This can return NULL if called before UpdateExtensions receives
53 // bulk extension data (e.g. if called from 55 // bulk extension data (e.g. if called from
54 // EventBindings::HandleContextCreated) 56 // EventBindings::HandleContextCreated)
55 const Extension* GetByURL(const GURL& url) const; 57 const Extension* GetByURL(WebKit::WebSecurityOrigin origin,
58 const GURL& url) const;
59
60 const Extension* GetByURLWithoutSecurityCheck(const GURL& url) const;
Aaron Boodman 2011/11/30 02:01:31 ExtensionURLInfo could have a constructor that jus
56 61
57 // Returns true if |new_url| is in the extent of the same extension as 62 // Returns true if |new_url| is in the extent of the same extension as
58 // |old_url|. Also returns true if neither URL is in an app. 63 // |old_url|. Also returns true if neither URL is in an app.
59 bool InSameExtent(const GURL& old_url, const GURL& new_url) const; 64 bool InSameExtent(const GURL& old_url, const GURL& new_url) const;
60 65
61 // Look up an Extension object by id. 66 // Look up an Extension object by id.
62 const Extension* GetByID(const std::string& id) const; 67 const Extension* GetByID(const std::string& id) const;
63 68
64 // Returns true if |url| should get extension api bindings and be permitted 69 // Returns true if |url| should get extension api bindings and be permitted
65 // to make api calls. Note that this is independent of what extension 70 // to make api calls. Note that this is independent of what extension
66 // permissions the given extension has been granted. 71 // permissions the given extension has been granted.
67 bool ExtensionBindingsAllowed(const GURL& url) const; 72 bool ExtensionBindingsAllowed(WebKit::WebSecurityOrigin origin,
73 const GURL& url) const;
68 74
69 private: 75 private:
70 FRIEND_TEST_ALL_PREFIXES(ExtensionSetTest, ExtensionSet); 76 FRIEND_TEST_ALL_PREFIXES(ExtensionSetTest, ExtensionSet);
71 77
72 ExtensionMap extensions_; 78 ExtensionMap extensions_;
73 79
74 DISALLOW_COPY_AND_ASSIGN(ExtensionSet); 80 DISALLOW_COPY_AND_ASSIGN(ExtensionSet);
75 }; 81 };
76 82
77 #endif // CHROME_COMMON_EXTENSIONS_EXTENSION_SET_H_ 83 #endif // CHROME_COMMON_EXTENSIONS_EXTENSION_SET_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698