summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/blocking
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/api/endpoints/blocking')
-rw-r--r--src/server/api/endpoints/blocking/create.ts76
-rw-r--r--src/server/api/endpoints/blocking/delete.ts76
-rw-r--r--src/server/api/endpoints/blocking/list.ts65
3 files changed, 217 insertions, 0 deletions
diff --git a/src/server/api/endpoints/blocking/create.ts b/src/server/api/endpoints/blocking/create.ts
new file mode 100644
index 0000000000..7166505309
--- /dev/null
+++ b/src/server/api/endpoints/blocking/create.ts
@@ -0,0 +1,76 @@
+import $ from 'cafy'; import ID, { transform } from '../../../../misc/cafy-id';
+const ms = require('ms');
+import User, { pack } from '../../../../models/user';
+import Blocking from '../../../../models/blocking';
+import create from '../../../../services/blocking/create';
+import define from '../../define';
+
+export const meta = {
+ stability: 'stable',
+
+ desc: {
+ 'ja-JP': '指定したユーザーをブロックします。',
+ 'en-US': 'Block a user.'
+ },
+
+ limit: {
+ duration: ms('1hour'),
+ max: 100
+ },
+
+ requireCredential: true,
+
+ kind: 'following-write',
+
+ params: {
+ userId: {
+ validator: $.type(ID),
+ transform: transform,
+ desc: {
+ 'ja-JP': '対象のユーザーのID',
+ 'en-US': 'Target user ID'
+ }
+ }
+ }
+};
+
+export default define(meta, (ps, user) => new Promise(async (res, rej) => {
+ const blocker = user;
+
+ // 自分自身
+ if (user._id.equals(ps.userId)) {
+ return rej('blockee is yourself');
+ }
+
+ // Get blockee
+ const blockee = await User.findOne({
+ _id: ps.userId
+ }, {
+ fields: {
+ data: false,
+ profile: false
+ }
+ });
+
+ if (blockee === null) {
+ return rej('user not found');
+ }
+
+ // Check if already blocking
+ const exist = await Blocking.findOne({
+ blockerId: blocker._id,
+ blockeeId: blockee._id
+ });
+
+ if (exist !== null) {
+ return rej('already blocking');
+ }
+
+ // Create blocking
+ await create(blocker, blockee);
+
+ // Send response
+ res(await pack(blockee._id, user, {
+ detail: true
+ }));
+}));
diff --git a/src/server/api/endpoints/blocking/delete.ts b/src/server/api/endpoints/blocking/delete.ts
new file mode 100644
index 0000000000..667255a66b
--- /dev/null
+++ b/src/server/api/endpoints/blocking/delete.ts
@@ -0,0 +1,76 @@
+import $ from 'cafy'; import ID, { transform } from '../../../../misc/cafy-id';
+const ms = require('ms');
+import User, { pack } from '../../../../models/user';
+import Blocking from '../../../../models/blocking';
+import deleteBlocking from '../../../../services/blocking/delete';
+import define from '../../define';
+
+export const meta = {
+ stability: 'stable',
+
+ desc: {
+ 'ja-JP': '指定したユーザーのブロックを解除します。',
+ 'en-US': 'Unblock a user.'
+ },
+
+ limit: {
+ duration: ms('1hour'),
+ max: 100
+ },
+
+ requireCredential: true,
+
+ kind: 'following-write',
+
+ params: {
+ userId: {
+ validator: $.type(ID),
+ transform: transform,
+ desc: {
+ 'ja-JP': '対象のユーザーのID',
+ 'en-US': 'Target user ID'
+ }
+ }
+ }
+};
+
+export default define(meta, (ps, user) => new Promise(async (res, rej) => {
+ const blocker = user;
+
+ // Check if the blockee is yourself
+ if (user._id.equals(ps.userId)) {
+ return rej('blockee is yourself');
+ }
+
+ // Get blockee
+ const blockee = await User.findOne({
+ _id: ps.userId
+ }, {
+ fields: {
+ data: false,
+ 'profile': false
+ }
+ });
+
+ if (blockee === null) {
+ return rej('user not found');
+ }
+
+ // Check not blocking
+ const exist = await Blocking.findOne({
+ blockerId: blocker._id,
+ blockeeId: blockee._id
+ });
+
+ if (exist === null) {
+ return rej('already not blocking');
+ }
+
+ // Delete blocking
+ await deleteBlocking(blocker, blockee);
+
+ // Send response
+ res(await pack(blockee._id, user, {
+ detail: true
+ }));
+}));
diff --git a/src/server/api/endpoints/blocking/list.ts b/src/server/api/endpoints/blocking/list.ts
new file mode 100644
index 0000000000..e2649573d5
--- /dev/null
+++ b/src/server/api/endpoints/blocking/list.ts
@@ -0,0 +1,65 @@
+import $ from 'cafy'; import ID, { transform } from '../../../../misc/cafy-id';
+import Blocking, { packMany } from '../../../../models/blocking';
+import define from '../../define';
+
+export const meta = {
+ desc: {
+ 'ja-JP': 'ブロックしているユーザー一覧を取得します。',
+ 'en-US': 'Get blocking users.'
+ },
+
+ requireCredential: true,
+
+ kind: 'following-read',
+
+ params: {
+ limit: {
+ validator: $.num.optional.range(1, 100),
+ default: 30
+ },
+
+ sinceId: {
+ validator: $.type(ID).optional,
+ transform: transform,
+ },
+
+ untilId: {
+ validator: $.type(ID).optional,
+ transform: transform,
+ },
+ }
+};
+
+export default define(meta, (ps, me) => new Promise(async (res, rej) => {
+ // Check if both of sinceId and untilId is specified
+ if (ps.sinceId && ps.untilId) {
+ return rej('cannot set sinceId and untilId');
+ }
+
+ const query = {
+ blockerId: me._id
+ } as any;
+
+ const sort = {
+ _id: -1
+ };
+
+ if (ps.sinceId) {
+ sort._id = 1;
+ query._id = {
+ $gt: ps.sinceId
+ };
+ } else if (ps.untilId) {
+ query._id = {
+ $lt: ps.untilId
+ };
+ }
+
+ const blockings = await Blocking
+ .find(query, {
+ limit: ps.limit,
+ sort: sort
+ });
+
+ res(await packMany(blockings, me));
+}));