make webfinger server stuff more readable
Some checks failed
ci/woodpecker/push/lint-backend Pipeline failed
ci/woodpecker/push/build Pipeline was successful
ci/woodpecker/push/lint-sw Pipeline failed
ci/woodpecker/push/lint-foundkey-js Pipeline was successful
ci/woodpecker/push/lint-client Pipeline failed
ci/woodpecker/push/test Pipeline failed

This commit is contained in:
Johann150 2023-12-16 09:59:51 +01:00
parent bed6a1e2d8
commit c67ff44207
Signed by: Johann150
GPG key ID: 9EE6577A2A06F8F1

View file

@ -80,26 +80,33 @@ router.get('/.well-known/oauth-authorization-server', oauth);
router.get('/.well-known/openid-configuration', oauth); router.get('/.well-known/openid-configuration', oauth);
router.get(webFingerPath, async ctx => { router.get(webFingerPath, async ctx => {
const fromId = (id: User['id']): FindOptionsWhere<User> => ({ const fromAcct = (acct_str: string): FindOptionsWhere<User> | number => {
id, const acct = Acct.parse(acct_str);
host: IsNull(), if (!acct.host || acct.host === config.host.toLowerCase()) {
isSuspended: false, return {
}); usernameLower: acct.username,
host: IsNull(),
isSuspended: false,
};
} else {
return 422;
}
};
const generateQuery = (resource: string): FindOptionsWhere<User> | number => const generateQuery = (resource: string): FindOptionsWhere<User> | number => {
resource.startsWith(`${config.url.toLowerCase()}/users/`) ? if (resource.startsWith(`${config.url.toLowerCase()}/users/`)) {
fromId(resource.split('/').pop()!) : return {
fromAcct(Acct.parse( id: resource.split('/').pop()!,
resource.startsWith(`${config.url.toLowerCase()}/@`) ? resource.split('/').pop()! : host: IsNull(),
resource.startsWith('acct:') ? resource.slice('acct:'.length) : isSuspended: false,
resource)); };
} else if (resource.startsWith(`${config.url.toLowerCase()}/@`)) {
const fromAcct = (acct: Acct.Acct): FindOptionsWhere<User> | number => return fromAcct(resource.split('/').pop()!);
!acct.host || acct.host === config.host.toLowerCase() ? { } else if (resource.startsWith("acct:")) {
usernameLower: acct.username, return fromAcct(resource.slice('acct:'.length));
host: IsNull(), }
isSuspended: false, return fromAcct(resource);
} : 422; };
let resource = ctx.query.resource; let resource = ctx.query.resource;