From ea40c6ad65cfc9c2ad985b3cd911cba7b402a679 Mon Sep 17 00:00:00 2001 From: Fabien O'Carroll Date: Thu, 16 May 2024 15:26:56 +0700 Subject: [PATCH] Used Article as Activity object ref https://linear.app/tryghost/issue/MOM-126 This allows us to pull out all of the data when converting to JSONLD --- ghost/ghost/src/core/activitypub/activity.entity.ts | 13 ++++++++++--- ghost/ghost/src/core/activitypub/actor.entity.ts | 5 +---- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/ghost/ghost/src/core/activitypub/activity.entity.ts b/ghost/ghost/src/core/activitypub/activity.entity.ts index 5fc9d3b8eb..1ab8b17811 100644 --- a/ghost/ghost/src/core/activitypub/activity.entity.ts +++ b/ghost/ghost/src/core/activitypub/activity.entity.ts @@ -1,4 +1,5 @@ import {Entity} from '../../common/entity.base'; +import {Article} from './article.object'; import {ActivityPub} from './types'; import {URI} from './uri.object'; @@ -11,7 +12,7 @@ type ActivityData = { type: string; // eslint-disable-next-line @typescript-eslint/no-explicit-any [x: string]: any; - }; + } | Article; to: URI | null; } @@ -45,7 +46,10 @@ export class Activity extends Entity { return this.attr.type; } - getObject() { + getObject(url: URL) { + if (this.attr.object instanceof Article) { + return this.attr.object.getJSONLD(url); + } return this.attr.object; } @@ -54,6 +58,9 @@ export class Activity extends Entity { } get objectId() { + if (this.attr.object instanceof Article) { + return this.attr.object.objectId; + } return this.attr.object.id; } @@ -62,7 +69,7 @@ export class Activity extends Entity { } getJSONLD(url: URL): ActivityPub.Activity { - const object = this.getObject(); + const object = this.getObject(url); return { '@context': 'https://www.w3.org/ns/activitystreams', id: this.activityId?.getValue(url) || null, diff --git a/ghost/ghost/src/core/activitypub/actor.entity.ts b/ghost/ghost/src/core/activitypub/actor.entity.ts index af0c808eb7..a2ba5ae3ac 100644 --- a/ghost/ghost/src/core/activitypub/actor.entity.ts +++ b/ghost/ghost/src/core/activitypub/actor.entity.ts @@ -157,10 +157,7 @@ export class Actor extends Entity { to: this.followersCollectionId, type: 'Create', actor: this.actorId, - object: { - id: article.objectId, - type: 'Article' - } + object: article }); this.doActivity(activity); }