UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

454 lines (453 loc) • 49.2 kB
/* eslint-disable no-param-reassign */ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "promise", { enumerable: true, get: function() { return promise; } }); const _types = require("../../config/types"); const _getDefaultValue = /*#__PURE__*/ _interop_require_default(require("../../getDefaultValue")); const _relationshipPopulationPromise = /*#__PURE__*/ _interop_require_default(require("./relationshipPopulationPromise")); const _traverseFields = require("./traverseFields"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const promise = async ({ collection, context, currentDepth, depth, doc, fallbackLocale, field, fieldPromises, findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc, triggerAccessControl = true, triggerHooks = true })=>{ if ((0, _types.fieldAffectsData)(field) && field.hidden && typeof siblingDoc[field.name] !== 'undefined' && !showHiddenFields) { delete siblingDoc[field.name]; } const shouldHoistLocalizedValue = flattenLocales && (0, _types.fieldAffectsData)(field) && typeof siblingDoc[field.name] === 'object' && siblingDoc[field.name] !== null && field.localized && locale !== 'all' && req.payload.config.localization; if (shouldHoistLocalizedValue) { // replace actual value with localized value before sanitizing // { [locale]: fields } -> fields const value = siblingDoc[field.name][locale]; let hoistedValue = value; if (fallbackLocale && fallbackLocale !== locale) { const fallbackValue = siblingDoc[field.name][fallbackLocale]; const isNullOrUndefined = typeof value === 'undefined' || value === null; if (fallbackValue) { switch(field.type){ case 'text': case 'textarea': { if (value === '' || isNullOrUndefined) { hoistedValue = fallbackValue; } break; } default: { if (isNullOrUndefined) { hoistedValue = fallbackValue; } break; } } } } siblingDoc[field.name] = hoistedValue; } // Sanitize outgoing field value switch(field.type){ case 'group': { // Fill groups with empty objects so fields with hooks within groups can populate // themselves virtually as necessary if (typeof siblingDoc[field.name] === 'undefined') { siblingDoc[field.name] = {}; } break; } case 'tabs': { field.tabs.forEach((tab)=>{ if ((0, _types.tabHasName)(tab) && (typeof siblingDoc[tab.name] === 'undefined' || siblingDoc[tab.name] === null)) { siblingDoc[tab.name] = {}; } }); break; } case 'richText': { const editor = field?.editor; // This is run here AND in the GraphQL Resolver if (editor?.populationPromise) { const populationPromise = editor.populationPromise({ context, currentDepth, depth, field, findMany, flattenLocales, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc }); if (populationPromise) { populationPromises.push(populationPromise); } } // This is only run here, independent of depth if (editor?.afterReadPromise) { const afterReadPromise = editor?.afterReadPromise({ field, incomingEditorState: siblingDoc[field.name], siblingDoc }); if (afterReadPromise) { populationPromises.push(afterReadPromise); } } break; } case 'point': { const pointDoc = siblingDoc[field.name]; if (Array.isArray(pointDoc?.coordinates) && pointDoc.coordinates.length === 2) { siblingDoc[field.name] = pointDoc.coordinates; } else { siblingDoc[field.name] = undefined; } break; } default: { break; } } if ((0, _types.fieldAffectsData)(field)) { // Execute hooks if (triggerHooks && field.hooks?.afterRead) { await field.hooks.afterRead.reduce(async (priorHook, currentHook)=>{ await priorHook; const shouldRunHookOnAllLocales = field.localized && (locale === 'all' || !flattenLocales) && typeof siblingDoc[field.name] === 'object'; if (shouldRunHookOnAllLocales) { const hookPromises = Object.entries(siblingDoc[field.name]).map(([locale, value])=>(async ()=>{ const hookedValue = await currentHook({ collection, context, data: doc, field, global, operation: 'read', originalDoc: doc, req, siblingData: siblingDoc, value }); if (hookedValue !== undefined) { siblingDoc[field.name][locale] = hookedValue; } })()); await Promise.all(hookPromises); } else { const hookedValue = await currentHook({ collection, context, data: doc, field, findMany, global, operation: 'read', originalDoc: doc, req, siblingData: siblingDoc, value: siblingDoc[field.name] }); if (hookedValue !== undefined) { siblingDoc[field.name] = hookedValue; } } }, Promise.resolve()); } // Execute access control let allowDefaultValue = true; if (triggerAccessControl && field.access && field.access.read) { const result = overrideAccess ? true : await field.access.read({ id: doc.id, data: doc, doc, req, siblingData: siblingDoc }); if (!result) { allowDefaultValue = false; delete siblingDoc[field.name]; } } // Set defaultValue on the field for globals being returned without being first created // or collection documents created prior to having a default if (allowDefaultValue && typeof siblingDoc[field.name] === 'undefined' && typeof field.defaultValue !== 'undefined') { siblingDoc[field.name] = await (0, _getDefaultValue.default)({ defaultValue: field.defaultValue, locale, user: req.user, value: siblingDoc[field.name] }); } if (field.type === 'relationship' || field.type === 'upload') { populationPromises.push((0, _relationshipPopulationPromise.default)({ currentDepth, depth, fallbackLocale, field, locale, overrideAccess, req, showHiddenFields, siblingDoc })); } } switch(field.type){ case 'group': { let groupDoc = siblingDoc[field.name]; if (typeof siblingDoc[field.name] !== 'object') groupDoc = {}; (0, _traverseFields.traverseFields)({ collection, context, currentDepth, depth, doc, fallbackLocale, fieldPromises, fields: field.fields, findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc: groupDoc, triggerAccessControl, triggerHooks }); break; } case 'array': { const rows = siblingDoc[field.name]; if (Array.isArray(rows)) { rows.forEach((row)=>{ (0, _traverseFields.traverseFields)({ collection, context, currentDepth, depth, doc, fallbackLocale, fieldPromises, fields: field.fields, findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc: row || {}, triggerAccessControl, triggerHooks }); }); } else if (!shouldHoistLocalizedValue && typeof rows === 'object' && rows !== null) { Object.values(rows).forEach((localeRows)=>{ if (Array.isArray(localeRows)) { localeRows.forEach((row)=>{ (0, _traverseFields.traverseFields)({ collection, context, currentDepth, depth, doc, fallbackLocale, fieldPromises, fields: field.fields, findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc: row || {}, triggerAccessControl, triggerHooks }); }); } }); } else { siblingDoc[field.name] = []; } break; } case 'blocks': { const rows = siblingDoc[field.name]; if (Array.isArray(rows)) { rows.forEach((row)=>{ const block = field.blocks.find((blockType)=>blockType.slug === row.blockType); if (block) { (0, _traverseFields.traverseFields)({ collection, context, currentDepth, depth, doc, fallbackLocale, fieldPromises, fields: block.fields, findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc: row || {}, triggerAccessControl, triggerHooks }); } }); } else if (!shouldHoistLocalizedValue && typeof rows === 'object' && rows !== null) { Object.values(rows).forEach((localeRows)=>{ if (Array.isArray(localeRows)) { localeRows.forEach((row)=>{ const block = field.blocks.find((blockType)=>blockType.slug === row.blockType); if (block) { (0, _traverseFields.traverseFields)({ collection, context, currentDepth, depth, doc, fallbackLocale, fieldPromises, fields: block.fields, findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc: row || {}, triggerAccessControl, triggerHooks }); } }); } }); } else { siblingDoc[field.name] = []; } break; } case 'row': case 'collapsible': { (0, _traverseFields.traverseFields)({ collection, context, currentDepth, depth, doc, fallbackLocale, fieldPromises, fields: field.fields, findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc, triggerAccessControl, triggerHooks }); break; } case 'tab': { let tabDoc = siblingDoc; if ((0, _types.tabHasName)(field)) { tabDoc = siblingDoc[field.name]; if (typeof siblingDoc[field.name] !== 'object') tabDoc = {}; } (0, _traverseFields.traverseFields)({ collection, context, currentDepth, depth, doc, fallbackLocale, fieldPromises, fields: field.fields, findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc: tabDoc, triggerAccessControl, triggerHooks }); break; } case 'tabs': { (0, _traverseFields.traverseFields)({ collection, context, currentDepth, depth, doc, fallbackLocale, fieldPromises, fields: field.tabs.map((tab)=>({ ...tab, type: 'tab' })), findMany, flattenLocales, global, locale, overrideAccess, populationPromises, req, showHiddenFields, siblingDoc, triggerAccessControl, triggerHooks }); break; } default: { break; } } }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../src/fields/hooks/afterRead/promise.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { RichTextAdapter } from '../../../admin/components/forms/field-types/RichText/types'\nimport type { SanitizedCollectionConfig } from '../../../collections/config/types'\nimport type { PayloadRequest, RequestContext } from '../../../express/types'\nimport type { SanitizedGlobalConfig } from '../../../globals/config/types'\nimport type { Field, TabAsField } from '../../config/types'\n\nimport { fieldAffectsData, tabHasName } from '../../config/types'\nimport getValueWithDefault from '../../getDefaultValue'\nimport relationshipPopulationPromise from './relationshipPopulationPromise'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  collection: SanitizedCollectionConfig | null\n  context: RequestContext\n  currentDepth: number\n  depth: number\n  doc: Record<string, unknown>\n  fallbackLocale: null | string\n  field: Field | TabAsField\n  fieldPromises: Promise<void>[]\n  findMany: boolean\n  flattenLocales: boolean\n  global: SanitizedGlobalConfig | null\n  locale: null | string\n  overrideAccess: boolean\n  populationPromises: Promise<void>[]\n  req: PayloadRequest\n  showHiddenFields: boolean\n  siblingDoc: Record<string, unknown>\n  triggerAccessControl?: boolean\n  triggerHooks?: boolean\n}\n\n// This function is responsible for the following actions, in order:\n// - Remove hidden fields from response\n// - Flatten locales into requested locale\n// - Sanitize outgoing data (point field, etc.)\n// - Execute field hooks\n// - Execute read access control\n// - Populate relationships\n\nexport const promise = async ({\n  collection,\n  context,\n  currentDepth,\n  depth,\n  doc,\n  fallbackLocale,\n  field,\n  fieldPromises,\n  findMany,\n  flattenLocales,\n  global,\n  locale,\n  overrideAccess,\n  populationPromises,\n  req,\n  showHiddenFields,\n  siblingDoc,\n  triggerAccessControl = true,\n  triggerHooks = true,\n}: Args): Promise<void> => {\n  if (\n    fieldAffectsData(field) &&\n    field.hidden &&\n    typeof siblingDoc[field.name] !== 'undefined' &&\n    !showHiddenFields\n  ) {\n    delete siblingDoc[field.name]\n  }\n\n  const shouldHoistLocalizedValue =\n    flattenLocales &&\n    fieldAffectsData(field) &&\n    typeof siblingDoc[field.name] === 'object' &&\n    siblingDoc[field.name] !== null &&\n    field.localized &&\n    locale !== 'all' &&\n    req.payload.config.localization\n\n  if (shouldHoistLocalizedValue) {\n    // replace actual value with localized value before sanitizing\n    // { [locale]: fields } -> fields\n    const value = siblingDoc[field.name][locale]\n\n    let hoistedValue = value\n\n    if (fallbackLocale && fallbackLocale !== locale) {\n      const fallbackValue = siblingDoc[field.name][fallbackLocale]\n      const isNullOrUndefined = typeof value === 'undefined' || value === null\n\n      if (fallbackValue) {\n        switch (field.type) {\n          case 'text':\n          case 'textarea': {\n            if (value === '' || isNullOrUndefined) {\n              hoistedValue = fallbackValue\n            }\n            break\n          }\n\n          default: {\n            if (isNullOrUndefined) {\n              hoistedValue = fallbackValue\n            }\n            break\n          }\n        }\n      }\n    }\n\n    siblingDoc[field.name] = hoistedValue\n  }\n\n  // Sanitize outgoing field value\n  switch (field.type) {\n    case 'group': {\n      // Fill groups with empty objects so fields with hooks within groups can populate\n      // themselves virtually as necessary\n      if (typeof siblingDoc[field.name] === 'undefined') {\n        siblingDoc[field.name] = {}\n      }\n\n      break\n    }\n    case 'tabs': {\n      field.tabs.forEach((tab) => {\n        if (\n          tabHasName(tab) &&\n          (typeof siblingDoc[tab.name] === 'undefined' || siblingDoc[tab.name] === null)\n        ) {\n          siblingDoc[tab.name] = {}\n        }\n      })\n\n      break\n    }\n\n    case 'richText': {\n      const editor: RichTextAdapter = field?.editor\n      // This is run here AND in the GraphQL Resolver\n      if (editor?.populationPromise) {\n        const populationPromise = editor.populationPromise({\n          context,\n          currentDepth,\n          depth,\n          field,\n          findMany,\n          flattenLocales,\n          overrideAccess,\n          populationPromises,\n          req,\n          showHiddenFields,\n          siblingDoc,\n        })\n\n        if (populationPromise) {\n          populationPromises.push(populationPromise)\n        }\n      }\n\n      // This is only run here, independent of depth\n      if (editor?.afterReadPromise) {\n        const afterReadPromise = editor?.afterReadPromise({\n          field,\n          incomingEditorState: siblingDoc[field.name] as object,\n          siblingDoc,\n        })\n\n        if (afterReadPromise) {\n          populationPromises.push(afterReadPromise)\n        }\n      }\n\n      break\n    }\n\n    case 'point': {\n      const pointDoc = siblingDoc[field.name] as Record<string, unknown>\n      if (Array.isArray(pointDoc?.coordinates) && pointDoc.coordinates.length === 2) {\n        siblingDoc[field.name] = pointDoc.coordinates\n      } else {\n        siblingDoc[field.name] = undefined\n      }\n\n      break\n    }\n\n    default: {\n      break\n    }\n  }\n\n  if (fieldAffectsData(field)) {\n    // Execute hooks\n    if (triggerHooks && field.hooks?.afterRead) {\n      await field.hooks.afterRead.reduce(async (priorHook, currentHook) => {\n        await priorHook\n\n        const shouldRunHookOnAllLocales =\n          field.localized &&\n          (locale === 'all' || !flattenLocales) &&\n          typeof siblingDoc[field.name] === 'object'\n\n        if (shouldRunHookOnAllLocales) {\n          const hookPromises = Object.entries(siblingDoc[field.name]).map(([locale, value]) =>\n            (async () => {\n              const hookedValue = await currentHook({\n                collection,\n                context,\n                data: doc,\n                field,\n                global,\n                operation: 'read',\n                originalDoc: doc,\n                req,\n                siblingData: siblingDoc,\n                value,\n              })\n\n              if (hookedValue !== undefined) {\n                siblingDoc[field.name][locale] = hookedValue\n              }\n            })(),\n          )\n\n          await Promise.all(hookPromises)\n        } else {\n          const hookedValue = await currentHook({\n            collection,\n            context,\n            data: doc,\n            field,\n            findMany,\n            global,\n            operation: 'read',\n            originalDoc: doc,\n            req,\n            siblingData: siblingDoc,\n            value: siblingDoc[field.name],\n          })\n\n          if (hookedValue !== undefined) {\n            siblingDoc[field.name] = hookedValue\n          }\n        }\n      }, Promise.resolve())\n    }\n\n    // Execute access control\n    let allowDefaultValue = true\n    if (triggerAccessControl && field.access && field.access.read) {\n      const result = overrideAccess\n        ? true\n        : await field.access.read({\n            id: doc.id as number | string,\n            data: doc,\n            doc,\n            req,\n            siblingData: siblingDoc,\n          })\n\n      if (!result) {\n        allowDefaultValue = false\n        delete siblingDoc[field.name]\n      }\n    }\n\n    // Set defaultValue on the field for globals being returned without being first created\n    // or collection documents created prior to having a default\n    if (\n      allowDefaultValue &&\n      typeof siblingDoc[field.name] === 'undefined' &&\n      typeof field.defaultValue !== 'undefined'\n    ) {\n      siblingDoc[field.name] = await getValueWithDefault({\n        defaultValue: field.defaultValue,\n        locale,\n        user: req.user,\n        value: siblingDoc[field.name],\n      })\n    }\n\n    if (field.type === 'relationship' || field.type === 'upload') {\n      populationPromises.push(\n        relationshipPopulationPromise({\n          currentDepth,\n          depth,\n          fallbackLocale,\n          field,\n          locale,\n          overrideAccess,\n          req,\n          showHiddenFields,\n          siblingDoc,\n        }),\n      )\n    }\n  }\n\n  switch (field.type) {\n    case 'group': {\n      let groupDoc = siblingDoc[field.name] as Record<string, unknown>\n      if (typeof siblingDoc[field.name] !== 'object') groupDoc = {}\n\n      traverseFields({\n        collection,\n        context,\n        currentDepth,\n        depth,\n        doc,\n        fallbackLocale,\n        fieldPromises,\n        fields: field.fields,\n        findMany,\n        flattenLocales,\n        global,\n        locale,\n        overrideAccess,\n        populationPromises,\n        req,\n        showHiddenFields,\n        siblingDoc: groupDoc,\n        triggerAccessControl,\n        triggerHooks,\n      })\n\n      break\n    }\n\n    case 'array': {\n      const rows = siblingDoc[field.name]\n\n      if (Array.isArray(rows)) {\n        rows.forEach((row) => {\n          traverseFields({\n            collection,\n            context,\n            currentDepth,\n            depth,\n            doc,\n            fallbackLocale,\n            fieldPromises,\n            fields: field.fields,\n            findMany,\n            flattenLocales,\n            global,\n            locale,\n            overrideAccess,\n            populationPromises,\n            req,\n            showHiddenFields,\n            siblingDoc: row || {},\n            triggerAccessControl,\n            triggerHooks,\n          })\n        })\n      } else if (!shouldHoistLocalizedValue && typeof rows === 'object' && rows !== null) {\n        Object.values(rows).forEach((localeRows) => {\n          if (Array.isArray(localeRows)) {\n            localeRows.forEach((row) => {\n              traverseFields({\n                collection,\n                context,\n                currentDepth,\n                depth,\n                doc,\n                fallbackLocale,\n                fieldPromises,\n                fields: field.fields,\n                findMany,\n                flattenLocales,\n                global,\n                locale,\n                overrideAccess,\n                populationPromises,\n                req,\n                showHiddenFields,\n                siblingDoc: row || {},\n                triggerAccessControl,\n                triggerHooks,\n              })\n            })\n          }\n        })\n      } else {\n        siblingDoc[field.name] = []\n      }\n      break\n    }\n\n    case 'blocks': {\n      const rows = siblingDoc[field.name]\n\n      if (Array.isArray(rows)) {\n        rows.forEach((row) => {\n          const block = field.blocks.find((blockType) => blockType.slug === row.blockType)\n\n          if (block) {\n            traverseFields({\n              collection,\n              context,\n              currentDepth,\n              depth,\n              doc,\n              fallbackLocale,\n              fieldPromises,\n              fields: block.fields,\n              findMany,\n              flattenLocales,\n              global,\n              locale,\n              overrideAccess,\n              populationPromises,\n              req,\n              showHiddenFields,\n              siblingDoc: row || {},\n              triggerAccessControl,\n              triggerHooks,\n            })\n          }\n        })\n      } else if (!shouldHoistLocalizedValue && typeof rows === 'object' && rows !== null) {\n        Object.values(rows).forEach((localeRows) => {\n          if (Array.isArray(localeRows)) {\n            localeRows.forEach((row) => {\n              const block = field.blocks.find((blockType) => blockType.slug === row.blockType)\n\n              if (block) {\n                traverseFields({\n                  collection,\n                  context,\n                  currentDepth,\n                  depth,\n                  doc,\n                  fallbackLocale,\n                  fieldPromises,\n                  fields: block.fields,\n                  findMany,\n                  flattenLocales,\n                  global,\n                  locale,\n                  overrideAccess,\n                  populationPromises,\n                  req,\n                  showHiddenFields,\n                  siblingDoc: row || {},\n                  triggerAccessControl,\n                  triggerHooks,\n                })\n              }\n            })\n          }\n        })\n      } else {\n        siblingDoc[field.name] = []\n      }\n\n      break\n    }\n\n    case 'row':\n    case 'collapsible': {\n      traverseFields({\n        collection,\n        context,\n        currentDepth,\n        depth,\n        doc,\n        fallbackLocale,\n        fieldPromises,\n        fields: field.fields,\n        findMany,\n        flattenLocales,\n        global,\n        locale,\n        overrideAccess,\n        populationPromises,\n        req,\n        showHiddenFields,\n        siblingDoc,\n        triggerAccessControl,\n        triggerHooks,\n      })\n\n      break\n    }\n\n    case 'tab': {\n      let tabDoc = siblingDoc\n      if (tabHasName(field)) {\n        tabDoc = siblingDoc[field.name] as Record<string, unknown>\n        if (typeof siblingDoc[field.name] !== 'object') tabDoc = {}\n      }\n\n      traverseFields({\n        collection,\n        context,\n        currentDepth,\n        depth,\n        doc,\n        fallbackLocale,\n        fieldPromises,\n        fields: field.fields,\n        findMany,\n        flattenLocales,\n        global,\n        locale,\n        overrideAccess,\n        populationPromises,\n        req,\n        showHiddenFields,\n        siblingDoc: tabDoc,\n        triggerAccessControl,\n        triggerHooks,\n      })\n\n      break\n    }\n\n    case 'tabs': {\n      traverseFields({\n        collection,\n        context,\n        currentDepth,\n        depth,\n        doc,\n        fallbackLocale,\n        fieldPromises,\n        fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n        findMany,\n        flattenLocales,\n        global,\n        locale,\n        overrideAccess,\n        populationPromises,\n        req,\n        showHiddenFields,\n        siblingDoc,\n        triggerAccessControl,\n        triggerHooks,\n      })\n      break\n    }\n\n    default: {\n      break\n    }\n  }\n}\n"],"names":["promise","collection","context","currentDepth","depth","doc","fallbackLocale","field","fieldPromises","findMany","flattenLocales","global","locale","overrideAccess","populationPromises","req","showHiddenFields","siblingDoc","triggerAccessControl","triggerHooks","fieldAffectsData","hidden","name","shouldHoistLocalizedValue","localized","payload","config","localization","value","hoistedValue","fallbackValue","isNullOrUndefined","type","tabs","forEach","tab","tabHasName","editor","populationPromise","push","afterReadPromise","incomingEditorState","pointDoc","Array","isArray","coordinates","length","undefined","hooks","afterRead","reduce","priorHook","currentHook","shouldRunHookOnAllLocales","hookPromises","Object","entries","map","hookedValue","data","operation","originalDoc","siblingData","Promise","all","resolve","allowDefaultValue","access","read","result","id","defaultValue","getValueWithDefault","user","relationshipPopulationPromise","groupDoc","traverseFields","fields","rows","row","values","localeRows","block","blocks","find","blockType","slug","tabDoc"],"mappings":"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"}