summaryrefslogtreecommitdiffstats
path: root/browser/components/nsBrowserContentHandler.js
diff options
context:
space:
mode:
Diffstat (limited to 'browser/components/nsBrowserContentHandler.js')
-rw-r--r--browser/components/nsBrowserContentHandler.js805
1 files changed, 0 insertions, 805 deletions
diff --git a/browser/components/nsBrowserContentHandler.js b/browser/components/nsBrowserContentHandler.js
deleted file mode 100644
index 74144fc1b..000000000
--- a/browser/components/nsBrowserContentHandler.js
+++ /dev/null
@@ -1,805 +0,0 @@
-/* This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-
-/* eslint no-undef:2 */
-
-Components.utils.import("resource://gre/modules/XPCOMUtils.jsm");
-Components.utils.import("resource://gre/modules/Services.jsm");
-Components.utils.import("resource://gre/modules/AppConstants.jsm");
-
-XPCOMUtils.defineLazyModuleGetter(this, "LaterRun",
- "resource:///modules/LaterRun.jsm");
-XPCOMUtils.defineLazyModuleGetter(this, "PrivateBrowsingUtils",
- "resource://gre/modules/PrivateBrowsingUtils.jsm");
-XPCOMUtils.defineLazyModuleGetter(this, "RecentWindow",
- "resource:///modules/RecentWindow.jsm");
-XPCOMUtils.defineLazyModuleGetter(this, "ShellService",
- "resource:///modules/ShellService.jsm");
-XPCOMUtils.defineLazyServiceGetter(this, "WindowsUIUtils",
- "@mozilla.org/windows-ui-utils;1", "nsIWindowsUIUtils");
-
-const nsISupports = Components.interfaces.nsISupports;
-
-const nsIBrowserDOMWindow = Components.interfaces.nsIBrowserDOMWindow;
-const nsIBrowserHandler = Components.interfaces.nsIBrowserHandler;
-const nsIBrowserHistory = Components.interfaces.nsIBrowserHistory;
-const nsIChannel = Components.interfaces.nsIChannel;
-const nsICommandLine = Components.interfaces.nsICommandLine;
-const nsICommandLineHandler = Components.interfaces.nsICommandLineHandler;
-const nsIContentHandler = Components.interfaces.nsIContentHandler;
-const nsIDocShellTreeItem = Components.interfaces.nsIDocShellTreeItem;
-const nsIDOMChromeWindow = Components.interfaces.nsIDOMChromeWindow;
-const nsIDOMWindow = Components.interfaces.nsIDOMWindow;
-const nsIFileURL = Components.interfaces.nsIFileURL;
-const nsIInterfaceRequestor = Components.interfaces.nsIInterfaceRequestor;
-const nsINetUtil = Components.interfaces.nsINetUtil;
-const nsIPrefLocalizedString = Components.interfaces.nsIPrefLocalizedString;
-const nsISupportsString = Components.interfaces.nsISupportsString;
-const nsIWebNavigation = Components.interfaces.nsIWebNavigation;
-const nsIWebNavigationInfo = Components.interfaces.nsIWebNavigationInfo;
-const nsICommandLineValidator = Components.interfaces.nsICommandLineValidator;
-
-const NS_BINDING_ABORTED = Components.results.NS_BINDING_ABORTED;
-const NS_ERROR_WONT_HANDLE_CONTENT = 0x805d0001;
-const NS_ERROR_ABORT = Components.results.NS_ERROR_ABORT;
-
-function shouldLoadURI(aURI) {
- if (aURI && !aURI.schemeIs("chrome"))
- return true;
-
- dump("*** Preventing external load of chrome: URI into browser window\n");
- dump(" Use --chrome <uri> instead\n");
- return false;
-}
-
-function resolveURIInternal(aCmdLine, aArgument) {
- var uri = aCmdLine.resolveURI(aArgument);
- var uriFixup = Services.uriFixup;
-
- if (!(uri instanceof nsIFileURL)) {
- return uriFixup.createFixupURI(aArgument,
- uriFixup.FIXUP_FLAG_FIX_SCHEME_TYPOS);
- }
-
- try {
- if (uri.file.exists())
- return uri;
- }
- catch (e) {
- Components.utils.reportError(e);
- }
-
- // We have interpreted the argument as a relative file URI, but the file
- // doesn't exist. Try URI fixup heuristics: see bug 290782.
-
- try {
- uri = uriFixup.createFixupURI(aArgument, 0);
- }
- catch (e) {
- Components.utils.reportError(e);
- }
-
- return uri;
-}
-
-var gFirstWindow = false;
-
-const OVERRIDE_NONE = 0;
-const OVERRIDE_NEW_PROFILE = 1;
-const OVERRIDE_NEW_MSTONE = 2;
-const OVERRIDE_NEW_BUILD_ID = 3;
-/**
- * Determines whether a home page override is needed.
- * Returns:
- * OVERRIDE_NEW_PROFILE if this is the first run with a new profile.
- * OVERRIDE_NEW_MSTONE if this is the first run with a build with a different
- * Gecko milestone (i.e. right after an upgrade).
- * OVERRIDE_NEW_BUILD_ID if this is the first run with a new build ID of the
- * same Gecko milestone (i.e. after a nightly upgrade).
- * OVERRIDE_NONE otherwise.
- */
-function needHomepageOverride(prefb) {
- var savedmstone = null;
- try {
- savedmstone = prefb.getCharPref("browser.startup.homepage_override.mstone");
- } catch (e) {}
-
- if (savedmstone == "ignore")
- return OVERRIDE_NONE;
-
- var mstone = Services.appinfo.platformVersion;
-
- var savedBuildID = null;
- try {
- savedBuildID = prefb.getCharPref("browser.startup.homepage_override.buildID");
- } catch (e) {}
-
- var buildID = Services.appinfo.platformBuildID;
-
- if (mstone != savedmstone) {
- // Bug 462254. Previous releases had a default pref to suppress the EULA
- // agreement if the platform's installer had already shown one. Now with
- // about:rights we've removed the EULA stuff and default pref, but we need
- // a way to make existing profiles retain the default that we removed.
- if (savedmstone)
- prefb.setBoolPref("browser.rights.3.shown", true);
-
- prefb.setCharPref("browser.startup.homepage_override.mstone", mstone);
- prefb.setCharPref("browser.startup.homepage_override.buildID", buildID);
- return (savedmstone ? OVERRIDE_NEW_MSTONE : OVERRIDE_NEW_PROFILE);
- }
-
- if (buildID != savedBuildID) {
- prefb.setCharPref("browser.startup.homepage_override.buildID", buildID);
- return OVERRIDE_NEW_BUILD_ID;
- }
-
- return OVERRIDE_NONE;
-}
-
-/**
- * Gets the override page for the first run after the application has been
- * updated.
- * @param defaultOverridePage
- * The default override page.
- * @return The override page.
- */
-function getPostUpdateOverridePage(defaultOverridePage) {
- var um = Components.classes["@mozilla.org/updates/update-manager;1"]
- .getService(Components.interfaces.nsIUpdateManager);
- try {
- // If the updates.xml file is deleted then getUpdateAt will throw.
- var update = um.getUpdateAt(0)
- .QueryInterface(Components.interfaces.nsIPropertyBag);
- } catch (e) {
- // This should never happen.
- Components.utils.reportError("Unable to find update: " + e);
- return defaultOverridePage;
- }
-
- let actions = update.getProperty("actions");
- // When the update doesn't specify actions fallback to the original behavior
- // of displaying the default override page.
- if (!actions)
- return defaultOverridePage;
-
- // The existence of silent or the non-existence of showURL in the actions both
- // mean that an override page should not be displayed.
- if (actions.indexOf("silent") != -1 || actions.indexOf("showURL") == -1)
- return "";
-
- return update.getProperty("openURL") || defaultOverridePage;
-}
-
-// Flag used to indicate that the arguments to openWindow can be passed directly.
-const NO_EXTERNAL_URIS = 1;
-
-function openWindow(parent, url, target, features, args, noExternalArgs) {
- if (noExternalArgs == NO_EXTERNAL_URIS) {
- // Just pass in the defaultArgs directly
- var argstring;
- if (args) {
- argstring = Components.classes["@mozilla.org/supports-string;1"]
- .createInstance(nsISupportsString);
- argstring.data = args;
- }
-
- return Services.ww.openWindow(parent, url, target, features, argstring);
- }
-
- // Pass an array to avoid the browser "|"-splitting behavior.
- var argArray = Components.classes["@mozilla.org/array;1"]
- .createInstance(Components.interfaces.nsIMutableArray);
-
- // add args to the arguments array
- var stringArgs = null;
- if (args instanceof Array) // array
- stringArgs = args;
- else if (args) // string
- stringArgs = [args];
-
- if (stringArgs) {
- // put the URIs into argArray
- var uriArray = Components.classes["@mozilla.org/array;1"]
- .createInstance(Components.interfaces.nsIMutableArray);
- stringArgs.forEach(function (uri) {
- var sstring = Components.classes["@mozilla.org/supports-string;1"]
- .createInstance(nsISupportsString);
- sstring.data = uri;
- uriArray.appendElement(sstring, /* weak = */ false);
- });
- argArray.appendElement(uriArray, /* weak =*/ false);
- } else {
- argArray.appendElement(null, /* weak =*/ false);
- }
-
- // Pass these as null to ensure that we always trigger the "single URL"
- // behavior in browser.js's gBrowserInit.onLoad (which handles the window
- // arguments)
- argArray.appendElement(null, /* weak =*/ false); // charset
- argArray.appendElement(null, /* weak =*/ false); // referer
- argArray.appendElement(null, /* weak =*/ false); // postData
- argArray.appendElement(null, /* weak =*/ false); // allowThirdPartyFixup
-
- return Services.ww.openWindow(parent, url, target, features, argArray);
-}
-
-function openPreferences() {
- var args = Components.classes["@mozilla.org/array;1"]
- .createInstance(Components.interfaces.nsIMutableArray);
-
- var wuri = Components.classes["@mozilla.org/supports-string;1"]
- .createInstance(Components.interfaces.nsISupportsString);
- wuri.data = "about:preferences";
-
- args.appendElement(wuri, /* weak = */ false);
-
- Services.ww.openWindow(null, gBrowserContentHandler.chromeURL,
- "_blank",
- "chrome,dialog=no,all",
- args);
-}
-
-function logSystemBasedSearch(engine) {
- var countId = (engine.identifier || ("other-" + engine.name)) + ".system";
- var count = Services.telemetry.getKeyedHistogramById("SEARCH_COUNTS");
- count.add(countId);
-}
-
-function doSearch(searchTerm, cmdLine) {
- var engine = Services.search.defaultEngine;
- logSystemBasedSearch(engine);
-
- var submission = engine.getSubmission(searchTerm, null, "system");
-
- // fill our nsIMutableArray with uri-as-wstring, null, null, postData
- var args = Components.classes["@mozilla.org/array;1"]
- .createInstance(Components.interfaces.nsIMutableArray);
-
- var wuri = Components.classes["@mozilla.org/supports-string;1"]
- .createInstance(Components.interfaces.nsISupportsString);
- wuri.data = submission.uri.spec;
-
- args.appendElement(wuri, /* weak =*/ false);
- args.appendElement(null, /* weak =*/ false);
- args.appendElement(null, /* weak =*/ false);
- args.appendElement(submission.postData, /* weak =*/ false);
-
- // XXXbsmedberg: use handURIToExistingBrowser to obey tabbed-browsing
- // preferences, but need nsIBrowserDOMWindow extensions
-
- return Services.ww.openWindow(null, gBrowserContentHandler.chromeURL,
- "_blank",
- "chrome,dialog=no,all" +
- gBrowserContentHandler.getFeatures(cmdLine),
- args);
-}
-
-function nsBrowserContentHandler() {
-}
-nsBrowserContentHandler.prototype = {
- classID: Components.ID("{5d0ce354-df01-421a-83fb-7ead0990c24e}"),
-
- _xpcom_factory: {
- createInstance: function bch_factory_ci(outer, iid) {
- if (outer)
- throw Components.results.NS_ERROR_NO_AGGREGATION;
- return gBrowserContentHandler.QueryInterface(iid);
- }
- },
-
- /* helper functions */
-
- mChromeURL : null,
-
- get chromeURL() {
- if (this.mChromeURL) {
- return this.mChromeURL;
- }
-
- this.mChromeURL = Services.prefs.getCharPref("browser.chromeURL");
-
- return this.mChromeURL;
- },
-
- /* nsISupports */
- QueryInterface : XPCOMUtils.generateQI([nsICommandLineHandler,
- nsIBrowserHandler,
- nsIContentHandler,
- nsICommandLineValidator]),
-
- /* nsICommandLineHandler */
- handle : function bch_handle(cmdLine) {
- if (cmdLine.handleFlag("browser", false)) {
- // Passing defaultArgs, so use NO_EXTERNAL_URIS
- openWindow(null, this.chromeURL, "_blank",
- "chrome,dialog=no,all" + this.getFeatures(cmdLine),
- this.defaultArgs, NO_EXTERNAL_URIS);
- cmdLine.preventDefault = true;
- }
-
- // In the past, when an instance was not already running, the -remote
- // option returned an error code. Any script or application invoking the
- // -remote option is expected to be handling this case, otherwise they
- // wouldn't be doing anything when there is no Firefox already running.
- // Making the -remote option always return an error code makes those
- // scripts or applications handle the situation as if Firefox was not
- // already running.
- if (cmdLine.handleFlag("remote", true)) {
- throw NS_ERROR_ABORT;
- }
-
- var uriparam;
- try {
- while ((uriparam = cmdLine.handleFlagWithParam("new-window", false))) {
- let uri = resolveURIInternal(cmdLine, uriparam);
- if (!shouldLoadURI(uri))
- continue;
- openWindow(null, this.chromeURL, "_blank",
- "chrome,dialog=no,all" + this.getFeatures(cmdLine),
- uri.spec);
- cmdLine.preventDefault = true;
- }
- }
- catch (e) {
- Components.utils.reportError(e);
- }
-
- try {
- while ((uriparam = cmdLine.handleFlagWithParam("new-tab", false))) {
- let uri = resolveURIInternal(cmdLine, uriparam);
- handURIToExistingBrowser(uri, nsIBrowserDOMWindow.OPEN_NEWTAB, cmdLine);
- cmdLine.preventDefault = true;
- }
- }
- catch (e) {
- Components.utils.reportError(e);
- }
-
- var chromeParam = cmdLine.handleFlagWithParam("chrome", false);
- if (chromeParam) {
-
- // Handle old preference dialog URLs.
- if (chromeParam == "chrome://browser/content/pref/pref.xul" ||
- chromeParam == "chrome://browser/content/preferences/preferences.xul") {
- openPreferences();
- cmdLine.preventDefault = true;
- } else try {
- let resolvedURI = resolveURIInternal(cmdLine, chromeParam);
- let isLocal = uri => {
- let localSchemes = new Set(["chrome", "file", "resource"]);
- if (uri instanceof Components.interfaces.nsINestedURI) {
- uri = uri.QueryInterface(Components.interfaces.nsINestedURI).innerMostURI;
- }
- return localSchemes.has(uri.scheme);
- };
- if (isLocal(resolvedURI)) {
- // If the URI is local, we are sure it won't wrongly inherit chrome privs
- var features = "chrome,dialog=no,all" + this.getFeatures(cmdLine);
- openWindow(null, resolvedURI.spec, "_blank", features);
- cmdLine.preventDefault = true;
- } else {
- dump("*** Preventing load of web URI as chrome\n");
- dump(" If you're trying to load a webpage, do not pass --chrome.\n");
- }
- }
- catch (e) {
- Components.utils.reportError(e);
- }
- }
- if (cmdLine.handleFlag("preferences", false)) {
- openPreferences();
- cmdLine.preventDefault = true;
- }
- if (cmdLine.handleFlag("silent", false))
- cmdLine.preventDefault = true;
-
- try {
- var privateWindowParam = cmdLine.handleFlagWithParam("private-window", false);
- if (privateWindowParam) {
- let resolvedURI = resolveURIInternal(cmdLine, privateWindowParam);
- handURIToExistingBrowser(resolvedURI, nsIBrowserDOMWindow.OPEN_NEWTAB, cmdLine, true);
- cmdLine.preventDefault = true;
- }
- } catch (e) {
- if (e.result != Components.results.NS_ERROR_INVALID_ARG) {
- throw e;
- }
- // NS_ERROR_INVALID_ARG is thrown when flag exists, but has no param.
- if (cmdLine.handleFlag("private-window", false)) {
- openWindow(null, this.chromeURL, "_blank",
- "chrome,dialog=no,private,all" + this.getFeatures(cmdLine),
- "about:privatebrowsing");
- cmdLine.preventDefault = true;
- }
- }
-
- var searchParam = cmdLine.handleFlagWithParam("search", false);
- if (searchParam) {
- doSearch(searchParam, cmdLine);
- cmdLine.preventDefault = true;
- }
-
- // The global PB Service consumes this flag, so only eat it in per-window
- // PB builds.
- if (cmdLine.handleFlag("private", false)) {
- PrivateBrowsingUtils.enterTemporaryAutoStartMode();
- }
-
- var fileParam = cmdLine.handleFlagWithParam("file", false);
- if (fileParam) {
- var file = cmdLine.resolveFile(fileParam);
- var fileURI = Services.io.newFileURI(file);
- openWindow(null, this.chromeURL, "_blank",
- "chrome,dialog=no,all" + this.getFeatures(cmdLine),
- fileURI.spec);
- cmdLine.preventDefault = true;
- }
-
- if (AppConstants.platform == "win") {
- // Handle "? searchterm" for Windows Vista start menu integration
- for (var i = cmdLine.length - 1; i >= 0; --i) {
- var param = cmdLine.getArgument(i);
- if (param.match(/^\? /)) {
- cmdLine.removeArguments(i, i);
- cmdLine.preventDefault = true;
-
- searchParam = param.substr(2);
- doSearch(searchParam, cmdLine);
- }
- }
- }
- },
-
- get helpInfo() {
- let info =
- " --browser Open a browser window.\n" +
- " --new-window <url> Open <url> in a new window.\n" +
- " --new-tab <url> Open <url> in a new tab.\n" +
- " --private-window <url> Open <url> in a new private window.\n";
- if (AppConstants.platform == "win") {
- info += " --preferences Open Options dialog.\n";
- } else {
- info += " --preferences Open Preferences dialog.\n";
- }
- info += " --search <term> Search <term> with your default search engine.\n";
- return info;
- },
-
- /* nsIBrowserHandler */
-
- get defaultArgs() {
- var prefb = Services.prefs;
-
- if (!gFirstWindow) {
- gFirstWindow = true;
- if (PrivateBrowsingUtils.isInTemporaryAutoStartMode) {
- return "about:privatebrowsing";
- }
- }
-
- var override;
- var overridePage = "";
- var additionalPage = "";
- var willRestoreSession = false;
- try {
- // Read the old value of homepage_override.mstone before
- // needHomepageOverride updates it, so that we can later add it to the
- // URL if we do end up showing an overridePage. This makes it possible
- // to have the overridePage's content vary depending on the version we're
- // upgrading from.
- let old_mstone = "unknown";
- try {
- old_mstone = Services.prefs.getCharPref("browser.startup.homepage_override.mstone");
- } catch (ex) {}
- override = needHomepageOverride(prefb);
- if (override != OVERRIDE_NONE) {
- switch (override) {
- case OVERRIDE_NEW_PROFILE:
- // New profile.
- overridePage = Services.urlFormatter.formatURLPref("startup.homepage_welcome_url");
- additionalPage = Services.urlFormatter.formatURLPref("startup.homepage_welcome_url.additional");
- // Turn on 'later run' pages for new profiles.
- LaterRun.enabled = true;
- break;
- case OVERRIDE_NEW_MSTONE:
- // Check whether we will restore a session. If we will, we assume
- // that this is an "update" session. This does not take crashes
- // into account because that requires waiting for the session file
- // to be read. If a crash occurs after updating, before restarting,
- // we may open the startPage in addition to restoring the session.
- var ss = Components.classes["@mozilla.org/browser/sessionstartup;1"]
- .getService(Components.interfaces.nsISessionStartup);
- willRestoreSession = ss.isAutomaticRestoreEnabled();
-
- overridePage = Services.urlFormatter.formatURLPref("startup.homepage_override_url");
- if (prefb.prefHasUserValue("app.update.postupdate"))
- overridePage = getPostUpdateOverridePage(overridePage);
-
- overridePage = overridePage.replace("%OLD_VERSION%", old_mstone);
- break;
- }
- }
- } catch (ex) {}
-
- // formatURLPref might return "about:blank" if getting the pref fails
- if (overridePage == "about:blank")
- overridePage = "";
-
- if (!additionalPage) {
- additionalPage = LaterRun.getURL() || "";
- }
-
- if (additionalPage && additionalPage != "about:blank") {
- if (overridePage) {
- overridePage += "|" + additionalPage;
- } else {
- overridePage = additionalPage;
- }
- }
-
- var startPage = "";
- try {
- var choice = prefb.getIntPref("browser.startup.page");
- if (choice == 1 || choice == 3)
- startPage = this.startPage;
- } catch (e) {
- Components.utils.reportError(e);
- }
-
- if (startPage == "about:blank")
- startPage = "";
-
- let skipStartPage = override == OVERRIDE_NEW_PROFILE &&
- prefb.getBoolPref("browser.startup.firstrunSkipsHomepage");
- // Only show the startPage if we're not restoring an update session and are
- // not set to skip the start page on this profile
- if (overridePage && startPage && !willRestoreSession && !skipStartPage)
- return overridePage + "|" + startPage;
-
- return overridePage || startPage || "about:blank" || "about:logopage";
- },
-
- get startPage() {
- var uri = Services.prefs.getComplexValue("browser.startup.homepage",
- nsIPrefLocalizedString).data;
- if (!uri) {
- Services.prefs.clearUserPref("browser.startup.homepage");
- uri = Services.prefs.getComplexValue("browser.startup.homepage",
- nsIPrefLocalizedString).data;
- }
- return uri;
- },
-
- mFeatures : null,
-
- getFeatures : function bch_features(cmdLine) {
- if (this.mFeatures === null) {
- this.mFeatures = "";
-
- try {
- var width = cmdLine.handleFlagWithParam("width", false);
- var height = cmdLine.handleFlagWithParam("height", false);
-
- if (width)
- this.mFeatures += ",width=" + width;
- if (height)
- this.mFeatures += ",height=" + height;
- }
- catch (e) {
- }
-
- // The global PB Service consumes this flag, so only eat it in per-window
- // PB builds.
- if (PrivateBrowsingUtils.isInTemporaryAutoStartMode) {
- this.mFeatures = ",private";
- }
- }
-
- return this.mFeatures;
- },
-
- /* nsIContentHandler */
-
- handleContent : function bch_handleContent(contentType, context, request) {
- try {
- var webNavInfo = Components.classes["@mozilla.org/webnavigation-info;1"]
- .getService(nsIWebNavigationInfo);
- if (!webNavInfo.isTypeSupported(contentType, null)) {
- throw NS_ERROR_WONT_HANDLE_CONTENT;
- }
- } catch (e) {
- throw NS_ERROR_WONT_HANDLE_CONTENT;
- }
-
- request.QueryInterface(nsIChannel);
- handURIToExistingBrowser(request.URI,
- nsIBrowserDOMWindow.OPEN_DEFAULTWINDOW, null);
- request.cancel(NS_BINDING_ABORTED);
- },
-
- /* nsICommandLineValidator */
- validate : function bch_validate(cmdLine) {
- // Other handlers may use osint so only handle the osint flag if the url
- // flag is also present and the command line is valid.
- var osintFlagIdx = cmdLine.findFlag("osint", false);
- var urlFlagIdx = cmdLine.findFlag("url", false);
- if (urlFlagIdx > -1 && (osintFlagIdx > -1 ||
- cmdLine.state == nsICommandLine.STATE_REMOTE_EXPLICIT)) {
- var urlParam = cmdLine.getArgument(urlFlagIdx + 1);
- if (cmdLine.length != urlFlagIdx + 2 || /firefoxurl:/.test(urlParam))
- throw NS_ERROR_ABORT;
- var isDefault = false;
- try {
- var url = Services.urlFormatter.formatURLPref("app.support.baseURL") +
- "win10-default-browser";
- if (urlParam == url) {
- isDefault = ShellService.isDefaultBrowser(false, false);
- }
- } catch (ex) {}
- if (isDefault) {
- // Firefox is already the default HTTP handler.
- // We don't have to show the instruction page.
- throw NS_ERROR_ABORT;
- }
- cmdLine.handleFlag("osint", false)
- }
- },
-};
-var gBrowserContentHandler = new nsBrowserContentHandler();
-
-function handURIToExistingBrowser(uri, location, cmdLine, forcePrivate)
-{
- if (!shouldLoadURI(uri))
- return;
-
- // Unless using a private window is forced, open external links in private
- // windows only if we're in perma-private mode.
- var allowPrivate = forcePrivate || PrivateBrowsingUtils.permanentPrivateBrowsing;
- var navWin = RecentWindow.getMostRecentBrowserWindow({private: allowPrivate});
- if (!navWin) {
- // if we couldn't load it in an existing window, open a new one
- var features = "chrome,dialog=no,all" + gBrowserContentHandler.getFeatures(cmdLine);
- if (forcePrivate) {
- features += ",private";
- }
- openWindow(null, gBrowserContentHandler.chromeURL, "_blank", features, uri.spec);
- return;
- }
-
- var navNav = navWin.QueryInterface(nsIInterfaceRequestor)
- .getInterface(nsIWebNavigation);
- var rootItem = navNav.QueryInterface(nsIDocShellTreeItem).rootTreeItem;
- var rootWin = rootItem.QueryInterface(nsIInterfaceRequestor)
- .getInterface(nsIDOMWindow);
- var bwin = rootWin.QueryInterface(nsIDOMChromeWindow).browserDOMWindow;
- bwin.openURI(uri, null, location,
- nsIBrowserDOMWindow.OPEN_EXTERNAL);
-}
-
-function nsDefaultCommandLineHandler() {
-}
-
-nsDefaultCommandLineHandler.prototype = {
- classID: Components.ID("{47cd0651-b1be-4a0f-b5c4-10e5a573ef71}"),
-
- /* nsISupports */
- QueryInterface : function dch_QI(iid) {
- if (!iid.equals(nsISupports) &&
- !iid.equals(nsICommandLineHandler))
- throw Components.results.NS_ERROR_NO_INTERFACE;
-
- return this;
- },
-
- _haveProfile: false,
-
- /* nsICommandLineHandler */
- handle : function dch_handle(cmdLine) {
- // The -url flag is inserted by the operating system when the default
- // application handler is used. We check for default browser to remove
- // instances where users explicitly decide to "open with" the browser.
- // Note that users who launch firefox manually with the -url flag will
- // get erroneously counted.
- try {
- if (cmdLine.findFlag("url", false) &&
- ShellService.isDefaultBrowser(false, false)) {
- Services.telemetry.getHistogramById("FX_STARTUP_EXTERNAL_CONTENT_HANDLER").add();
- }
- } catch (e) {}
-
- var urilist = [];
-
- if (AppConstants.platform == "win") {
- // If we don't have a profile selected yet (e.g. the Profile Manager is
- // displayed) we will crash if we open an url and then select a profile. To
- // prevent this handle all url command line flags and set the command line's
- // preventDefault to true to prevent the display of the ui. The initial
- // command line will be retained when nsAppRunner calls LaunchChild though
- // urls launched after the initial launch will be lost.
- if (!this._haveProfile) {
- try {
- // This will throw when a profile has not been selected.
- Services.dirsvc.get("ProfD", Components.interfaces.nsILocalFile);
- this._haveProfile = true;
- }
- catch (e) {
- while ((ar = cmdLine.handleFlagWithParam("url", false)));
- cmdLine.preventDefault = true;
- }
- }
- }
-
- try {
- var ar;
- while ((ar = cmdLine.handleFlagWithParam("url", false))) {
- var uri = resolveURIInternal(cmdLine, ar);
- urilist.push(uri);
- }
- }
- catch (e) {
- Components.utils.reportError(e);
- }
-
- for (let i = 0; i < cmdLine.length; ++i) {
- var curarg = cmdLine.getArgument(i);
- if (curarg.match(/^-/)) {
- Components.utils.reportError("Warning: unrecognized command line flag " + curarg + "\n");
- // To emulate the pre-nsICommandLine behavior, we ignore
- // the argument after an unrecognized flag.
- ++i;
- } else {
- try {
- urilist.push(resolveURIInternal(cmdLine, curarg));
- }
- catch (e) {
- Components.utils.reportError("Error opening URI '" + curarg + "' from the command line: " + e + "\n");
- }
- }
- }
-
- if (urilist.length) {
- if (cmdLine.state != nsICommandLine.STATE_INITIAL_LAUNCH &&
- urilist.length == 1) {
- // Try to find an existing window and load our URI into the
- // current tab, new tab, or new window as prefs determine.
- try {
- handURIToExistingBrowser(urilist[0], nsIBrowserDOMWindow.OPEN_DEFAULTWINDOW, cmdLine);
- return;
- }
- catch (e) {
- }
- }
-
- var URLlist = urilist.filter(shouldLoadURI).map(u => u.spec);
- if (URLlist.length) {
- openWindow(null, gBrowserContentHandler.chromeURL, "_blank",
- "chrome,dialog=no,all" + gBrowserContentHandler.getFeatures(cmdLine),
- URLlist);
- }
-
- }
- else if (!cmdLine.preventDefault) {
- if (AppConstants.isPlatformAndVersionAtLeast("win", "10") &&
- cmdLine.state != nsICommandLine.STATE_INITIAL_LAUNCH &&
- WindowsUIUtils.inTabletMode) {
- // In windows 10 tablet mode, do not create a new window, but reuse the existing one.
- let win = RecentWindow.getMostRecentBrowserWindow();
- if (win) {
- win.focus();
- return;
- }
- }
- // Passing defaultArgs, so use NO_EXTERNAL_URIS
- openWindow(null, gBrowserContentHandler.chromeURL, "_blank",
- "chrome,dialog=no,all" + gBrowserContentHandler.getFeatures(cmdLine),
- gBrowserContentHandler.defaultArgs, NO_EXTERNAL_URIS);
- }
- },
-
- helpInfo : "",
-};
-
-var components = [nsBrowserContentHandler, nsDefaultCommandLineHandler];
-this.NSGetFactory = XPCOMUtils.generateNSGetFactory(components);