mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-13 06:34:39 -04:00
53 lines
1.4 KiB
TypeScript
53 lines
1.4 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: 2021 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
import {
|
|
Body,
|
|
Controller,
|
|
Delete,
|
|
Get,
|
|
HttpCode,
|
|
Param,
|
|
Post,
|
|
} from '@nestjs/common';
|
|
import { ConsoleLoggerService } from '../../../logger/console-logger.service';
|
|
import { AuthTokenDto } from '../../../auth/auth-token.dto';
|
|
import { AuthTokenWithSecretDto } from '../../../auth/auth-token-with-secret.dto';
|
|
import { AuthService } from '../../../auth/auth.service';
|
|
|
|
@Controller('tokens')
|
|
export class TokensController {
|
|
constructor(
|
|
private readonly logger: ConsoleLoggerService,
|
|
private authService: AuthService,
|
|
) {
|
|
this.logger.setContext(TokensController.name);
|
|
}
|
|
|
|
@Get()
|
|
async getUserTokens(): Promise<AuthTokenDto[]> {
|
|
// ToDo: Get real userName
|
|
return (
|
|
await this.authService.getTokensByUsername('hardcoded')
|
|
).map((token) => this.authService.toAuthTokenDto(token));
|
|
}
|
|
|
|
@Post()
|
|
async postTokenRequest(
|
|
@Body('label') label: string,
|
|
@Body('until') until: number,
|
|
): Promise<AuthTokenWithSecretDto> {
|
|
// ToDo: Get real userName
|
|
return this.authService.createTokenForUser('hardcoded', label, until);
|
|
}
|
|
|
|
@Delete('/:keyId')
|
|
@HttpCode(204)
|
|
async deleteToken(@Param('keyId') keyId: string) {
|
|
// ToDo: Get real userName
|
|
return this.authService.removeToken('hardcoded', keyId);
|
|
}
|
|
}
|