diff options
| author | 2019-04-25 15:58:58 +0100 | |
|---|---|---|
| committer | 2019-04-25 15:58:58 +0100 | |
| commit | 7643a962bd29504bf48a23383109b7642700a349 (patch) | |
| tree | 24eecb40a61ac6a682722e4a0694eeb36a4fcfc7 /src | |
| parent | Make masterlogin passwords one-time-use (diff) | |
| signature | ||
Refuse to get the title for any url that points locall
Diffstat (limited to 'src')
| -rw-r--r-- | src/utils/http.py | 32 |
1 files changed, 30 insertions, 2 deletions
diff --git a/src/utils/http.py b/src/utils/http.py index 19f7fc20..09a47607 100644 --- a/src/utils/http.py +++ b/src/utils/http.py @@ -1,6 +1,7 @@ -import re, signal, traceback, typing, urllib.error, urllib.parse +import ipaddress, re, signal, socket, traceback, typing +import urllib.error, urllib.parse import json as _json -import bs4, requests +import bs4, netifaces, requests from src import utils REGEX_URL = re.compile("https?://\S+", re.I) @@ -87,3 +88,30 @@ def request(url: str, method: str="GET", get_params: dict={}, def strip_html(s: str) -> str: return bs4.BeautifulSoup(s, "lxml").get_text() +def resolve_hostname(hostname: str) -> typing.List[str]: + try: + addresses = socket.getaddrinfo(hostname, None, 0, socket.SOCK_STREAM) + except: + return [] + return [address[-1][0] for address in addresses] + +def is_ip(addr: str) -> bool: + try: + ipaddress.ip_address(addr) + except ValueError: + return False + return True + +def is_localhost(hostname: str) -> bool: + if is_ip(hostname): + ips = [ipaddress.ip_address(hostname)] + else: + ips = [ipaddress.ip_address(ip) for ip in resolve_hostname(hostname)] + + for interface in netifaces.interfaces(): + links = netifaces.ifaddresses(interface) + for link in links[netifaces.AF_INET]+links[netifaces.AF_INET6]: + address = ipaddress.ip_address(link["addr"].split("%", 1)[0]) + if address in ips: + return True + return False |
