Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(api): Replace the id with slug in the global-search service #455

Merged
merged 5 commits into from
Sep 22, 2024
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
101 changes: 55 additions & 46 deletions apps/api/src/workspace/service/workspace.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import {
Environment,
EventSource,
EventType,
Prisma,
Project,
ProjectAccessLevel,
Secret,
Expand Down Expand Up @@ -434,16 +435,10 @@ export class WorkspaceService {
searchTerm: string
): Promise<Partial<Project>[]> {
// Fetch projects where user has READ_PROJECT authority and match search term
return this.prisma.project.findMany({
where: {
id: { in: projectIds },
OR: [
{ name: { contains: searchTerm, mode: 'insensitive' } },
{ description: { contains: searchTerm, mode: 'insensitive' } }
]
},
select: { id: true, name: true, description: true }
})
return this.createSearchQuery('Project', projectIds, searchTerm, [
'name',
'description'
])
}

/**
Expand All @@ -457,18 +452,10 @@ export class WorkspaceService {
projectIds: string[],
searchTerm: string
): Promise<Partial<Environment>[]> {
return this.prisma.environment.findMany({
where: {
project: {
id: { in: projectIds }
},
OR: [
{ name: { contains: searchTerm, mode: 'insensitive' } },
{ description: { contains: searchTerm, mode: 'insensitive' } }
]
},
select: { id: true, name: true, description: true }
})
return this.createSearchQuery('Environment', projectIds, searchTerm, [
'name',
'description'
])
}

/**
Expand All @@ -483,18 +470,10 @@ export class WorkspaceService {
searchTerm: string
): Promise<Partial<Secret>[]> {
// Fetch secrets associated with projects user has READ_SECRET authority on
return await this.prisma.secret.findMany({
where: {
project: {
id: { in: projectIds }
},
OR: [
{ name: { contains: searchTerm, mode: 'insensitive' } },
{ note: { contains: searchTerm, mode: 'insensitive' } }
]
},
select: { id: true, name: true, note: true }
})
return this.createSearchQuery('Secret', projectIds, searchTerm, [
'name',
'note'
])
}

/**
Expand All @@ -508,18 +487,10 @@ export class WorkspaceService {
projectIds: string[],
searchTerm: string
): Promise<Partial<Variable>[]> {
return this.prisma.variable.findMany({
where: {
project: {
id: { in: projectIds }
},
OR: [
{ name: { contains: searchTerm, mode: 'insensitive' } },
{ note: { contains: searchTerm, mode: 'insensitive' } }
]
},
select: { id: true, name: true, note: true }
})
return this.createSearchQuery('Variable', projectIds, searchTerm, [
'name',
'note'
])
}

/**
Expand All @@ -542,4 +513,42 @@ export class WorkspaceService {
})) > 0
)
}

/**
* Creates a search query object based on provided project IDs and search term.
* @param model The Prisma model name (e.g., 'Project', 'Environment')
* @param projectIds The IDs of projects to query
* @param searchTerm The search term to query by
* @param fields The fields to apply the search term in the query
* @returns The prisma query object
* @private
*/
private createSearchQuery<T>(
rajdip-b marked this conversation as resolved.
Show resolved Hide resolved
model: Prisma.ModelName,
projectIds: string[],
searchTerm: string,
fields: Array<Exclude<keyof T, 'slug'>>
): Promise<Partial<T>[]> {
const idQueryFilter =
model === 'Project'
? { id: { in: projectIds } }
: { projectId: { in: projectIds } }

const searchConditions = fields.map((field) => ({
[field]: { contains: searchTerm, mode: 'insensitive' }
}))

const selectFields = Object.fromEntries([
['slug', true],
...fields.map((field) => [field, true])
])

return this.prisma[model].findMany({
where: {
...idQueryFilter,
OR: searchConditions
},
select: selectFields
})
}
}
8 changes: 4 additions & 4 deletions packages/api-client/src/types/workspace.types.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -96,22 +96,22 @@ export interface GlobalSearchRequest {

export interface GlobalSearchResponse {
projects: {
id: string
slug: string
name: string
description: string
}[]
environments: {
id: string
slug: string
name: string
description: string
}[]
secrets: {
id: string
slug: string
name: string
note: string
}[]
variables: {
id: string
slug: string
name: string
note: string
}[]
Expand Down
Loading