summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/following/create.ts
diff options
context:
space:
mode:
authortamaina <tamaina@hotmail.co.jp>2018-04-11 20:27:09 +0900
committerGitHub <noreply@github.com>2018-04-11 20:27:09 +0900
commitd43fe853c3605696e2e57e240845d0fc9c284f61 (patch)
tree838914e262c0fca5737588a7bba64e2b9f3d8e5f /src/server/api/endpoints/following/create.ts
parentUpdate README.md (diff)
parentwip #1443 (diff)
downloadmisskey-d43fe853c3605696e2e57e240845d0fc9c284f61.tar.gz
misskey-d43fe853c3605696e2e57e240845d0fc9c284f61.tar.bz2
misskey-d43fe853c3605696e2e57e240845d0fc9c284f61.zip
Merge pull request #1 from syuilo/master
追従
Diffstat (limited to 'src/server/api/endpoints/following/create.ts')
-rw-r--r--src/server/api/endpoints/following/create.ts53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/server/api/endpoints/following/create.ts b/src/server/api/endpoints/following/create.ts
new file mode 100644
index 0000000000..27e5eb31db
--- /dev/null
+++ b/src/server/api/endpoints/following/create.ts
@@ -0,0 +1,53 @@
+/**
+ * Module dependencies
+ */
+import $ from 'cafy';
+import User from '../../../../models/user';
+import Following from '../../../../models/following';
+import create from '../../../../services/following/create';
+
+/**
+ * Follow a user
+ */
+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');
+
+ // 自分自身
+ if (user._id.equals(userId)) {
+ return rej('followee is yourself');
+ }
+
+ // Get followee
+ const followee = await User.findOne({
+ _id: userId
+ }, {
+ fields: {
+ data: false,
+ profile: false
+ }
+ });
+
+ if (followee === null) {
+ return rej('user not found');
+ }
+
+ // Check if already following
+ const exist = await Following.findOne({
+ followerId: follower._id,
+ followeeId: followee._id
+ });
+
+ if (exist !== null) {
+ return rej('already following');
+ }
+
+ // Create following
+ create(follower, followee);
+
+ // Send response
+ res();
+});