payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
330 lines (329 loc) • 39.2 kB
JavaScript
"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 _combineQueries = require("../../database/combineQueries");
const _validateQueryPaths = require("../../database/queryValidation/validateQueryPaths");
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 _buildCollectionFields = require("../../versions/buildCollectionFields");
const _appendVersionToQueryKey = require("../../versions/drafts/appendVersionToQueryKey");
const _saveVersion = require("../../versions/saveVersion");
const _utils = require("./utils");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
async function update(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 { collection: { config: collectionConfig }, collection, depth, draft: draftArg = false, overrideAccess, overwriteExistingFiles = false, req: { fallbackLocale, locale, payload: { config }, payload, t }, req, showHiddenFields, where } = args;
if (!where) {
throw new _errors.APIError("Missing 'where' query of documents to update.", _httpstatus.default.BAD_REQUEST);
}
const { data: bulkUpdateData } = args;
const shouldSaveDraft = Boolean(draftArg && collectionConfig.versions.drafts);
// /////////////////////////////////////
// Access
// /////////////////////////////////////
let accessResult;
if (!overrideAccess) {
accessResult = await (0, _executeAccess.default)({
req
}, collectionConfig.access.update);
}
await (0, _validateQueryPaths.validateQueryPaths)({
collectionConfig,
overrideAccess,
req,
where
});
// /////////////////////////////////////
// Retrieve documents
// /////////////////////////////////////
const fullWhere = (0, _combineQueries.combineQueries)(where, accessResult);
let docs;
if (collectionConfig.versions?.drafts && shouldSaveDraft) {
const versionsWhere = (0, _appendVersionToQueryKey.appendVersionToQueryKey)(fullWhere);
await (0, _validateQueryPaths.validateQueryPaths)({
collectionConfig: collection.config,
overrideAccess,
req,
versionFields: (0, _buildCollectionFields.buildVersionCollectionFields)(collection.config),
where: versionsWhere
});
const query = await payload.db.queryDrafts({
collection: collectionConfig.slug,
locale,
req,
where: versionsWhere
});
docs = query.docs;
} else {
const query = await payload.db.find({
collection: collectionConfig.slug,
limit: 0,
locale,
pagination: false,
req,
where: fullWhere
});
docs = query.docs;
}
// /////////////////////////////////////
// Generate data for all files and sizes
// /////////////////////////////////////
const { data: newFileData, files: filesToUpload } = await (0, _generateFileData.generateFileData)({
collection,
config,
data: bulkUpdateData,
overwriteExistingFiles,
req,
throwOnMissingFile: false
});
const errors = [];
const promises = docs.map(async (doc)=>{
const { id } = doc;
let data = {
...newFileData,
...bulkUpdateData
};
try {
const originalDoc = await (0, _afterRead.afterRead)({
collection: collectionConfig,
context: req.context,
depth: 0,
doc,
fallbackLocale,
global: null,
locale,
overrideAccess: true,
req,
showHiddenFields: true
});
await (0, _deleteAssociatedFiles.deleteAssociatedFiles)({
collectionConfig,
config,
doc,
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: doc,
global: null,
operation: 'update',
req,
skipValidation: shouldSaveDraft || data._status === 'draft'
});
// /////////////////////////////////////
// Update
// /////////////////////////////////////
if (!shouldSaveDraft) {
result = await req.payload.db.updateOne({
id,
collection: collectionConfig.slug,
data: result,
locale,
req
});
}
// /////////////////////////////////////
// Create version
// /////////////////////////////////////
if (collectionConfig.versions) {
result = await (0, _saveVersion.saveVersion)({
id,
collection: collectionConfig,
docWithLocales: {
...result,
createdAt: doc.createdAt
},
draft: shouldSaveDraft,
payload,
req
});
}
// /////////////////////////////////////
// afterRead - Fields
// /////////////////////////////////////
result = await (0, _afterRead.afterRead)({
collection: collectionConfig,
context: req.context,
depth,
doc: result,
fallbackLocale: null,
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());
await (0, _unlinkTempFiles.unlinkTempFiles)({
collectionConfig,
config,
req
});
// /////////////////////////////////////
// Return results
// /////////////////////////////////////
return result;
} catch (error) {
errors.push({
id,
message: error.message
});
}
return null;
});
const awaitedDocs = await Promise.all(promises);
let result = {
docs: awaitedDocs.filter(Boolean),
errors
};
// /////////////////////////////////////
// afterOperation - Collection
// /////////////////////////////////////
result = await (0, _utils.buildAfterOperation)({
args,
collection: collectionConfig,
operation: 'update',
result
});
if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req);
return result;
} catch (error) {
await (0, _killTransaction.killTransaction)(args.req);
throw error;
}
}
const _default = update;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/operations/update.ts"],"sourcesContent":["import type { DeepPartial } from 'ts-essentials'\n\nimport httpStatus from 'http-status'\n\nimport type { GeneratedTypes } from '../../'\nimport type { AccessResult } from '../../config/types'\nimport type { PayloadRequest } from '../../express/types'\nimport type { Where } from '../../types'\nimport type { BulkOperationResult, Collection } from '../config/types'\nimport type { CreateUpdateType } from './create'\n\nimport executeAccess from '../../auth/executeAccess'\nimport { combineQueries } from '../../database/combineQueries'\nimport { validateQueryPaths } from '../../database/queryValidation/validateQueryPaths'\nimport { APIError } 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 { buildVersionCollectionFields } from '../../versions/buildCollectionFields'\nimport { appendVersionToQueryKey } from '../../versions/drafts/appendVersionToQueryKey'\nimport { saveVersion } from '../../versions/saveVersion'\nimport { buildAfterOperation } from './utils'\n\nexport type Arguments<T extends CreateUpdateType> = {\n  collection: Collection\n  data: DeepPartial<T>\n  depth?: number\n  disableVerificationEmail?: boolean\n  draft?: boolean\n  overrideAccess?: boolean\n  overwriteExistingFiles?: boolean\n  req: PayloadRequest\n  showHiddenFields?: boolean\n  where: Where\n}\n\nasync function update<TSlug extends keyof GeneratedTypes['collections']>(\n  incomingArgs: Arguments<GeneratedTypes['collections'][TSlug]>,\n): Promise<BulkOperationResult<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      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      where,\n    } = args\n\n    if (!where) {\n      throw new APIError(\"Missing 'where' query of documents to update.\", httpStatus.BAD_REQUEST)\n    }\n\n    const { data: bulkUpdateData } = args\n    const shouldSaveDraft = Boolean(draftArg && collectionConfig.versions.drafts)\n\n    // /////////////////////////////////////\n    // Access\n    // /////////////////////////////////////\n\n    let accessResult: AccessResult\n    if (!overrideAccess) {\n      accessResult = await executeAccess({ req }, collectionConfig.access.update)\n    }\n\n    await validateQueryPaths({\n      collectionConfig,\n      overrideAccess,\n      req,\n      where,\n    })\n\n    // /////////////////////////////////////\n    // Retrieve documents\n    // /////////////////////////////////////\n\n    const fullWhere = combineQueries(where, accessResult)\n\n    let docs\n\n    if (collectionConfig.versions?.drafts && shouldSaveDraft) {\n      const versionsWhere = appendVersionToQueryKey(fullWhere)\n\n      await validateQueryPaths({\n        collectionConfig: collection.config,\n        overrideAccess,\n        req,\n        versionFields: buildVersionCollectionFields(collection.config),\n        where: versionsWhere,\n      })\n\n      const query = await payload.db.queryDrafts<GeneratedTypes['collections'][TSlug]>({\n        collection: collectionConfig.slug,\n        locale,\n        req,\n        where: versionsWhere,\n      })\n\n      docs = query.docs\n    } else {\n      const query = await payload.db.find({\n        collection: collectionConfig.slug,\n        limit: 0,\n        locale,\n        pagination: false,\n        req,\n        where: fullWhere,\n      })\n\n      docs = query.docs\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: bulkUpdateData,\n      overwriteExistingFiles,\n      req,\n      throwOnMissingFile: false,\n    })\n\n    const errors = []\n\n    const promises = docs.map(async (doc) => {\n      const { id } = doc\n      let data = {\n        ...newFileData,\n        ...bulkUpdateData,\n      }\n\n      try {\n        const originalDoc = await afterRead({\n          collection: collectionConfig,\n          context: req.context,\n          depth: 0,\n          doc,\n          fallbackLocale,\n          global: null,\n          locale,\n          overrideAccess: true,\n          req,\n          showHiddenFields: true,\n        })\n\n        await deleteAssociatedFiles({\n          collectionConfig,\n          config,\n          doc,\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: doc,\n          global: null,\n          operation: 'update',\n          req,\n          skipValidation: shouldSaveDraft || data._status === 'draft',\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: result,\n            locale,\n            req,\n          })\n        }\n\n        // /////////////////////////////////////\n        // Create version\n        // /////////////////////////////////////\n\n        if (collectionConfig.versions) {\n          result = await saveVersion({\n            id,\n            collection: collectionConfig,\n            docWithLocales: {\n              ...result,\n              createdAt: doc.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: null,\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        await unlinkTempFiles({\n          collectionConfig,\n          config,\n          req,\n        })\n\n        // /////////////////////////////////////\n        // Return results\n        // /////////////////////////////////////\n\n        return result\n      } catch (error) {\n        errors.push({\n          id,\n          message: error.message,\n        })\n      }\n      return null\n    })\n\n    const awaitedDocs = await Promise.all(promises)\n\n    let result = {\n      docs: awaitedDocs.filter(Boolean),\n      errors,\n    }\n\n    // /////////////////////////////////////\n    // afterOperation - Collection\n    // /////////////////////////////////////\n\n    result = await buildAfterOperation<GeneratedTypes['collections'][TSlug]>({\n      args,\n      collection: collectionConfig,\n      operation: 'update',\n      result,\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 update\n"],"names":["update","incomingArgs","args","shouldCommit","initTransaction","req","collection","config","hooks","beforeOperation","reduce","priorHook","hook","context","operation","Promise","resolve","collectionConfig","depth","draft","draftArg","overrideAccess","overwriteExistingFiles","fallbackLocale","locale","payload","t","showHiddenFields","where","APIError","httpStatus","BAD_REQUEST","data","bulkUpdateData","shouldSaveDraft","Boolean","versions","drafts","accessResult","executeAccess","access","validateQueryPaths","fullWhere","combineQueries","docs","versionsWhere","appendVersionToQueryKey","versionFields","buildVersionCollectionFields","query","db","queryDrafts","slug","find","limit","pagination","newFileData","files","filesToUpload","generateFileData","throwOnMissingFile","errors","promises","map","doc","id","originalDoc","afterRead","global","deleteAssociatedFiles","overrideDelete","beforeValidate","upload","disableLocalStorage","uploadFiles","beforeChange","result","docWithLocales","skipValidation","_status","updateOne","saveVersion","createdAt","afterChange","previousDoc","unlinkTempFiles","error","push","message","awaitedDocs","all","filter","buildAfterOperation","commitTransaction","killTransaction"],"mappings":"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"}