UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

153 lines (152 loc) • 17.7 kB
/* eslint-disable no-underscore-dangle */ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _executeAccess = /*#__PURE__*/ _interop_require_default(require("../../auth/executeAccess")); const _combineQueries = require("../../database/combineQueries"); const _errors = require("../../errors"); const _afterRead = require("../../fields/hooks/afterRead"); const _commitTransaction = require("../../utilities/commitTransaction"); const _initTransaction = require("../../utilities/initTransaction"); const _killTransaction = require("../../utilities/killTransaction"); const _replaceWithDraftIfAvailable = /*#__PURE__*/ _interop_require_default(require("../../versions/drafts/replaceWithDraftIfAvailable")); const _utils = require("./utils"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } async function findByID(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: 'read', req: args.req }) || args; }, Promise.resolve()); const { id, collection: { config: collectionConfig }, currentDepth, depth, disableErrors, draft: draftEnabled = false, overrideAccess = false, req: { fallbackLocale, locale, t }, req, showHiddenFields } = args; // ///////////////////////////////////// // Access // ///////////////////////////////////// const accessResult = !overrideAccess ? await (0, _executeAccess.default)({ id, disableErrors, req }, collectionConfig.access.read) : true; // If errors are disabled, and access returns false, return null if (accessResult === false) return null; const findOneArgs = { collection: collectionConfig.slug, locale, req: { transactionID: req.transactionID }, where: (0, _combineQueries.combineQueries)({ id: { equals: id } }, accessResult) }; // ///////////////////////////////////// // Find by ID // ///////////////////////////////////// if (!findOneArgs.where.and[0].id) throw new _errors.NotFound(t); let result = await req.payload.db.findOne(findOneArgs); if (!result) { if (!disableErrors) { throw new _errors.NotFound(t); } return null; } // ///////////////////////////////////// // Replace document with draft if available // ///////////////////////////////////// if (collectionConfig.versions?.drafts && draftEnabled) { result = await (0, _replaceWithDraftIfAvailable.default)({ accessResult, doc: result, entity: collectionConfig, entityType: 'collection', overrideAccess, req }); } // ///////////////////////////////////// // beforeRead - Collection // ///////////////////////////////////// await collectionConfig.hooks.beforeRead.reduce(async (priorHook, hook)=>{ await priorHook; result = await hook({ collection: collectionConfig, context: req.context, doc: result, query: findOneArgs.where, req }) || result; }, Promise.resolve()); // ///////////////////////////////////// // afterRead - Fields // ///////////////////////////////////// result = await (0, _afterRead.afterRead)({ collection: collectionConfig, context: req.context, currentDepth, depth, doc: result, fallbackLocale, global: null, locale, overrideAccess, req, showHiddenFields }); // ///////////////////////////////////// // afterRead - Collection // ///////////////////////////////////// await collectionConfig.hooks.afterRead.reduce(async (priorHook, hook)=>{ await priorHook; result = await hook({ collection: collectionConfig, context: req.context, doc: result, query: findOneArgs.where, req }) || result; }, Promise.resolve()); // ///////////////////////////////////// // afterOperation - Collection // ///////////////////////////////////// result = await (0, _utils.buildAfterOperation)({ args, collection: collectionConfig, operation: 'findByID', result: result }) // TODO: fix this typing ; // ///////////////////////////////////// // Return results // ///////////////////////////////////// if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req); return result; } catch (error) { await (0, _killTransaction.killTransaction)(args.req); throw error; } } const _default = findByID; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/operations/findByID.ts"],"sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport type { FindOneArgs } from '../../database/types'\nimport type { PayloadRequest } from '../../express/types'\nimport type { Collection, TypeWithID } from '../config/types'\n\nimport executeAccess from '../../auth/executeAccess'\nimport { combineQueries } from '../../database/combineQueries'\nimport { NotFound } from '../../errors'\nimport { afterRead } from '../../fields/hooks/afterRead'\nimport { commitTransaction } from '../../utilities/commitTransaction'\nimport { initTransaction } from '../../utilities/initTransaction'\nimport { killTransaction } from '../../utilities/killTransaction'\nimport replaceWithDraftIfAvailable from '../../versions/drafts/replaceWithDraftIfAvailable'\nimport { buildAfterOperation } from './utils'\n\nexport type Arguments = {\n  collection: Collection\n  currentDepth?: number\n  depth?: number\n  disableErrors?: boolean\n  draft?: boolean\n  id: number | string\n  overrideAccess?: boolean\n  req: PayloadRequest\n  showHiddenFields?: boolean\n}\n\nasync function findByID<T extends TypeWithID>(incomingArgs: Arguments): Promise<T> {\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(async (priorHook, hook) => {\n      await priorHook\n\n      args =\n        (await hook({\n          args,\n          collection: args.collection.config,\n          context: args.req.context,\n          operation: 'read',\n          req: args.req,\n        })) || args\n    }, Promise.resolve())\n\n    const {\n      id,\n      collection: { config: collectionConfig },\n      currentDepth,\n      depth,\n      disableErrors,\n      draft: draftEnabled = false,\n      overrideAccess = false,\n      req: { fallbackLocale, locale, t },\n      req,\n      showHiddenFields,\n    } = args\n\n    // /////////////////////////////////////\n    // Access\n    // /////////////////////////////////////\n\n    const accessResult = !overrideAccess\n      ? await executeAccess({ id, disableErrors, req }, collectionConfig.access.read)\n      : true\n\n    // If errors are disabled, and access returns false, return null\n    if (accessResult === false) return null\n\n    const findOneArgs: FindOneArgs = {\n      collection: collectionConfig.slug,\n      locale,\n      req: {\n        transactionID: req.transactionID,\n      } as PayloadRequest,\n      where: combineQueries({ id: { equals: id } }, accessResult),\n    }\n\n    // /////////////////////////////////////\n    // Find by ID\n    // /////////////////////////////////////\n\n    if (!findOneArgs.where.and[0].id) throw new NotFound(t)\n\n    let result: T = await req.payload.db.findOne(findOneArgs)\n\n    if (!result) {\n      if (!disableErrors) {\n        throw new NotFound(t)\n      }\n\n      return null\n    }\n\n    // /////////////////////////////////////\n    // Replace document with draft if available\n    // /////////////////////////////////////\n\n    if (collectionConfig.versions?.drafts && draftEnabled) {\n      result = await replaceWithDraftIfAvailable({\n        accessResult,\n        doc: result,\n        entity: collectionConfig,\n        entityType: 'collection',\n        overrideAccess,\n        req,\n      })\n    }\n\n    // /////////////////////////////////////\n    // beforeRead - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.beforeRead.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      result =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          doc: result,\n          query: findOneArgs.where,\n          req,\n        })) || result\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // afterRead - Fields\n    // /////////////////////////////////////\n\n    result = await afterRead({\n      collection: collectionConfig,\n      context: req.context,\n      currentDepth,\n      depth,\n      doc: result,\n      fallbackLocale,\n      global: null,\n      locale,\n      overrideAccess,\n      req,\n      showHiddenFields,\n    })\n\n    // /////////////////////////////////////\n    // afterRead - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.afterRead.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      result =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          doc: result,\n          query: findOneArgs.where,\n          req,\n        })) || result\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // afterOperation - Collection\n    // /////////////////////////////////////\n\n    result = await buildAfterOperation<T>({\n      args,\n      collection: collectionConfig,\n      operation: 'findByID',\n      result: result as any,\n    }) // TODO: fix this typing\n\n    // /////////////////////////////////////\n    // Return results\n    // /////////////////////////////////////\n\n    if (shouldCommit) await commitTransaction(req)\n\n    return result\n  } catch (error: unknown) {\n    await killTransaction(args.req)\n    throw error\n  }\n}\n\nexport default findByID\n"],"names":["findByID","incomingArgs","args","shouldCommit","initTransaction","req","collection","config","hooks","beforeOperation","reduce","priorHook","hook","context","operation","Promise","resolve","id","collectionConfig","currentDepth","depth","disableErrors","draft","draftEnabled","overrideAccess","fallbackLocale","locale","t","showHiddenFields","accessResult","executeAccess","access","read","findOneArgs","slug","transactionID","where","combineQueries","equals","and","NotFound","result","payload","db","findOne","versions","drafts","replaceWithDraftIfAvailable","doc","entity","entityType","beforeRead","query","afterRead","global","buildAfterOperation","commitTransaction","error","killTransaction"],"mappings":"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"}