summaryrefslogtreecommitdiff
path: root/src/remote/activitypub/kernel/follow.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/remote/activitypub/kernel/follow.ts')
-rw-r--r--src/remote/activitypub/kernel/follow.ts20
1 files changed, 7 insertions, 13 deletions
diff --git a/src/remote/activitypub/kernel/follow.ts b/src/remote/activitypub/kernel/follow.ts
index fca6d26ccc..3e2063302a 100644
--- a/src/remote/activitypub/kernel/follow.ts
+++ b/src/remote/activitypub/kernel/follow.ts
@@ -1,26 +1,20 @@
import { IRemoteUser } from '../../../models/entities/user';
-import config from '../../../config';
import follow from '../../../services/following/create';
import { IFollow } from '../type';
-import { Users } from '../../../models';
+import DbResolver from '../db-resolver';
-export default async (actor: IRemoteUser, activity: IFollow): Promise<void> => {
- const id = typeof activity.object === 'string' ? activity.object : activity.object.id;
- if (id == null) throw new Error('missing id');
-
- if (!id.startsWith(config.url + '/')) {
- return;
- }
-
- const followee = await Users.findOne(id.split('/').pop());
+export default async (actor: IRemoteUser, activity: IFollow): Promise<string> => {
+ const dbResolver = new DbResolver();
+ const followee = await dbResolver.getUserFromApId(activity.object);
if (followee == null) {
- throw new Error('followee not found');
+ return `skip: followee not found`;
}
if (followee.host != null) {
- throw new Error('フォローしようとしているユーザーはローカルユーザーではありません');
+ return `skip: フォローしようとしているユーザーはローカルユーザーではありません`;
}
await follow(actor, followee, activity.id);
+ return `ok`;
};