mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-28 14:04:43 -04:00
Merge pull request #1671 from hedgedoc/enhancement/validation_logs
This commit is contained in:
commit
9d785100e8
2 changed files with 32 additions and 8 deletions
11
src/main.ts
11
src/main.ts
|
@ -3,7 +3,7 @@
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: AGPL-3.0-only
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
*/
|
*/
|
||||||
import { LogLevel, ValidationPipe } from '@nestjs/common';
|
import { LogLevel } from '@nestjs/common';
|
||||||
import { ConfigService } from '@nestjs/config';
|
import { ConfigService } from '@nestjs/config';
|
||||||
import { NestFactory } from '@nestjs/core';
|
import { NestFactory } from '@nestjs/core';
|
||||||
import { NestExpressApplication } from '@nestjs/platform-express';
|
import { NestExpressApplication } from '@nestjs/platform-express';
|
||||||
|
@ -15,6 +15,7 @@ import { MediaConfig } from './config/media.config';
|
||||||
import { ConsoleLoggerService } from './logger/console-logger.service';
|
import { ConsoleLoggerService } from './logger/console-logger.service';
|
||||||
import { BackendType } from './media/backends/backend-type.enum';
|
import { BackendType } from './media/backends/backend-type.enum';
|
||||||
import { setupSessionMiddleware } from './utils/session';
|
import { setupSessionMiddleware } from './utils/session';
|
||||||
|
import { setupValidationPipe } from './utils/setup-pipes';
|
||||||
import { setupPrivateApiDocs, setupPublicApiDocs } from './utils/swagger';
|
import { setupPrivateApiDocs, setupPublicApiDocs } from './utils/swagger';
|
||||||
|
|
||||||
async function bootstrap(): Promise<void> {
|
async function bootstrap(): Promise<void> {
|
||||||
|
@ -55,13 +56,7 @@ async function bootstrap(): Promise<void> {
|
||||||
});
|
});
|
||||||
logger.log(`Enabling CORS for '${appConfig.rendererOrigin}'`, 'AppBootstrap');
|
logger.log(`Enabling CORS for '${appConfig.rendererOrigin}'`, 'AppBootstrap');
|
||||||
|
|
||||||
app.useGlobalPipes(
|
app.useGlobalPipes(setupValidationPipe(logger));
|
||||||
new ValidationPipe({
|
|
||||||
forbidUnknownValues: true,
|
|
||||||
skipMissingProperties: false,
|
|
||||||
transform: true,
|
|
||||||
}),
|
|
||||||
);
|
|
||||||
if (mediaConfig.backend.use === BackendType.FILESYSTEM) {
|
if (mediaConfig.backend.use === BackendType.FILESYSTEM) {
|
||||||
logger.log(
|
logger.log(
|
||||||
`Serving the local folder '${mediaConfig.backend.filesystem.uploadPath}' under '/uploads'`,
|
`Serving the local folder '${mediaConfig.backend.filesystem.uploadPath}' under '/uploads'`,
|
||||||
|
|
29
src/utils/setup-pipes.ts
Normal file
29
src/utils/setup-pipes.ts
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2021 The HedgeDoc developers (see AUTHORS file)
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
*/
|
||||||
|
import { BadRequestException, ValidationPipe } from '@nestjs/common';
|
||||||
|
|
||||||
|
import { ConsoleLoggerService } from '../logger/console-logger.service';
|
||||||
|
|
||||||
|
export function setupValidationPipe(
|
||||||
|
logger: ConsoleLoggerService,
|
||||||
|
): ValidationPipe {
|
||||||
|
return new ValidationPipe({
|
||||||
|
forbidUnknownValues: true,
|
||||||
|
skipMissingProperties: false,
|
||||||
|
transform: true,
|
||||||
|
exceptionFactory: (errors): BadRequestException => {
|
||||||
|
// strip the trailing newline for cleaner logs
|
||||||
|
const errorMessage = errors.toString().trimEnd();
|
||||||
|
logger.debug(
|
||||||
|
`Errors were encountered while validating a request:\n${errorMessage}`,
|
||||||
|
'ValidationPipe',
|
||||||
|
);
|
||||||
|
return new BadRequestException(
|
||||||
|
'Encountered an exception while validating the request.',
|
||||||
|
);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue