@webiny/api-headless-cms-ddb 5.32.0 → 5.33.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"names":["createType","createLatestType","createPublishedType","createEntriesStorageOperations","params","entity","plugins","dataLoaders","DataLoadersHandler","storageTransformPlugins","byType","StorageTransformPlugin","type","reduce","collection","plugin","fieldType","createStorageTransformCallable","model","field","value","fromStorage","getStoragePlugin","create","args","entry","storageEntry","partitionKey","createPartitionKey","id","locale","tenant","isPublished","status","locked","items","putBatch","PK","SK","createRevisionSortKey","TYPE","GSI1_PK","createGSIPartitionKey","GSI1_SK","createGSISortKey","createLatestSortKey","push","createPublishedSortKey","batchWriteAll","table","clearAll","ex","WebinyError","message","code","error","createRevisionFrom","update","latestStorageEntry","getLatestRevisionByEntryId","deleteEntry","queryAllParams","options","gte","records","queryAll","map","item","deleteBatch","deleteRevision","latestEntry","publishedStorageEntry","getPublishedRevisionByEntryId","result","ids","shift","getRevisionById","getRevisions","getAllEntryRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","entryId","version","queryParams","lt","zeroPad","filters","attr","eq","reverse","queryOne","cleanupItem","list","limit","initialLimit","where","initialWhere","after","sort","fields","search","published","index","length","hasMoreItems","totalCount","cursor","modelFields","buildModelFields","filteredItems","filterItems","fullTextSearch","term","sortedItems","sortEntryItems","start","parseInt","decodeCursor","end","undefined","slicedItems","slice","encodeCursor","cleanupItems","get","requestChanges","requestReview","publish","CONTENT_ENTRY_STATUS","UNPUBLISHED","unpublish","delete"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { DataLoadersHandler } from \"./dataLoaders\";\nimport {\n CmsEntry,\n CmsEntryListWhere,\n CmsEntryStorageOperations,\n CmsEntryStorageOperationsCreateParams,\n CmsEntryStorageOperationsCreateRevisionFromParams,\n CmsEntryStorageOperationsDeleteParams,\n CmsEntryStorageOperationsDeleteRevisionParams,\n CmsEntryStorageOperationsGetByIdsParams,\n CmsEntryStorageOperationsGetLatestByIdsParams,\n CmsEntryStorageOperationsGetLatestRevisionParams,\n CmsEntryStorageOperationsGetParams,\n CmsEntryStorageOperationsGetPreviousRevisionParams,\n CmsEntryStorageOperationsGetPublishedByIdsParams,\n CmsEntryStorageOperationsGetRevisionParams,\n CmsEntryStorageOperationsGetRevisionsParams,\n CmsEntryStorageOperationsListParams,\n CmsEntryStorageOperationsPublishParams,\n CmsEntryStorageOperationsRequestChangesParams,\n CmsEntryStorageOperationsRequestReviewParams,\n CmsEntryStorageOperationsUnpublishParams,\n CmsEntryStorageOperationsUpdateParams,\n CmsModel,\n CONTENT_ENTRY_STATUS\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport { filterItems, buildModelFields, sortEntryItems, FilterItemFromStorage } from \"./utils\";\nimport {\n createGSIPartitionKey,\n createGSISortKey,\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys\";\nimport { batchWriteAll } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport {\n queryAll,\n QueryAllParams,\n queryOne,\n QueryOneParams\n} from \"@webiny/db-dynamodb/utils/query\";\nimport { cleanupItem, cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils/cursor\";\nimport { zeroPad } from \"@webiny/utils/zeroPad\";\nimport { StorageTransformPlugin } from \"@webiny/api-headless-cms\";\n\nconst createType = (): string => {\n return \"cms.entry\";\n};\nconst createLatestType = (): string => {\n return `${createType()}.l`;\n};\nconst createPublishedType = (): string => {\n return `${createType()}.p`;\n};\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: Entity<any>;\n plugins: PluginsContainer;\n}\nexport const createEntriesStorageOperations = (\n params: CreateEntriesStorageOperationsParams\n): CmsEntryStorageOperations => {\n const { entity, plugins } = params;\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const storageTransformPlugins = plugins\n .byType<StorageTransformPlugin>(StorageTransformPlugin.type)\n .reduce((collection, plugin) => {\n collection[plugin.fieldType] = plugin;\n return collection;\n }, {} as Record<string, StorageTransformPlugin>);\n\n const createStorageTransformCallable = (model: CmsModel): FilterItemFromStorage => {\n return (field, value) => {\n const plugin: StorageTransformPlugin = storageTransformPlugins[field.type];\n if (!plugin) {\n return value;\n }\n return plugin.fromStorage({\n model,\n field,\n value,\n getStoragePlugin(fieldType: string): StorageTransformPlugin {\n return storageTransformPlugins[fieldType] || storageTransformPlugins[\"*\"];\n },\n plugins\n });\n };\n };\n\n const create = async (model: CmsModel, args: CmsEntryStorageOperationsCreateParams) => {\n const { entry, storageEntry } = args;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n\n const locked = isPublished ? true : entry.locked;\n /**\n * We need to:\n * - create new main entry item\n * - create new or update latest entry item\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n\n /**\n * We need to create published entry if\n */\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert data into the DynamoDB.\",\n ex.code || \"CREATE_ENTRY_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n\n return storageEntry;\n };\n\n const createRevisionFrom = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsCreateRevisionFromParams\n ) => {\n const { entry, storageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n /**\n * We need to:\n * - create the main entry item\n * - update the last entry item to a current one\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create revision from given entry.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n /**\n * There are no modifications on the entry created so just return the data.\n */\n return storageEntry;\n };\n\n const update = async (model: CmsModel, params: CmsEntryStorageOperationsUpdateParams) => {\n const { entry, storageEntry } = params;\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const items = [];\n /**\n * We need to:\n * - update the current entry\n * - update the latest entry if the current entry is the latest one\n */\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n /**\n * We need the latest entry to update it as well if neccessary.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return storageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update entry.\",\n ex.code || \"UPDATE_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry\n }\n );\n }\n };\n\n const deleteEntry = async (model: CmsModel, params: CmsEntryStorageOperationsDeleteParams) => {\n const { entry } = params;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n };\n\n let records = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n const items = records.map(item => {\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete the entry.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n entry\n }\n );\n }\n };\n\n const deleteRevision = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsDeleteRevisionParams\n ) => {\n const { entry, latestEntry, latestStorageEntry } = params;\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n })\n ];\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n /**\n * If revision we are deleting is the published one as well, we need to delete those records as well.\n */\n if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (latestStorageEntry) {\n items.push(\n entity.putBatch({\n ...latestStorageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(latestStorageEntry)\n })\n );\n }\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, {\n error: ex,\n entry,\n latestEntry\n });\n }\n };\n\n const getLatestRevisionByEntryId = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const result = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [params.id]\n });\n return result.shift() || null;\n };\n const getPublishedRevisionByEntryId = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const result = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [params.id]\n });\n return result.shift() || null;\n };\n\n const getRevisionById = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsGetRevisionParams\n ) => {\n const result = await dataLoaders.getRevisionById({\n model,\n ids: [params.id]\n });\n return result.shift() || null;\n };\n\n const getRevisions = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsGetRevisionsParams\n ) => {\n return await dataLoaders.getAllEntryRevisions({\n model,\n ids: [params.id]\n });\n };\n\n const getByIds = async (model: CmsModel, params: CmsEntryStorageOperationsGetByIdsParams) => {\n return dataLoaders.getRevisionById({\n model,\n ids: params.ids\n });\n };\n\n const getLatestByIds = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsGetLatestByIdsParams\n ) => {\n return dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: params.ids\n });\n };\n\n const getPublishedByIds = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsGetPublishedByIdsParams\n ) => {\n return dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: params.ids\n });\n };\n\n const getPreviousRevision = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsGetPreviousRevisionParams\n ) => {\n const { entryId, version } = params;\n const queryParams: QueryOneParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant: model.tenant,\n locale: model.locale,\n id: entryId\n }),\n options: {\n lt: `REV#${zeroPad(version)}`,\n /**\n * We need to have extra checks because DynamoDB will return published or latest record if there is no REV# record.\n */\n filters: [\n {\n attr: \"TYPE\",\n eq: createType()\n },\n {\n attr: \"version\",\n lt: version\n }\n ],\n reverse: true\n }\n };\n\n try {\n const result = await queryOne<CmsEntry>(queryParams);\n\n return cleanupItem(entity, result);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get previous version of given entry.\",\n ex.code || \"GET_PREVIOUS_VERSION_ERROR\",\n {\n ...params,\n error: ex,\n partitionKey: queryParams.partitionKey,\n options: queryParams.options,\n model\n }\n );\n }\n };\n\n const list = async (model: CmsModel, params: CmsEntryStorageOperationsListParams) => {\n const {\n limit: initialLimit = 10,\n where: initialWhere,\n after,\n sort,\n fields,\n search\n } = params;\n const limit = initialLimit <= 0 || initialLimit >= 10000 ? 10000 : initialLimit;\n\n const type = initialWhere.published ? \"P\" : \"L\";\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createGSIPartitionKey(model, type),\n options: {\n index: \"GSI1\",\n gte: \" \"\n }\n };\n let records = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(ex.message, \"QUERY_ENTRIES_ERROR\", {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n });\n }\n if (records.length === 0) {\n return {\n hasMoreItems: false,\n totalCount: 0,\n cursor: null,\n items: []\n };\n }\n const where: Partial<CmsEntryListWhere> = {\n ...initialWhere\n };\n delete where[\"published\"];\n delete where[\"latest\"];\n /**\n * We need a object containing field, transformers and paths.\n * Just build it here and pass on into other methods that require it to avoid mapping multiple times.\n */\n const modelFields = buildModelFields({\n plugins,\n model\n });\n /**\n * Filter the read items via the code.\n * It will build the filters out of the where input and transform the values it is using.\n */\n const filteredItems = await filterItems({\n items: records,\n where,\n plugins,\n fields: modelFields,\n fromStorage: createStorageTransformCallable(model),\n fullTextSearch: {\n term: search,\n fields: fields || []\n }\n });\n\n const totalCount = filteredItems.length;\n /**\n * Sorting is also done via the code.\n * It takes the sort input and sorts by it via the lodash sortBy method.\n */\n const sortedItems = sortEntryItems({\n items: filteredItems,\n sort,\n fields: modelFields\n });\n\n const start = parseInt((decodeCursor(after) as string) || \"0\") || 0;\n const hasMoreItems = totalCount > start + limit;\n const end = limit > totalCount + start + limit ? undefined : start + limit;\n const slicedItems = sortedItems.slice(start, end);\n /**\n * Although we do not need a cursor here, we will use it as such to keep it standardized.\n * Number is simply encoded.\n */\n const cursor = totalCount > start + limit ? encodeCursor(`${start + limit}`) : null;\n return {\n hasMoreItems,\n totalCount,\n cursor,\n items: cleanupItems(entity, slicedItems)\n };\n };\n\n const get = async (model: CmsModel, params: CmsEntryStorageOperationsGetParams) => {\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const requestChanges = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsRequestChangesParams\n ) => {\n const { entry, storageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n /**\n * We need to:\n * - update the existing entry\n * - update latest version - if existing entry is the latest version\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n TYPE: createType(),\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated along side the request changes one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute the request changes batch.\",\n ex.code || \"REQUEST_CHANGES_ERROR\",\n {\n entry\n }\n );\n }\n return entry;\n };\n\n const requestReview = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsRequestReviewParams\n ) => {\n const { entry, storageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n /**\n * We need to:\n * - update existing entry\n * - update latest entry - if existing entry is the latest entry\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n TYPE: createType(),\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated along side the request review one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return entry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute request review batch.\",\n ex.code || \"REQUEST_REVIEW_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n };\n\n const publish = async (model: CmsModel, params: CmsEntryStorageOperationsPublishParams) => {\n const { entry, storageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n /**\n * We need the latest and published entries to see if something needs to be updated along side the publishing one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n /**\n * We need to update:\n * - current entry revision sort key\n * - published sort key\n * - latest sort key - if entry updated is actually latest\n * - previous published entry to unpublished status - if any previously published entry\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n if (latestStorageEntry && entry.id === latestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n if (publishedStorageEntry && publishedStorageEntry.id !== entry.id) {\n items.push(\n entity.putBatch({\n ...publishedStorageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(publishedStorageEntry),\n TYPE: createType(),\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED,\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(publishedStorageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return entry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute the publishing batch.\",\n ex.code || \"PUBLISH_ERROR\",\n {\n entry,\n latestStorageEntry,\n publishedStorageEntry\n }\n );\n }\n };\n\n const unpublish = async (model: CmsModel, params: CmsEntryStorageOperationsUnpublishParams) => {\n const { entry, storageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n /**\n * We need to:\n * - delete currently published entry\n * - update current entry revision with new data\n * - update latest entry status - if entry being unpublished is latest\n */\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated along side the unpublishing one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && entry.id === latestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return storageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute unpublish batch.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n delete: deleteEntry,\n deleteRevision,\n getPreviousRevision,\n getPublishedByIds,\n getLatestByIds,\n getByIds,\n getRevisionById,\n getPublishedRevisionByEntryId,\n getLatestRevisionByEntryId,\n get,\n getRevisions,\n requestChanges,\n requestReview,\n publish,\n list,\n unpublish\n };\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["createType","createLatestType","createPublishedType","convertToStorageEntry","params","model","storageEntry","values","convertValueKeyToStorage","fields","convertFromStorageEntry","convertValueKeyFromStorage","createEntriesStorageOperations","entity","plugins","dataLoaders","DataLoadersHandler","storageTransformPlugins","byType","StorageTransformPlugin","type","reduce","collection","plugin","fieldType","createStorageTransformCallable","field","value","fromStorage","getStoragePlugin","create","entry","initialStorageEntry","partitionKey","createPartitionKey","id","locale","tenant","isPublished","status","locked","items","putBatch","PK","SK","createRevisionSortKey","TYPE","GSI1_PK","createGSIPartitionKey","GSI1_SK","createGSISortKey","createLatestSortKey","push","createPublishedSortKey","batchWriteAll","table","clearAll","ex","WebinyError","message","code","error","createRevisionFrom","update","latestStorageEntry","getLatestRevisionByEntryId","deleteEntry","queryAllParams","options","gte","records","queryAll","map","item","deleteBatch","deleteRevision","latestEntry","initialLatestStorageEntry","publishedStorageEntry","getPublishedRevisionByEntryId","ids","shift","getRevisionById","getRevisions","getAllEntryRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","entryId","version","queryParams","lt","zeroPad","filters","attr","eq","reverse","result","queryOne","cleanupItem","list","limit","initialLimit","where","initialWhere","after","sort","search","published","index","length","hasMoreItems","totalCount","cursor","modelFields","buildModelFields","filteredItems","filterItems","record","fullTextSearch","term","sortedItems","sortEntryItems","start","parseInt","decodeCursor","end","undefined","slicedItems","slice","encodeCursor","cleanupItems","get","requestChanges","requestReview","publish","initialPublishedStorageEntry","CONTENT_ENTRY_STATUS","UNPUBLISHED","unpublish","delete"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { DataLoadersHandler } from \"./dataLoaders\";\nimport {\n CmsEntry,\n CmsEntryListWhere,\n CmsEntryStorageOperations,\n CmsEntryStorageOperationsCreateParams,\n CmsEntryStorageOperationsCreateRevisionFromParams,\n CmsEntryStorageOperationsDeleteParams,\n CmsEntryStorageOperationsDeleteRevisionParams,\n CmsEntryStorageOperationsGetByIdsParams,\n CmsEntryStorageOperationsGetLatestByIdsParams,\n CmsEntryStorageOperationsGetLatestRevisionParams,\n CmsEntryStorageOperationsGetParams,\n CmsEntryStorageOperationsGetPreviousRevisionParams,\n CmsEntryStorageOperationsGetPublishedByIdsParams,\n CmsEntryStorageOperationsGetRevisionParams,\n CmsEntryStorageOperationsGetRevisionsParams,\n CmsEntryStorageOperationsListParams,\n CmsEntryStorageOperationsPublishParams,\n CmsEntryStorageOperationsRequestChangesParams,\n CmsEntryStorageOperationsRequestReviewParams,\n CmsEntryStorageOperationsUnpublishParams,\n CmsEntryStorageOperationsUpdateParams,\n StorageOperationsCmsModel,\n CONTENT_ENTRY_STATUS,\n CmsStorageEntry\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport { filterItems, buildModelFields, sortEntryItems, FilterItemFromStorage } from \"./utils\";\nimport {\n createGSIPartitionKey,\n createGSISortKey,\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys\";\nimport { batchWriteAll } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport {\n queryAll,\n QueryAllParams,\n queryOne,\n QueryOneParams\n} from \"@webiny/db-dynamodb/utils/query\";\nimport { cleanupItem, cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils/cursor\";\nimport { zeroPad } from \"@webiny/utils/zeroPad\";\nimport { StorageTransformPlugin } from \"@webiny/api-headless-cms\";\n\nconst createType = (): string => {\n return \"cms.entry\";\n};\nconst createLatestType = (): string => {\n return `${createType()}.l`;\n};\nconst createPublishedType = (): string => {\n return `${createType()}.p`;\n};\n\ninterface ConvertStorageEntryParams {\n storageEntry: CmsStorageEntry;\n model: StorageOperationsCmsModel;\n}\nconst convertToStorageEntry = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyToStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nconst convertFromStorageEntry = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyFromStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: Entity<any>;\n plugins: PluginsContainer;\n}\nexport const createEntriesStorageOperations = (\n params: CreateEntriesStorageOperationsParams\n): CmsEntryStorageOperations => {\n const { entity, plugins } = params;\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const storageTransformPlugins = plugins\n .byType<StorageTransformPlugin>(StorageTransformPlugin.type)\n .reduce((collection, plugin) => {\n collection[plugin.fieldType] = plugin;\n return collection;\n }, {} as Record<string, StorageTransformPlugin>);\n\n const createStorageTransformCallable = (\n model: StorageOperationsCmsModel\n ): FilterItemFromStorage => {\n return (field, value) => {\n const plugin: StorageTransformPlugin = storageTransformPlugins[field.type];\n if (!plugin) {\n return value;\n }\n return plugin.fromStorage({\n model,\n field,\n value,\n getStoragePlugin(fieldType: string): StorageTransformPlugin {\n return storageTransformPlugins[fieldType] || storageTransformPlugins[\"*\"];\n },\n plugins\n });\n };\n };\n\n const create = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsCreateParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n\n const locked = isPublished ? true : entry.locked;\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to:\n * - create new main entry item\n * - create new or update latest entry item\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n\n /**\n * We need to create published entry if\n */\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert data into the DynamoDB.\",\n ex.code || \"CREATE_ENTRY_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n\n return initialStorageEntry;\n };\n\n const createRevisionFrom = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsCreateRevisionFromParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - create the main entry item\n * - update the last entry item to a current one\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create revision from given entry.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n /**\n * There are no modifications on the entry created so just return the data.\n */\n return initialStorageEntry;\n };\n\n const update = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsUpdateParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const items = [];\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to:\n * - update the current entry\n * - update the latest entry if the current entry is the latest one\n */\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n /**\n * We need the latest entry to update it as well if neccessary.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update entry.\",\n ex.code || \"UPDATE_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry\n }\n );\n }\n };\n\n const deleteEntry = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsDeleteParams\n ) => {\n const { entry } = params;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n };\n\n let records = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n const items = records.map(item => {\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete the entry.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n entry\n }\n );\n }\n };\n\n const deleteRevision = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsDeleteRevisionParams\n ) => {\n const { entry, latestEntry, latestStorageEntry: initialLatestStorageEntry } = params;\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n })\n ];\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n /**\n * If revision we are deleting is the published one as well, we need to delete those records as well.\n */\n if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (initialLatestStorageEntry) {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...latestStorageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(latestStorageEntry)\n })\n );\n }\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, {\n error: ex,\n entry,\n latestEntry\n });\n }\n };\n\n const getLatestRevisionByEntryId = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const items = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n const getPublishedRevisionByEntryId = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const items = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisionById = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetRevisionParams\n ) => {\n const items = await dataLoaders.getRevisionById({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisions = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetRevisionsParams\n ) => {\n const items = await dataLoaders.getAllEntryRevisions({\n model,\n ids: [params.id]\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetByIdsParams\n ) => {\n const items = await dataLoaders.getRevisionById({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getLatestByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetLatestByIdsParams\n ) => {\n const items = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPublishedByIds = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetPublishedByIdsParams\n ) => {\n const items = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPreviousRevision = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetPreviousRevisionParams\n ) => {\n const { entryId, version } = params;\n const queryParams: QueryOneParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant: model.tenant,\n locale: model.locale,\n id: entryId\n }),\n options: {\n lt: `REV#${zeroPad(version)}`,\n /**\n * We need to have extra checks because DynamoDB will return published or latest record if there is no REV# record.\n */\n filters: [\n {\n attr: \"TYPE\",\n eq: createType()\n },\n {\n attr: \"version\",\n lt: version\n }\n ],\n reverse: true\n }\n };\n\n try {\n const result = await queryOne<CmsEntry>(queryParams);\n\n const storageEntry = cleanupItem(entity, result);\n if (!storageEntry) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry,\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get previous version of given entry.\",\n ex.code || \"GET_PREVIOUS_VERSION_ERROR\",\n {\n ...params,\n error: ex,\n partitionKey: queryParams.partitionKey,\n options: queryParams.options,\n model\n }\n );\n }\n };\n\n const list = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsListParams\n ) => {\n const {\n limit: initialLimit = 10,\n where: initialWhere,\n after,\n sort,\n fields,\n search\n } = params;\n const limit = initialLimit <= 0 || initialLimit >= 10000 ? 10000 : initialLimit;\n\n const type = initialWhere.published ? \"P\" : \"L\";\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createGSIPartitionKey(model, type),\n options: {\n index: \"GSI1\",\n gte: \" \"\n }\n };\n let records = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(ex.message, \"QUERY_ENTRIES_ERROR\", {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n });\n }\n if (records.length === 0) {\n return {\n hasMoreItems: false,\n totalCount: 0,\n cursor: null,\n items: []\n };\n }\n const where: Partial<CmsEntryListWhere> = {\n ...initialWhere\n };\n delete where[\"published\"];\n delete where[\"latest\"];\n /**\n * We need a object containing field, transformers and paths.\n * Just build it here and pass on into other methods that require it to avoid mapping multiple times.\n */\n const modelFields = buildModelFields({\n plugins,\n model\n });\n /**\n * Filter the read items via the code.\n * It will build the filters out of the where input and transform the values it is using.\n */\n const filteredItems = await filterItems({\n items: records.map(record => {\n return convertFromStorageEntry({\n storageEntry: record,\n model\n });\n }),\n where,\n plugins,\n fields: modelFields,\n fromStorage: createStorageTransformCallable(model),\n fullTextSearch: {\n term: search,\n fields: fields || []\n }\n });\n\n const totalCount = filteredItems.length;\n\n /**\n * Sorting is also done via the code.\n * It takes the sort input and sorts by it via the lodash sortBy method.\n */\n const sortedItems = sortEntryItems({\n items: filteredItems,\n sort,\n fields: modelFields\n });\n\n const start = parseInt((decodeCursor(after) as string) || \"0\") || 0;\n const hasMoreItems = totalCount > start + limit;\n const end = limit > totalCount + start + limit ? undefined : start + limit;\n const slicedItems = sortedItems.slice(start, end);\n /**\n * Although we do not need a cursor here, we will use it as such to keep it standardized.\n * Number is simply encoded.\n */\n const cursor = totalCount > start + limit ? encodeCursor(`${start + limit}`) : null;\n return {\n hasMoreItems,\n totalCount,\n cursor,\n items: cleanupItems(entity, slicedItems)\n };\n };\n\n const get = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsGetParams\n ) => {\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const requestChanges = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsRequestChangesParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n\n /**\n * We need to:\n * - update the existing entry\n * - update latest version - if existing entry is the latest version\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n TYPE: createType(),\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated along side the request changes one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute the request changes batch.\",\n ex.code || \"REQUEST_CHANGES_ERROR\",\n {\n entry\n }\n );\n }\n return entry;\n };\n\n const requestReview = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsRequestReviewParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - update existing entry\n * - update latest entry - if existing entry is the latest entry\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n TYPE: createType(),\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated along side the request review one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute request review batch.\",\n ex.code || \"REQUEST_REVIEW_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n };\n\n const publish = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsPublishParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n /**\n * We need the latest and published entries to see if something needs to be updated along side the publishing one.\n */\n const initialLatestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n const initialPublishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to update:\n * - current entry revision sort key\n * - published sort key\n * - latest sort key - if entry updated is actually latest\n * - previous published entry to unpublished status - if any previously published entry\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n if (initialLatestStorageEntry && entry.id === initialLatestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n if (initialPublishedStorageEntry && initialPublishedStorageEntry.id !== entry.id) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...publishedStorageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(publishedStorageEntry),\n TYPE: createType(),\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED,\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(publishedStorageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute the publishing batch.\",\n ex.code || \"PUBLISH_ERROR\",\n {\n entry,\n latestStorageEntry: initialLatestStorageEntry,\n publishedStorageEntry: initialPublishedStorageEntry\n }\n );\n }\n };\n\n const unpublish = async (\n model: StorageOperationsCmsModel,\n params: CmsEntryStorageOperationsUnpublishParams\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - delete currently published entry\n * - update current entry revision with new data\n * - update latest entry status - if entry being unpublished is latest\n */\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated along side the unpublishing one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && entry.id === latestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute unpublish batch.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n delete: deleteEntry,\n deleteRevision,\n getPreviousRevision,\n getPublishedByIds,\n getLatestByIds,\n getByIds,\n getRevisionById,\n getPublishedRevisionByEntryId,\n getLatestRevisionByEntryId,\n get,\n getRevisions,\n requestChanges,\n requestReview,\n publish,\n list,\n unpublish\n };\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AA2BA;;AACA;;AAQA;;AACA;;AAMA;;AAEA;;AACA;;AACA;;;;;;AAEA,MAAMA,UAAU,GAAG,MAAc;EAC7B,OAAO,WAAP;AACH,CAFD;;AAGA,MAAMC,gBAAgB,GAAG,MAAc;EACnC,OAAQ,GAAED,UAAU,EAAG,IAAvB;AACH,CAFD;;AAGA,MAAME,mBAAmB,GAAG,MAAc;EACtC,OAAQ,GAAEF,UAAU,EAAG,IAAvB;AACH,CAFD;;AAQA,MAAMG,qBAAqB,GAAIC,MAAD,IAAwD;EAClF,MAAM;IAAEC,KAAF;IAASC;EAAT,IAA0BF,MAAhC;EAEA,MAAMG,MAAM,GAAGF,KAAK,CAACG,wBAAN,CAA+B;IAC1CC,MAAM,EAAEJ,KAAK,CAACI,MAD4B;IAE1CF,MAAM,EAAED,YAAY,CAACC;EAFqB,CAA/B,CAAf;EAIA,uCACOD,YADP;IAEIC;EAFJ;AAIH,CAXD;;AAaA,MAAMG,uBAAuB,GAAIN,MAAD,IAAwD;EACpF,MAAM;IAAEC,KAAF;IAASC;EAAT,IAA0BF,MAAhC;EAEA,MAAMG,MAAM,GAAGF,KAAK,CAACM,0BAAN,CAAiC;IAC5CF,MAAM,EAAEJ,KAAK,CAACI,MAD8B;IAE5CF,MAAM,EAAED,YAAY,CAACC;EAFuB,CAAjC,CAAf;EAIA,uCACOD,YADP;IAEIC;EAFJ;AAIH,CAXD;;AAiBO,MAAMK,8BAA8B,GACvCR,MAD0C,IAEd;EAC5B,MAAM;IAAES,MAAF;IAAUC;EAAV,IAAsBV,MAA5B;EAEA,MAAMW,WAAW,GAAG,IAAIC,+BAAJ,CAAuB;IACvCH;EADuC,CAAvB,CAApB;EAIA,MAAMI,uBAAuB,GAAGH,OAAO,CAClCI,MAD2B,CACIC,sCAAA,CAAuBC,IAD3B,EAE3BC,MAF2B,CAEpB,CAACC,UAAD,EAAaC,MAAb,KAAwB;IAC5BD,UAAU,CAACC,MAAM,CAACC,SAAR,CAAV,GAA+BD,MAA/B;IACA,OAAOD,UAAP;EACH,CAL2B,EAKzB,EALyB,CAAhC;;EAOA,MAAMG,8BAA8B,GAChCpB,KADmC,IAEX;IACxB,OAAO,CAACqB,KAAD,EAAQC,KAAR,KAAkB;MACrB,MAAMJ,MAA8B,GAAGN,uBAAuB,CAACS,KAAK,CAACN,IAAP,CAA9D;;MACA,IAAI,CAACG,MAAL,EAAa;QACT,OAAOI,KAAP;MACH;;MACD,OAAOJ,MAAM,CAACK,WAAP,CAAmB;QACtBvB,KADsB;QAEtBqB,KAFsB;QAGtBC,KAHsB;;QAItBE,gBAAgB,CAACL,SAAD,EAA4C;UACxD,OAAOP,uBAAuB,CAACO,SAAD,CAAvB,IAAsCP,uBAAuB,CAAC,GAAD,CAApE;QACH,CANqB;;QAOtBH;MAPsB,CAAnB,CAAP;IASH,CAdD;EAeH,CAlBD;;EAoBA,MAAMgB,MAAM,GAAG,OACXzB,KADW,EAEXD,MAFW,KAGV;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAMC,WAAW,GAAGP,KAAK,CAACQ,MAAN,KAAiB,WAArC;IAEA,MAAMC,MAAM,GAAGF,WAAW,GAAG,IAAH,GAAUP,KAAK,CAACS,MAA1C;IAEA,MAAMlC,YAAY,GAAGH,qBAAqB,CAAC;MACvCE,KADuC;MAEvCC,YAAY,EAAE0B;IAFyB,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;;IACQ,MAAMS,KAAK,GAAG,CACV5B,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIkC,MAFJ;MAGIG,EAAE,EAAEV,YAHR;MAIIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB,CAJR;MAKIe,IAAI,EAAE9C,UAAU,EALpB;MAMI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;MAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IAPb,GADU,EAUVO,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIkC,MAFJ;MAGIG,EAAE,EAAEV,YAHR;MAIIW,EAAE,EAAE,IAAAO,yBAAA,GAJR;MAKIL,IAAI,EAAE7C,gBAAgB,EAL1B;MAMI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;MAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IAPb,GAVU,CAAd;IAqBA;AACR;AACA;;IACQ,IAAIgC,WAAJ,EAAiB;MACbG,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;QAEIkC,MAFJ;QAGIG,EAAE,EAAEV,YAHR;QAIIW,EAAE,EAAE,IAAAS,4BAAA,GAJR;QAKIP,IAAI,EAAE7C,gBAAgB,EAL1B;QAMI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;QAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;MAPb,GADJ;IAWH;;IAED,IAAI;MACA,MAAM,IAAAgD,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,0CADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,oBAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEI1B;MAFJ,CAHE,CAAN;IAQH;;IAED,OAAOC,mBAAP;EACH,CAnFD;;EAqFA,MAAM8B,kBAAkB,GAAG,OACvBzD,KADuB,EAEvBD,MAFuB,KAGtB;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAM/B,YAAY,GAAGH,qBAAqB,CAAC;MACvCG,YAAY,EAAE0B,mBADyB;MAEvC3B;IAFuC,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;;IACQ,MAAMoC,KAAK,GAAG,CACV5B,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBvC,YAAtB,CAHR;MAIIwC,IAAI,EAAE9C,UAAU,EAJpB;MAKI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IANb,GADU,EASVO,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;MAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;MAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IANb,GATU,CAAd;;IAkBA,IAAI;MACA,MAAM,IAAAgD,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,6CADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,uBAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEI1B,KAFJ;QAGIzB;MAHJ,CAHE,CAAN;IASH;IACD;AACR;AACA;;;IACQ,OAAO0B,mBAAP;EACH,CA9DD;;EAgEA,MAAM+B,MAAM,GAAG,OACX1D,KADW,EAEXD,MAFW,KAGV;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IACA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAMC,WAAW,GAAGP,KAAK,CAACQ,MAAN,KAAiB,WAArC;IACA,MAAMC,MAAM,GAAGF,WAAW,GAAG,IAAH,GAAUP,KAAK,CAACS,MAA1C;IAEA,MAAMC,KAAK,GAAG,EAAd;IAEA,MAAMnC,YAAY,GAAGH,qBAAqB,CAAC;MACvCE,KADuC;MAEvCC,YAAY,EAAE0B;IAFyB,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;;IACQS,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIkC,MAFJ;MAGIG,EAAE,EAAEV,YAHR;MAIIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBvC,YAAtB,CAJR;MAKIwC,IAAI,EAAE9C,UAAU,EALpB;MAMI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;MAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;IAPb,GADJ;;IAYA,IAAIgC,WAAJ,EAAiB;MACbG,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;QAEIkC,MAFJ;QAGIG,EAAE,EAAEV,YAHR;QAIIW,EAAE,EAAE,IAAAS,4BAAA,GAJR;QAKIP,IAAI,EAAE5C,mBAAmB,EAL7B;QAMI6C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;QAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB5C,YAAjB;MAPb,GADJ;IAWH;IAED;AACR;AACA;;;IACQ,MAAM0D,kBAAkB,GAAG,MAAMC,0BAA0B,CAAC5D,KAAD,EAAQ0B,KAAR,CAA3D;;IAEA,IAAIiC,kBAAkB,IAAIA,kBAAkB,CAAC7B,EAAnB,KAA0BJ,KAAK,CAACI,EAA1D,EAA8D;MAC1DM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;QAEIkC,MAFJ;QAGIG,EAAE,EAAEV,YAHR;QAIIW,EAAE,EAAE,IAAAO,yBAAA,GAJR;QAKIL,IAAI,EAAE7C,gBAAgB,EAL1B;QAMI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;QAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;MAPb,GADJ;IAWH;;IAED,IAAI;MACA,MAAM,IAAAuB,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;MAGA,OAAO2B,mBAAP;IACH,CATD,CASE,OAAOyB,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,yBADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,cAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEI1B,KAFJ;QAGIiC;MAHJ,CAHE,CAAN;IASH;EACJ,CA1FD;;EA4FA,MAAME,WAAW,GAAG,OAChB7D,KADgB,EAEhBD,MAFgB,KAGf;IACD,MAAM;MAAE2B;IAAF,IAAY3B,MAAlB;IAEA,MAAM+D,cAA8B,GAAG;MACnCtD,MADmC;MAEnCoB,YAAY,EAAE,IAAAC,wBAAA,EAAmB;QAC7BC,EAAE,EAAEJ,KAAK,CAACI,EADmB;QAE7BC,MAAM,EAAE/B,KAAK,CAAC+B,MAFe;QAG7BC,MAAM,EAAEhC,KAAK,CAACgC;MAHe,CAAnB,CAFqB;MAOnC+B,OAAO,EAAE;QACLC,GAAG,EAAE;MADA;IAP0B,CAAvC;IAYA,IAAIC,OAAO,GAAG,EAAd;;IACA,IAAI;MACAA,OAAO,GAAG,MAAM,IAAAC,eAAA,EAASJ,cAAT,CAAhB;IACH,CAFD,CAEE,OAAOV,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,6BADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,wBAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEI1B;MAFJ,CAHE,CAAN;IAQH;;IACD,MAAMU,KAAK,GAAG6B,OAAO,CAACE,GAAR,CAAYC,IAAI,IAAI;MAC9B,OAAO5D,MAAM,CAAC6D,WAAP,CAAmB;QACtB/B,EAAE,EAAE8B,IAAI,CAAC9B,EADa;QAEtBC,EAAE,EAAE6B,IAAI,CAAC7B;MAFa,CAAnB,CAAP;IAIH,CALa,CAAd;;IAOA,IAAI;MACA,MAAM,IAAAU,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,6BADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,oBAFT,EAGF;QACIC,KAAK,EAAEJ,EADX;QAEIxB,YAAY,EAAEkC,cAAc,CAAClC,YAFjC;QAGIF;MAHJ,CAHE,CAAN;IASH;EACJ,CAzDD;;EA2DA,MAAM4C,cAAc,GAAG,OACnBtE,KADmB,EAEnBD,MAFmB,KAGlB;IACD,MAAM;MAAE2B,KAAF;MAAS6C,WAAT;MAAsBZ,kBAAkB,EAAEa;IAA1C,IAAwEzE,MAA9E;IACA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAMI,KAAK,GAAG,CACV5B,MAAM,CAAC6D,WAAP,CAAmB;MACf/B,EAAE,EAAEV,YADW;MAEfW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB;IAFW,CAAnB,CADU,CAAd;IAOA,MAAM+C,qBAAqB,GAAG,MAAMC,6BAA6B,CAAC1E,KAAD,EAAQ0B,KAAR,CAAjE;IAEA;AACR;AACA;;IACQ,IAAI+C,qBAAqB,IAAI/C,KAAK,CAACI,EAAN,KAAa2C,qBAAqB,CAAC3C,EAAhE,EAAoE;MAChEM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6D,WAAP,CAAmB;QACf/B,EAAE,EAAEV,YADW;QAEfW,EAAE,EAAE,IAAAS,4BAAA;MAFW,CAAnB,CADJ;IAMH;;IACD,IAAIwB,yBAAJ,EAA+B;MAC3B,MAAMb,kBAAkB,GAAG7D,qBAAqB,CAAC;QAC7CG,YAAY,EAAEuE,yBAD+B;QAE7CxE;MAF6C,CAAD,CAAhD;MAIAoC,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOsB,kBADP;QAEIrB,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;QAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;QAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;QAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBc,kBAAjB;MANb,GADJ;IAUH;;IACD,IAAI;MACA,MAAM,IAAAV,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CAAgBD,EAAE,CAACE,OAAnB,EAA4BF,EAAE,CAACG,IAA/B,EAAqC;QACvCC,KAAK,EAAEJ,EADgC;QAEvC1B,KAFuC;QAGvC6C;MAHuC,CAArC,CAAN;IAKH;EACJ,CA9DD;;EAgEA,MAAMX,0BAA0B,GAAG,OAC/B5D,KAD+B,EAE/BD,MAF+B,KAG9B;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACkD,0BAAZ,CAAuC;MACvD5D,KADuD;MAEvD2E,GAAG,EAAE,CAAC5E,MAAM,CAAC+B,EAAR;IAFkD,CAAvC,CAApB;IAIA,MAAMsC,IAAI,GAAGhC,KAAK,CAACwC,KAAN,MAAiB,IAA9B;;IACA,IAAI,CAACR,IAAL,EAAW;MACP,OAAO,IAAP;IACH;;IACD,OAAO/D,uBAAuB,CAAC;MAC3BJ,YAAY,EAAEmE,IADa;MAE3BpE;IAF2B,CAAD,CAA9B;EAIH,CAhBD;;EAiBA,MAAM0E,6BAA6B,GAAG,OAClC1E,KADkC,EAElCD,MAFkC,KAGjC;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACgE,6BAAZ,CAA0C;MAC1D1E,KAD0D;MAE1D2E,GAAG,EAAE,CAAC5E,MAAM,CAAC+B,EAAR;IAFqD,CAA1C,CAApB;IAIA,MAAMsC,IAAI,GAAGhC,KAAK,CAACwC,KAAN,MAAiB,IAA9B;;IACA,IAAI,CAACR,IAAL,EAAW;MACP,OAAO,IAAP;IACH;;IACD,OAAO/D,uBAAuB,CAAC;MAC3BJ,YAAY,EAAEmE,IADa;MAE3BpE;IAF2B,CAAD,CAA9B;EAIH,CAhBD;;EAkBA,MAAM6E,eAAe,GAAG,OACpB7E,KADoB,EAEpBD,MAFoB,KAGnB;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACmE,eAAZ,CAA4B;MAC5C7E,KAD4C;MAE5C2E,GAAG,EAAE,CAAC5E,MAAM,CAAC+B,EAAR;IAFuC,CAA5B,CAApB;IAIA,MAAMsC,IAAI,GAAGhC,KAAK,CAACwC,KAAN,MAAiB,IAA9B;;IACA,IAAI,CAACR,IAAL,EAAW;MACP,OAAO,IAAP;IACH;;IACD,OAAO/D,uBAAuB,CAAC;MAC3BJ,YAAY,EAAEmE,IADa;MAE3BpE;IAF2B,CAAD,CAA9B;EAIH,CAhBD;;EAkBA,MAAM8E,YAAY,GAAG,OACjB9E,KADiB,EAEjBD,MAFiB,KAGhB;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACqE,oBAAZ,CAAiC;MACjD/E,KADiD;MAEjD2E,GAAG,EAAE,CAAC5E,MAAM,CAAC+B,EAAR;IAF4C,CAAjC,CAApB;IAKA,OAAOM,KAAK,CAAC+B,GAAN,CAAUC,IAAI,IAAI;MACrB,OAAO/D,uBAAuB,CAAC;QAC3BJ,YAAY,EAAEmE,IADa;QAE3BpE;MAF2B,CAAD,CAA9B;IAIH,CALM,CAAP;EAMH,CAfD;;EAiBA,MAAMgF,QAAQ,GAAG,OACbhF,KADa,EAEbD,MAFa,KAGZ;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACmE,eAAZ,CAA4B;MAC5C7E,KAD4C;MAE5C2E,GAAG,EAAE5E,MAAM,CAAC4E;IAFgC,CAA5B,CAApB;IAKA,OAAOvC,KAAK,CAAC+B,GAAN,CAAUC,IAAI,IAAI;MACrB,OAAO/D,uBAAuB,CAAC;QAC3BJ,YAAY,EAAEmE,IADa;QAE3BpE;MAF2B,CAAD,CAA9B;IAIH,CALM,CAAP;EAMH,CAfD;;EAiBA,MAAMiF,cAAc,GAAG,OACnBjF,KADmB,EAEnBD,MAFmB,KAGlB;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACkD,0BAAZ,CAAuC;MACvD5D,KADuD;MAEvD2E,GAAG,EAAE5E,MAAM,CAAC4E;IAF2C,CAAvC,CAApB;IAKA,OAAOvC,KAAK,CAAC+B,GAAN,CAAUC,IAAI,IAAI;MACrB,OAAO/D,uBAAuB,CAAC;QAC3BJ,YAAY,EAAEmE,IADa;QAE3BpE;MAF2B,CAAD,CAA9B;IAIH,CALM,CAAP;EAMH,CAfD;;EAiBA,MAAMkF,iBAAiB,GAAG,OACtBlF,KADsB,EAEtBD,MAFsB,KAGrB;IACD,MAAMqC,KAAK,GAAG,MAAM1B,WAAW,CAACgE,6BAAZ,CAA0C;MAC1D1E,KAD0D;MAE1D2E,GAAG,EAAE5E,MAAM,CAAC4E;IAF8C,CAA1C,CAApB;IAKA,OAAOvC,KAAK,CAAC+B,GAAN,CAAUC,IAAI,IAAI;MACrB,OAAO/D,uBAAuB,CAAC;QAC3BJ,YAAY,EAAEmE,IADa;QAE3BpE;MAF2B,CAAD,CAA9B;IAIH,CALM,CAAP;EAMH,CAfD;;EAiBA,MAAMmF,mBAAmB,GAAG,OACxBnF,KADwB,EAExBD,MAFwB,KAGvB;IACD,MAAM;MAAEqF,OAAF;MAAWC;IAAX,IAAuBtF,MAA7B;IACA,MAAMuF,WAA2B,GAAG;MAChC9E,MADgC;MAEhCoB,YAAY,EAAE,IAAAC,wBAAA,EAAmB;QAC7BG,MAAM,EAAEhC,KAAK,CAACgC,MADe;QAE7BD,MAAM,EAAE/B,KAAK,CAAC+B,MAFe;QAG7BD,EAAE,EAAEsD;MAHyB,CAAnB,CAFkB;MAOhCrB,OAAO,EAAE;QACLwB,EAAE,EAAG,OAAM,IAAAC,gBAAA,EAAQH,OAAR,CAAiB,EADvB;;QAEL;AAChB;AACA;QACgBI,OAAO,EAAE,CACL;UACIC,IAAI,EAAE,MADV;UAEIC,EAAE,EAAEhG,UAAU;QAFlB,CADK,EAKL;UACI+F,IAAI,EAAE,SADV;UAEIH,EAAE,EAAEF;QAFR,CALK,CALJ;QAeLO,OAAO,EAAE;MAfJ;IAPuB,CAApC;;IA0BA,IAAI;MACA,MAAMC,MAAM,GAAG,MAAM,IAAAC,eAAA,EAAmBR,WAAnB,CAArB;MAEA,MAAMrF,YAAY,GAAG,IAAA8F,oBAAA,EAAYvF,MAAZ,EAAoBqF,MAApB,CAArB;;MACA,IAAI,CAAC5F,YAAL,EAAmB;QACf,OAAO,IAAP;MACH;;MACD,OAAOI,uBAAuB,CAAC;QAC3BJ,YAD2B;QAE3BD;MAF2B,CAAD,CAA9B;IAIH,CAXD,CAWE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,gDADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,4BAFT,kCAIKxD,MAJL;QAKEyD,KAAK,EAAEJ,EALT;QAMExB,YAAY,EAAE0D,WAAW,CAAC1D,YAN5B;QAOEmC,OAAO,EAAEuB,WAAW,CAACvB,OAPvB;QAQE/D;MARF,GAAN;IAWH;EACJ,CAvDD;;EAyDA,MAAMgG,IAAI,GAAG,OACThG,KADS,EAETD,MAFS,KAGR;IACD,MAAM;MACFkG,KAAK,EAAEC,YAAY,GAAG,EADpB;MAEFC,KAAK,EAAEC,YAFL;MAGFC,KAHE;MAIFC,IAJE;MAKFlG,MALE;MAMFmG;IANE,IAOFxG,MAPJ;IAQA,MAAMkG,KAAK,GAAGC,YAAY,IAAI,CAAhB,IAAqBA,YAAY,IAAI,KAArC,GAA6C,KAA7C,GAAqDA,YAAnE;IAEA,MAAMnF,IAAI,GAAGqF,YAAY,CAACI,SAAb,GAAyB,GAAzB,GAA+B,GAA5C;IAEA,MAAM1C,cAA8B,GAAG;MACnCtD,MADmC;MAEnCoB,YAAY,EAAE,IAAAe,2BAAA,EAAsB3C,KAAtB,EAA6Be,IAA7B,CAFqB;MAGnCgD,OAAO,EAAE;QACL0C,KAAK,EAAE,MADF;QAELzC,GAAG,EAAE;MAFA;IAH0B,CAAvC;IAQA,IAAIC,OAAO,GAAG,EAAd;;IACA,IAAI;MACAA,OAAO,GAAG,MAAM,IAAAC,eAAA,EAASJ,cAAT,CAAhB;IACH,CAFD,CAEE,OAAOV,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CAAgBD,EAAE,CAACE,OAAnB,EAA4B,qBAA5B,EAAmD;QACrDE,KAAK,EAAEJ,EAD8C;QAErDxB,YAAY,EAAEkC,cAAc,CAAClC,YAFwB;QAGrDmC,OAAO,EAAED,cAAc,CAACC;MAH6B,CAAnD,CAAN;IAKH;;IACD,IAAIE,OAAO,CAACyC,MAAR,KAAmB,CAAvB,EAA0B;MACtB,OAAO;QACHC,YAAY,EAAE,KADX;QAEHC,UAAU,EAAE,CAFT;QAGHC,MAAM,EAAE,IAHL;QAIHzE,KAAK,EAAE;MAJJ,CAAP;IAMH;;IACD,MAAM+D,KAAiC,qBAChCC,YADgC,CAAvC;;IAGA,OAAOD,KAAK,CAAC,WAAD,CAAZ;IACA,OAAOA,KAAK,CAAC,QAAD,CAAZ;IACA;AACR;AACA;AACA;;IACQ,MAAMW,WAAW,GAAG,IAAAC,uBAAA,EAAiB;MACjCtG,OADiC;MAEjCT;IAFiC,CAAjB,CAApB;IAIA;AACR;AACA;AACA;;IACQ,MAAMgH,aAAa,GAAG,MAAM,IAAAC,kBAAA,EAAY;MACpC7E,KAAK,EAAE6B,OAAO,CAACE,GAAR,CAAY+C,MAAM,IAAI;QACzB,OAAO7G,uBAAuB,CAAC;UAC3BJ,YAAY,EAAEiH,MADa;UAE3BlH;QAF2B,CAAD,CAA9B;MAIH,CALM,CAD6B;MAOpCmG,KAPoC;MAQpC1F,OARoC;MASpCL,MAAM,EAAE0G,WAT4B;MAUpCvF,WAAW,EAAEH,8BAA8B,CAACpB,KAAD,CAVP;MAWpCmH,cAAc,EAAE;QACZC,IAAI,EAAEb,MADM;QAEZnG,MAAM,EAAEA,MAAM,IAAI;MAFN;IAXoB,CAAZ,CAA5B;IAiBA,MAAMwG,UAAU,GAAGI,aAAa,CAACN,MAAjC;IAEA;AACR;AACA;AACA;;IACQ,MAAMW,WAAW,GAAG,IAAAC,qBAAA,EAAe;MAC/BlF,KAAK,EAAE4E,aADwB;MAE/BV,IAF+B;MAG/BlG,MAAM,EAAE0G;IAHuB,CAAf,CAApB;IAMA,MAAMS,KAAK,GAAGC,QAAQ,CAAE,IAAAC,oBAAA,EAAapB,KAAb,CAAD,IAAmC,GAApC,CAAR,IAAoD,CAAlE;IACA,MAAMM,YAAY,GAAGC,UAAU,GAAGW,KAAK,GAAGtB,KAA1C;IACA,MAAMyB,GAAG,GAAGzB,KAAK,GAAGW,UAAU,GAAGW,KAAb,GAAqBtB,KAA7B,GAAqC0B,SAArC,GAAiDJ,KAAK,GAAGtB,KAArE;IACA,MAAM2B,WAAW,GAAGP,WAAW,CAACQ,KAAZ,CAAkBN,KAAlB,EAAyBG,GAAzB,CAApB;IACA;AACR;AACA;AACA;;IACQ,MAAMb,MAAM,GAAGD,UAAU,GAAGW,KAAK,GAAGtB,KAArB,GAA6B,IAAA6B,oBAAA,EAAc,GAAEP,KAAK,GAAGtB,KAAM,EAA9B,CAA7B,GAAgE,IAA/E;IACA,OAAO;MACHU,YADG;MAEHC,UAFG;MAGHC,MAHG;MAIHzE,KAAK,EAAE,IAAA2F,qBAAA,EAAavH,MAAb,EAAqBoH,WAArB;IAJJ,CAAP;EAMH,CAvGD;;EAyGA,MAAMI,GAAG,GAAG,OACRhI,KADQ,EAERD,MAFQ,KAGP;IACD,MAAM;MAAEqC;IAAF,IAAY,MAAM4D,IAAI,CAAChG,KAAD,kCACrBD,MADqB;MAExBkG,KAAK,EAAE;IAFiB,GAA5B;IAIA,OAAO7D,KAAK,CAACwC,KAAN,MAAiB,IAAxB;EACH,CATD;;EAWA,MAAMqD,cAAc,GAAG,OACnBjI,KADmB,EAEnBD,MAFmB,KAGlB;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAM/B,YAAY,GAAGH,qBAAqB,CAAC;MACvCG,YAAY,EAAE0B,mBADyB;MAEvC3B;IAFuC,CAAD,CAA1C;IAKA;AACR;AACA;AACA;AACA;;IACQ,MAAMoC,KAAK,GAAG,CACV5B,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIwC,IAAI,EAAE9C,UAAU,EAFpB;MAGI2C,EAAE,EAAEV,YAHR;MAIIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB,CAJR;MAKIgB,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;IANb,GADU,CAAd;IAWA;AACR;AACA;;IACQ,MAAMiC,kBAAkB,GAAG,MAAMC,0BAA0B,CAAC5D,KAAD,EAAQ0B,KAAR,CAA3D;;IAEA,IAAIiC,kBAAkB,IAAIA,kBAAkB,CAAC7B,EAAnB,KAA0BJ,KAAK,CAACI,EAA1D,EAA8D;MAC1DM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;QAEIqC,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;QAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;QAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;QAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;MANb,GADJ;IAUH;;IAED,IAAI;MACA,MAAM,IAAAuB,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;IAGH,CARD,CAQE,OAAOoD,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,8CADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,uBAFT,EAGF;QACI7B;MADJ,CAHE,CAAN;IAOH;;IACD,OAAOA,KAAP;EACH,CArED;;EAuEA,MAAMwG,aAAa,GAAG,OAClBlI,KADkB,EAElBD,MAFkB,KAGjB;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAM/B,YAAY,GAAGH,qBAAqB,CAAC;MACvCG,YAAY,EAAE0B,mBADyB;MAEvC3B;IAFuC,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;;IACQ,MAAMoC,KAAK,GAAG,CACV5B,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIwC,IAAI,EAAE9C,UAAU,EAFpB;MAGI2C,EAAE,EAAEV,YAHR;MAIIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB,CAJR;MAKIgB,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;IANb,GADU,CAAd;IAWA;AACR;AACA;;IACQ,MAAMiC,kBAAkB,GAAG,MAAMC,0BAA0B,CAAC5D,KAAD,EAAQ0B,KAAR,CAA3D;;IAEA,IAAIiC,kBAAkB,IAAIA,kBAAkB,CAAC7B,EAAnB,KAA0BJ,KAAK,CAACI,EAA1D,EAA8D;MAC1DM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;QAEIqC,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;QAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;QAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;QAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;MANb,GADJ;IAUH;;IAED,IAAI;MACA,MAAM,IAAAuB,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;MAGA,OAAO2B,mBAAP;IACH,CATD,CASE,OAAOyB,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,yCADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,sBAFT,EAGF;QACI7B,KADJ;QAEIzB;MAFJ,CAHE,CAAN;IAQH;EACJ,CArED;;EAuEA,MAAMkI,OAAO,GAAG,OACZnI,KADY,EAEZD,MAFY,KAGX;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA;AACR;AACA;;IACQ,MAAMwC,yBAAyB,GAAG,MAAMZ,0BAA0B,CAAC5D,KAAD,EAAQ0B,KAAR,CAAlE;IACA,MAAM0G,4BAA4B,GAAG,MAAM1D,6BAA6B,CAAC1E,KAAD,EAAQ0B,KAAR,CAAxE;IAEA,MAAMzB,YAAY,GAAGH,qBAAqB,CAAC;MACvCE,KADuC;MAEvCC,YAAY,EAAE0B;IAFyB,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;AACA;AACA;;IACQ,MAAMS,KAAK,GAAG,CACV5B,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB,CAHR;MAIIe,IAAI,EAAE9C,UAAU,EAJpB;MAKI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;IANb,GADU,EASVlB,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAS,4BAAA,GAHR;MAIIP,IAAI,EAAE5C,mBAAmB,EAJ7B;MAKI6C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;IANb,GATU,CAAd;;IAkBA,IAAI8C,yBAAyB,IAAI9C,KAAK,CAACI,EAAN,KAAa0C,yBAAyB,CAAC1C,EAAxE,EAA4E;MACxEM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;QAEIqC,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;QAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;QAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;QAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;MANb,GADJ;IAUH;;IACD,IAAI0G,4BAA4B,IAAIA,4BAA4B,CAACtG,EAA7B,KAAoCJ,KAAK,CAACI,EAA9E,EAAkF;MAC9E,MAAM2C,qBAAqB,GAAG3E,qBAAqB,CAAC;QAChDG,YAAY,EAAEmI,4BADkC;QAEhDpI;MAFgD,CAAD,CAAnD;MAIAoC,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOoC,qBADP;QAEInC,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBiC,qBAAtB,CAHR;QAIIhC,IAAI,EAAE9C,UAAU,EAJpB;QAKIuC,MAAM,EAAEmG,2BAAA,CAAqBC,WALjC;QAMI5F,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CANb;QAOI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiB4B,qBAAjB;MAPb,GADJ;IAWH;;IAED,IAAI;MACA,MAAM,IAAAxB,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;MAGA,OAAO2B,mBAAP;IACH,CATD,CASE,OAAOyB,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,yCADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,eAFT,EAGF;QACI7B,KADJ;QAEIiC,kBAAkB,EAAEa,yBAFxB;QAGIC,qBAAqB,EAAE2D;MAH3B,CAHE,CAAN;IASH;EACJ,CAjGD;;EAmGA,MAAMG,SAAS,GAAG,OACdvI,KADc,EAEdD,MAFc,KAGb;IACD,MAAM;MAAE2B,KAAF;MAASzB,YAAY,EAAE0B;IAAvB,IAA+C5B,MAArD;IAEA,MAAM6B,YAAY,GAAG,IAAAC,wBAAA,EAAmB;MACpCC,EAAE,EAAEJ,KAAK,CAACI,EAD0B;MAEpCC,MAAM,EAAE/B,KAAK,CAAC+B,MAFsB;MAGpCC,MAAM,EAAEhC,KAAK,CAACgC;IAHsB,CAAnB,CAArB;IAMA,MAAM/B,YAAY,GAAGH,qBAAqB,CAAC;MACvCG,YAAY,EAAE0B,mBADyB;MAEvC3B;IAFuC,CAAD,CAA1C;IAIA;AACR;AACA;AACA;AACA;AACA;;IACQ,MAAMoC,KAAK,GAAG,CACV5B,MAAM,CAAC6D,WAAP,CAAmB;MACf/B,EAAE,EAAEV,YADW;MAEfW,EAAE,EAAE,IAAAS,4BAAA;IAFW,CAAnB,CADU,EAKVxC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;MAEIqC,EAAE,EAAEV,YAFR;MAGIW,EAAE,EAAE,IAAAC,2BAAA,EAAsBd,KAAtB,CAHR;MAIIe,IAAI,EAAE9C,UAAU,EAJpB;MAKI+C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;MAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;IANb,GALU,CAAd;IAeA;AACR;AACA;;IACQ,MAAMiC,kBAAkB,GAAG,MAAMC,0BAA0B,CAAC5D,KAAD,EAAQ0B,KAAR,CAA3D;;IAEA,IAAIiC,kBAAkB,IAAIjC,KAAK,CAACI,EAAN,KAAa6B,kBAAkB,CAAC7B,EAA1D,EAA8D;MAC1DM,KAAK,CAACW,IAAN,CACIvC,MAAM,CAAC6B,QAAP,iCACOpC,YADP;QAEIqC,EAAE,EAAEV,YAFR;QAGIW,EAAE,EAAE,IAAAO,yBAAA,GAHR;QAIIL,IAAI,EAAE7C,gBAAgB,EAJ1B;QAKI8C,OAAO,EAAE,IAAAC,2BAAA,EAAsB3C,KAAtB,EAA6B,GAA7B,CALb;QAMI4C,OAAO,EAAE,IAAAC,sBAAA,EAAiBnB,KAAjB;MANb,GADJ;IAUH;;IAED,IAAI;MACA,MAAM,IAAAuB,yBAAA,EAAc;QAChBC,KAAK,EAAE1C,MAAM,CAAC0C,KADE;QAEhBd;MAFgB,CAAd,CAAN;MAIA1B,WAAW,CAACyC,QAAZ,CAAqB;QACjBnD;MADiB,CAArB;MAGA,OAAO2B,mBAAP;IACH,CATD,CASE,OAAOyB,EAAP,EAAW;MACT,MAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,oCADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,iBAFT,EAGF;QACI7B,KADJ;QAEIzB;MAFJ,CAHE,CAAN;IAQH;EACJ,CA1ED;;EA4EA,OAAO;IACHwB,MADG;IAEHgC,kBAFG;IAGHC,MAHG;IAIH8E,MAAM,EAAE3E,WAJL;IAKHS,cALG;IAMHa,mBANG;IAOHD,iBAPG;IAQHD,cARG;IASHD,QATG;IAUHH,eAVG;IAWHH,6BAXG;IAYHd,0BAZG;IAaHoE,GAbG;IAcHlD,YAdG;IAeHmD,cAfG;IAgBHC,aAhBG;IAiBHC,OAjBG;IAkBHnC,IAlBG;IAmBHuC;EAnBG,CAAP;AAqBH,CAxgCM"}
@@ -13,26 +13,31 @@ const systemFields = {
13
13
  id: createSystemField({
14
14
  id: "id",
15
15
  type: "text",
16
+ storageId: "id",
16
17
  fieldId: "id"
17
18
  }),
18
19
  entryId: createSystemField({
19
20
  id: "entryId",
20
21
  type: "text",
22
+ storageId: "entryId",
21
23
  fieldId: "entryId"
22
24
  }),
23
25
  createdOn: createSystemField({
24
26
  id: "createdOn",
25
27
  type: "datetime",
28
+ storageId: "createdOn",
26
29
  fieldId: "createdOn"
27
30
  }),
28
31
  savedOn: createSystemField({
29
32
  id: "savedOn",
30
33
  type: "datetime",
34
+ storageId: "savedOn",
31
35
  fieldId: "savedOn"
32
36
  }),
33
37
  createdBy: createSystemField({
34
38
  id: "createdBy",
35
39
  type: "plainObject",
40
+ storageId: "createdBy",
36
41
  fieldId: "createdBy",
37
42
  settings: {
38
43
  path: "createdBy.id"
@@ -41,11 +46,13 @@ const systemFields = {
41
46
  meta: createSystemField({
42
47
  id: "meta",
43
48
  type: "plainObject",
49
+ storageId: "meta",
44
50
  fieldId: "meta"
45
51
  }),
46
52
  ownedBy: createSystemField({
47
53
  id: "ownedBy",
48
54
  type: "plainObject",
55
+ storageId: "ownedBy",
49
56
  fieldId: "ownedBy",
50
57
  settings: {
51
58
  path: "ownedBy.id"
@@ -54,6 +61,7 @@ const systemFields = {
54
61
  version: createSystemField({
55
62
  id: "version",
56
63
  type: "number",
64
+ storageId: "version",
57
65
  fieldId: "version"
58
66
  })
59
67
  };
@@ -1 +1 @@
1
- {"version":3,"names":["createSystemField","field","systemFields","id","type","fieldId","entryId","createdOn","savedOn","createdBy","settings","path","meta","ownedBy","version"],"sources":["systemFields.ts"],"sourcesContent":["import { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\nconst createSystemField = (field: Partial<CmsModelField>): CmsModelField => {\n return field as CmsModelField;\n};\n\nexport const systemFields: Record<string, CmsModelField> = {\n id: createSystemField({\n id: \"id\",\n type: \"text\",\n fieldId: \"id\"\n }),\n entryId: createSystemField({\n id: \"entryId\",\n type: \"text\",\n fieldId: \"entryId\"\n }),\n createdOn: createSystemField({\n id: \"createdOn\",\n type: \"datetime\",\n fieldId: \"createdOn\"\n }),\n savedOn: createSystemField({\n id: \"savedOn\",\n type: \"datetime\",\n fieldId: \"savedOn\"\n }),\n createdBy: createSystemField({\n id: \"createdBy\",\n type: \"plainObject\",\n fieldId: \"createdBy\",\n settings: {\n path: \"createdBy.id\"\n }\n }),\n meta: createSystemField({\n id: \"meta\",\n type: \"plainObject\",\n fieldId: \"meta\"\n }),\n ownedBy: createSystemField({\n id: \"ownedBy\",\n type: \"plainObject\",\n fieldId: \"ownedBy\",\n settings: {\n path: \"ownedBy.id\"\n }\n }),\n version: createSystemField({\n id: \"version\",\n type: \"number\",\n fieldId: \"version\"\n })\n};\n"],"mappings":";;;;;;;AAEA,MAAMA,iBAAiB,GAAIC,KAAD,IAAkD;EACxE,OAAOA,KAAP;AACH,CAFD;;AAIO,MAAMC,YAA2C,GAAG;EACvDC,EAAE,EAAEH,iBAAiB,CAAC;IAClBG,EAAE,EAAE,IADc;IAElBC,IAAI,EAAE,MAFY;IAGlBC,OAAO,EAAE;EAHS,CAAD,CADkC;EAMvDC,OAAO,EAAEN,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SADmB;IAEvBC,IAAI,EAAE,MAFiB;IAGvBC,OAAO,EAAE;EAHc,CAAD,CAN6B;EAWvDE,SAAS,EAAEP,iBAAiB,CAAC;IACzBG,EAAE,EAAE,WADqB;IAEzBC,IAAI,EAAE,UAFmB;IAGzBC,OAAO,EAAE;EAHgB,CAAD,CAX2B;EAgBvDG,OAAO,EAAER,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SADmB;IAEvBC,IAAI,EAAE,UAFiB;IAGvBC,OAAO,EAAE;EAHc,CAAD,CAhB6B;EAqBvDI,SAAS,EAAET,iBAAiB,CAAC;IACzBG,EAAE,EAAE,WADqB;IAEzBC,IAAI,EAAE,aAFmB;IAGzBC,OAAO,EAAE,WAHgB;IAIzBK,QAAQ,EAAE;MACNC,IAAI,EAAE;IADA;EAJe,CAAD,CArB2B;EA6BvDC,IAAI,EAAEZ,iBAAiB,CAAC;IACpBG,EAAE,EAAE,MADgB;IAEpBC,IAAI,EAAE,aAFc;IAGpBC,OAAO,EAAE;EAHW,CAAD,CA7BgC;EAkCvDQ,OAAO,EAAEb,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SADmB;IAEvBC,IAAI,EAAE,aAFiB;IAGvBC,OAAO,EAAE,SAHc;IAIvBK,QAAQ,EAAE;MACNC,IAAI,EAAE;IADA;EAJa,CAAD,CAlC6B;EA0CvDG,OAAO,EAAEd,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SADmB;IAEvBC,IAAI,EAAE,QAFiB;IAGvBC,OAAO,EAAE;EAHc,CAAD;AA1C6B,CAApD"}
1
+ {"version":3,"names":["createSystemField","field","systemFields","id","type","storageId","fieldId","entryId","createdOn","savedOn","createdBy","settings","path","meta","ownedBy","version"],"sources":["systemFields.ts"],"sourcesContent":["import { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\ntype CmsModelFieldInput = Partial<CmsModelField> &\n Pick<CmsModelField, \"id\" | \"type\" | \"storageId\" | \"fieldId\">;\nconst createSystemField = (field: CmsModelFieldInput): CmsModelField => {\n return field as CmsModelField;\n};\n\nexport const systemFields: Record<string, CmsModelField> = {\n id: createSystemField({\n id: \"id\",\n type: \"text\",\n storageId: \"id\",\n fieldId: \"id\"\n }),\n entryId: createSystemField({\n id: \"entryId\",\n type: \"text\",\n storageId: \"entryId\",\n fieldId: \"entryId\"\n }),\n createdOn: createSystemField({\n id: \"createdOn\",\n type: \"datetime\",\n storageId: \"createdOn\",\n fieldId: \"createdOn\"\n }),\n savedOn: createSystemField({\n id: \"savedOn\",\n type: \"datetime\",\n storageId: \"savedOn\",\n fieldId: \"savedOn\"\n }),\n createdBy: createSystemField({\n id: \"createdBy\",\n type: \"plainObject\",\n storageId: \"createdBy\",\n fieldId: \"createdBy\",\n settings: {\n path: \"createdBy.id\"\n }\n }),\n meta: createSystemField({\n id: \"meta\",\n type: \"plainObject\",\n storageId: \"meta\",\n fieldId: \"meta\"\n }),\n ownedBy: createSystemField({\n id: \"ownedBy\",\n type: \"plainObject\",\n storageId: \"ownedBy\",\n fieldId: \"ownedBy\",\n settings: {\n path: \"ownedBy.id\"\n }\n }),\n version: createSystemField({\n id: \"version\",\n type: \"number\",\n storageId: \"version\",\n fieldId: \"version\"\n })\n};\n"],"mappings":";;;;;;;AAIA,MAAMA,iBAAiB,GAAIC,KAAD,IAA8C;EACpE,OAAOA,KAAP;AACH,CAFD;;AAIO,MAAMC,YAA2C,GAAG;EACvDC,EAAE,EAAEH,iBAAiB,CAAC;IAClBG,EAAE,EAAE,IADc;IAElBC,IAAI,EAAE,MAFY;IAGlBC,SAAS,EAAE,IAHO;IAIlBC,OAAO,EAAE;EAJS,CAAD,CADkC;EAOvDC,OAAO,EAAEP,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SADmB;IAEvBC,IAAI,EAAE,MAFiB;IAGvBC,SAAS,EAAE,SAHY;IAIvBC,OAAO,EAAE;EAJc,CAAD,CAP6B;EAavDE,SAAS,EAAER,iBAAiB,CAAC;IACzBG,EAAE,EAAE,WADqB;IAEzBC,IAAI,EAAE,UAFmB;IAGzBC,SAAS,EAAE,WAHc;IAIzBC,OAAO,EAAE;EAJgB,CAAD,CAb2B;EAmBvDG,OAAO,EAAET,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SADmB;IAEvBC,IAAI,EAAE,UAFiB;IAGvBC,SAAS,EAAE,SAHY;IAIvBC,OAAO,EAAE;EAJc,CAAD,CAnB6B;EAyBvDI,SAAS,EAAEV,iBAAiB,CAAC;IACzBG,EAAE,EAAE,WADqB;IAEzBC,IAAI,EAAE,aAFmB;IAGzBC,SAAS,EAAE,WAHc;IAIzBC,OAAO,EAAE,WAJgB;IAKzBK,QAAQ,EAAE;MACNC,IAAI,EAAE;IADA;EALe,CAAD,CAzB2B;EAkCvDC,IAAI,EAAEb,iBAAiB,CAAC;IACpBG,EAAE,EAAE,MADgB;IAEpBC,IAAI,EAAE,aAFc;IAGpBC,SAAS,EAAE,MAHS;IAIpBC,OAAO,EAAE;EAJW,CAAD,CAlCgC;EAwCvDQ,OAAO,EAAEd,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SADmB;IAEvBC,IAAI,EAAE,aAFiB;IAGvBC,SAAS,EAAE,SAHY;IAIvBC,OAAO,EAAE,SAJc;IAKvBK,QAAQ,EAAE;MACNC,IAAI,EAAE;IADA;EALa,CAAD,CAxC6B;EAiDvDG,OAAO,EAAEf,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SADmB;IAEvBC,IAAI,EAAE,QAFiB;IAGvBC,SAAS,EAAE,SAHY;IAIvBC,OAAO,EAAE;EAJc,CAAD;AAjD6B,CAApD"}
@@ -30,6 +30,11 @@ const VALUES_ATTRIBUTE = "values";
30
30
  const extractWhereParams = key => {
31
31
  const result = key.split("_");
32
32
  const fieldId = result.shift();
33
+
34
+ if (!fieldId) {
35
+ return null;
36
+ }
37
+
33
38
  const rawOp = result.length === 0 ? "eq" : result.join("_");
34
39
  /**
35
40
  * When rawOp is not, it means it is equal negated so just return that.
@@ -37,7 +42,7 @@ const extractWhereParams = key => {
37
42
 
38
43
  if (rawOp === "not") {
39
44
  return {
40
- fieldId: fieldId,
45
+ fieldId,
41
46
  operation: "eq",
42
47
  negate: true
43
48
  };
@@ -46,7 +51,7 @@ const extractWhereParams = key => {
46
51
  const negate = rawOp.match("not_") !== null;
47
52
  const operation = rawOp.replace("not_", "");
48
53
  return {
49
- fieldId: fieldId,
54
+ fieldId,
50
55
  operation,
51
56
  negate
52
57
  };
@@ -89,7 +94,7 @@ const createValuePath = params => {
89
94
  const basePath = _systemFields.systemFields[fieldId] ? "" : `${VALUES_ATTRIBUTE}.`;
90
95
 
91
96
  if (!valuePathPlugin || valuePathPlugin.canUse(field) === false) {
92
- return `${basePath}${field.fieldId}`;
97
+ return `${basePath}${fieldId}`;
93
98
  }
94
99
 
95
100
  const path = valuePathPlugin.createPath({
@@ -151,11 +156,17 @@ const createFilters = params => {
151
156
  continue;
152
157
  }
153
158
 
159
+ const whereParams = extractWhereParams(key);
160
+
161
+ if (!whereParams) {
162
+ continue;
163
+ }
164
+
154
165
  const {
155
166
  fieldId,
156
167
  operation,
157
168
  negate
158
- } = extractWhereParams(key);
169
+ } = whereParams;
159
170
  const field = fields[fieldId];
160
171
 
161
172
  if (!field) {
@@ -191,11 +202,17 @@ const createFilters = params => {
191
202
  }
192
203
 
193
204
  for (const propertyFilter of propertyFilters) {
205
+ const whereParams = extractWhereParams(propertyFilter);
206
+
207
+ if (!whereParams) {
208
+ continue;
209
+ }
210
+
194
211
  const {
195
212
  fieldId: propertyId,
196
213
  operation: propertyOperation,
197
214
  negate: propertyNegate
198
- } = extractWhereParams(propertyFilter);
215
+ } = whereParams;
199
216
  const filterPlugin = getFilterPlugin({
200
217
  plugins: filterPlugins,
201
218
  operation: propertyOperation
@@ -297,7 +314,17 @@ const createFullTextSearch = ({
297
314
  fields
298
315
  }) => {
299
316
  for (const targetField of targetFields) {
300
- const value = await fromStorage(fields[targetField].def, item.values[targetField]);
317
+ const field = Object.values(fields).find(field => {
318
+ return field.def.fieldId === targetField;
319
+ });
320
+
321
+ if (!field) {
322
+ throw new _error.default(`Unknown field "${targetField}" in the model.`, "UNKNOWN_FIELD", {
323
+ target: targetField
324
+ });
325
+ }
326
+
327
+ const value = await fromStorage(field.def, item.values[targetField]);
301
328
 
302
329
  if (!value) {
303
330
  continue;
@@ -445,13 +472,15 @@ const extractSort = (sortBy, fields) => {
445
472
  const result = sortBy.split("_");
446
473
 
447
474
  if (result.length !== 2) {
448
- throw new _error.default("Problem in determining the sorting for the entry items.", "SORT_ERROR", {
475
+ throw new _error.default("Problem in determining the sorting for the entry items.", "SORT_EXTRACT_ERROR", {
449
476
  sortBy
450
477
  });
451
478
  }
452
479
 
453
480
  const [fieldId, order] = result;
454
- const modelField = fields[fieldId];
481
+ const modelField = Object.values(fields).find(field => {
482
+ return field.def.fieldId === fieldId;
483
+ });
455
484
 
456
485
  if (!modelField) {
457
486
  throw new _error.default("Sorting field does not exist in the content model.", "SORTING_FIELD_ERROR", {
@@ -464,6 +493,7 @@ const extractSort = (sortBy, fields) => {
464
493
  field: modelField.def
465
494
  });
466
495
  return {
496
+ field: modelField,
467
497
  fieldId,
468
498
  valuePath,
469
499
  reverse: order === "DESC"
@@ -482,7 +512,7 @@ const sortEntryItems = params => {
482
512
  } else if (sort.length === 0) {
483
513
  sort.push("savedOn_DESC");
484
514
  } else if (sort.length > 1) {
485
- throw new _error.default("Sorting is limited to a single field.", "SORT_ERROR", {
515
+ throw new _error.default("Sorting is limited to a single field.", "SORT_MULTIPLE_FIELDS_ERROR", {
486
516
  sort: sort
487
517
  });
488
518
  }
@@ -490,17 +520,17 @@ const sortEntryItems = params => {
490
520
  const [firstSort] = sort;
491
521
 
492
522
  if (!firstSort) {
493
- throw new _error.default("Empty sort array item.", "SORT_ERROR", {
523
+ throw new _error.default("Empty sort array item.", "SORT_EMPTY_ERROR", {
494
524
  sort
495
525
  });
496
526
  }
497
527
 
498
528
  const {
499
529
  fieldId,
530
+ field,
500
531
  valuePath,
501
532
  reverse
502
533
  } = extractSort(firstSort, fields);
503
- const field = fields[fieldId];
504
534
  const itemsToSort = items.map(item => {
505
535
  return {
506
536
  id: item.id,
@@ -575,6 +605,15 @@ const buildModelFields = ({
575
605
  property: "fieldType"
576
606
  });
577
607
  const fields = Object.values(_systemFields.systemFields).reduce((collection, field) => {
608
+ /**
609
+ * This should be caught on the tests runs and never actually happen on live system.
610
+ */
611
+ if (!field.fieldId) {
612
+ throw new _error.default("Missing system field `fieldId`.", "FIELD_ID_ERROR", {
613
+ field
614
+ });
615
+ }
616
+
578
617
  const transformValuePlugin = transformValuePlugins[field.type];
579
618
  const valuePathPlugin = valuePathPlugins[field.type];
580
619
 
@@ -606,6 +645,11 @@ const buildModelFields = ({
606
645
  return collection;
607
646
  }, {});
608
647
  return model.fields.reduce((collection, field) => {
648
+ if (!field.fieldId) {
649
+ console.log(`Field "${field.storageId}" in model "${model.modelId}" is missing fieldId.`);
650
+ return collection;
651
+ }
652
+
609
653
  const transformValuePlugin = transformValuePlugins[field.type];
610
654
  const valuePathPlugin = valuePathPlugins[field.type];
611
655