summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/following/delete.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2018-03-29 14:51:06 +0900
committerGitHub <noreply@github.com>2018-03-29 14:51:06 +0900
commit0b5597c873d2d9d45be94a18e1b74f44d9925185 (patch)
tree8b4dac3a56cf703650c8207f9279028a8560a96b /src/server/api/endpoints/following/delete.ts
parentoops (diff)
parentResolve conflicts (diff)
downloadmisskey-0b5597c873d2d9d45be94a18e1b74f44d9925185.tar.gz
misskey-0b5597c873d2d9d45be94a18e1b74f44d9925185.tar.bz2
misskey-0b5597c873d2d9d45be94a18e1b74f44d9925185.zip
Merge pull request #1332 from syuilo/pr/1327
Pr/1327
Diffstat (limited to 'src/server/api/endpoints/following/delete.ts')
-rw-r--r--src/server/api/endpoints/following/delete.ts81
1 files changed, 81 insertions, 0 deletions
diff --git a/src/server/api/endpoints/following/delete.ts b/src/server/api/endpoints/following/delete.ts
new file mode 100644
index 0000000000..25eba8b262
--- /dev/null
+++ b/src/server/api/endpoints/following/delete.ts
@@ -0,0 +1,81 @@
+/**
+ * Module dependencies
+ */
+import $ from 'cafy';
+import User, { pack as packUser } from '../../models/user';
+import Following from '../../models/following';
+import event from '../../event';
+
+/**
+ * Unfollow a user
+ *
+ * @param {any} params
+ * @param {any} user
+ * @return {Promise<any>}
+ */
+module.exports = (params, user) => new Promise(async (res, rej) => {
+ const follower = user;
+
+ // Get 'userId' parameter
+ const [userId, userIdErr] = $(params.userId).id().$;
+ if (userIdErr) return rej('invalid userId param');
+
+ // Check if the followee is yourself
+ if (user._id.equals(userId)) {
+ return rej('followee is yourself');
+ }
+
+ // Get followee
+ const followee = await User.findOne({
+ _id: userId
+ }, {
+ fields: {
+ data: false,
+ 'account.profile': false
+ }
+ });
+
+ if (followee === null) {
+ return rej('user not found');
+ }
+
+ // Check not following
+ const exist = await Following.findOne({
+ followerId: follower._id,
+ followeeId: followee._id,
+ deletedAt: { $exists: false }
+ });
+
+ if (exist === null) {
+ return rej('already not following');
+ }
+
+ // Delete following
+ await Following.update({
+ _id: exist._id
+ }, {
+ $set: {
+ deletedAt: new Date()
+ }
+ });
+
+ // Send response
+ res();
+
+ // Decrement following count
+ User.update({ _id: follower._id }, {
+ $inc: {
+ followingCount: -1
+ }
+ });
+
+ // Decrement followers count
+ User.update({ _id: followee._id }, {
+ $inc: {
+ followersCount: -1
+ }
+ });
+
+ // Publish follow event
+ event(follower._id, 'unfollow', await packUser(followee, follower));
+});