From 2d1470af1f6c9fb9763445596be3b9909d6de311 Mon Sep 17 00:00:00 2001 From: Anton Lazarev Date: Mon, 29 Jan 2024 18:51:40 -0800 Subject: [PATCH] support scriptletGlobals as a Map and as a plain JS object --- 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');