@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 +10 -8
- package/index.js.map +1 -1
- package/operations/entry/index.js +29 -33
- package/operations/entry/index.js.map +1 -1
- package/operations/entry/utils.d.ts +4 -0
- package/operations/entry/utils.js +81 -5
- package/operations/entry/utils.js.map +1 -1
- package/operations/group/index.js +1 -3
- package/operations/group/index.js.map +1 -1
- package/operations/model/index.js +0 -2
- package/operations/model/index.js.map +1 -1
- package/operations/settings/index.js +1 -3
- package/operations/settings/index.js.map +1 -1
- package/operations/system/index.js +1 -3
- package/operations/system/index.js.map +1 -1
- package/package.json +12 -12
package/index.js
CHANGED
|
@@ -42,7 +42,7 @@ const createStorageOperations = params => {
|
|
|
42
42
|
attributes,
|
|
43
43
|
table,
|
|
44
44
|
documentClient,
|
|
45
|
-
plugins:
|
|
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
|
-
...(
|
|
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
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
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","
|
|
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)(
|
|
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)(
|
|
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
|
-
|
|
287
|
-
|
|
288
|
-
|
|
282
|
+
entry,
|
|
283
|
+
latestEntry,
|
|
284
|
+
latestStorageEntry
|
|
289
285
|
} = params;
|
|
290
|
-
const partitionKey = (0, _keys.createPartitionKey)(
|
|
286
|
+
const partitionKey = (0, _keys.createPartitionKey)(entry);
|
|
291
287
|
const items = [entity.deleteBatch({
|
|
292
288
|
PK: partitionKey,
|
|
293
|
-
SK: (0, _keys.createRevisionSortKey)(
|
|
289
|
+
SK: (0, _keys.createRevisionSortKey)(entry)
|
|
294
290
|
})];
|
|
295
|
-
const publishedStorageEntry = await getPublishedRevisionByEntryId(model,
|
|
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 &&
|
|
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 (
|
|
308
|
-
items.push(entity.putBatch(_objectSpread(_objectSpread({},
|
|
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)(
|
|
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
|
-
|
|
329
|
-
|
|
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:
|
|
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 =
|
|
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({},
|
|
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
|
|
182
|
+
value,
|
|
171
183
|
field: field.def
|
|
172
184
|
};
|
|
173
185
|
|
|
174
186
|
if (isObjectFiltering(objectFilteringParams)) {
|
|
175
|
-
const propertyFilters = Object.keys(
|
|
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(
|
|
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(
|
|
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","
|
|
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","
|
|
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","
|
|
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.
|
|
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.
|
|
25
|
-
"@webiny/api-headless-cms": "5.25.
|
|
26
|
-
"@webiny/db-dynamodb": "5.25.
|
|
27
|
-
"@webiny/error": "5.25.
|
|
28
|
-
"@webiny/handler-db": "5.25.
|
|
29
|
-
"@webiny/utils": "5.25.
|
|
30
|
-
"aws-sdk": "2.
|
|
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.
|
|
44
|
-
"@webiny/plugins": "^5.25.
|
|
45
|
-
"@webiny/project-utils": "^5.25.
|
|
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": "
|
|
60
|
+
"gitHead": "aeeff2c4da36d72638831e85f3fa1f815e9abb3e"
|
|
61
61
|
}
|