[tor-commits] [tor-browser/tor-browser-45.1.0esr-6.0-1] fixup! Bug 12827: Create preference to disable SVG.

gk at torproject.org gk at torproject.org
Mon May 16 09:03:45 UTC 2016


commit 7ffe3230d2b6020394803784c140765e7c8e4b76
Author: Kathy Brade <brade at pearlcrescent.com>
Date:   Tue May 10 16:57:17 2016 -0400

    fixup! Bug 12827: Create preference to disable SVG.
    
    When SVGs are disabled, do no load SVG images within the
    Page Info Media tab (bug 18770).
---
 image/ImageFactory.cpp | 17 +++++++++++++++--
 1 file changed, 15 insertions(+), 2 deletions(-)

diff --git a/image/ImageFactory.cpp b/image/ImageFactory.cpp
index 9298d74..ec20c78 100644
--- a/image/ImageFactory.cpp
+++ b/image/ImageFactory.cpp
@@ -98,8 +98,10 @@ ImageFactory::CreateImage(nsIRequest* aRequest,
     nsCOMPtr<nsIChannel> channel(do_QueryInterface(aRequest));
     isBlocked = !NS_SVGEnabledForChannel(channel);
     if (!isBlocked && channel && !NS_SVGEnabledForChannel(nullptr)) {
-      // Special case for favicons: block this image load if SVGs are
-      // disallowed from content and if this image load originated from the
+      // This SVG was not blocked based on the channel but SVGs are
+      // disallowed from content. Check some special cases.
+
+      // For favicons, block this SVG image load if it originated from the
       // favicon xul:image node within a tab.
       nsCOMPtr<nsILoadInfo> loadInfo;
       nsresult rv = channel->GetLoadInfo(getter_AddRefs(loadInfo));
@@ -111,6 +113,17 @@ ImageFactory::CreateImage(nsIRequest* aRequest,
             nsAutoString anonid;
             elem->GetAttribute(NS_LITERAL_STRING("anonid"), anonid);
             isBlocked = anonid.EqualsLiteral("tab-icon-image");
+
+            if (!isBlocked) {
+              // For the Page Info "Media" tab, block this SVG image load if
+              // it originated from a node within a chrome document that has
+              // an id of "thepreviewimage".
+              if (nsContentUtils::IsChromeDoc(node->OwnerDoc())) {
+                nsAutoString loadingID;
+                elem->GetId(loadingID);
+                isBlocked = loadingID.EqualsLiteral("thepreviewimage");
+              }
+            }
           }
         }
       }



More information about the tor-commits mailing list