payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
120 lines (119 loc) • 14.1 kB
JavaScript
/* 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 _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");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
async function findVersionByID(args) {
const { id, collection: { config: collectionConfig }, currentDepth, depth, disableErrors, overrideAccess, req: { fallbackLocale, locale, payload, t }, req, showHiddenFields } = args;
if (!id) {
throw new _errors.APIError('Missing ID of version.', _httpstatus.default.BAD_REQUEST);
}
try {
const shouldCommit = await (0, _initTransaction.initTransaction)(req);
// /////////////////////////////////////
// Access
// /////////////////////////////////////
const accessResults = !overrideAccess ? await (0, _executeAccess.default)({
id,
disableErrors,
req
}, collectionConfig.access.readVersions) : true;
// If errors are disabled, and access returns false, return null
if (accessResults === false) return null;
const hasWhereAccess = typeof accessResults === 'object';
const fullWhere = (0, _combineQueries.combineQueries)({
id: {
equals: id
}
}, accessResults);
// /////////////////////////////////////
// Find by ID
// /////////////////////////////////////
const versionsQuery = await payload.db.findVersions({
collection: collectionConfig.slug,
limit: 1,
locale,
pagination: false,
req,
where: fullWhere
});
const result = versionsQuery.docs[0];
if (!result) {
if (!disableErrors) {
if (!hasWhereAccess) throw new _errors.NotFound(t);
if (hasWhereAccess) throw new _errors.Forbidden(t);
}
return null;
}
// /////////////////////////////////////
// beforeRead - Collection
// /////////////////////////////////////
await collectionConfig.hooks.beforeRead.reduce(async (priorHook, hook)=>{
await priorHook;
result.version = await hook({
collection: collectionConfig,
context: req.context,
doc: result.version,
query: fullWhere,
req
}) || result.version;
}, Promise.resolve());
// /////////////////////////////////////
// afterRead - Fields
// /////////////////////////////////////
result.version = await (0, _afterRead.afterRead)({
collection: collectionConfig,
context: req.context,
currentDepth,
depth,
doc: result.version,
fallbackLocale,
global: null,
locale,
overrideAccess,
req,
showHiddenFields
});
// /////////////////////////////////////
// afterRead - Collection
// /////////////////////////////////////
await collectionConfig.hooks.afterRead.reduce(async (priorHook, hook)=>{
await priorHook;
result.version = await hook({
collection: collectionConfig,
context: req.context,
doc: result.version,
query: fullWhere,
req
}) || result.version;
}, Promise.resolve());
// /////////////////////////////////////
// Return results
// /////////////////////////////////////
if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req);
return result;
} catch (error) {
await (0, _killTransaction.killTransaction)(req);
throw error;
}
}
const _default = findVersionByID;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/operations/findVersionByID.ts"],"sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport httpStatus from 'http-status'\n\nimport type { PayloadRequest } from '../../express/types'\nimport type { TypeWithVersion } from '../../versions/types'\nimport type { Collection, TypeWithID } from '../config/types'\n\nimport executeAccess from '../../auth/executeAccess'\nimport { combineQueries } from '../../database/combineQueries'\nimport { APIError, Forbidden, NotFound } from '../../errors'\nimport { afterRead } from '../../fields/hooks/afterRead'\nimport { commitTransaction } from '../../utilities/commitTransaction'\nimport { initTransaction } from '../../utilities/initTransaction'\nimport { killTransaction } from '../../utilities/killTransaction'\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 findVersionByID<T extends TypeWithID = any>(\n  args: Arguments,\n): Promise<TypeWithVersion<T>> {\n  const {\n    id,\n    collection: { config: collectionConfig },\n    currentDepth,\n    depth,\n    disableErrors,\n    overrideAccess,\n    req: { fallbackLocale, locale, payload, t },\n    req,\n    showHiddenFields,\n  } = args\n\n  if (!id) {\n    throw new APIError('Missing ID of version.', httpStatus.BAD_REQUEST)\n  }\n\n  try {\n    const shouldCommit = await initTransaction(req)\n\n    // /////////////////////////////////////\n    // Access\n    // /////////////////////////////////////\n\n    const accessResults = !overrideAccess\n      ? await executeAccess({ id, disableErrors, req }, collectionConfig.access.readVersions)\n      : true\n\n    // If errors are disabled, and access returns false, return null\n    if (accessResults === false) return null\n\n    const hasWhereAccess = typeof accessResults === 'object'\n\n    const fullWhere = combineQueries({ id: { equals: id } }, accessResults)\n\n    // /////////////////////////////////////\n    // Find by ID\n    // /////////////////////////////////////\n\n    const versionsQuery = await payload.db.findVersions<T>({\n      collection: collectionConfig.slug,\n      limit: 1,\n      locale,\n      pagination: false,\n      req,\n      where: fullWhere,\n    })\n\n    const result = versionsQuery.docs[0]\n\n    if (!result) {\n      if (!disableErrors) {\n        if (!hasWhereAccess) throw new NotFound(t)\n        if (hasWhereAccess) throw new Forbidden(t)\n      }\n\n      return null\n    }\n\n    // /////////////////////////////////////\n    // beforeRead - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.beforeRead.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      result.version =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          doc: result.version,\n          query: fullWhere,\n          req,\n        })) || result.version\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // afterRead - Fields\n    // /////////////////////////////////////\n\n    result.version = await afterRead({\n      collection: collectionConfig,\n      context: req.context,\n      currentDepth,\n      depth,\n      doc: result.version,\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.version =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          doc: result.version,\n          query: fullWhere,\n          req,\n        })) || result.version\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // Return results\n    // /////////////////////////////////////\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 findVersionByID\n"],"names":["findVersionByID","args","id","collection","config","collectionConfig","currentDepth","depth","disableErrors","overrideAccess","req","fallbackLocale","locale","payload","t","showHiddenFields","APIError","httpStatus","BAD_REQUEST","shouldCommit","initTransaction","accessResults","executeAccess","access","readVersions","hasWhereAccess","fullWhere","combineQueries","equals","versionsQuery","db","findVersions","slug","limit","pagination","where","result","docs","NotFound","Forbidden","hooks","beforeRead","reduce","priorHook","hook","version","context","doc","query","Promise","resolve","afterRead","global","commitTransaction","error","killTransaction"],"mappings":"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"}