summaryrefslogtreecommitdiff
path: root/src/remote/activitypub/act/create/note.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2018-04-06 19:35:23 +0900
committersyuilo <syuilotan@yahoo.co.jp>2018-04-06 19:35:23 +0900
commit4e9ae8e8d5c862ac7a72f56d7bc0b7dab9c81044 (patch)
tree895a954636b782b20af97bf65719bb0607f3ef32 /src/remote/activitypub/act/create/note.ts
parentFix type annotation (diff)
downloadsharkey-4e9ae8e8d5c862ac7a72f56d7bc0b7dab9c81044.tar.gz
sharkey-4e9ae8e8d5c862ac7a72f56d7bc0b7dab9c81044.tar.bz2
sharkey-4e9ae8e8d5c862ac7a72f56d7bc0b7dab9c81044.zip
Split code
Diffstat (limited to 'src/remote/activitypub/act/create/note.ts')
-rw-r--r--src/remote/activitypub/act/create/note.ts60
1 files changed, 60 insertions, 0 deletions
diff --git a/src/remote/activitypub/act/create/note.ts b/src/remote/activitypub/act/create/note.ts
new file mode 100644
index 0000000000..2ccd503aeb
--- /dev/null
+++ b/src/remote/activitypub/act/create/note.ts
@@ -0,0 +1,60 @@
+import { JSDOM } from 'jsdom';
+import * as debug from 'debug';
+
+import Resolver from '../../resolver';
+import Post, { IPost } from '../../../../models/post';
+import createPost from '../../../../services/post/create';
+import { IRemoteUser, isRemoteUser } from '../../../../models/user';
+import resolvePerson from '../../resolve-person';
+import createImage from './image';
+
+const log = debug('misskey:activitypub');
+
+export default async function createNote(resolver: Resolver, actor: IRemoteUser, note): Promise<IPost> {
+ if (
+ ('attributedTo' in note && actor.account.uri !== note.attributedTo) ||
+ typeof note.id !== 'string'
+ ) {
+ log(`invalid note: ${JSON.stringify(note, null, 2)}`);
+ throw new Error('invalid note');
+ }
+
+ log(`Creating the Note: ${note.id}`);
+
+ const media = [];
+ if ('attachment' in note && note.attachment != null) {
+ // TODO: attachmentは必ずしもImageではない
+ // TODO: ループの中でawaitはすべきでない
+ note.attachment.forEach(async media => {
+ const created = await createImage(resolver, note.actor, media);
+ media.push(created);
+ });
+ }
+
+ let reply = null;
+ if ('inReplyTo' in note && note.inReplyTo != null) {
+ const inReplyToPost = await Post.findOne({ uri: note.inReplyTo.id || note.inReplyTo });
+ if (inReplyToPost) {
+ reply = inReplyToPost;
+ } else {
+ const inReplyTo = await resolver.resolve(note.inReplyTo) as any;
+ const actor = await resolvePerson(inReplyTo.attributedTo);
+ if (isRemoteUser(actor)) {
+ reply = await createNote(resolver, actor, inReplyTo);
+ }
+ }
+ }
+
+ const { window } = new JSDOM(note.content);
+
+ return await createPost(actor, {
+ createdAt: new Date(note.published),
+ media,
+ reply,
+ repost: undefined,
+ text: window.document.body.textContent,
+ viaMobile: false,
+ geo: undefined,
+ uri: note.id
+ });
+}