UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

314 lines (313 loc) • 35.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _httpstatus = /*#__PURE__*/ _interop_require_default(require("http-status")); const _executeAccess = /*#__PURE__*/ _interop_require_default(require("../../auth/executeAccess")); const _generatePasswordSaltHash = require("../../auth/strategies/local/generatePasswordSaltHash"); const _types = require("../../auth/types"); const _combineQueries = require("../../database/combineQueries"); const _errors = require("../../errors"); const _afterChange = require("../../fields/hooks/afterChange"); const _afterRead = require("../../fields/hooks/afterRead"); const _beforeChange = require("../../fields/hooks/beforeChange"); const _beforeValidate = require("../../fields/hooks/beforeValidate"); const _deleteAssociatedFiles = require("../../uploads/deleteAssociatedFiles"); const _generateFileData = require("../../uploads/generateFileData"); const _unlinkTempFiles = require("../../uploads/unlinkTempFiles"); const _uploadFiles = require("../../uploads/uploadFiles"); const _commitTransaction = require("../../utilities/commitTransaction"); const _initTransaction = require("../../utilities/initTransaction"); const _killTransaction = require("../../utilities/killTransaction"); const _getLatestCollectionVersion = require("../../versions/getLatestCollectionVersion"); const _saveVersion = require("../../versions/saveVersion"); const _utils = require("./utils"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } async function updateByID(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: 'update', req: args.req }) || args; }, Promise.resolve()); const { id, autosave = false, collection: { config: collectionConfig }, collection, depth, draft: draftArg = false, overrideAccess, overwriteExistingFiles = false, req: { fallbackLocale, locale, payload: { config }, payload, t }, req, showHiddenFields } = args; if (!id) { throw new _errors.APIError('Missing ID of document to update.', _httpstatus.default.BAD_REQUEST); } let { data } = args; const { password } = data; const shouldSaveDraft = Boolean(draftArg && collectionConfig.versions.drafts); const shouldSavePassword = Boolean(password && collectionConfig.auth && !shouldSaveDraft); // ///////////////////////////////////// // Access // ///////////////////////////////////// const accessResults = !overrideAccess ? await (0, _executeAccess.default)({ id, data, req }, collectionConfig.access.update) : true; const hasWherePolicy = (0, _types.hasWhereAccessResult)(accessResults); // ///////////////////////////////////// // Retrieve document // ///////////////////////////////////// const findOneArgs = { collection: collectionConfig.slug, locale, req, where: (0, _combineQueries.combineQueries)({ id: { equals: id } }, accessResults) }; const docWithLocales = await (0, _getLatestCollectionVersion.getLatestCollectionVersion)({ id, config: collectionConfig, payload, query: findOneArgs, req }); if (!docWithLocales && !hasWherePolicy) throw new _errors.NotFound(t); if (!docWithLocales && hasWherePolicy) throw new _errors.Forbidden(t); const originalDoc = await (0, _afterRead.afterRead)({ collection: collectionConfig, context: req.context, depth: 0, doc: docWithLocales, fallbackLocale: null, global: null, locale, overrideAccess: true, req, showHiddenFields: true }); // ///////////////////////////////////// // Generate data for all files and sizes // ///////////////////////////////////// const { data: newFileData, files: filesToUpload } = await (0, _generateFileData.generateFileData)({ collection, config, data, overwriteExistingFiles, req, throwOnMissingFile: false }); data = newFileData; // ///////////////////////////////////// // Delete any associated files // ///////////////////////////////////// await (0, _deleteAssociatedFiles.deleteAssociatedFiles)({ collectionConfig, config, doc: docWithLocales, files: filesToUpload, overrideDelete: false, t }); // ///////////////////////////////////// // beforeValidate - Fields // ///////////////////////////////////// data = await (0, _beforeValidate.beforeValidate)({ id, collection: collectionConfig, context: req.context, data, doc: originalDoc, global: null, operation: 'update', overrideAccess, req }); // ///////////////////////////////////// // beforeValidate - Collection // ///////////////////////////////////// await collectionConfig.hooks.beforeValidate.reduce(async (priorHook, hook)=>{ await priorHook; data = await hook({ collection: collectionConfig, context: req.context, data, operation: 'update', originalDoc, req }) || data; }, Promise.resolve()); // ///////////////////////////////////// // Write files to local storage // ///////////////////////////////////// if (!collectionConfig.upload.disableLocalStorage) { await (0, _uploadFiles.uploadFiles)(payload, filesToUpload, t); } // ///////////////////////////////////// // beforeChange - Collection // ///////////////////////////////////// await collectionConfig.hooks.beforeChange.reduce(async (priorHook, hook)=>{ await priorHook; data = await hook({ collection: collectionConfig, context: req.context, data, operation: 'update', originalDoc, req }) || data; }, Promise.resolve()); // ///////////////////////////////////// // beforeChange - Fields // ///////////////////////////////////// let result = await (0, _beforeChange.beforeChange)({ id, collection: collectionConfig, context: req.context, data, doc: originalDoc, docWithLocales, global: null, operation: 'update', req, skipValidation: shouldSaveDraft || data._status === 'draft' }); // ///////////////////////////////////// // Handle potential password update // ///////////////////////////////////// const dataToUpdate = { ...result }; if (shouldSavePassword && typeof password === 'string') { const { hash, salt } = await (0, _generatePasswordSaltHash.generatePasswordSaltHash)({ password }); dataToUpdate.salt = salt; dataToUpdate.hash = hash; delete dataToUpdate.password; delete data.password; } // ///////////////////////////////////// // Update // ///////////////////////////////////// if (!shouldSaveDraft) { result = await req.payload.db.updateOne({ id, collection: collectionConfig.slug, data: dataToUpdate, locale, req }); } // ///////////////////////////////////// // Create version // ///////////////////////////////////// if (collectionConfig.versions) { result = await (0, _saveVersion.saveVersion)({ id, autosave, collection: collectionConfig, docWithLocales: { ...result, createdAt: docWithLocales.createdAt }, draft: shouldSaveDraft, payload, req }); } // ///////////////////////////////////// // afterRead - Fields // ///////////////////////////////////// result = await (0, _afterRead.afterRead)({ collection: collectionConfig, context: req.context, 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, req }) || result; }, Promise.resolve()); // ///////////////////////////////////// // afterChange - Fields // ///////////////////////////////////// result = await (0, _afterChange.afterChange)({ collection: collectionConfig, context: req.context, data, doc: result, global: null, operation: 'update', previousDoc: originalDoc, req }); // ///////////////////////////////////// // afterChange - Collection // ///////////////////////////////////// await collectionConfig.hooks.afterChange.reduce(async (priorHook, hook)=>{ await priorHook; result = await hook({ collection: collectionConfig, context: req.context, doc: result, operation: 'update', previousDoc: originalDoc, req }) || result; }, Promise.resolve()); // ///////////////////////////////////// // afterOperation - Collection // ///////////////////////////////////// result = await (0, _utils.buildAfterOperation)({ args, collection: collectionConfig, operation: 'updateByID', result }); await (0, _unlinkTempFiles.unlinkTempFiles)({ collectionConfig, config, req }); // ///////////////////////////////////// // Return results // ///////////////////////////////////// if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req); return result; } catch (error) { await (0, _killTransaction.killTransaction)(args.req); throw error; } } const _default = updateByID; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/operations/updateByID.ts"],"sourcesContent":["import type { DeepPartial } from 'ts-essentials'\n\nimport httpStatus from 'http-status'\n\nimport type { FindOneArgs } from '../../database/types'\nimport type { PayloadRequest } from '../../express/types'\nimport type { GeneratedTypes } from '../../index'\nimport type { Collection } from '../config/types'\n\nimport executeAccess from '../../auth/executeAccess'\nimport { generatePasswordSaltHash } from '../../auth/strategies/local/generatePasswordSaltHash'\nimport { hasWhereAccessResult } from '../../auth/types'\nimport { combineQueries } from '../../database/combineQueries'\nimport { APIError, Forbidden, NotFound } from '../../errors'\nimport { afterChange } from '../../fields/hooks/afterChange'\nimport { afterRead } from '../../fields/hooks/afterRead'\nimport { beforeChange } from '../../fields/hooks/beforeChange'\nimport { beforeValidate } from '../../fields/hooks/beforeValidate'\nimport { deleteAssociatedFiles } from '../../uploads/deleteAssociatedFiles'\nimport { generateFileData } from '../../uploads/generateFileData'\nimport { unlinkTempFiles } from '../../uploads/unlinkTempFiles'\nimport { uploadFiles } from '../../uploads/uploadFiles'\nimport { commitTransaction } from '../../utilities/commitTransaction'\nimport { initTransaction } from '../../utilities/initTransaction'\nimport { killTransaction } from '../../utilities/killTransaction'\nimport { getLatestCollectionVersion } from '../../versions/getLatestCollectionVersion'\nimport { saveVersion } from '../../versions/saveVersion'\nimport { buildAfterOperation } from './utils'\n\nexport type Arguments<T extends { [field: number | string | symbol]: unknown }> = {\n  autosave?: boolean\n  collection: Collection\n  data: DeepPartial<T>\n  depth?: number\n  disableVerificationEmail?: boolean\n  draft?: boolean\n  id: number | string\n  overrideAccess?: boolean\n  overwriteExistingFiles?: boolean\n  req: PayloadRequest\n  showHiddenFields?: boolean\n}\n\nasync function updateByID<TSlug extends keyof GeneratedTypes['collections']>(\n  incomingArgs: Arguments<GeneratedTypes['collections'][TSlug]>,\n): Promise<GeneratedTypes['collections'][TSlug]> {\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: 'update',\n          req: args.req,\n        })) || args\n    }, Promise.resolve())\n\n    const {\n      id,\n      autosave = false,\n      collection: { config: collectionConfig },\n      collection,\n      depth,\n      draft: draftArg = false,\n      overrideAccess,\n      overwriteExistingFiles = false,\n      req: {\n        fallbackLocale,\n        locale,\n        payload: { config },\n        payload,\n        t,\n      },\n      req,\n      showHiddenFields,\n    } = args\n\n    if (!id) {\n      throw new APIError('Missing ID of document to update.', httpStatus.BAD_REQUEST)\n    }\n\n    let { data } = args\n    const { password } = data\n    const shouldSaveDraft = Boolean(draftArg && collectionConfig.versions.drafts)\n    const shouldSavePassword = Boolean(password && collectionConfig.auth && !shouldSaveDraft)\n\n    // /////////////////////////////////////\n    // Access\n    // /////////////////////////////////////\n\n    const accessResults = !overrideAccess\n      ? await executeAccess({ id, data, req }, collectionConfig.access.update)\n      : true\n    const hasWherePolicy = hasWhereAccessResult(accessResults)\n\n    // /////////////////////////////////////\n    // Retrieve document\n    // /////////////////////////////////////\n\n    const findOneArgs: FindOneArgs = {\n      collection: collectionConfig.slug,\n      locale,\n      req,\n      where: combineQueries({ id: { equals: id } }, accessResults),\n    }\n\n    const docWithLocales = await getLatestCollectionVersion({\n      id,\n      config: collectionConfig,\n      payload,\n      query: findOneArgs,\n      req,\n    })\n\n    if (!docWithLocales && !hasWherePolicy) throw new NotFound(t)\n    if (!docWithLocales && hasWherePolicy) throw new Forbidden(t)\n\n    const originalDoc = await afterRead({\n      collection: collectionConfig,\n      context: req.context,\n      depth: 0,\n      doc: docWithLocales,\n      fallbackLocale: null,\n      global: null,\n      locale,\n      overrideAccess: true,\n      req,\n      showHiddenFields: true,\n    })\n\n    // /////////////////////////////////////\n    // Generate data for all files and sizes\n    // /////////////////////////////////////\n\n    const { data: newFileData, files: filesToUpload } = await generateFileData({\n      collection,\n      config,\n      data,\n      overwriteExistingFiles,\n      req,\n      throwOnMissingFile: false,\n    })\n\n    data = newFileData\n\n    // /////////////////////////////////////\n    // Delete any associated files\n    // /////////////////////////////////////\n\n    await deleteAssociatedFiles({\n      collectionConfig,\n      config,\n      doc: docWithLocales,\n      files: filesToUpload,\n      overrideDelete: false,\n      t,\n    })\n\n    // /////////////////////////////////////\n    // beforeValidate - Fields\n    // /////////////////////////////////////\n\n    data = await beforeValidate<DeepPartial<GeneratedTypes['collections'][TSlug]>>({\n      id,\n      collection: collectionConfig,\n      context: req.context,\n      data,\n      doc: originalDoc,\n      global: null,\n      operation: 'update',\n      overrideAccess,\n      req,\n    })\n\n    // /////////////////////////////////////\n    // beforeValidate - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.beforeValidate.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      data =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          data,\n          operation: 'update',\n          originalDoc,\n          req,\n        })) || data\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // Write files to local storage\n    // /////////////////////////////////////\n\n    if (!collectionConfig.upload.disableLocalStorage) {\n      await uploadFiles(payload, filesToUpload, t)\n    }\n\n    // /////////////////////////////////////\n    // beforeChange - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.beforeChange.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      data =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          data,\n          operation: 'update',\n          originalDoc,\n          req,\n        })) || data\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // beforeChange - Fields\n    // /////////////////////////////////////\n\n    let result = await beforeChange<GeneratedTypes['collections'][TSlug]>({\n      id,\n      collection: collectionConfig,\n      context: req.context,\n      data,\n      doc: originalDoc,\n      docWithLocales,\n      global: null,\n      operation: 'update',\n      req,\n      skipValidation: shouldSaveDraft || data._status === 'draft',\n    })\n\n    // /////////////////////////////////////\n    // Handle potential password update\n    // /////////////////////////////////////\n\n    const dataToUpdate: Record<string, unknown> = { ...result }\n\n    if (shouldSavePassword && typeof password === 'string') {\n      const { hash, salt } = await generatePasswordSaltHash({ password })\n      dataToUpdate.salt = salt\n      dataToUpdate.hash = hash\n      delete dataToUpdate.password\n      delete data.password\n    }\n\n    // /////////////////////////////////////\n    // Update\n    // /////////////////////////////////////\n\n    if (!shouldSaveDraft) {\n      result = await req.payload.db.updateOne({\n        id,\n        collection: collectionConfig.slug,\n        data: dataToUpdate,\n        locale,\n        req,\n      })\n    }\n\n    // /////////////////////////////////////\n    // Create version\n    // /////////////////////////////////////\n\n    if (collectionConfig.versions) {\n      result = await saveVersion({\n        id,\n        autosave,\n        collection: collectionConfig,\n        docWithLocales: {\n          ...result,\n          createdAt: docWithLocales.createdAt,\n        },\n        draft: shouldSaveDraft,\n        payload,\n        req,\n      })\n    }\n\n    // /////////////////////////////////////\n    // afterRead - Fields\n    // /////////////////////////////////////\n\n    result = await afterRead({\n      collection: collectionConfig,\n      context: req.context,\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          req,\n        })) || result\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // afterChange - Fields\n    // /////////////////////////////////////\n\n    result = await afterChange<GeneratedTypes['collections'][TSlug]>({\n      collection: collectionConfig,\n      context: req.context,\n      data,\n      doc: result,\n      global: null,\n      operation: 'update',\n      previousDoc: originalDoc,\n      req,\n    })\n\n    // /////////////////////////////////////\n    // afterChange - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.afterChange.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      result =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          doc: result,\n          operation: 'update',\n          previousDoc: originalDoc,\n          req,\n        })) || result\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // afterOperation - Collection\n    // /////////////////////////////////////\n\n    result = await buildAfterOperation<GeneratedTypes['collections'][TSlug]>({\n      args,\n      collection: collectionConfig,\n      operation: 'updateByID',\n      result,\n    })\n\n    await unlinkTempFiles({\n      collectionConfig,\n      config,\n      req,\n    })\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 updateByID\n"],"names":["updateByID","incomingArgs","args","shouldCommit","initTransaction","req","collection","config","hooks","beforeOperation","reduce","priorHook","hook","context","operation","Promise","resolve","id","autosave","collectionConfig","depth","draft","draftArg","overrideAccess","overwriteExistingFiles","fallbackLocale","locale","payload","t","showHiddenFields","APIError","httpStatus","BAD_REQUEST","data","password","shouldSaveDraft","Boolean","versions","drafts","shouldSavePassword","auth","accessResults","executeAccess","access","update","hasWherePolicy","hasWhereAccessResult","findOneArgs","slug","where","combineQueries","equals","docWithLocales","getLatestCollectionVersion","query","NotFound","Forbidden","originalDoc","afterRead","doc","global","newFileData","files","filesToUpload","generateFileData","throwOnMissingFile","deleteAssociatedFiles","overrideDelete","beforeValidate","upload","disableLocalStorage","uploadFiles","beforeChange","result","skipValidation","_status","dataToUpdate","hash","salt","generatePasswordSaltHash","db","updateOne","saveVersion","createdAt","afterChange","previousDoc","buildAfterOperation","unlinkTempFiles","commitTransaction","error","killTransaction"],"mappings":"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"}