UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

175 lines (174 loc) • 19.9 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 _httpstatus = /*#__PURE__*/ _interop_require_default(require("http-status")); const _executeAccess = /*#__PURE__*/ _interop_require_default(require("../../auth/executeAccess")); 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 _commitTransaction = require("../../utilities/commitTransaction"); const _initTransaction = require("../../utilities/initTransaction"); const _killTransaction = require("../../utilities/killTransaction"); const _getLatestCollectionVersion = require("../../versions/getLatestCollectionVersion"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } async function restoreVersion(args) { const { id, collection: { config: collectionConfig }, depth, overrideAccess = false, req, req: { fallbackLocale, locale, payload, t }, showHiddenFields } = args; try { const shouldCommit = await (0, _initTransaction.initTransaction)(req); if (!id) { throw new _errors.APIError('Missing ID of version to restore.', _httpstatus.default.BAD_REQUEST); } // ///////////////////////////////////// // Retrieve original raw version // ///////////////////////////////////// const { docs: versionDocs } = await req.payload.db.findVersions({ collection: collectionConfig.slug, limit: 1, locale, req, where: { id: { equals: id } } }); const [rawVersion] = versionDocs; if (!rawVersion) { throw new _errors.NotFound(t); } const parentDocID = rawVersion.parent; // ///////////////////////////////////// // Access // ///////////////////////////////////// const accessResults = !overrideAccess ? await (0, _executeAccess.default)({ id: parentDocID, 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: parentDocID } }, accessResults) }; const doc = await req.payload.db.findOne(findOneArgs); if (!doc && !hasWherePolicy) throw new _errors.NotFound(t); if (!doc && hasWherePolicy) throw new _errors.Forbidden(t); // ///////////////////////////////////// // fetch previousDoc // ///////////////////////////////////// const prevDocWithLocales = await (0, _getLatestCollectionVersion.getLatestCollectionVersion)({ id: parentDocID, config: collectionConfig, payload, query: findOneArgs, req }); // ///////////////////////////////////// // Update // ///////////////////////////////////// let result = await req.payload.db.updateOne({ id: parentDocID, collection: collectionConfig.slug, data: rawVersion.version, req }); // ///////////////////////////////////// // Save `previousDoc` as a version after restoring // ///////////////////////////////////// const prevVersion = { ...prevDocWithLocales }; delete prevVersion.id; await payload.db.createVersion({ autosave: false, collectionSlug: collectionConfig.slug, createdAt: prevVersion.createdAt, parent: parentDocID, req, updatedAt: new Date().toISOString(), versionData: rawVersion.version }); // ///////////////////////////////////// // 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: result, doc: result, global: null, operation: 'update', previousDoc: prevDocWithLocales, 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: prevDocWithLocales, req }) || result; }, Promise.resolve()); if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req); return result; } catch (error) { await (0, _killTransaction.killTransaction)(req); throw error; } } const _default = restoreVersion; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/operations/restoreVersion.ts"],"sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport httpStatus from 'http-status'\n\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 { 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 { commitTransaction } from '../../utilities/commitTransaction'\nimport { initTransaction } from '../../utilities/initTransaction'\nimport { killTransaction } from '../../utilities/killTransaction'\nimport { getLatestCollectionVersion } from '../../versions/getLatestCollectionVersion'\n\nexport type Arguments = {\n  collection: Collection\n  currentDepth?: number\n  depth?: number\n  disableErrors?: boolean\n  id: number | string\n  overrideAccess?: boolean\n  req: PayloadRequest\n  showHiddenFields?: boolean\n}\n\nasync function restoreVersion<T extends TypeWithID = any>(args: Arguments): Promise<T> {\n  const {\n    id,\n    collection: { config: collectionConfig },\n    depth,\n    overrideAccess = false,\n    req,\n    req: { fallbackLocale, locale, payload, t },\n    showHiddenFields,\n  } = args\n\n  try {\n    const shouldCommit = await initTransaction(req)\n\n    if (!id) {\n      throw new APIError('Missing ID of version to restore.', httpStatus.BAD_REQUEST)\n    }\n\n    // /////////////////////////////////////\n    // Retrieve original raw version\n    // /////////////////////////////////////\n\n    const { docs: versionDocs } = await req.payload.db.findVersions({\n      collection: collectionConfig.slug,\n      limit: 1,\n      locale,\n      req,\n      where: { id: { equals: id } },\n    })\n\n    const [rawVersion] = versionDocs\n\n    if (!rawVersion) {\n      throw new NotFound(t)\n    }\n\n    const parentDocID = rawVersion.parent\n\n    // /////////////////////////////////////\n    // Access\n    // /////////////////////////////////////\n\n    const accessResults = !overrideAccess\n      ? await executeAccess({ id: parentDocID, 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: parentDocID } }, accessResults),\n    }\n\n    const doc = await req.payload.db.findOne(findOneArgs)\n\n    if (!doc && !hasWherePolicy) throw new NotFound(t)\n    if (!doc && hasWherePolicy) throw new Forbidden(t)\n\n    // /////////////////////////////////////\n    // fetch previousDoc\n    // /////////////////////////////////////\n\n    const prevDocWithLocales = await getLatestCollectionVersion({\n      id: parentDocID,\n      config: collectionConfig,\n      payload,\n      query: findOneArgs,\n      req,\n    })\n\n    // /////////////////////////////////////\n    // Update\n    // /////////////////////////////////////\n\n    let result = await req.payload.db.updateOne({\n      id: parentDocID,\n      collection: collectionConfig.slug,\n      data: rawVersion.version,\n      req,\n    })\n\n    // /////////////////////////////////////\n    // Save `previousDoc` as a version after restoring\n    // /////////////////////////////////////\n\n    const prevVersion = { ...prevDocWithLocales }\n\n    delete prevVersion.id\n\n    await payload.db.createVersion({\n      autosave: false,\n      collectionSlug: collectionConfig.slug,\n      createdAt: prevVersion.createdAt,\n      parent: parentDocID,\n      req,\n      updatedAt: new Date().toISOString(),\n      versionData: rawVersion.version,\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({\n      collection: collectionConfig,\n      context: req.context,\n      data: result,\n      doc: result,\n      global: null,\n      operation: 'update',\n      previousDoc: prevDocWithLocales,\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: prevDocWithLocales,\n          req,\n        })) || result\n    }, Promise.resolve())\n\n    if (shouldCommit) await commitTransaction(req)\n\n    return result\n  } catch (error: unknown) {\n    await killTransaction(req)\n    throw error\n  }\n}\n\nexport default restoreVersion\n"],"names":["restoreVersion","args","id","collection","config","collectionConfig","depth","overrideAccess","req","fallbackLocale","locale","payload","t","showHiddenFields","shouldCommit","initTransaction","APIError","httpStatus","BAD_REQUEST","docs","versionDocs","db","findVersions","slug","limit","where","equals","rawVersion","NotFound","parentDocID","parent","accessResults","executeAccess","access","update","hasWherePolicy","hasWhereAccessResult","findOneArgs","combineQueries","doc","findOne","Forbidden","prevDocWithLocales","getLatestCollectionVersion","query","result","updateOne","data","version","prevVersion","createVersion","autosave","collectionSlug","createdAt","updatedAt","Date","toISOString","versionData","afterRead","context","global","hooks","reduce","priorHook","hook","Promise","resolve","afterChange","operation","previousDoc","commitTransaction","error","killTransaction"],"mappings":"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"}