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

Side by Side Diff: chrome/browser/extensions/extension_tab_util.cc

Issue 10920070: Remove permission warnings from most tabs and windows APIs. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 3 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 #include "chrome/browser/extensions/extension_tab_util.h" 5 #include "chrome/browser/extensions/extension_tab_util.h"
6 6
7 #include "chrome/browser/extensions/api/tabs/tabs_constants.h" 7 #include "chrome/browser/extensions/api/tabs/tabs_constants.h"
8 #include "chrome/browser/extensions/tab_helper.h" 8 #include "chrome/browser/extensions/tab_helper.h"
9 #include "chrome/browser/extensions/window_controller.h" 9 #include "chrome/browser/extensions/window_controller.h"
10 #include "chrome/browser/net/url_fixer_upper.h" 10 #include "chrome/browser/net/url_fixer_upper.h"
11 #include "chrome/browser/profiles/profile.h" 11 #include "chrome/browser/profiles/profile.h"
12 #include "chrome/browser/sessions/session_id.h" 12 #include "chrome/browser/sessions/session_id.h"
13 #include "chrome/browser/ui/browser.h" 13 #include "chrome/browser/ui/browser.h"
14 #include "chrome/browser/ui/browser_finder.h" 14 #include "chrome/browser/ui/browser_finder.h"
15 #include "chrome/browser/ui/browser_list.h" 15 #include "chrome/browser/ui/browser_list.h"
16 #include "chrome/browser/ui/browser_tabstrip.h" 16 #include "chrome/browser/ui/browser_tabstrip.h"
17 #include "chrome/browser/ui/browser_window.h" 17 #include "chrome/browser/ui/browser_window.h"
18 #include "chrome/browser/ui/tab_contents/tab_contents.h" 18 #include "chrome/browser/ui/tab_contents/tab_contents.h"
19 #include "chrome/browser/ui/tab_contents/tab_contents_iterator.h" 19 #include "chrome/browser/ui/tab_contents/tab_contents_iterator.h"
20 #include "chrome/browser/ui/tabs/tab_strip_model.h" 20 #include "chrome/browser/ui/tabs/tab_strip_model.h"
21 #include "chrome/common/extensions/extension.h" 21 #include "chrome/common/extensions/extension.h"
22 #include "chrome/common/extensions/extension_manifest_constants.h" 22 #include "chrome/common/extensions/extension_manifest_constants.h"
23 #include "chrome/common/extensions/permissions/api_permission.h"
23 #include "chrome/common/url_constants.h" 24 #include "chrome/common/url_constants.h"
24 #include "content/public/browser/favicon_status.h" 25 #include "content/public/browser/favicon_status.h"
25 #include "content/public/browser/navigation_entry.h" 26 #include "content/public/browser/navigation_entry.h"
26 #include "content/public/browser/web_contents.h" 27 #include "content/public/browser/web_contents.h"
27 #include "googleurl/src/gurl.h" 28 #include "googleurl/src/gurl.h"
28 29
29 namespace keys = extensions::tabs_constants; 30 namespace keys = extensions::tabs_constants;
30 31
31 using content::NavigationEntry; 32 using content::NavigationEntry;
32 using content::WebContents; 33 using content::WebContents;
34 using extensions::APIPermission;
35 using extensions::Extension;
33 36
34 int ExtensionTabUtil::GetWindowId(const Browser* browser) { 37 int ExtensionTabUtil::GetWindowId(const Browser* browser) {
35 return browser->session_id().id(); 38 return browser->session_id().id();
36 } 39 }
37 40
38 int ExtensionTabUtil::GetWindowIdOfTabStripModel( 41 int ExtensionTabUtil::GetWindowIdOfTabStripModel(
39 const TabStripModel* tab_strip_model) { 42 const TabStripModel* tab_strip_model) {
40 for (BrowserList::const_iterator it = BrowserList::begin(); 43 for (BrowserList::const_iterator it = BrowserList::begin();
41 it != BrowserList::end(); ++it) { 44 it != BrowserList::end(); ++it) {
42 if ((*it)->tab_strip_model() == tab_strip_model) 45 if ((*it)->tab_strip_model() == tab_strip_model)
43 return GetWindowId(*it); 46 return GetWindowId(*it);
44 } 47 }
45 return -1; 48 return -1;
46 } 49 }
47 50
48 int ExtensionTabUtil::GetTabId(const WebContents* web_contents) { 51 int ExtensionTabUtil::GetTabId(const WebContents* web_contents) {
49 return SessionID::IdForTab(TabContents::FromWebContents(web_contents)); 52 return SessionID::IdForTab(TabContents::FromWebContents(web_contents));
50 } 53 }
51 54
52 std::string ExtensionTabUtil::GetTabStatusText(bool is_loading) { 55 std::string ExtensionTabUtil::GetTabStatusText(bool is_loading) {
53 return is_loading ? keys::kStatusValueLoading : keys::kStatusValueComplete; 56 return is_loading ? keys::kStatusValueLoading : keys::kStatusValueComplete;
54 } 57 }
55 58
56 int ExtensionTabUtil::GetWindowIdOfTab(const WebContents* web_contents) { 59 int ExtensionTabUtil::GetWindowIdOfTab(const WebContents* web_contents) {
57 return SessionID::IdForWindowContainingTab( 60 return SessionID::IdForWindowContainingTab(
58 TabContents::FromWebContents(web_contents)); 61 TabContents::FromWebContents(web_contents));
59 } 62 }
60 63
61 DictionaryValue* ExtensionTabUtil::CreateTabValue(const WebContents* contents) { 64 DictionaryValue* ExtensionTabUtil::CreateTabValue(
65 const WebContents* contents,
66 const Extension* extension) {
62 // Find the tab strip and index of this guy. 67 // Find the tab strip and index of this guy.
63 TabStripModel* tab_strip = NULL; 68 TabStripModel* tab_strip = NULL;
64 int tab_index; 69 int tab_index;
65 if (ExtensionTabUtil::GetTabStripModel(contents, &tab_strip, &tab_index)) 70 if (ExtensionTabUtil::GetTabStripModel(contents, &tab_strip, &tab_index)) {
66 return ExtensionTabUtil::CreateTabValue(contents, tab_strip, tab_index); 71 return ExtensionTabUtil::CreateTabValue(contents,
72 tab_strip,
73 tab_index,
74 extension);
75 }
67 76
68 // Couldn't find it. This can happen if the tab is being dragged. 77 // Couldn't find it. This can happen if the tab is being dragged.
69 return ExtensionTabUtil::CreateTabValue(contents, NULL, -1); 78 return ExtensionTabUtil::CreateTabValue(contents, NULL, -1, extension);
70 } 79 }
71 80
72 ListValue* ExtensionTabUtil::CreateTabList(const Browser* browser) { 81 ListValue* ExtensionTabUtil::CreateTabList(
82 const Browser* browser,
83 const Extension* extension) {
73 ListValue* tab_list = new ListValue(); 84 ListValue* tab_list = new ListValue();
74 TabStripModel* tab_strip = browser->tab_strip_model(); 85 TabStripModel* tab_strip = browser->tab_strip_model();
75 for (int i = 0; i < tab_strip->count(); ++i) { 86 for (int i = 0; i < tab_strip->count(); ++i) {
76 tab_list->Append(ExtensionTabUtil::CreateTabValue( 87 tab_list->Append(CreateTabValue(
77 tab_strip->GetTabContentsAt(i)->web_contents(), tab_strip, i)); 88 tab_strip->GetTabContentsAt(i)->web_contents(),
89 tab_strip,
90 i,
91 extension));
78 } 92 }
79 93
80 return tab_list; 94 return tab_list;
81 } 95 }
82 96
83 DictionaryValue* ExtensionTabUtil::CreateTabValue(const WebContents* contents, 97 DictionaryValue* ExtensionTabUtil::CreateTabValue(
84 TabStripModel* tab_strip, 98 const WebContents* contents,
85 int tab_index) { 99 TabStripModel* tab_strip,
100 int tab_index,
101 const Extension* extension) {
86 DictionaryValue* result = new DictionaryValue(); 102 DictionaryValue* result = new DictionaryValue();
87 bool is_loading = contents->IsLoading(); 103 bool is_loading = contents->IsLoading();
88 result->SetInteger(keys::kIdKey, ExtensionTabUtil::GetTabId(contents)); 104 result->SetInteger(keys::kIdKey, GetTabId(contents));
89 result->SetInteger(keys::kIndexKey, tab_index); 105 result->SetInteger(keys::kIndexKey, tab_index);
90 result->SetInteger(keys::kWindowIdKey, 106 result->SetInteger(keys::kWindowIdKey, GetWindowIdOfTab(contents));
91 ExtensionTabUtil::GetWindowIdOfTab(contents));
92 result->SetString(keys::kUrlKey, contents->GetURL().spec());
93 result->SetString(keys::kStatusKey, GetTabStatusText(is_loading)); 107 result->SetString(keys::kStatusKey, GetTabStatusText(is_loading));
94 result->SetBoolean(keys::kActiveKey, 108 result->SetBoolean(keys::kActiveKey,
95 tab_strip && tab_index == tab_strip->active_index()); 109 tab_strip && tab_index == tab_strip->active_index());
96 result->SetBoolean(keys::kSelectedKey, 110 result->SetBoolean(keys::kSelectedKey,
97 tab_strip && tab_index == tab_strip->active_index()); 111 tab_strip && tab_index == tab_strip->active_index());
98 result->SetBoolean(keys::kHighlightedKey, 112 result->SetBoolean(keys::kHighlightedKey,
99 tab_strip && tab_strip->IsTabSelected(tab_index)); 113 tab_strip && tab_strip->IsTabSelected(tab_index));
100 result->SetBoolean(keys::kPinnedKey, 114 result->SetBoolean(keys::kPinnedKey,
101 tab_strip && tab_strip->IsTabPinned(tab_index)); 115 tab_strip && tab_strip->IsTabPinned(tab_index));
102 result->SetString(keys::kTitleKey, contents->GetTitle());
103 result->SetBoolean(keys::kIncognitoKey, 116 result->SetBoolean(keys::kIncognitoKey,
104 contents->GetBrowserContext()->IsOffTheRecord()); 117 contents->GetBrowserContext()->IsOffTheRecord());
105 118
119 // Only add privacy-sensitive data if the requesting extension has the tabs
120 // permission.
121 bool has_permission = false;
122 if (extension) {
123 if (tab_index >= 0) {
124 has_permission =
125 extension->HasAPIPermissionForTab(
126 tab_index, APIPermission::kTab) ||
127 extension->HasAPIPermissionForTab(
128 tab_index, APIPermission::kWebNavigation);
129 } else {
130 has_permission =
131 extension->HasAPIPermission(APIPermission::kTab) ||
132 extension->HasAPIPermission(APIPermission::kWebNavigation);
133 }
134 }
135
136 if (has_permission) {
137 result->SetString(keys::kUrlKey, contents->GetURL().spec());
138 result->SetString(keys::kTitleKey, contents->GetTitle());
139 if (!is_loading) {
140 NavigationEntry* entry = contents->GetController().GetActiveEntry();
141 if (entry && entry->GetFavicon().valid)
142 result->SetString(keys::kFaviconUrlKey, entry->GetFavicon().url.spec());
143 }
144 }
145
106 if (tab_strip) { 146 if (tab_strip) {
107 content::NavigationController* opener = 147 content::NavigationController* opener =
108 tab_strip->GetOpenerOfTabContentsAt(tab_index); 148 tab_strip->GetOpenerOfTabContentsAt(tab_index);
109 if (opener) { 149 if (opener) {
110 result->SetInteger(keys::kOpenerTabIdKey, 150 result->SetInteger(keys::kOpenerTabIdKey,
111 ExtensionTabUtil::GetTabId(opener->GetWebContents())); 151 GetTabId(opener->GetWebContents()));
112 } 152 }
113 } 153 }
114 154
115 if (!is_loading) {
116 NavigationEntry* entry = contents->GetController().GetActiveEntry();
117 if (entry) {
118 if (entry->GetFavicon().valid)
119 result->SetString(keys::kFaviconUrlKey, entry->GetFavicon().url.spec());
120 }
121 }
122
123 return result; 155 return result;
124 } 156 }
125 157
126 DictionaryValue* ExtensionTabUtil::CreateTabValueActive( 158 DictionaryValue* ExtensionTabUtil::CreateTabValueActive(
127 const WebContents* contents, 159 const WebContents* contents,
128 bool active) { 160 bool active,
129 DictionaryValue* result = ExtensionTabUtil::CreateTabValue(contents); 161 const extensions::Extension* extension) {
162 DictionaryValue* result = CreateTabValue(contents, extension);
130 result->SetBoolean(keys::kSelectedKey, active); 163 result->SetBoolean(keys::kSelectedKey, active);
131 return result; 164 return result;
132 } 165 }
133 166
134 bool ExtensionTabUtil::GetTabStripModel(const WebContents* web_contents, 167 bool ExtensionTabUtil::GetTabStripModel(const WebContents* web_contents,
135 TabStripModel** tab_strip_model, 168 TabStripModel** tab_strip_model,
136 int* tab_index) { 169 int* tab_index) {
137 DCHECK(web_contents); 170 DCHECK(web_contents);
138 DCHECK(tab_strip_model); 171 DCHECK(tab_strip_model);
139 DCHECK(tab_index); 172 DCHECK(tab_index);
(...skipping 14 matching lines...) Expand all
154 187
155 bool ExtensionTabUtil::GetDefaultTab(Browser* browser, 188 bool ExtensionTabUtil::GetDefaultTab(Browser* browser,
156 TabContents** contents, 189 TabContents** contents,
157 int* tab_id) { 190 int* tab_id) {
158 DCHECK(browser); 191 DCHECK(browser);
159 DCHECK(contents); 192 DCHECK(contents);
160 193
161 *contents = chrome::GetActiveTabContents(browser); 194 *contents = chrome::GetActiveTabContents(browser);
162 if (*contents) { 195 if (*contents) {
163 if (tab_id) 196 if (tab_id)
164 *tab_id = ExtensionTabUtil::GetTabId((*contents)->web_contents()); 197 *tab_id = GetTabId((*contents)->web_contents());
165 return true; 198 return true;
166 } 199 }
167 200
168 return false; 201 return false;
169 } 202 }
170 203
171 bool ExtensionTabUtil::GetTabById(int tab_id, 204 bool ExtensionTabUtil::GetTabById(int tab_id,
172 Profile* profile, 205 Profile* profile,
173 bool include_incognito, 206 bool include_incognito,
174 Browser** browser, 207 Browser** browser,
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after
264 297
265 // static 298 // static
266 extensions::WindowController* ExtensionTabUtil::GetWindowControllerOfTab( 299 extensions::WindowController* ExtensionTabUtil::GetWindowControllerOfTab(
267 const WebContents* web_contents) { 300 const WebContents* web_contents) {
268 Browser* browser = browser::FindBrowserWithWebContents(web_contents); 301 Browser* browser = browser::FindBrowserWithWebContents(web_contents);
269 if (browser != NULL) 302 if (browser != NULL)
270 return browser->extension_window_controller(); 303 return browser->extension_window_controller();
271 304
272 return NULL; 305 return NULL;
273 } 306 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698