Skip to content

Commit

Permalink
fixed
Browse files Browse the repository at this point in the history
  • Loading branch information
rajdip-b committed Dec 3, 2024
1 parent 3024f3f commit cbfbcd3
Show file tree
Hide file tree
Showing 16 changed files with 3,569 additions and 613 deletions.
2,170 changes: 2,111 additions & 59 deletions apps/api/package-lock.json

Large diffs are not rendered by default.

22 changes: 19 additions & 3 deletions apps/api/src/project/project.e2e.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -467,6 +467,22 @@ describe('Project Controller Tests', () => {

expect(response.statusCode).toBe(401)
})

it('should fetch correct counts of environments, variables, and secrets for projects in a workspace', async () => {
const response = await app.inject({
method: 'GET',
url: `/project/${project1.slug}`,
headers: {
'x-e2e-user-email': user1.email
}
})

expect(response.statusCode).toBe(200)
const project = response.json().items[0]
expect(project.environmentCount).toEqual(2)
expect(project.variableCount).toEqual(2)
expect(project.secretCount).toEqual(2)
})
})

describe('Get All Projects Tests', () => {
Expand Down Expand Up @@ -605,9 +621,9 @@ describe('Project Controller Tests', () => {
expect(response.json().items.length).toEqual(1)

const project = response.json().items[0]
expect(project.totalEnvironmentsOfProject).toEqual(2)
expect(project.totalVariablesOfProject).toEqual(2)
expect(project.totalSecretsOfProject).toEqual(2)
expect(project.environmentCount).toEqual(2)
expect(project.variableCount).toEqual(2)
expect(project.secretCount).toEqual(2)
// Verify project details
expect(project.name).toEqual('Project4')
expect(project.description).toEqual(
Expand Down
6 changes: 6 additions & 0 deletions apps/api/src/project/project.types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,9 @@ import { Project, Secret } from '@prisma/client'
export interface ProjectWithSecrets extends Project {
secrets: Secret[]
}

export interface ProjectWithCounts extends Partial<Project> {
secretCount: number
variableCount: number
environmentCount: number
}
142 changes: 73 additions & 69 deletions apps/api/src/project/service/project.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ import { CreateProject } from '../dto/create.project/create.project'
import { UpdateProject } from '../dto/update.project/update.project'
import { PrismaService } from '@/prisma/prisma.service'
import { v4 } from 'uuid'
import { ProjectWithSecrets } from '../project.types'
import { ProjectWithCounts, ProjectWithSecrets } from '../project.types'
import { AuthorityCheckerService } from '@/common/authority-checker.service'
import { ForkProject } from '../dto/fork.project/fork.project'
import { paginate } from '@/common/paginate'
Expand Down Expand Up @@ -741,7 +741,10 @@ export class ProjectService {

delete project.secrets

return project
return await this.countEnvironmentsVariablesAndSecretsInProject(
project,
user
)
}

/**
Expand Down Expand Up @@ -822,73 +825,9 @@ export class ProjectService {
).map((project) => excludeFields(project, 'privateKey', 'publicKey'))

const items = await Promise.all(
projects.map(async (project) => {
let totalEnvironmentsOfProject = 0
let totalVariablesOfProject = 0
let totalSecretsOfProject = 0
// When we later implement RBAC for environments, we would need to updated
// this code to only include environments like we do while fetching projects.

// What would be even better is, we should fetch environments directly. And then,
// accumulate the projects into a set of projects. And then, return that set along
// with the required data.
const allEnvs = await this.prisma.environment.findMany({
where: { projectId: project.id }
})

// This entire block will become invalid after RBAC for environments are implemented
const envPromises = allEnvs.map(async (env) => {
const hasRequiredPermission =
await this.authorityCheckerService.checkAuthorityOverEnvironment({
userId: user.id,
entity: { slug: env.slug },
authorities: [
Authority.READ_ENVIRONMENT,
Authority.READ_SECRET,
Authority.READ_VARIABLE
],
prisma: this.prisma
})
if (hasRequiredPermission) {
totalEnvironmentsOfProject += 1

const fetchSecretCount = this.prisma.secret.count({
where: {
projectId: project.id,
versions: { some: { environmentId: env.id } }
}
})

const fetchVariableCount = this.prisma.variable.count({
where: {
projectId: project.id,
versions: { some: { environmentId: env.id } }
}
})

return this.prisma.$transaction([
fetchSecretCount,
fetchVariableCount
])
}
return [0, 0]
})
const counts = await Promise.all(envPromises)
totalSecretsOfProject = counts.reduce(
(sum, [secretCount]) => sum + secretCount,
0
)
totalVariablesOfProject = counts.reduce(
(sum, [, variableCount]) => sum + variableCount,
0
)
return {
...project,
totalEnvironmentsOfProject,
totalVariablesOfProject,
totalSecretsOfProject
}
})
projects.map(async (project) =>
this.countEnvironmentsVariablesAndSecretsInProject(project, user)
)
)

//calculate metadata
Expand Down Expand Up @@ -1258,4 +1197,69 @@ export class ProjectService {

return { txs, newPrivateKey, newPublicKey }
}

private async countEnvironmentsVariablesAndSecretsInProject(
project: Partial<Project>,
user: User
): Promise<ProjectWithCounts> {
let environmentCount = 0
let variableCount = 0
let secretCount = 0
// When we later implement RBAC for environments, we would need to updated
// this code to only include environments like we do while fetching projects.

// What would be even better is, we should fetch environments directly. And then,
// accumulate the projects into a set of projects. And then, return that set along
// with the required data.
const allEnvs = await this.prisma.environment.findMany({
where: { projectId: project.id }
})

// This entire block will become invalid after RBAC for environments are implemented
const envPromises = allEnvs.map(async (env) => {
const hasRequiredPermission =
await this.authorityCheckerService.checkAuthorityOverEnvironment({
userId: user.id,
entity: { slug: env.slug },
authorities: [
Authority.READ_ENVIRONMENT,
Authority.READ_SECRET,
Authority.READ_VARIABLE
],
prisma: this.prisma
})
if (hasRequiredPermission) {
environmentCount += 1

const fetchSecretCount = this.prisma.secret.count({
where: {
projectId: project.id,
versions: { some: { environmentId: env.id } }
}
})

const fetchVariableCount = this.prisma.variable.count({
where: {
projectId: project.id,
versions: { some: { environmentId: env.id } }
}
})

return this.prisma.$transaction([fetchSecretCount, fetchVariableCount])
}
return [0, 0]
})
const counts = await Promise.all(envPromises)
secretCount = counts.reduce((sum, [secretCount]) => sum + secretCount, 0)
variableCount = counts.reduce(
(sum, [, variableCount]) => sum + variableCount,
0
)
return {
...project,
environmentCount,
variableCount,
secretCount
}
}
}
8 changes: 4 additions & 4 deletions apps/platform/.eslintrc.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -12,15 +12,15 @@ module.exports = {
'@typescript-eslint/explicit-module-boundary-types': 'off',
'@typescript-eslint/no-explicit-any': 'off',
'@typescript-eslint/no-unused-vars': ['warn'],
'@typescript-eslint/no-unsafe-argument': 'off',
'@typescript-eslint/no-unsafe-assignment': 'off',
'@typescript-eslint/no-unsafe-call': 'off',
'@typescript-eslint/no-unsafe-return': 'off',
'@typescript-eslint/no-unsafe-member-access': 'off',
'@typescript-eslint/space-before-function-paren': 'off',
'@typescript-eslint/strict-boolean-expressions': 'off',
'@typescript-eslint/prefer-nullish-coalescing': 'off',
'space-before-function-paren': 'off',
'@typescript-eslint/member-delimiter-style': 'off'
'@typescript-eslint/member-delimiter-style': 'off',
'@typescript-eslint/no-confusing-void-expression': 'off',
'@typescript-eslint/no-floating-promises': 'off',
'@typescript-eslint/no-misused-promises': 'off'
}
}
2 changes: 1 addition & 1 deletion apps/platform/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
"dev": "env-cmd -f ../../.env --silent next dev -p 3025",
"build": "next build",
"start": "next start",
"lint": "next lint --fix"
"lint": "eslint \"src/**/*.ts\" --fix --config .eslintrc.cjs"
},
"dependencies": {
"@radix-ui/react-accordion": "^1.2.0",
Expand Down
Loading

0 comments on commit cbfbcd3

Please sign in to comment.