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

Unified Diff: chrome/browser/ui/omnibox/omnibox_navigation_observer.cc

Issue 865313002: Prevent a possible crash on omnibox navigation. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Also check for failed main frame loads Created 5 years, 11 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/ui/omnibox/omnibox_navigation_observer.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/omnibox/omnibox_navigation_observer.cc
diff --git a/chrome/browser/ui/omnibox/omnibox_navigation_observer.cc b/chrome/browser/ui/omnibox/omnibox_navigation_observer.cc
index 040dbdefa2cfcd57bace95ae91c9f25a2bc92c59..e5926fb1efbbdf30023467c384763897cc308854 100644
--- a/chrome/browser/ui/omnibox/omnibox_navigation_observer.cc
+++ b/chrome/browser/ui/omnibox/omnibox_navigation_observer.cc
@@ -15,6 +15,7 @@
#include "content/public/browser/navigation_entry.h"
#include "content/public/browser/notification_service.h"
#include "content/public/browser/notification_types.h"
+#include "content/public/browser/render_frame_host.h"
#include "content/public/browser/web_contents.h"
#include "net/base/load_flags.h"
#include "net/base/registry_controlled_domains/registry_controlled_domain.h"
@@ -86,23 +87,58 @@ void OmniboxNavigationObserver::Observe(
const content::NotificationSource& source,
const content::NotificationDetails& details) {
DCHECK_EQ(content::NOTIFICATION_NAV_ENTRY_PENDING, type);
- registrar_.Remove(this, content::NOTIFICATION_NAV_ENTRY_PENDING,
- content::NotificationService::AllSources());
+
+ // It's possible for an attempted omnibox navigation to cause the extensions
+ // system to synchronously navigate an extension background page. Not only is
+ // this navigation not the one we want to observe, the associated WebContents
+ // is invisible and has no InfoBarService, so trying to show an infobar in it
+ // later will crash. Just ignore this navigation and keep listening.
content::NavigationController* controller =
content::Source<content::NavigationController>(source).ptr();
+ content::WebContents* web_contents = controller->GetWebContents();
+ if (!InfoBarService::FromWebContents(web_contents))
+ return;
+
+ CHECK_EQ(match_.destination_url,
+ content::Details<content::NavigationEntry>(
+ details)->GetVirtualURL());
+ registrar_.Remove(this, content::NOTIFICATION_NAV_ENTRY_PENDING,
+ content::NotificationService::AllSources());
if (fetcher_) {
fetcher_->SetRequestContext(
controller->GetBrowserContext()->GetRequestContext());
}
- WebContentsObserver::Observe(controller->GetWebContents());
+ WebContentsObserver::Observe(web_contents);
// DidStartNavigationToPendingEntry() will be called for this load as well.
}
+void OmniboxNavigationObserver::DidStartNavigationToPendingEntry(
+ const GURL& url,
+ content::NavigationController::ReloadType reload_type) {
+ if (load_state_ == LOAD_NOT_SEEN) {
+ load_state_ = LOAD_PENDING;
+ if (fetcher_)
+ fetcher_->Start();
+ } else {
+ delete this;
+ }
+}
+
+void OmniboxNavigationObserver::DidFailProvisionalLoad(
+ content::RenderFrameHost* render_frame_host,
+ const GURL& validated_url,
+ int error_code,
+ const base::string16& error_description) {
+ if ((load_state_ != LOAD_COMMITTED) && !render_frame_host->GetParent())
+ delete this;
+}
+
void OmniboxNavigationObserver::NavigationEntryCommitted(
const content::LoadCommittedDetails& load_details) {
load_state_ = LOAD_COMMITTED;
if (ResponseCodeIndicatesSuccess(load_details.http_status_code) &&
- IsValidNavigation(match_.destination_url, load_details.entry->GetURL()))
+ IsValidNavigation(match_.destination_url,
+ load_details.entry->GetVirtualURL()))
OnSuccessfulNavigation();
if (!fetcher_ || (fetch_state_ != FETCH_NOT_COMPLETE))
OnAllLoadingFinished(); // deletes |this|!
@@ -112,18 +148,6 @@ void OmniboxNavigationObserver::WebContentsDestroyed() {
delete this;
}
-void OmniboxNavigationObserver::DidStartNavigationToPendingEntry(
- const GURL& url,
- content::NavigationController::ReloadType reload_type) {
- if (load_state_ == LOAD_NOT_SEEN) {
- load_state_ = LOAD_PENDING;
- if (fetcher_)
- fetcher_->Start();
- } else {
- delete this;
- }
-}
-
void OmniboxNavigationObserver::OnURLFetchComplete(
const net::URLFetcher* source) {
DCHECK_EQ(fetcher_.get(), source);
« no previous file with comments | « chrome/browser/ui/omnibox/omnibox_navigation_observer.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698