Files
speckle-server/packages/server/modules/workspaces/repositories/workspaceJoinRequests.ts
T
Alessandro Magionami 6d0f08b7b5 feat(workspaces): approve join request (#3833)
* feat(workspaces): approve join request

* chore(workspaces): add missing dep to resolver call

* chore(workspaces): use commandFactory
2025-01-16 16:46:59 +01:00

105 lines
3.1 KiB
TypeScript

import {
CreateWorkspaceJoinRequest,
GetWorkspaceJoinRequest,
UpdateWorkspaceJoinRequestStatus
} from '@/modules/workspaces/domain/operations'
import {
WorkspaceJoinRequest,
WorkspaceJoinRequestStatus
} from '@/modules/workspacesCore/domain/types'
import {
WorkspaceAcl,
WorkspaceJoinRequests
} from '@/modules/workspacesCore/helpers/db'
import { Roles } from '@speckle/shared'
import { Knex } from 'knex'
const tables = {
workspaceJoinRequests: (db: Knex) =>
db<WorkspaceJoinRequest>(WorkspaceJoinRequests.name)
}
export const createWorkspaceJoinRequestFactory =
({ db }: { db: Knex }): CreateWorkspaceJoinRequest =>
async ({ workspaceJoinRequest }) => {
const res = await tables.workspaceJoinRequests(db).insert(workspaceJoinRequest, '*')
return res[0]
}
export const updateWorkspaceJoinRequestStatusFactory =
({ db }: { db: Knex }): UpdateWorkspaceJoinRequestStatus =>
async ({ workspaceId, userId, status }) => {
return await tables
.workspaceJoinRequests(db)
.insert({ workspaceId, userId, status })
.onConflict(['workspaceId', 'userId'])
.merge(['status'])
}
export const getWorkspaceJoinRequestFactory =
({ db }: { db: Knex }): GetWorkspaceJoinRequest =>
async ({ workspaceId, userId, status }) => {
const query = tables
.workspaceJoinRequests(db)
.where(WorkspaceJoinRequests.col.workspaceId, workspaceId)
.where(WorkspaceJoinRequests.col.userId, userId)
if (status) {
query.andWhere(WorkspaceJoinRequests.col.status, status)
}
return await query.first()
}
type WorkspaceJoinRequestFilter = {
workspaceId: string
status?: WorkspaceJoinRequestStatus | null
userId: string
}
const adminWorkspaceJoinRequestsBaseQueryFactory =
(db: Knex) => (filter: WorkspaceJoinRequestFilter) => {
const query = tables
.workspaceJoinRequests(db)
.innerJoin(
WorkspaceAcl.name,
WorkspaceAcl.col.workspaceId,
WorkspaceJoinRequests.col.workspaceId
)
.where(WorkspaceAcl.col.role, Roles.Workspace.Admin)
.where(WorkspaceAcl.col.userId, filter.userId)
.where(WorkspaceJoinRequests.col.workspaceId, filter.workspaceId)
if (filter.status) query.andWhere(WorkspaceJoinRequests.col.status, filter.status)
return query
}
export const getAdminWorkspaceJoinRequestsFactory =
({ db }: { db: Knex }) =>
async ({
filter,
cursor,
limit
}: {
filter: WorkspaceJoinRequestFilter
cursor?: string
limit: number
}) => {
const query = adminWorkspaceJoinRequestsBaseQueryFactory(db)(filter)
if (cursor) {
query.andWhere(WorkspaceJoinRequests.col.createdAt, '<', cursor)
}
return await query
.select<WorkspaceJoinRequest[]>(WorkspaceJoinRequests.cols)
.orderBy(WorkspaceJoinRequests.col.createdAt, 'desc')
.limit(limit)
}
export const countAdminWorkspaceJoinRequestsFactory =
({ db }: { db: Knex }) =>
async ({ filter }: { filter: WorkspaceJoinRequestFilter }) => {
const query = adminWorkspaceJoinRequestsBaseQueryFactory(db)(filter)
const [res] = await query.count()
return parseInt(res.count.toString())
}