fix: handle URI actor IDs

This commit is contained in:
Opliko
2024-04-25 12:59:05 +02:00
parent 8fd4ae2d8f
commit 700016649d
2 changed files with 8 additions and 4 deletions

View File

@@ -31,8 +31,9 @@ Actors.assert = async (ids, options = {}) => {
// Translate webfinger handles to uris
ids = (await Promise.all(ids.map(async (id) => {
const originalId = id;
if (id.includes('@')) {
const host = id.split('@')[1];
const isUri = activitypub.helpers.isUri(id);
if (id.includes('@') || isUri) {
const host = isUri ? new URL(id).host : id.split('@')[1];
if (host === nconf.get('url_parsed').host) { // do not assert loopback ids
return null;
}

View File

@@ -38,7 +38,8 @@ Helpers.isUri = (value) => {
Helpers.query = async (id) => {
const [username, hostname] = id.split('@');
if (!username || !hostname) {
const isUri = Helpers.isUri(id);
if ((!username || !hostname) && !isUri) {
return false;
}
@@ -46,11 +47,13 @@ Helpers.query = async (id) => {
return webfingerCache.get(id);
}
const protocol = isUri ? '' : 'acct:'; // if ID is an URI the protocol is already included
// Make a webfinger query to retrieve routing information
let response;
let body;
try {
({ response, body } = await request.get(`https://${hostname}/.well-known/webfinger?resource=acct%3a${encodeURIComponent(id)}`));
({ response, body } = await request.get(`https://${hostname}/.well-known/webfinger?resource=${encodeURIComponent(protocol)}${encodeURIComponent(id)}`));
} catch (e) {
return false;
}