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

Side by Side Diff: extensions/browser/process_manager.cc

Issue 1413853005: Track all extension frames in ProcessManager, inspect extensionoptions (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add ProcessManagerObserver::OnExtensionFrameNavigated notification Created 5 years, 1 month 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "extensions/browser/process_manager.h" 5 #include "extensions/browser/process_manager.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after
159 159
160 ExtensionRenderFrameData() 160 ExtensionRenderFrameData()
161 : view_type(VIEW_TYPE_INVALID), has_keepalive(false) {} 161 : view_type(VIEW_TYPE_INVALID), has_keepalive(false) {}
162 162
163 // Returns whether the view can keep the lazy background page alive or not. 163 // Returns whether the view can keep the lazy background page alive or not.
164 bool CanKeepalive() const { 164 bool CanKeepalive() const {
165 switch (view_type) { 165 switch (view_type) {
166 case VIEW_TYPE_APP_WINDOW: 166 case VIEW_TYPE_APP_WINDOW:
167 case VIEW_TYPE_BACKGROUND_CONTENTS: 167 case VIEW_TYPE_BACKGROUND_CONTENTS:
168 case VIEW_TYPE_EXTENSION_DIALOG: 168 case VIEW_TYPE_EXTENSION_DIALOG:
169 case VIEW_TYPE_EXTENSION_OPTIONS:
169 case VIEW_TYPE_EXTENSION_POPUP: 170 case VIEW_TYPE_EXTENSION_POPUP:
170 case VIEW_TYPE_LAUNCHER_PAGE: 171 case VIEW_TYPE_LAUNCHER_PAGE:
171 case VIEW_TYPE_PANEL: 172 case VIEW_TYPE_PANEL:
172 case VIEW_TYPE_TAB_CONTENTS: 173 case VIEW_TYPE_TAB_CONTENTS:
173 case VIEW_TYPE_VIRTUAL_KEYBOARD: 174 case VIEW_TYPE_VIRTUAL_KEYBOARD:
174 return true; 175 return true;
175 176
176 case VIEW_TYPE_INVALID: 177 case VIEW_TYPE_INVALID:
177 case VIEW_TYPE_EXTENSION_BACKGROUND_PAGE: 178 case VIEW_TYPE_EXTENSION_BACKGROUND_PAGE:
178 return false; 179 return false;
(...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after
302 ReleaseLazyKeepaliveCountForFrame(render_frame_host); 303 ReleaseLazyKeepaliveCountForFrame(render_frame_host);
303 all_extension_frames_.erase(frame); 304 all_extension_frames_.erase(frame);
304 305
305 FOR_EACH_OBSERVER(ProcessManagerObserver, 306 FOR_EACH_OBSERVER(ProcessManagerObserver,
306 observer_list_, 307 observer_list_,
307 OnExtensionFrameUnregistered(extension_id, 308 OnExtensionFrameUnregistered(extension_id,
308 render_frame_host)); 309 render_frame_host));
309 } 310 }
310 } 311 }
311 312
313 void ProcessManager::DidNavigateRenderFrameHost(
314 content::RenderFrameHost* render_frame_host) {
315 ExtensionRenderFrames::iterator frame =
316 all_extension_frames_.find(render_frame_host);
317
318 if (frame != all_extension_frames_.end()) {
319 std::string extension_id = GetExtensionID(render_frame_host);
320
321 FOR_EACH_OBSERVER(ProcessManagerObserver,
322 observer_list_,
323 OnExtensionFrameNavigated(extension_id,
324 render_frame_host));
325 }
326 }
327
312 scoped_refptr<content::SiteInstance> ProcessManager::GetSiteInstanceForURL( 328 scoped_refptr<content::SiteInstance> ProcessManager::GetSiteInstanceForURL(
313 const GURL& url) { 329 const GURL& url) {
314 return make_scoped_refptr(site_instance_->GetRelatedSiteInstance(url)); 330 return make_scoped_refptr(site_instance_->GetRelatedSiteInstance(url));
315 } 331 }
316 332
317 const ProcessManager::FrameSet ProcessManager::GetAllFrames() const { 333 const ProcessManager::FrameSet ProcessManager::GetAllFrames() const {
318 FrameSet result; 334 FrameSet result;
319 for (const auto& key_value : all_extension_frames_) 335 for (const auto& key_value : all_extension_frames_)
320 result.insert(key_value.first); 336 result.insert(key_value.first);
321 return result; 337 return result;
322 } 338 }
323 339
324 ProcessManager::FrameSet ProcessManager::GetRenderFrameHostsForExtension( 340 ProcessManager::FrameSet ProcessManager::GetRenderFrameHostsForExtension(
325 const std::string& extension_id) { 341 const std::string& extension_id) {
326 FrameSet result; 342 FrameSet result;
327 scoped_refptr<content::SiteInstance> site_instance(GetSiteInstanceForURL(
328 Extension::GetBaseURLFromExtensionId(extension_id)));
329 if (!site_instance.get())
330 return result;
331
332 // Gather up all the frames for that site.
333 for (const auto& key_value : all_extension_frames_) { 343 for (const auto& key_value : all_extension_frames_) {
334 if (key_value.first->GetSiteInstance() == site_instance) 344 if (GetExtensionID(key_value.first) == extension_id)
ncarter (slow) 2015/11/05 20:03:23 This will result in a match even if key_value's Si
robwu 2015/11/12 00:33:58 I don't know. For now I'll assume that chrome-gues
335 result.insert(key_value.first); 345 result.insert(key_value.first);
336 } 346 }
337
338 return result; 347 return result;
339 } 348 }
340 349
341 void ProcessManager::AddObserver(ProcessManagerObserver* observer) { 350 void ProcessManager::AddObserver(ProcessManagerObserver* observer) {
342 observer_list_.AddObserver(observer); 351 observer_list_.AddObserver(observer);
343 } 352 }
344 353
345 void ProcessManager::RemoveObserver(ProcessManagerObserver* observer) { 354 void ProcessManager::RemoveObserver(ProcessManagerObserver* observer) {
346 observer_list_.RemoveObserver(observer); 355 observer_list_.RemoveObserver(observer);
347 } 356 }
(...skipping 613 matching lines...) Expand 10 before | Expand all | Expand 10 after
961 if (extension && !IncognitoInfo::IsSplitMode(extension)) { 970 if (extension && !IncognitoInfo::IsSplitMode(extension)) {
962 BrowserContext* original_context = 971 BrowserContext* original_context =
963 ExtensionsBrowserClient::Get()->GetOriginalContext(browser_context()); 972 ExtensionsBrowserClient::Get()->GetOriginalContext(browser_context());
964 return ProcessManager::Get(original_context)->GetSiteInstanceForURL(url); 973 return ProcessManager::Get(original_context)->GetSiteInstanceForURL(url);
965 } 974 }
966 975
967 return ProcessManager::GetSiteInstanceForURL(url); 976 return ProcessManager::GetSiteInstanceForURL(url);
968 } 977 }
969 978
970 } // namespace extensions 979 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698