@webiny/api-headless-cms-ddb-es 5.36.2 → 5.37.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/configurations.js.map +1 -1
- package/definitions/entry.js +3 -0
- package/definitions/entry.js.map +1 -1
- package/definitions/entryElasticsearch.js.map +1 -1
- package/definitions/group.js.map +1 -1
- package/definitions/model.js.map +1 -1
- package/definitions/settings.js.map +1 -1
- package/definitions/system.js.map +1 -1
- package/definitions/table.js.map +1 -1
- package/definitions/tableElasticsearch.js.map +1 -1
- package/dynamoDb/index.js.map +1 -1
- package/dynamoDb/storage/date.js +1 -10
- package/dynamoDb/storage/date.js.map +1 -1
- package/dynamoDb/storage/longText.js.map +1 -1
- package/dynamoDb/storage/richText.js +1 -7
- package/dynamoDb/storage/richText.js.map +1 -1
- package/elasticsearch/createElasticsearchIndex.js.map +1 -1
- package/elasticsearch/deleteElasticsearchIndex.js.map +1 -1
- package/elasticsearch/index.js.map +1 -1
- package/elasticsearch/indexing/dateTimeIndexing.js +4 -2
- package/elasticsearch/indexing/dateTimeIndexing.js.map +1 -1
- package/elasticsearch/indexing/defaultFieldIndexing.js.map +1 -1
- package/elasticsearch/indexing/index.js.map +1 -1
- package/elasticsearch/indexing/longTextIndexing.js.map +1 -1
- package/elasticsearch/indexing/numberIndexing.js.map +1 -1
- package/elasticsearch/indexing/objectIndexing.js +1 -1
- package/elasticsearch/indexing/objectIndexing.js.map +1 -1
- package/elasticsearch/indexing/richTextIndexing.js.map +1 -1
- package/elasticsearch/indices/base.js.map +1 -1
- package/elasticsearch/indices/index.js.map +1 -1
- package/elasticsearch/indices/japanese.js.map +1 -1
- package/elasticsearch/search/index.js.map +1 -1
- package/elasticsearch/search/refSearch.js.map +1 -1
- package/elasticsearch/search/timeSearch.js.map +1 -1
- package/helpers/entryIndexHelpers.js.map +1 -1
- package/helpers/fieldIdentifier.d.ts +2 -2
- package/helpers/fieldIdentifier.js +4 -2
- package/helpers/fieldIdentifier.js.map +1 -1
- package/helpers/index.js.map +1 -1
- package/index.js.map +1 -1
- package/operations/entry/dataLoader/DataLoaderCache.js.map +1 -1
- package/operations/entry/dataLoader/constants.js.map +1 -1
- package/operations/entry/dataLoader/createBatchScheduleFn.js.map +1 -1
- package/operations/entry/dataLoader/getAllEntryRevisions.js.map +1 -1
- package/operations/entry/dataLoader/getLatestRevisionByEntryId.js.map +1 -1
- package/operations/entry/dataLoader/getPublishedRevisionByEntryId.js.map +1 -1
- package/operations/entry/dataLoader/getRevisionById.js.map +1 -1
- package/operations/entry/dataLoader/index.js.map +1 -1
- package/operations/entry/dataLoaders.js.map +1 -1
- package/operations/entry/elasticsearch/assignMinimumShouldMatchToQuery.js.map +1 -1
- package/operations/entry/elasticsearch/body.js.map +1 -1
- package/operations/entry/elasticsearch/fields.js +39 -0
- package/operations/entry/elasticsearch/fields.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/applyFiltering.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/exec.js +1 -1
- package/operations/entry/elasticsearch/filtering/exec.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/index.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/path.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/plugins/defaultFilterPlugin.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/plugins/index.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/plugins/objectFilterPlugin.js +3 -1
- package/operations/entry/elasticsearch/filtering/plugins/objectFilterPlugin.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/plugins/refFilterPlugin.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/populated.js.map +1 -1
- package/operations/entry/elasticsearch/filtering/values.js.map +1 -1
- package/operations/entry/elasticsearch/fullTextSearch.js.map +1 -1
- package/operations/entry/elasticsearch/fullTextSearchFields.js.map +1 -1
- package/operations/entry/elasticsearch/initialQuery.js.map +1 -1
- package/operations/entry/elasticsearch/keyword.js.map +1 -1
- package/operations/entry/elasticsearch/plugins/bodyModifier.js.map +1 -1
- package/operations/entry/elasticsearch/plugins/operator.js.map +1 -1
- package/operations/entry/elasticsearch/plugins/queryModifier.js.map +1 -1
- package/operations/entry/elasticsearch/plugins/search.js.map +1 -1
- package/operations/entry/elasticsearch/plugins/sortModifier.js.map +1 -1
- package/operations/entry/elasticsearch/sort.js.map +1 -1
- package/operations/entry/elasticsearch/transformValueForSearch.js.map +1 -1
- package/operations/entry/index.js +121 -6
- package/operations/entry/index.js.map +1 -1
- package/operations/entry/keys.js.map +1 -1
- package/operations/entry/recordType.js.map +1 -1
- package/operations/group/index.js.map +1 -1
- package/operations/model/index.js.map +1 -1
- package/operations/settings/index.js.map +1 -1
- package/operations/system/index.js.map +1 -1
- package/package.json +25 -28
- package/plugins/CmsElasticsearchModelFieldPlugin.js +9 -3
- package/plugins/CmsElasticsearchModelFieldPlugin.js.map +1 -1
- package/plugins/CmsEntryElasticsearchBodyModifierPlugin.js.map +1 -1
- package/plugins/CmsEntryElasticsearchFullTextSearchPlugin.js.map +1 -1
- package/plugins/CmsEntryElasticsearchIndexPlugin.js.map +1 -1
- package/plugins/CmsEntryElasticsearchQueryBuilderValueSearchPlugin.js.map +1 -1
- package/plugins/CmsEntryElasticsearchQueryModifierPlugin.js.map +1 -1
- package/plugins/CmsEntryElasticsearchSortModifierPlugin.js.map +1 -1
- package/plugins/CmsEntryFilterPlugin.js.map +1 -1
- package/plugins/index.js.map +1 -1
- package/types.js +4 -4
- package/types.js.map +1 -1
|
@@ -22,6 +22,7 @@ var _cleanup = require("@webiny/db-dynamodb/utils/cleanup");
|
|
|
22
22
|
var _body = require("./elasticsearch/body");
|
|
23
23
|
var _recordType = require("./recordType");
|
|
24
24
|
var _apiHeadlessCms = require("@webiny/api-headless-cms");
|
|
25
|
+
var _dbDynamodb = require("@webiny/db-dynamodb");
|
|
25
26
|
const getEntryData = input => {
|
|
26
27
|
const output = (0, _objectSpread2.default)({}, input);
|
|
27
28
|
delete output["PK"];
|
|
@@ -452,6 +453,115 @@ const createEntriesStorageOperations = params => {
|
|
|
452
453
|
}
|
|
453
454
|
return initialStorageEntry;
|
|
454
455
|
};
|
|
456
|
+
const move = async (initialModel, id, folderId) => {
|
|
457
|
+
const model = getStorageOperationsModel(initialModel);
|
|
458
|
+
const partitionKey = (0, _keys.createPartitionKey)({
|
|
459
|
+
id,
|
|
460
|
+
locale: model.locale,
|
|
461
|
+
tenant: model.tenant
|
|
462
|
+
});
|
|
463
|
+
/**
|
|
464
|
+
* First we need to fetch all the records in the regular DynamoDB table.
|
|
465
|
+
*/
|
|
466
|
+
const queryAllParams = {
|
|
467
|
+
entity,
|
|
468
|
+
partitionKey,
|
|
469
|
+
options: {
|
|
470
|
+
gte: " "
|
|
471
|
+
}
|
|
472
|
+
};
|
|
473
|
+
const latestSortKey = (0, _keys.createLatestSortKey)();
|
|
474
|
+
const publishedSortKey = (0, _keys.createPublishedSortKey)();
|
|
475
|
+
const records = await (0, _query.queryAll)(queryAllParams);
|
|
476
|
+
/**
|
|
477
|
+
* Then update the folderId in each record and prepare it to be stored.
|
|
478
|
+
*/
|
|
479
|
+
let latestRecord = undefined;
|
|
480
|
+
let publishedRecord = undefined;
|
|
481
|
+
const items = [];
|
|
482
|
+
for (const record of records) {
|
|
483
|
+
items.push(entity.putBatch((0, _objectSpread2.default)((0, _objectSpread2.default)({}, record), {}, {
|
|
484
|
+
location: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, record === null || record === void 0 ? void 0 : record.location), {}, {
|
|
485
|
+
folderId
|
|
486
|
+
})
|
|
487
|
+
})));
|
|
488
|
+
/**
|
|
489
|
+
* We need to get the published and latest records, so we can update the Elasticsearch.
|
|
490
|
+
*/
|
|
491
|
+
if (record.SK === publishedSortKey) {
|
|
492
|
+
publishedRecord = record;
|
|
493
|
+
} else if (record.SK === latestSortKey) {
|
|
494
|
+
latestRecord = record;
|
|
495
|
+
}
|
|
496
|
+
}
|
|
497
|
+
try {
|
|
498
|
+
await (0, _batchWrite.batchWriteAll)({
|
|
499
|
+
table: entity.table,
|
|
500
|
+
items
|
|
501
|
+
});
|
|
502
|
+
dataLoaders.clearAll({
|
|
503
|
+
model
|
|
504
|
+
});
|
|
505
|
+
} catch (ex) {
|
|
506
|
+
throw new _error.default(ex.message || "Could not move all entry records from in the DynamoDB table.", ex.code || "MOVE_ENTRY_ERROR", {
|
|
507
|
+
error: ex,
|
|
508
|
+
id
|
|
509
|
+
});
|
|
510
|
+
}
|
|
511
|
+
const esGetItems = [];
|
|
512
|
+
if (publishedRecord) {
|
|
513
|
+
esGetItems.push(esEntity.getBatch({
|
|
514
|
+
PK: partitionKey,
|
|
515
|
+
SK: publishedSortKey
|
|
516
|
+
}));
|
|
517
|
+
}
|
|
518
|
+
if (latestRecord) {
|
|
519
|
+
esGetItems.push(esEntity.getBatch({
|
|
520
|
+
PK: partitionKey,
|
|
521
|
+
SK: latestSortKey
|
|
522
|
+
}));
|
|
523
|
+
}
|
|
524
|
+
if (esGetItems.length === 0) {
|
|
525
|
+
return;
|
|
526
|
+
}
|
|
527
|
+
const esRecords = await (0, _dbDynamodb.batchReadAll)({
|
|
528
|
+
table: esEntity.table,
|
|
529
|
+
items: esGetItems
|
|
530
|
+
});
|
|
531
|
+
const esItems = (await Promise.all(esRecords.map(async record => {
|
|
532
|
+
if (!record) {
|
|
533
|
+
return null;
|
|
534
|
+
}
|
|
535
|
+
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, record), {}, {
|
|
536
|
+
data: await (0, _apiElasticsearch.decompress)(plugins, record.data)
|
|
537
|
+
});
|
|
538
|
+
}))).filter(Boolean);
|
|
539
|
+
if (esItems.length === 0) {
|
|
540
|
+
return;
|
|
541
|
+
}
|
|
542
|
+
const esUpdateItems = [];
|
|
543
|
+
for (const item of esItems) {
|
|
544
|
+
var _item$data;
|
|
545
|
+
esUpdateItems.push(esEntity.putBatch((0, _objectSpread2.default)((0, _objectSpread2.default)({}, item), {}, {
|
|
546
|
+
data: await (0, _apiElasticsearch.compress)(plugins, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, item.data), {}, {
|
|
547
|
+
location: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, (_item$data = item.data) === null || _item$data === void 0 ? void 0 : _item$data.location), {}, {
|
|
548
|
+
folderId
|
|
549
|
+
})
|
|
550
|
+
}))
|
|
551
|
+
})));
|
|
552
|
+
}
|
|
553
|
+
try {
|
|
554
|
+
await (0, _batchWrite.batchWriteAll)({
|
|
555
|
+
table: esEntity.table,
|
|
556
|
+
items: esUpdateItems
|
|
557
|
+
});
|
|
558
|
+
} catch (ex) {
|
|
559
|
+
throw new _error.default(ex.message || "Could not move entry DynamoDB Elasticsearch records.", ex.code || "MOVE_ES_ENTRY_ERROR", {
|
|
560
|
+
error: ex,
|
|
561
|
+
partitionKey
|
|
562
|
+
});
|
|
563
|
+
}
|
|
564
|
+
};
|
|
455
565
|
const deleteEntry = async (initialModel, params) => {
|
|
456
566
|
const {
|
|
457
567
|
entry
|
|
@@ -703,7 +813,7 @@ const createEntriesStorageOperations = params => {
|
|
|
703
813
|
});
|
|
704
814
|
};
|
|
705
815
|
const list = async (initialModel, params) => {
|
|
706
|
-
var _response
|
|
816
|
+
var _response;
|
|
707
817
|
const model = getStorageOperationsModel(initialModel);
|
|
708
818
|
const limit = (0, _apiElasticsearch.createLimit)(params.limit, 50);
|
|
709
819
|
const {
|
|
@@ -754,7 +864,7 @@ const createEntriesStorageOperations = params => {
|
|
|
754
864
|
const {
|
|
755
865
|
hits,
|
|
756
866
|
total
|
|
757
|
-
} = ((_response = response) === null || _response === void 0
|
|
867
|
+
} = ((_response = response) === null || _response === void 0 || (_response = _response.body) === null || _response === void 0 ? void 0 : _response.hits) || {};
|
|
758
868
|
const items = (0, _helpers.extractEntriesFromIndex)({
|
|
759
869
|
plugins,
|
|
760
870
|
model,
|
|
@@ -1218,6 +1328,7 @@ const createEntriesStorageOperations = params => {
|
|
|
1218
1328
|
}
|
|
1219
1329
|
};
|
|
1220
1330
|
const getUniqueFieldValues = async (model, params) => {
|
|
1331
|
+
var _response$body$aggreg;
|
|
1221
1332
|
const {
|
|
1222
1333
|
where,
|
|
1223
1334
|
fieldId
|
|
@@ -1282,15 +1393,19 @@ const createEntriesStorageOperations = params => {
|
|
|
1282
1393
|
body
|
|
1283
1394
|
});
|
|
1284
1395
|
}
|
|
1285
|
-
const
|
|
1286
|
-
|
|
1287
|
-
|
|
1288
|
-
|
|
1396
|
+
const buckets = ((_response$body$aggreg = response.body.aggregations["getUniqueFieldValues"]) === null || _response$body$aggreg === void 0 ? void 0 : _response$body$aggreg.buckets) || [];
|
|
1397
|
+
return buckets.map(file => {
|
|
1398
|
+
return {
|
|
1399
|
+
value: file.key,
|
|
1400
|
+
count: file.doc_count
|
|
1401
|
+
};
|
|
1402
|
+
});
|
|
1289
1403
|
};
|
|
1290
1404
|
return {
|
|
1291
1405
|
create,
|
|
1292
1406
|
createRevisionFrom,
|
|
1293
1407
|
update,
|
|
1408
|
+
move,
|
|
1294
1409
|
delete: deleteEntry,
|
|
1295
1410
|
deleteRevision,
|
|
1296
1411
|
deleteMultipleEntries,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["getEntryData","input","output","getESLatestEntryData","plugins","entry","compress","latest","TYPE","createLatestRecordType","__type","getESPublishedEntryData","published","createPublishedRecordType","convertEntryKeysToStorage","params","model","values","convertValueKeyToStorage","fields","convertEntryKeysFromStorage","convertValueKeyFromStorage","createEntriesStorageOperations","entity","esEntity","elasticsearch","storageOperationsCmsModelPlugin","getStorageOperationsCmsModelPlugin","oneByType","StorageOperationsCmsModelPlugin","type","getStorageOperationsModel","plugin","getModel","dataLoaders","DataLoadersHandler","create","initialModel","initialEntry","storageEntry","initialStorageEntry","isPublished","status","locked","esEntry","prepareEntryToIndex","lodashCloneDeep","index","esIndex","configurations","es","esLatestData","esPublishedData","revisionKeys","PK","createPartitionKey","id","locale","tenant","SK","createRevisionSortKey","latestKeys","createLatestSortKey","publishedKeys","createPublishedSortKey","items","putBatch","createRecordType","push","batchWriteAll","table","clearAll","ex","WebinyError","message","code","error","esItems","data","createRevisionFrom","put","update","latestStorageEntry","getLatestRevisionByEntryId","ids","publishedStorageEntry","getPublishedRevisionByEntryId","undefined","elasticsearchLatestData","elasticsearchPublishedData","length","deleteEntry","entryId","partitionKey","queryAll","options","gte","deleteItems","map","item","deleteBatch","deleteEsItems","deleteRevision","latestEntry","deleteMultipleEntries","entries","revisions","getAllEntryRevisions","revision","version","list","limit","createLimit","result","indices","exists","body","hasMoreItems","totalCount","cursor","createElasticsearchBody","after","decodeCursor","response","search","hits","total","extractEntriesFromIndex","_source","pop","encodeCursor","sort","value","get","shift","publish","latestEsEntry","getRecord","keys","previouslyPublishedEntry","getRevisionById","CONTENT_ENTRY_STATUS","UNPUBLISHED","savedOn","latestEsEntryDataDecompressed","decompress","PUBLISHED","publishedOn","preparedEntryData","unpublish","getRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","queryParams","lt","zeroPad","filters","attr","eq","reverse","queryOne","cleanupItem","getUniqueFieldValues","where","fieldId","initialBody","field","find","f","size","aggregations","terms","storageId","buckets","key","delete"],"sources":["index.ts"],"sourcesContent":["import lodashCloneDeep from \"lodash/cloneDeep\";\nimport WebinyError from \"@webiny/error\";\nimport {\n CmsEntry,\n CmsModel,\n CmsStorageEntry,\n CONTENT_ENTRY_STATUS,\n StorageOperationsCmsModel\n} from \"@webiny/api-headless-cms/types\";\nimport { extractEntriesFromIndex, prepareEntryToIndex } from \"~/helpers\";\nimport { configurations } from \"~/configurations\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport { Client } from \"@elastic/elasticsearch\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { batchWriteAll } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport { DataLoadersHandler } from \"~/operations/entry/dataLoaders\";\nimport {\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys\";\nimport { queryAll, queryOne, QueryOneParams } from \"@webiny/db-dynamodb/utils/query\";\nimport {\n compress,\n createLimit,\n decodeCursor,\n decompress,\n encodeCursor\n} from \"@webiny/api-elasticsearch\";\nimport { get as getRecord } from \"@webiny/db-dynamodb/utils/get\";\nimport { zeroPad } from \"@webiny/utils\";\nimport { cleanupItem } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport {\n ElasticsearchSearchResponse,\n SearchBody as ElasticsearchSearchBody\n} from \"@webiny/api-elasticsearch/types\";\nimport { CmsEntryStorageOperations, CmsIndexEntry } from \"~/types\";\nimport { createElasticsearchBody } from \"~/operations/entry/elasticsearch/body\";\nimport { createLatestRecordType, createPublishedRecordType, createRecordType } from \"./recordType\";\nimport { StorageOperationsCmsModelPlugin } from \"@webiny/api-headless-cms\";\nimport { DocumentClient } from \"aws-sdk/clients/dynamodb\";\n\nconst getEntryData = (input: CmsEntry): CmsEntry => {\n const output: any = {\n ...input\n };\n delete output[\"PK\"];\n delete output[\"SK\"];\n delete output[\"published\"];\n delete output[\"latest\"];\n\n return output;\n};\n\nconst getESLatestEntryData = async (plugins: PluginsContainer, entry: CmsEntry) => {\n return compress(plugins, {\n ...getEntryData(entry),\n latest: true,\n TYPE: createLatestRecordType(),\n __type: createLatestRecordType()\n });\n};\n\nconst getESPublishedEntryData = async (plugins: PluginsContainer, entry: CmsEntry) => {\n return compress(plugins, {\n ...getEntryData(entry),\n published: true,\n TYPE: createPublishedRecordType(),\n __type: createPublishedRecordType()\n });\n};\n\ninterface ConvertStorageEntryParams {\n entry: CmsStorageEntry;\n model: StorageOperationsCmsModel;\n}\nconst convertEntryKeysToStorage = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, entry } = params;\n\n const values = model.convertValueKeyToStorage({\n fields: model.fields,\n values: entry.values\n });\n return {\n ...entry,\n values\n };\n};\n\nconst convertEntryKeysFromStorage = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, entry } = params;\n\n const values = model.convertValueKeyFromStorage({\n fields: model.fields,\n values: entry.values\n });\n return {\n ...entry,\n values\n };\n};\n\ninterface ElasticsearchDbRecord {\n index: string;\n data: Record<string, string>;\n}\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: Entity<any>;\n esEntity: Entity<any>;\n elasticsearch: Client;\n plugins: PluginsContainer;\n}\nexport const createEntriesStorageOperations = (\n params: CreateEntriesStorageOperationsParams\n): CmsEntryStorageOperations => {\n const { entity, esEntity, elasticsearch, plugins } = params;\n\n let storageOperationsCmsModelPlugin: StorageOperationsCmsModelPlugin | undefined;\n const getStorageOperationsCmsModelPlugin = () => {\n if (storageOperationsCmsModelPlugin) {\n return storageOperationsCmsModelPlugin;\n }\n storageOperationsCmsModelPlugin = plugins.oneByType<StorageOperationsCmsModelPlugin>(\n StorageOperationsCmsModelPlugin.type\n );\n return storageOperationsCmsModelPlugin;\n };\n\n const getStorageOperationsModel = (model: CmsModel): StorageOperationsCmsModel => {\n const plugin = getStorageOperationsCmsModelPlugin();\n return plugin.getModel(model);\n };\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const create: CmsEntryStorageOperations[\"create\"] = async (initialModel, params) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n\n const model = getStorageOperationsModel(initialModel);\n\n const isPublished = initialEntry.status === \"published\";\n const locked = isPublished ? true : initialEntry.locked;\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n const esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep({ ...entry, locked }),\n storageEntry: lodashCloneDeep({ ...storageEntry, locked })\n });\n\n const { index: esIndex } = configurations.es({\n model\n });\n\n const esLatestData = await getESLatestEntryData(plugins, esEntry);\n const esPublishedData = await getESPublishedEntryData(plugins, esEntry);\n\n const revisionKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey(entry)\n };\n\n const latestKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createLatestSortKey()\n };\n\n const publishedKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createPublishedSortKey()\n };\n\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n ...revisionKeys,\n TYPE: createRecordType()\n }),\n entity.putBatch({\n ...storageEntry,\n locked,\n ...latestKeys,\n TYPE: createLatestRecordType()\n })\n ];\n\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n ...publishedKeys,\n TYPE: createPublishedRecordType()\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert entry data into the DynamoDB table.\",\n ex.code || \"CREATE_ENTRY_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n\n const esItems = [\n esEntity.putBatch({\n ...latestKeys,\n index: esIndex,\n data: esLatestData\n })\n ];\n if (isPublished) {\n esItems.push(\n esEntity.putBatch({\n ...publishedKeys,\n index: esIndex,\n data: esPublishedData\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert entry data into the Elasticsearch DynamoDB table.\",\n ex.code || \"CREATE_ES_ENTRY_ERROR\",\n {\n error: ex,\n entry,\n esEntry\n }\n );\n }\n\n return initialStorageEntry;\n };\n\n const createRevisionFrom: CmsEntryStorageOperations[\"createRevisionFrom\"] = async (\n initialModel,\n params\n ) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n const revisionKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey(entry)\n };\n const latestKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createLatestSortKey()\n };\n\n const esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep(entry),\n storageEntry: lodashCloneDeep(storageEntry)\n });\n\n const esLatestData = await getESLatestEntryData(plugins, esEntry);\n\n const items = [\n entity.putBatch({\n ...storageEntry,\n TYPE: createRecordType(),\n ...revisionKeys\n }),\n entity.putBatch({\n ...storageEntry,\n TYPE: createLatestRecordType(),\n ...latestKeys\n })\n ];\n\n const { index } = configurations.es({\n model\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 in the DynamoDB table.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n /**\n * Update the \"latest\" entry item in the Elasticsearch\n */\n try {\n await esEntity.put({\n ...latestKeys,\n index,\n data: esLatestData\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update latest entry in the DynamoDB Elasticsearch table.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n /**\n * There are no modifications on the entry created so just return the data.\n */\n return initialStorageEntry;\n };\n\n const update: CmsEntryStorageOperations[\"update\"] = async (initialModel, params) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const revisionKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey(entry)\n };\n const latestKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createLatestSortKey()\n };\n\n const publishedKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createPublishedSortKey()\n };\n\n /**\n * We need the latest entry to check if it needs to be updated.\n */\n const [latestStorageEntry] = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n const [publishedStorageEntry] = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n ...revisionKeys,\n TYPE: createRecordType()\n })\n ];\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n ...publishedKeys,\n TYPE: createPublishedRecordType()\n })\n );\n }\n\n const esItems = [];\n\n const { index: esIndex } = configurations.es({\n model\n });\n /**\n * Variable for the elasticsearch entry so we do not convert it more than once\n */\n let esEntry: CmsIndexEntry | undefined = undefined;\n /**\n * If the latest entry is the one being updated, we need to create a new latest entry records.\n */\n let elasticsearchLatestData: any = null;\n if (latestStorageEntry?.id === entry.id) {\n /**\n * First we update the regular DynamoDB table\n */\n items.push(\n entity.putBatch({\n ...storageEntry,\n ...latestKeys,\n TYPE: createLatestSortKey()\n })\n );\n /**\n * And then update the Elasticsearch table to propagate changes to the Elasticsearch\n */\n esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep({\n ...entry,\n locked\n }),\n storageEntry: lodashCloneDeep({\n ...storageEntry,\n locked\n })\n });\n\n elasticsearchLatestData = await getESLatestEntryData(plugins, esEntry);\n\n esItems.push(\n esEntity.putBatch({\n ...latestKeys,\n index: esIndex,\n data: elasticsearchLatestData\n })\n );\n }\n let elasticsearchPublishedData = null;\n if (isPublished && publishedStorageEntry?.id === entry.id) {\n if (!elasticsearchLatestData) {\n /**\n * And then update the Elasticsearch table to propagate changes to the Elasticsearch\n */\n if (!esEntry) {\n esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep({\n ...entry,\n locked\n }),\n storageEntry: lodashCloneDeep({\n ...storageEntry,\n locked\n })\n });\n }\n elasticsearchPublishedData = await getESPublishedEntryData(plugins, esEntry);\n } else {\n elasticsearchPublishedData = {\n ...elasticsearchLatestData,\n published: true,\n TYPE: createPublishedRecordType(),\n __type: createPublishedRecordType()\n };\n delete elasticsearchPublishedData.latest;\n }\n esItems.push(\n esEntity.putBatch({\n ...publishedKeys,\n index: esIndex,\n data: elasticsearchPublishedData\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 update entry DynamoDB records.\",\n ex.code || \"UPDATE_ENTRY_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n if (esItems.length === 0) {\n return initialStorageEntry;\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update entry DynamoDB Elasticsearch records.\",\n ex.code || \"UPDATE_ES_ENTRY_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n return initialStorageEntry;\n };\n\n const deleteEntry: CmsEntryStorageOperations[\"delete\"] = async (initialModel, params) => {\n const { entry } = params;\n const id = entry.id || entry.entryId;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const items = await queryAll<CmsEntry>({\n entity,\n partitionKey,\n options: {\n gte: \" \"\n }\n });\n\n const esItems = await queryAll<CmsEntry>({\n entity: esEntity,\n partitionKey,\n options: {\n gte: \" \"\n }\n });\n\n const deleteItems = items.map(item => {\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n const deleteEsItems = esItems.map(item => {\n return esEntity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n try {\n await batchWriteAll({\n table: entity.table,\n items: deleteItems\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete entry records from DynamoDB table.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: deleteEsItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete entry records from DynamoDB Elasticsearch table.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n };\n\n const deleteRevision: CmsEntryStorageOperations[\"deleteRevision\"] = async (\n initialModel,\n params\n ) => {\n const { entry, latestEntry, latestStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const { index } = configurations.es({\n model\n });\n /**\n * We need published entry to delete it if necessary.\n */\n const [publishedStorageEntry] = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n /**\n * We need to delete all existing records of the given entry revision.\n */\n const items = [\n /**\n * Delete records of given entry revision.\n */\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n })\n ];\n\n const esItems = [];\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?.id === entry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n esItems.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (latestEntry && latestStorageEntry) {\n const esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep(latestEntry),\n storageEntry: lodashCloneDeep(latestStorageEntry)\n });\n\n const esLatestData = await getESLatestEntryData(plugins, esEntry);\n /**\n * In the end we need to set the new latest entry\n */\n items.push(\n entity.putBatch({\n ...latestStorageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestRecordType()\n })\n );\n esItems.push(\n esEntity.putBatch({\n PK: partitionKey,\n SK: createLatestSortKey(),\n index,\n data: esLatestData\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not batch write entry records to DynamoDB table.\",\n ex.code || \"DELETE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n latestEntry,\n latestStorageEntry\n }\n );\n }\n\n if (esItems.length === 0) {\n return;\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message ||\n \"Could not batch write entry records to DynamoDB Elasticsearch table.\",\n ex.code || \"DELETE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n latestEntry,\n latestStorageEntry\n }\n );\n }\n };\n\n const deleteMultipleEntries: CmsEntryStorageOperations[\"deleteMultipleEntries\"] = async (\n initialModel,\n params\n ) => {\n const { entries } = params;\n const model = getStorageOperationsModel(initialModel);\n /**\n * First we need all the revisions of the entries we want to delete.\n */\n const revisions = await dataLoaders.getAllEntryRevisions({\n model,\n ids: entries\n });\n /**\n * Then we need to construct the queries for all the revisions and entries.\n */\n const items: Record<string, DocumentClient.WriteRequest>[] = [];\n const esItems: Record<string, DocumentClient.WriteRequest>[] = [];\n for (const id of entries) {\n /**\n * Latest item.\n */\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"L\"\n })\n );\n esItems.push(\n esEntity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"L\"\n })\n );\n /**\n * Published item.\n */\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"P\"\n })\n );\n esItems.push(\n esEntity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"P\"\n })\n );\n }\n /**\n * Exact revisions of all the entries\n */\n for (const revision of revisions) {\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id: revision.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey({\n version: revision.version\n })\n })\n );\n }\n\n await batchWriteAll({\n table: entity.table,\n items\n });\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n };\n\n const list: CmsEntryStorageOperations[\"list\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const limit = createLimit(params.limit, 50);\n const { index } = configurations.es({\n model\n });\n\n try {\n const result = await elasticsearch.indices.exists({\n index\n });\n if (!result?.body) {\n return {\n hasMoreItems: false,\n totalCount: 0,\n cursor: null,\n items: []\n };\n }\n } catch (ex) {\n throw new WebinyError(\n \"Could not determine if Elasticsearch index exists.\",\n \"ELASTICSEARCH_INDEX_CHECK_ERROR\",\n {\n error: ex,\n index\n }\n );\n }\n\n const body = createElasticsearchBody({\n model,\n params: {\n ...params,\n limit,\n after: decodeCursor(params.after)\n },\n plugins\n });\n\n let response: ElasticsearchSearchResponse<CmsIndexEntry>;\n try {\n response = await elasticsearch.search({\n index,\n body\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code || \"ELASTICSEARCH_ERROR\", {\n error: ex,\n index,\n body,\n model\n });\n }\n\n const { hits, total } = response?.body?.hits || {};\n\n const items = extractEntriesFromIndex({\n plugins,\n model,\n entries: hits.map(item => item._source)\n }).map(item => {\n return convertEntryKeysFromStorage({\n model,\n entry: item\n });\n });\n\n const hasMoreItems = items.length > limit;\n if (hasMoreItems) {\n /**\n * Remove the last item from results, we don't want to include it.\n */\n items.pop();\n }\n /**\n * Cursor is the `sort` value of the last item in the array.\n * https://www.elastic.co/guide/en/elasticsearch/reference/current/paginate-search-results.html#search-after\n */\n const cursor = items.length > 0 ? encodeCursor(hits[items.length - 1].sort) || null : null;\n return {\n hasMoreItems,\n totalCount: total.value,\n cursor,\n items\n };\n };\n\n const get: CmsEntryStorageOperations[\"get\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish: CmsEntryStorageOperations[\"publish\"] = async (initialModel, params) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n /**\n * We need currently published entry to check if need to remove it.\n */\n const [publishedStorageEntry] = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n const revisionKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey(entry)\n };\n const latestKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createLatestSortKey()\n };\n const publishedKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createPublishedSortKey()\n };\n\n let latestEsEntry: ElasticsearchDbRecord | null = null;\n try {\n latestEsEntry = await getRecord<ElasticsearchDbRecord>({\n entity: esEntity,\n keys: latestKeys\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not read Elasticsearch latest or published data.\",\n ex.code || \"PUBLISH_BATCH_READ\",\n {\n error: ex,\n latestKeys: latestKeys,\n publishedKeys: publishedKeys\n }\n );\n }\n\n const items = [\n entity.putBatch({\n ...storageEntry,\n ...revisionKeys,\n TYPE: createRecordType()\n })\n ];\n const esItems = [];\n\n const { index } = configurations.es({\n model\n });\n\n if (publishedStorageEntry && publishedStorageEntry.id !== entry.id) {\n /**\n * If there is a `published` entry already, we need to set it to `unpublished`. We need to\n * execute two updates: update the previously published entry's status and the published entry record.\n * DynamoDB does not support `batchUpdate` - so here we load the previously published\n * entry's data to update its status within a batch operation. If, hopefully,\n * they introduce a true update batch operation, remove this `read` call.\n */\n const [previouslyPublishedEntry] = await dataLoaders.getRevisionById({\n model,\n ids: [publishedStorageEntry.id]\n });\n items.push(\n /**\n * Update currently published entry (unpublish it)\n */\n entity.putBatch({\n ...previouslyPublishedEntry,\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED,\n savedOn: entry.savedOn,\n TYPE: createRecordType(),\n PK: createPartitionKey(publishedStorageEntry),\n SK: createRevisionSortKey(publishedStorageEntry)\n })\n );\n }\n /**\n * Update the helper item in DB with the new published entry\n */\n items.push(\n entity.putBatch({\n ...storageEntry,\n ...publishedKeys,\n TYPE: createPublishedRecordType()\n })\n );\n\n /**\n * We need the latest entry to check if it needs to be updated as well in the Elasticsearch.\n */\n const [latestStorageEntry] = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n if (latestStorageEntry?.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n ...latestKeys\n })\n );\n }\n /**\n * If we are publishing the latest revision, let's also update the latest revision's status in ES.\n */\n if (latestEsEntry && latestStorageEntry?.id === entry.id) {\n /**\n * Need to decompress the data from Elasticsearch DynamoDB table.\n *\n * No need to transform it for the storage because it was fetched directly from the Elasticsearch table, where it sits transformed.\n */\n const latestEsEntryDataDecompressed: CmsEntry = (await decompress(\n plugins,\n latestEsEntry.data\n )) as any;\n\n esItems.push(\n esEntity.putBatch({\n index,\n PK: createPartitionKey(latestEsEntryDataDecompressed),\n SK: createLatestSortKey(),\n data: await getESLatestEntryData(plugins, {\n ...latestEsEntryDataDecompressed,\n status: CONTENT_ENTRY_STATUS.PUBLISHED,\n locked: true,\n savedOn: entry.savedOn,\n publishedOn: entry.publishedOn\n })\n })\n );\n }\n\n const preparedEntryData = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep(entry),\n storageEntry: lodashCloneDeep(storageEntry)\n });\n /**\n * Update the published revision entry in ES.\n */\n const esPublishedData = await getESPublishedEntryData(plugins, preparedEntryData);\n\n esItems.push(\n esEntity.putBatch({\n ...publishedKeys,\n index,\n data: esPublishedData\n })\n );\n\n /**\n * Finally, execute regular table batch.\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 store publish entry records in DynamoDB table.\",\n ex.code || \"PUBLISH_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry,\n publishedStorageEntry\n }\n );\n }\n /**\n * And Elasticsearch table batch.\n */\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message ||\n \"Could not store publish entry records in DynamoDB Elasticsearch table.\",\n ex.code || \"PUBLISH_ES_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry,\n publishedStorageEntry\n }\n );\n }\n return initialStorageEntry;\n };\n\n const unpublish: CmsEntryStorageOperations[\"unpublish\"] = async (initialModel, params) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n /**\n * We need the latest entry to check if it needs to be updated.\n */\n const [latestStorageEntry] = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createRecordType()\n })\n ];\n\n const esItems = [\n esEntity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n ];\n /**\n * If we are unpublishing the latest revision, let's also update the latest revision entry's status in ES.\n */\n if (latestStorageEntry?.id === entry.id) {\n const { index } = configurations.es({\n model\n });\n\n const preparedEntryData = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep(entry),\n storageEntry: lodashCloneDeep(storageEntry)\n });\n\n const esLatestData = await getESLatestEntryData(plugins, preparedEntryData);\n esItems.push(\n esEntity.putBatch({\n PK: partitionKey,\n SK: createLatestSortKey(),\n index,\n data: esLatestData\n })\n );\n }\n\n /**\n * Finally, execute regular table batch.\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 store unpublished entry records in DynamoDB table.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n /**\n * And Elasticsearch table batch.\n */\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message ||\n \"Could not store unpublished entry records in DynamoDB Elasticsearch table.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n return initialStorageEntry;\n };\n\n const getLatestRevisionByEntryId: CmsEntryStorageOperations[\"getLatestRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const [entry] = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [params.id]\n });\n if (!entry) {\n return null;\n }\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n };\n\n const getPublishedRevisionByEntryId: CmsEntryStorageOperations[\"getPublishedRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const [entry] = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [params.id]\n });\n if (!entry) {\n return null;\n }\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n };\n\n const getRevisionById: CmsEntryStorageOperations[\"getRevisionById\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const [entry] = await dataLoaders.getRevisionById({\n model,\n ids: [params.id]\n });\n if (!entry) {\n return null;\n }\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n };\n\n const getRevisions: CmsEntryStorageOperations[\"getRevisions\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const entries = await dataLoaders.getAllEntryRevisions({\n model,\n ids: [params.id]\n });\n\n return entries.map(entry => {\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n });\n };\n\n const getByIds: CmsEntryStorageOperations[\"getByIds\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const entries = await dataLoaders.getRevisionById({\n model,\n ids: params.ids\n });\n return entries.map(entry => {\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n });\n };\n\n const getLatestByIds: CmsEntryStorageOperations[\"getLatestByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const entries = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: params.ids\n });\n return entries.map(entry => {\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n });\n };\n\n const getPublishedByIds: CmsEntryStorageOperations[\"getPublishedByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const entries = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: params.ids\n });\n\n return entries.map(entry => {\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n });\n };\n\n const getPreviousRevision: CmsEntryStorageOperations[\"getPreviousRevision\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\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: createRecordType()\n },\n {\n attr: \"version\",\n lt: version\n }\n ],\n reverse: true\n }\n };\n\n try {\n const result = await queryOne<CmsEntry>(queryParams);\n\n const entry = cleanupItem(entity, result);\n\n if (!entry) {\n return null;\n }\n return convertEntryKeysFromStorage({\n entry,\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get previous version of given entry.\",\n ex.code || \"GET_PREVIOUS_VERSION_ERROR\",\n {\n ...params,\n error: ex,\n partitionKey: queryParams.partitionKey,\n options: queryParams.options,\n model\n }\n );\n }\n };\n\n const getUniqueFieldValues: CmsEntryStorageOperations[\"getUniqueFieldValues\"] = async (\n model,\n params\n ) => {\n const { where, fieldId } = params;\n\n const { index } = configurations.es({\n model\n });\n\n try {\n const result = await elasticsearch.indices.exists({\n index\n });\n if (!result?.body) {\n return [];\n }\n } catch (ex) {\n throw new WebinyError(\n \"Could not determine if Elasticsearch index exists.\",\n \"ELASTICSEARCH_INDEX_CHECK_ERROR\",\n {\n error: ex,\n index\n }\n );\n }\n\n const initialBody = createElasticsearchBody({\n model,\n params: {\n limit: 1,\n where\n },\n plugins\n });\n\n const field = model.fields.find(f => f.fieldId === fieldId);\n if (!field) {\n throw new WebinyError(\n `Could not find field with given \"fieldId\" value.`,\n \"FIELD_NOT_FOUND\",\n {\n fieldId\n }\n );\n }\n\n const body: ElasticsearchSearchBody = {\n ...initialBody,\n /**\n * We do not need any hits returned, we only need the aggregations.\n */\n size: 0,\n aggregations: {\n getUniqueFieldValues: {\n terms: {\n field: `values.${field.storageId}.keyword`,\n size: 1000000\n }\n }\n }\n };\n\n let response: ElasticsearchSearchResponse<string> | undefined = undefined;\n\n try {\n response = await elasticsearch.search({\n index,\n body\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Error in the Elasticsearch query.\",\n ex.code || \"ELASTICSEARCH_ERROR\",\n {\n error: ex,\n index,\n model,\n body\n }\n );\n }\n\n const values = response.body.aggregations[\"getUniqueFieldValues\"] || { buckets: [] };\n\n return values.buckets.map(item => item.key) || [];\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n delete: deleteEntry,\n deleteRevision,\n deleteMultipleEntries,\n get,\n publish,\n unpublish,\n list,\n getLatestRevisionByEntryId,\n getPublishedRevisionByEntryId,\n getRevisionById,\n getRevisions,\n getByIds,\n getLatestByIds,\n getPublishedByIds,\n getPreviousRevision,\n getUniqueFieldValues,\n dataLoaders\n };\n};\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["_cloneDeep","_interopRequireDefault","require","_error","_types","_helpers","_configurations","_batchWrite","_dataLoaders","_keys","_query","_apiElasticsearch","_get","_utils","_cleanup","_body","_recordType","_apiHeadlessCms","_dbDynamodb","getEntryData","input","output","_objectSpread2","default","getESLatestEntryData","plugins","entry","compress","latest","TYPE","createLatestRecordType","__type","getESPublishedEntryData","published","createPublishedRecordType","convertEntryKeysToStorage","params","model","values","convertValueKeyToStorage","fields","convertEntryKeysFromStorage","convertValueKeyFromStorage","createEntriesStorageOperations","entity","esEntity","elasticsearch","storageOperationsCmsModelPlugin","getStorageOperationsCmsModelPlugin","oneByType","StorageOperationsCmsModelPlugin","type","getStorageOperationsModel","plugin","getModel","dataLoaders","DataLoadersHandler","create","initialModel","initialEntry","storageEntry","initialStorageEntry","isPublished","status","locked","esEntry","prepareEntryToIndex","lodashCloneDeep","index","esIndex","configurations","es","esLatestData","esPublishedData","revisionKeys","PK","createPartitionKey","id","locale","tenant","SK","createRevisionSortKey","latestKeys","createLatestSortKey","publishedKeys","createPublishedSortKey","items","putBatch","createRecordType","push","batchWriteAll","table","clearAll","ex","WebinyError","message","code","error","esItems","data","createRevisionFrom","put","update","latestStorageEntry","getLatestRevisionByEntryId","ids","publishedStorageEntry","getPublishedRevisionByEntryId","undefined","elasticsearchLatestData","elasticsearchPublishedData","length","move","folderId","partitionKey","queryAllParams","options","gte","latestSortKey","publishedSortKey","records","queryAll","latestRecord","publishedRecord","record","location","esGetItems","getBatch","esRecords","batchReadAll","Promise","all","map","decompress","filter","Boolean","esUpdateItems","item","_item$data","deleteEntry","entryId","deleteItems","deleteBatch","deleteEsItems","deleteRevision","latestEntry","deleteMultipleEntries","entries","revisions","getAllEntryRevisions","revision","version","list","_response","limit","createLimit","result","indices","exists","body","hasMoreItems","totalCount","cursor","createElasticsearchBody","after","decodeCursor","response","search","hits","total","extractEntriesFromIndex","_source","pop","encodeCursor","sort","value","get","shift","publish","latestEsEntry","getRecord","keys","previouslyPublishedEntry","getRevisionById","CONTENT_ENTRY_STATUS","UNPUBLISHED","savedOn","latestEsEntryDataDecompressed","PUBLISHED","publishedOn","preparedEntryData","unpublish","getRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","queryParams","lt","zeroPad","filters","attr","eq","reverse","queryOne","cleanupItem","getUniqueFieldValues","_response$body$aggreg","where","fieldId","initialBody","field","find","f","size","aggregations","terms","storageId","buckets","file","key","count","doc_count","delete","exports"],"sources":["index.ts"],"sourcesContent":["import lodashCloneDeep from \"lodash/cloneDeep\";\nimport WebinyError from \"@webiny/error\";\nimport {\n CmsEntry,\n CmsModel,\n CmsStorageEntry,\n CONTENT_ENTRY_STATUS,\n StorageOperationsCmsModel\n} from \"@webiny/api-headless-cms/types\";\nimport { extractEntriesFromIndex, prepareEntryToIndex } from \"~/helpers\";\nimport { configurations } from \"~/configurations\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport { Client } from \"@elastic/elasticsearch\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { batchWriteAll, BatchWriteItem } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport { DataLoadersHandler } from \"~/operations/entry/dataLoaders\";\nimport {\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys\";\nimport {\n queryAll,\n QueryAllParams,\n queryOne,\n QueryOneParams\n} from \"@webiny/db-dynamodb/utils/query\";\nimport {\n compress,\n createLimit,\n decodeCursor,\n decompress,\n encodeCursor\n} from \"@webiny/api-elasticsearch\";\nimport { get as getRecord } from \"@webiny/db-dynamodb/utils/get\";\nimport { zeroPad } from \"@webiny/utils\";\nimport { cleanupItem } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport {\n ElasticsearchSearchResponse,\n SearchBody as ElasticsearchSearchBody\n} from \"@webiny/api-elasticsearch/types\";\nimport { CmsEntryStorageOperations, CmsIndexEntry } from \"~/types\";\nimport { createElasticsearchBody } from \"~/operations/entry/elasticsearch/body\";\nimport { createLatestRecordType, createPublishedRecordType, createRecordType } from \"./recordType\";\nimport { StorageOperationsCmsModelPlugin } from \"@webiny/api-headless-cms\";\nimport { DocumentClient } from \"aws-sdk/clients/dynamodb\";\nimport { batchReadAll, BatchReadItem } from \"@webiny/db-dynamodb\";\n\nconst getEntryData = (input: CmsEntry): CmsEntry => {\n const output: any = {\n ...input\n };\n delete output[\"PK\"];\n delete output[\"SK\"];\n delete output[\"published\"];\n delete output[\"latest\"];\n\n return output;\n};\n\nconst getESLatestEntryData = async (plugins: PluginsContainer, entry: CmsEntry) => {\n return compress(plugins, {\n ...getEntryData(entry),\n latest: true,\n TYPE: createLatestRecordType(),\n __type: createLatestRecordType()\n });\n};\n\nconst getESPublishedEntryData = async (plugins: PluginsContainer, entry: CmsEntry) => {\n return compress(plugins, {\n ...getEntryData(entry),\n published: true,\n TYPE: createPublishedRecordType(),\n __type: createPublishedRecordType()\n });\n};\n\ninterface ConvertStorageEntryParams {\n entry: CmsStorageEntry;\n model: StorageOperationsCmsModel;\n}\nconst convertEntryKeysToStorage = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, entry } = params;\n\n const values = model.convertValueKeyToStorage({\n fields: model.fields,\n values: entry.values\n });\n return {\n ...entry,\n values\n };\n};\n\nconst convertEntryKeysFromStorage = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, entry } = params;\n\n const values = model.convertValueKeyFromStorage({\n fields: model.fields,\n values: entry.values\n });\n return {\n ...entry,\n values\n };\n};\n\ninterface ElasticsearchDbRecord {\n index: string;\n data: Record<string, any>;\n}\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: Entity<any>;\n esEntity: Entity<any>;\n elasticsearch: Client;\n plugins: PluginsContainer;\n}\nexport const createEntriesStorageOperations = (\n params: CreateEntriesStorageOperationsParams\n): CmsEntryStorageOperations => {\n const { entity, esEntity, elasticsearch, plugins } = params;\n\n let storageOperationsCmsModelPlugin: StorageOperationsCmsModelPlugin | undefined;\n const getStorageOperationsCmsModelPlugin = () => {\n if (storageOperationsCmsModelPlugin) {\n return storageOperationsCmsModelPlugin;\n }\n storageOperationsCmsModelPlugin = plugins.oneByType<StorageOperationsCmsModelPlugin>(\n StorageOperationsCmsModelPlugin.type\n );\n return storageOperationsCmsModelPlugin;\n };\n\n const getStorageOperationsModel = (model: CmsModel): StorageOperationsCmsModel => {\n const plugin = getStorageOperationsCmsModelPlugin();\n return plugin.getModel(model);\n };\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const create: CmsEntryStorageOperations[\"create\"] = async (initialModel, params) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n\n const model = getStorageOperationsModel(initialModel);\n\n const isPublished = initialEntry.status === \"published\";\n const locked = isPublished ? true : initialEntry.locked;\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n const esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep({ ...entry, locked }),\n storageEntry: lodashCloneDeep({ ...storageEntry, locked })\n });\n\n const { index: esIndex } = configurations.es({\n model\n });\n\n const esLatestData = await getESLatestEntryData(plugins, esEntry);\n const esPublishedData = await getESPublishedEntryData(plugins, esEntry);\n\n const revisionKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey(entry)\n };\n\n const latestKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createLatestSortKey()\n };\n\n const publishedKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createPublishedSortKey()\n };\n\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n ...revisionKeys,\n TYPE: createRecordType()\n }),\n entity.putBatch({\n ...storageEntry,\n locked,\n ...latestKeys,\n TYPE: createLatestRecordType()\n })\n ];\n\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n ...publishedKeys,\n TYPE: createPublishedRecordType()\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert entry data into the DynamoDB table.\",\n ex.code || \"CREATE_ENTRY_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n\n const esItems = [\n esEntity.putBatch({\n ...latestKeys,\n index: esIndex,\n data: esLatestData\n })\n ];\n if (isPublished) {\n esItems.push(\n esEntity.putBatch({\n ...publishedKeys,\n index: esIndex,\n data: esPublishedData\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert entry data into the Elasticsearch DynamoDB table.\",\n ex.code || \"CREATE_ES_ENTRY_ERROR\",\n {\n error: ex,\n entry,\n esEntry\n }\n );\n }\n\n return initialStorageEntry;\n };\n\n const createRevisionFrom: CmsEntryStorageOperations[\"createRevisionFrom\"] = async (\n initialModel,\n params\n ) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n const revisionKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey(entry)\n };\n const latestKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createLatestSortKey()\n };\n\n const esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep(entry),\n storageEntry: lodashCloneDeep(storageEntry)\n });\n\n const esLatestData = await getESLatestEntryData(plugins, esEntry);\n\n const items = [\n entity.putBatch({\n ...storageEntry,\n TYPE: createRecordType(),\n ...revisionKeys\n }),\n entity.putBatch({\n ...storageEntry,\n TYPE: createLatestRecordType(),\n ...latestKeys\n })\n ];\n\n const { index } = configurations.es({\n model\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 in the DynamoDB table.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n /**\n * Update the \"latest\" entry item in the Elasticsearch\n */\n try {\n await esEntity.put({\n ...latestKeys,\n index,\n data: esLatestData\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update latest entry in the DynamoDB Elasticsearch table.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n /**\n * There are no modifications on the entry created so just return the data.\n */\n return initialStorageEntry;\n };\n\n const update: CmsEntryStorageOperations[\"update\"] = async (initialModel, params) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const revisionKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey(entry)\n };\n const latestKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createLatestSortKey()\n };\n\n const publishedKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createPublishedSortKey()\n };\n\n /**\n * We need the latest entry to check if it needs to be updated.\n */\n const [latestStorageEntry] = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n const [publishedStorageEntry] = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n ...revisionKeys,\n TYPE: createRecordType()\n })\n ];\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n ...publishedKeys,\n TYPE: createPublishedRecordType()\n })\n );\n }\n\n const esItems = [];\n\n const { index: esIndex } = configurations.es({\n model\n });\n /**\n * Variable for the elasticsearch entry so we do not convert it more than once\n */\n let esEntry: CmsIndexEntry | undefined = undefined;\n /**\n * If the latest entry is the one being updated, we need to create a new latest entry records.\n */\n let elasticsearchLatestData: any = null;\n if (latestStorageEntry?.id === entry.id) {\n /**\n * First we update the regular DynamoDB table\n */\n items.push(\n entity.putBatch({\n ...storageEntry,\n ...latestKeys,\n TYPE: createLatestSortKey()\n })\n );\n /**\n * And then update the Elasticsearch table to propagate changes to the Elasticsearch\n */\n esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep({\n ...entry,\n locked\n }),\n storageEntry: lodashCloneDeep({\n ...storageEntry,\n locked\n })\n });\n\n elasticsearchLatestData = await getESLatestEntryData(plugins, esEntry);\n\n esItems.push(\n esEntity.putBatch({\n ...latestKeys,\n index: esIndex,\n data: elasticsearchLatestData\n })\n );\n }\n let elasticsearchPublishedData = null;\n if (isPublished && publishedStorageEntry?.id === entry.id) {\n if (!elasticsearchLatestData) {\n /**\n * And then update the Elasticsearch table to propagate changes to the Elasticsearch\n */\n if (!esEntry) {\n esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep({\n ...entry,\n locked\n }),\n storageEntry: lodashCloneDeep({\n ...storageEntry,\n locked\n })\n });\n }\n elasticsearchPublishedData = await getESPublishedEntryData(plugins, esEntry);\n } else {\n elasticsearchPublishedData = {\n ...elasticsearchLatestData,\n published: true,\n TYPE: createPublishedRecordType(),\n __type: createPublishedRecordType()\n };\n delete elasticsearchPublishedData.latest;\n }\n esItems.push(\n esEntity.putBatch({\n ...publishedKeys,\n index: esIndex,\n data: elasticsearchPublishedData\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 update entry DynamoDB records.\",\n ex.code || \"UPDATE_ENTRY_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n if (esItems.length === 0) {\n return initialStorageEntry;\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update entry DynamoDB Elasticsearch records.\",\n ex.code || \"UPDATE_ES_ENTRY_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n return initialStorageEntry;\n };\n\n const move: CmsEntryStorageOperations[\"move\"] = async (initialModel, id, folderId) => {\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n });\n /**\n * First we need to fetch all the records in the regular DynamoDB table.\n */\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey,\n options: {\n gte: \" \"\n }\n };\n const latestSortKey = createLatestSortKey();\n const publishedSortKey = createPublishedSortKey();\n const records = await queryAll<CmsEntry>(queryAllParams);\n /**\n * Then update the folderId in each record and prepare it to be stored.\n */\n let latestRecord: CmsEntry | undefined = undefined;\n let publishedRecord: CmsEntry | undefined = undefined;\n const items: BatchWriteItem[] = [];\n for (const record of records) {\n items.push(\n entity.putBatch({\n ...record,\n location: {\n ...record?.location,\n folderId\n }\n })\n );\n /**\n * We need to get the published and latest records, so we can update the Elasticsearch.\n */\n if (record.SK === publishedSortKey) {\n publishedRecord = record;\n } else if (record.SK === latestSortKey) {\n latestRecord = record;\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 move all entry records from in the DynamoDB table.\",\n ex.code || \"MOVE_ENTRY_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n const esGetItems: BatchReadItem[] = [];\n if (publishedRecord) {\n esGetItems.push(\n esEntity.getBatch({\n PK: partitionKey,\n SK: publishedSortKey\n })\n );\n }\n if (latestRecord) {\n esGetItems.push(\n esEntity.getBatch({\n PK: partitionKey,\n SK: latestSortKey\n })\n );\n }\n if (esGetItems.length === 0) {\n return;\n }\n const esRecords = await batchReadAll<ElasticsearchDbRecord>({\n table: esEntity.table,\n items: esGetItems\n });\n const esItems = (\n await Promise.all(\n esRecords.map(async record => {\n if (!record) {\n return null;\n }\n return {\n ...record,\n data: await decompress(plugins, record.data)\n };\n })\n )\n ).filter(Boolean) as ElasticsearchDbRecord[];\n\n if (esItems.length === 0) {\n return;\n }\n const esUpdateItems: BatchWriteItem[] = [];\n for (const item of esItems) {\n esUpdateItems.push(\n esEntity.putBatch({\n ...item,\n data: await compress(plugins, {\n ...item.data,\n location: {\n ...item.data?.location,\n folderId\n }\n })\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esUpdateItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not move entry DynamoDB Elasticsearch records.\",\n ex.code || \"MOVE_ES_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey\n }\n );\n }\n };\n\n const deleteEntry: CmsEntryStorageOperations[\"delete\"] = async (initialModel, params) => {\n const { entry } = params;\n const id = entry.id || entry.entryId;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const items = await queryAll<CmsEntry>({\n entity,\n partitionKey,\n options: {\n gte: \" \"\n }\n });\n\n const esItems = await queryAll<CmsEntry>({\n entity: esEntity,\n partitionKey,\n options: {\n gte: \" \"\n }\n });\n\n const deleteItems = items.map(item => {\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n const deleteEsItems = esItems.map(item => {\n return esEntity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n try {\n await batchWriteAll({\n table: entity.table,\n items: deleteItems\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete entry records from DynamoDB table.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: deleteEsItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete entry records from DynamoDB Elasticsearch table.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n };\n\n const deleteRevision: CmsEntryStorageOperations[\"deleteRevision\"] = async (\n initialModel,\n params\n ) => {\n const { entry, latestEntry, latestStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const { index } = configurations.es({\n model\n });\n /**\n * We need published entry to delete it if necessary.\n */\n const [publishedStorageEntry] = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n /**\n * We need to delete all existing records of the given entry revision.\n */\n const items = [\n /**\n * Delete records of given entry revision.\n */\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n })\n ];\n\n const esItems = [];\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?.id === entry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n esItems.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (latestEntry && latestStorageEntry) {\n const esEntry = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep(latestEntry),\n storageEntry: lodashCloneDeep(latestStorageEntry)\n });\n\n const esLatestData = await getESLatestEntryData(plugins, esEntry);\n /**\n * In the end we need to set the new latest entry\n */\n items.push(\n entity.putBatch({\n ...latestStorageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestRecordType()\n })\n );\n esItems.push(\n esEntity.putBatch({\n PK: partitionKey,\n SK: createLatestSortKey(),\n index,\n data: esLatestData\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not batch write entry records to DynamoDB table.\",\n ex.code || \"DELETE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n latestEntry,\n latestStorageEntry\n }\n );\n }\n\n if (esItems.length === 0) {\n return;\n }\n\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message ||\n \"Could not batch write entry records to DynamoDB Elasticsearch table.\",\n ex.code || \"DELETE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n latestEntry,\n latestStorageEntry\n }\n );\n }\n };\n\n const deleteMultipleEntries: CmsEntryStorageOperations[\"deleteMultipleEntries\"] = async (\n initialModel,\n params\n ) => {\n const { entries } = params;\n const model = getStorageOperationsModel(initialModel);\n /**\n * First we need all the revisions of the entries we want to delete.\n */\n const revisions = await dataLoaders.getAllEntryRevisions({\n model,\n ids: entries\n });\n /**\n * Then we need to construct the queries for all the revisions and entries.\n */\n const items: Record<string, DocumentClient.WriteRequest>[] = [];\n const esItems: Record<string, DocumentClient.WriteRequest>[] = [];\n for (const id of entries) {\n /**\n * Latest item.\n */\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"L\"\n })\n );\n esItems.push(\n esEntity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"L\"\n })\n );\n /**\n * Published item.\n */\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"P\"\n })\n );\n esItems.push(\n esEntity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"P\"\n })\n );\n }\n /**\n * Exact revisions of all the entries\n */\n for (const revision of revisions) {\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id: revision.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey({\n version: revision.version\n })\n })\n );\n }\n\n await batchWriteAll({\n table: entity.table,\n items\n });\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n };\n\n const list: CmsEntryStorageOperations[\"list\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const limit = createLimit(params.limit, 50);\n const { index } = configurations.es({\n model\n });\n\n try {\n const result = await elasticsearch.indices.exists({\n index\n });\n if (!result?.body) {\n return {\n hasMoreItems: false,\n totalCount: 0,\n cursor: null,\n items: []\n };\n }\n } catch (ex) {\n throw new WebinyError(\n \"Could not determine if Elasticsearch index exists.\",\n \"ELASTICSEARCH_INDEX_CHECK_ERROR\",\n {\n error: ex,\n index\n }\n );\n }\n\n const body = createElasticsearchBody({\n model,\n params: {\n ...params,\n limit,\n after: decodeCursor(params.after)\n },\n plugins\n });\n\n let response: ElasticsearchSearchResponse<CmsIndexEntry>;\n try {\n response = await elasticsearch.search({\n index,\n body\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code || \"ELASTICSEARCH_ERROR\", {\n error: ex,\n index,\n body,\n model\n });\n }\n\n const { hits, total } = response?.body?.hits || {};\n\n const items = extractEntriesFromIndex({\n plugins,\n model,\n entries: hits.map(item => item._source)\n }).map(item => {\n return convertEntryKeysFromStorage({\n model,\n entry: item\n });\n });\n\n const hasMoreItems = items.length > limit;\n if (hasMoreItems) {\n /**\n * Remove the last item from results, we don't want to include it.\n */\n items.pop();\n }\n /**\n * Cursor is the `sort` value of the last item in the array.\n * https://www.elastic.co/guide/en/elasticsearch/reference/current/paginate-search-results.html#search-after\n */\n const cursor = items.length > 0 ? encodeCursor(hits[items.length - 1].sort) || null : null;\n return {\n hasMoreItems,\n totalCount: total.value,\n cursor,\n items\n };\n };\n\n const get: CmsEntryStorageOperations[\"get\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish: CmsEntryStorageOperations[\"publish\"] = async (initialModel, params) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n /**\n * We need currently published entry to check if need to remove it.\n */\n const [publishedStorageEntry] = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n const revisionKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey(entry)\n };\n const latestKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createLatestSortKey()\n };\n const publishedKeys = {\n PK: createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createPublishedSortKey()\n };\n\n let latestEsEntry: ElasticsearchDbRecord | null = null;\n try {\n latestEsEntry = await getRecord<ElasticsearchDbRecord>({\n entity: esEntity,\n keys: latestKeys\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not read Elasticsearch latest or published data.\",\n ex.code || \"PUBLISH_BATCH_READ\",\n {\n error: ex,\n latestKeys: latestKeys,\n publishedKeys: publishedKeys\n }\n );\n }\n\n const items = [\n entity.putBatch({\n ...storageEntry,\n ...revisionKeys,\n TYPE: createRecordType()\n })\n ];\n const esItems = [];\n\n const { index } = configurations.es({\n model\n });\n\n if (publishedStorageEntry && publishedStorageEntry.id !== entry.id) {\n /**\n * If there is a `published` entry already, we need to set it to `unpublished`. We need to\n * execute two updates: update the previously published entry's status and the published entry record.\n * DynamoDB does not support `batchUpdate` - so here we load the previously published\n * entry's data to update its status within a batch operation. If, hopefully,\n * they introduce a true update batch operation, remove this `read` call.\n */\n const [previouslyPublishedEntry] = await dataLoaders.getRevisionById({\n model,\n ids: [publishedStorageEntry.id]\n });\n items.push(\n /**\n * Update currently published entry (unpublish it)\n */\n entity.putBatch({\n ...previouslyPublishedEntry,\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED,\n savedOn: entry.savedOn,\n TYPE: createRecordType(),\n PK: createPartitionKey(publishedStorageEntry),\n SK: createRevisionSortKey(publishedStorageEntry)\n })\n );\n }\n /**\n * Update the helper item in DB with the new published entry\n */\n items.push(\n entity.putBatch({\n ...storageEntry,\n ...publishedKeys,\n TYPE: createPublishedRecordType()\n })\n );\n\n /**\n * We need the latest entry to check if it needs to be updated as well in the Elasticsearch.\n */\n const [latestStorageEntry] = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n if (latestStorageEntry?.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n ...latestKeys\n })\n );\n }\n /**\n * If we are publishing the latest revision, let's also update the latest revision's status in ES.\n */\n if (latestEsEntry && latestStorageEntry?.id === entry.id) {\n /**\n * Need to decompress the data from Elasticsearch DynamoDB table.\n *\n * No need to transform it for the storage because it was fetched directly from the Elasticsearch table, where it sits transformed.\n */\n const latestEsEntryDataDecompressed: CmsEntry = (await decompress(\n plugins,\n latestEsEntry.data\n )) as any;\n\n esItems.push(\n esEntity.putBatch({\n index,\n PK: createPartitionKey(latestEsEntryDataDecompressed),\n SK: createLatestSortKey(),\n data: await getESLatestEntryData(plugins, {\n ...latestEsEntryDataDecompressed,\n status: CONTENT_ENTRY_STATUS.PUBLISHED,\n locked: true,\n savedOn: entry.savedOn,\n publishedOn: entry.publishedOn\n })\n })\n );\n }\n\n const preparedEntryData = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep(entry),\n storageEntry: lodashCloneDeep(storageEntry)\n });\n /**\n * Update the published revision entry in ES.\n */\n const esPublishedData = await getESPublishedEntryData(plugins, preparedEntryData);\n\n esItems.push(\n esEntity.putBatch({\n ...publishedKeys,\n index,\n data: esPublishedData\n })\n );\n\n /**\n * Finally, execute regular table batch.\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 store publish entry records in DynamoDB table.\",\n ex.code || \"PUBLISH_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry,\n publishedStorageEntry\n }\n );\n }\n /**\n * And Elasticsearch table batch.\n */\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message ||\n \"Could not store publish entry records in DynamoDB Elasticsearch table.\",\n ex.code || \"PUBLISH_ES_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry,\n publishedStorageEntry\n }\n );\n }\n return initialStorageEntry;\n };\n\n const unpublish: CmsEntryStorageOperations[\"unpublish\"] = async (initialModel, params) => {\n const { entry: initialEntry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const entry = convertEntryKeysToStorage({\n model,\n entry: initialEntry\n });\n const storageEntry = convertEntryKeysToStorage({\n model,\n entry: initialStorageEntry\n });\n\n /**\n * We need the latest entry to check if it needs to be updated.\n */\n const [latestStorageEntry] = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [entry.id]\n });\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createRecordType()\n })\n ];\n\n const esItems = [\n esEntity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n ];\n /**\n * If we are unpublishing the latest revision, let's also update the latest revision entry's status in ES.\n */\n if (latestStorageEntry?.id === entry.id) {\n const { index } = configurations.es({\n model\n });\n\n const preparedEntryData = prepareEntryToIndex({\n plugins,\n model,\n entry: lodashCloneDeep(entry),\n storageEntry: lodashCloneDeep(storageEntry)\n });\n\n const esLatestData = await getESLatestEntryData(plugins, preparedEntryData);\n esItems.push(\n esEntity.putBatch({\n PK: partitionKey,\n SK: createLatestSortKey(),\n index,\n data: esLatestData\n })\n );\n }\n\n /**\n * Finally, execute regular table batch.\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 store unpublished entry records in DynamoDB table.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n /**\n * And Elasticsearch table batch.\n */\n try {\n await batchWriteAll({\n table: esEntity.table,\n items: esItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message ||\n \"Could not store unpublished entry records in DynamoDB Elasticsearch table.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n return initialStorageEntry;\n };\n\n const getLatestRevisionByEntryId: CmsEntryStorageOperations[\"getLatestRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const [entry] = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: [params.id]\n });\n if (!entry) {\n return null;\n }\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n };\n\n const getPublishedRevisionByEntryId: CmsEntryStorageOperations[\"getPublishedRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const [entry] = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: [params.id]\n });\n if (!entry) {\n return null;\n }\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n };\n\n const getRevisionById: CmsEntryStorageOperations[\"getRevisionById\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const [entry] = await dataLoaders.getRevisionById({\n model,\n ids: [params.id]\n });\n if (!entry) {\n return null;\n }\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n };\n\n const getRevisions: CmsEntryStorageOperations[\"getRevisions\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const entries = await dataLoaders.getAllEntryRevisions({\n model,\n ids: [params.id]\n });\n\n return entries.map(entry => {\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n });\n };\n\n const getByIds: CmsEntryStorageOperations[\"getByIds\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const entries = await dataLoaders.getRevisionById({\n model,\n ids: params.ids\n });\n return entries.map(entry => {\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n });\n };\n\n const getLatestByIds: CmsEntryStorageOperations[\"getLatestByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const entries = await dataLoaders.getLatestRevisionByEntryId({\n model,\n ids: params.ids\n });\n return entries.map(entry => {\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n });\n };\n\n const getPublishedByIds: CmsEntryStorageOperations[\"getPublishedByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const entries = await dataLoaders.getPublishedRevisionByEntryId({\n model,\n ids: params.ids\n });\n\n return entries.map(entry => {\n return convertEntryKeysFromStorage({\n model,\n entry\n });\n });\n };\n\n const getPreviousRevision: CmsEntryStorageOperations[\"getPreviousRevision\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\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: createRecordType()\n },\n {\n attr: \"version\",\n lt: version\n }\n ],\n reverse: true\n }\n };\n\n try {\n const result = await queryOne<CmsEntry>(queryParams);\n\n const entry = cleanupItem(entity, result);\n\n if (!entry) {\n return null;\n }\n return convertEntryKeysFromStorage({\n entry,\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get previous version of given entry.\",\n ex.code || \"GET_PREVIOUS_VERSION_ERROR\",\n {\n ...params,\n error: ex,\n partitionKey: queryParams.partitionKey,\n options: queryParams.options,\n model\n }\n );\n }\n };\n\n const getUniqueFieldValues: CmsEntryStorageOperations[\"getUniqueFieldValues\"] = async (\n model,\n params\n ) => {\n const { where, fieldId } = params;\n\n const { index } = configurations.es({\n model\n });\n\n try {\n const result = await elasticsearch.indices.exists({\n index\n });\n if (!result?.body) {\n return [];\n }\n } catch (ex) {\n throw new WebinyError(\n \"Could not determine if Elasticsearch index exists.\",\n \"ELASTICSEARCH_INDEX_CHECK_ERROR\",\n {\n error: ex,\n index\n }\n );\n }\n\n const initialBody = createElasticsearchBody({\n model,\n params: {\n limit: 1,\n where\n },\n plugins\n });\n\n const field = model.fields.find(f => f.fieldId === fieldId);\n if (!field) {\n throw new WebinyError(\n `Could not find field with given \"fieldId\" value.`,\n \"FIELD_NOT_FOUND\",\n {\n fieldId\n }\n );\n }\n\n const body: ElasticsearchSearchBody = {\n ...initialBody,\n /**\n * We do not need any hits returned, we only need the aggregations.\n */\n size: 0,\n aggregations: {\n getUniqueFieldValues: {\n terms: {\n field: `values.${field.storageId}.keyword`,\n size: 1000000\n }\n }\n }\n };\n\n let response: ElasticsearchSearchResponse<string> | undefined = undefined;\n\n try {\n response = await elasticsearch.search({\n index,\n body\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Error in the Elasticsearch query.\",\n ex.code || \"ELASTICSEARCH_ERROR\",\n {\n error: ex,\n index,\n model,\n body\n }\n );\n }\n\n const buckets = response.body.aggregations[\"getUniqueFieldValues\"]?.buckets || [];\n return buckets.map(file => {\n return {\n value: file.key,\n count: file.doc_count\n };\n });\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n move,\n delete: deleteEntry,\n deleteRevision,\n deleteMultipleEntries,\n get,\n publish,\n unpublish,\n list,\n getLatestRevisionByEntryId,\n getPublishedRevisionByEntryId,\n getRevisionById,\n getRevisions,\n getByIds,\n getLatestByIds,\n getPublishedByIds,\n getPreviousRevision,\n getUniqueFieldValues,\n dataLoaders\n };\n};\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createPartitionKey","params","tenant","locale","id","initialId","parseIdentifier","createRevisionSortKey","zeroPad","version","createLatestSortKey","createPublishedSortKey"],"sources":["keys.ts"],"sourcesContent":["import { parseIdentifier, zeroPad } from \"@webiny/utils\";\n\nexport interface PartitionKeyParams {\n id: string;\n tenant: string;\n locale: string;\n}\nexport const createPartitionKey = (params: PartitionKeyParams): string => {\n const { tenant, locale, id: initialId } = params;\n const { id } = parseIdentifier(initialId);\n return `T#${tenant}#L#${locale}#CMS#CME#${id}`;\n};\n\nexport interface SortKeyParams {\n version: number;\n}\nexport const createRevisionSortKey = (params: SortKeyParams): string => {\n return `REV#${zeroPad(params.version)}`;\n};\n\nexport const createLatestSortKey = (): string => {\n return \"L\";\n};\n\nexport const createPublishedSortKey = (): string => {\n return \"P\";\n};\n"],"mappings":";;;;;;AAAA;AAOO,
|
|
1
|
+
{"version":3,"names":["_utils","require","createPartitionKey","params","tenant","locale","id","initialId","parseIdentifier","exports","createRevisionSortKey","zeroPad","version","createLatestSortKey","createPublishedSortKey"],"sources":["keys.ts"],"sourcesContent":["import { parseIdentifier, zeroPad } from \"@webiny/utils\";\n\nexport interface PartitionKeyParams {\n id: string;\n tenant: string;\n locale: string;\n}\nexport const createPartitionKey = (params: PartitionKeyParams): string => {\n const { tenant, locale, id: initialId } = params;\n const { id } = parseIdentifier(initialId);\n return `T#${tenant}#L#${locale}#CMS#CME#${id}`;\n};\n\nexport interface SortKeyParams {\n version: number;\n}\nexport const createRevisionSortKey = (params: SortKeyParams): string => {\n return `REV#${zeroPad(params.version)}`;\n};\n\nexport const createLatestSortKey = (): string => {\n return \"L\";\n};\n\nexport const createPublishedSortKey = (): string => {\n return \"P\";\n};\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AAOO,MAAMC,kBAAkB,GAAIC,MAA0B,IAAa;EACtE,MAAM;IAAEC,MAAM;IAAEC,MAAM;IAAEC,EAAE,EAAEC;EAAU,CAAC,GAAGJ,MAAM;EAChD,MAAM;IAAEG;EAAG,CAAC,GAAG,IAAAE,sBAAe,EAACD,SAAS,CAAC;EACzC,OAAQ,KAAIH,MAAO,MAAKC,MAAO,YAAWC,EAAG,EAAC;AAClD,CAAC;AAACG,OAAA,CAAAP,kBAAA,GAAAA,kBAAA;AAKK,MAAMQ,qBAAqB,GAAIP,MAAqB,IAAa;EACpE,OAAQ,OAAM,IAAAQ,cAAO,EAACR,MAAM,CAACS,OAAO,CAAE,EAAC;AAC3C,CAAC;AAACH,OAAA,CAAAC,qBAAA,GAAAA,qBAAA;AAEK,MAAMG,mBAAmB,GAAGA,CAAA,KAAc;EAC7C,OAAO,GAAG;AACd,CAAC;AAACJ,OAAA,CAAAI,mBAAA,GAAAA,mBAAA;AAEK,MAAMC,sBAAsB,GAAGA,CAAA,KAAc;EAChD,OAAO,GAAG;AACd,CAAC;AAACL,OAAA,CAAAK,sBAAA,GAAAA,sBAAA"}
|