about summary refs log tree commit diff stats
path: root/src/assets
diff options
context:
space:
mode:
authorAustin Huang <im@austinhuang.me>2022-10-22 03:57:06 +0000
committerHygna <hygna@proton.me>2022-10-22 22:38:09 +0100
commit1dfd4f87641d7580fb6674844e33207277647b9e (patch)
treec03dbeee4dd3d61f61ea93833a2006fd8eb5c14a /src/assets
parentMoved web-ext config from flags to js file (diff)
downloadlibredirect-1dfd4f87641d7580fb6674844e33207277647b9e.zip
handle more reddit cdn urls
Diffstat (limited to 'src/assets')
-rw-r--r--src/assets/javascripts/services.js16
1 files changed, 15 insertions, 1 deletions
diff --git a/src/assets/javascripts/services.js b/src/assets/javascripts/services.js
index 8aa044ea..9c4205f6 100644
--- a/src/assets/javascripts/services.js
+++ b/src/assets/javascripts/services.js
@@ -400,7 +400,21 @@ function redirect(url, type, initiator, forceRedirection) {
 			if (url.href.search(/^https?:\/{2}(?:[im]\.)?stack\./) > -1) return `${randomInstance}/stack${url.pathname}${url.search}`

 			else return `${randomInstance}${url.pathname}${url.search}`

 		case "libreddit":

-			if (url.hostname.match(/^(i|preview)\.redd\.it/)) return `${randomInstance}/img${url.pathname}`

+			const subdomain = url.hostname.match(/^(?:(?:external-)?preview|i)(?=\.redd\.it)/)

+			if (!subdomain) return `${randomInstance}${url.pathname}${url.search}`

+			switch (subdomain[0]) {

+				case "preview":

+					return `${randomInstance}/preview/pre${url.pathname}${url.search}`

+				case "external-preview":

+					return `${randomInstance}/preview/external-pre${url.pathname}${url.search}`

+				case "i":

+					return `${randomInstance}/img${url.pathname}`

+			}

+		case "teddit":

+			if (/^(?:(?:external-)?preview|i)\.redd\.it/.test(url.hostname)) {

+				if (url.search == "") return `${randomInstance}${url.pathname}?teddit_proxy=${url.hostname}`

+				else return `${randomInstance}${url.pathname}${url.search}&teddit_proxy=${url.hostname}`

+			}

 			return `${randomInstance}${url.pathname}${url.search}`

 		default:

 			return `${randomInstance}${url.pathname}${url.search}`