From cdbf1bc3d0b58eb7e0a0f7d10f945e033d58800c Mon Sep 17 00:00:00 2001 From: Muntasir Mallik <73852736+muntaxir4@users.noreply.github.com> Date: Sat, 7 Dec 2024 10:29:59 +0530 Subject: [PATCH] fix(api): Enable global project access (#580) --- apps/api/src/project/project.e2e.spec.ts | 37 ++++++++++--------- .../src/project/service/project.service.ts | 13 ++++--- 2 files changed, 28 insertions(+), 22 deletions(-) diff --git a/apps/api/src/project/project.e2e.spec.ts b/apps/api/src/project/project.e2e.spec.ts index 11d24775..31009209 100644 --- a/apps/api/src/project/project.e2e.spec.ts +++ b/apps/api/src/project/project.e2e.spec.ts @@ -867,23 +867,26 @@ describe('Project Controller Tests', () => { await prisma.workspace.deleteMany() }) - // it('should allow any user to access a global project', async () => { - // const response = await app.inject({ - // method: 'GET', - // url: `/project/${globalProject.slug}`, - // headers: { - // 'x-e2e-user-email': user2.email // user2 is not a member of workspace1 - // } - // }) - - // expect(response.statusCode).toBe(200) - // expect(response.json()).toEqual({ - // ...globalProject, - // lastUpdatedById: user1.id, - // createdAt: expect.any(String), - // updatedAt: expect.any(String) - // }) - // }) + it('should allow any user to access a global project', async () => { + const response = await app.inject({ + method: 'GET', + url: `/project/${globalProject.slug}`, + headers: { + 'x-e2e-user-email': user2.email // user2 is not a member of workspace1 + } + }) + + expect(response.statusCode).toBe(200) + expect(response.json()).toEqual({ + ...globalProject, + lastUpdatedById: user1.id, + environmentCount: 1, + secretCount: 0, + variableCount: 0, + createdAt: expect.any(String), + updatedAt: expect.any(String) + }) + }) it('should allow workspace members with READ_PROJECT to access an internal project', async () => { const response = await app.inject({ diff --git a/apps/api/src/project/service/project.service.ts b/apps/api/src/project/service/project.service.ts index a56fc81a..ab14e9c2 100644 --- a/apps/api/src/project/service/project.service.ts +++ b/apps/api/src/project/service/project.service.ts @@ -1221,11 +1221,14 @@ export class ProjectService { await this.authorityCheckerService.checkAuthorityOverEnvironment({ userId: user.id, entity: { slug: env.slug }, - authorities: [ - Authority.READ_ENVIRONMENT, - Authority.READ_SECRET, - Authority.READ_VARIABLE - ], + authorities: + project.accessLevel == ProjectAccessLevel.GLOBAL + ? [] + : [ + Authority.READ_ENVIRONMENT, + Authority.READ_SECRET, + Authority.READ_VARIABLE + ], prisma: this.prisma }) if (hasRequiredPermission) {