blob: c99220b407214057e8ff24164a8cd11dcf6c51f7 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
// Copyright (c) 2011 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.
#include "chrome/common/extensions/extension_set.h"
#include "base/logging.h"
#include "chrome/common/url_constants.h"
using WebKit::WebSecurityOrigin;
ExtensionURLInfo::ExtensionURLInfo(WebSecurityOrigin origin, const GURL& url)
: origin_(origin),
url_(url) {
DCHECK(!origin_.isNull());
}
ExtensionURLInfo::ExtensionURLInfo(const GURL& url)
: url_(url) {
}
ExtensionSet::ExtensionSet() {
}
ExtensionSet::~ExtensionSet() {
}
size_t ExtensionSet::size() const {
return extensions_.size();
}
bool ExtensionSet::is_empty() const {
return extensions_.empty();
}
bool ExtensionSet::Contains(const std::string& extension_id) const {
return extensions_.find(extension_id) != extensions_.end();
}
void ExtensionSet::Insert(const scoped_refptr<const Extension>& extension) {
extensions_[extension->id()] = extension;
}
void ExtensionSet::Remove(const std::string& id) {
extensions_.erase(id);
}
void ExtensionSet::Clear() {
extensions_.clear();
}
std::string ExtensionSet::GetIDByURL(const ExtensionURLInfo& info) const {
DCHECK(!info.origin().isNull());
if (info.url().SchemeIs(chrome::kExtensionScheme))
return info.origin().isUnique() ? "" : info.url().host();
const Extension* extension = GetByURL(info);
if (!extension)
return "";
return extension->id();
}
const Extension* ExtensionSet::GetByURL(const ExtensionURLInfo& info) const {
// In the common case, the document's origin will correspond to its URL,
// but in some rare cases involving sandboxing, the two will be different.
// We catch those cases by checking whether the document's origin is unique.
// If that's not the case, then we conclude that the document's security
// context is well-described by its URL and proceed to use only the URL.
if (!info.origin().isNull() && info.origin().isUnique())
return NULL;
if (info.url().SchemeIs(chrome::kExtensionScheme))
return GetByID(info.url().host());
ExtensionMap::const_iterator i = extensions_.begin();
for (; i != extensions_.end(); ++i) {
if (i->second->web_extent().MatchesURL(info.url()))
return i->second.get();
}
return NULL;
}
bool ExtensionSet::InSameExtent(const GURL& old_url,
const GURL& new_url) const {
return GetByURL(ExtensionURLInfo(old_url)) ==
GetByURL(ExtensionURLInfo(new_url));
}
const Extension* ExtensionSet::GetByID(const std::string& id) const {
ExtensionMap::const_iterator i = extensions_.find(id);
if (i != extensions_.end())
return i->second.get();
else
return NULL;
}
bool ExtensionSet::ExtensionBindingsAllowed(
const ExtensionURLInfo& info) const {
if (info.origin().isUnique())
return false;
if (info.url().SchemeIs(chrome::kExtensionScheme))
return true;
ExtensionMap::const_iterator i = extensions_.begin();
for (; i != extensions_.end(); ++i) {
if (i->second->location() == Extension::COMPONENT &&
i->second->web_extent().MatchesURL(info.url()))
return true;
}
return false;
}
|