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

Unified Diff: chrome/browser/extensions/extension_tabs_module.cc

Issue 9796012: Revert 127833 - Re-land alexbost's experimental offscreenTabs API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 8 years, 9 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/extensions/extension_tabs_module.h ('k') | chrome/chrome_browser_extensions.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/extensions/extension_tabs_module.cc
===================================================================
--- chrome/browser/extensions/extension_tabs_module.cc (revision 127860)
+++ chrome/browser/extensions/extension_tabs_module.cc (working copy)
@@ -26,6 +26,7 @@
#include "chrome/browser/extensions/extension_tabs_module_constants.h"
#include "chrome/browser/extensions/extension_window_controller.h"
#include "chrome/browser/extensions/extension_window_list.h"
+#include "chrome/browser/net/url_fixer_upper.h"
#include "chrome/browser/prefs/incognito_mode_prefs.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/sessions/restore_tab_helper.h"
@@ -190,6 +191,31 @@
return false;
}
+// Takes |url_string| and returns a GURL which is either valid and absolute
+// or invalid. If |url_string| is not directly interpretable as a valid (it is
+// likely a relative URL) an attempt is made to resolve it. |extension| is
+// provided so it can be resolved relative to its extension base
+// (chrome-extension://<id>/). Using the source frame url would be more correct,
+// but because the api shipped with urls resolved relative to their extension
+// base, we decided it wasn't worth breaking existing extensions to fix.
+GURL ResolvePossiblyRelativeURL(const std::string& url_string,
+ const Extension* extension) {
+ GURL url = GURL(url_string);
+ if (!url.is_valid())
+ url = extension->GetResourceURL(url_string);
+
+ return url;
+}
+
+bool IsCrashURL(const GURL& url) {
+ // Check a fixed-up URL, to normalize the scheme and parse hosts correctly.
+ GURL fixed_url =
+ URLFixerUpper::FixupURL(url.possibly_invalid_spec(), std::string());
+ return (fixed_url.SchemeIs(chrome::kChromeUIScheme) &&
+ (fixed_url.host() == chrome::kChromeUIBrowserCrashHost ||
+ fixed_url.host() == chrome::kChromeUICrashHost));
+}
+
// Reads the |value| as either a single integer value or a list of integers.
bool ReadOneOrMoreIntegers(
Value* value, std::vector<int>* result) {
@@ -416,15 +442,14 @@
// Second, resolve, validate and convert them to GURLs.
for (std::vector<std::string>::iterator i = url_strings.begin();
i != url_strings.end(); ++i) {
- GURL url = ExtensionTabUtil::ResolvePossiblyRelativeURL(
- *i, GetExtension());
+ GURL url = ResolvePossiblyRelativeURL(*i, GetExtension());
if (!url.is_valid()) {
error_ = ExtensionErrorUtils::FormatErrorMessage(
keys::kInvalidUrlError, *i);
return false;
}
// Don't let the extension crash the browser or renderers.
- if (ExtensionTabUtil::IsCrashURL(url)) {
+ if (IsCrashURL(url)) {
error_ = keys::kNoCrashBrowserError;
return false;
}
@@ -985,8 +1010,7 @@
if (args->HasKey(keys::kUrlKey)) {
EXTENSION_FUNCTION_VALIDATE(args->GetString(keys::kUrlKey,
&url_string));
- url = ExtensionTabUtil::ResolvePossiblyRelativeURL(url_string,
- GetExtension());
+ url = ResolvePossiblyRelativeURL(url_string, GetExtension());
if (!url.is_valid()) {
error_ = ExtensionErrorUtils::FormatErrorMessage(keys::kInvalidUrlError,
url_string);
@@ -995,7 +1019,7 @@
}
// Don't let extensions crash the browser or renderers.
- if (ExtensionTabUtil::IsCrashURL(url)) {
+ if (IsCrashURL(url)) {
error_ = keys::kNoCrashBrowserError;
return false;
}
@@ -1192,16 +1216,70 @@
}
web_contents_ = contents->web_contents();
+ NavigationController& controller = web_contents_->GetController();
// TODO(rafaelw): handle setting remaining tab properties:
// -title
// -favIconUrl
- // Navigate the tab to a new location if the url is different.
+ // We wait to fire the callback when executing 'javascript:' URLs in tabs.
bool is_async = false;
- if (!UpdateURLIfPresent(update_props, &is_async))
- return false;
+ // Navigate the tab to a new location if the url is different.
+ std::string url_string;
+ if (update_props->HasKey(keys::kUrlKey)) {
+ EXTENSION_FUNCTION_VALIDATE(update_props->GetString(
+ keys::kUrlKey, &url_string));
+ GURL url = ResolvePossiblyRelativeURL(url_string, GetExtension());
+
+ if (!url.is_valid()) {
+ error_ = ExtensionErrorUtils::FormatErrorMessage(keys::kInvalidUrlError,
+ url_string);
+ return false;
+ }
+
+ // Don't let the extension crash the browser or renderers.
+ if (IsCrashURL(url)) {
+ error_ = keys::kNoCrashBrowserError;
+ return false;
+ }
+
+ // JavaScript URLs can do the same kinds of things as cross-origin XHR, so
+ // we need to check host permissions before allowing them.
+ if (url.SchemeIs(chrome::kJavaScriptScheme)) {
+ if (!GetExtension()->CanExecuteScriptOnPage(
+ web_contents_->GetURL(), NULL, &error_)) {
+ return false;
+ }
+
+ ExtensionMsg_ExecuteCode_Params params;
+ params.request_id = request_id();
+ params.extension_id = extension_id();
+ params.is_javascript = true;
+ params.code = url.path();
+ params.all_frames = false;
+ params.in_main_world = true;
+
+ RenderViewHost* render_view_host = web_contents_->GetRenderViewHost();
+ render_view_host->Send(
+ new ExtensionMsg_ExecuteCode(render_view_host->GetRoutingID(),
+ params));
+
+ Observe(web_contents_);
+ AddRef(); // Balanced in OnExecuteCodeFinished().
+
+ is_async = true;
+ }
+
+ controller.LoadURL(
+ url, content::Referrer(), content::PAGE_TRANSITION_LINK, std::string());
+
+ // The URL of a tab contents never actually changes to a JavaScript URL, so
+ // this check only makes sense in other cases.
+ if (!url.SchemeIs(chrome::kJavaScriptScheme))
+ DCHECK_EQ(url.spec(), web_contents_->GetURL().spec());
+ }
+
bool active = false;
// TODO(rafaelw): Setting |active| from js doesn't make much sense.
// Move tab selection management up to window.
@@ -1262,67 +1340,6 @@
return true;
}
-bool UpdateTabFunction::UpdateURLIfPresent(DictionaryValue* update_props,
- bool* is_async) {
- if (!update_props->HasKey(keys::kUrlKey))
- return true;
-
- std::string url_string;
- EXTENSION_FUNCTION_VALIDATE(update_props->GetString(
- keys::kUrlKey, &url_string));
- GURL url = ExtensionTabUtil::ResolvePossiblyRelativeURL(
- url_string, GetExtension());
-
- if (!url.is_valid()) {
- error_ = ExtensionErrorUtils::FormatErrorMessage(
- keys::kInvalidUrlError, url_string);
- return false;
- }
-
- // Don't let the extension crash the browser or renderers.
- if (ExtensionTabUtil::IsCrashURL(url)) {
- error_ = keys::kNoCrashBrowserError;
- return false;
- }
-
- // JavaScript URLs can do the same kinds of things as cross-origin XHR, so
- // we need to check host permissions before allowing them.
- if (url.SchemeIs(chrome::kJavaScriptScheme)) {
- if (!GetExtension()->CanExecuteScriptOnPage(
- web_contents_->GetURL(), NULL, &error_)) {
- return false;
- }
-
- ExtensionMsg_ExecuteCode_Params params;
- params.request_id = request_id();
- params.extension_id = extension_id();
- params.is_javascript = true;
- params.code = url.path();
- params.all_frames = false;
- params.in_main_world = true;
-
- RenderViewHost* render_view_host = web_contents_->GetRenderViewHost();
- render_view_host->Send(
- new ExtensionMsg_ExecuteCode(render_view_host->GetRoutingID(), params));
-
- Observe(web_contents_);
- AddRef(); // Balanced in OnExecuteCodeFinished().
-
- *is_async = true;
- return true;
- }
-
- web_contents_->GetController().LoadURL(
- url, content::Referrer(), content::PAGE_TRANSITION_LINK, std::string());
-
- // The URL of a tab contents never actually changes to a JavaScript URL, so
- // this check only makes sense in other cases.
- if (!url.SchemeIs(chrome::kJavaScriptScheme))
- DCHECK_EQ(url.spec(), web_contents_->GetURL().spec());
-
- return true;
-}
-
void UpdateTabFunction::PopulateResult() {
if (!has_callback())
return;
@@ -1374,7 +1391,7 @@
SendResponse(success);
Observe(NULL);
- Release(); // Balanced in UpdateURLIfPresent().
+ Release(); // Balanced in RunImpl().
}
bool MoveTabsFunction::RunImpl() {
@@ -1577,8 +1594,7 @@
return true;
}
-bool CaptureVisibleTabFunction::GetTabToCapture(
- WebContents** web_contents, TabContentsWrapper** wrapper) {
+bool CaptureVisibleTabFunction::RunImpl() {
Browser* browser = NULL;
// windowId defaults to "current" window.
int window_id = extension_misc::kCurrentWindowId;
@@ -1589,23 +1605,6 @@
if (!GetBrowserFromWindowID(this, window_id, &browser))
return false;
- *web_contents = browser->GetSelectedWebContents();
- if (*web_contents == NULL) {
- error_ = keys::kInternalVisibleTabCaptureError;
- return false;
- }
-
- *wrapper = browser->GetSelectedTabContentsWrapper();
-
- return true;
-};
-
-bool CaptureVisibleTabFunction::RunImpl() {
- WebContents* web_contents = NULL;
- TabContentsWrapper* wrapper = NULL;
- if (!GetTabToCapture(&web_contents, &wrapper))
- return false;
-
image_format_ = FORMAT_JPEG; // Default format is JPEG.
image_quality_ = kDefaultQuality; // Default quality setting.
@@ -1634,6 +1633,12 @@
}
}
+ WebContents* web_contents = browser->GetSelectedWebContents();
+ if (!web_contents) {
+ error_ = keys::kInternalVisibleTabCaptureError;
+ return false;
+ }
+
// captureVisibleTab() can return an image containing sensitive information
// that the browser would otherwise protect. Ensure the extension has
// permission to do this.
@@ -1644,6 +1649,7 @@
// If a backing store is cached for the tab we want to capture,
// and it can be copied into a bitmap, then use it to generate the image.
+ // This may fail if we can not copy a backing store into a bitmap.
// For example, some uncommon X11 visual modes are not supported by
// CopyFromBackingStore().
skia::PlatformCanvas temp_canvas;
@@ -1655,7 +1661,7 @@
}
// Ask the renderer for a snapshot of the tab.
- wrapper->snapshot_tab_helper()->CaptureSnapshot();
+ TabContentsWrapper* wrapper = browser->GetSelectedTabContentsWrapper();
registrar_.Add(this,
chrome::NOTIFICATION_TAB_SNAPSHOT_TAKEN,
content::Source<WebContents>(wrapper->web_contents()));
« no previous file with comments | « chrome/browser/extensions/extension_tabs_module.h ('k') | chrome/chrome_browser_extensions.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698