Bug 590068 - Use search service to keep track of additional search params in about:home. r=gavin,mak
authorMatthew Noorenberghe <mozilla@noorenberghe.ca>
Wed, 04 Apr 2012 02:50:39 -0700
changeset 131547 b061b91098b29338d6bd0eb624907224949640fa
parent 131546 1ba8ddf7bef0f0e4cebae28bec3d7dde41dcbcb6
child 131548 300ea51c6353c180a71d8454f94249abd3abd61a
push id2323
push userbbajaj@mozilla.com
push dateMon, 01 Apr 2013 19:47:02 +0000
treeherdermozilla-beta@7712be144d91 [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewersgavin, mak
bugs590068
milestone21.0a1
first release with
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
last release without
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
Bug 590068 - Use search service to keep track of additional search params in about:home. r=gavin,mak
browser/base/content/abouthome/aboutHome.js
browser/components/search/test/browser_google.js
browser/locales/en-US/searchplugins/google.xml
browser/modules/AboutHomeUtils.jsm
--- a/browser/base/content/abouthome/aboutHome.js
+++ b/browser/base/content/abouthome/aboutHome.js
@@ -1,14 +1,12 @@
 /* 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/. */
 
-// If a definition requires additional params, check that the final search url
-// is handled correctly by the engine.
 const SEARCH_ENGINES = {
   "Google": {
     image: "data:image/png;base64," +
            "iVBORw0KGgoAAAANSUhEUgAAAEYAAAAcCAYAAADcO8kVAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJ" +
            "bWFnZVJlYWR5ccllPAAADHdJREFUeNrsWQl0VNUZvve9NzNJJpnsIkuEJMoqAVJAodCKoFUsAUFQ" +
            "qhig0npaRUE8Viv1FFtQWxSwLXVhEawbhOWobOICFCGiEIIQRGIgCSFjMslsb9567+1/Z+7gmIYK" +
            "Vivt6Ztzz5y5b+7yf//3f/9/38PoW7gYY+i7uDDG39heJfT/q91LGTiTIcWJkCxzxDmCCBGCkBEO" +
            "FDCm5CPs+CGWYvcliRxEzDwgu9I/IzZClonQgT/jC9Eu3GFTz6sdKc57kIzHWKaFjIA2wz++Zhkn" +
@@ -63,17 +61,16 @@ const SEARCH_ENGINES = {
            "tH99bE8YGN/wd/mgxdG7NFDb8/ZohryYA5HguHhI5uYO27vyoqtrmAiXr31JX/V48CuY8R8FJhxE" +
            "eeEAQWk9HnYlFmMJoRKG03QLtUJ7/93FvpXXJ7wM/6Za4l71UEu5pWkoucv0Be0tm95vmUdy5t5k" +
            "tpbPbe8B2vmsi7+rl2Nf4yVaUlLHSQXu7r8tw1JyT+ivhQBaAhZUxBSC5EPpPtMKVDzi3z/+HZHJ" +
            "7K/7IvC/CRhZ6Ep6evGGyXJS3kAsp3SGcgLKc7uSktBhrW7ZFq32r/HHCVbb0P9fBSYOTpIoJ5SE" +
            "7GUnpHbrbG8EzsfWfwgwAEfC/ToQIhkhAAAAAElFTkSuQmCC"
 #ifdef XP_MACOSX
   , imageHD: ""
 #endif
-  , params: "source=hp&channel=np"
   }
 };
 
 // The process of adding a new default snippet involves:
 //   * add a new entity to aboutHome.dtd
 //   * add a <span/> for it in aboutHome.xhtml
 //   * add an entry here in the proper ordering (based on spans)
 // The <a/> part of the snippet will be linked to the corresponding url.
@@ -124,23 +121,16 @@ function onSearchSubmit(aEvent)
 function setupSearchEngine()
 {
   let searchEngineName = document.documentElement.getAttribute("searchEngineName");
   let searchEngineInfo = SEARCH_ENGINES[searchEngineName];
   if (!searchEngineInfo) {
     return;
   }
 
-  // Enqueue additional params if required by the engine definition.
-  if (searchEngineInfo.params) {
-    let searchEngineURL = document.documentElement.getAttribute("searchEngineURL");
-    searchEngineURL += "&" + searchEngineInfo.params;
-    document.documentElement.setAttribute("searchEngineURL", searchEngineURL);
-  }
-
   // Add search engine logo.
   if (searchEngineInfo.image) {
     let logoElt = document.getElementById("searchEngineLogo");
     logoElt.src = searchEngineInfo.image;
 #ifdef XP_MACOSX
     if (searchEngineInfo.imageHD && window.matchMedia("(min-resolution: 2dppx)"))
       logoElt.src = searchEngineInfo.imageHD;
 #endif
--- a/browser/components/search/test/browser_google.js
+++ b/browser/components/search/test/browser_google.js
@@ -142,16 +142,26 @@ function test() {
               "value": "rcs",
               "purpose": "contextmenu",
             },
             {
               "name": "channel",
               "value": "fflb",
               "purpose": "keyword",
             },
+            {
+              "name": "channel",
+              "value": "np",
+              "purpose": "homepage",
+            },
+            {
+              "name": "source",
+              "value": "hp",
+              "purpose": "homepage",
+            },
           ],
           mozparams: {
             "client": {
               "name": "client",
               "falseValue": "firefox",
               "trueValue": GOOGLE_CLIENT,
               "condition": "defaultEngine",
               "mozparam": true,
--- a/browser/locales/en-US/searchplugins/google.xml
+++ b/browser/locales/en-US/searchplugins/google.xml
@@ -20,11 +20,13 @@
   <MozParam name="client" condition="defaultEngine" trueValue="firefox-aurora" falseValue="firefox"/>
 #elif MOZ_UPDATE_CHANNEL == nightly
   <MozParam name="client" condition="defaultEngine" trueValue="firefox-nightly" falseValue="firefox"/>
 #else
   <MozParam name="client" condition="defaultEngine" trueValue="firefox-a" falseValue="firefox"/>
 #endif
   <MozParam name="channel" condition="purpose" purpose="contextmenu" value="rcs"/>
   <MozParam name="channel" condition="purpose" purpose="keyword" value="fflb"/>
+  <MozParam name="channel" condition="purpose" purpose="homepage" value="np"/>
+  <MozParam name="source" condition="purpose" purpose="homepage" value="hp"/>
 </Url>
 <SearchForm>https://www.google.com/</SearchForm>
 </SearchPlugin>
--- a/browser/modules/AboutHomeUtils.jsm
+++ b/browser/modules/AboutHomeUtils.jsm
@@ -18,17 +18,17 @@ const STARTPAGE_VERSION = 3;
 this.AboutHomeUtils = new Object();
 
 /**
  * Returns an object containing the name and searchURL of the original default
  * search engine.
  */
 XPCOMUtils.defineLazyGetter(AboutHomeUtils, "defaultSearchEngine", function() {
   let defaultEngine = Services.search.originalDefaultEngine;
-  let submission = defaultEngine.getSubmission("_searchTerms_");
+  let submission = defaultEngine.getSubmission("_searchTerms_", null, "homepage");
   if (submission.postData) {
     throw new Error("Home page does not support POST search engines.");
   }
 
   return Object.freeze({
     name: defaultEngine.name,
     searchURL: submission.uri.spec
   });