summaryrefslogtreecommitdiff
path: root/packages/backend/src/misc
diff options
context:
space:
mode:
authorHazelnoot <acomputerdog@gmail.com>2025-04-24 13:07:41 -0400
committerHazelnoot <acomputerdog@gmail.com>2025-04-24 13:07:41 -0400
commitac894986f97888829badb39c6a8b33d0ecf0721c (patch)
treeb64de6d0529bd66119713050b7e5812eb0651af3 /packages/backend/src/misc
parentmerge: fix/revert some defaults back to sharkey defaults (!967) (diff)
parentmerge: Fix typo in contributing. (!965) (diff)
downloadsharkey-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.ts34
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;
+}