@webiny/api-headless-cms-ddb 5.25.0-beta.6 → 5.25.1-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.
package/index.js CHANGED
@@ -42,7 +42,7 @@ const createStorageOperations = params => {
42
42
  attributes,
43
43
  table,
44
44
  documentClient,
45
- plugins: customPlugins,
45
+ plugins: userPlugins,
46
46
  modelFieldToGraphQLPlugins
47
47
  } = params;
48
48
  const tableInstance = (0, _table.createTable)({
@@ -80,7 +80,7 @@ const createStorageOperations = params => {
80
80
  /**
81
81
  * User defined custom plugins.
82
82
  */
83
- ...(customPlugins || []),
83
+ ...(userPlugins || []),
84
84
  /**
85
85
  * Plugins of type CmsModelFieldToGraphQLPlugin.
86
86
  */
@@ -94,12 +94,14 @@ const createStorageOperations = params => {
94
94
  */
95
95
  (0, _dynamoDb.default)()]);
96
96
  return {
97
- plugins: [
98
- /**
99
- * Field plugins for DynamoDB.
100
- * We must pass them to the base application.
101
- */
102
- (0, _dynamoDb.default)()],
97
+ beforeInit: async context => {
98
+ context.plugins.register([
99
+ /**
100
+ * Field plugins for DynamoDB.
101
+ * We must pass them to the base application.
102
+ */
103
+ (0, _dynamoDb.default)()]);
104
+ },
103
105
  getEntities: () => entities,
104
106
  getTable: () => tableInstance,
105
107
  system: (0, _system2.createSystemStorageOperations)({
package/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":["createStorageOperations","params","attributes","table","documentClient","plugins","customPlugins","modelFieldToGraphQLPlugins","tableInstance","entities","settings","entityName","ENTITIES","SETTINGS","system","SYSTEM","groups","GROUPS","models","MODELS","entries","ENTRIES","PluginsContainer","getEntities","getTable","entity"],"mappings":";;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEO,MAAMA,uBAAiD,GAAGC,MAAM,IAAI;AACvE,QAAM;AACFC,IAAAA,UADE;AAEFC,IAAAA,KAFE;AAGFC,IAAAA,cAHE;AAIFC,IAAAA,OAAO,EAAEC,aAJP;AAKFC,IAAAA;AALE,MAMFN,MANJ;AAQA,QAAMO,aAAa,GAAG,wBAAY;AAC9BL,IAAAA,KAD8B;AAE9BC,IAAAA;AAF8B,GAAZ,CAAtB;AAKA,QAAMK,QAAQ,GAAG;AACbC,IAAAA,QAAQ,EAAE,oCAAqB;AAC3BC,MAAAA,UAAU,EAAEC,gBAASC,QADM;AAE3BV,MAAAA,KAAK,EAAEK,aAFoB;AAG3BN,MAAAA,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACU,gBAASC,QAAV,CAAb,GAAmC;AAH9B,KAArB,CADG;AAMbC,IAAAA,MAAM,EAAE,gCAAmB;AACvBH,MAAAA,UAAU,EAAEC,gBAASG,MADE;AAEvBZ,MAAAA,KAAK,EAAEK,aAFgB;AAGvBN,MAAAA,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACU,gBAASG,MAAV,CAAb,GAAiC;AAHhC,KAAnB,CANK;AAWbC,IAAAA,MAAM,EAAE,8BAAkB;AACtBL,MAAAA,UAAU,EAAEC,gBAASK,MADC;AAEtBd,MAAAA,KAAK,EAAEK,aAFe;AAGtBN,MAAAA,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACU,gBAASK,MAAV,CAAb,GAAiC;AAHjC,KAAlB,CAXK;AAgBbC,IAAAA,MAAM,EAAE,8BAAkB;AACtBP,MAAAA,UAAU,EAAEC,gBAASO,MADC;AAEtBhB,MAAAA,KAAK,EAAEK,aAFe;AAGtBN,MAAAA,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACU,gBAASO,MAAV,CAAb,GAAiC;AAHjC,KAAlB,CAhBK;AAqBbC,IAAAA,OAAO,EAAE,8BAAkB;AACvBT,MAAAA,UAAU,EAAEC,gBAASS,OADE;AAEvBlB,MAAAA,KAAK,EAAEK,aAFgB;AAGvBN,MAAAA,UAAU,EAAEA,UAAU,GAAGA,UAAU,CAACU,gBAASS,OAAV,CAAb,GAAkC;AAHjC,KAAlB;AArBI,GAAjB;AA4BA,QAAMhB,OAAO,GAAG,IAAIiB,yBAAJ,CAAqB;AACjC;AACR;AACA;AACQ,MAAIhB,aAAa,IAAI,EAArB,CAJiC;AAKjC;AACR;AACA;AACQC,EAAAA,0BARiC;AASjC;AACR;AACA;AACQ,yBAZiC;AAajC;AACR;AACA;AACQ,0BAhBiC,CAArB,CAAhB;AAmBA,SAAO;AACHF,IAAAA,OAAO,EAAE;AACL;AACZ;AACA;AACA;AACY,4BALK,CADN;AAQHkB,IAAAA,WAAW,EAAE,MAAMd,QARhB;AASHe,IAAAA,QAAQ,EAAE,MAAMhB,aATb;AAUHM,IAAAA,MAAM,EAAE,4CAA8B;AAClCW,MAAAA,MAAM,EAAEhB,QAAQ,CAACK;AADiB,KAA9B,CAVL;AAaHJ,IAAAA,QAAQ,EAAE,gDAAgC;AACtCe,MAAAA,MAAM,EAAEhB,QAAQ,CAACC;AADqB,KAAhC,CAbP;AAgBHM,IAAAA,MAAM,EAAE,2CAA8B;AAClCS,MAAAA,MAAM,EAAEhB,QAAQ,CAACO,MADiB;AAElCX,MAAAA;AAFkC,KAA9B,CAhBL;AAoBHa,IAAAA,MAAM,EAAE,2CAA8B;AAClCO,MAAAA,MAAM,EAAEhB,QAAQ,CAACS;AADiB,KAA9B,CApBL;AAuBHE,IAAAA,OAAO,EAAE,4CAA+B;AACpCK,MAAAA,MAAM,EAAEhB,QAAQ,CAACW,OADmB;AAEpCf,MAAAA;AAFoC,KAA/B;AAvBN,GAAP;AA4BH,CAzFM","sourcesContent":["import dynamoDbValueFilters from \"@webiny/db-dynamodb/plugins/filters\";\nimport dynamoDbPlugins from \"./dynamoDb\";\nimport { ENTITIES, StorageOperationsFactory } from \"~/types\";\nimport { createTable } from \"~/definitions/table\";\nimport { createSettingsEntity } from \"~/definitions/settings\";\nimport { createSystemEntity } from \"~/definitions/system\";\nimport { createGroupEntity } from \"~/definitions/group\";\nimport { createModelEntity } from \"~/definitions/model\";\nimport { createEntryEntity } from \"~/definitions/entry\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { createSystemStorageOperations } from \"~/operations/system\";\nimport { createSettingsStorageOperations } from \"~/operations/settings\";\nimport { createGroupsStorageOperations } from \"~/operations/group\";\nimport { createModelsStorageOperations } from \"~/operations/model\";\nimport { createEntriesStorageOperations } from \"./operations/entry\";\n\nexport const createStorageOperations: StorageOperationsFactory = params => {\n const {\n attributes,\n table,\n documentClient,\n plugins: customPlugins,\n modelFieldToGraphQLPlugins\n } = params;\n\n const tableInstance = createTable({\n table,\n documentClient\n });\n\n const entities = {\n settings: createSettingsEntity({\n entityName: ENTITIES.SETTINGS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.SETTINGS] : {}\n }),\n system: createSystemEntity({\n entityName: ENTITIES.SYSTEM,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.SYSTEM] : {}\n }),\n groups: createGroupEntity({\n entityName: ENTITIES.GROUPS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.GROUPS] : {}\n }),\n models: createModelEntity({\n entityName: ENTITIES.MODELS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.MODELS] : {}\n }),\n entries: createEntryEntity({\n entityName: ENTITIES.ENTRIES,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.ENTRIES] : {}\n })\n };\n\n const plugins = new PluginsContainer([\n /**\n * User defined custom plugins.\n */\n ...(customPlugins || []),\n /**\n * Plugins of type CmsModelFieldToGraphQLPlugin.\n */\n modelFieldToGraphQLPlugins,\n /**\n * DynamoDB filter plugins for the where conditions.\n */\n dynamoDbValueFilters(),\n /**\n * Field plugins for DynamoDB.\n */\n dynamoDbPlugins()\n ]);\n\n return {\n plugins: [\n /**\n * Field plugins for DynamoDB.\n * We must pass them to the base application.\n */\n dynamoDbPlugins()\n ],\n getEntities: () => entities,\n getTable: () => tableInstance,\n system: createSystemStorageOperations({\n entity: entities.system\n }),\n settings: createSettingsStorageOperations({\n entity: entities.settings\n }),\n groups: createGroupsStorageOperations({\n entity: entities.groups,\n plugins\n }),\n models: createModelsStorageOperations({\n entity: entities.models\n }),\n entries: createEntriesStorageOperations({\n entity: entities.entries,\n plugins\n })\n };\n};\n"]}
1
+ {"version":3,"sources":["index.ts"],"names":["createStorageOperations","params","attributes","table","documentClient","plugins","userPlugins","modelFieldToGraphQLPlugins","tableInstance","entities","settings","entityName","ENTITIES","SETTINGS","system","SYSTEM","groups","GROUPS","models","MODELS","entries","ENTRIES","PluginsContainer","beforeInit","context","register","getEntities","getTable","entity"],"mappings":"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","sourcesContent":["import dynamoDbValueFilters from \"@webiny/db-dynamodb/plugins/filters\";\nimport dynamoDbPlugins from \"./dynamoDb\";\nimport { ENTITIES, StorageOperationsFactory } from \"~/types\";\nimport { createTable } from \"~/definitions/table\";\nimport { createSettingsEntity } from \"~/definitions/settings\";\nimport { createSystemEntity } from \"~/definitions/system\";\nimport { createGroupEntity } from \"~/definitions/group\";\nimport { createModelEntity } from \"~/definitions/model\";\nimport { createEntryEntity } from \"~/definitions/entry\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { createSystemStorageOperations } from \"~/operations/system\";\nimport { createSettingsStorageOperations } from \"~/operations/settings\";\nimport { createGroupsStorageOperations } from \"~/operations/group\";\nimport { createModelsStorageOperations } from \"~/operations/model\";\nimport { createEntriesStorageOperations } from \"./operations/entry\";\n\nexport const createStorageOperations: StorageOperationsFactory = params => {\n const {\n attributes,\n table,\n documentClient,\n plugins: userPlugins,\n modelFieldToGraphQLPlugins\n } = params;\n\n const tableInstance = createTable({\n table,\n documentClient\n });\n\n const entities = {\n settings: createSettingsEntity({\n entityName: ENTITIES.SETTINGS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.SETTINGS] : {}\n }),\n system: createSystemEntity({\n entityName: ENTITIES.SYSTEM,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.SYSTEM] : {}\n }),\n groups: createGroupEntity({\n entityName: ENTITIES.GROUPS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.GROUPS] : {}\n }),\n models: createModelEntity({\n entityName: ENTITIES.MODELS,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.MODELS] : {}\n }),\n entries: createEntryEntity({\n entityName: ENTITIES.ENTRIES,\n table: tableInstance,\n attributes: attributes ? attributes[ENTITIES.ENTRIES] : {}\n })\n };\n\n const plugins = new PluginsContainer([\n /**\n * User defined custom plugins.\n */\n ...(userPlugins || []),\n /**\n * Plugins of type CmsModelFieldToGraphQLPlugin.\n */\n modelFieldToGraphQLPlugins,\n /**\n * DynamoDB filter plugins for the where conditions.\n */\n dynamoDbValueFilters(),\n /**\n * Field plugins for DynamoDB.\n */\n dynamoDbPlugins()\n ]);\n\n return {\n beforeInit: async context => {\n context.plugins.register([\n /**\n * Field plugins for DynamoDB.\n * We must pass them to the base application.\n */\n dynamoDbPlugins()\n ]);\n },\n getEntities: () => entities,\n getTable: () => tableInstance,\n system: createSystemStorageOperations({\n entity: entities.system\n }),\n settings: createSettingsStorageOperations({\n entity: entities.settings\n }),\n groups: createGroupsStorageOperations({\n entity: entities.groups,\n plugins\n }),\n models: createModelsStorageOperations({\n entity: entities.models\n }),\n entries: createEntriesStorageOperations({\n entity: entities.entries,\n plugins\n })\n };\n};\n"]}
@@ -128,12 +128,11 @@ const createEntriesStorageOperations = params => {
128
128
 
129
129
  const createRevisionFrom = async (model, params) => {
130
130
  const {
131
- originalEntry,
132
131
  entry,
133
132
  storageEntry,
134
133
  latestEntry
135
134
  } = params;
136
- const partitionKey = (0, _keys.createPartitionKey)(storageEntry);
135
+ const partitionKey = (0, _keys.createPartitionKey)(entry);
137
136
  /**
138
137
  * We need to:
139
138
  * - create the main entry item
@@ -165,7 +164,6 @@ const createEntriesStorageOperations = params => {
165
164
  } catch (ex) {
166
165
  throw new _error.default(ex.message || "Could not create revision from given entry.", ex.code || "CREATE_REVISION_ERROR", {
167
166
  error: ex,
168
- originalEntry,
169
167
  latestEntry,
170
168
  entry,
171
169
  storageEntry
@@ -181,11 +179,10 @@ const createEntriesStorageOperations = params => {
181
179
 
182
180
  const update = async (model, params) => {
183
181
  const {
184
- originalEntry,
185
182
  entry,
186
183
  storageEntry
187
184
  } = params;
188
- const partitionKey = (0, _keys.createPartitionKey)(originalEntry);
185
+ const partitionKey = (0, _keys.createPartitionKey)(entry);
189
186
  const items = [];
190
187
  /**
191
188
  * We need to:
@@ -228,7 +225,6 @@ const createEntriesStorageOperations = params => {
228
225
  } catch (ex) {
229
226
  throw new _error.default(ex.message || "Could not update entry.", ex.code || "UPDATE_ERROR", {
230
227
  error: ex,
231
- originalEntry,
232
228
  entry,
233
229
  latestStorageEntry
234
230
  });
@@ -283,34 +279,34 @@ const createEntriesStorageOperations = params => {
283
279
 
284
280
  const deleteRevision = async (model, params) => {
285
281
  const {
286
- entryToDelete,
287
- entryToSetAsLatest,
288
- storageEntryToSetAsLatest
282
+ entry,
283
+ latestEntry,
284
+ latestStorageEntry
289
285
  } = params;
290
- const partitionKey = (0, _keys.createPartitionKey)(entryToDelete);
286
+ const partitionKey = (0, _keys.createPartitionKey)(entry);
291
287
  const items = [entity.deleteBatch({
292
288
  PK: partitionKey,
293
- SK: (0, _keys.createRevisionSortKey)(entryToDelete)
289
+ SK: (0, _keys.createRevisionSortKey)(entry)
294
290
  })];
295
- const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entryToDelete);
291
+ const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);
296
292
  /**
297
293
  * If revision we are deleting is the published one as well, we need to delete those records as well.
298
294
  */
299
295
 
300
- if (publishedStorageEntry && entryToDelete.id === publishedStorageEntry.id) {
296
+ if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {
301
297
  items.push(entity.deleteBatch({
302
298
  PK: partitionKey,
303
299
  SK: (0, _keys.createPublishedSortKey)()
304
300
  }));
305
301
  }
306
302
 
307
- if (storageEntryToSetAsLatest) {
308
- items.push(entity.putBatch(_objectSpread(_objectSpread({}, storageEntryToSetAsLatest), {}, {
303
+ if (latestStorageEntry) {
304
+ items.push(entity.putBatch(_objectSpread(_objectSpread({}, latestStorageEntry), {}, {
309
305
  PK: partitionKey,
310
306
  SK: (0, _keys.createLatestSortKey)(),
311
307
  TYPE: createLatestType(),
312
308
  GSI1_PK: (0, _keys.createGSIPartitionKey)(model, "L"),
313
- GSI1_SK: (0, _keys.createGSISortKey)(storageEntryToSetAsLatest)
309
+ GSI1_SK: (0, _keys.createGSISortKey)(latestStorageEntry)
314
310
  })));
315
311
  }
316
312
 
@@ -325,8 +321,8 @@ const createEntriesStorageOperations = params => {
325
321
  } catch (ex) {
326
322
  throw new _error.default(ex.message, ex.code, {
327
323
  error: ex,
328
- entryToDelete,
329
- entryToSetAsLatest
324
+ entry,
325
+ latestEntry
330
326
  });
331
327
  }
332
328
  };
@@ -432,12 +428,14 @@ const createEntriesStorageOperations = params => {
432
428
  const list = async (model, params) => {
433
429
  const {
434
430
  limit: initialLimit = 10,
435
- where: originalWhere,
431
+ where: initialWhere,
436
432
  after,
437
- sort
433
+ sort,
434
+ fields,
435
+ search
438
436
  } = params;
439
437
  const limit = initialLimit <= 0 || initialLimit >= 10000 ? 10000 : initialLimit;
440
- const type = originalWhere.published ? "P" : "L";
438
+ const type = initialWhere.published ? "P" : "L";
441
439
  const queryAllParams = {
442
440
  entity,
443
441
  partitionKey: (0, _keys.createGSIPartitionKey)(model, type),
@@ -467,12 +465,10 @@ const createEntriesStorageOperations = params => {
467
465
  };
468
466
  }
469
467
 
470
- const where = _objectSpread({}, originalWhere);
468
+ const where = _objectSpread({}, initialWhere);
471
469
 
472
470
  delete where["published"];
473
471
  delete where["latest"];
474
- delete where["locale"];
475
- delete where["tenant"];
476
472
  /**
477
473
  * We need a object containing field, transformers and paths.
478
474
  * Just build it here and pass on into other methods that require it to avoid mapping multiple times.
@@ -492,7 +488,11 @@ const createEntriesStorageOperations = params => {
492
488
  where,
493
489
  plugins,
494
490
  fields: modelFields,
495
- fromStorage: createStorageTransformCallable(model)
491
+ fromStorage: createStorageTransformCallable(model),
492
+ fullTextSearch: {
493
+ term: search,
494
+ fields: fields || []
495
+ }
496
496
  });
497
497
  const totalCount = filteredItems.length;
498
498
  /**
@@ -535,8 +535,7 @@ const createEntriesStorageOperations = params => {
535
535
  const requestChanges = async (model, params) => {
536
536
  const {
537
537
  entry,
538
- storageEntry,
539
- originalEntry
538
+ storageEntry
540
539
  } = params;
541
540
  const partitionKey = (0, _keys.createPartitionKey)(entry);
542
541
  /**
@@ -578,8 +577,7 @@ const createEntriesStorageOperations = params => {
578
577
  });
579
578
  } catch (ex) {
580
579
  throw new _error.default(ex.message || "Could not execute the request changes batch.", ex.code || "REQUEST_CHANGES_ERROR", {
581
- entry,
582
- originalEntry
580
+ entry
583
581
  });
584
582
  }
585
583
 
@@ -589,8 +587,7 @@ const createEntriesStorageOperations = params => {
589
587
  const requestReview = async (model, params) => {
590
588
  const {
591
589
  entry,
592
- storageEntry,
593
- originalEntry
590
+ storageEntry
594
591
  } = params;
595
592
  const partitionKey = (0, _keys.createPartitionKey)(entry);
596
593
  /**
@@ -634,8 +631,7 @@ const createEntriesStorageOperations = params => {
634
631
  } catch (ex) {
635
632
  throw new _error.default(ex.message || "Could not execute request review batch.", ex.code || "REQUEST_REVIEW_ERROR", {
636
633
  entry,
637
- storageEntry,
638
- originalEntry
634
+ storageEntry
639
635
  });
640
636
  }
641
637
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"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","items","putBatch","PK","SK","TYPE","GSI1_PK","GSI1_SK","table","clearAll","ex","WebinyError","message","code","error","createRevisionFrom","originalEntry","latestEntry","update","push","latestStorageEntry","getLatestRevisionByEntryId","id","deleteEntry","queryAllParams","options","gte","records","map","item","deleteBatch","deleteRevision","entryToDelete","entryToSetAsLatest","storageEntryToSetAsLatest","publishedStorageEntry","getPublishedRevisionByEntryId","result","ids","shift","getRevisionById","getRevisions","getAllEntryRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","tenant","locale","entryId","version","queryParams","lt","filters","attr","eq","reverse","list","limit","initialLimit","where","originalWhere","after","sort","published","index","length","hasMoreItems","totalCount","cursor","modelFields","filteredItems","fields","sortedItems","start","parseInt","end","undefined","slicedItems","slice","get","requestChanges","requestReview","publish","status","CONTENT_ENTRY_STATUS","UNPUBLISHED","unpublish","delete"],"mappings":"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","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<any> {\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(entry);\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 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 PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\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 { originalEntry, entry, storageEntry, latestEntry } = params;\n\n const partitionKey = createPartitionKey(storageEntry);\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 originalEntry,\n latestEntry,\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 { originalEntry, entry, storageEntry } = params;\n const partitionKey = createPartitionKey(originalEntry);\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 PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\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 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 originalEntry,\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(entry),\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 { entryToDelete, entryToSetAsLatest, storageEntryToSetAsLatest } = params;\n const partitionKey = createPartitionKey(entryToDelete);\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entryToDelete)\n })\n ];\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entryToDelete);\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 && entryToDelete.id === publishedStorageEntry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (storageEntryToSetAsLatest) {\n items.push(\n entity.putBatch({\n ...storageEntryToSetAsLatest,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntryToSetAsLatest)\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 entryToDelete,\n entryToSetAsLatest\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 { tenant, locale } = model;\n const { entryId, version } = params;\n const queryParams: QueryOneParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant,\n 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 { limit: initialLimit = 10, where: originalWhere, after, sort } = params;\n const limit = initialLimit <= 0 || initialLimit >= 10000 ? 10000 : initialLimit;\n\n const type = originalWhere.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 ...originalWhere\n };\n delete where[\"published\"];\n delete where[\"latest\"];\n delete where[\"locale\"];\n delete where[\"tenant\"];\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 });\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) || \"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, originalEntry } = params;\n\n const partitionKey = createPartitionKey(entry);\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 originalEntry\n }\n );\n }\n return entry;\n };\n\n const requestReview = async (\n model: CmsModel,\n params: CmsEntryStorageOperationsRequestReviewParams\n ) => {\n const { entry, storageEntry, originalEntry } = params;\n\n const partitionKey = createPartitionKey(entry);\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 originalEntry\n }\n );\n }\n };\n\n const publish = async (model: CmsModel, params: CmsEntryStorageOperationsPublishParams) => {\n const { entry, storageEntry } = params;\n\n const partitionKey = createPartitionKey(entry);\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(entry);\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"]}
1
+ {"version":3,"sources":["index.ts"],"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","items","putBatch","PK","SK","TYPE","GSI1_PK","GSI1_SK","table","clearAll","ex","WebinyError","message","code","error","createRevisionFrom","latestEntry","update","push","latestStorageEntry","getLatestRevisionByEntryId","id","deleteEntry","queryAllParams","options","gte","records","map","item","deleteBatch","deleteRevision","publishedStorageEntry","getPublishedRevisionByEntryId","result","ids","shift","getRevisionById","getRevisions","getAllEntryRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","tenant","locale","entryId","version","queryParams","lt","filters","attr","eq","reverse","list","limit","initialLimit","where","initialWhere","after","sort","fields","search","published","index","length","hasMoreItems","totalCount","cursor","modelFields","filteredItems","fullTextSearch","term","sortedItems","start","parseInt","end","undefined","slicedItems","slice","get","requestChanges","requestReview","publish","status","CONTENT_ENTRY_STATUS","UNPUBLISHED","unpublish","delete"],"mappings":"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","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(entry);\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 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 PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\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, latestEntry } = params;\n\n const partitionKey = createPartitionKey(entry);\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 latestEntry,\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(entry);\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 PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\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 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(entry),\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(entry);\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 { tenant, locale } = model;\n const { entryId, version } = params;\n const queryParams: QueryOneParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant,\n 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) || \"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(entry);\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(entry);\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(entry);\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(entry);\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"]}
@@ -17,6 +17,10 @@ interface FilterItemsParams {
17
17
  plugins: PluginsContainer;
18
18
  fields: ModelFieldRecords;
19
19
  fromStorage: FilterItemFromStorage;
20
+ fullTextSearch?: {
21
+ term?: string;
22
+ fields?: string[];
23
+ };
20
24
  }
21
25
  export declare const filterItems: (params: FilterItemsParams) => Promise<CmsEntry[]>;
22
26
  interface SortEntryItemsArgs {
@@ -7,6 +7,8 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.sortEntryItems = exports.filterItems = exports.buildModelFields = void 0;
9
9
 
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+
10
12
  var _error = _interopRequireDefault(require("@webiny/error"));
11
13
 
12
14
  var _sortBy = _interopRequireDefault(require("lodash/sortBy"));
@@ -19,6 +21,10 @@ var _ValueFilterPlugin = require("@webiny/db-dynamodb/plugins/definitions/ValueF
19
21
 
20
22
  var _CmsEntryFieldFilterPathPlugin = require("../../plugins/CmsEntryFieldFilterPathPlugin");
21
23
 
24
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
25
+
26
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
27
+
22
28
  const VALUES_ATTRIBUTE = "values";
23
29
 
24
30
  const extractWhereParams = key => {
@@ -139,6 +145,12 @@ const createFilters = params => {
139
145
  continue;
140
146
  }
141
147
 
148
+ const value = where[key];
149
+
150
+ if (value === undefined) {
151
+ continue;
152
+ }
153
+
142
154
  const {
143
155
  fieldId,
144
156
  operation,
@@ -167,12 +179,12 @@ const createFilters = params => {
167
179
 
168
180
  const objectFilteringParams = {
169
181
  key,
170
- value: where[key],
182
+ value,
171
183
  field: field.def
172
184
  };
173
185
 
174
186
  if (isObjectFiltering(objectFilteringParams)) {
175
- const propertyFilters = Object.keys(where[key]);
187
+ const propertyFilters = Object.keys(value);
176
188
 
177
189
  if (propertyFilters.length === 0) {
178
190
  continue;
@@ -198,7 +210,7 @@ const createFilters = params => {
198
210
  path: `${basePath}.${multiValuesPath}${propertyId}`,
199
211
  filterPlugin,
200
212
  negate: propertyNegate,
201
- compareValue: transformValue(where[key][propertyFilter], transformValueCallable),
213
+ compareValue: transformValue(value[propertyFilter], transformValueCallable),
202
214
  transformValue: transformValueCallable
203
215
  });
204
216
  }
@@ -218,7 +230,7 @@ const createFilters = params => {
218
230
  }),
219
231
  filterPlugin,
220
232
  negate,
221
- compareValue: transformValue(where[key], transformValueCallable),
233
+ compareValue: transformValue(value, transformValueCallable),
222
234
  transformValue: transformValueCallable
223
235
  });
224
236
  }
@@ -267,19 +279,65 @@ const execFilter = params => {
267
279
  return matched;
268
280
  };
269
281
 
282
+ /**
283
+ * Unfortunately we must use the contains plugin directly as plugins do not support multi field searching.
284
+ */
285
+ const createFullTextSearch = ({
286
+ term,
287
+ fields: targetFields,
288
+ plugin
289
+ }) => {
290
+ if (!term || term.trim().length === 0 || !targetFields || targetFields.length === 0) {
291
+ return null;
292
+ }
293
+
294
+ return async ({
295
+ item,
296
+ fromStorage,
297
+ fields
298
+ }) => {
299
+ for (const targetField of targetFields) {
300
+ const value = await fromStorage(fields[targetField].def, item.values[targetField]);
301
+
302
+ if (!value) {
303
+ continue;
304
+ }
305
+
306
+ if (plugin.matches({
307
+ value,
308
+ compareValue: term
309
+ }) === true) {
310
+ return true;
311
+ }
312
+ }
313
+
314
+ return false;
315
+ };
316
+ };
317
+
270
318
  const filterItems = async params => {
271
319
  const {
272
320
  items: records,
273
321
  where,
274
322
  plugins,
275
323
  fields,
276
- fromStorage
324
+ fromStorage,
325
+ fullTextSearch
277
326
  } = params;
278
327
  const filters = createFilters({
279
328
  plugins,
280
329
  where,
281
330
  fields
282
331
  });
332
+ const fullTextSearchPlugin = plugins.byType(_ValueFilterPlugin.ValueFilterPlugin.type).find(plugin => plugin.getOperation() === "contains");
333
+
334
+ if (!fullTextSearchPlugin) {
335
+ throw new _error.default(`Missing "contains" plugin to run the full-text search.`, "MISSING_PLUGIN");
336
+ }
337
+
338
+ const search = createFullTextSearch(_objectSpread(_objectSpread({}, fullTextSearch), {}, {
339
+ plugin: fullTextSearchPlugin
340
+ }));
283
341
  const promises = records.map(async record => {
284
342
  /**
285
343
  * We need to go through all the filters and apply them to the given record.
@@ -348,6 +406,24 @@ const filterItems = async params => {
348
406
  return null;
349
407
  }
350
408
  }
409
+ /**
410
+ * If we have full text search defined, run it. Otherwise just return the given record.
411
+ */
412
+
413
+
414
+ if (!search) {
415
+ return record;
416
+ }
417
+
418
+ const result = await search({
419
+ item: record,
420
+ fromStorage,
421
+ fields
422
+ });
423
+
424
+ if (!result) {
425
+ return null;
426
+ }
351
427
 
352
428
  return record;
353
429
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["utils.ts"],"names":["VALUES_ATTRIBUTE","extractWhereParams","key","result","split","fieldId","shift","rawOp","length","join","operation","negate","match","replace","transformValue","value","transform","Array","isArray","map","v","getFilterPlugin","params","plugins","plugin","WebinyError","createValuePath","field","index","valuePathPlugin","type","basePath","systemFields","canUse","path","createPath","isObjectFiltering","Date","toISOString","createFilters","where","fields","filterPlugins","getMappedPlugins","ValueFilterPlugin","property","transformValuePlugins","valuePathPlugins","CmsEntryFieldFilterPathPlugin","filters","hasOwnProperty","transformValuePlugin","def","transformValueCallable","objectFilteringParams","propertyFilters","Object","keys","propertyFilter","propertyId","propertyOperation","propertyNegate","filterPlugin","multiValuesPath","multipleValues","push","compareValue","getFilterValuePath","filter","includes","paths","getFilterValuePropertyPath","pop","execFilter","plainValue","matched","matches","filterItems","items","records","fromStorage","promises","record","valuePath","rawValue","dotProp","get","propertyPath","console","log","set","values","results","Promise","all","Boolean","extractSort","sortBy","order","modelField","reverse","sortEntryItems","sort","firstSort","itemsToSort","item","id","valueTransformer","sortedItems","newItems","s","find","i","sortingBy","pluginsContainer","byType","reduce","collection","buildModelFields","model","isSystemField"],"mappings":"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","sourcesContent":["import WebinyError from \"@webiny/error\";\nimport lodashSortBy from \"lodash/sortBy\";\nimport dotProp from \"dot-prop\";\nimport {\n CmsEntry,\n CmsEntryListWhere,\n CmsModel,\n CmsModelField\n} from \"@webiny/api-headless-cms/types\";\nimport { Plugin } from \"@webiny/plugins/types\";\nimport { CmsFieldFilterValueTransformPlugin } from \"~/types\";\nimport { systemFields } from \"./systemFields\";\nimport { ValueFilterPlugin } from \"@webiny/db-dynamodb/plugins/definitions/ValueFilterPlugin\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport {\n CmsEntryFieldFilterPathPlugin,\n CmsEntryFieldFilterPathPluginParams,\n CreatePathCallable as CmsEntryFieldFieldCreatePathCallable\n} from \"~/plugins/CmsEntryFieldFilterPathPlugin\";\n\ninterface ModelField {\n def: CmsModelField;\n valueTransformer: (value: any) => any;\n createPath: CmsEntryFieldFieldCreatePathCallable;\n isSystemField?: boolean;\n}\n\ntype ModelFieldRecords = Record<string, ModelField>;\n\ntype MappedPlugins<T extends Plugin> = Record<string, T>;\n\ninterface CreateFiltersParams {\n plugins: PluginsContainer;\n where: Partial<CmsEntryListWhere>;\n fields: ModelFieldRecords;\n}\n\ninterface ItemFilter {\n fieldId: string;\n path: string;\n filterPlugin: ValueFilterPlugin;\n negate: boolean;\n compareValue: any;\n transformValue: <I = any, O = any>(value: I) => O;\n}\n\nexport interface FilterItemFromStorage {\n <T = any>(field: CmsModelField, value: any): Promise<T>;\n}\ninterface FilterItemsParams {\n items: CmsEntry[];\n where: Partial<CmsEntryListWhere>;\n plugins: PluginsContainer;\n fields: ModelFieldRecords;\n fromStorage: FilterItemFromStorage;\n}\n\nconst VALUES_ATTRIBUTE = \"values\";\n\nconst extractWhereParams = (key: string) => {\n const result = key.split(\"_\");\n const fieldId = result.shift();\n const rawOp = result.length === 0 ? \"eq\" : result.join(\"_\");\n /**\n * When rawOp is not, it means it is equal negated so just return that.\n */\n if (rawOp === \"not\") {\n return {\n fieldId: fieldId as string,\n operation: \"eq\",\n negate: true\n };\n }\n const negate = rawOp.match(\"not_\") !== null;\n const operation = rawOp.replace(\"not_\", \"\");\n return {\n fieldId: fieldId as string,\n operation,\n negate\n };\n};\n\nconst transformValue = (value: any, transform: (value: any) => any): any => {\n if (Array.isArray(value)) {\n return value.map(v => transform(v));\n }\n return transform(value);\n};\n\ninterface GetFilterPluginParams {\n plugins: MappedPlugins<ValueFilterPlugin>;\n operation: string;\n}\nconst getFilterPlugin = (params: GetFilterPluginParams) => {\n const { plugins, operation } = params;\n const plugin = plugins[operation];\n if (plugin) {\n return plugin;\n }\n throw new WebinyError(\n `There is no filter plugin for operation \"${operation}\".`,\n \"FILTER_PLUGIN_ERROR\",\n {\n operation\n }\n );\n};\n\ninterface CreateValuePathParams {\n field: CmsModelField;\n plugins: MappedPlugins<CmsEntryFieldFilterPathPlugin>;\n index?: number;\n}\nconst createValuePath = (params: CreateValuePathParams): string => {\n const { field, plugins, index } = params;\n const { fieldId } = field;\n const valuePathPlugin = plugins[field.type];\n const basePath = systemFields[fieldId] ? \"\" : `${VALUES_ATTRIBUTE}.`;\n if (!valuePathPlugin || valuePathPlugin.canUse(field) === false) {\n return `${basePath}${field.fieldId}`;\n }\n const path = valuePathPlugin.createPath({\n field,\n index\n });\n return `${basePath}${path}`;\n};\n\ninterface ObjectFilteringParams {\n key: string;\n field: CmsModelField;\n value: any;\n}\nconst isObjectFiltering = (params: ObjectFilteringParams): boolean => {\n const { value } = params;\n if (!value) {\n return false;\n } else if (Array.isArray(value) === true) {\n return false;\n } else if (value instanceof Date || !!value.toISOString) {\n return false;\n } else if (typeof value !== \"object\") {\n return false;\n }\n return true;\n};\n\nconst createFilters = (params: CreateFiltersParams): ItemFilter[] => {\n const { where, plugins, fields } = params;\n const filterPlugins = getMappedPlugins<ValueFilterPlugin>({\n plugins,\n type: ValueFilterPlugin.type,\n property: \"operation\"\n });\n const transformValuePlugins = getMappedPlugins<CmsFieldFilterValueTransformPlugin>({\n plugins,\n type: \"cms-field-filter-value-transform\",\n property: \"fieldType\"\n });\n const valuePathPlugins = getMappedPlugins<CmsEntryFieldFilterPathPlugin>({\n plugins,\n type: CmsEntryFieldFilterPathPlugin.type,\n property: \"fieldType\"\n });\n\n const filters: ItemFilter[] = [];\n\n for (const key in where) {\n if (where.hasOwnProperty(key) === false) {\n continue;\n }\n const { fieldId, operation, negate } = extractWhereParams(key);\n\n const field: ModelField = fields[fieldId];\n if (!field) {\n throw new WebinyError(\n `There is no field with the fieldId \"${fieldId}\".`,\n \"FIELD_ERROR\",\n {\n fieldId\n }\n );\n }\n\n const transformValuePlugin: CmsFieldFilterValueTransformPlugin =\n transformValuePlugins[field.def.type];\n\n const transformValueCallable = (value: any) => {\n if (!transformValuePlugin) {\n return value;\n }\n return transformValuePlugin.transform({\n field: field.def,\n value\n });\n };\n\n const objectFilteringParams = {\n key,\n value: where[key],\n field: field.def\n };\n if (isObjectFiltering(objectFilteringParams)) {\n const propertyFilters = Object.keys(where[key]);\n if (propertyFilters.length === 0) {\n continue;\n }\n for (const propertyFilter of propertyFilters) {\n const {\n fieldId: propertyId,\n operation: propertyOperation,\n negate: propertyNegate\n } = extractWhereParams(propertyFilter);\n\n const filterPlugin = getFilterPlugin({\n plugins: filterPlugins,\n operation: propertyOperation\n });\n\n const basePath = createValuePath({\n field: field.def,\n plugins: valuePathPlugins\n });\n\n const multiValuesPath = field.def.multipleValues ? \"%s.\" : \"\";\n\n filters.push({\n fieldId,\n path: `${basePath}.${multiValuesPath}${propertyId}`,\n filterPlugin,\n negate: propertyNegate,\n compareValue: transformValue(\n where[key][propertyFilter],\n transformValueCallable\n ),\n transformValue: transformValueCallable\n });\n }\n\n continue;\n }\n\n const filterPlugin = getFilterPlugin({\n plugins: filterPlugins,\n operation\n });\n\n filters.push({\n fieldId,\n path: createValuePath({\n field: field.def,\n plugins: valuePathPlugins\n }),\n filterPlugin,\n negate,\n compareValue: transformValue(where[key], transformValueCallable),\n transformValue: transformValueCallable\n });\n }\n\n return filters;\n};\n/**\n * In case filter field is not multiple values one, return exact path.\n * If is multiple values field, use path without the last part\n */\nconst getFilterValuePath = (filter: ItemFilter): string => {\n if (filter.path.includes(\".%s.\") === false) {\n return filter.path;\n }\n const paths = filter.path.split(\".%s.\");\n return paths.shift() as string;\n};\n\nconst getFilterValuePropertyPath = (filter: ItemFilter): string | null => {\n if (filter.path.includes(\".%s.\") === false) {\n return null;\n }\n const paths = filter.path.split(\".%s.\");\n return paths.pop() || null;\n};\n\ninterface ExecFilterParams {\n value: any;\n filter: ItemFilter;\n}\nconst execFilter = (params: ExecFilterParams) => {\n const { value: plainValue, filter } = params;\n\n const value = transformValue(plainValue, filter.transformValue);\n const matched = filter.filterPlugin.matches({\n value,\n compareValue: filter.compareValue\n });\n if (filter.negate) {\n return matched === false;\n }\n return matched;\n};\n\nexport const filterItems = async (params: FilterItemsParams): Promise<CmsEntry[]> => {\n const { items: records, where, plugins, fields, fromStorage } = params;\n\n const filters = createFilters({\n plugins,\n where,\n fields\n });\n\n const promises: Promise<CmsEntry | null>[] = records.map(async record => {\n /**\n * We need to go through all the filters and apply them to the given record.\n */\n for (const filter of filters) {\n /**\n * In case is multiple values field, last part is removed from path.\n * -> values.categories.id -> values.categories\n */\n const valuePath = getFilterValuePath(filter);\n\n const rawValue = dotProp.get(record, valuePath);\n if (valuePath !== filter.path) {\n /**\n * Calculated is different than original because we need to search in the array of objects.\n */\n const propertyPath = getFilterValuePropertyPath(filter);\n if (!propertyPath) {\n console.log(`Cannot determine the property path of \"${filter.path}\".`);\n continue;\n }\n\n const plainValue = await fromStorage<Record<string, string>[]>(\n fields[filter.fieldId].def,\n rawValue\n );\n /**\n * We cannot go through the value because it is not array. Log the error and continue.\n */\n if (Array.isArray(plainValue) === false) {\n console.log(\n `Cannot go through the value on ${valuePath} because it is not an array, and we expect it to be.`\n );\n continue;\n }\n record = dotProp.set(record, valuePath, plainValue);\n\n const values = plainValue.map(value => {\n return value[propertyPath];\n });\n\n const result = execFilter({\n value: values,\n filter\n });\n\n if (!result) {\n return null;\n }\n continue;\n }\n\n const plainValue = await fromStorage(fields[filter.fieldId].def, rawValue);\n /**\n * If raw value is not same as the value after the storage transform, set the value to the items being filtered.\n */\n if (plainValue !== rawValue) {\n record = dotProp.set(record, filter.path, plainValue);\n }\n\n const result = execFilter({\n value: plainValue,\n filter\n });\n if (result === false) {\n return null;\n }\n }\n\n return record;\n });\n /**\n * We run filtering as promises so it is a bit faster than in for ... of loop.\n */\n const results: (CmsEntry | null)[] = await Promise.all(promises);\n /**\n * And filter out the null values which are returned when filter is not satisfied.\n */\n return results.filter(Boolean) as CmsEntry[];\n};\n\nconst extractSort = (\n sortBy: string,\n fields: ModelFieldRecords\n): { valuePath: string; reverse: boolean; fieldId: string } => {\n const result = sortBy.split(\"_\");\n if (result.length !== 2) {\n throw new WebinyError(\n \"Problem in determining the sorting for the entry items.\",\n \"SORT_ERROR\",\n {\n sortBy\n }\n );\n }\n const [fieldId, order] = result;\n\n const modelField = fields[fieldId];\n\n if (!modelField) {\n throw new WebinyError(\n \"Sorting field does not exist in the content model.\",\n \"SORTING_FIELD_ERROR\",\n {\n fieldId,\n fields\n }\n );\n }\n const valuePath = modelField.createPath({\n field: modelField.def\n });\n return {\n fieldId,\n valuePath,\n reverse: order === \"DESC\"\n };\n};\n\ninterface SortEntryItemsArgs {\n items: CmsEntry[];\n sort?: string[];\n fields: ModelFieldRecords;\n}\n\nexport const sortEntryItems = (params: SortEntryItemsArgs): CmsEntry[] => {\n const { items, sort = [], fields } = params;\n if (items.length <= 1) {\n return items;\n } else if (sort.length === 0) {\n sort.push(\"savedOn_DESC\");\n } else if (sort.length > 1) {\n throw new WebinyError(\"Sorting is limited to a single field.\", \"SORT_ERROR\", {\n sort: sort\n });\n }\n const [firstSort] = sort;\n if (!firstSort) {\n throw new WebinyError(\"Empty sort array item.\", \"SORT_ERROR\", {\n sort\n });\n }\n\n const { fieldId, valuePath, reverse } = extractSort(firstSort, fields);\n const field = fields[fieldId];\n\n const itemsToSort = items.map(item => {\n return {\n id: item.id,\n value: field.valueTransformer(dotProp.get(item, valuePath))\n };\n });\n const sortedItems: { id: string; value: any }[] = lodashSortBy(itemsToSort, \"value\");\n const newItems = sortedItems.map(s => {\n const item = items.find(i => i.id === s.id);\n if (item) {\n return item;\n }\n throw new WebinyError(\n \"Could not find item by given id after the sorting.\",\n \"SORTING_ITEMS_ERROR\",\n {\n id: s.id,\n sortingBy: fieldId,\n reverse\n }\n );\n });\n if (!reverse) {\n return newItems;\n }\n return newItems.reverse();\n};\n\nconst getMappedPlugins = <T extends Plugin>(params: {\n plugins: PluginsContainer;\n type: string;\n property: string;\n}): MappedPlugins<T> => {\n const { plugins: pluginsContainer, type, property } = params;\n const plugins = pluginsContainer.byType<T>(type);\n if (plugins.length === 0) {\n throw new WebinyError(`There are no plugins of type \"${type}\".`, \"PLUGINS_ERROR\", {\n type\n });\n }\n return plugins.reduce((collection, plugin) => {\n const key = plugin[property];\n if (typeof key !== \"string\") {\n throw new WebinyError(\n \"Property to map the plugins on must be a string.\",\n \"PLUGIN_PROPERTY_ERROR\",\n {\n type,\n property\n }\n );\n }\n collection[key] = plugin;\n return collection;\n }, {} as MappedPlugins<T>);\n};\n\nexport const buildModelFields = ({\n plugins,\n model\n}: {\n plugins: PluginsContainer;\n model: CmsModel;\n}) => {\n const transformValuePlugins = getMappedPlugins<CmsFieldFilterValueTransformPlugin>({\n plugins,\n type: \"cms-field-filter-value-transform\",\n property: \"fieldType\"\n });\n const valuePathPlugins = getMappedPlugins<CmsEntryFieldFilterPathPlugin>({\n plugins,\n type: CmsEntryFieldFilterPathPlugin.type,\n property: \"fieldType\"\n });\n const fields: ModelFieldRecords = Object.values(systemFields).reduce((collection, field) => {\n const transformValuePlugin = transformValuePlugins[field.type];\n const valuePathPlugin = valuePathPlugins[field.type];\n\n let createPath: CmsEntryFieldFilterPathPluginParams[\"path\"] = params => {\n return params.field.fieldId;\n };\n if (valuePathPlugin) {\n createPath = params => {\n return valuePathPlugin.createPath(params);\n };\n }\n collection[field.fieldId] = {\n def: field,\n valueTransformer: (value: any) => {\n if (!transformValuePlugin) {\n return value;\n }\n return transformValuePlugin.transform({ field, value });\n },\n createPath,\n isSystemField: true\n };\n\n return collection;\n }, {} as ModelFieldRecords);\n\n return model.fields.reduce((collection, field) => {\n const transformValuePlugin = transformValuePlugins[field.type];\n const valuePathPlugin = valuePathPlugins[field.type];\n\n let createPath: CmsEntryFieldFilterPathPluginParams[\"path\"] = params => {\n return `${VALUES_ATTRIBUTE}.${params.field.fieldId}`;\n };\n if (valuePathPlugin) {\n createPath = params => {\n return valuePathPlugin.createPath(params);\n };\n }\n\n collection[field.fieldId] = {\n def: field,\n valueTransformer: (value: any) => {\n if (!transformValuePlugin) {\n return value;\n }\n return transformValuePlugin.transform({ field, value });\n },\n createPath\n };\n\n return collection;\n }, fields);\n};\n"]}
1
+ {"version":3,"sources":["utils.ts"],"names":["VALUES_ATTRIBUTE","extractWhereParams","key","result","split","fieldId","shift","rawOp","length","join","operation","negate","match","replace","transformValue","value","transform","Array","isArray","map","v","getFilterPlugin","params","plugins","plugin","WebinyError","createValuePath","field","index","valuePathPlugin","type","basePath","systemFields","canUse","path","createPath","isObjectFiltering","Date","toISOString","createFilters","where","fields","filterPlugins","getMappedPlugins","ValueFilterPlugin","property","transformValuePlugins","valuePathPlugins","CmsEntryFieldFilterPathPlugin","filters","hasOwnProperty","undefined","transformValuePlugin","def","transformValueCallable","objectFilteringParams","propertyFilters","Object","keys","propertyFilter","propertyId","propertyOperation","propertyNegate","filterPlugin","multiValuesPath","multipleValues","push","compareValue","getFilterValuePath","filter","includes","paths","getFilterValuePropertyPath","pop","execFilter","plainValue","matched","matches","createFullTextSearch","term","targetFields","trim","item","fromStorage","targetField","values","filterItems","items","records","fullTextSearch","fullTextSearchPlugin","byType","find","getOperation","search","promises","record","valuePath","rawValue","dotProp","get","propertyPath","console","log","set","results","Promise","all","Boolean","extractSort","sortBy","order","modelField","reverse","sortEntryItems","sort","firstSort","itemsToSort","id","valueTransformer","sortedItems","newItems","s","i","sortingBy","pluginsContainer","reduce","collection","buildModelFields","model","isSystemField"],"mappings":"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","sourcesContent":["import WebinyError from \"@webiny/error\";\nimport lodashSortBy from \"lodash/sortBy\";\nimport dotProp from \"dot-prop\";\nimport {\n CmsEntry,\n CmsEntryListWhere,\n CmsModel,\n CmsModelField\n} from \"@webiny/api-headless-cms/types\";\nimport { Plugin } from \"@webiny/plugins/types\";\nimport { CmsFieldFilterValueTransformPlugin } from \"~/types\";\nimport { systemFields } from \"./systemFields\";\nimport { ValueFilterPlugin } from \"@webiny/db-dynamodb/plugins/definitions/ValueFilterPlugin\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport {\n CmsEntryFieldFilterPathPlugin,\n CmsEntryFieldFilterPathPluginParams,\n CreatePathCallable as CmsEntryFieldFieldCreatePathCallable\n} from \"~/plugins/CmsEntryFieldFilterPathPlugin\";\n\ninterface ModelField {\n def: CmsModelField;\n valueTransformer: (value: any) => any;\n createPath: CmsEntryFieldFieldCreatePathCallable;\n isSystemField?: boolean;\n}\n\ntype ModelFieldRecords = Record<string, ModelField>;\n\ntype MappedPlugins<T extends Plugin> = Record<string, T>;\n\ninterface CreateFiltersParams {\n plugins: PluginsContainer;\n where: Partial<CmsEntryListWhere>;\n fields: ModelFieldRecords;\n}\n\ninterface ItemFilter {\n fieldId: string;\n path: string;\n filterPlugin: ValueFilterPlugin;\n negate: boolean;\n compareValue: any;\n transformValue: <I = any, O = any>(value: I) => O;\n}\n\nexport interface FilterItemFromStorage {\n <T = any>(field: CmsModelField, value: any): Promise<T>;\n}\ninterface FilterItemsParams {\n items: CmsEntry[];\n where: Partial<CmsEntryListWhere>;\n plugins: PluginsContainer;\n fields: ModelFieldRecords;\n fromStorage: FilterItemFromStorage;\n fullTextSearch?: {\n term?: string;\n fields?: string[];\n };\n}\n\nconst VALUES_ATTRIBUTE = \"values\";\n\nconst extractWhereParams = (key: string) => {\n const result = key.split(\"_\");\n const fieldId = result.shift();\n const rawOp = result.length === 0 ? \"eq\" : result.join(\"_\");\n /**\n * When rawOp is not, it means it is equal negated so just return that.\n */\n if (rawOp === \"not\") {\n return {\n fieldId: fieldId as string,\n operation: \"eq\",\n negate: true\n };\n }\n const negate = rawOp.match(\"not_\") !== null;\n const operation = rawOp.replace(\"not_\", \"\");\n return {\n fieldId: fieldId as string,\n operation,\n negate\n };\n};\n\nconst transformValue = (value: any, transform: (value: any) => any): any => {\n if (Array.isArray(value)) {\n return value.map(v => transform(v));\n }\n return transform(value);\n};\n\ninterface GetFilterPluginParams {\n plugins: MappedPlugins<ValueFilterPlugin>;\n operation: string;\n}\nconst getFilterPlugin = (params: GetFilterPluginParams) => {\n const { plugins, operation } = params;\n const plugin = plugins[operation];\n if (plugin) {\n return plugin;\n }\n throw new WebinyError(\n `There is no filter plugin for operation \"${operation}\".`,\n \"FILTER_PLUGIN_ERROR\",\n {\n operation\n }\n );\n};\n\ninterface CreateValuePathParams {\n field: CmsModelField;\n plugins: MappedPlugins<CmsEntryFieldFilterPathPlugin>;\n index?: number;\n}\nconst createValuePath = (params: CreateValuePathParams): string => {\n const { field, plugins, index } = params;\n const { fieldId } = field;\n const valuePathPlugin = plugins[field.type];\n const basePath = systemFields[fieldId] ? \"\" : `${VALUES_ATTRIBUTE}.`;\n if (!valuePathPlugin || valuePathPlugin.canUse(field) === false) {\n return `${basePath}${field.fieldId}`;\n }\n const path = valuePathPlugin.createPath({\n field,\n index\n });\n return `${basePath}${path}`;\n};\n\ninterface ObjectFilteringParams {\n key: string;\n field: CmsModelField;\n value: any;\n}\nconst isObjectFiltering = (params: ObjectFilteringParams): boolean => {\n const { value } = params;\n if (!value) {\n return false;\n } else if (Array.isArray(value) === true) {\n return false;\n } else if (value instanceof Date || !!value.toISOString) {\n return false;\n } else if (typeof value !== \"object\") {\n return false;\n }\n return true;\n};\n\nconst createFilters = (params: CreateFiltersParams): ItemFilter[] => {\n const { where, plugins, fields } = params;\n const filterPlugins = getMappedPlugins<ValueFilterPlugin>({\n plugins,\n type: ValueFilterPlugin.type,\n property: \"operation\"\n });\n const transformValuePlugins = getMappedPlugins<CmsFieldFilterValueTransformPlugin>({\n plugins,\n type: \"cms-field-filter-value-transform\",\n property: \"fieldType\"\n });\n const valuePathPlugins = getMappedPlugins<CmsEntryFieldFilterPathPlugin>({\n plugins,\n type: CmsEntryFieldFilterPathPlugin.type,\n property: \"fieldType\"\n });\n\n const filters: ItemFilter[] = [];\n\n for (const key in where) {\n if (where.hasOwnProperty(key) === false) {\n continue;\n }\n\n const value = (where as any)[key];\n if (value === undefined) {\n continue;\n }\n\n const { fieldId, operation, negate } = extractWhereParams(key);\n\n const field: ModelField = fields[fieldId];\n if (!field) {\n throw new WebinyError(\n `There is no field with the fieldId \"${fieldId}\".`,\n \"FIELD_ERROR\",\n {\n fieldId\n }\n );\n }\n\n const transformValuePlugin: CmsFieldFilterValueTransformPlugin =\n transformValuePlugins[field.def.type];\n\n const transformValueCallable = (value: any) => {\n if (!transformValuePlugin) {\n return value;\n }\n return transformValuePlugin.transform({\n field: field.def,\n value\n });\n };\n\n const objectFilteringParams = {\n key,\n value,\n field: field.def\n };\n if (isObjectFiltering(objectFilteringParams)) {\n const propertyFilters = Object.keys(value);\n if (propertyFilters.length === 0) {\n continue;\n }\n for (const propertyFilter of propertyFilters) {\n const {\n fieldId: propertyId,\n operation: propertyOperation,\n negate: propertyNegate\n } = extractWhereParams(propertyFilter);\n\n const filterPlugin = getFilterPlugin({\n plugins: filterPlugins,\n operation: propertyOperation\n });\n\n const basePath = createValuePath({\n field: field.def,\n plugins: valuePathPlugins\n });\n\n const multiValuesPath = field.def.multipleValues ? \"%s.\" : \"\";\n\n filters.push({\n fieldId,\n path: `${basePath}.${multiValuesPath}${propertyId}`,\n filterPlugin,\n negate: propertyNegate,\n compareValue: transformValue(value[propertyFilter], transformValueCallable),\n transformValue: transformValueCallable\n });\n }\n\n continue;\n }\n\n const filterPlugin = getFilterPlugin({\n plugins: filterPlugins,\n operation\n });\n\n filters.push({\n fieldId,\n path: createValuePath({\n field: field.def,\n plugins: valuePathPlugins\n }),\n filterPlugin,\n negate,\n compareValue: transformValue(value, transformValueCallable),\n transformValue: transformValueCallable\n });\n }\n\n return filters;\n};\n/**\n * In case filter field is not multiple values one, return exact path.\n * If is multiple values field, use path without the last part\n */\nconst getFilterValuePath = (filter: ItemFilter): string => {\n if (filter.path.includes(\".%s.\") === false) {\n return filter.path;\n }\n const paths = filter.path.split(\".%s.\");\n return paths.shift() as string;\n};\n\nconst getFilterValuePropertyPath = (filter: ItemFilter): string | null => {\n if (filter.path.includes(\".%s.\") === false) {\n return null;\n }\n const paths = filter.path.split(\".%s.\");\n return paths.pop() || null;\n};\n\ninterface ExecFilterParams {\n value: any;\n filter: ItemFilter;\n}\nconst execFilter = (params: ExecFilterParams) => {\n const { value: plainValue, filter } = params;\n\n const value = transformValue(plainValue, filter.transformValue);\n const matched = filter.filterPlugin.matches({\n value,\n compareValue: filter.compareValue\n });\n if (filter.negate) {\n return matched === false;\n }\n return matched;\n};\n\ninterface CreateFullTextSearchParams {\n term?: string;\n fields?: string[];\n plugin: ValueFilterPlugin;\n}\n\ninterface FullTextSearchParams {\n item: CmsEntry;\n fromStorage: FilterItemFromStorage;\n fields: ModelFieldRecords;\n}\n/**\n * Unfortunately we must use the contains plugin directly as plugins do not support multi field searching.\n */\nconst createFullTextSearch = ({\n term,\n fields: targetFields,\n plugin\n}: CreateFullTextSearchParams) => {\n if (!term || term.trim().length === 0 || !targetFields || targetFields.length === 0) {\n return null;\n }\n return async ({ item, fromStorage, fields }: FullTextSearchParams) => {\n for (const targetField of targetFields) {\n const value = await fromStorage(fields[targetField].def, item.values[targetField]);\n if (!value) {\n continue;\n }\n if (plugin.matches({ value, compareValue: term }) === true) {\n return true;\n }\n }\n return false;\n };\n};\n\nexport const filterItems = async (params: FilterItemsParams): Promise<CmsEntry[]> => {\n const { items: records, where, plugins, fields, fromStorage, fullTextSearch } = params;\n\n const filters = createFilters({\n plugins,\n where,\n fields\n });\n\n const fullTextSearchPlugin = plugins\n .byType<ValueFilterPlugin>(ValueFilterPlugin.type)\n .find(plugin => plugin.getOperation() === \"contains\");\n if (!fullTextSearchPlugin) {\n throw new WebinyError(\n `Missing \"contains\" plugin to run the full-text search.`,\n \"MISSING_PLUGIN\"\n );\n }\n\n const search = createFullTextSearch({\n ...fullTextSearch,\n plugin: fullTextSearchPlugin\n });\n\n const promises: Promise<CmsEntry | null>[] = records.map(async record => {\n /**\n * We need to go through all the filters and apply them to the given record.\n */\n for (const filter of filters) {\n /**\n * In case is multiple values field, last part is removed from path.\n * -> values.categories.id -> values.categories\n */\n const valuePath = getFilterValuePath(filter);\n\n const rawValue = dotProp.get(record, valuePath);\n if (valuePath !== filter.path) {\n /**\n * Calculated is different than original because we need to search in the array of objects.\n */\n const propertyPath = getFilterValuePropertyPath(filter);\n if (!propertyPath) {\n console.log(`Cannot determine the property path of \"${filter.path}\".`);\n continue;\n }\n\n const plainValue = await fromStorage<Record<string, string>[]>(\n fields[filter.fieldId].def,\n rawValue\n );\n /**\n * We cannot go through the value because it is not array. Log the error and continue.\n */\n if (Array.isArray(plainValue) === false) {\n console.log(\n `Cannot go through the value on ${valuePath} because it is not an array, and we expect it to be.`\n );\n continue;\n }\n record = dotProp.set(record, valuePath, plainValue);\n\n const values = plainValue.map(value => {\n return value[propertyPath];\n });\n\n const result = execFilter({\n value: values,\n filter\n });\n\n if (!result) {\n return null;\n }\n continue;\n }\n\n const plainValue = await fromStorage(fields[filter.fieldId].def, rawValue);\n /**\n * If raw value is not same as the value after the storage transform, set the value to the items being filtered.\n */\n if (plainValue !== rawValue) {\n record = dotProp.set(record, filter.path, plainValue);\n }\n\n const result = execFilter({\n value: plainValue,\n filter\n });\n if (result === false) {\n return null;\n }\n }\n /**\n * If we have full text search defined, run it. Otherwise just return the given record.\n */\n if (!search) {\n return record;\n }\n const result = await search({\n item: record,\n fromStorage,\n fields\n });\n if (!result) {\n return null;\n }\n\n return record;\n });\n /**\n * We run filtering as promises so it is a bit faster than in for ... of loop.\n */\n const results: (CmsEntry | null)[] = await Promise.all(promises);\n /**\n * And filter out the null values which are returned when filter is not satisfied.\n */\n\n return results.filter(Boolean) as CmsEntry[];\n};\n\nconst extractSort = (\n sortBy: string,\n fields: ModelFieldRecords\n): { valuePath: string; reverse: boolean; fieldId: string } => {\n const result = sortBy.split(\"_\");\n if (result.length !== 2) {\n throw new WebinyError(\n \"Problem in determining the sorting for the entry items.\",\n \"SORT_ERROR\",\n {\n sortBy\n }\n );\n }\n const [fieldId, order] = result;\n\n const modelField = fields[fieldId];\n\n if (!modelField) {\n throw new WebinyError(\n \"Sorting field does not exist in the content model.\",\n \"SORTING_FIELD_ERROR\",\n {\n fieldId,\n fields\n }\n );\n }\n const valuePath = modelField.createPath({\n field: modelField.def\n });\n return {\n fieldId,\n valuePath,\n reverse: order === \"DESC\"\n };\n};\n\ninterface SortEntryItemsArgs {\n items: CmsEntry[];\n sort?: string[];\n fields: ModelFieldRecords;\n}\n\nexport const sortEntryItems = (params: SortEntryItemsArgs): CmsEntry[] => {\n const { items, sort = [], fields } = params;\n if (items.length <= 1) {\n return items;\n } else if (sort.length === 0) {\n sort.push(\"savedOn_DESC\");\n } else if (sort.length > 1) {\n throw new WebinyError(\"Sorting is limited to a single field.\", \"SORT_ERROR\", {\n sort: sort\n });\n }\n const [firstSort] = sort;\n if (!firstSort) {\n throw new WebinyError(\"Empty sort array item.\", \"SORT_ERROR\", {\n sort\n });\n }\n\n const { fieldId, valuePath, reverse } = extractSort(firstSort, fields);\n const field = fields[fieldId];\n\n const itemsToSort = items.map(item => {\n return {\n id: item.id,\n value: field.valueTransformer(dotProp.get(item, valuePath))\n };\n });\n const sortedItems: { id: string; value: any }[] = lodashSortBy(itemsToSort, \"value\");\n const newItems = sortedItems.map(s => {\n const item = items.find(i => i.id === s.id);\n if (item) {\n return item;\n }\n throw new WebinyError(\n \"Could not find item by given id after the sorting.\",\n \"SORTING_ITEMS_ERROR\",\n {\n id: s.id,\n sortingBy: fieldId,\n reverse\n }\n );\n });\n if (!reverse) {\n return newItems;\n }\n return newItems.reverse();\n};\n\nconst getMappedPlugins = <T extends Plugin>(params: {\n plugins: PluginsContainer;\n type: string;\n property: string;\n}): MappedPlugins<T> => {\n const { plugins: pluginsContainer, type, property } = params;\n const plugins = pluginsContainer.byType<T>(type);\n if (plugins.length === 0) {\n throw new WebinyError(`There are no plugins of type \"${type}\".`, \"PLUGINS_ERROR\", {\n type\n });\n }\n return plugins.reduce((collection, plugin) => {\n const key = plugin[property];\n if (typeof key !== \"string\") {\n throw new WebinyError(\n \"Property to map the plugins on must be a string.\",\n \"PLUGIN_PROPERTY_ERROR\",\n {\n type,\n property\n }\n );\n }\n collection[key] = plugin;\n return collection;\n }, {} as MappedPlugins<T>);\n};\n\nexport const buildModelFields = ({\n plugins,\n model\n}: {\n plugins: PluginsContainer;\n model: CmsModel;\n}) => {\n const transformValuePlugins = getMappedPlugins<CmsFieldFilterValueTransformPlugin>({\n plugins,\n type: \"cms-field-filter-value-transform\",\n property: \"fieldType\"\n });\n const valuePathPlugins = getMappedPlugins<CmsEntryFieldFilterPathPlugin>({\n plugins,\n type: CmsEntryFieldFilterPathPlugin.type,\n property: \"fieldType\"\n });\n const fields: ModelFieldRecords = Object.values(systemFields).reduce((collection, field) => {\n const transformValuePlugin = transformValuePlugins[field.type];\n const valuePathPlugin = valuePathPlugins[field.type];\n\n let createPath: CmsEntryFieldFilterPathPluginParams[\"path\"] = params => {\n return params.field.fieldId;\n };\n if (valuePathPlugin) {\n createPath = params => {\n return valuePathPlugin.createPath(params);\n };\n }\n collection[field.fieldId] = {\n def: field,\n valueTransformer: (value: any) => {\n if (!transformValuePlugin) {\n return value;\n }\n return transformValuePlugin.transform({ field, value });\n },\n createPath,\n isSystemField: true\n };\n\n return collection;\n }, {} as ModelFieldRecords);\n\n return model.fields.reduce((collection, field) => {\n const transformValuePlugin = transformValuePlugins[field.type];\n const valuePathPlugin = valuePathPlugins[field.type];\n\n let createPath: CmsEntryFieldFilterPathPluginParams[\"path\"] = params => {\n return `${VALUES_ATTRIBUTE}.${params.field.fieldId}`;\n };\n if (valuePathPlugin) {\n createPath = params => {\n return valuePathPlugin.createPath(params);\n };\n }\n\n collection[field.fieldId] = {\n def: field,\n valueTransformer: (value: any) => {\n if (!transformValuePlugin) {\n return value;\n }\n return transformValuePlugin.transform({ field, value });\n },\n createPath\n };\n\n return collection;\n }, fields);\n};\n"]}
@@ -86,8 +86,7 @@ const createGroupsStorageOperations = params => {
86
86
 
87
87
  const update = async params => {
88
88
  const {
89
- group,
90
- original
89
+ group
91
90
  } = params;
92
91
  const keys = createKeys(group);
93
92
 
@@ -100,7 +99,6 @@ const createGroupsStorageOperations = params => {
100
99
  throw new _error.default(ex.message || "Could not update group.", ex.code || "UPDATE_GROUP_ERROR", {
101
100
  error: ex,
102
101
  group,
103
- original,
104
102
  keys
105
103
  });
106
104
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"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","original","deleteGroup","delete","get","list","sort","where","queryAllParams","partitionKey","options","gte","records","filteredItems","items","fields"],"mappings":"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","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, original } = 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 original,\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"]}
1
+ {"version":3,"sources":["index.ts"],"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","list","sort","where","queryAllParams","partitionKey","options","gte","records","filteredItems","items","fields"],"mappings":"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","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"]}
@@ -78,7 +78,6 @@ const createModelsStorageOperations = params => {
78
78
 
79
79
  const update = async params => {
80
80
  const {
81
- original,
82
81
  model
83
82
  } = params;
84
83
  const keys = createKeys(model);
@@ -92,7 +91,6 @@ const createModelsStorageOperations = params => {
92
91
  throw new _error.default(ex.message || "Could not update model.", ex.code || "MODEL_UPDATE_ERROR", {
93
92
  error: ex,
94
93
  model,
95
- original,
96
94
  keys
97
95
  });
98
96
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":["createPartitionKey","params","tenant","locale","WebinyError","createSortKey","modelId","createKeys","PK","SK","createType","createModelsStorageOperations","entity","create","model","keys","put","TYPE","ex","error","update","original","message","code","deleteModel","delete","get","item","list","where","queryAllParams","partitionKey","options","gte","items"],"mappings":"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","sourcesContent":["import {\n CmsModel,\n CmsModelStorageOperations,\n CmsModelStorageOperationsCreateParams,\n CmsModelStorageOperationsDeleteParams,\n CmsModelStorageOperationsGetParams,\n CmsModelStorageOperationsListParams,\n CmsModelStorageOperationsUpdateParams\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, cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { queryAll, QueryAllParams } from \"@webiny/db-dynamodb/utils/query\";\n\ninterface PartitionKeysParams {\n tenant: string;\n locale: string;\n}\nconst createPartitionKey = (params: PartitionKeysParams): string => {\n const { tenant, locale } = params;\n if (!tenant) {\n throw new WebinyError(`Missing tenant variable when creating model partitionKey.`);\n } else if (!locale) {\n throw new WebinyError(`Missing locale variable when creating model partitionKey.`);\n }\n return `T#${tenant}#L#${locale}#CMS#CM`;\n};\n\ninterface SortKeyParams {\n modelId: string;\n}\nconst createSortKey = (params: SortKeyParams): string => {\n return params.modelId;\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\nconst createKeys = (params: PartitionKeysParams & SortKeyParams): Keys => {\n return {\n PK: createPartitionKey(params),\n SK: createSortKey(params)\n };\n};\n\nconst createType = (): string => {\n return \"cms.model\";\n};\n\ninterface CreateModelsStorageOperationsParams {\n entity: Entity<any>;\n}\nexport const createModelsStorageOperations = (\n params: CreateModelsStorageOperationsParams\n): CmsModelStorageOperations => {\n const { entity } = params;\n\n const create = async (params: CmsModelStorageOperationsCreateParams) => {\n const { model } = params;\n\n const keys = createKeys(model);\n\n try {\n await entity.put({\n ...model,\n ...keys,\n TYPE: createType()\n });\n return model;\n } catch (ex) {\n throw new WebinyError(`Could not create CMS Content Model.`, \"CREATE_MODEL_ERROR\", {\n error: ex,\n model,\n keys\n });\n }\n };\n\n const update = async (params: CmsModelStorageOperationsUpdateParams) => {\n const { original, model } = params;\n\n const keys = createKeys(model);\n\n try {\n await entity.put({\n ...model,\n ...keys,\n TYPE: createType()\n });\n return model;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update model.\",\n ex.code || \"MODEL_UPDATE_ERROR\",\n {\n error: ex,\n model,\n original,\n keys\n }\n );\n }\n };\n\n const deleteModel = async (params: CmsModelStorageOperationsDeleteParams) => {\n const { model } = params;\n const keys = createKeys(model);\n\n try {\n await entity.delete(keys);\n return model;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete model.\",\n ex.code || \"MODEL_DELETE_ERROR\",\n {\n error: ex,\n model,\n keys\n }\n );\n }\n };\n\n const get = async (params: CmsModelStorageOperationsGetParams) => {\n const keys = createKeys(params);\n\n try {\n const item = await getRecord<CmsModel>({\n entity,\n keys\n });\n return cleanupItem(entity, item);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get model.\",\n ex.code || \"MODEL_GET_ERROR\",\n {\n error: ex,\n keys\n }\n );\n }\n };\n\n const list = async (params: CmsModelStorageOperationsListParams) => {\n const { where } = params;\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey(where),\n options: {\n gte: \" \"\n }\n };\n try {\n const items = await queryAll<CmsModel>(queryAllParams);\n\n return cleanupItems(entity, items);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not list models.\",\n ex.code || \"MODEL_LIST_ERROR\",\n {\n error: ex,\n partitionKey: queryAllParams.partitionKey\n }\n );\n }\n };\n\n return {\n create,\n update,\n delete: deleteModel,\n get,\n list\n };\n};\n"]}
1
+ {"version":3,"sources":["index.ts"],"names":["createPartitionKey","params","tenant","locale","WebinyError","createSortKey","modelId","createKeys","PK","SK","createType","createModelsStorageOperations","entity","create","model","keys","put","TYPE","ex","error","update","message","code","deleteModel","delete","get","item","list","where","queryAllParams","partitionKey","options","gte","items"],"mappings":"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","sourcesContent":["import {\n CmsModel,\n CmsModelStorageOperations,\n CmsModelStorageOperationsCreateParams,\n CmsModelStorageOperationsDeleteParams,\n CmsModelStorageOperationsGetParams,\n CmsModelStorageOperationsListParams,\n CmsModelStorageOperationsUpdateParams\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, cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { queryAll, QueryAllParams } from \"@webiny/db-dynamodb/utils/query\";\n\ninterface PartitionKeysParams {\n tenant: string;\n locale: string;\n}\nconst createPartitionKey = (params: PartitionKeysParams): string => {\n const { tenant, locale } = params;\n if (!tenant) {\n throw new WebinyError(`Missing tenant variable when creating model partitionKey.`);\n } else if (!locale) {\n throw new WebinyError(`Missing locale variable when creating model partitionKey.`);\n }\n return `T#${tenant}#L#${locale}#CMS#CM`;\n};\n\ninterface SortKeyParams {\n modelId: string;\n}\nconst createSortKey = (params: SortKeyParams): string => {\n return params.modelId;\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\nconst createKeys = (params: PartitionKeysParams & SortKeyParams): Keys => {\n return {\n PK: createPartitionKey(params),\n SK: createSortKey(params)\n };\n};\n\nconst createType = (): string => {\n return \"cms.model\";\n};\n\ninterface CreateModelsStorageOperationsParams {\n entity: Entity<any>;\n}\nexport const createModelsStorageOperations = (\n params: CreateModelsStorageOperationsParams\n): CmsModelStorageOperations => {\n const { entity } = params;\n\n const create = async (params: CmsModelStorageOperationsCreateParams) => {\n const { model } = params;\n\n const keys = createKeys(model);\n\n try {\n await entity.put({\n ...model,\n ...keys,\n TYPE: createType()\n });\n return model;\n } catch (ex) {\n throw new WebinyError(`Could not create CMS Content Model.`, \"CREATE_MODEL_ERROR\", {\n error: ex,\n model,\n keys\n });\n }\n };\n\n const update = async (params: CmsModelStorageOperationsUpdateParams) => {\n const { model } = params;\n\n const keys = createKeys(model);\n\n try {\n await entity.put({\n ...model,\n ...keys,\n TYPE: createType()\n });\n return model;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update model.\",\n ex.code || \"MODEL_UPDATE_ERROR\",\n {\n error: ex,\n model,\n keys\n }\n );\n }\n };\n\n const deleteModel = async (params: CmsModelStorageOperationsDeleteParams) => {\n const { model } = params;\n const keys = createKeys(model);\n\n try {\n await entity.delete(keys);\n return model;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete model.\",\n ex.code || \"MODEL_DELETE_ERROR\",\n {\n error: ex,\n model,\n keys\n }\n );\n }\n };\n\n const get = async (params: CmsModelStorageOperationsGetParams) => {\n const keys = createKeys(params);\n\n try {\n const item = await getRecord<CmsModel>({\n entity,\n keys\n });\n return cleanupItem(entity, item);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get model.\",\n ex.code || \"MODEL_GET_ERROR\",\n {\n error: ex,\n keys\n }\n );\n }\n };\n\n const list = async (params: CmsModelStorageOperationsListParams) => {\n const { where } = params;\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey(where),\n options: {\n gte: \" \"\n }\n };\n try {\n const items = await queryAll<CmsModel>(queryAllParams);\n\n return cleanupItems(entity, items);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not list models.\",\n ex.code || \"MODEL_LIST_ERROR\",\n {\n error: ex,\n partitionKey: queryAllParams.partitionKey\n }\n );\n }\n };\n\n return {\n create,\n update,\n delete: deleteModel,\n get,\n list\n };\n};\n"]}
@@ -88,8 +88,7 @@ const createSettingsStorageOperations = params => {
88
88
 
89
89
  const update = async params => {
90
90
  const {
91
- settings,
92
- original
91
+ settings
93
92
  } = params;
94
93
  const keys = createKeys(settings);
95
94
  const dbSettings = convertToDbData(settings);
@@ -102,7 +101,6 @@ const createSettingsStorageOperations = params => {
102
101
  error: ex,
103
102
  settings,
104
103
  dbSettings,
105
- original,
106
104
  keys
107
105
  });
108
106
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":["convertToDbData","settings","contentModelLastChange","toISOString","convertFromDbData","Date","createPartitionKey","tenant","locale","createSortKey","createKeys","params","PK","SK","createSettingsStorageOperations","entity","create","keys","dbSettings","put","ex","WebinyError","message","code","error","update","original","get","record"],"mappings":"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","sourcesContent":["import {\n CmsSettings,\n CmsSettingsStorageOperations,\n CmsSettingsStorageOperationsCreateParams,\n CmsSettingsStorageOperationsGetParams,\n CmsSettingsStorageOperationsUpdateParams\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport { get as getRecord } from \"@webiny/db-dynamodb/utils/get\";\nimport WebinyError from \"@webiny/error\";\nimport { cleanupItem } from \"@webiny/db-dynamodb/utils/cleanup\";\n\ninterface CmsSettingsDb extends Omit<CmsSettings, \"contentModelLastChange\"> {\n contentModelLastChange: string;\n}\n\nconst convertToDbData = (settings: CmsSettings): CmsSettingsDb => {\n return {\n ...settings,\n contentModelLastChange: settings.contentModelLastChange.toISOString()\n };\n};\n\nconst convertFromDbData = (settings?: CmsSettingsDb): CmsSettings | null => {\n if (!settings) {\n return null;\n }\n let contentModelLastChange;\n try {\n contentModelLastChange = new Date(settings.contentModelLastChange);\n } catch {\n contentModelLastChange = new Date();\n }\n return {\n ...settings,\n contentModelLastChange\n };\n};\n\ninterface PartitionKeyParams {\n tenant: string;\n locale: string;\n}\n\nconst createPartitionKey = ({ tenant, locale }: PartitionKeyParams): string => {\n return `T#${tenant}#L#${locale}#CMS#SETTINGS`;\n};\n\nconst createSortKey = (): string => {\n return \"settings\";\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\nconst createKeys = (params: PartitionKeyParams): Keys => {\n return {\n PK: createPartitionKey(params),\n SK: createSortKey()\n };\n};\n\ninterface CreateSettingsStorageOperationsParams {\n entity: Entity<any>;\n}\n\nexport const createSettingsStorageOperations = (\n params: CreateSettingsStorageOperationsParams\n): CmsSettingsStorageOperations => {\n const { entity } = params;\n\n const create = async (params: CmsSettingsStorageOperationsCreateParams) => {\n const { settings } = params;\n const keys = createKeys(settings);\n\n const dbSettings: CmsSettingsDb = convertToDbData(settings);\n\n try {\n await entity.put({\n ...dbSettings,\n ...keys\n });\n return settings;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create settings.\",\n ex.code || \"CREATE_SETTINGS_ERROR\",\n {\n error: ex,\n settings,\n dbSettings,\n keys\n }\n );\n }\n };\n\n const update = async (params: CmsSettingsStorageOperationsUpdateParams) => {\n const { settings, original } = params;\n\n const keys = createKeys(settings);\n\n const dbSettings: CmsSettingsDb = convertToDbData(settings);\n\n try {\n await entity.put({\n ...dbSettings,\n ...keys\n });\n return settings;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update settings.\",\n ex.code || \"UPDATE_SETTINGS_ERROR\",\n {\n error: ex,\n settings,\n dbSettings,\n original,\n keys\n }\n );\n }\n };\n\n const get = async (params: CmsSettingsStorageOperationsGetParams) => {\n const keys = createKeys(params);\n try {\n const record = await getRecord<CmsSettingsDb>({\n entity,\n keys\n });\n if (!record) {\n return null;\n }\n const settings = cleanupItem(entity, record) as CmsSettingsDb;\n return convertFromDbData(settings);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get settings.\",\n ex.code || \"GET_SETTINGS_ERROR\",\n {\n error: ex,\n keys\n }\n );\n }\n };\n\n return {\n create,\n get,\n update\n };\n};\n"]}
1
+ {"version":3,"sources":["index.ts"],"names":["convertToDbData","settings","contentModelLastChange","toISOString","convertFromDbData","Date","createPartitionKey","tenant","locale","createSortKey","createKeys","params","PK","SK","createSettingsStorageOperations","entity","create","keys","dbSettings","put","ex","WebinyError","message","code","error","update","get","record"],"mappings":"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","sourcesContent":["import {\n CmsSettings,\n CmsSettingsStorageOperations,\n CmsSettingsStorageOperationsCreateParams,\n CmsSettingsStorageOperationsGetParams,\n CmsSettingsStorageOperationsUpdateParams\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport { get as getRecord } from \"@webiny/db-dynamodb/utils/get\";\nimport WebinyError from \"@webiny/error\";\nimport { cleanupItem } from \"@webiny/db-dynamodb/utils/cleanup\";\n\ninterface CmsSettingsDb extends Omit<CmsSettings, \"contentModelLastChange\"> {\n contentModelLastChange: string;\n}\n\nconst convertToDbData = (settings: CmsSettings): CmsSettingsDb => {\n return {\n ...settings,\n contentModelLastChange: settings.contentModelLastChange.toISOString()\n };\n};\n\nconst convertFromDbData = (settings?: CmsSettingsDb): CmsSettings | null => {\n if (!settings) {\n return null;\n }\n let contentModelLastChange;\n try {\n contentModelLastChange = new Date(settings.contentModelLastChange);\n } catch {\n contentModelLastChange = new Date();\n }\n return {\n ...settings,\n contentModelLastChange\n };\n};\n\ninterface PartitionKeyParams {\n tenant: string;\n locale: string;\n}\n\nconst createPartitionKey = ({ tenant, locale }: PartitionKeyParams): string => {\n return `T#${tenant}#L#${locale}#CMS#SETTINGS`;\n};\n\nconst createSortKey = (): string => {\n return \"settings\";\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\nconst createKeys = (params: PartitionKeyParams): Keys => {\n return {\n PK: createPartitionKey(params),\n SK: createSortKey()\n };\n};\n\ninterface CreateSettingsStorageOperationsParams {\n entity: Entity<any>;\n}\n\nexport const createSettingsStorageOperations = (\n params: CreateSettingsStorageOperationsParams\n): CmsSettingsStorageOperations => {\n const { entity } = params;\n\n const create = async (params: CmsSettingsStorageOperationsCreateParams) => {\n const { settings } = params;\n const keys = createKeys(settings);\n\n const dbSettings: CmsSettingsDb = convertToDbData(settings);\n\n try {\n await entity.put({\n ...dbSettings,\n ...keys\n });\n return settings;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create settings.\",\n ex.code || \"CREATE_SETTINGS_ERROR\",\n {\n error: ex,\n settings,\n dbSettings,\n keys\n }\n );\n }\n };\n\n const update = async (params: CmsSettingsStorageOperationsUpdateParams) => {\n const { settings } = params;\n\n const keys = createKeys(settings);\n\n const dbSettings: CmsSettingsDb = convertToDbData(settings);\n\n try {\n await entity.put({\n ...dbSettings,\n ...keys\n });\n return settings;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update settings.\",\n ex.code || \"UPDATE_SETTINGS_ERROR\",\n {\n error: ex,\n settings,\n dbSettings,\n keys\n }\n );\n }\n };\n\n const get = async (params: CmsSettingsStorageOperationsGetParams) => {\n const keys = createKeys(params);\n try {\n const record = await getRecord<CmsSettingsDb>({\n entity,\n keys\n });\n if (!record) {\n return null;\n }\n const settings = cleanupItem(entity, record) as CmsSettingsDb;\n return convertFromDbData(settings);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get settings.\",\n ex.code || \"GET_SETTINGS_ERROR\",\n {\n error: ex,\n keys\n }\n );\n }\n };\n\n return {\n create,\n get,\n update\n };\n};\n"]}
@@ -60,8 +60,7 @@ const createSystemStorageOperations = params => {
60
60
 
61
61
  const update = async params => {
62
62
  const {
63
- system,
64
- original
63
+ system
65
64
  } = params;
66
65
  const keys = createKeys(system);
67
66
 
@@ -72,7 +71,6 @@ const createSystemStorageOperations = params => {
72
71
  throw new _error.default(ex.message || "Could not update system.", ex.code || "UPDATE_SYSTEM_ERROR", {
73
72
  error: ex,
74
73
  system,
75
- original,
76
74
  keys
77
75
  });
78
76
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":["createPartitionKey","tenant","toLowerCase","createSortKey","createKeys","params","PK","SK","createSystemStorageOperations","entity","create","system","keys","put","ex","WebinyError","message","code","error","update","original","get"],"mappings":";;;;;;;;;;;AAQA;;AACA;;AACA;;;;;;AASA,MAAMA,kBAAkB,GAAG,CAAC;AAAEC,EAAAA;AAAF,CAAD,KAA4C;AACnE,SAAQ,KAAIA,MAAM,CAACC,WAAP,EAAqB,SAAjC;AACH,CAFD;;AAGA,MAAMC,aAAa,GAAG,MAAc;AAChC,SAAO,KAAP;AACH,CAFD;;AAQA,MAAMC,UAAU,GAAIC,MAAD,IAAsC;AACrD,SAAO;AACHC,IAAAA,EAAE,EAAEN,kBAAkB,CAACK,MAAD,CADnB;AAEHE,IAAAA,EAAE,EAAEJ,aAAa;AAFd,GAAP;AAIH,CALD;;AAOO,MAAMK,6BAA6B,GACtCH,MADyC,IAEZ;AAC7B,QAAM;AAAEI,IAAAA;AAAF,MAAaJ,MAAnB;;AAEA,QAAMK,MAAM,GAAG,OAAO;AAAEC,IAAAA;AAAF,GAAP,KAA8D;AACzE,UAAMC,IAAI,GAAGR,UAAU,CAACO,MAAD,CAAvB;;AACA,QAAI;AACA,YAAMF,MAAM,CAACI,GAAP,iCACCF,MADD,GAECC,IAFD,EAAN;AAIA,aAAOD,MAAP;AACH,KAND,CAME,OAAOG,EAAP,EAAW;AACT,YAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,0BADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,qBAFT,EAGF;AACIC,QAAAA,KAAK,EAAEJ,EADX;AAEIH,QAAAA,MAFJ;AAGIC,QAAAA;AAHJ,OAHE,CAAN;AASH;AACJ,GAnBD;;AAqBA,QAAMO,MAAM,GAAG,MAAOd,MAAP,IAA0D;AACrE,UAAM;AAAEM,MAAAA,MAAF;AAAUS,MAAAA;AAAV,QAAuBf,MAA7B;AAEA,UAAMO,IAAI,GAAGR,UAAU,CAACO,MAAD,CAAvB;;AAEA,QAAI;AACA,YAAMF,MAAM,CAACI,GAAP,iCACCF,MADD,GAECC,IAFD,EAAN;AAIA,aAAOD,MAAP;AACH,KAND,CAME,OAAOG,EAAP,EAAW;AACT,YAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,0BADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,qBAFT,EAGF;AACIC,QAAAA,KAAK,EAAEJ,EADX;AAEIH,QAAAA,MAFJ;AAGIS,QAAAA,QAHJ;AAIIR,QAAAA;AAJJ,OAHE,CAAN;AAUH;AACJ,GAvBD;;AAyBA,QAAMS,GAAG,GAAG,MAAOhB,MAAP,IAAuD;AAC/D,UAAMO,IAAI,GAAGR,UAAU,CAACC,MAAD,CAAvB;;AAEA,QAAI;AACA,YAAMM,MAAM,GAAG,MAAM,cAAqB;AACtCF,QAAAA,MADsC;AAEtCG,QAAAA;AAFsC,OAArB,CAArB;AAIA,aAAO,0BAAYH,MAAZ,EAAoBE,MAApB,CAAP;AACH,KAND,CAME,OAAOG,EAAP,EAAW;AACT,YAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,uBADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,kBAFT,EAGF;AACIC,QAAAA,KAAK,EAAEJ,EADX;AAEIF,QAAAA;AAFJ,OAHE,CAAN;AAQH;AACJ,GAnBD;;AAqBA,SAAO;AACHF,IAAAA,MADG;AAEHS,IAAAA,MAFG;AAGHE,IAAAA;AAHG,GAAP;AAKH,CA7EM","sourcesContent":["import {\n CmsSystem,\n CmsSystemStorageOperations,\n CmsSystemStorageOperationsCreateParams,\n CmsSystemStorageOperationsGetParams,\n CmsSystemStorageOperationsUpdateParams\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\";\n\ninterface CreateSystemStorageOperationsParams {\n entity: Entity<any>;\n}\n\ninterface PartitionKeyParams {\n tenant: string;\n}\nconst createPartitionKey = ({ tenant }: PartitionKeyParams): string => {\n return `T#${tenant.toLowerCase()}#SYSTEM`;\n};\nconst createSortKey = (): string => {\n return \"CMS\";\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\nconst createKeys = (params: PartitionKeyParams): Keys => {\n return {\n PK: createPartitionKey(params),\n SK: createSortKey()\n };\n};\n\nexport const createSystemStorageOperations = (\n params: CreateSystemStorageOperationsParams\n): CmsSystemStorageOperations => {\n const { entity } = params;\n\n const create = async ({ system }: CmsSystemStorageOperationsCreateParams) => {\n const keys = createKeys(system);\n try {\n await entity.put({\n ...system,\n ...keys\n });\n return system;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create system.\",\n ex.code || \"CREATE_SYSTEM_ERROR\",\n {\n error: ex,\n system,\n keys\n }\n );\n }\n };\n\n const update = async (params: CmsSystemStorageOperationsUpdateParams) => {\n const { system, original } = params;\n\n const keys = createKeys(system);\n\n try {\n await entity.put({\n ...system,\n ...keys\n });\n return system;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update system.\",\n ex.code || \"UPDATE_SYSTEM_ERROR\",\n {\n error: ex,\n system,\n original,\n keys\n }\n );\n }\n };\n\n const get = async (params: CmsSystemStorageOperationsGetParams) => {\n const keys = createKeys(params);\n\n try {\n const system = await getRecord<CmsSystem>({\n entity,\n keys\n });\n return cleanupItem(entity, system);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get system.\",\n ex.code || \"GET_SYSTEM_ERROR\",\n {\n error: ex,\n keys\n }\n );\n }\n };\n\n return {\n create,\n update,\n get\n };\n};\n"]}
1
+ {"version":3,"sources":["index.ts"],"names":["createPartitionKey","tenant","toLowerCase","createSortKey","createKeys","params","PK","SK","createSystemStorageOperations","entity","create","system","keys","put","ex","WebinyError","message","code","error","update","get"],"mappings":";;;;;;;;;;;AAQA;;AACA;;AACA;;;;;;AASA,MAAMA,kBAAkB,GAAG,CAAC;AAAEC,EAAAA;AAAF,CAAD,KAA4C;AACnE,SAAQ,KAAIA,MAAM,CAACC,WAAP,EAAqB,SAAjC;AACH,CAFD;;AAGA,MAAMC,aAAa,GAAG,MAAc;AAChC,SAAO,KAAP;AACH,CAFD;;AAQA,MAAMC,UAAU,GAAIC,MAAD,IAAsC;AACrD,SAAO;AACHC,IAAAA,EAAE,EAAEN,kBAAkB,CAACK,MAAD,CADnB;AAEHE,IAAAA,EAAE,EAAEJ,aAAa;AAFd,GAAP;AAIH,CALD;;AAOO,MAAMK,6BAA6B,GACtCH,MADyC,IAEZ;AAC7B,QAAM;AAAEI,IAAAA;AAAF,MAAaJ,MAAnB;;AAEA,QAAMK,MAAM,GAAG,OAAO;AAAEC,IAAAA;AAAF,GAAP,KAA8D;AACzE,UAAMC,IAAI,GAAGR,UAAU,CAACO,MAAD,CAAvB;;AACA,QAAI;AACA,YAAMF,MAAM,CAACI,GAAP,iCACCF,MADD,GAECC,IAFD,EAAN;AAIA,aAAOD,MAAP;AACH,KAND,CAME,OAAOG,EAAP,EAAW;AACT,YAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,0BADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,qBAFT,EAGF;AACIC,QAAAA,KAAK,EAAEJ,EADX;AAEIH,QAAAA,MAFJ;AAGIC,QAAAA;AAHJ,OAHE,CAAN;AASH;AACJ,GAnBD;;AAqBA,QAAMO,MAAM,GAAG,MAAOd,MAAP,IAA0D;AACrE,UAAM;AAAEM,MAAAA;AAAF,QAAaN,MAAnB;AAEA,UAAMO,IAAI,GAAGR,UAAU,CAACO,MAAD,CAAvB;;AAEA,QAAI;AACA,YAAMF,MAAM,CAACI,GAAP,iCACCF,MADD,GAECC,IAFD,EAAN;AAIA,aAAOD,MAAP;AACH,KAND,CAME,OAAOG,EAAP,EAAW;AACT,YAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,0BADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,qBAFT,EAGF;AACIC,QAAAA,KAAK,EAAEJ,EADX;AAEIH,QAAAA,MAFJ;AAGIC,QAAAA;AAHJ,OAHE,CAAN;AASH;AACJ,GAtBD;;AAwBA,QAAMQ,GAAG,GAAG,MAAOf,MAAP,IAAuD;AAC/D,UAAMO,IAAI,GAAGR,UAAU,CAACC,MAAD,CAAvB;;AAEA,QAAI;AACA,YAAMM,MAAM,GAAG,MAAM,cAAqB;AACtCF,QAAAA,MADsC;AAEtCG,QAAAA;AAFsC,OAArB,CAArB;AAIA,aAAO,0BAAYH,MAAZ,EAAoBE,MAApB,CAAP;AACH,KAND,CAME,OAAOG,EAAP,EAAW;AACT,YAAM,IAAIC,cAAJ,CACFD,EAAE,CAACE,OAAH,IAAc,uBADZ,EAEFF,EAAE,CAACG,IAAH,IAAW,kBAFT,EAGF;AACIC,QAAAA,KAAK,EAAEJ,EADX;AAEIF,QAAAA;AAFJ,OAHE,CAAN;AAQH;AACJ,GAnBD;;AAqBA,SAAO;AACHF,IAAAA,MADG;AAEHS,IAAAA,MAFG;AAGHC,IAAAA;AAHG,GAAP;AAKH,CA5EM","sourcesContent":["import {\n CmsSystem,\n CmsSystemStorageOperations,\n CmsSystemStorageOperationsCreateParams,\n CmsSystemStorageOperationsGetParams,\n CmsSystemStorageOperationsUpdateParams\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\";\n\ninterface CreateSystemStorageOperationsParams {\n entity: Entity<any>;\n}\n\ninterface PartitionKeyParams {\n tenant: string;\n}\nconst createPartitionKey = ({ tenant }: PartitionKeyParams): string => {\n return `T#${tenant.toLowerCase()}#SYSTEM`;\n};\nconst createSortKey = (): string => {\n return \"CMS\";\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\nconst createKeys = (params: PartitionKeyParams): Keys => {\n return {\n PK: createPartitionKey(params),\n SK: createSortKey()\n };\n};\n\nexport const createSystemStorageOperations = (\n params: CreateSystemStorageOperationsParams\n): CmsSystemStorageOperations => {\n const { entity } = params;\n\n const create = async ({ system }: CmsSystemStorageOperationsCreateParams) => {\n const keys = createKeys(system);\n try {\n await entity.put({\n ...system,\n ...keys\n });\n return system;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create system.\",\n ex.code || \"CREATE_SYSTEM_ERROR\",\n {\n error: ex,\n system,\n keys\n }\n );\n }\n };\n\n const update = async (params: CmsSystemStorageOperationsUpdateParams) => {\n const { system } = params;\n\n const keys = createKeys(system);\n\n try {\n await entity.put({\n ...system,\n ...keys\n });\n return system;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update system.\",\n ex.code || \"UPDATE_SYSTEM_ERROR\",\n {\n error: ex,\n system,\n keys\n }\n );\n }\n };\n\n const get = async (params: CmsSystemStorageOperationsGetParams) => {\n const keys = createKeys(params);\n\n try {\n const system = await getRecord<CmsSystem>({\n entity,\n keys\n });\n return cleanupItem(entity, system);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get system.\",\n ex.code || \"GET_SYSTEM_ERROR\",\n {\n error: ex,\n keys\n }\n );\n }\n };\n\n return {\n create,\n update,\n get\n };\n};\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webiny/api-headless-cms-ddb",
3
- "version": "5.25.0-beta.6",
3
+ "version": "5.25.1-beta.1",
4
4
  "main": "index.js",
5
5
  "keywords": [
6
6
  "@webiny/api-headless-cms",
@@ -21,13 +21,13 @@
21
21
  ],
22
22
  "license": "MIT",
23
23
  "dependencies": {
24
- "@babel/runtime": "7.17.7",
25
- "@webiny/api-headless-cms": "5.25.0-beta.6",
26
- "@webiny/db-dynamodb": "5.25.0-beta.6",
27
- "@webiny/error": "5.25.0-beta.6",
28
- "@webiny/handler-db": "5.25.0-beta.6",
29
- "@webiny/utils": "5.25.0-beta.6",
30
- "aws-sdk": "2.1095.0",
24
+ "@babel/runtime": "7.16.7",
25
+ "@webiny/api-headless-cms": "5.25.1-beta.1",
26
+ "@webiny/db-dynamodb": "5.25.1-beta.1",
27
+ "@webiny/error": "5.25.1-beta.1",
28
+ "@webiny/handler-db": "5.25.1-beta.1",
29
+ "@webiny/utils": "5.25.1-beta.1",
30
+ "aws-sdk": "2.1066.0",
31
31
  "dataloader": "2.0.0",
32
32
  "dot-prop": "5.3.0",
33
33
  "dynamodb-toolbox": "0.3.5",
@@ -40,9 +40,9 @@
40
40
  "@babel/preset-env": "^7.16.4",
41
41
  "@babel/preset-flow": "^7.16.0",
42
42
  "@types/jsonpack": "^1.1.0",
43
- "@webiny/cli": "^5.25.0-beta.6",
44
- "@webiny/plugins": "^5.25.0-beta.6",
45
- "@webiny/project-utils": "^5.25.0-beta.6",
43
+ "@webiny/cli": "^5.25.1-beta.1",
44
+ "@webiny/plugins": "^5.25.1-beta.1",
45
+ "@webiny/project-utils": "^5.25.1-beta.1",
46
46
  "jest": "^26.6.3",
47
47
  "jest-dynalite": "^3.2.0",
48
48
  "jest-environment-node": "^26.6.2",
@@ -57,5 +57,5 @@
57
57
  "build": "yarn webiny run build",
58
58
  "watch": "yarn webiny run watch"
59
59
  },
60
- "gitHead": "a208508363613ea3cb7540d18bb9b2f2250a8466"
60
+ "gitHead": "aeeff2c4da36d72638831e85f3fa1f815e9abb3e"
61
61
  }