mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-21 02:35:23 -04:00

Signed-off-by: Yannick Bungers <git@innay.de> Signed-off-by: Tilman Vatteroth <git@tilmanvatteroth.de>
63 lines
2.7 KiB
TypeScript
63 lines
2.7 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: 2021 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
|
|
import { Reflector } from '@nestjs/core';
|
|
|
|
import { ConsoleLoggerService } from '../../logger/console-logger.service';
|
|
import { NotesService } from '../../notes/notes.service';
|
|
import { Permission } from '../../permissions/permissions.enum';
|
|
import { PermissionsService } from '../../permissions/permissions.service';
|
|
import { getNote } from './get-note.interceptor';
|
|
import { CompleteRequest } from './request.type';
|
|
|
|
/**
|
|
* This guards controller methods from access, if the user has not the appropriate permissions.
|
|
* The permissions are set via the {@link Permissions} decorator in addition to this guard.
|
|
* If the check permission is not CREATE the method needs to extract the noteIdOrAlias from
|
|
* request.params['noteIdOrAlias'] or request.headers['hedgedoc-note'] to check if the user has the permission.
|
|
*/
|
|
@Injectable()
|
|
export class PermissionsGuard implements CanActivate {
|
|
constructor(
|
|
private readonly logger: ConsoleLoggerService,
|
|
private reflector: Reflector,
|
|
private permissionsService: PermissionsService,
|
|
private noteService: NotesService,
|
|
) {
|
|
this.logger.setContext(PermissionsGuard.name);
|
|
}
|
|
|
|
async canActivate(context: ExecutionContext): Promise<boolean> {
|
|
const permissions = this.reflector.get<Permission[]>(
|
|
'permissions',
|
|
context.getHandler(),
|
|
);
|
|
// If no permissions are set this is probably an error and this guard should not let the request pass
|
|
if (!permissions) {
|
|
this.logger.error(
|
|
'Could not find permission metadata. This should never happen. If you see this, please open an issue at https://github.com/hedgedoc/hedgedoc/issues',
|
|
);
|
|
return false;
|
|
}
|
|
const request: CompleteRequest = context.switchToHttp().getRequest();
|
|
const user = request.user ?? null;
|
|
// handle CREATE permissions, as this does not need any note
|
|
if (permissions[0] === Permission.CREATE) {
|
|
return this.permissionsService.mayCreate(user);
|
|
}
|
|
// Get the note from the parameter noteIdOrAlias or the http header hedgedoc-note
|
|
// Attention: This gets the note an additional time if used in conjunction with GetNoteInterceptor or NoteHeaderInterceptor
|
|
let noteIdOrAlias = request.params['noteIdOrAlias'];
|
|
if (noteIdOrAlias === undefined)
|
|
noteIdOrAlias = request.headers['hedgedoc-note'] as string;
|
|
const note = await getNote(this.noteService, noteIdOrAlias);
|
|
return await this.permissionsService.checkPermissionOnNote(
|
|
permissions[0],
|
|
user,
|
|
note,
|
|
);
|
|
}
|
|
}
|