@brewww/authentication-service
Version:
Authenticator service for Brew projects.
83 lines • 4.75 kB
JavaScript
;
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ResetPasswordService = void 0;
const common_1 = require("@nestjs/common");
const entities_1 = require("../entities");
const typeorm_1 = require("@nestjs/typeorm");
const typeorm_2 = require("typeorm");
const invalid_reset_password_request_error_1 = require("../error/invalid-reset-password-request.error");
const user_service_1 = require("../user/user.service");
const config_1 = require("../config");
const active_reset_password_request_exists_error_1 = require("../error/active-reset-password-request-exists.error");
let ResetPasswordService = class ResetPasswordService {
constructor(userService, userResetPasswordRequestRepository) {
this.userService = userService;
this.userResetPasswordRequestRepository = userResetPasswordRequestRepository;
}
async resetPasswordAsync(user, newPassword, key) {
const userResetPasswordRequest = await this.getResetPasswordRequestAsync(key);
if (!userResetPasswordRequest)
throw new invalid_reset_password_request_error_1.InvalidResetPasswordRequestError();
await this.userService.updateUserPasswordAsync(user, newPassword);
await this.expireResetPasswordRequestAsync(userResetPasswordRequest);
}
async getResetPasswordRequestAsync(key) {
return await this.userResetPasswordRequestRepository.findOne({
where: { key, expiresAt: (0, typeorm_2.MoreThan)(new Date()) },
});
}
async createResetPasswordRequest(email) {
const activeUserResetPasswordRequest = await this.getActiveResetPasswordRequestByEmail(email);
if (activeUserResetPasswordRequest &&
activeUserResetPasswordRequest.resendableAt > new Date()) {
throw new active_reset_password_request_exists_error_1.ActiveResetPasswordRequestExistsError();
}
const createdUserResetPasswordRequest = this.createUserResetPasswordRequest(email);
return await this.userResetPasswordRequestRepository.save(createdUserResetPasswordRequest);
}
createUserResetPasswordRequest(email) {
const currentTime = new Date();
const resendableAt = (0, config_1.authenticationConfig)().resetPassword.resendableAt !== 0
? new Date(currentTime.getDate() +
(0, config_1.authenticationConfig)().resetPassword.resendableAt)
: null;
const expiresAt = new Date(currentTime.getDate() + (0, config_1.authenticationConfig)().resetPassword.expiresAt);
const userResetPasswordRequest = new entities_1.UserResetPasswordRequest();
userResetPasswordRequest.email = email;
userResetPasswordRequest.createdAt = currentTime;
userResetPasswordRequest.expiresAt = expiresAt;
userResetPasswordRequest.resendableAt = resendableAt;
return userResetPasswordRequest;
}
async getActiveResetPasswordRequestByEmail(email) {
const activeResetPasswordRequest = await this.userResetPasswordRequestRepository.findOne({
where: [{ email: email }, { expiresAt: (0, typeorm_2.MoreThan)(new Date()) }],
});
return activeResetPasswordRequest;
}
async expireResetPasswordRequestAsync(resetPasswordRequest) {
resetPasswordRequest.expiresAt = new Date();
await this.userResetPasswordRequestRepository.save(resetPasswordRequest);
}
};
ResetPasswordService = __decorate([
(0, common_1.Injectable)(),
__param(0, (0, common_1.Inject)("UserService")),
__param(1, (0, typeorm_1.InjectRepository)(entities_1.UserResetPasswordRequest)),
__metadata("design:paramtypes", [user_service_1.UserService,
typeorm_2.Repository])
], ResetPasswordService);
exports.ResetPasswordService = ResetPasswordService;
//# sourceMappingURL=reset-password.service.js.map