payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
197 lines (196 loc) • 23.4 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _executeAccess = /*#__PURE__*/ _interop_require_default(require("../../auth/executeAccess"));
const _combineQueries = require("../../database/combineQueries");
const _validateQueryPaths = require("../../database/queryValidation/validateQueryPaths");
const _afterRead = require("../../fields/hooks/afterRead");
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 _getQueryDraftsSort = require("../../versions/drafts/getQueryDraftsSort");
const _utils = require("./utils");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
async function find(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: 'read',
req: args.req
}) || args;
}, Promise.resolve());
const { collection: { config: collectionConfig }, collection, currentDepth, depth, disableErrors, draft: draftsEnabled, limit, overrideAccess, page, pagination = true, req: { fallbackLocale, locale, payload }, req, showHiddenFields, sort, where } = args;
// /////////////////////////////////////
// Access
// /////////////////////////////////////
let accessResult;
if (!overrideAccess) {
accessResult = await (0, _executeAccess.default)({
disableErrors,
req
}, collectionConfig.access.read);
// If errors are disabled, and access returns false, return empty results
if (accessResult === false) {
return {
docs: [],
hasNextPage: false,
hasPrevPage: false,
limit,
nextPage: null,
page: 1,
pagingCounter: 1,
prevPage: null,
totalDocs: 0,
totalPages: 1
};
}
}
// /////////////////////////////////////
// Find
// /////////////////////////////////////
const usePagination = pagination && limit !== 0;
const sanitizedLimit = limit ?? (usePagination ? 10 : 0);
const sanitizedPage = page || 1;
let result;
let fullWhere = (0, _combineQueries.combineQueries)(where, accessResult);
if (collectionConfig.versions?.drafts && draftsEnabled) {
fullWhere = (0, _appendVersionToQueryKey.appendVersionToQueryKey)(fullWhere);
await (0, _validateQueryPaths.validateQueryPaths)({
collectionConfig: collection.config,
overrideAccess,
req,
versionFields: (0, _buildCollectionFields.buildVersionCollectionFields)(collection.config),
where: fullWhere
});
result = await payload.db.queryDrafts({
collection: collectionConfig.slug,
limit: sanitizedLimit,
locale,
page: sanitizedPage,
pagination: usePagination,
req,
sort: (0, _getQueryDraftsSort.getQueryDraftsSort)(sort),
where: fullWhere
});
} else {
await (0, _validateQueryPaths.validateQueryPaths)({
collectionConfig,
overrideAccess,
req,
where
});
result = await payload.db.find({
collection: collectionConfig.slug,
limit: sanitizedLimit,
locale,
page: sanitizedPage,
pagination,
req,
sort,
where: fullWhere
});
}
// /////////////////////////////////////
// beforeRead - Collection
// /////////////////////////////////////
result = {
...result,
docs: await Promise.all(result.docs.map(async (doc)=>{
let docRef = doc;
await collectionConfig.hooks.beforeRead.reduce(async (priorHook, hook)=>{
await priorHook;
docRef = await hook({
collection: collectionConfig,
context: req.context,
doc: docRef,
query: fullWhere,
req
}) || docRef;
}, Promise.resolve());
return docRef;
}))
};
// /////////////////////////////////////
// afterRead - Fields
// /////////////////////////////////////
result = {
...result,
docs: await Promise.all(result.docs.map(async (doc)=>(0, _afterRead.afterRead)({
collection: collectionConfig,
context: req.context,
currentDepth,
depth,
doc,
fallbackLocale,
findMany: true,
global: null,
locale,
overrideAccess,
req,
showHiddenFields
})))
};
// /////////////////////////////////////
// afterRead - Collection
// /////////////////////////////////////
result = {
...result,
docs: await Promise.all(result.docs.map(async (doc)=>{
let docRef = doc;
await collectionConfig.hooks.afterRead.reduce(async (priorHook, hook)=>{
await priorHook;
docRef = await hook({
collection: collectionConfig,
context: req.context,
doc: docRef,
findMany: true,
query: fullWhere,
req
}) || doc;
}, Promise.resolve());
return docRef;
}))
};
// /////////////////////////////////////
// afterOperation - Collection
// /////////////////////////////////////
result = await (0, _utils.buildAfterOperation)({
args,
collection: collectionConfig,
operation: 'find',
result
});
// /////////////////////////////////////
// Return results
// /////////////////////////////////////
if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req);
return result;
} catch (error) {
await (0, _killTransaction.killTransaction)(args.req);
throw error;
}
}
const _default = find;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/operations/find.ts"],"sourcesContent":["import type { AccessResult } from '../../config/types'\nimport type { PaginatedDocs } from '../../database/types'\nimport type { PayloadRequest } from '../../express/types'\nimport type { Where } from '../../types'\nimport type { Collection, TypeWithID } from '../config/types'\n\nimport executeAccess from '../../auth/executeAccess'\nimport { combineQueries } from '../../database/combineQueries'\nimport { validateQueryPaths } from '../../database/queryValidation/validateQueryPaths'\nimport { afterRead } from '../../fields/hooks/afterRead'\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 { getQueryDraftsSort } from '../../versions/drafts/getQueryDraftsSort'\nimport { buildAfterOperation } from './utils'\n\nexport type Arguments = {\n  collection: Collection\n  currentDepth?: number\n  depth?: number\n  disableErrors?: boolean\n  draft?: boolean\n  limit?: number\n  overrideAccess?: boolean\n  page?: number\n  pagination?: boolean\n  req?: PayloadRequest\n  showHiddenFields?: boolean\n  sort?: string\n  where?: Where\n}\n\nasync function find<T extends TypeWithID & Record<string, unknown>>(\n  incomingArgs: Arguments,\n): Promise<PaginatedDocs<T>> {\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: 'read',\n          req: args.req,\n        })) || args\n    }, Promise.resolve())\n\n    const {\n      collection: { config: collectionConfig },\n      collection,\n      currentDepth,\n      depth,\n      disableErrors,\n      draft: draftsEnabled,\n      limit,\n      overrideAccess,\n      page,\n      pagination = true,\n      req: { fallbackLocale, locale, payload },\n      req,\n      showHiddenFields,\n      sort,\n      where,\n    } = args\n\n    // /////////////////////////////////////\n    // Access\n    // /////////////////////////////////////\n\n    let accessResult: AccessResult\n\n    if (!overrideAccess) {\n      accessResult = await executeAccess({ disableErrors, req }, collectionConfig.access.read)\n\n      // If errors are disabled, and access returns false, return empty results\n      if (accessResult === false) {\n        return {\n          docs: [],\n          hasNextPage: false,\n          hasPrevPage: false,\n          limit,\n          nextPage: null,\n          page: 1,\n          pagingCounter: 1,\n          prevPage: null,\n          totalDocs: 0,\n          totalPages: 1,\n        }\n      }\n    }\n\n    // /////////////////////////////////////\n    // Find\n    // /////////////////////////////////////\n\n    const usePagination = pagination && limit !== 0\n    const sanitizedLimit = limit ?? (usePagination ? 10 : 0)\n    const sanitizedPage = page || 1\n\n    let result: PaginatedDocs<T>\n\n    let fullWhere = combineQueries(where, accessResult)\n\n    if (collectionConfig.versions?.drafts && draftsEnabled) {\n      fullWhere = appendVersionToQueryKey(fullWhere)\n\n      await validateQueryPaths({\n        collectionConfig: collection.config,\n        overrideAccess,\n        req,\n        versionFields: buildVersionCollectionFields(collection.config),\n        where: fullWhere,\n      })\n\n      result = await payload.db.queryDrafts<T>({\n        collection: collectionConfig.slug,\n        limit: sanitizedLimit,\n        locale,\n        page: sanitizedPage,\n        pagination: usePagination,\n        req,\n        sort: getQueryDraftsSort(sort),\n        where: fullWhere,\n      })\n    } else {\n      await validateQueryPaths({\n        collectionConfig,\n        overrideAccess,\n        req,\n        where,\n      })\n\n      result = await payload.db.find<T>({\n        collection: collectionConfig.slug,\n        limit: sanitizedLimit,\n        locale,\n        page: sanitizedPage,\n        pagination,\n        req,\n        sort,\n        where: fullWhere,\n      })\n    }\n\n    // /////////////////////////////////////\n    // beforeRead - Collection\n    // /////////////////////////////////////\n\n    result = {\n      ...result,\n      docs: await Promise.all(\n        result.docs.map(async (doc) => {\n          let docRef = doc\n\n          await collectionConfig.hooks.beforeRead.reduce(async (priorHook, hook) => {\n            await priorHook\n\n            docRef =\n              (await hook({\n                collection: collectionConfig,\n                context: req.context,\n                doc: docRef,\n                query: fullWhere,\n                req,\n              })) || docRef\n          }, Promise.resolve())\n\n          return docRef\n        }),\n      ),\n    }\n\n    // /////////////////////////////////////\n    // afterRead - Fields\n    // /////////////////////////////////////\n\n    result = {\n      ...result,\n      docs: await Promise.all(\n        result.docs.map(async (doc) =>\n          afterRead<T>({\n            collection: collectionConfig,\n            context: req.context,\n            currentDepth,\n            depth,\n            doc,\n            fallbackLocale,\n            findMany: true,\n            global: null,\n            locale,\n            overrideAccess,\n            req,\n            showHiddenFields,\n          }),\n        ),\n      ),\n    }\n\n    // /////////////////////////////////////\n    // afterRead - Collection\n    // /////////////////////////////////////\n\n    result = {\n      ...result,\n      docs: await Promise.all(\n        result.docs.map(async (doc) => {\n          let docRef = doc\n\n          await collectionConfig.hooks.afterRead.reduce(async (priorHook, hook) => {\n            await priorHook\n\n            docRef =\n              (await hook({\n                collection: collectionConfig,\n                context: req.context,\n                doc: docRef,\n                findMany: true,\n                query: fullWhere,\n                req,\n              })) || doc\n          }, Promise.resolve())\n\n          return docRef\n        }),\n      ),\n    }\n\n    // /////////////////////////////////////\n    // afterOperation - Collection\n    // /////////////////////////////////////\n\n    result = await buildAfterOperation<T>({\n      args,\n      collection: collectionConfig,\n      operation: 'find',\n      result,\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 find\n"],"names":["find","incomingArgs","args","shouldCommit","initTransaction","req","collection","config","hooks","beforeOperation","reduce","priorHook","hook","context","operation","Promise","resolve","collectionConfig","currentDepth","depth","disableErrors","draft","draftsEnabled","limit","overrideAccess","page","pagination","fallbackLocale","locale","payload","showHiddenFields","sort","where","accessResult","executeAccess","access","read","docs","hasNextPage","hasPrevPage","nextPage","pagingCounter","prevPage","totalDocs","totalPages","usePagination","sanitizedLimit","sanitizedPage","result","fullWhere","combineQueries","versions","drafts","appendVersionToQueryKey","validateQueryPaths","versionFields","buildVersionCollectionFields","db","queryDrafts","slug","getQueryDraftsSort","all","map","doc","docRef","beforeRead","query","afterRead","findMany","global","buildAfterOperation","commitTransaction","error","killTransaction"],"mappings":"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"}