summaryrefslogtreecommitdiff
path: root/packages/backend/src/core/HttpRequestService.ts
diff options
context:
space:
mode:
authorHazelnoot <acomputerdog@gmail.com>2025-02-22 14:12:05 -0500
committerHazelnoot <acomputerdog@gmail.com>2025-03-02 11:06:29 -0500
commita568333ecd17edd1a4752abe755bb223fbfe44f4 (patch)
tree2cb0054b8df518ce55b51deb4c552d6b598387d8 /packages/backend/src/core/HttpRequestService.ts
parentmerge: Add "reject quotes" settings (!901) (diff)
downloadsharkey-a568333ecd17edd1a4752abe755bb223fbfe44f4.tar.gz
sharkey-a568333ecd17edd1a4752abe755bb223fbfe44f4.tar.bz2
sharkey-a568333ecd17edd1a4752abe755bb223fbfe44f4.zip
remove assertActivityMatchesUrls in favor of three-way same-authority checks
Diffstat (limited to 'packages/backend/src/core/HttpRequestService.ts')
-rw-r--r--packages/backend/src/core/HttpRequestService.ts11
1 files changed, 7 insertions, 4 deletions
diff --git a/packages/backend/src/core/HttpRequestService.ts b/packages/backend/src/core/HttpRequestService.ts
index 083153940a..19992a7597 100644
--- a/packages/backend/src/core/HttpRequestService.ts
+++ b/packages/backend/src/core/HttpRequestService.ts
@@ -16,8 +16,8 @@ import type { Config } from '@/config.js';
import { StatusError } from '@/misc/status-error.js';
import { bindThis } from '@/decorators.js';
import { validateContentTypeSetAsActivityPub } from '@/core/activitypub/misc/validator.js';
-import { assertActivityMatchesUrls } from '@/core/activitypub/misc/check-against-url.js';
-import type { IObject } from '@/core/activitypub/type.js';
+import { IObject } from '@/core/activitypub/type.js';
+import { ApUtilityService } from './activitypub/ApUtilityService.js';
import type { Response } from 'node-fetch';
import type { URL } from 'node:url';
@@ -145,6 +145,7 @@ export class HttpRequestService {
constructor(
@Inject(DI.config)
private config: Config,
+ private readonly apUtilityService: ApUtilityService,
) {
const cache = new CacheableLookup({
maxTtl: 3600, // 1hours
@@ -198,6 +199,7 @@ export class HttpRequestService {
* Get agent by URL
* @param url URL
* @param bypassProxy Allways bypass proxy
+ * @param isLocalAddressAllowed
*/
@bindThis
public getAgentByUrl(url: URL, bypassProxy = false, isLocalAddressAllowed = false): http.Agent | https.Agent {
@@ -229,10 +231,11 @@ export class HttpRequestService {
validators: [validateContentTypeSetAsActivityPub],
});
- const finalUrl = res.url; // redirects may have been involved
const activity = await res.json() as IObject;
- assertActivityMatchesUrls(activity, [finalUrl]);
+ // Make sure the object ID matches the final URL (which is where it actually exists).
+ // The caller (ApResolverService) will verify the ID against the original / entry URL, which ensures that all three match.
+ this.apUtilityService.assertIdMatchesUrlAuthority(activity, res.url);
return activity;
}