summaryrefslogtreecommitdiff
path: root/src/remote/activitypub/kernel/block
diff options
context:
space:
mode:
authorMeiMei <30769358+mei23@users.noreply.github.com>2018-10-29 20:32:42 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2018-10-29 20:32:42 +0900
commitd64dc458999afdc0bfd5f662a583bd1a0f6eebb3 (patch)
tree7bafd2682c100ef3badb7dd0d992dbf35930678a /src/remote/activitypub/kernel/block
parentMerge branch 'develop' of https://github.com/syuilo/misskey into develop (diff)
downloadsharkey-d64dc458999afdc0bfd5f662a583bd1a0f6eebb3.tar.gz
sharkey-d64dc458999afdc0bfd5f662a583bd1a0f6eebb3.tar.bz2
sharkey-d64dc458999afdc0bfd5f662a583bd1a0f6eebb3.zip
User blocking (Following part) (#3035)
* block wip * UndoBlock * UnBlock * wip * follow * UI * fix
Diffstat (limited to 'src/remote/activitypub/kernel/block')
-rw-r--r--src/remote/activitypub/kernel/block/index.ts34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/remote/activitypub/kernel/block/index.ts b/src/remote/activitypub/kernel/block/index.ts
new file mode 100644
index 0000000000..dec591accf
--- /dev/null
+++ b/src/remote/activitypub/kernel/block/index.ts
@@ -0,0 +1,34 @@
+import * as mongo from 'mongodb';
+import User, { IRemoteUser } from '../../../../models/user';
+import config from '../../../../config';
+import * as debug from 'debug';
+import { IBlock } from '../../type';
+import block from '../../../../services/blocking/create';
+
+const log = debug('misskey:activitypub');
+
+export default async (actor: IRemoteUser, activity: IBlock): Promise<void> => {
+ const id = typeof activity.object == 'string' ? activity.object : activity.object.id;
+
+ const uri = activity.id || activity;
+
+ log(`Block: ${uri}`);
+
+ if (!id.startsWith(config.url + '/')) {
+ return null;
+ }
+
+ const blockee = await User.findOne({
+ _id: new mongo.ObjectID(id.split('/').pop())
+ });
+
+ if (blockee === null) {
+ throw new Error('blockee not found');
+ }
+
+ if (blockee.host != null) {
+ throw new Error('ブロックしようとしているユーザーはローカルユーザーではありません');
+ }
+
+ block(actor, blockee);
+};