payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
206 lines (205 loc) • 24.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 _afterRead = require("../../fields/hooks/afterRead");
const _deleteUserPreferences = require("../../preferences/deleteUserPreferences");
const _deleteAssociatedFiles = require("../../uploads/deleteAssociatedFiles");
const _commitTransaction = require("../../utilities/commitTransaction");
const _initTransaction = require("../../utilities/initTransaction");
const _killTransaction = require("../../utilities/killTransaction");
const _deleteCollectionVersions = require("../../versions/deleteCollectionVersions");
const _utils = require("./utils");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
async function deleteOperation(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: 'delete',
req: args.req
}) || args;
}, Promise.resolve());
const { collection: { config: collectionConfig }, depth, overrideAccess, req: { fallbackLocale, locale, payload: { config }, payload, t }, req, showHiddenFields, where } = args;
if (!where) {
throw new _errors.APIError("Missing 'where' query of documents to delete.", _httpstatus.default.BAD_REQUEST);
}
// /////////////////////////////////////
// Access
// /////////////////////////////////////
let accessResult;
if (!overrideAccess) {
accessResult = await (0, _executeAccess.default)({
req
}, collectionConfig.access.delete);
}
await (0, _validateQueryPaths.validateQueryPaths)({
collectionConfig,
overrideAccess,
req,
where
});
const fullWhere = (0, _combineQueries.combineQueries)(where, accessResult);
// /////////////////////////////////////
// Retrieve documents
// /////////////////////////////////////
const { docs } = await payload.db.find({
collection: collectionConfig.slug,
locale,
req,
where: fullWhere
});
const errors = [];
/* eslint-disable no-param-reassign */ const promises = docs.map(async (doc)=>{
let result;
const { id } = doc;
try {
// /////////////////////////////////////
// beforeDelete - Collection
// /////////////////////////////////////
await collectionConfig.hooks.beforeDelete.reduce(async (priorHook, hook)=>{
await priorHook;
return hook({
id,
collection: collectionConfig,
context: req.context,
req
});
}, Promise.resolve());
await (0, _deleteAssociatedFiles.deleteAssociatedFiles)({
collectionConfig,
config,
doc,
overrideDelete: true,
t
});
// /////////////////////////////////////
// Delete versions
// /////////////////////////////////////
if (collectionConfig.versions) {
await (0, _deleteCollectionVersions.deleteCollectionVersions)({
id,
slug: collectionConfig.slug,
payload,
req
});
}
// /////////////////////////////////////
// Delete document
// /////////////////////////////////////
await payload.db.deleteOne({
collection: collectionConfig.slug,
req,
where: {
id: {
equals: id
}
}
});
// /////////////////////////////////////
// afterRead - Fields
// /////////////////////////////////////
result = await (0, _afterRead.afterRead)({
collection: collectionConfig,
context: req.context,
depth,
doc: result || doc,
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 || doc,
req
}) || result;
}, Promise.resolve());
// /////////////////////////////////////
// afterDelete - Collection
// /////////////////////////////////////
await collectionConfig.hooks.afterDelete.reduce(async (priorHook, hook)=>{
await priorHook;
result = await hook({
id,
collection: collectionConfig,
context: req.context,
doc: result,
req
}) || result;
}, Promise.resolve());
// /////////////////////////////////////
// 8. Return results
// /////////////////////////////////////
return result;
} catch (error) {
errors.push({
id: doc.id,
message: error.message
});
}
return null;
});
const awaitedDocs = await Promise.all(promises);
// /////////////////////////////////////
// Delete Preferences
// /////////////////////////////////////
await (0, _deleteUserPreferences.deleteUserPreferences)({
collectionConfig,
ids: docs.map(({ id })=>id),
payload,
req
});
let result = {
docs: awaitedDocs.filter(Boolean),
errors
};
// /////////////////////////////////////
// afterOperation - Collection
// /////////////////////////////////////
result = await (0, _utils.buildAfterOperation)({
args,
collection: collectionConfig,
operation: 'delete',
result
});
if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req);
return result;
} catch (error) {
await (0, _killTransaction.killTransaction)(args.req);
throw error;
}
}
const _default = deleteOperation;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/operations/delete.ts"],"sourcesContent":["import 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 { BeforeOperationHook, Collection } from '../config/types'\n\nimport executeAccess from '../../auth/executeAccess'\nimport { combineQueries } from '../../database/combineQueries'\nimport { validateQueryPaths } from '../../database/queryValidation/validateQueryPaths'\nimport { APIError } from '../../errors'\nimport { afterRead } from '../../fields/hooks/afterRead'\nimport { deleteUserPreferences } from '../../preferences/deleteUserPreferences'\nimport { deleteAssociatedFiles } from '../../uploads/deleteAssociatedFiles'\nimport { commitTransaction } from '../../utilities/commitTransaction'\nimport { initTransaction } from '../../utilities/initTransaction'\nimport { killTransaction } from '../../utilities/killTransaction'\nimport { deleteCollectionVersions } from '../../versions/deleteCollectionVersions'\nimport { buildAfterOperation } from './utils'\n\nexport type Arguments = {\n  collection: Collection\n  depth?: number\n  overrideAccess?: boolean\n  req: PayloadRequest\n  showHiddenFields?: boolean\n  where: Where\n}\n\nasync function deleteOperation<TSlug extends keyof GeneratedTypes['collections']>(\n  incomingArgs: Arguments,\n): Promise<{\n  docs: GeneratedTypes['collections'][TSlug][]\n  errors: {\n    id: GeneratedTypes['collections'][TSlug]['id']\n    message: string\n  }[]\n}> {\n  let args = incomingArgs\n\n  try {\n    const shouldCommit = await initTransaction(args.req)\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: 'delete',\n            req: args.req,\n          })) || args\n      },\n      Promise.resolve(),\n    )\n\n    const {\n      collection: { config: collectionConfig },\n      depth,\n      overrideAccess,\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 delete.\", httpStatus.BAD_REQUEST)\n    }\n\n    // /////////////////////////////////////\n    // Access\n    // /////////////////////////////////////\n\n    let accessResult: AccessResult\n\n    if (!overrideAccess) {\n      accessResult = await executeAccess({ req }, collectionConfig.access.delete)\n    }\n\n    await validateQueryPaths({\n      collectionConfig,\n      overrideAccess,\n      req,\n      where,\n    })\n\n    const fullWhere = combineQueries(where, accessResult)\n\n    // /////////////////////////////////////\n    // Retrieve documents\n    // /////////////////////////////////////\n\n    const { docs } = await payload.db.find<GeneratedTypes['collections'][TSlug]>({\n      collection: collectionConfig.slug,\n      locale,\n      req,\n      where: fullWhere,\n    })\n\n    const errors = []\n\n    /* eslint-disable no-param-reassign */\n    const promises = docs.map(async (doc) => {\n      let result\n\n      const { id } = doc\n\n      try {\n        // /////////////////////////////////////\n        // beforeDelete - Collection\n        // /////////////////////////////////////\n\n        await collectionConfig.hooks.beforeDelete.reduce(async (priorHook, hook) => {\n          await priorHook\n\n          return hook({\n            id,\n            collection: collectionConfig,\n            context: req.context,\n            req,\n          })\n        }, Promise.resolve())\n\n        await deleteAssociatedFiles({\n          collectionConfig,\n          config,\n          doc,\n          overrideDelete: true,\n          t,\n        })\n\n        // /////////////////////////////////////\n        // Delete versions\n        // /////////////////////////////////////\n\n        if (collectionConfig.versions) {\n          await deleteCollectionVersions({\n            id,\n            slug: collectionConfig.slug,\n            payload,\n            req,\n          })\n        }\n\n        // /////////////////////////////////////\n        // Delete document\n        // /////////////////////////////////////\n\n        await payload.db.deleteOne({\n          collection: collectionConfig.slug,\n          req,\n          where: {\n            id: {\n              equals: id,\n            },\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 || doc,\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 || doc,\n              req,\n            })) || result\n        }, Promise.resolve())\n\n        // /////////////////////////////////////\n        // afterDelete - Collection\n        // /////////////////////////////////////\n\n        await collectionConfig.hooks.afterDelete.reduce(async (priorHook, hook) => {\n          await priorHook\n\n          result =\n            (await hook({\n              id,\n              collection: collectionConfig,\n              context: req.context,\n              doc: result,\n              req,\n            })) || result\n        }, Promise.resolve())\n\n        // /////////////////////////////////////\n        // 8. Return results\n        // /////////////////////////////////////\n\n        return result\n      } catch (error) {\n        errors.push({\n          id: doc.id,\n          message: error.message,\n        })\n      }\n      return null\n    })\n\n    const awaitedDocs = await Promise.all(promises)\n\n    // /////////////////////////////////////\n    // Delete Preferences\n    // /////////////////////////////////////\n\n    await deleteUserPreferences({\n      collectionConfig,\n      ids: docs.map(({ id }) => id),\n      payload,\n      req,\n    })\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: 'delete',\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 deleteOperation\n"],"names":["deleteOperation","incomingArgs","args","shouldCommit","initTransaction","req","collection","config","hooks","beforeOperation","reduce","priorHook","hook","context","operation","Promise","resolve","collectionConfig","depth","overrideAccess","fallbackLocale","locale","payload","t","showHiddenFields","where","APIError","httpStatus","BAD_REQUEST","accessResult","executeAccess","access","delete","validateQueryPaths","fullWhere","combineQueries","docs","db","find","slug","errors","promises","map","doc","result","id","beforeDelete","deleteAssociatedFiles","overrideDelete","versions","deleteCollectionVersions","deleteOne","equals","afterRead","global","afterDelete","error","push","message","awaitedDocs","all","deleteUserPreferences","ids","filter","Boolean","buildAfterOperation","commitTransaction","killTransaction"],"mappings":"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"}