blob: e7a4b092c42e711d4cf53df04f0688e18320e365 (
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
117
118
119
120
121
122
123
124
125
126
127
128
|
// Copyright (c) 2010 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/browser/extensions/extension_info_map.h"
#include "chrome/common/extensions/extension.h"
#include "chrome/common/url_constants.h"
#include "content/browser/browser_thread.h"
namespace {
static void CheckOnValidThread() {
DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
}
} // namespace
ExtensionInfoMap::ExtensionInfoMap() {
}
ExtensionInfoMap::~ExtensionInfoMap() {
}
void ExtensionInfoMap::AddExtension(const Extension* extension) {
CheckOnValidThread();
extension_info_[extension->id()] = extension;
}
void ExtensionInfoMap::RemoveExtension(const std::string& id) {
CheckOnValidThread();
Map::iterator iter = extension_info_.find(id);
if (iter != extension_info_.end()) {
extension_info_.erase(iter);
} else {
// NOTE: This can currently happen if we receive multiple unload
// notifications, e.g. setting incognito-enabled state for a
// disabled extension (e.g., via sync). See
// http://code.google.com/p/chromium/issues/detail?id=50582 .
NOTREACHED() << id;
}
}
std::string ExtensionInfoMap::GetNameForExtension(const std::string& id) const {
Map::const_iterator iter = extension_info_.find(id);
if (iter != extension_info_.end())
return iter->second->name();
else
return std::string();
}
FilePath ExtensionInfoMap::GetPathForExtension(const std::string& id) const {
Map::const_iterator iter = extension_info_.find(id);
if (iter != extension_info_.end())
return iter->second->path();
else
return FilePath();
}
bool ExtensionInfoMap::ExtensionHasWebExtent(const std::string& id) const {
Map::const_iterator iter = extension_info_.find(id);
return iter != extension_info_.end() &&
!iter->second->web_extent().is_empty();
}
bool ExtensionInfoMap::ExtensionCanLoadInIncognito(
const std::string& id) const {
Map::const_iterator iter = extension_info_.find(id);
// Only split-mode extensions can load in incognito profiles.
return iter != extension_info_.end() && iter->second->incognito_split_mode();
}
std::string ExtensionInfoMap::GetDefaultLocaleForExtension(
const std::string& id) const {
Map::const_iterator iter = extension_info_.find(id);
std::string result;
if (iter != extension_info_.end())
result = iter->second->default_locale();
return result;
}
ExtensionExtent ExtensionInfoMap::GetEffectiveHostPermissionsForExtension(
const std::string& id) const {
Map::const_iterator iter = extension_info_.find(id);
ExtensionExtent result;
if (iter != extension_info_.end())
result = iter->second->GetEffectiveHostPermissions();
return result;
}
bool ExtensionInfoMap::CheckURLAccessToExtensionPermission(
const GURL& url,
const char* permission_name) const {
Map::const_iterator info;
if (url.SchemeIs(chrome::kExtensionScheme)) {
// If the url is an extension scheme, we just look it up by extension id.
std::string id = url.host();
info = extension_info_.find(id);
} else {
// Otherwise, we scan for a matching extent. Overlapping extents are
// disallowed, so only one will match.
info = extension_info_.begin();
while (info != extension_info_.end() &&
!info->second->web_extent().ContainsURL(url))
++info;
}
if (info == extension_info_.end())
return false;
return info->second->api_permissions().count(permission_name) != 0;
}
bool ExtensionInfoMap::URLIsForExtensionIcon(const GURL& url) const {
DCHECK(url.SchemeIs(chrome::kExtensionScheme));
Map::const_iterator iter = extension_info_.find(url.host());
if (iter == extension_info_.end())
return false;
std::string path = url.path();
DCHECK(path.length() > 0 && path[0] == '/');
path = path.substr(1);
return iter->second->icons().ContainsPath(path);
}
|