From d05f9806527e7c7096eca9079b02bf7eda29f708 Mon Sep 17 00:00:00 2001 From: Ray Lothian Date: Mon, 14 Nov 2022 01:31:04 -0500 Subject: [PATCH] new fix for #160 --- v2/firefox/common.js | 43 +++++++++++++++++++++++++++++++++++++++---- 1 file changed, 39 insertions(+), 4 deletions(-) diff --git a/v2/firefox/common.js b/v2/firefox/common.js index b939ad3..4549159 100644 --- a/v2/firefox/common.js +++ b/v2/firefox/common.js @@ -266,7 +266,7 @@ const ua = { o.productSub = '20030107'; if (prefs.userAgentData && p.browser && p.browser.major) { - if (['Opera', 'Chrome', 'Edge', 'Vivaldi'].includes(p.browser.name)) { + if (['Opera', 'Chrome', 'Edge'].includes(p.browser.name)) { o.userAgentDataBuilder = {p, ua: s}; delete o.userAgentData; } @@ -536,7 +536,38 @@ const onBeforeSendHeaders = d => { } // https://github.com/ray-lothian/UserAgent-Switcher/issues/160 else if (name.startsWith('sec-ch-')) { - requestHeaders[i] = null; + if (o.userAgentDataBuilder) { + if (name === 'sec-ch-ua-platform') { + let platform = o.userAgentDataBuilder.p?.os?.name || 'Windows'; + + if (platform.toLowerCase().includes('mac')) { + platform = 'macOS'; + } + else if (name.includes('debian')) { + platform = 'Linux'; + } + + requestHeaders[i].value = '"' + platform + '"'; + } + else if (name === 'sec-ch-ua') { + const version = o.userAgentDataBuilder.p?.browser?.major || 107; + let name = o.userAgentDataBuilder.p?.browser?.name || 'Google Chrome'; + if (name === 'Chrome') { + name = 'Google Chrome'; + } + requestHeaders[i].value = `"${name}";v="${version}", "Chromium";v="${version}", "Not=A?Brand";v="24"`; + } + else if (name === 'sec-ch-ua-mobile') { + requestHeaders[i].value = + /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(o.userAgent) ? '?1' : '?0'; + } + else { + requestHeaders[i] = null; + } + } + else { + requestHeaders[i] = null; + } } } } @@ -567,7 +598,7 @@ const onCommitted = d => { const o = JSON.parse(decodeURIComponent(escape(atob('${s}')))); if (o.userAgentDataBuilder) { - navigator.userAgentData = new class NavigatorUAData { + const v = new class NavigatorUAData { #p; constructor({p, ua}) { @@ -587,7 +618,7 @@ const onCommitted = d => { version: '24' }]; - this.mobile = /Android|webOS|iPhone|iPad|Mac|Macintosh|iPod|BlackBerry|IEMobile|Opera Mini/i.test(ua); + this.mobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(ua); // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-CH-UA-Platform this.platform = 'Unknown'; @@ -639,6 +670,10 @@ const onCommitted = d => { return Promise.resolve(r); } }(o.userAgentDataBuilder); + + navigator.__defineGetter__('userAgentData', () => { + return v; + }); } delete o.userAgentDataBuilder;