[tor-commits] [tor-messenger-build/updater] Add patch or #16940 (also #14392)
sukhbir at torproject.org
sukhbir at torproject.org
Fri Jul 29 17:20:47 UTC 2016
commit 9cfd3634a5ab22c39b0ec715e3410c4ebebc5ed1
Author: Sukhbir Singh <sukhbir at torproject.org>
Date: Mon Jul 18 12:41:06 2016 -0400
Add patch or #16940 (also #14392)
---
...ate-load-local-changes-bug-14392-first.mozpatch | 18 +
...te-load-local-changes-bug-16940-second.mozpatch | 368 +++++++++++++++++++++
projects/instantbird/aboutTBUpdateLogo.png | Bin 0 -> 2724 bytes
3 files changed, 386 insertions(+)
diff --git a/projects/instantbird/Update-load-local-changes-bug-14392-first.mozpatch b/projects/instantbird/Update-load-local-changes-bug-14392-first.mozpatch
new file mode 100644
index 0000000..e1bc5bf
--- /dev/null
+++ b/projects/instantbird/Update-load-local-changes-bug-14392-first.mozpatch
@@ -0,0 +1,18 @@
+commit bb781597694015aed8ea4d121eac503542fd52f2
+Author: Mike Perry <mikeperry-git at torproject.org>
+Date: Wed Feb 11 16:45:24 2015 -0800
+
+ Bug 14392: Make about:tor behave like other initial pages.
+
+diff --git a/browser/base/content/browser.js b/browser/base/content/browser.js
+index 4f2642a..934a223 100644
+--- a/browser/base/content/browser.js
++++ b/browser/base/content/browser.js
+@@ -258,6 +258,7 @@ XPCOMUtils.defineLazyModuleGetter(this, "LoginManagerParent",
+ "resource://gre/modules/LoginManagerParent.jsm");
+
+ var gInitialPages = [
++ "about:tor",
+ "about:blank",
+ "about:newtab",
+ "about:home",
diff --git a/projects/instantbird/Update-load-local-changes-bug-16940-second.mozpatch b/projects/instantbird/Update-load-local-changes-bug-16940-second.mozpatch
new file mode 100644
index 0000000..25aac2a
--- /dev/null
+++ b/projects/instantbird/Update-load-local-changes-bug-16940-second.mozpatch
@@ -0,0 +1,368 @@
+From 3815bb323160cf9163a07e36859c2ea83c905ace Mon Sep 17 00:00:00 2001
+From: Kathy Brade <brade at pearlcrescent.com>
+Date: Wed, 25 Nov 2015 11:36:20 -0500
+Subject: Bug 16940: After update, load local change notes.
+
+Add an about:tbupdate page that displays the first section from
+TorBrowser/Docs/ChangeLog.txt and includes a link to the remote
+post-update page (typically our blog entry for the release).
+
+diff --git a/browser/base/content/abouttbupdate/aboutTBUpdate.css b/browser/base/content/abouttbupdate/aboutTBUpdate.css
+new file mode 100644
+index 0000000..489c9d2
+--- /dev/null
++++ b/browser/base/content/abouttbupdate/aboutTBUpdate.css
+@@ -0,0 +1,34 @@
++body {
++ font-family: sans-serif;
++ font-size: 110%;
++ background-image: -moz-linear-gradient(top, #ffffff, #ffffff 10%, #d5ffd5 50%, #d5ffd5);
++ background-attachment: fixed;
++ background-size: 100% 100%;
++}
++
++#logo {
++ background-image: url("chrome://browser/content/abouttbupdate/aboutTBUpdateLogo.png");
++ height: 128px;
++ width: 128px;
++ margin: 20px;
++ float: left;
++}
++
++#msg {
++ margin-top: 50px;
++ float: left;
++}
++
++#msg-updated {
++ font-size: 120%;
++ margin-bottom: 20px;
++}
++
++#changelog-container {
++ margin: 0px 20px 20px 20px;
++}
++
++#changelog {
++ margin-left: 20px;
++ white-space: pre;
++}
+diff --git a/browser/base/content/abouttbupdate/aboutTBUpdate.js b/browser/base/content/abouttbupdate/aboutTBUpdate.js
+new file mode 100644
+index 0000000..8243647
+--- /dev/null
++++ b/browser/base/content/abouttbupdate/aboutTBUpdate.js
+@@ -0,0 +1,10 @@
++// Copyright (c) 2015, The Tor Project, Inc.
++// See LICENSE for licensing information.
++//
++// vim: set sw=2 sts=2 ts=8 et syntax=javascript:
++
++function init()
++{
++ let event = new CustomEvent("AboutTBUpdateLoad", { bubbles: true });
++ document.dispatchEvent(event);
++}
+diff --git a/browser/base/content/abouttbupdate/aboutTBUpdate.xhtml b/browser/base/content/abouttbupdate/aboutTBUpdate.xhtml
+new file mode 100644
+index 0000000..3a29e0c
+--- /dev/null
++++ b/browser/base/content/abouttbupdate/aboutTBUpdate.xhtml
+@@ -0,0 +1,34 @@
++<?xml version="1.0" encoding="UTF-8"?>
++
++<!DOCTYPE html [
++ <!ENTITY % htmlDTD
++ PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
++ "DTD/xhtml1-strict.dtd">
++ %htmlDTD;
++ <!ENTITY % globalDTD SYSTEM "chrome://global/locale/global.dtd">
++ %globalDTD;
++ <!ENTITY % tbUpdateDTD SYSTEM "chrome://browser/locale/aboutTBUpdate.dtd">
++ %tbUpdateDTD;
++]>
++
++<html xmlns="http://www.w3.org/1999/xhtml">
++<head>
++ <title>&aboutTBUpdate.title;</title>
++ <link rel="stylesheet" type="text/css"
++ href="chrome://browser/content/abouttbupdate/aboutTBUpdate.css"/>
++ <script src="chrome://browser/content/abouttbupdate/aboutTBUpdate.js"
++ type="text/javascript;version=1.7"/>
++</head>
++<body dir="&locale.dir;" onload="init()">
++<div id="logo"/>
++<div id="msg">
++<div id="msg-updated">&aboutTBUpdate.updated;</div>
++<div>&aboutTBUpdate.linkPrefix;<a id="infolink">&aboutTBUpdate.linkLabel;</a>&aboutTBUpdate.linkSuffix;
++</div>
++</div>
++<br clear="all"/>
++<div id="changelog-container">&aboutTBUpdate.changeLogHeading;
++<div id="changelog"></div>
++</div>
++</body>
++</html>
+diff --git a/browser/base/content/abouttbupdate/aboutTBUpdateLogo.png b/browser/base/content/abouttbupdate/aboutTBUpdateLogo.png
+new file mode 100644
+index 0000000..be5cae9
+Binary files /dev/null and b/browser/base/content/abouttbupdate/aboutTBUpdateLogo.png differ
+diff --git a/browser/base/content/browser.js b/browser/base/content/browser.js
+index 6e78084..0adbe61 100644
+--- a/browser/base/content/browser.js
++++ b/browser/base/content/browser.js
+@@ -259,6 +259,9 @@ XPCOMUtils.defineLazyModuleGetter(this, "LoginManagerParent",
+
+ var gInitialPages = [
+ "about:tor",
++#ifdef TOR_BROWSER_UPDATE
++ "about:tbupdate",
++#endif
+ "about:blank",
+ "about:newtab",
+ "about:home",
+@@ -2425,8 +2428,14 @@ function URLBarSetURI(aURI) {
+
+ // Replace initial page URIs with an empty string
+ // only if there's no opener (bug 370555).
++#ifdef TOR_BROWSER_UPDATE
++ if (gInitialPages.indexOf(uri.spec.split('?')[0]) != -1 &&
++ checkEmptyPageOrigin(gBrowser.selectedBrowser, uri))
++#else
+ if (gInitialPages.indexOf(uri.spec) != -1 &&
+- checkEmptyPageOrigin(gBrowser.selectedBrowser, uri)) {
++ checkEmptyPageOrigin(gBrowser.selectedBrowser, uri))
++#endif
++ {
+ value = "";
+ } else {
+ value = losslessDecodeURI(uri);
+@@ -7043,7 +7052,11 @@ var gIdentityHandler = {
+ this._uriHasHost = false;
+ }
+
+- let whitelist = /^(?:accounts|addons|cache|config|crashes|customizing|downloads|healthreport|home|license|newaddon|permissions|preferences|privatebrowsing|rights|sessionrestore|support|welcomeback)(?:[?#]|$)/i;
++#ifdef TOR_BROWSER_UPDATE
++ let whitelist = /^(?:accounts|addons|cache|config|crashes|customizing|downloads|healthreport|home|license|newaddon|permissions|preferences|privatebrowsing|rights|sessionrestore|support|welcomeback|tor|tbupdate)(?:[?#]|$)/i;
++#else
++ let whitelist = /^(?:accounts|addons|cache|config|crashes|customizing|downloads|healthreport|home|license|newaddon|permissions|preferences|privatebrowsing|rights|sessionrestore|support|welcomeback|tor)(?:[?#]|$)/i;
++#endif
+ this._isSecureInternalUI = uri.schemeIs("about") && whitelist.test(uri.path);
+
+ this._sslStatus = gBrowser.securityUI
+diff --git a/browser/base/content/tab-content.js b/browser/base/content/tab-content.js
+index c8f39ee..44489a2 100644
+--- a/browser/base/content/tab-content.js
++++ b/browser/base/content/tab-content.js
+@@ -10,6 +10,9 @@ var {classes: Cc, interfaces: Ci, utils: Cu, results: Cr} = Components;
+ Cu.import("resource://gre/modules/XPCOMUtils.jsm");
+ Cu.import("resource://gre/modules/Services.jsm");
+ Cu.import("resource://gre/modules/ExtensionContent.jsm");
++#ifdef TOR_BROWSER_UPDATE
++Cu.import("resource://gre/modules/NetUtil.jsm");
++#endif
+
+ XPCOMUtils.defineLazyModuleGetter(this, "E10SUtils",
+ "resource:///modules/E10SUtils.jsm");
+@@ -368,6 +371,82 @@ var AboutReaderListener = {
+ };
+ AboutReaderListener.init();
+
++#ifdef TOR_BROWSER_UPDATE
++let AboutTBUpdateListener = {
++ init: function(chromeGlobal) {
++ chromeGlobal.addEventListener('AboutTBUpdateLoad', this, false, true);
++ },
++
++ get isAboutTBUpdate() {
++ return content.document.documentURI.split('?')[0].toLowerCase()
++ == "about:tbupdate";
++ },
++
++ handleEvent: function(aEvent) {
++ if (this.isAboutTBUpdate && (aEvent.type == "AboutTBUpdateLoad"))
++ this.onPageLoad();
++ },
++
++ onPageLoad: function() {
++ let doc = content.document;
++ doc.getElementById("infolink").setAttribute("href", this.getPostUpdateURL());
++ doc.getElementById("changelog").textContent = this.getChangeLogText();
++ },
++
++ // Extract the post update URL from this page's query string.
++ getPostUpdateURL: function() {
++ let idx = content.document.documentURI.indexOf('?');
++ if (idx > 0)
++ return decodeURIComponent(content.document.documentURI.substring(idx+1));
++
++ // No query string: use the default URL.
++ return Services.urlFormatter.formatURLPref("startup.homepage_override_url");
++ },
++
++ // Read and return the text from the beginning of the changelog file that is
++ // located at TorBrowser/Docs/ChangeLog.txt.
++ // On Mac OS, when building with --enable-tor-browser-data-outside-app-dir
++ // to support Gatekeeper signing, the file is located in
++ // TorBrowser.app/Contents/Resources/TorBrowser/Docs/.
++ //
++ // When electrolysis is enabled we will need to adopt an architecture that is
++ // more similar to the one that is used for about:home (see AboutHomeListener
++ // in this file and browser/modules/AboutHome.jsm).
++ getChangeLogText: function() {
++ try {
++#ifdef TOR_BROWSER_DATA_OUTSIDE_APP_DIR
++ // "XREExeF".parent is the directory that contains firefox, i.e.,
++ // Browser/ or, on Mac OS, TorBrowser.app/Contents/MacOS/.
++ let f = Services.dirsvc.get("XREExeF", Ci.nsIFile).parent;
++#ifdef XP_MACOSX
++ f = f.parent;
++ f.append("Resources");
++#endif
++ f.append("TorBrowser");
++#else
++ // "DefProfRt" is .../TorBrowser/Data/Browser
++ let f = Cc["@mozilla.org/file/directory_service;1"]
++ .getService(Ci.nsIProperties).get("DefProfRt", Ci.nsIFile);
++ f = f.parent.parent; // Remove "Data/Browser"
++#endif
++ f.append("Docs");
++ f.append("ChangeLog.txt");
++
++ let fs = Cc["@mozilla.org/network/file-input-stream;1"]
++ .createInstance(Ci.nsIFileInputStream);
++ fs.init(f, -1, 0, 0);
++ let s = NetUtil.readInputStreamToString(fs, fs.available());
++ fs.close();
++
++ // Truncate at the first empty line.
++ return s.replace(/[\r\n][\r\n][\s\S]*$/m, "");
++ } catch (e) {}
++
++ return "";
++ },
++};
++AboutTBUpdateListener.init(this);
++#endif
+
+ var ContentSearchMediator = {
+
+diff --git a/browser/base/jar.mn b/browser/base/jar.mn
+index a39f8fa..45f6e09 100644
+--- a/browser/base/jar.mn
++++ b/browser/base/jar.mn
+@@ -73,8 +73,14 @@ browser.jar:
+ content/browser/aboutTabCrashed.xhtml (content/aboutTabCrashed.xhtml)
+ * content/browser/aboutTabGroupsMigration.xhtml (content/aboutTabGroupsMigration.xhtml)
+ content/browser/aboutTabGroupsMigration.js (content/aboutTabGroupsMigration.js)
++#ifdef TOR_BROWSER_UPDATE
++ content/browser/abouttbupdate/aboutTBUpdate.xhtml (content/abouttbupdate/aboutTBUpdate.xhtml)
++ content/browser/abouttbupdate/aboutTBUpdate.js (content/abouttbupdate/aboutTBUpdate.js)
++ content/browser/abouttbupdate/aboutTBUpdate.css (content/abouttbupdate/aboutTBUpdate.css)
++ content/browser/abouttbupdate/aboutTBUpdateLogo.png (content/abouttbupdate/aboutTBUpdateLogo.png)
++#endif
+ * content/browser/browser.css (content/browser.css)
+- content/browser/browser.js (content/browser.js)
++* content/browser/browser.js (content/browser.js)
+ * content/browser/browser.xul (content/browser.xul)
+ content/browser/browser-addons.js (content/browser-addons.js)
+ content/browser/browser-ctrlTab.js (content/browser-ctrlTab.js)
+@@ -104,7 +110,7 @@ browser.jar:
+ content/browser/browser-thumbnails.js (content/browser-thumbnails.js)
+ content/browser/browser-trackingprotection.js (content/browser-trackingprotection.js)
+ * content/browser/chatWindow.xul (content/chatWindow.xul)
+- content/browser/tab-content.js (content/tab-content.js)
++* content/browser/tab-content.js (content/tab-content.js)
+ content/browser/content.js (content/content.js)
+ content/browser/social-content.js (content/social-content.js)
+ content/browser/defaultthemes/1.footer.jpg (content/defaultthemes/1.footer.jpg)
+diff --git a/browser/components/about/AboutRedirector.cpp b/browser/components/about/AboutRedirector.cpp
+index 78f55c9..ab069e5 100644
+--- a/browser/components/about/AboutRedirector.cpp
++++ b/browser/components/about/AboutRedirector.cpp
+@@ -138,6 +138,13 @@ static RedirEntry kRedirMap[] = {
+ nsIAboutModule::ALLOW_SCRIPT |
+ nsIAboutModule::HIDE_FROM_ABOUTABOUT |
+ nsIAboutModule::MAKE_UNLINKABLE },
++#ifdef TOR_BROWSER_UPDATE
++ { "tbupdate", "chrome://browser/content/abouttbupdate/aboutTBUpdate.xhtml",
++ nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT |
++ nsIAboutModule::ALLOW_SCRIPT |
++ nsIAboutModule::MAKE_UNLINKABLE |
++ nsIAboutModule::HIDE_FROM_ABOUTABOUT },
++#endif
+ };
+ static const int kRedirTotal = ArrayLength(kRedirMap);
+
+diff --git a/browser/components/build/nsModule.cpp b/browser/components/build/nsModule.cpp
+index 7950d7c..a316cb3 100644
+--- a/browser/components/build/nsModule.cpp
++++ b/browser/components/build/nsModule.cpp
+@@ -115,6 +115,9 @@ static const mozilla::Module::ContractIDEntry kBrowserContracts[] = {
+ { NS_ABOUT_MODULE_CONTRACTID_PREFIX "reader", &kNS_BROWSER_ABOUT_REDIRECTOR_CID },
+ { NS_ABOUT_MODULE_CONTRACTID_PREFIX "pocket-saved", &kNS_BROWSER_ABOUT_REDIRECTOR_CID },
+ { NS_ABOUT_MODULE_CONTRACTID_PREFIX "pocket-signup", &kNS_BROWSER_ABOUT_REDIRECTOR_CID },
++#ifdef TOR_BROWSER_UPDATE
++ { NS_ABOUT_MODULE_CONTRACTID_PREFIX "tbupdate", &kNS_BROWSER_ABOUT_REDIRECTOR_CID },
++#endif
+ #if defined(XP_WIN)
+ { NS_IEHISTORYENUMERATOR_CONTRACTID, &kNS_WINIEHISTORYENUMERATOR_CID },
+ #elif defined(XP_MACOSX)
+diff --git a/browser/components/nsBrowserContentHandler.js b/browser/components/nsBrowserContentHandler.js
+index b892eaf..8cc5cc5 100644
+--- a/browser/components/nsBrowserContentHandler.js
++++ b/browser/components/nsBrowserContentHandler.js
+@@ -573,6 +573,13 @@ nsBrowserContentHandler.prototype = {
+ // 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.
++ //
++ // Tor Browser: Instead of opening the post-update "override page"
++ // directly, an about:tbupdate page is opened that includes a link
++ // to the override page as well as text from the first part of the
++ // local ChangeLog.txt file. The override page URL comes from the
++ // openURL attribute within the updates.xml file or, if no showURL
++ // action is present, from the startup.homepage_override_url pref.
+ var ss = Components.classes["@mozilla.org/browser/sessionstartup;1"]
+ .getService(Components.interfaces.nsISessionStartup);
+ willRestoreSession = ss.isAutomaticRestoreEnabled();
+@@ -586,6 +593,11 @@ nsBrowserContentHandler.prototype = {
+ overridePage = overridePage.replace("%OLD_TOR_BROWSER_VERSION%",
+ old_tbversion);
+ #endif
++
++#ifdef TOR_BROWSER_UPDATE
++ if (overridePage)
++ overridePage = "about:tbupdate?" + encodeURIComponent(overridePage);
++#endif
+ break;
+ }
+ }
+diff --git a/browser/locales/en-US/chrome/browser/aboutTBUpdate.dtd b/browser/locales/en-US/chrome/browser/aboutTBUpdate.dtd
+new file mode 100644
+index 0000000..37567bd
+--- /dev/null
++++ b/browser/locales/en-US/chrome/browser/aboutTBUpdate.dtd
+@@ -0,0 +1,6 @@
++<!ENTITY aboutTBUpdate.title "Tor Messenger Update">
++<!ENTITY aboutTBUpdate.updated "Tor Messenger has been updated.">
++<!ENTITY aboutTBUpdate.linkPrefix "For the most up-to-date information about this release, ">
++<!ENTITY aboutTBUpdate.linkLabel "visit our website">
++<!ENTITY aboutTBUpdate.linkSuffix ".">
++<!ENTITY aboutTBUpdate.changeLogHeading "Changelog:">
+diff --git a/browser/locales/jar.mn b/browser/locales/jar.mn
+index 44c5e6a..0f18e06 100644
+--- a/browser/locales/jar.mn
++++ b/browser/locales/jar.mn
+@@ -21,6 +21,9 @@
+ locale/browser/aboutTabCrashed.dtd (%chrome/browser/aboutTabCrashed.dtd)
+ locale/browser/syncCustomize.dtd (%chrome/browser/syncCustomize.dtd)
+ locale/browser/aboutSyncTabs.dtd (%chrome/browser/aboutSyncTabs.dtd)
++#ifdef TOR_BROWSER_UPDATE
++ locale/browser/aboutTBUpdate.dtd (%chrome/browser/aboutTBUpdate.dtd)
++#endif
+ locale/browser/browser.dtd (%chrome/browser/browser.dtd)
+ locale/browser/baseMenuOverlay.dtd (%chrome/browser/baseMenuOverlay.dtd)
+ locale/browser/browser.properties (%chrome/browser/browser.properties)
+--
+cgit v0.10.2
diff --git a/projects/instantbird/aboutTBUpdateLogo.png b/projects/instantbird/aboutTBUpdateLogo.png
new file mode 100644
index 0000000..3de3c93
Binary files /dev/null and b/projects/instantbird/aboutTBUpdateLogo.png differ
More information about the tor-commits
mailing list