main
Bob Mottram 2024-04-12 11:19:56 +01:00
parent fbb91fc8f1
commit 48f0830db9
2 changed files with 51 additions and 59 deletions

View File

@ -2628,7 +2628,15 @@ def daemon_http_get(self) -> None:
return
# get webfinger endpoint for a person
if get_webfinger(self, calling_domain, referer_domain, cookie):
if get_webfinger(self, calling_domain, referer_domain, cookie,
self.path, self.server.debug,
self.server.onion_domain,
self.server.i2p_domain,
self.server.http_prefix,
self.server.domain,
self.server.domain_full,
self.server.base_dir,
self.server.port):
fitness_performance(getreq_start_time, self.server.fitness,
'_GET', 'webfinger called',
self.server.debug)

View File

@ -22,27 +22,29 @@ from daemon_utils import has_accept
def get_webfinger(self, calling_domain: str, referer_domain: str,
cookie: str) -> bool:
if not self.path.startswith('/.well-known'):
cookie: str, path: str, debug: bool,
onion_domain: str, i2p_domain: str,
http_prefix: str, domain: str, domain_full: str,
base_dir: str, port: int) -> bool:
if not path.startswith('/.well-known'):
return False
if self.server.debug:
if debug:
print('DEBUG: WEBFINGER well-known')
if self.server.debug:
if debug:
print('DEBUG: WEBFINGER host-meta')
if self.path.startswith('/.well-known/host-meta'):
if path.startswith('/.well-known/host-meta'):
if calling_domain.endswith('.onion') and \
self.server.onion_domain:
onion_domain:
wf_result = \
webfinger_meta('http', self.server.onion_domain)
webfinger_meta('http', onion_domain)
elif (calling_domain.endswith('.i2p') and
self.server.i2p_domain):
i2p_domain):
wf_result = \
webfinger_meta('http', self.server.i2p_domain)
webfinger_meta('http', i2p_domain)
else:
wf_result = \
webfinger_meta(self.server.http_prefix,
self.server.domain_full)
webfinger_meta(http_prefix, domain_full)
if wf_result:
msg = wf_result.encode('utf-8')
msglen = len(msg)
@ -52,28 +54,24 @@ def get_webfinger(self, calling_domain: str, referer_domain: str,
return True
http_404(self, 6)
return True
if self.path.startswith('/api/statusnet') or \
self.path.startswith('/api/gnusocial') or \
self.path.startswith('/siteinfo') or \
self.path.startswith('/poco') or \
self.path.startswith('/friendi'):
if path.startswith('/api/statusnet') or \
path.startswith('/api/gnusocial') or \
path.startswith('/siteinfo') or \
path.startswith('/poco') or \
path.startswith('/friendi'):
http_404(self, 7)
return True
# protocol handler. See https://fedi-to.github.io/protocol-handler.html
if self.path.startswith('/.well-known/protocol-handler'):
if path.startswith('/.well-known/protocol-handler'):
if calling_domain.endswith('.onion'):
protocol_url, _ = \
wellknown_protocol_handler(self.path, 'http',
self.server.onion_domain)
wellknown_protocol_handler(path, 'http', onion_domain)
elif calling_domain.endswith('.i2p'):
protocol_url, _ = \
wellknown_protocol_handler(self.path,
'http', self.server.i2p_domain)
wellknown_protocol_handler(path, 'http', i2p_domain)
else:
protocol_url, _ = \
wellknown_protocol_handler(self.path,
self.server.http_prefix,
self.server.domain_full)
wellknown_protocol_handler(path, http_prefix, domain_full)
if protocol_url:
redirect_headers(self, protocol_url, cookie,
calling_domain, 308)
@ -81,29 +79,22 @@ def get_webfinger(self, calling_domain: str, referer_domain: str,
http_404(self, 8)
return True
# nodeinfo
if self.path.startswith('/.well-known/nodeinfo') or \
self.path.startswith('/.well-known/x-nodeinfo'):
if calling_domain.endswith('.onion') and \
self.server.onion_domain:
if path.startswith('/.well-known/nodeinfo') or \
path.startswith('/.well-known/x-nodeinfo'):
if calling_domain.endswith('.onion') and onion_domain:
wf_result = \
webfinger_node_info('http', self.server.onion_domain)
elif (calling_domain.endswith('.i2p') and
self.server.i2p_domain):
webfinger_node_info('http', onion_domain)
elif (calling_domain.endswith('.i2p') and i2p_domain):
wf_result = \
webfinger_node_info('http', self.server.i2p_domain)
webfinger_node_info('http', i2p_domain)
else:
wf_result = \
webfinger_node_info(self.server.http_prefix,
self.server.domain_full)
webfinger_node_info(http_prefix, domain_full)
if wf_result:
msg_str = json.dumps(wf_result)
msg_str = convert_domains(calling_domain,
referer_domain,
msg_str,
self.server.http_prefix,
self.server.domain,
self.server.onion_domain,
self.server.i2p_domain)
msg_str = convert_domains(calling_domain, referer_domain,
msg_str, http_prefix, domain,
onion_domain, i2p_domain)
msg = msg_str.encode('utf-8')
msglen = len(msg)
if has_accept(self, calling_domain):
@ -120,31 +111,24 @@ def get_webfinger(self, calling_domain: str, referer_domain: str,
http_404(self, 9)
return True
if self.server.debug:
print('DEBUG: WEBFINGER lookup ' + self.path + ' ' +
str(self.server.base_dir))
if debug:
print('DEBUG: WEBFINGER lookup ' + path + ' ' + str(base_dir))
wf_result = \
webfinger_lookup(self.path, self.server.base_dir,
self.server.domain,
self.server.onion_domain,
self.server.i2p_domain,
self.server.port, self.server.debug)
webfinger_lookup(path, base_dir,
domain, onion_domain,
i2p_domain, port, debug)
if wf_result:
msg_str = json.dumps(wf_result)
msg_str = convert_domains(calling_domain,
referer_domain,
msg_str,
self.server.http_prefix,
self.server.domain,
self.server.onion_domain,
self.server.i2p_domain)
msg_str = convert_domains(calling_domain, referer_domain,
msg_str, http_prefix, domain,
onion_domain, i2p_domain)
msg = msg_str.encode('utf-8')
msglen = len(msg)
set_headers(self, 'application/jrd+json', msglen,
None, calling_domain, True)
write2(self, msg)
else:
if self.server.debug:
print('DEBUG: WEBFINGER lookup 404 ' + self.path)
if debug:
print('DEBUG: WEBFINGER lookup 404 ' + path)
http_404(self, 10)
return True