add support for TinyURL
This commit is contained in:
parent
e5b701aa55
commit
73a80f6d3d
@ -1,5 +1,6 @@
|
|||||||
const shortenerDomains = [
|
const shortenerDomains = [
|
||||||
"t.co"
|
"t.co",
|
||||||
|
"tinyurl.com"
|
||||||
];
|
];
|
||||||
|
|
||||||
browser.contextMenus.create({
|
browser.contextMenus.create({
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"manifest_version": 2,
|
"manifest_version": 2,
|
||||||
"name": "Unshortener",
|
"name": "Unshortener",
|
||||||
"version": "0.2",
|
"version": "0.3",
|
||||||
|
|
||||||
"description": "Unshorten links from Twitter.",
|
"description": "Unshorten links from Twitter.",
|
||||||
|
|
||||||
|
@ -3,10 +3,11 @@ from typing import Optional
|
|||||||
from urllib.parse import urlparse
|
from urllib.parse import urlparse
|
||||||
from fastapi import FastAPI
|
from fastapi import FastAPI
|
||||||
from fastapi.middleware.cors import CORSMiddleware
|
from fastapi.middleware.cors import CORSMiddleware
|
||||||
from unshorteners import unshorten_twitter
|
from unshorteners import unshorten_twitter, unshorten_tinyurl
|
||||||
|
|
||||||
UNSHORTEN = {
|
UNSHORTEN = {
|
||||||
't.co': unshorten_twitter
|
't.co': unshorten_twitter,
|
||||||
|
'tinyurl.com': unshorten_tinyurl
|
||||||
}
|
}
|
||||||
|
|
||||||
CACHE = {}
|
CACHE = {}
|
||||||
@ -32,9 +33,11 @@ async def receive_url(url: Optional[str] = None):
|
|||||||
return {"error": f"cannot unshorten {domain}"}
|
return {"error": f"cannot unshorten {domain}"}
|
||||||
|
|
||||||
if url in CACHE:
|
if url in CACHE:
|
||||||
unshortened = CACHE[url]
|
return CACHE[url]
|
||||||
else:
|
|
||||||
unshortened = UNSHORTEN[domain](url)
|
|
||||||
CACHE[url] = unshortened
|
|
||||||
|
|
||||||
return unshortened
|
result = UNSHORTEN[domain](url)
|
||||||
|
if result:
|
||||||
|
CACHE[url] = result
|
||||||
|
return result
|
||||||
|
|
||||||
|
return {"error": f"server error"}
|
||||||
|
@ -1,12 +1,27 @@
|
|||||||
"""Unshortening functions"""
|
"""Unshortening functions"""
|
||||||
import re
|
import re
|
||||||
import requests
|
import requests
|
||||||
|
from typing import Optional
|
||||||
|
|
||||||
|
|
||||||
def unshorten_twitter(url: str):
|
def unshorten_tinyurl(url: str) -> Optional[str]:
|
||||||
|
"""Retrieve the actual URL behind a TinyURL."""
|
||||||
|
try:
|
||||||
|
response = requests.get(url, timeout=4, allow_redirects=False)
|
||||||
|
except requests.RequestException:
|
||||||
|
return None
|
||||||
|
|
||||||
|
if response.status_code == 301:
|
||||||
|
return response.headers.get("location", None)
|
||||||
|
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
def unshorten_twitter(url: str) -> Optional[str]:
|
||||||
"""Retrieve the actual URL behind a Twitter URL."""
|
"""Retrieve the actual URL behind a Twitter URL."""
|
||||||
pattern = re.compile(r"<title>(.*?)<\/title>")
|
pattern = re.compile(r"<title>(.*?)<\/title>")
|
||||||
|
|
||||||
|
try:
|
||||||
response = requests.get(
|
response = requests.get(
|
||||||
url=url,
|
url=url,
|
||||||
headers={
|
headers={
|
||||||
@ -14,6 +29,8 @@ def unshorten_twitter(url: str):
|
|||||||
},
|
},
|
||||||
timeout=4
|
timeout=4
|
||||||
)
|
)
|
||||||
|
except requests.RequestException:
|
||||||
|
return None
|
||||||
|
|
||||||
match = pattern.search(response.text)
|
match = pattern.search(response.text)
|
||||||
if match:
|
if match:
|
||||||
|
Loading…
Reference in New Issue
Block a user