From dcef0c8076fbb1edcc4f721e5511f9ee58bcde18 Mon Sep 17 00:00:00 2001 From: SimonBrazell Date: Mon, 24 Feb 2020 19:22:10 +1100 Subject: [PATCH] Fix OSM redirects --- background.js | 16 +++++++++------- manifest.json | 2 +- 2 files changed, 10 insertions(+), 8 deletions(-) diff --git a/background.js b/background.js index dd620d8..b6575f6 100644 --- a/background.js +++ b/background.js @@ -8,7 +8,7 @@ const bibliogramDefault = 'https://bibliogram.art'; const instagramRegex = /((www|about|help)\.)?instagram\.com/; const instagramPathsRegex = /(\/a|\/admin|\/api|\/favicon.ico|\/static|\/imageproxy|\/p|\/u|\/developer|\/about|\/legal|\/explore|\/director)/; const osmDefault = 'https://openstreetmap.org'; -const googleMapsRegex = /https?:\/\/((www|maps)\.)?(google).*(\/maps)/; +const googleMapsRegex = /https?:\/\/(((www|maps)\.)?(google).*(\/maps)|maps\.(google).*)/; const latLngZoomRegex = /@(-?\d[0-9.]*),(-?\d[0-9.]*),(\d{1,2})[.z]/; const dataLatLngRegex = /(!3d|!4d)(-?[0-9]{1,10}.[0-9]{1,10})/g; @@ -113,18 +113,20 @@ function redirectGoogleMaps(url) { if (url.pathname.includes('/embed')) { return; } - let lat = ''; - let lon = ''; - let zoom = ''; + let mapCentre = ''; if (url.pathname.match(latLngZoomRegex)) { [, lat, lon, zoom] = url.pathname.match(latLngZoomRegex); + mapCentre = `#map=${zoom}/${lat}/${lon}`; } if (url.pathname.includes('data=')) { const [mlat, mlon] = url.pathname.match(dataLatLngRegex); - return `${osmInstance}/?mlat=${mlat.replace('!3d', '')}&mlon=${mlon.replace('!4d', '')}#map=${zoom}/${lat}/${lon}`; + return `${osmInstance}/?mlat=${mlat.replace('!3d', '')}&mlon=${mlon.replace('!4d', '')}${mapCentre}`; + } else if (url.search.includes('ll=')) { + const [mlat, mlon] = url.searchParams.get('ll').split(','); + return `${osmInstance}/?mlat=${mlat}&mlon=${mlon}${mapCentre}`; } else { - const query = encodeURI(url.searchParams.get('q')) || url.pathname.split('/')[3]; - return `${osmInstance}/search?query=${query}#map=${zoom}/${lat}/${lon}`; + const query = url.searchParams.get('q') || url.searchParams.get('query') || url.pathname.split('/')[3]; + return `${osmInstance}/search?query=${encodeURI(query)}${mapCentre}`; } } diff --git a/manifest.json b/manifest.json index 5f96e22..62d482e 100644 --- a/manifest.json +++ b/manifest.json @@ -1,7 +1,7 @@ { "name": "Privacy Redirect", "description": "Redirects Twitter, YouTube, Instagram & Google Maps requests to privacy friendly alternatives.", - "version": "1.1.10", + "version": "1.1.11", "manifest_version": 2, "background": { "scripts": [