summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/following/create.ts
diff options
context:
space:
mode:
authorAkihiko Odaki <nekomanma@pixiv.co.jp>2018-04-01 19:43:26 +0900
committerAkihiko Odaki <nekomanma@pixiv.co.jp>2018-04-01 23:30:57 +0900
commitdc529711ced031155f53fa321159ec2830ef8b05 (patch)
tree7a677cd11deab9a3026e7fc30f57556398901083 /src/server/api/endpoints/following/create.ts
parentImplement account public key endpoint (diff)
downloadsharkey-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.ts29
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');
});