UNPKG

@mercury-labs/nest-auth

Version:

Mercury framework auth library. It supports local auth, jwt with both bearer token and cookie, basic auth.

33 lines 1.77 kB
"use strict"; 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 __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.Pbkdf2PasswordHasherService = void 0; const common_1 = require("@nestjs/common"); const crypto_1 = __importDefault(require("crypto")); let Pbkdf2PasswordHasherService = exports.Pbkdf2PasswordHasherService = class Pbkdf2PasswordHasherService { async hash(password) { const salt = crypto_1.default.randomBytes(16).toString('hex'); const hash = crypto_1.default .pbkdf2Sync(password, salt, 10000, 512, 'sha512') .toString('hex'); return { salt, hash }; } async compare(password, hashedPassword) { const hashPassword = crypto_1.default .pbkdf2Sync(password, hashedPassword.salt, 10000, 512, 'sha512') .toString('hex'); return hashedPassword.hash === hashPassword; } }; exports.Pbkdf2PasswordHasherService = Pbkdf2PasswordHasherService = __decorate([ (0, common_1.Injectable)() ], Pbkdf2PasswordHasherService); //# sourceMappingURL=pbkdf2.password-hasher.service.js.map