From c519a67f8b4fb7e7fd6840dc0d7b2730bdc28b22 Mon Sep 17 00:00:00 2001 From: brave-builds <45370463+brave-builds@users.noreply.github.com> Date: Fri, 2 Feb 2024 05:45:39 +0100 Subject: [PATCH] Support upcoming `scriptletGlobals` change in upstream uBO (uplift to 1.63.x) (#21843) Uplift of #21813 (squashed) to beta --- browser/brave_shields/ad_block_service_browsertest.cc | 2 +- .../cosmetic_filters/renderer/cosmetic_filters_js_handler.cc | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/browser/brave_shields/ad_block_service_browsertest.cc b/browser/brave_shields/ad_block_service_browsertest.cc index 294b22696f50..97c2c28f53b5 100644 --- a/browser/brave_shields/ad_block_service_browsertest.cc +++ b/browser/brave_shields/ad_block_service_browsertest.cc @@ -2423,7 +2423,7 @@ IN_PROC_BROWSER_TEST_F(ScriptletDebugLogsFlagEnabledTest, CanDebugSetToTrue) { ASSERT_TRUE(InstallDefaultAdBlockExtension()); std::string scriptlet = "(function() {" - " if (scriptletGlobals.get('canDebug')) {" + " if (scriptletGlobals.get('canDebug') && scriptletGlobals.canDebug) {" " window.success = true;" " }" "})();"; diff --git a/components/cosmetic_filters/renderer/cosmetic_filters_js_handler.cc b/components/cosmetic_filters/renderer/cosmetic_filters_js_handler.cc index 9c6c15f16d55..d2d8e8ea77b1 100644 --- a/components/cosmetic_filters/renderer/cosmetic_filters_js_handler.cc +++ b/components/cosmetic_filters/renderer/cosmetic_filters_js_handler.cc @@ -46,7 +46,7 @@ const char kObservingScriptletEntryPoint[] = const char kScriptletInitScript[] = R"((function() { - let text = '(function() {\nconst scriptletGlobals = new Map(%s);\nlet deAmpEnabled = %s;\n' + %s + '})()'; + let text = '(function() {\nconst scriptletGlobals = (() => {\nconst forwardedMapMethods = ["has", "get", "set"];\nconst handler = {\nget(target, prop) { if (forwardedMapMethods.includes(prop)) { return Map.prototype[prop].bind(target) } return target.get(prop); },\nset(target, prop, value) { if (!forwardedMapMethods.includes(prop)) { target.set(prop, value); } }\n};\nreturn new Proxy(new Map(%s), handler);\n})();\nlet deAmpEnabled = %s;\n' + %s + '})()'; let script; try { script = document.createElement('script');