payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
107 lines (106 loc) • 13.5 kB
JavaScript
"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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"}