1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-11 00:08:30 +01:00
unleash.unleash/src/lib/routes/admin-api/maintenance.ts

101 lines
3.4 KiB
TypeScript
Raw Normal View History

2022-12-21 12:23:44 +01:00
import { ADMIN, IUnleashConfig, IUnleashServices } from '../../types';
import { Request, Response } from 'express';
import Controller from '../controller';
import { Logger } from '../../logger';
import {
createRequestSchema,
createResponseSchema,
emptyResponse,
2023-04-10 09:55:29 +02:00
getStandardResponses,
2022-12-21 12:23:44 +01:00
} from '../../openapi';
import { OpenApiService } from '../../services';
import { IAuthRequest } from '../unleash-types';
import { extractUsername } from '../../util';
import {
MaintenanceSchema,
maintenanceSchema,
} from '../../openapi/spec/maintenance-schema';
import MaintenanceService from 'lib/services/maintenance-service';
export default class MaintenanceController extends Controller {
private maintenanceService: MaintenanceService;
private openApiService: OpenApiService;
private logger: Logger;
constructor(
config: IUnleashConfig,
{
maintenanceService,
openApiService,
}: Pick<IUnleashServices, 'maintenanceService' | 'openApiService'>,
) {
super(config);
this.maintenanceService = maintenanceService;
this.openApiService = openApiService;
this.logger = config.getLogger('routes/admin-api/maintenance');
this.route({
method: 'post',
path: '',
permission: ADMIN,
handler: this.toggleMaintenance,
middleware: [
this.openApiService.validPath({
2023-04-10 09:55:29 +02:00
summary: 'Enabled/disabled maintenance mode',
description:
'Lets administrators put Unleash into a mostly read-only mode. While Unleash is in maintenance mode, users can not change any configuration settings',
2022-12-21 12:23:44 +01:00
tags: ['Maintenance'],
operationId: 'toggleMaintenance',
responses: {
204: emptyResponse,
2023-04-10 09:55:29 +02:00
...getStandardResponses(400, 401, 403),
2022-12-21 12:23:44 +01:00
},
2023-04-10 09:55:29 +02:00
requestBody: createRequestSchema('toggleMaintenanceSchema'),
2022-12-21 12:23:44 +01:00
}),
],
});
this.route({
method: 'get',
path: '',
permission: ADMIN,
handler: this.getMaintenance,
middleware: [
this.openApiService.validPath({
2023-04-10 09:55:29 +02:00
summary: 'Get maintenance mode status',
description:
'Tells you whether maintenance mode is enabled or disabled',
2022-12-21 12:23:44 +01:00
tags: ['Maintenance'],
operationId: 'getMaintenance',
responses: {
200: createResponseSchema('maintenanceSchema'),
2023-04-10 09:55:29 +02:00
...getStandardResponses(401, 403),
2022-12-21 12:23:44 +01:00
},
}),
],
});
}
async toggleMaintenance(
req: IAuthRequest<unknown, unknown, MaintenanceSchema>,
res: Response,
): Promise<void> {
await this.maintenanceService.toggleMaintenanceMode(
req.body,
extractUsername(req),
);
res.status(204).end();
}
async getMaintenance(req: Request, res: Response): Promise<void> {
const settings = await this.maintenanceService.getMaintenanceSetting();
this.openApiService.respondWithValidation(
200,
res,
maintenanceSchema.$id,
settings,
);
}
}
module.exports = MaintenanceController;