diff --git a/src/lib/features/project/project-read-model-type.ts b/src/lib/features/project/project-read-model-type.ts index cd9b470289..a3d2270edc 100644 --- a/src/lib/features/project/project-read-model-type.ts +++ b/src/lib/features/project/project-read-model-type.ts @@ -1,5 +1,5 @@ import type { ProjectMode } from '../../types'; -import type { IProjectQuery } from './project-store-type'; +import type { IProjectQuery, IProjectsQuery } from './project-store-type'; export type ProjectForUi = { id: string; @@ -28,7 +28,7 @@ export type ProjectForInsights = { export interface IProjectReadModel { getProjectsForAdminUi( - query?: IProjectQuery, + query?: IProjectQuery & IProjectsQuery, userId?: number, ): Promise; getProjectsForInsights( diff --git a/src/lib/features/project/project-read-model.ts b/src/lib/features/project/project-read-model.ts index 66977d94e2..b15ab461f5 100644 --- a/src/lib/features/project/project-read-model.ts +++ b/src/lib/features/project/project-read-model.ts @@ -6,7 +6,7 @@ import type { ProjectForInsights, ProjectForUi, } from './project-read-model-type'; -import type { IProjectQuery } from './project-store-type'; +import type { IProjectQuery, IProjectsQuery } from './project-store-type'; import metricsHelper from '../../util/metrics-helper'; import type EventEmitter from 'events'; import type { IProjectMembersCount } from './project-store'; @@ -79,7 +79,7 @@ export class ProjectReadModel implements IProjectReadModel { } async getProjectsForAdminUi( - query?: IProjectQuery, + query?: IProjectQuery & IProjectsQuery, userId?: number, ): Promise { const projectTimer = this.timer('getProjectsForAdminUi'); @@ -113,6 +113,9 @@ export class ProjectReadModel implements IProjectReadModel { if (query?.id) { projects = projects.where(`${TABLE}.id`, query.id); } + if (query?.ids) { + projects = projects.whereIn(`${TABLE}.id`, query.ids); + } let selectColumns = [ this.db.raw( diff --git a/src/lib/features/project/project-service.e2e.test.ts b/src/lib/features/project/project-service.e2e.test.ts index 1171f78ee5..c7e5cf9c44 100644 --- a/src/lib/features/project/project-service.e2e.test.ts +++ b/src/lib/features/project/project-service.e2e.test.ts @@ -152,6 +152,11 @@ test('should create new project', async () => { expect(project.name).toEqual(ret.name); expect(project.description).toEqual(ret.description); expect(ret.createdAt).toBeTruthy(); + + const projectsById = await projectService.getProjects({ id: 'test' }); + const projectsByIds = await projectService.getProjects({ ids: ['test'] }); + expect(projectsById).toMatchObject([{ id: 'test' }]); + expect(projectsByIds).toMatchObject([{ id: 'test' }]); }); test('should create new private project', async () => { diff --git a/src/lib/features/project/project-service.ts b/src/lib/features/project/project-service.ts index ac5f16b386..4c8272a032 100644 --- a/src/lib/features/project/project-service.ts +++ b/src/lib/features/project/project-service.ts @@ -83,6 +83,7 @@ import type { IProjectApplicationsSearchParams, IProjectEnterpriseSettingsUpdate, IProjectQuery, + IProjectsQuery, } from './project-store-type'; import type { IProjectFlagCreatorsReadModel } from './project-flag-creators-read-model.type'; import { throwExceedsLimitError } from '../../error/exceeds-limit-error'; @@ -230,13 +231,13 @@ export default class ProjectService { } async getProjects( - query?: IProjectQuery, + query?: IProjectQuery & IProjectsQuery, userId?: number, ): Promise { - const getProjects = () => - this.projectReadModel.getProjectsForAdminUi(query, userId); - - const projects = await getProjects(); + const projects = await this.projectReadModel.getProjectsForAdminUi( + query, + userId, + ); if (userId) { const projectAccess = diff --git a/src/lib/features/project/project-store-type.ts b/src/lib/features/project/project-store-type.ts index b4374f9b5c..9f3a190a27 100644 --- a/src/lib/features/project/project-store-type.ts +++ b/src/lib/features/project/project-store-type.ts @@ -48,6 +48,10 @@ export interface IProjectQuery { archived?: boolean; } +export interface IProjectsQuery { + ids?: string[]; +} + export type ProjectEnvironment = { environment: string; changeRequestEnabled?: boolean;