diff options
| author | かっこかり <67428053+kakkokari-gtyih@users.noreply.github.com> | 2025-11-23 22:41:14 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-11-23 22:41:14 +0900 |
| commit | 70fa621e22b90b1f649eb3c1d291cec1ed57b0ac (patch) | |
| tree | 340faad1772971e9ebaffb1654bb03c33a65c7c9 /packages/backend | |
| parent | chore(dev): add start:inspect command for debugging (diff) | |
| download | misskey-70fa621e22b90b1f649eb3c1d291cec1ed57b0ac.tar.gz misskey-70fa621e22b90b1f649eb3c1d291cec1ed57b0ac.tar.bz2 misskey-70fa621e22b90b1f649eb3c1d291cec1ed57b0ac.zip | |
fix(backend): `clips/my-favorites` APIをページネーションに対応させる (#16835)
* fix(backend): `clips/my-favorites` APIをページネーションに対応させる
* fix
* fix test
* fix
Diffstat (limited to 'packages/backend')
| -rw-r--r-- | packages/backend/src/server/api/endpoints/clips/my-favorites.ts | 10 | ||||
| -rw-r--r-- | packages/backend/test/e2e/clips.ts | 15 |
2 files changed, 17 insertions, 8 deletions
diff --git a/packages/backend/src/server/api/endpoints/clips/my-favorites.ts b/packages/backend/src/server/api/endpoints/clips/my-favorites.ts index 44719592d1..057b567312 100644 --- a/packages/backend/src/server/api/endpoints/clips/my-favorites.ts +++ b/packages/backend/src/server/api/endpoints/clips/my-favorites.ts @@ -5,6 +5,7 @@ import { Inject, Injectable } from '@nestjs/common'; import { Endpoint } from '@/server/api/endpoint-base.js'; +import { QueryService } from '@/core/QueryService.js'; import type { ClipFavoritesRepository } from '@/models/_.js'; import { DI } from '@/di-symbols.js'; import { ClipEntityService } from '@/core/entities/ClipEntityService.js'; @@ -30,6 +31,11 @@ export const meta = { export const paramDef = { type: 'object', properties: { + limit: { type: 'integer', minimum: 1, maximum: 100, default: 10 }, + sinceId: { type: 'string', format: 'misskey:id' }, + untilId: { type: 'string', format: 'misskey:id' }, + sinceDate: { type: 'integer' }, + untilDate: { type: 'integer' }, }, required: [], } as const; @@ -40,14 +46,16 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint- @Inject(DI.clipFavoritesRepository) private clipFavoritesRepository: ClipFavoritesRepository, + private queryService: QueryService, private clipEntityService: ClipEntityService, ) { super(meta, paramDef, async (ps, me) => { - const query = this.clipFavoritesRepository.createQueryBuilder('favorite') + const query = this.queryService.makePaginationQuery(this.clipFavoritesRepository.createQueryBuilder('favorite'), ps.sinceId, ps.untilId, ps.sinceDate, ps.untilDate) .andWhere('favorite.userId = :meId', { meId: me.id }) .leftJoinAndSelect('favorite.clip', 'clip'); const favorites = await query + .limit(ps.limit) .getMany(); return this.clipEntityService.packMany(favorites.map(x => x.clip!), me); diff --git a/packages/backend/test/e2e/clips.ts b/packages/backend/test/e2e/clips.ts index fe9a217ee8..fec83c2433 100644 --- a/packages/backend/test/e2e/clips.ts +++ b/packages/backend/test/e2e/clips.ts @@ -506,10 +506,10 @@ describe('クリップ', () => { }); }; - const myFavorites = async (request: Partial<ApiRequest<'clips/my-favorites'>> = {}): Promise<Misskey.entities.Clip[]> => { + const myFavorites = async (parameters: Misskey.entities.ClipsMyFavoritesRequest, request: Partial<ApiRequest<'clips/my-favorites'>> = {}): Promise<Misskey.entities.Clip[]> => { return successfulApiCall({ endpoint: 'clips/my-favorites', - parameters: {}, + parameters, user: alice, ...request, }); @@ -562,8 +562,9 @@ describe('クリップ', () => { await favorite({ clipId: clip.id }); } - // pagenationはない。全部一気にとれる。 - const favorited = await myFavorites(); + const favorited = await myFavorites({ + limit: 30, + }); assert.strictEqual(favorited.length, clips.length); for (const clip of favorited) { assert.strictEqual(clip.favoritedCount, 1); @@ -617,7 +618,7 @@ describe('クリップ', () => { const clip = await show({ clipId: aliceClip.id }); assert.strictEqual(clip.favoritedCount, 0); assert.strictEqual(clip.isFavorited, false); - assert.deepStrictEqual(await myFavorites(), []); + assert.deepStrictEqual(await myFavorites({}), []); }); test.each([ @@ -651,13 +652,13 @@ describe('クリップ', () => { test('を取得できる。', async () => { await favorite({ clipId: aliceClip.id }); - const favorited = await myFavorites(); + const favorited = await myFavorites({}); assert.deepStrictEqual(favorited, [await show({ clipId: aliceClip.id })]); }); test('を取得したとき他人のお気に入りは含まない。', async () => { await favorite({ clipId: aliceClip.id }); - const favorited = await myFavorites({ user: bob }); + const favorited = await myFavorites({}, { user: bob }); assert.deepStrictEqual(favorited, []); }); }); |