summaryrefslogtreecommitdiff
path: root/src/remote/activitypub/kernel/block/index.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/remote/activitypub/kernel/block/index.ts')
-rw-r--r--src/remote/activitypub/kernel/block/index.ts30
1 files changed, 10 insertions, 20 deletions
diff --git a/src/remote/activitypub/kernel/block/index.ts b/src/remote/activitypub/kernel/block/index.ts
index 24bc9d524f..6c794e1250 100644
--- a/src/remote/activitypub/kernel/block/index.ts
+++ b/src/remote/activitypub/kernel/block/index.ts
@@ -1,32 +1,22 @@
-import config from '../../../../config';
-import { IBlock, getApId } from '../../type';
+import { IBlock } from '../../type';
import block from '../../../../services/blocking/create';
-import { apLogger } from '../../logger';
-import { Users } from '../../../../models';
import { IRemoteUser } from '../../../../models/entities/user';
+import DbResolver from '../../db-resolver';
-const logger = apLogger;
+export default async (actor: IRemoteUser, activity: IBlock): Promise<string> => {
+ // ※ activity.objectにブロック対象があり、それは存在するローカルユーザーのはず
-export default async (actor: IRemoteUser, activity: IBlock): Promise<void> => {
- const id = getApId(activity.object);
-
- const uri = getApId(activity);
-
- logger.info(`Block: ${uri}`);
-
- if (!id.startsWith(config.url + '/')) {
- return;
- }
-
- const blockee = await Users.findOne(id.split('/').pop());
+ const dbResolver = new DbResolver();
+ const blockee = await dbResolver.getUserFromApId(activity.object);
if (blockee == null) {
- throw new Error('blockee not found');
+ return `skip: blockee not found`;
}
if (blockee.host != null) {
- throw new Error('ブロックしようとしているユーザーはローカルユーザーではありません');
+ return `skip: ブロックしようとしているユーザーはローカルユーザーではありません`;
}
- block(actor, blockee);
+ await block(actor, blockee);
+ return `ok`;
};