mirror of
https://github.com/n8n-io/n8n.git
synced 2026-06-01 09:17:08 +02:00
83 lines
2.1 KiB
TypeScript
83 lines
2.1 KiB
TypeScript
import { CreateRoleDto, RoleGetQueryDto, RoleListQueryDto, UpdateRoleDto } from '@n8n/api-types';
|
|
import { LICENSE_FEATURES } from '@n8n/constants';
|
|
import { AuthenticatedRequest } from '@n8n/db';
|
|
import {
|
|
Body,
|
|
Delete,
|
|
Get,
|
|
GlobalScope,
|
|
Licensed,
|
|
Param,
|
|
Patch,
|
|
Post,
|
|
Query,
|
|
RestController,
|
|
} from '@n8n/decorators';
|
|
import { Role as RoleDTO } from '@n8n/permissions';
|
|
|
|
import { RoleService } from '@/services/role.service';
|
|
|
|
@RestController('/roles')
|
|
export class RoleController {
|
|
constructor(private readonly roleService: RoleService) {}
|
|
|
|
@Get('/')
|
|
async getAllRoles(
|
|
_req: AuthenticatedRequest,
|
|
_res: Response,
|
|
@Query query: RoleListQueryDto,
|
|
): Promise<Record<string, RoleDTO[]>> {
|
|
const allRoles = await this.roleService.getAllRoles(query.withUsageCount);
|
|
return {
|
|
global: allRoles.filter((r) => r.roleType === 'global'),
|
|
project: allRoles.filter((r) => r.roleType === 'project'),
|
|
credential: allRoles.filter((r) => r.roleType === 'credential'),
|
|
workflow: allRoles.filter((r) => r.roleType === 'workflow'),
|
|
};
|
|
}
|
|
|
|
@Get('/:slug')
|
|
async getRoleBySlug(
|
|
_req: AuthenticatedRequest,
|
|
_res: Response,
|
|
@Param('slug') slug: string,
|
|
@Query query: RoleGetQueryDto,
|
|
): Promise<RoleDTO> {
|
|
return await this.roleService.getRole(slug, query.withUsageCount);
|
|
}
|
|
|
|
@Patch('/:slug')
|
|
@GlobalScope('role:manage')
|
|
@Licensed(LICENSE_FEATURES.CUSTOM_ROLES)
|
|
async updateRole(
|
|
_req: AuthenticatedRequest,
|
|
_res: Response,
|
|
@Param('slug') slug: string,
|
|
@Body updateRole: UpdateRoleDto,
|
|
): Promise<RoleDTO> {
|
|
return await this.roleService.updateCustomRole(slug, updateRole);
|
|
}
|
|
|
|
@Delete('/:slug')
|
|
@GlobalScope('role:manage')
|
|
@Licensed(LICENSE_FEATURES.CUSTOM_ROLES)
|
|
async deleteRole(
|
|
_req: AuthenticatedRequest,
|
|
_res: Response,
|
|
@Param('slug') slug: string,
|
|
): Promise<RoleDTO> {
|
|
return await this.roleService.removeCustomRole(slug);
|
|
}
|
|
|
|
@Post('/')
|
|
@GlobalScope('role:manage')
|
|
@Licensed(LICENSE_FEATURES.CUSTOM_ROLES)
|
|
async createRole(
|
|
_req: AuthenticatedRequest,
|
|
_res: Response,
|
|
@Body createRole: CreateRoleDto,
|
|
): Promise<RoleDTO> {
|
|
return await this.roleService.createCustomRole(createRole);
|
|
}
|
|
}
|