UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

107 lines (106 loc) 13.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _jsonwebtoken = /*#__PURE__*/ _interop_require_default(require("jsonwebtoken")); const _errors = require("../../errors"); const _commitTransaction = require("../../utilities/commitTransaction"); const _getCookieExpiration = /*#__PURE__*/ _interop_require_default(require("../../utilities/getCookieExpiration")); const _initTransaction = require("../../utilities/initTransaction"); const _killTransaction = require("../../utilities/killTransaction"); const _authenticate = require("../strategies/local/authenticate"); const _generatePasswordSaltHash = require("../strategies/local/generatePasswordSaltHash"); const _getFieldsToSign = require("./getFieldsToSign"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } async function resetPassword(args) { if (!Object.prototype.hasOwnProperty.call(args.data, 'token') || !Object.prototype.hasOwnProperty.call(args.data, 'password')) { throw new _errors.APIError('Missing required data.'); } const { collection: { config: collectionConfig }, data, depth, overrideAccess, req: { payload: { config, secret }, payload }, req } = args; try { const shouldCommit = await (0, _initTransaction.initTransaction)(req); // ///////////////////////////////////// // Reset Password // ///////////////////////////////////// const user = await payload.db.findOne({ collection: collectionConfig.slug, req, where: { resetPasswordExpiration: { greater_than: new Date() }, resetPasswordToken: { equals: data.token } } }); if (!user) throw new _errors.APIError('Token is either invalid or has expired.'); // TODO: replace this method const { hash, salt } = await (0, _generatePasswordSaltHash.generatePasswordSaltHash)({ password: data.password }); user.salt = salt; user.hash = hash; user.resetPasswordExpiration = new Date().toISOString(); if (collectionConfig.auth.verify) { user._verified = true; } const doc = await payload.db.updateOne({ id: user.id, collection: collectionConfig.slug, data: user, req }); await (0, _authenticate.authenticateLocalStrategy)({ doc, password: data.password }); const fieldsToSign = (0, _getFieldsToSign.getFieldsToSign)({ collectionConfig, email: user.email, user }); const token = _jsonwebtoken.default.sign(fieldsToSign, secret, { expiresIn: collectionConfig.auth.tokenExpiration }); if (args.res) { const cookieOptions = { domain: undefined, expires: (0, _getCookieExpiration.default)(collectionConfig.auth.tokenExpiration), httpOnly: true, path: '/', sameSite: collectionConfig.auth.cookies.sameSite, secure: collectionConfig.auth.cookies.secure }; if (collectionConfig.auth.cookies.domain) cookieOptions.domain = collectionConfig.auth.cookies.domain; args.res.cookie(`${config.cookiePrefix}-token`, token, cookieOptions); } const fullUser = await payload.findByID({ id: user.id, collection: collectionConfig.slug, depth, overrideAccess, req }); if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req); return { token: collectionConfig.auth.removeTokenFromResponses ? undefined : token, user: fullUser }; } catch (error) { await (0, _killTransaction.killTransaction)(req); throw error; } } const _default = resetPassword; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/auth/operations/resetPassword.ts"],"sourcesContent":["import type { Response } from 'express'\n\nimport jwt from 'jsonwebtoken'\n\nimport type { Collection } from '../../collections/config/types'\nimport type { PayloadRequest } from '../../express/types'\n\nimport { APIError } from '../../errors'\nimport { commitTransaction } from '../../utilities/commitTransaction'\nimport getCookieExpiration from '../../utilities/getCookieExpiration'\nimport { initTransaction } from '../../utilities/initTransaction'\nimport { killTransaction } from '../../utilities/killTransaction'\nimport { authenticateLocalStrategy } from '../strategies/local/authenticate'\nimport { generatePasswordSaltHash } from '../strategies/local/generatePasswordSaltHash'\nimport { getFieldsToSign } from './getFieldsToSign'\n\nexport type Result = {\n  token?: string\n  user: Record<string, unknown>\n}\n\nexport type Arguments = {\n  collection: Collection\n  data: {\n    password: string\n    token: string\n  }\n  depth?: number\n  overrideAccess?: boolean\n  req: PayloadRequest\n  res?: Response\n}\n\nasync function resetPassword(args: Arguments): Promise<Result> {\n  if (\n    !Object.prototype.hasOwnProperty.call(args.data, 'token') ||\n    !Object.prototype.hasOwnProperty.call(args.data, 'password')\n  ) {\n    throw new APIError('Missing required data.')\n  }\n\n  const {\n    collection: { config: collectionConfig },\n    data,\n    depth,\n    overrideAccess,\n    req: {\n      payload: { config, secret },\n      payload,\n    },\n    req,\n  } = args\n\n  try {\n    const shouldCommit = await initTransaction(req)\n\n    // /////////////////////////////////////\n    // Reset Password\n    // /////////////////////////////////////\n\n    const user = await payload.db.findOne<any>({\n      collection: collectionConfig.slug,\n      req,\n      where: {\n        resetPasswordExpiration: { greater_than: new Date() },\n        resetPasswordToken: { equals: data.token },\n      },\n    })\n\n    if (!user) throw new APIError('Token is either invalid or has expired.')\n\n    // TODO: replace this method\n    const { hash, salt } = await generatePasswordSaltHash({ password: data.password })\n\n    user.salt = salt\n    user.hash = hash\n\n    user.resetPasswordExpiration = new Date().toISOString()\n\n    if (collectionConfig.auth.verify) {\n      user._verified = true\n    }\n\n    const doc = await payload.db.updateOne({\n      id: user.id,\n      collection: collectionConfig.slug,\n      data: user,\n      req,\n    })\n\n    await authenticateLocalStrategy({ doc, password: data.password })\n\n    const fieldsToSign = getFieldsToSign({\n      collectionConfig,\n      email: user.email,\n      user,\n    })\n\n    const token = jwt.sign(fieldsToSign, secret, {\n      expiresIn: collectionConfig.auth.tokenExpiration,\n    })\n\n    if (args.res) {\n      const cookieOptions = {\n        domain: undefined,\n        expires: getCookieExpiration(collectionConfig.auth.tokenExpiration),\n        httpOnly: true,\n        path: '/',\n        sameSite: collectionConfig.auth.cookies.sameSite,\n        secure: collectionConfig.auth.cookies.secure,\n      }\n\n      if (collectionConfig.auth.cookies.domain)\n        cookieOptions.domain = collectionConfig.auth.cookies.domain\n\n      args.res.cookie(`${config.cookiePrefix}-token`, token, cookieOptions)\n    }\n\n    const fullUser = await payload.findByID({\n      id: user.id,\n      collection: collectionConfig.slug,\n      depth,\n      overrideAccess,\n      req,\n    })\n    if (shouldCommit) await commitTransaction(req)\n\n    return {\n      token: collectionConfig.auth.removeTokenFromResponses ? undefined : token,\n      user: fullUser,\n    }\n  } catch (error: unknown) {\n    await killTransaction(req)\n    throw error\n  }\n}\n\nexport default resetPassword\n"],"names":["resetPassword","args","Object","prototype","hasOwnProperty","call","data","APIError","collection","config","collectionConfig","depth","overrideAccess","req","payload","secret","shouldCommit","initTransaction","user","db","findOne","slug","where","resetPasswordExpiration","greater_than","Date","resetPasswordToken","equals","token","hash","salt","generatePasswordSaltHash","password","toISOString","auth","verify","_verified","doc","updateOne","id","authenticateLocalStrategy","fieldsToSign","getFieldsToSign","email","jwt","sign","expiresIn","tokenExpiration","res","cookieOptions","domain","undefined","expires","getCookieExpiration","httpOnly","path","sameSite","cookies","secure","cookie","cookiePrefix","fullUser","findByID","commitTransaction","removeTokenFromResponses","error","killTransaction"],"mappings":"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"}