diff options
| author | Akihiko Odaki <nekomanma@pixiv.co.jp> | 2018-04-01 19:43:26 +0900 |
|---|---|---|
| committer | Akihiko Odaki <nekomanma@pixiv.co.jp> | 2018-04-01 23:30:57 +0900 |
| commit | dc529711ced031155f53fa321159ec2830ef8b05 (patch) | |
| tree | 7a677cd11deab9a3026e7fc30f57556398901083 /src/server/api/endpoints/following/create.ts | |
| parent | Implement account public key endpoint (diff) | |
| download | sharkey-dc529711ced031155f53fa321159ec2830ef8b05.tar.gz sharkey-dc529711ced031155f53fa321159ec2830ef8b05.tar.bz2 sharkey-dc529711ced031155f53fa321159ec2830ef8b05.zip | |
Implement remote follow
Diffstat (limited to 'src/server/api/endpoints/following/create.ts')
| -rw-r--r-- | src/server/api/endpoints/following/create.ts | 29 |
1 files changed, 5 insertions, 24 deletions
diff --git a/src/server/api/endpoints/following/create.ts b/src/server/api/endpoints/following/create.ts index a689250e35..03c13ab7fc 100644 --- a/src/server/api/endpoints/following/create.ts +++ b/src/server/api/endpoints/following/create.ts @@ -2,10 +2,9 @@ * Module dependencies */ import $ from 'cafy'; -import User, { pack as packUser } from '../../../../models/user'; +import User from '../../../../models/user'; import Following from '../../../../models/following'; -import notify from '../../common/notify'; -import event from '../../../../common/event'; +import queue from '../../../../queue'; /** * Follow a user @@ -52,33 +51,15 @@ module.exports = (params, user) => new Promise(async (res, rej) => { } // Create following - await Following.insert({ + const { _id } = await Following.insert({ createdAt: new Date(), followerId: follower._id, followeeId: followee._id }); + queue.create('http', { type: 'follow', following: _id }).save(); + // Send response res(); - // Increment following count - User.update(follower._id, { - $inc: { - followingCount: 1 - } - }); - - // Increment followers count - User.update({ _id: followee._id }, { - $inc: { - followersCount: 1 - } - }); - - // Publish follow event - event(follower._id, 'follow', await packUser(followee, follower)); - event(followee._id, 'followed', await packUser(follower, followee)); - - // Notify - notify(followee._id, follower._id, 'follow'); }); |