diff options
Diffstat (limited to 'src/server/api/endpoints/blocking')
| -rw-r--r-- | src/server/api/endpoints/blocking/create.ts | 76 | ||||
| -rw-r--r-- | src/server/api/endpoints/blocking/delete.ts | 76 | ||||
| -rw-r--r-- | src/server/api/endpoints/blocking/list.ts | 65 |
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)); +})); |