diff options
| author | Hazelnoot <acomputerdog@gmail.com> | 2025-04-24 13:07:41 -0400 |
|---|---|---|
| committer | Hazelnoot <acomputerdog@gmail.com> | 2025-04-24 13:07:41 -0400 |
| commit | ac894986f97888829badb39c6a8b33d0ecf0721c (patch) | |
| tree | b64de6d0529bd66119713050b7e5812eb0651af3 /packages/backend/src/misc | |
| parent | merge: fix/revert some defaults back to sharkey defaults (!967) (diff) | |
| parent | merge: Fix typo in contributing. (!965) (diff) | |
| download | sharkey-ac894986f97888829badb39c6a8b33d0ecf0721c.tar.gz sharkey-ac894986f97888829badb39c6a8b33d0ecf0721c.tar.bz2 sharkey-ac894986f97888829badb39c6a8b33d0ecf0721c.zip | |
Merge branch 'develop' into merge/2025-03-24
# Conflicts:
# CONTRIBUTING.md
# packages/backend/src/core/activitypub/models/ApPersonService.ts
Diffstat (limited to 'packages/backend/src/misc')
| -rw-r--r-- | packages/backend/src/misc/verify-field-link.ts | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/packages/backend/src/misc/verify-field-link.ts b/packages/backend/src/misc/verify-field-link.ts new file mode 100644 index 0000000000..f519acfba0 --- /dev/null +++ b/packages/backend/src/misc/verify-field-link.ts @@ -0,0 +1,34 @@ +/* +* SPDX-FileCopyrightText: piuvas and other Sharkey contributors +* SPDX-License-Identifier: AGPL-3.0-only +*/ + +import { JSDOM } from 'jsdom'; +import type { HttpRequestService } from '@/core/HttpRequestService.js'; + +type Field = { name: string, value: string }; + +export async function verifyFieldLinks(fields: Field[], profile_url: string, httpRequestService: HttpRequestService): Promise<string[]> { + const verified_links = []; + for (const field_url of fields + .filter(x => URL.canParse(x.value) && ['http:', 'https:'].includes((new URL(x.value).protocol)))) { + try { + const html = await httpRequestService.getHtml(field_url.value); + + const { window } = new JSDOM(html); + const doc: Document = window.document; + + const aEls = Array.from(doc.getElementsByTagName('a')); + const linkEls = Array.from(doc.getElementsByTagName('link')); + + const includesProfileLinks = [...aEls, ...linkEls].some(link => link.rel === 'me' && link.href === profile_url); + if (includesProfileLinks) { verified_links.push(field_url.value); } + + window.close(); + } catch (err) { + // don't do anything. + continue; + } + } + return verified_links; +} |