summaryrefslogtreecommitdiff
path: root/src/server/api
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2018-06-01 21:55:27 +0900
committersyuilo <syuilotan@yahoo.co.jp>2018-06-01 21:55:27 +0900
commit0be790fa31d28f7efc0d0b5b847c5c93a60f0dbd (patch)
treee9ae1fa6befbd39e1c5f0cd45bf1f968edde19f2 /src/server/api
parentwip (diff)
downloadsharkey-0be790fa31d28f7efc0d0b5b847c5c93a60f0dbd.tar.gz
sharkey-0be790fa31d28f7efc0d0b5b847c5c93a60f0dbd.tar.bz2
sharkey-0be790fa31d28f7efc0d0b5b847c5c93a60f0dbd.zip
wip
Diffstat (limited to 'src/server/api')
-rw-r--r--src/server/api/endpoints.ts10
-rw-r--r--src/server/api/endpoints/following/request/accept.ts26
-rw-r--r--src/server/api/endpoints/following/request/reject.ts26
3 files changed, 62 insertions, 0 deletions
diff --git a/src/server/api/endpoints.ts b/src/server/api/endpoints.ts
index 196f3adebc..bd8f30b38f 100644
--- a/src/server/api/endpoints.ts
+++ b/src/server/api/endpoints.ts
@@ -449,6 +449,16 @@ const endpoints: Endpoint[] = [
kind: 'following-write'
},
{
+ name: 'following/request/accept',
+ withCredential: true,
+ kind: 'following-write'
+ },
+ {
+ name: 'following/request/reject',
+ withCredential: true,
+ kind: 'following-write'
+ },
+ {
name: 'following/stalk',
withCredential: true,
limit: {
diff --git a/src/server/api/endpoints/following/request/accept.ts b/src/server/api/endpoints/following/request/accept.ts
new file mode 100644
index 0000000000..bf0aff4b77
--- /dev/null
+++ b/src/server/api/endpoints/following/request/accept.ts
@@ -0,0 +1,26 @@
+import $ from 'cafy'; import ID from '../../../../../cafy-id';
+import acceptFollowRequest from '../../../../../services/user/accept-follow-request';
+import User from '../../../../../models/user';
+
+/**
+ * Accept a follow request
+ */
+module.exports = (params, user) => new Promise(async (res, rej) => {
+ // Get 'followerId' parameter
+ const [followerId, followerIdErr] = $.type(ID).get(params.followerId);
+ if (followerIdErr) return rej('invalid followerId param');
+
+ // Fetch follower
+ const follower = await User.findOne({
+ _id: followerId
+ });
+
+ if (follower === null) {
+ return rej('follower not found');
+ }
+
+ await acceptFollowRequest(user, follower);
+
+ // Send response
+ res();
+});
diff --git a/src/server/api/endpoints/following/request/reject.ts b/src/server/api/endpoints/following/request/reject.ts
new file mode 100644
index 0000000000..5a995e1962
--- /dev/null
+++ b/src/server/api/endpoints/following/request/reject.ts
@@ -0,0 +1,26 @@
+import $ from 'cafy'; import ID from '../../../../../cafy-id';
+import rejectFollowRequest from '../../../../../services/user/reject-follow-request';
+import User from '../../../../../models/user';
+
+/**
+ * Reject a follow request
+ */
+module.exports = (params, user) => new Promise(async (res, rej) => {
+ // Get 'followerId' parameter
+ const [followerId, followerIdErr] = $.type(ID).get(params.followerId);
+ if (followerIdErr) return rej('invalid followerId param');
+
+ // Fetch follower
+ const follower = await User.findOne({
+ _id: followerId
+ });
+
+ if (follower === null) {
+ return rej('follower not found');
+ }
+
+ await rejectFollowRequest(user, follower);
+
+ // Send response
+ res();
+});