UNPKG

mzinga

Version:

Node, React and MongoDB Headless CMS and Application Framework

136 lines (135 loc) 17.6 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 (!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 }); let result; // ///////////////////////////////////// // refresh hook - Collection // ///////////////////////////////////// for (const refreshHook of args.collection.config.hooks.refresh){ const hookResult = await refreshHook({ args, user }); if (hookResult) { result = hookResult; break; } } if (!result) { 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); } result = { exp, refreshedToken, strategy: args.req.user._strategy, 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: result.exp, req: args.req, res: args.res, token: result.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  strategy?: string\n  user: Document\n}\n\nexport type Arguments = {\n  collection: Collection\n  req: PayloadRequest\n  res?: Response\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 (!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    let result: Result\n\n    // /////////////////////////////////////\n    // refresh hook - Collection\n    // /////////////////////////////////////\n\n    for (const refreshHook of args.collection.config.hooks.refresh) {\n      const hookResult = await refreshHook({ args, user })\n\n      if (hookResult) {\n        result = hookResult\n        break\n      }\n    }\n\n    if (!result) {\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      result = {\n        exp,\n        refreshedToken,\n        strategy: args.req.user._strategy,\n        user,\n      }\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: result.exp,\n          req: args.req,\n          res: args.res,\n          token: result.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","user","Forbidden","t","parsedURL","url","parse","isGraphQL","pathname","routes","graphQL","findByID","id","depth","auth","result","refreshHook","hookResult","fieldsToSign","getFieldsToSign","email","refreshedToken","jwt","sign","expiresIn","tokenExpiration","exp","decode","res","cookieOptions","domain","undefined","expires","getCookieExpiration","httpOnly","path","sameSite","cookies","secure","cookie","cookiePrefix","strategy","_strategy","afterRefresh","token","buildAfterOperation","removeTokenFromResponses","commitTransaction","error","killTransaction"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}