diff --git a/daemon.py b/daemon.py index a7527db53..cdde0d956 100644 --- a/daemon.py +++ b/daemon.py @@ -1732,15 +1732,15 @@ class PubServer(BaseHTTPRequestHandler): # protocol handler. See https://fedi-to.github.io/protocol-handler.html if self.path.startswith('/.well-known/protocol-handler'): if calling_domain.endswith('.onion'): - protocol_url = \ + protocol_url, _ = \ wellknown_protocol_handler(self.path, 'http', self.server.onion_domain) elif calling_domain.endswith('.i2p'): - protocol_url = \ + protocol_url, _ = \ wellknown_protocol_handler(self.path, 'http', self.server.i2p_domain) else: - protocol_url = \ + protocol_url, _ = \ wellknown_protocol_handler(self.path, self.server.http_prefix, self.server.domain_full) diff --git a/webfinger.py b/webfinger.py index 934770361..ae93426c2 100644 --- a/webfinger.py +++ b/webfinger.py @@ -252,12 +252,12 @@ def webfinger_meta(http_prefix: str, domain_full: str) -> str: return meta_str -def wellknown_protocol_handler(path: str, - http_prefix: str, domain_full: str) -> {}: +def wellknown_protocol_handler(path: str, http_prefix: str, + domain_full: str) -> ({}, str): """See https://fedi-to.github.io/protocol-handler.html """ if not path.startswith('/.well-known/protocol-handler?'): - return None + return None, None if 'target=' in path: path = urllib.parse.unquote(path) @@ -265,11 +265,11 @@ def wellknown_protocol_handler(path: str, if ';' in target: target = target.split(';')[0] if not target: - return None + return None, None if not target.startswith('web+epicyon:') and \ not target.startswith('web+mastodon:') and \ not target.startswith('web+ap:'): - return None + return None, None handle = target.split(':', 1)[1].strip() if handle.startswith('//'): handle = handle[2:] @@ -283,11 +283,15 @@ def wellknown_protocol_handler(path: str, domain_and_path = domain_full # not an open redirect if domain_and_path.startswith(domain_full): + command = '' + if '/' in nickname: + command = nickname.split('/')[0] + nickname = nickname.split('/')[1] domain_length = len(domain_full) path_str = domain_and_path[domain_length:] return http_prefix + '://' + domain_full + \ - '/users/' + nickname + path_str - return None + '/users/' + nickname + path_str, command + return None, None def webfinger_lookup(path: str, base_dir: str,