2021-01-05 21:12:38 +00:00
|
|
|
/*
|
2021-01-06 20:36:07 +00:00
|
|
|
* SPDX-FileCopyrightText: 2021 The HedgeDoc developers (see AUTHORS file)
|
2021-01-05 21:12:38 +00:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
2021-09-23 20:05:57 +00:00
|
|
|
import { LogLevel } from '@nestjs/common';
|
2020-10-30 21:35:57 +00:00
|
|
|
import { ConfigService } from '@nestjs/config';
|
2020-07-25 18:26:10 +00:00
|
|
|
import { NestFactory } from '@nestjs/core';
|
2020-10-24 09:32:23 +00:00
|
|
|
import { NestExpressApplication } from '@nestjs/platform-express';
|
2021-08-29 16:45:46 +00:00
|
|
|
|
2020-07-25 18:26:10 +00:00
|
|
|
import { AppModule } from './app.module';
|
2020-10-30 21:35:57 +00:00
|
|
|
import { AppConfig } from './config/app.config';
|
2021-08-31 11:36:13 +00:00
|
|
|
import { AuthConfig } from './config/auth.config';
|
2021-01-15 15:57:04 +00:00
|
|
|
import { MediaConfig } from './config/media.config';
|
2021-04-02 17:08:30 +00:00
|
|
|
import { ConsoleLoggerService } from './logger/console-logger.service';
|
2021-08-29 16:45:46 +00:00
|
|
|
import { BackendType } from './media/backends/backend-type.enum';
|
2021-09-23 20:36:13 +00:00
|
|
|
import { setupFrontendProxy } from './utils/frontend-integration';
|
2021-08-31 11:36:13 +00:00
|
|
|
import { setupSessionMiddleware } from './utils/session';
|
2021-09-23 20:05:57 +00:00
|
|
|
import { setupValidationPipe } from './utils/setup-pipes';
|
2021-08-29 16:45:46 +00:00
|
|
|
import { setupPrivateApiDocs, setupPublicApiDocs } from './utils/swagger';
|
2020-07-21 19:24:56 +00:00
|
|
|
|
2021-02-27 16:41:32 +00:00
|
|
|
async function bootstrap(): Promise<void> {
|
2021-04-02 17:08:30 +00:00
|
|
|
const app = await NestFactory.create<NestExpressApplication>(AppModule, {
|
|
|
|
logger: ['error', 'warn', 'log'] as LogLevel[],
|
2021-07-15 18:21:42 +00:00
|
|
|
bufferLogs: true,
|
2021-04-02 17:08:30 +00:00
|
|
|
});
|
|
|
|
const logger = await app.resolve(ConsoleLoggerService);
|
2020-09-27 19:48:42 +00:00
|
|
|
logger.log('Switching logger', 'AppBootstrap');
|
|
|
|
app.useLogger(logger);
|
2020-10-30 21:35:57 +00:00
|
|
|
const configService = app.get(ConfigService);
|
|
|
|
const appConfig = configService.get<AppConfig>('appConfig');
|
2021-08-31 11:36:13 +00:00
|
|
|
const authConfig = configService.get<AuthConfig>('authConfig');
|
2021-01-15 15:57:04 +00:00
|
|
|
const mediaConfig = configService.get<MediaConfig>('mediaConfig');
|
2020-07-26 14:53:43 +00:00
|
|
|
|
2021-08-31 11:36:13 +00:00
|
|
|
if (!appConfig || !authConfig || !mediaConfig) {
|
2021-04-29 14:22:01 +00:00
|
|
|
logger.error('Could not initialize config, aborting.', 'AppBootstrap');
|
|
|
|
process.exit(1);
|
|
|
|
}
|
|
|
|
|
2021-01-25 22:11:56 +00:00
|
|
|
setupPublicApiDocs(app);
|
2021-04-02 15:40:44 +00:00
|
|
|
logger.log(
|
|
|
|
`Serving OpenAPI docs for public api under '/apidoc'`,
|
|
|
|
'AppBootstrap',
|
|
|
|
);
|
2021-01-25 22:11:56 +00:00
|
|
|
if (process.env.NODE_ENV === 'development') {
|
|
|
|
setupPrivateApiDocs(app);
|
2021-04-02 15:40:44 +00:00
|
|
|
logger.log(
|
|
|
|
`Serving OpenAPI docs for private api under '/private/apidoc'`,
|
|
|
|
'AppBootstrap',
|
|
|
|
);
|
2021-09-23 20:36:13 +00:00
|
|
|
setupFrontendProxy(app, logger);
|
2021-01-25 22:11:56 +00:00
|
|
|
}
|
2020-07-26 14:53:43 +00:00
|
|
|
|
2021-08-31 11:36:13 +00:00
|
|
|
setupSessionMiddleware(app, authConfig);
|
|
|
|
|
2021-04-02 15:36:51 +00:00
|
|
|
app.enableCors({
|
|
|
|
origin: appConfig.rendererOrigin,
|
|
|
|
});
|
|
|
|
logger.log(`Enabling CORS for '${appConfig.rendererOrigin}'`, 'AppBootstrap');
|
|
|
|
|
2021-09-23 20:05:57 +00:00
|
|
|
app.useGlobalPipes(setupValidationPipe(logger));
|
2021-02-15 06:39:52 +00:00
|
|
|
if (mediaConfig.backend.use === BackendType.FILESYSTEM) {
|
|
|
|
logger.log(
|
2021-04-02 15:38:22 +00:00
|
|
|
`Serving the local folder '${mediaConfig.backend.filesystem.uploadPath}' under '/uploads'`,
|
2021-02-15 06:39:52 +00:00
|
|
|
'AppBootstrap',
|
|
|
|
);
|
|
|
|
app.useStaticAssets(mediaConfig.backend.filesystem.uploadPath, {
|
|
|
|
prefix: '/uploads/',
|
2020-10-30 21:35:57 +00:00
|
|
|
});
|
|
|
|
}
|
2021-04-25 12:41:38 +00:00
|
|
|
logger.log(
|
|
|
|
`Serving the local folder 'public' under '/public'`,
|
|
|
|
'AppBootstrap',
|
|
|
|
);
|
|
|
|
app.useStaticAssets('public', {
|
|
|
|
prefix: '/public/',
|
|
|
|
});
|
2020-10-30 21:35:57 +00:00
|
|
|
await app.listen(appConfig.port);
|
|
|
|
logger.log(`Listening on port ${appConfig.port}`, 'AppBootstrap');
|
2020-07-21 19:24:56 +00:00
|
|
|
}
|
|
|
|
|
2021-02-24 20:08:08 +00:00
|
|
|
void bootstrap();
|