From 17d62b689df22af66486cb50e9de82d745b129ce Mon Sep 17 00:00:00 2001 From: syuilo Date: Sun, 29 Nov 2020 12:34:39 +0900 Subject: wip --- src/server/api/endpoints/users/pages.ts | 40 +++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 src/server/api/endpoints/users/pages.ts (limited to 'src/server/api/endpoints/users/pages.ts') diff --git a/src/server/api/endpoints/users/pages.ts b/src/server/api/endpoints/users/pages.ts new file mode 100644 index 0000000000..706a2e115b --- /dev/null +++ b/src/server/api/endpoints/users/pages.ts @@ -0,0 +1,40 @@ +import $ from 'cafy'; +import { ID } from '../../../../misc/cafy-id'; +import define from '../../define'; +import { Pages } from '../../../../models'; +import { makePaginationQuery } from '../../common/make-pagination-query'; + +export const meta = { + tags: ['users', 'pages'], + + params: { + userId: { + validator: $.type(ID), + }, + + limit: { + validator: $.optional.num.range(1, 100), + default: 10 + }, + + sinceId: { + validator: $.optional.type(ID), + }, + + untilId: { + validator: $.optional.type(ID), + }, + } +}; + +export default define(meta, async (ps, user) => { + const query = makePaginationQuery(Pages.createQueryBuilder('page'), ps.sinceId, ps.untilId) + .andWhere(`page.userId = :userId`, { userId: ps.userId }) + .andWhere('page.visibility = \'public\''); + + const pages = await query + .take(ps.limit!) + .getMany(); + + return await Pages.packMany(pages); +}); -- cgit v1.2.3-freya