diff options
Diffstat (limited to 'src/server/api')
| -rw-r--r-- | src/server/api/endpoints/blocking/list.ts | 64 | ||||
| -rw-r--r-- | src/server/api/endpoints/mute/list.ts | 80 |
2 files changed, 99 insertions, 45 deletions
diff --git a/src/server/api/endpoints/blocking/list.ts b/src/server/api/endpoints/blocking/list.ts new file mode 100644 index 0000000000..a0bef38b58 --- /dev/null +++ b/src/server/api/endpoints/blocking/list.ts @@ -0,0 +1,64 @@ +import $ from 'cafy'; import ID from '../../../../misc/cafy-id'; +import Blocking, { packMany } from '../../../../models/blocking'; +import { ILocalUser } from '../../../../models/user'; +import getParams from '../../get-params'; + +export const meta = { + desc: { + 'ja-JP': 'ブロックしているユーザー一覧を取得します。', + 'en-US': 'Get blocking users.' + }, + + requireCredential: true, + + kind: 'following-read', + + params: { + limit: $.num.optional.range(1, 100).note({ + default: 30 + }), + + sinceId: $.type(ID).optional.note({ + }), + + untilId: $.type(ID).optional.note({ + }), + } +}; + +export default (params: any, me: ILocalUser) => new Promise(async (res, rej) => { + const [ps, psErr] = getParams(meta, params); + if (psErr) return rej(psErr); + + // 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)); +}); diff --git a/src/server/api/endpoints/mute/list.ts b/src/server/api/endpoints/mute/list.ts index 387b2396f5..4653877621 100644 --- a/src/server/api/endpoints/mute/list.ts +++ b/src/server/api/endpoints/mute/list.ts @@ -1,7 +1,7 @@ import $ from 'cafy'; import ID from '../../../../misc/cafy-id'; -import Mute from '../../../../models/mute'; -import { pack, ILocalUser } from '../../../../models/user'; -import { getFriendIds } from '../../common/get-friends'; +import Mute, { packMany } from '../../../../models/mute'; +import { ILocalUser } from '../../../../models/user'; +import getParams from '../../get-params'; export const meta = { desc: { @@ -11,64 +11,54 @@ export const meta = { requireCredential: true, - kind: 'account/read' + kind: 'account/read', + + params: { + limit: $.num.optional.range(1, 100).note({ + default: 30 + }), + + sinceId: $.type(ID).optional.note({ + }), + + untilId: $.type(ID).optional.note({ + }), + } }; export default (params: any, me: ILocalUser) => new Promise(async (res, rej) => { - // Get 'iknow' parameter - const [iknow = false, iknowErr] = $.bool.optional.get(params.iknow); - if (iknowErr) return rej('invalid iknow param'); - - // Get 'limit' parameter - const [limit = 30, limitErr] = $.num.optional.range(1, 100).get(params.limit); - if (limitErr) return rej('invalid limit param'); + const [ps, psErr] = getParams(meta, params); + if (psErr) return rej(psErr); - // Get 'cursor' parameter - const [cursor = null, cursorErr] = $.type(ID).optional.get(params.cursor); - if (cursorErr) return rej('invalid cursor param'); + // Check if both of sinceId and untilId is specified + if (ps.sinceId && ps.untilId) { + return rej('cannot set sinceId and untilId'); + } - // Construct query const query = { - muterId: me._id, - deletedAt: { $exists: false } + muterId: me._id } as any; - if (iknow) { - // Get my friends - const myFriends = await getFriendIds(me._id); + const sort = { + _id: -1 + }; - query.muteeId = { - $in: myFriends + if (ps.sinceId) { + sort._id = 1; + query._id = { + $gt: ps.sinceId }; - } - - // カーソルが指定されている場合 - if (cursor) { + } else if (ps.untilId) { query._id = { - $lt: cursor + $lt: ps.untilId }; } - // Get mutes const mutes = await Mute .find(query, { - limit: limit + 1, - sort: { _id: -1 } + limit: ps.limit, + sort: sort }); - // 「次のページ」があるかどうか - const inStock = mutes.length === limit + 1; - if (inStock) { - mutes.pop(); - } - - // Serialize - const users = await Promise.all(mutes.map(async m => - await pack(m.muteeId, me, { detail: true }))); - - // Response - res({ - users: users, - next: inStock ? mutes[mutes.length - 1]._id : null, - }); + res(await packMany(mutes, me)); }); |