diff options
| author | MeiMei <30769358+mei23@users.noreply.github.com> | 2019-10-29 06:01:14 +0900 |
|---|---|---|
| committer | syuilo <Syuilotan@yahoo.co.jp> | 2019-10-29 06:01:14 +0900 |
| commit | 245b08b624573cf4f6cb3192995d5d4f319cbce2 (patch) | |
| tree | e9f1eb3385bdda1dee715ef77b96717267866de6 /src/remote/activitypub | |
| parent | Update README.md [AUTOGEN] (#5556) (diff) | |
| download | sharkey-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.ts | 8 | ||||
| -rw-r--r-- | src/remote/activitypub/renderer/note.ts | 9 | ||||
| -rw-r--r-- | src/remote/activitypub/type.ts | 1 |
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 { |