UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

119 lines (118 loc) • 15.7 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 _url = /*#__PURE__*/ _interop_require_default(require("url")); const _utils = require("../../collections/operations/utils"); 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 _getFieldsToSign = require("./getFieldsToSign"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } async function refresh(incomingArgs) { let args = incomingArgs; try { const shouldCommit = await (0, _initTransaction.initTransaction)(args.req); // ///////////////////////////////////// // beforeOperation - Collection // ///////////////////////////////////// await args.collection.config.hooks.beforeOperation.reduce(async (priorHook, hook)=>{ await priorHook; args = await hook({ args, collection: args.collection?.config, context: args.req.context, operation: 'refresh', req: args.req }) || args; }, Promise.resolve()); // ///////////////////////////////////// // Refresh // ///////////////////////////////////// const { collection: { config: collectionConfig }, req: { payload: { config, secret } } } = args; if (typeof args.token !== 'string' || !args.req.user) throw new _errors.Forbidden(args.req.t); const parsedURL = _url.default.parse(args.req.url); const isGraphQL = parsedURL.pathname === config.routes.graphQL; const user = await args.req.payload.findByID({ id: args.req.user.id, collection: args.req.user.collection, depth: isGraphQL ? 0 : args.collection.config.auth.depth, req: args.req }); const fieldsToSign = (0, _getFieldsToSign.getFieldsToSign)({ collectionConfig, email: user?.email, user: args?.req?.user }); const refreshedToken = _jsonwebtoken.default.sign(fieldsToSign, secret, { expiresIn: collectionConfig.auth.tokenExpiration }); const exp = _jsonwebtoken.default.decode(refreshedToken).exp; 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`, refreshedToken, cookieOptions); } let result = { exp, refreshedToken, user }; // ///////////////////////////////////// // After Refresh - Collection // ///////////////////////////////////// await collectionConfig.hooks.afterRefresh.reduce(async (priorHook, hook)=>{ await priorHook; result = await hook({ collection: args.collection?.config, context: args.req.context, exp, req: args.req, res: args.res, token: refreshedToken }) || result; }, Promise.resolve()); // ///////////////////////////////////// // afterOperation - Collection // ///////////////////////////////////// result = await (0, _utils.buildAfterOperation)({ args, collection: args.collection?.config, operation: 'refresh', result }); // ///////////////////////////////////// // Return results // ///////////////////////////////////// if (collectionConfig.auth.removeTokenFromResponses) { delete result.refreshedToken; } if (shouldCommit) await (0, _commitTransaction.commitTransaction)(args.req); return result; } catch (error) { await (0, _killTransaction.killTransaction)(args.req); throw error; } } const _default = refresh; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/auth/operations/refresh.ts"],"sourcesContent":["import type { Response } from 'express'\n\nimport jwt from 'jsonwebtoken'\nimport url from 'url'\n\nimport type { BeforeOperationHook, Collection } from '../../collections/config/types'\nimport type { PayloadRequest } from '../../express/types'\nimport type { Document } from '../../types'\n\nimport { buildAfterOperation } from '../../collections/operations/utils'\nimport { Forbidden } from '../../errors'\nimport { commitTransaction } from '../../utilities/commitTransaction'\nimport getCookieExpiration from '../../utilities/getCookieExpiration'\nimport { initTransaction } from '../../utilities/initTransaction'\nimport { killTransaction } from '../../utilities/killTransaction'\nimport { getFieldsToSign } from './getFieldsToSign'\n\nexport type Result = {\n  exp: number\n  refreshedToken: string\n  user: Document\n}\n\nexport type Arguments = {\n  collection: Collection\n  req: PayloadRequest\n  res?: Response\n  token: string\n}\n\nasync function refresh(incomingArgs: Arguments): Promise<Result> {\n  let args = incomingArgs\n\n  try {\n    const shouldCommit = await initTransaction(args.req)\n\n    // /////////////////////////////////////\n    // beforeOperation - Collection\n    // /////////////////////////////////////\n\n    await args.collection.config.hooks.beforeOperation.reduce(\n      async (priorHook: BeforeOperationHook | Promise<void>, hook: BeforeOperationHook) => {\n        await priorHook\n\n        args =\n          (await hook({\n            args,\n            collection: args.collection?.config,\n            context: args.req.context,\n            operation: 'refresh',\n            req: args.req,\n          })) || args\n      },\n      Promise.resolve(),\n    )\n\n    // /////////////////////////////////////\n    // Refresh\n    // /////////////////////////////////////\n\n    const {\n      collection: { config: collectionConfig },\n      req: {\n        payload: { config, secret },\n      },\n    } = args\n\n    if (typeof args.token !== 'string' || !args.req.user) throw new Forbidden(args.req.t)\n\n    const parsedURL = url.parse(args.req.url)\n    const isGraphQL = parsedURL.pathname === config.routes.graphQL\n\n    const user = await args.req.payload.findByID({\n      id: args.req.user.id,\n      collection: args.req.user.collection,\n      depth: isGraphQL ? 0 : args.collection.config.auth.depth,\n      req: args.req,\n    })\n\n    const fieldsToSign = getFieldsToSign({\n      collectionConfig,\n      email: user?.email as string,\n      user: args?.req?.user,\n    })\n\n    const refreshedToken = jwt.sign(fieldsToSign, secret, {\n      expiresIn: collectionConfig.auth.tokenExpiration,\n    })\n\n    const exp = (jwt.decode(refreshedToken) as Record<string, unknown>).exp as number\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`, refreshedToken, cookieOptions)\n    }\n\n    let result: Result = {\n      exp,\n      refreshedToken,\n      user,\n    }\n\n    // /////////////////////////////////////\n    // After Refresh - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.afterRefresh.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      result =\n        (await hook({\n          collection: args.collection?.config,\n          context: args.req.context,\n          exp,\n          req: args.req,\n          res: args.res,\n          token: refreshedToken,\n        })) || result\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // afterOperation - Collection\n    // /////////////////////////////////////\n\n    result = await buildAfterOperation({\n      args,\n      collection: args.collection?.config,\n      operation: 'refresh',\n      result,\n    })\n\n    // /////////////////////////////////////\n    // Return results\n    // /////////////////////////////////////\n\n    if (collectionConfig.auth.removeTokenFromResponses) {\n      delete result.refreshedToken\n    }\n\n    if (shouldCommit) await commitTransaction(args.req)\n\n    return result\n  } catch (error: unknown) {\n    await killTransaction(args.req)\n    throw error\n  }\n}\n\nexport default refresh\n"],"names":["refresh","incomingArgs","args","shouldCommit","initTransaction","req","collection","config","hooks","beforeOperation","reduce","priorHook","hook","context","operation","Promise","resolve","collectionConfig","payload","secret","token","user","Forbidden","t","parsedURL","url","parse","isGraphQL","pathname","routes","graphQL","findByID","id","depth","auth","fieldsToSign","getFieldsToSign","email","refreshedToken","jwt","sign","expiresIn","tokenExpiration","exp","decode","res","cookieOptions","domain","undefined","expires","getCookieExpiration","httpOnly","path","sameSite","cookies","secure","cookie","cookiePrefix","result","afterRefresh","buildAfterOperation","removeTokenFromResponses","commitTransaction","error","killTransaction"],"mappings":"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"}