unleash-server
Version:
Unleash is an enterprise ready feature toggles service. It provides different strategies for handling feature toggles.
103 lines • 4.21 kB
JavaScript
;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const controller_1 = __importDefault(require("../controller"));
const permissions_1 = require("../../types/permissions");
const create_request_schema_1 = require("../../openapi/util/create-request-schema");
const create_response_schema_1 = require("../../openapi/util/create-response-schema");
const token_user_schema_1 = require("../../openapi/spec/token-user-schema");
const standard_responses_1 = require("../../openapi/util/standard-responses");
class ResetPasswordController extends controller_1.default {
constructor(config, { userService, openApiService, }) {
super(config);
this.logger = config.getLogger('lib/routes/auth/reset-password-controller.ts');
this.openApiService = openApiService;
this.userService = userService;
this.route({
method: 'get',
path: '/validate',
handler: this.validateToken,
permission: permissions_1.NONE,
middleware: [
openApiService.validPath({
tags: ['Auth'],
operationId: 'validateToken',
responses: { 200: (0, create_response_schema_1.createResponseSchema)('tokenUserSchema') },
}),
],
});
this.route({
method: 'post',
path: '/password',
handler: this.changePassword,
permission: permissions_1.NONE,
middleware: [
openApiService.validPath({
tags: ['Auth'],
operationId: 'changePassword',
requestBody: (0, create_request_schema_1.createRequestSchema)('changePasswordSchema'),
responses: { 200: standard_responses_1.emptyResponse },
}),
],
});
this.route({
method: 'post',
path: '/validate-password',
handler: this.validatePassword,
permission: permissions_1.NONE,
middleware: [
openApiService.validPath({
tags: ['Auth'],
operationId: 'validatePassword',
requestBody: (0, create_request_schema_1.createRequestSchema)('validatePasswordSchema'),
responses: { 200: standard_responses_1.emptyResponse },
}),
],
});
this.route({
method: 'post',
path: '/password-email',
handler: this.sendResetPasswordEmail,
permission: permissions_1.NONE,
middleware: [
openApiService.validPath({
tags: ['Auth'],
operationId: 'sendResetPasswordEmail',
requestBody: (0, create_request_schema_1.createRequestSchema)('emailSchema'),
responses: { 200: standard_responses_1.emptyResponse },
}),
],
});
}
async sendResetPasswordEmail(req, res) {
const { email } = req.body;
await this.userService.createResetPasswordEmail(email);
res.status(200).end();
}
async validatePassword(req, res) {
const { password } = req.body;
this.userService.validatePassword(password);
res.status(200).end();
}
async validateToken(req, res) {
const { token } = req.query;
const user = await this.userService.getUserForToken(token);
await this.logout(req);
this.openApiService.respondWithValidation(200, res, token_user_schema_1.tokenUserSchema.$id, user);
}
async changePassword(req, res) {
await this.logout(req);
const { token, password } = req.body;
await this.userService.resetPassword(token, password);
res.status(200).end();
}
async logout(req) {
if (req.session) {
req.session.destroy(() => { });
}
}
}
exports.default = ResetPasswordController;
//# sourceMappingURL=reset-password-controller.js.map