@webiny/api-headless-cms-ddb 5.34.8 → 5.35.0-beta.1

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.
Files changed (91) hide show
  1. package/definitions/entry.js +3 -5
  2. package/definitions/entry.js.map +1 -1
  3. package/definitions/group.js +0 -5
  4. package/definitions/group.js.map +1 -1
  5. package/definitions/model.js +17 -5
  6. package/definitions/model.js.map +1 -1
  7. package/definitions/settings.js +0 -5
  8. package/definitions/settings.js.map +1 -1
  9. package/definitions/system.js +0 -5
  10. package/definitions/system.js.map +1 -1
  11. package/definitions/table.js +0 -3
  12. package/definitions/table.js.map +1 -1
  13. package/dynamoDb/index.js +0 -7
  14. package/dynamoDb/index.js.map +1 -1
  15. package/dynamoDb/path/plainObject.js +1 -8
  16. package/dynamoDb/path/plainObject.js.map +1 -1
  17. package/dynamoDb/storage/date.js +1 -19
  18. package/dynamoDb/storage/date.js.map +1 -1
  19. package/dynamoDb/storage/longText.js +1 -18
  20. package/dynamoDb/storage/longText.js.map +1 -1
  21. package/dynamoDb/storage/richText.js +0 -18
  22. package/dynamoDb/storage/richText.js.map +1 -1
  23. package/dynamoDb/transformValue/datetime.js +1 -8
  24. package/dynamoDb/transformValue/datetime.js.map +1 -1
  25. package/index.js +6 -30
  26. package/index.js.map +1 -1
  27. package/operations/entry/dataLoaders.js +1 -44
  28. package/operations/entry/dataLoaders.js.map +1 -1
  29. package/operations/entry/filtering/createExpressions.js +2 -39
  30. package/operations/entry/filtering/createExpressions.js.map +1 -1
  31. package/operations/entry/filtering/createFields.js +0 -18
  32. package/operations/entry/filtering/createFields.js.map +1 -1
  33. package/operations/entry/filtering/extractSort.js +0 -10
  34. package/operations/entry/filtering/extractSort.js.map +1 -1
  35. package/operations/entry/filtering/filter.js +1 -36
  36. package/operations/entry/filtering/filter.js.map +1 -1
  37. package/operations/entry/filtering/fullTextSearch.js +0 -12
  38. package/operations/entry/filtering/fullTextSearch.js.map +1 -1
  39. package/operations/entry/filtering/getValue.js +0 -18
  40. package/operations/entry/filtering/getValue.js.map +1 -1
  41. package/operations/entry/filtering/index.js +0 -2
  42. package/operations/entry/filtering/index.js.map +1 -1
  43. package/operations/entry/filtering/mapPlugins.js +0 -8
  44. package/operations/entry/filtering/mapPlugins.js.map +1 -1
  45. package/operations/entry/filtering/plugins/defaultFilterCreate.js +0 -7
  46. package/operations/entry/filtering/plugins/defaultFilterCreate.js.map +1 -1
  47. package/operations/entry/filtering/plugins/index.js +0 -5
  48. package/operations/entry/filtering/plugins/index.js.map +1 -1
  49. package/operations/entry/filtering/plugins/objectFilterCreate.js +0 -21
  50. package/operations/entry/filtering/plugins/objectFilterCreate.js.map +1 -1
  51. package/operations/entry/filtering/plugins/refFilterCreate.js +0 -18
  52. package/operations/entry/filtering/plugins/refFilterCreate.js.map +1 -1
  53. package/operations/entry/filtering/sort.js +0 -15
  54. package/operations/entry/filtering/sort.js.map +1 -1
  55. package/operations/entry/filtering/systemFields.js +0 -2
  56. package/operations/entry/filtering/systemFields.js.map +1 -1
  57. package/operations/entry/filtering/transform.js +0 -3
  58. package/operations/entry/filtering/transform.js.map +1 -1
  59. package/operations/entry/filtering/values.js +0 -6
  60. package/operations/entry/filtering/values.js.map +1 -1
  61. package/operations/entry/filtering/where.js +0 -6
  62. package/operations/entry/filtering/where.js.map +1 -1
  63. package/operations/entry/index.js +58 -116
  64. package/operations/entry/index.js.map +1 -1
  65. package/operations/entry/keys.js +0 -18
  66. package/operations/entry/keys.js.map +1 -1
  67. package/operations/entry/systemFields.js +0 -2
  68. package/operations/entry/systemFields.js.map +1 -1
  69. package/operations/group/index.js +2 -32
  70. package/operations/group/index.js.map +1 -1
  71. package/operations/model/index.js +0 -25
  72. package/operations/model/index.js.map +1 -1
  73. package/operations/settings/index.js +0 -24
  74. package/operations/settings/index.js.map +1 -1
  75. package/operations/system/index.js +0 -17
  76. package/operations/system/index.js.map +1 -1
  77. package/package.json +13 -13
  78. package/plugins/CmsEntryFieldFilterPathPlugin.js +0 -14
  79. package/plugins/CmsEntryFieldFilterPathPlugin.js.map +1 -1
  80. package/plugins/CmsEntryFieldFilterPlugin.js +0 -7
  81. package/plugins/CmsEntryFieldFilterPlugin.js.map +1 -1
  82. package/plugins/CmsEntryFieldSortingPlugin.js +0 -10
  83. package/plugins/CmsEntryFieldSortingPlugin.js.map +1 -1
  84. package/plugins/CmsFieldFilterValueTransformPlugin.d.ts +11 -0
  85. package/plugins/CmsFieldFilterValueTransformPlugin.js +24 -0
  86. package/plugins/CmsFieldFilterValueTransformPlugin.js.map +1 -0
  87. package/plugins/index.d.ts +1 -0
  88. package/plugins/index.js +11 -6
  89. package/plugins/index.js.map +1 -1
  90. package/types.js +0 -1
  91. package/types.js.map +1 -1
@@ -1 +1 @@
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","sortBy","search","published","index","storageEntries","length","hasMoreItems","totalCount","cursor","modelFields","createFields","Promise","all","fieldId","filteredItems","filter","fullTextSearch","term","sortedItems","start","parseInt","decodeCursor","end","undefined","slicedItems","slice","encodeCursor","cleanupItems","get","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 CmsEntryStorageOperationsUnpublishParams,\n CmsEntryStorageOperationsUpdateParams,\n StorageOperationsCmsModel,\n CONTENT_ENTRY_STATUS,\n CmsStorageEntry\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\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\";\nimport { FilterItemFromStorage } from \"./filtering/types\";\nimport { createFields } from \"~/operations/entry/filtering/createFields\";\nimport { filter, sort } from \"~/operations/entry/filtering\";\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: sortBy,\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 storageEntries: CmsStorageEntry[] = [];\n try {\n storageEntries = await queryAll<CmsStorageEntry>(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 (storageEntries.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 an 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 = createFields({\n plugins,\n fields: model.fields\n });\n\n const fromStorage = createStorageTransformCallable(model);\n /**\n * Let's transform records from storage ones to regular ones, so we do not need to do it later.\n *\n * This is always being done, but at least its in parallel.\n */\n const records = await Promise.all(\n storageEntries.map(async storageEntry => {\n const entry = convertFromStorageEntry({\n storageEntry,\n model\n });\n\n for (const field of model.fields) {\n entry.values[field.fieldId] = await fromStorage(\n field,\n entry.values[field.fieldId]\n );\n }\n\n return entry as CmsEntry;\n })\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 = filter({\n items: records,\n where,\n plugins,\n fields: modelFields,\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 = sort({\n model,\n plugins,\n items: filteredItems,\n sort: sortBy,\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 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 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","storageOperationsCmsModelPlugin","getStorageOperationsCmsModelPlugin","oneByType","StorageOperationsCmsModelPlugin","type","getStorageOperationsModel","plugin","getModel","dataLoaders","DataLoadersHandler","storageTransformPlugins","byType","StorageTransformPlugin","reduce","collection","fieldType","createStorageTransformCallable","field","value","fromStorage","getStoragePlugin","create","initialModel","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","sortBy","search","published","index","storageEntries","length","hasMoreItems","totalCount","cursor","modelFields","createFields","Promise","all","fieldId","filteredItems","filter","fullTextSearch","term","sortedItems","start","parseInt","decodeCursor","end","undefined","slicedItems","slice","encodeCursor","cleanupItems","get","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 CmsModel,\n CmsStorageEntry,\n CONTENT_ENTRY_STATUS,\n StorageOperationsCmsModel\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\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 { StorageOperationsCmsModelPlugin, StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport { FilterItemFromStorage } from \"./filtering/types\";\nimport { createFields } from \"~/operations/entry/filtering/createFields\";\nimport { filter, sort } from \"~/operations/entry/filtering\";\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 let storageOperationsCmsModelPlugin: StorageOperationsCmsModelPlugin | undefined;\n const getStorageOperationsCmsModelPlugin = () => {\n if (storageOperationsCmsModelPlugin) {\n return storageOperationsCmsModelPlugin;\n }\n storageOperationsCmsModelPlugin = plugins.oneByType<StorageOperationsCmsModelPlugin>(\n StorageOperationsCmsModelPlugin.type\n );\n return storageOperationsCmsModelPlugin;\n };\n\n const getStorageOperationsModel = (model: CmsModel): StorageOperationsCmsModel => {\n const plugin = getStorageOperationsCmsModelPlugin();\n return plugin.getModel(model);\n };\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: CmsEntryStorageOperations[\"create\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\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 the 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: CmsEntryStorageOperations[\"createRevisionFrom\"] = async (\n initialModel,\n params\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"update\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\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 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 necessary.\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: CmsEntryStorageOperations[\"delete\"] = async (initialModel, params) => {\n const { entry } = params;\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"deleteRevision\"] = async (\n initialModel,\n params\n ) => {\n const { entry, latestEntry, latestStorageEntry: initialLatestStorageEntry } = params;\n\n const model = getStorageOperationsModel(initialModel);\n\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: CmsEntryStorageOperations[\"getLatestRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"getPublishedRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"getRevisionById\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"getRevisions\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"getByIds\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"getLatestByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"getPublishedByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"getPreviousRevision\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\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: CmsEntryStorageOperations[\"list\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const {\n limit: initialLimit = 10,\n where: initialWhere,\n after,\n sort: sortBy,\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 storageEntries: CmsStorageEntry[] = [];\n try {\n storageEntries = await queryAll<CmsStorageEntry>(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 (storageEntries.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 an 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 = createFields({\n plugins,\n fields: model.fields\n });\n\n const fromStorage = createStorageTransformCallable(model);\n /**\n * Let's transform records from storage ones to regular ones, so we do not need to do it later.\n *\n * This is always being done, but at least its in parallel.\n */\n const records = await Promise.all(\n storageEntries.map(async storageEntry => {\n const entry = convertFromStorageEntry({\n storageEntry,\n model\n });\n\n for (const field of model.fields) {\n entry.values[field.fieldId] = await fromStorage(\n field,\n entry.values[field.fieldId]\n );\n }\n\n return entry as CmsEntry;\n })\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 = filter({\n items: records,\n where,\n plugins,\n fields: modelFields,\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 = sort({\n model,\n plugins,\n items: filteredItems,\n sort: sortBy,\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: CmsEntryStorageOperations[\"get\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish: CmsEntryStorageOperations[\"publish\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\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 alongside 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 * - the 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: CmsEntryStorageOperations[\"unpublish\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\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 the 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 alongside 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 publish,\n list,\n unpublish\n };\n};\n"],"mappings":"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"}
@@ -1,31 +1,24 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.createRevisionSortKey = exports.createPublishedSortKey = exports.createPartitionKey = exports.createLatestSortKey = exports.createGSISortKey = exports.createGSIPartitionKey = void 0;
9
-
10
8
  var _utils = require("@webiny/utils");
11
-
12
9
  var _error = _interopRequireDefault(require("@webiny/error"));
13
-
14
10
  const createBasePartitionKey = params => {
15
11
  const {
16
12
  tenant,
17
13
  locale
18
14
  } = params;
19
-
20
15
  if (!tenant) {
21
16
  throw new _error.default(`Missing tenant variable when creating entry basePartitionKey`);
22
17
  } else if (!locale) {
23
18
  throw new _error.default(`Missing tenant variable when creating entry basePartitionKey`);
24
19
  }
25
-
26
20
  return `T#${tenant}#L#${locale}#CMS#CME`;
27
21
  };
28
-
29
22
  const createPartitionKey = params => {
30
23
  const {
31
24
  id: initialId
@@ -35,27 +28,19 @@ const createPartitionKey = params => {
35
28
  } = (0, _utils.parseIdentifier)(initialId);
36
29
  return `${createBasePartitionKey(params)}#CME#${id}`;
37
30
  };
38
-
39
31
  exports.createPartitionKey = createPartitionKey;
40
-
41
32
  const createRevisionSortKey = params => {
42
33
  return `REV#${(0, _utils.zeroPad)(params.version)}`;
43
34
  };
44
-
45
35
  exports.createRevisionSortKey = createRevisionSortKey;
46
-
47
36
  const createLatestSortKey = () => {
48
37
  return "L";
49
38
  };
50
-
51
39
  exports.createLatestSortKey = createLatestSortKey;
52
-
53
40
  const createPublishedSortKey = () => {
54
41
  return "P";
55
42
  };
56
-
57
43
  exports.createPublishedSortKey = createPublishedSortKey;
58
-
59
44
  const createGSIPartitionKey = (params, type) => {
60
45
  const {
61
46
  modelId
@@ -63,11 +48,8 @@ const createGSIPartitionKey = (params, type) => {
63
48
  const partitionKey = createBasePartitionKey(params);
64
49
  return `${partitionKey}#M#${modelId}#${type}`;
65
50
  };
66
-
67
51
  exports.createGSIPartitionKey = createGSIPartitionKey;
68
-
69
52
  const createGSISortKey = params => {
70
53
  return params.id;
71
54
  };
72
-
73
55
  exports.createGSISortKey = createGSISortKey;
@@ -1 +1 @@
1
- {"version":3,"names":["createBasePartitionKey","params","tenant","locale","WebinyError","createPartitionKey","id","initialId","parseIdentifier","createRevisionSortKey","zeroPad","version","createLatestSortKey","createPublishedSortKey","createGSIPartitionKey","type","modelId","partitionKey","createGSISortKey"],"sources":["keys.ts"],"sourcesContent":["import { parseIdentifier, zeroPad } from \"@webiny/utils\";\nimport WebinyError from \"@webiny/error\";\n\ninterface BasePartitionKeyParams {\n tenant: string;\n locale: string;\n}\nconst createBasePartitionKey = (params: BasePartitionKeyParams): string => {\n const { tenant, locale } = params;\n if (!tenant) {\n throw new WebinyError(`Missing tenant variable when creating entry basePartitionKey`);\n } else if (!locale) {\n throw new WebinyError(`Missing tenant variable when creating entry basePartitionKey`);\n }\n return `T#${tenant}#L#${locale}#CMS#CME`;\n};\n\nexport interface PartitionKeyParams extends BasePartitionKeyParams {\n id: string;\n}\nexport const createPartitionKey = (params: PartitionKeyParams): string => {\n const { id: initialId } = params;\n const { id } = parseIdentifier(initialId);\n return `${createBasePartitionKey(params)}#CME#${id}`;\n};\n\nexport interface SortKeyParams {\n version: number;\n}\nexport const createRevisionSortKey = (params: SortKeyParams): string => {\n return `REV#${zeroPad(params.version)}`;\n};\n\nexport const createLatestSortKey = (): string => {\n return \"L\";\n};\n\nexport const createPublishedSortKey = (): string => {\n return \"P\";\n};\n\nexport interface GSIPartitionKeyParams {\n tenant: string;\n locale: string;\n modelId: string;\n}\nexport const createGSIPartitionKey = (params: GSIPartitionKeyParams, type: \"A\" | \"L\" | \"P\") => {\n const { modelId } = params;\n const partitionKey = createBasePartitionKey(params);\n return `${partitionKey}#M#${modelId}#${type}`;\n};\n\nexport interface GSISortKeyParams {\n id: string;\n}\nexport const createGSISortKey = (params: GSISortKeyParams): string => {\n return params.id;\n};\n"],"mappings":";;;;;;;;;AAAA;;AACA;;AAMA,MAAMA,sBAAsB,GAAIC,MAAD,IAA4C;EACvE,MAAM;IAAEC,MAAF;IAAUC;EAAV,IAAqBF,MAA3B;;EACA,IAAI,CAACC,MAAL,EAAa;IACT,MAAM,IAAIE,cAAJ,CAAiB,8DAAjB,CAAN;EACH,CAFD,MAEO,IAAI,CAACD,MAAL,EAAa;IAChB,MAAM,IAAIC,cAAJ,CAAiB,8DAAjB,CAAN;EACH;;EACD,OAAQ,KAAIF,MAAO,MAAKC,MAAO,UAA/B;AACH,CARD;;AAaO,MAAME,kBAAkB,GAAIJ,MAAD,IAAwC;EACtE,MAAM;IAAEK,EAAE,EAAEC;EAAN,IAAoBN,MAA1B;EACA,MAAM;IAAEK;EAAF,IAAS,IAAAE,sBAAA,EAAgBD,SAAhB,CAAf;EACA,OAAQ,GAAEP,sBAAsB,CAACC,MAAD,CAAS,QAAOK,EAAG,EAAnD;AACH,CAJM;;;;AASA,MAAMG,qBAAqB,GAAIR,MAAD,IAAmC;EACpE,OAAQ,OAAM,IAAAS,cAAA,EAAQT,MAAM,CAACU,OAAf,CAAwB,EAAtC;AACH,CAFM;;;;AAIA,MAAMC,mBAAmB,GAAG,MAAc;EAC7C,OAAO,GAAP;AACH,CAFM;;;;AAIA,MAAMC,sBAAsB,GAAG,MAAc;EAChD,OAAO,GAAP;AACH,CAFM;;;;AASA,MAAMC,qBAAqB,GAAG,CAACb,MAAD,EAAgCc,IAAhC,KAA0D;EAC3F,MAAM;IAAEC;EAAF,IAAcf,MAApB;EACA,MAAMgB,YAAY,GAAGjB,sBAAsB,CAACC,MAAD,CAA3C;EACA,OAAQ,GAAEgB,YAAa,MAAKD,OAAQ,IAAGD,IAAK,EAA5C;AACH,CAJM;;;;AASA,MAAMG,gBAAgB,GAAIjB,MAAD,IAAsC;EAClE,OAAOA,MAAM,CAACK,EAAd;AACH,CAFM"}
1
+ {"version":3,"names":["createBasePartitionKey","params","tenant","locale","WebinyError","createPartitionKey","id","initialId","parseIdentifier","createRevisionSortKey","zeroPad","version","createLatestSortKey","createPublishedSortKey","createGSIPartitionKey","type","modelId","partitionKey","createGSISortKey"],"sources":["keys.ts"],"sourcesContent":["import { parseIdentifier, zeroPad } from \"@webiny/utils\";\nimport WebinyError from \"@webiny/error\";\n\ninterface BasePartitionKeyParams {\n tenant: string;\n locale: string;\n}\nconst createBasePartitionKey = (params: BasePartitionKeyParams): string => {\n const { tenant, locale } = params;\n if (!tenant) {\n throw new WebinyError(`Missing tenant variable when creating entry basePartitionKey`);\n } else if (!locale) {\n throw new WebinyError(`Missing tenant variable when creating entry basePartitionKey`);\n }\n return `T#${tenant}#L#${locale}#CMS#CME`;\n};\n\nexport interface PartitionKeyParams extends BasePartitionKeyParams {\n id: string;\n}\nexport const createPartitionKey = (params: PartitionKeyParams): string => {\n const { id: initialId } = params;\n const { id } = parseIdentifier(initialId);\n return `${createBasePartitionKey(params)}#CME#${id}`;\n};\n\nexport interface SortKeyParams {\n version: number;\n}\nexport const createRevisionSortKey = (params: SortKeyParams): string => {\n return `REV#${zeroPad(params.version)}`;\n};\n\nexport const createLatestSortKey = (): string => {\n return \"L\";\n};\n\nexport const createPublishedSortKey = (): string => {\n return \"P\";\n};\n\nexport interface GSIPartitionKeyParams {\n tenant: string;\n locale: string;\n modelId: string;\n}\nexport const createGSIPartitionKey = (params: GSIPartitionKeyParams, type: \"A\" | \"L\" | \"P\") => {\n const { modelId } = params;\n const partitionKey = createBasePartitionKey(params);\n return `${partitionKey}#M#${modelId}#${type}`;\n};\n\nexport interface GSISortKeyParams {\n id: string;\n}\nexport const createGSISortKey = (params: GSISortKeyParams): string => {\n return params.id;\n};\n"],"mappings":";;;;;;;AAAA;AACA;AAMA,MAAMA,sBAAsB,GAAIC,MAA8B,IAAa;EACvE,MAAM;IAAEC,MAAM;IAAEC;EAAO,CAAC,GAAGF,MAAM;EACjC,IAAI,CAACC,MAAM,EAAE;IACT,MAAM,IAAIE,cAAW,CAAE,8DAA6D,CAAC;EACzF,CAAC,MAAM,IAAI,CAACD,MAAM,EAAE;IAChB,MAAM,IAAIC,cAAW,CAAE,8DAA6D,CAAC;EACzF;EACA,OAAQ,KAAIF,MAAO,MAAKC,MAAO,UAAS;AAC5C,CAAC;AAKM,MAAME,kBAAkB,GAAIJ,MAA0B,IAAa;EACtE,MAAM;IAAEK,EAAE,EAAEC;EAAU,CAAC,GAAGN,MAAM;EAChC,MAAM;IAAEK;EAAG,CAAC,GAAG,IAAAE,sBAAe,EAACD,SAAS,CAAC;EACzC,OAAQ,GAAEP,sBAAsB,CAACC,MAAM,CAAE,QAAOK,EAAG,EAAC;AACxD,CAAC;AAAC;AAKK,MAAMG,qBAAqB,GAAIR,MAAqB,IAAa;EACpE,OAAQ,OAAM,IAAAS,cAAO,EAACT,MAAM,CAACU,OAAO,CAAE,EAAC;AAC3C,CAAC;AAAC;AAEK,MAAMC,mBAAmB,GAAG,MAAc;EAC7C,OAAO,GAAG;AACd,CAAC;AAAC;AAEK,MAAMC,sBAAsB,GAAG,MAAc;EAChD,OAAO,GAAG;AACd,CAAC;AAAC;AAOK,MAAMC,qBAAqB,GAAG,CAACb,MAA6B,EAAEc,IAAqB,KAAK;EAC3F,MAAM;IAAEC;EAAQ,CAAC,GAAGf,MAAM;EAC1B,MAAMgB,YAAY,GAAGjB,sBAAsB,CAACC,MAAM,CAAC;EACnD,OAAQ,GAAEgB,YAAa,MAAKD,OAAQ,IAAGD,IAAK,EAAC;AACjD,CAAC;AAAC;AAKK,MAAMG,gBAAgB,GAAIjB,MAAwB,IAAa;EAClE,OAAOA,MAAM,CAACK,EAAE;AACpB,CAAC;AAAC"}
@@ -4,11 +4,9 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.systemFields = void 0;
7
-
8
7
  const createSystemField = field => {
9
8
  return field;
10
9
  };
11
-
12
10
  const systemFields = {
13
11
  id: createSystemField({
14
12
  id: "id",
@@ -1 +1 @@
1
- {"version":3,"names":["createSystemField","field","systemFields","id","type","storageId","fieldId","entryId","createdOn","savedOn","createdBy","settings","path","meta","ownedBy","version","status"],"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 status: createSystemField({\n id: \"status\",\n type: \"string\",\n storageId: \"status\",\n fieldId: \"status\"\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,CAjD6B;EAuDvDU,MAAM,EAAEhB,iBAAiB,CAAC;IACtBG,EAAE,EAAE,QADkB;IAEtBC,IAAI,EAAE,QAFgB;IAGtBC,SAAS,EAAE,QAHW;IAItBC,OAAO,EAAE;EAJa,CAAD;AAvD8B,CAApD"}
1
+ {"version":3,"names":["createSystemField","field","systemFields","id","type","storageId","fieldId","entryId","createdOn","savedOn","createdBy","settings","path","meta","ownedBy","version","status"],"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 status: createSystemField({\n id: \"status\",\n type: \"string\",\n storageId: \"status\",\n fieldId: \"status\"\n })\n};\n"],"mappings":";;;;;;AAIA,MAAMA,iBAAiB,GAAIC,KAAyB,IAAoB;EACpE,OAAOA,KAAK;AAChB,CAAC;AAEM,MAAMC,YAA2C,GAAG;EACvDC,EAAE,EAAEH,iBAAiB,CAAC;IAClBG,EAAE,EAAE,IAAI;IACRC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,IAAI;IACfC,OAAO,EAAE;EACb,CAAC,CAAC;EACFC,OAAO,EAAEP,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFE,SAAS,EAAER,iBAAiB,CAAC;IACzBG,EAAE,EAAE,WAAW;IACfC,IAAI,EAAE,UAAU;IAChBC,SAAS,EAAE,WAAW;IACtBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFG,OAAO,EAAET,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,UAAU;IAChBC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFI,SAAS,EAAEV,iBAAiB,CAAC;IACzBG,EAAE,EAAE,WAAW;IACfC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,WAAW;IACtBC,OAAO,EAAE,WAAW;IACpBK,QAAQ,EAAE;MACNC,IAAI,EAAE;IACV;EACJ,CAAC,CAAC;EACFC,IAAI,EAAEb,iBAAiB,CAAC;IACpBG,EAAE,EAAE,MAAM;IACVC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,MAAM;IACjBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFQ,OAAO,EAAEd,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBK,QAAQ,EAAE;MACNC,IAAI,EAAE;IACV;EACJ,CAAC,CAAC;EACFG,OAAO,EAAEf,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,QAAQ;IACdC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFU,MAAM,EAAEhB,iBAAiB,CAAC;IACtBG,EAAE,EAAE,QAAQ;IACZC,IAAI,EAAE,QAAQ;IACdC,SAAS,EAAE,QAAQ;IACnBC,OAAO,EAAE;EACb,CAAC;AACL,CAAC;AAAC"}
@@ -1,28 +1,18 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.createGroupsStorageOperations = void 0;
9
-
10
8
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
-
12
9
  var _error = _interopRequireDefault(require("@webiny/error"));
13
-
14
10
  var _get = require("@webiny/db-dynamodb/utils/get");
15
-
16
11
  var _cleanup = require("@webiny/db-dynamodb/utils/cleanup");
17
-
18
12
  var _query = require("@webiny/db-dynamodb/utils/query");
19
-
20
13
  var _filter = require("@webiny/db-dynamodb/utils/filter");
21
-
22
14
  var _ValueFilterPlugin = require("@webiny/db-dynamodb/plugins/definitions/ValueFilterPlugin");
23
-
24
15
  var _sort = require("@webiny/db-dynamodb/utils/sort");
25
-
26
16
  const createPartitionKey = params => {
27
17
  const {
28
18
  tenant,
@@ -30,42 +20,35 @@ const createPartitionKey = params => {
30
20
  } = params;
31
21
  return `T#${tenant}#L#${locale}#CMS#CMG`;
32
22
  };
33
-
34
23
  const createSortKeys = params => {
35
24
  const {
36
25
  id
37
26
  } = params;
38
27
  return id;
39
28
  };
40
-
41
29
  const createKeys = params => {
42
30
  return {
43
31
  PK: createPartitionKey(params),
44
32
  SK: createSortKeys(params)
45
33
  };
46
34
  };
47
-
48
35
  const createType = () => {
49
36
  return "cms.group";
50
37
  };
51
-
52
38
  const createGroupsStorageOperations = params => {
53
39
  const {
54
40
  entity,
55
41
  plugins
56
42
  } = params;
57
43
  const filteringPlugins = plugins.byType(_ValueFilterPlugin.ValueFilterPlugin.type);
58
-
59
44
  if (filteringPlugins.length === 0) {
60
45
  throw new _error.default("DynamoDB filtering plugins not loaded.", "MISSING_DYNAMODB_FILTERING_PLUGINS");
61
46
  }
62
-
63
47
  const create = async params => {
64
48
  const {
65
49
  group
66
50
  } = params;
67
51
  const keys = createKeys(group);
68
-
69
52
  try {
70
53
  await entity.put((0, _objectSpread2.default)((0, _objectSpread2.default)({}, group), {}, {
71
54
  TYPE: createType()
@@ -79,13 +62,11 @@ const createGroupsStorageOperations = params => {
79
62
  });
80
63
  }
81
64
  };
82
-
83
65
  const update = async params => {
84
66
  const {
85
67
  group
86
68
  } = params;
87
69
  const keys = createKeys(group);
88
-
89
70
  try {
90
71
  await entity.put((0, _objectSpread2.default)((0, _objectSpread2.default)({}, group), {}, {
91
72
  TYPE: createType()
@@ -99,14 +80,12 @@ const createGroupsStorageOperations = params => {
99
80
  });
100
81
  }
101
82
  };
102
-
103
83
  const deleteGroup = async params => {
104
84
  const {
105
85
  group
106
- } = params; // TODO make sure that group has locale and tenant on it - add it in the crud just in case
107
-
86
+ } = params;
87
+ // TODO make sure that group has locale and tenant on it - add it in the crud just in case
108
88
  const keys = createKeys(group);
109
-
110
89
  try {
111
90
  await entity.delete(keys);
112
91
  return group;
@@ -118,10 +97,8 @@ const createGroupsStorageOperations = params => {
118
97
  });
119
98
  }
120
99
  };
121
-
122
100
  const get = async params => {
123
101
  const keys = createKeys(params);
124
-
125
102
  try {
126
103
  const group = await (0, _get.get)({
127
104
  entity,
@@ -136,7 +113,6 @@ const createGroupsStorageOperations = params => {
136
113
  }));
137
114
  }
138
115
  };
139
-
140
116
  const list = async params => {
141
117
  const {
142
118
  sort,
@@ -150,7 +126,6 @@ const createGroupsStorageOperations = params => {
150
126
  }
151
127
  };
152
128
  let records = [];
153
-
154
129
  try {
155
130
  records = await (0, _query.queryAll)(queryAllParams);
156
131
  } catch (ex) {
@@ -161,25 +136,21 @@ const createGroupsStorageOperations = params => {
161
136
  where
162
137
  }));
163
138
  }
164
-
165
139
  const filteredItems = (0, _filter.filterItems)({
166
140
  items: records,
167
141
  where,
168
142
  fields: [],
169
143
  plugins
170
144
  });
171
-
172
145
  if (!sort || sort.length === 0) {
173
146
  return filteredItems;
174
147
  }
175
-
176
148
  return (0, _sort.sortItems)({
177
149
  items: filteredItems,
178
150
  sort,
179
151
  fields: []
180
152
  });
181
153
  };
182
-
183
154
  return {
184
155
  create,
185
156
  update,
@@ -188,5 +159,4 @@ const createGroupsStorageOperations = params => {
188
159
  list
189
160
  };
190
161
  };
191
-
192
162
  exports.createGroupsStorageOperations = createGroupsStorageOperations;
@@ -1 +1 @@
1
- {"version":3,"names":["createPartitionKey","params","tenant","locale","createSortKeys","id","createKeys","PK","SK","createType","createGroupsStorageOperations","entity","plugins","filteringPlugins","byType","ValueFilterPlugin","type","length","WebinyError","create","group","keys","put","TYPE","ex","message","code","error","update","deleteGroup","delete","get","getRecord","cleanupItem","list","sort","where","queryAllParams","partitionKey","options","gte","records","queryAll","filteredItems","filterItems","items","fields","sortItems"],"sources":["index.ts"],"sourcesContent":["import {\n CmsGroup,\n CmsGroupStorageOperations,\n CmsGroupStorageOperationsCreateParams,\n CmsGroupStorageOperationsDeleteParams,\n CmsGroupStorageOperationsGetParams,\n CmsGroupStorageOperationsListParams,\n CmsGroupStorageOperationsUpdateParams\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport WebinyError from \"@webiny/error\";\nimport { get as getRecord } from \"@webiny/db-dynamodb/utils/get\";\nimport { cleanupItem } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { queryAll, QueryAllParams } from \"@webiny/db-dynamodb/utils/query\";\nimport { filterItems } from \"@webiny/db-dynamodb/utils/filter\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { ValueFilterPlugin } from \"@webiny/db-dynamodb/plugins/definitions/ValueFilterPlugin\";\nimport { sortItems } from \"@webiny/db-dynamodb/utils/sort\";\n\ninterface PartitionKeyParams {\n tenant: string;\n locale: string;\n}\nconst createPartitionKey = (params: PartitionKeyParams): string => {\n const { tenant, locale } = params;\n return `T#${tenant}#L#${locale}#CMS#CMG`;\n};\n\ninterface SortKeyParams {\n id: string;\n}\nconst createSortKeys = (params: SortKeyParams): string => {\n const { id } = params;\n return id;\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\nconst createKeys = (params: PartitionKeyParams & SortKeyParams): Keys => {\n return {\n PK: createPartitionKey(params),\n SK: createSortKeys(params)\n };\n};\n\nconst createType = (): string => {\n return \"cms.group\";\n};\n\ninterface CreateGroupsStorageOperationsParams {\n entity: Entity<any>;\n plugins: PluginsContainer;\n}\nexport const createGroupsStorageOperations = (\n params: CreateGroupsStorageOperationsParams\n): CmsGroupStorageOperations => {\n const { entity, plugins } = params;\n\n const filteringPlugins = plugins.byType<ValueFilterPlugin>(ValueFilterPlugin.type);\n if (filteringPlugins.length === 0) {\n throw new WebinyError(\n \"DynamoDB filtering plugins not loaded.\",\n \"MISSING_DYNAMODB_FILTERING_PLUGINS\"\n );\n }\n\n const create = async (params: CmsGroupStorageOperationsCreateParams) => {\n const { group } = params;\n const keys = createKeys(group);\n try {\n await entity.put({\n ...group,\n TYPE: createType(),\n ...keys\n });\n return group;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create group.\",\n ex.code || \"CREATE_GROUP_ERROR\",\n {\n error: ex,\n group,\n keys\n }\n );\n }\n };\n const update = async (params: CmsGroupStorageOperationsUpdateParams) => {\n const { group } = params;\n const keys = createKeys(group);\n try {\n await entity.put({\n ...group,\n TYPE: createType(),\n ...keys\n });\n return group;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update group.\",\n ex.code || \"UPDATE_GROUP_ERROR\",\n {\n error: ex,\n group,\n keys\n }\n );\n }\n };\n const deleteGroup = async (params: CmsGroupStorageOperationsDeleteParams) => {\n const { group } = params;\n // TODO make sure that group has locale and tenant on it - add it in the crud just in case\n const keys = createKeys(group);\n\n try {\n await entity.delete(keys);\n return group;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete group.\",\n ex.code || \"DELETE_GROUP_ERROR\",\n {\n error: ex,\n group,\n keys\n }\n );\n }\n };\n const get = async (params: CmsGroupStorageOperationsGetParams) => {\n const keys = createKeys(params);\n\n try {\n const group = await getRecord<CmsGroup>({\n entity,\n keys\n });\n\n return cleanupItem(entity, group);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get group.\",\n ex.code || \"GET_GROUP_ERROR\",\n {\n error: ex,\n ...params,\n keys\n }\n );\n }\n };\n const list = async (params: CmsGroupStorageOperationsListParams) => {\n const { sort, where } = params;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey(where),\n options: {\n gte: \" \"\n }\n };\n\n let records: CmsGroup[] = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not list groups.\",\n ex.code || \"LIST_GROUP_ERROR\",\n {\n error: ex,\n ...params,\n sort,\n where\n }\n );\n }\n\n const filteredItems = filterItems({\n items: records,\n where,\n fields: [],\n plugins\n });\n if (!sort || sort.length === 0) {\n return filteredItems;\n }\n return sortItems({\n items: filteredItems,\n sort,\n fields: []\n });\n };\n\n return {\n create,\n update,\n delete: deleteGroup,\n get,\n list\n };\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["createPartitionKey","params","tenant","locale","createSortKeys","id","createKeys","PK","SK","createType","createGroupsStorageOperations","entity","plugins","filteringPlugins","byType","ValueFilterPlugin","type","length","WebinyError","create","group","keys","put","TYPE","ex","message","code","error","update","deleteGroup","delete","get","getRecord","cleanupItem","list","sort","where","queryAllParams","partitionKey","options","gte","records","queryAll","filteredItems","filterItems","items","fields","sortItems"],"sources":["index.ts"],"sourcesContent":["import {\n CmsGroup,\n CmsGroupStorageOperations,\n CmsGroupStorageOperationsCreateParams,\n CmsGroupStorageOperationsDeleteParams,\n CmsGroupStorageOperationsGetParams,\n CmsGroupStorageOperationsListParams,\n CmsGroupStorageOperationsUpdateParams\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport WebinyError from \"@webiny/error\";\nimport { get as getRecord } from \"@webiny/db-dynamodb/utils/get\";\nimport { cleanupItem } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { queryAll, QueryAllParams } from \"@webiny/db-dynamodb/utils/query\";\nimport { filterItems } from \"@webiny/db-dynamodb/utils/filter\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { ValueFilterPlugin } from \"@webiny/db-dynamodb/plugins/definitions/ValueFilterPlugin\";\nimport { sortItems } from \"@webiny/db-dynamodb/utils/sort\";\n\ninterface PartitionKeyParams {\n tenant: string;\n locale: string;\n}\nconst createPartitionKey = (params: PartitionKeyParams): string => {\n const { tenant, locale } = params;\n return `T#${tenant}#L#${locale}#CMS#CMG`;\n};\n\ninterface SortKeyParams {\n id: string;\n}\nconst createSortKeys = (params: SortKeyParams): string => {\n const { id } = params;\n return id;\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\nconst createKeys = (params: PartitionKeyParams & SortKeyParams): Keys => {\n return {\n PK: createPartitionKey(params),\n SK: createSortKeys(params)\n };\n};\n\nconst createType = (): string => {\n return \"cms.group\";\n};\n\ninterface CreateGroupsStorageOperationsParams {\n entity: Entity<any>;\n plugins: PluginsContainer;\n}\nexport const createGroupsStorageOperations = (\n params: CreateGroupsStorageOperationsParams\n): CmsGroupStorageOperations => {\n const { entity, plugins } = params;\n\n const filteringPlugins = plugins.byType<ValueFilterPlugin>(ValueFilterPlugin.type);\n if (filteringPlugins.length === 0) {\n throw new WebinyError(\n \"DynamoDB filtering plugins not loaded.\",\n \"MISSING_DYNAMODB_FILTERING_PLUGINS\"\n );\n }\n\n const create = async (params: CmsGroupStorageOperationsCreateParams) => {\n const { group } = params;\n const keys = createKeys(group);\n try {\n await entity.put({\n ...group,\n TYPE: createType(),\n ...keys\n });\n return group;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create group.\",\n ex.code || \"CREATE_GROUP_ERROR\",\n {\n error: ex,\n group,\n keys\n }\n );\n }\n };\n const update = async (params: CmsGroupStorageOperationsUpdateParams) => {\n const { group } = params;\n const keys = createKeys(group);\n try {\n await entity.put({\n ...group,\n TYPE: createType(),\n ...keys\n });\n return group;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update group.\",\n ex.code || \"UPDATE_GROUP_ERROR\",\n {\n error: ex,\n group,\n keys\n }\n );\n }\n };\n const deleteGroup = async (params: CmsGroupStorageOperationsDeleteParams) => {\n const { group } = params;\n // TODO make sure that group has locale and tenant on it - add it in the crud just in case\n const keys = createKeys(group);\n\n try {\n await entity.delete(keys);\n return group;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete group.\",\n ex.code || \"DELETE_GROUP_ERROR\",\n {\n error: ex,\n group,\n keys\n }\n );\n }\n };\n const get = async (params: CmsGroupStorageOperationsGetParams) => {\n const keys = createKeys(params);\n\n try {\n const group = await getRecord<CmsGroup>({\n entity,\n keys\n });\n\n return cleanupItem(entity, group);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get group.\",\n ex.code || \"GET_GROUP_ERROR\",\n {\n error: ex,\n ...params,\n keys\n }\n );\n }\n };\n const list = async (params: CmsGroupStorageOperationsListParams) => {\n const { sort, where } = params;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey(where),\n options: {\n gte: \" \"\n }\n };\n\n let records: CmsGroup[] = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not list groups.\",\n ex.code || \"LIST_GROUP_ERROR\",\n {\n error: ex,\n ...params,\n sort,\n where\n }\n );\n }\n\n const filteredItems = filterItems({\n items: records,\n where,\n fields: [],\n plugins\n });\n if (!sort || sort.length === 0) {\n return filteredItems;\n }\n return sortItems({\n items: filteredItems,\n sort,\n fields: []\n });\n };\n\n return {\n create,\n update,\n delete: deleteGroup,\n get,\n list\n };\n};\n"],"mappings":";;;;;;;;AAUA;AACA;AACA;AACA;AACA;AAEA;AACA;AAMA,MAAMA,kBAAkB,GAAIC,MAA0B,IAAa;EAC/D,MAAM;IAAEC,MAAM;IAAEC;EAAO,CAAC,GAAGF,MAAM;EACjC,OAAQ,KAAIC,MAAO,MAAKC,MAAO,UAAS;AAC5C,CAAC;AAKD,MAAMC,cAAc,GAAIH,MAAqB,IAAa;EACtD,MAAM;IAAEI;EAAG,CAAC,GAAGJ,MAAM;EACrB,OAAOI,EAAE;AACb,CAAC;AAMD,MAAMC,UAAU,GAAIL,MAA0C,IAAW;EACrE,OAAO;IACHM,EAAE,EAAEP,kBAAkB,CAACC,MAAM,CAAC;IAC9BO,EAAE,EAAEJ,cAAc,CAACH,MAAM;EAC7B,CAAC;AACL,CAAC;AAED,MAAMQ,UAAU,GAAG,MAAc;EAC7B,OAAO,WAAW;AACtB,CAAC;AAMM,MAAMC,6BAA6B,GACtCT,MAA2C,IACf;EAC5B,MAAM;IAAEU,MAAM;IAAEC;EAAQ,CAAC,GAAGX,MAAM;EAElC,MAAMY,gBAAgB,GAAGD,OAAO,CAACE,MAAM,CAAoBC,oCAAiB,CAACC,IAAI,CAAC;EAClF,IAAIH,gBAAgB,CAACI,MAAM,KAAK,CAAC,EAAE;IAC/B,MAAM,IAAIC,cAAW,CACjB,wCAAwC,EACxC,oCAAoC,CACvC;EACL;EAEA,MAAMC,MAAM,GAAG,MAAOlB,MAA6C,IAAK;IACpE,MAAM;MAAEmB;IAAM,CAAC,GAAGnB,MAAM;IACxB,MAAMoB,IAAI,GAAGf,UAAU,CAACc,KAAK,CAAC;IAC9B,IAAI;MACA,MAAMT,MAAM,CAACW,GAAG,6DACTF,KAAK;QACRG,IAAI,EAAEd,UAAU;MAAE,GACfY,IAAI,EACT;MACF,OAAOD,KAAK;IAChB,CAAC,CAAC,OAAOI,EAAE,EAAE;MACT,MAAM,IAAIN,cAAW,CACjBM,EAAE,CAACC,OAAO,IAAI,yBAAyB,EACvCD,EAAE,CAACE,IAAI,IAAI,oBAAoB,EAC/B;QACIC,KAAK,EAAEH,EAAE;QACTJ,KAAK;QACLC;MACJ,CAAC,CACJ;IACL;EACJ,CAAC;EACD,MAAMO,MAAM,GAAG,MAAO3B,MAA6C,IAAK;IACpE,MAAM;MAAEmB;IAAM,CAAC,GAAGnB,MAAM;IACxB,MAAMoB,IAAI,GAAGf,UAAU,CAACc,KAAK,CAAC;IAC9B,IAAI;MACA,MAAMT,MAAM,CAACW,GAAG,6DACTF,KAAK;QACRG,IAAI,EAAEd,UAAU;MAAE,GACfY,IAAI,EACT;MACF,OAAOD,KAAK;IAChB,CAAC,CAAC,OAAOI,EAAE,EAAE;MACT,MAAM,IAAIN,cAAW,CACjBM,EAAE,CAACC,OAAO,IAAI,yBAAyB,EACvCD,EAAE,CAACE,IAAI,IAAI,oBAAoB,EAC/B;QACIC,KAAK,EAAEH,EAAE;QACTJ,KAAK;QACLC;MACJ,CAAC,CACJ;IACL;EACJ,CAAC;EACD,MAAMQ,WAAW,GAAG,MAAO5B,MAA6C,IAAK;IACzE,MAAM;MAAEmB;IAAM,CAAC,GAAGnB,MAAM;IACxB;IACA,MAAMoB,IAAI,GAAGf,UAAU,CAACc,KAAK,CAAC;IAE9B,IAAI;MACA,MAAMT,MAAM,CAACmB,MAAM,CAACT,IAAI,CAAC;MACzB,OAAOD,KAAK;IAChB,CAAC,CAAC,OAAOI,EAAE,EAAE;MACT,MAAM,IAAIN,cAAW,CACjBM,EAAE,CAACC,OAAO,IAAI,yBAAyB,EACvCD,EAAE,CAACE,IAAI,IAAI,oBAAoB,EAC/B;QACIC,KAAK,EAAEH,EAAE;QACTJ,KAAK;QACLC;MACJ,CAAC,CACJ;IACL;EACJ,CAAC;EACD,MAAMU,GAAG,GAAG,MAAO9B,MAA0C,IAAK;IAC9D,MAAMoB,IAAI,GAAGf,UAAU,CAACL,MAAM,CAAC;IAE/B,IAAI;MACA,MAAMmB,KAAK,GAAG,MAAM,IAAAY,QAAS,EAAW;QACpCrB,MAAM;QACNU;MACJ,CAAC,CAAC;MAEF,OAAO,IAAAY,oBAAW,EAACtB,MAAM,EAAES,KAAK,CAAC;IACrC,CAAC,CAAC,OAAOI,EAAE,EAAE;MACT,MAAM,IAAIN,cAAW,CACjBM,EAAE,CAACC,OAAO,IAAI,sBAAsB,EACpCD,EAAE,CAACE,IAAI,IAAI,iBAAiB;QAExBC,KAAK,EAAEH;MAAE,GACNvB,MAAM;QACToB;MAAI,GAEX;IACL;EACJ,CAAC;EACD,MAAMa,IAAI,GAAG,MAAOjC,MAA2C,IAAK;IAChE,MAAM;MAAEkC,IAAI;MAAEC;IAAM,CAAC,GAAGnC,MAAM;IAE9B,MAAMoC,cAA8B,GAAG;MACnC1B,MAAM;MACN2B,YAAY,EAAEtC,kBAAkB,CAACoC,KAAK,CAAC;MACvCG,OAAO,EAAE;QACLC,GAAG,EAAE;MACT;IACJ,CAAC;IAED,IAAIC,OAAmB,GAAG,EAAE;IAC5B,IAAI;MACAA,OAAO,GAAG,MAAM,IAAAC,eAAQ,EAACL,cAAc,CAAC;IAC5C,CAAC,CAAC,OAAOb,EAAE,EAAE;MACT,MAAM,IAAIN,cAAW,CACjBM,EAAE,CAACC,OAAO,IAAI,wBAAwB,EACtCD,EAAE,CAACE,IAAI,IAAI,kBAAkB;QAEzBC,KAAK,EAAEH;MAAE,GACNvB,MAAM;QACTkC,IAAI;QACJC;MAAK,GAEZ;IACL;IAEA,MAAMO,aAAa,GAAG,IAAAC,mBAAW,EAAC;MAC9BC,KAAK,EAAEJ,OAAO;MACdL,KAAK;MACLU,MAAM,EAAE,EAAE;MACVlC;IACJ,CAAC,CAAC;IACF,IAAI,CAACuB,IAAI,IAAIA,IAAI,CAAClB,MAAM,KAAK,CAAC,EAAE;MAC5B,OAAO0B,aAAa;IACxB;IACA,OAAO,IAAAI,eAAS,EAAC;MACbF,KAAK,EAAEF,aAAa;MACpBR,IAAI;MACJW,MAAM,EAAE;IACZ,CAAC,CAAC;EACN,CAAC;EAED,OAAO;IACH3B,MAAM;IACNS,MAAM;IACNE,MAAM,EAAED,WAAW;IACnBE,GAAG;IACHG;EACJ,CAAC;AACL,CAAC;AAAC"}