summaryrefslogtreecommitdiff
path: root/src/remote/activitypub
diff options
context:
space:
mode:
authorMeiMei <30769358+mei23@users.noreply.github.com>2019-10-29 06:01:14 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2019-10-29 06:01:14 +0900
commit245b08b624573cf4f6cb3192995d5d4f319cbce2 (patch)
treee9f1eb3385bdda1dee715ef77b96717267866de6 /src/remote/activitypub
parentUpdate README.md [AUTOGEN] (#5556) (diff)
downloadsharkey-245b08b624573cf4f6cb3192995d5d4f319cbce2.tar.gz
sharkey-245b08b624573cf4f6cb3192995d5d4f319cbce2.tar.bz2
sharkey-245b08b624573cf4f6cb3192995d5d4f319cbce2.zip
Talk federation (#5534)
Diffstat (limited to 'src/remote/activitypub')
-rw-r--r--src/remote/activitypub/models/note.ts8
-rw-r--r--src/remote/activitypub/renderer/note.ts9
-rw-r--r--src/remote/activitypub/type.ts1
3 files changed, 16 insertions, 2 deletions
diff --git a/src/remote/activitypub/models/note.ts b/src/remote/activitypub/models/note.ts
index eb7cd6f81a..17c3721bdb 100644
--- a/src/remote/activitypub/models/note.ts
+++ b/src/remote/activitypub/models/note.ts
@@ -23,6 +23,7 @@ import { genId } from '../../../misc/gen-id';
import { fetchMeta } from '../../../misc/fetch-meta';
import { ensure } from '../../../prelude/ensure';
import { getApLock } from '../../../misc/app-lock';
+import { createMessage } from '../../../services/messages/create';
const logger = apLogger;
@@ -223,6 +224,13 @@ export async function createNote(value: string | IObject, resolver?: Resolver, s
if (actor.uri) updatePerson(actor.uri);
}
+ if (note._misskey_talk && visibility === 'specified') {
+ for (const recipient of visibleUsers) {
+ await createMessage(actor, recipient, undefined, text || undefined, (files && files.length > 0) ? files[0] : null);
+ return null;
+ }
+ }
+
return await post(actor, {
createdAt: note.published ? new Date(note.published) : null,
files,
diff --git a/src/remote/activitypub/renderer/note.ts b/src/remote/activitypub/renderer/note.ts
index ca823941c0..d58e1de433 100644
--- a/src/remote/activitypub/renderer/note.ts
+++ b/src/remote/activitypub/renderer/note.ts
@@ -12,7 +12,7 @@ import { Emoji } from '../../../models/entities/emoji';
import { Poll } from '../../../models/entities/poll';
import { ensure } from '../../../prelude/ensure';
-export default async function renderNote(note: Note, dive = true): Promise<any> {
+export default async function renderNote(note: Note, dive = true, isTalk = false): Promise<any> {
const promisedFiles: Promise<DriveFile[]> = note.fileIds.length > 0
? DriveFiles.find({ id: In(note.fileIds) })
: Promise.resolve([]);
@@ -145,6 +145,10 @@ export default async function renderNote(note: Note, dive = true): Promise<any>
}))
} : {};
+ const asTalk = isTalk ? {
+ _misskey_talk: true
+ } : {};
+
return {
id: `${config.url}/notes/${note.id}`,
type: 'Note',
@@ -160,7 +164,8 @@ export default async function renderNote(note: Note, dive = true): Promise<any>
attachment: files.map(renderDocument),
sensitive: note.cw != null || files.some(file => file.isSensitive),
tag,
- ...asPoll
+ ...asPoll,
+ ...asTalk
};
}
diff --git a/src/remote/activitypub/type.ts b/src/remote/activitypub/type.ts
index df9da42fa8..5670df243d 100644
--- a/src/remote/activitypub/type.ts
+++ b/src/remote/activitypub/type.ts
@@ -75,6 +75,7 @@ export interface INote extends IObject {
type: 'Note' | 'Question' | 'Article' | 'Audio' | 'Document' | 'Image' | 'Page' | 'Video';
_misskey_content?: string;
_misskey_quote?: string;
+ _misskey_talk: boolean;
}
export interface IQuestion extends IObject {