summaryrefslogtreecommitdiff
path: root/src/remote/activitypub/kernel
diff options
context:
space:
mode:
authorMeiMei <30769358+mei23@users.noreply.github.com>2019-06-28 18:54:10 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2019-06-28 18:54:09 +0900
commit0141affe056e2b7103f67088f6f5bdb276c8d5d3 (patch)
treec66cb7597f43a749d24b48ee0b552133ec000b38 /src/remote/activitypub/kernel
parentUse as const (diff)
downloadsharkey-0141affe056e2b7103f67088f6f5bdb276c8d5d3.tar.gz
sharkey-0141affe056e2b7103f67088f6f5bdb276c8d5d3.tar.bz2
sharkey-0141affe056e2b7103f67088f6f5bdb276c8d5d3.zip
Fix: AP object / actor type (#5086)
* attributedToがArrayの場合などに対応 * attachment以外で来るDocument系のObjectに対応 * Renote, Reply 対応 * 表示をいい感じに * fix type * revert as const * Fix Note / Question type * attributedToのtypeで複合配列を想定する
Diffstat (limited to 'src/remote/activitypub/kernel')
-rw-r--r--src/remote/activitypub/kernel/announce/index.ts14
-rw-r--r--src/remote/activitypub/kernel/announce/note.ts15
-rw-r--r--src/remote/activitypub/kernel/create/image.ts6
-rw-r--r--src/remote/activitypub/kernel/create/index.ts19
-rw-r--r--src/remote/activitypub/kernel/delete/index.ts26
5 files changed, 21 insertions, 59 deletions
diff --git a/src/remote/activitypub/kernel/announce/index.ts b/src/remote/activitypub/kernel/announce/index.ts
index ebd5a27b92..68fce52e17 100644
--- a/src/remote/activitypub/kernel/announce/index.ts
+++ b/src/remote/activitypub/kernel/announce/index.ts
@@ -1,13 +1,13 @@
import Resolver from '../../resolver';
import { IRemoteUser } from '../../../../models/entities/user';
import announceNote from './note';
-import { IAnnounce, INote } from '../../type';
+import { IAnnounce, INote, validPost, getApId } from '../../type';
import { apLogger } from '../../logger';
const logger = apLogger;
export default async (actor: IRemoteUser, activity: IAnnounce): Promise<void> => {
- const uri = activity.id || activity;
+ const uri = getApId(activity);
logger.info(`Announce: ${uri}`);
@@ -22,15 +22,9 @@ export default async (actor: IRemoteUser, activity: IAnnounce): Promise<void> =>
throw e;
}
- switch (object.type) {
- case 'Note':
- case 'Question':
- case 'Article':
+ if (validPost.includes(object.type)) {
announceNote(resolver, actor, activity, object as INote);
- break;
-
- default:
+ } else {
logger.warn(`Unknown announce type: ${object.type}`);
- break;
}
};
diff --git a/src/remote/activitypub/kernel/announce/note.ts b/src/remote/activitypub/kernel/announce/note.ts
index 6843041475..2a07f50c8a 100644
--- a/src/remote/activitypub/kernel/announce/note.ts
+++ b/src/remote/activitypub/kernel/announce/note.ts
@@ -1,7 +1,7 @@
import Resolver from '../../resolver';
import post from '../../../../services/note/create';
import { IRemoteUser, User } from '../../../../models/entities/user';
-import { IAnnounce, INote } from '../../type';
+import { IAnnounce, INote, getApId, getApIds } from '../../type';
import { fetchNote, resolveNote } from '../../models/note';
import { resolvePerson } from '../../models/person';
import { apLogger } from '../../logger';
@@ -14,17 +14,13 @@ const logger = apLogger;
* アナウンスアクティビティを捌きます
*/
export default async function(resolver: Resolver, actor: IRemoteUser, activity: IAnnounce, note: INote): Promise<void> {
- const uri = activity.id || activity;
+ const uri = getApId(activity);
// アナウンサーが凍結されていたらスキップ
if (actor.isSuspended) {
return;
}
- if (typeof uri !== 'string') {
- throw new Error('invalid announce');
- }
-
// アナウンス先をブロックしてたら中断
const meta = await fetchMeta();
if (meta.blockedHosts.includes(extractDbHost(uri))) return;
@@ -52,11 +48,14 @@ export default async function(resolver: Resolver, actor: IRemoteUser, activity:
logger.info(`Creating the (Re)Note: ${uri}`);
//#region Visibility
- const visibility = getVisibility(activity.to || [], activity.cc || [], actor);
+ const to = getApIds(activity.to);
+ const cc = getApIds(activity.cc);
+
+ const visibility = getVisibility(to, cc, actor);
let visibleUsers: User[] = [];
if (visibility == 'specified') {
- visibleUsers = await Promise.all((note.to || []).map(uri => resolvePerson(uri)));
+ visibleUsers = await Promise.all(to.map(uri => resolvePerson(uri)));
}
//#endergion
diff --git a/src/remote/activitypub/kernel/create/image.ts b/src/remote/activitypub/kernel/create/image.ts
deleted file mode 100644
index 7720e8f1bd..0000000000
--- a/src/remote/activitypub/kernel/create/image.ts
+++ /dev/null
@@ -1,6 +0,0 @@
-import { IRemoteUser } from '../../../../models/entities/user';
-import { createImage } from '../../models/image';
-
-export default async function(actor: IRemoteUser, image: any): Promise<void> {
- await createImage(image.url, actor);
-}
diff --git a/src/remote/activitypub/kernel/create/index.ts b/src/remote/activitypub/kernel/create/index.ts
index 0326b591f8..a6fa2336f3 100644
--- a/src/remote/activitypub/kernel/create/index.ts
+++ b/src/remote/activitypub/kernel/create/index.ts
@@ -1,14 +1,13 @@
import Resolver from '../../resolver';
import { IRemoteUser } from '../../../../models/entities/user';
-import createImage from './image';
import createNote from './note';
-import { ICreate } from '../../type';
+import { ICreate, getApId, validPost } from '../../type';
import { apLogger } from '../../logger';
const logger = apLogger;
export default async (actor: IRemoteUser, activity: ICreate): Promise<void> => {
- const uri = activity.id || activity;
+ const uri = getApId(activity);
logger.info(`Create: ${uri}`);
@@ -23,19 +22,9 @@ export default async (actor: IRemoteUser, activity: ICreate): Promise<void> => {
throw e;
}
- switch (object.type) {
- case 'Image':
- createImage(actor, object);
- break;
-
- case 'Note':
- case 'Question':
- case 'Article':
+ if (validPost.includes(object.type)) {
createNote(resolver, actor, object);
- break;
-
- default:
+ } else {
logger.warn(`Unknown type: ${object.type}`);
- break;
}
};
diff --git a/src/remote/activitypub/kernel/delete/index.ts b/src/remote/activitypub/kernel/delete/index.ts
index 199a6a6187..be7779e026 100644
--- a/src/remote/activitypub/kernel/delete/index.ts
+++ b/src/remote/activitypub/kernel/delete/index.ts
@@ -1,9 +1,8 @@
import Resolver from '../../resolver';
import deleteNote from './note';
import { IRemoteUser } from '../../../../models/entities/user';
-import { IDelete } from '../../type';
+import { IDelete, getApId, validPost } from '../../type';
import { apLogger } from '../../logger';
-import { Notes } from '../../../../models';
/**
* 削除アクティビティを捌きます
@@ -17,24 +16,11 @@ export default async (actor: IRemoteUser, activity: IDelete): Promise<void> => {
const object = await resolver.resolve(activity.object);
- const uri = (object as any).id;
+ const uri = getApId(object);
- switch (object.type) {
- case 'Note':
- case 'Question':
- case 'Article':
- deleteNote(actor, uri);
- break;
-
- case 'Tombstone':
- const note = await Notes.findOne({ uri });
- if (note != null) {
- deleteNote(actor, uri);
- }
- break;
-
- default:
- apLogger.warn(`Unknown type: ${object.type}`);
- break;
+ if (validPost.includes(object.type) || object.type === 'Tombstone') {
+ deleteNote(actor, uri);
+ } else {
+ apLogger.warn(`Unknown type: ${object.type}`);
}
};