@webiny/api-headless-cms-ddb 5.35.0 → 5.35.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.js +6 -4
- package/index.js.map +1 -1
- package/operations/entry/dataLoader/DataLoaderCache.d.ts +17 -0
- package/operations/entry/dataLoader/DataLoaderCache.js +43 -0
- package/operations/entry/dataLoader/DataLoaderCache.js.map +1 -0
- package/operations/entry/dataLoader/constants.d.ts +1 -0
- package/operations/entry/dataLoader/constants.js +9 -0
- package/operations/entry/dataLoader/constants.js.map +1 -0
- package/operations/entry/dataLoader/createBatchScheduleFn.d.ts +8 -0
- package/operations/entry/dataLoader/createBatchScheduleFn.js +23 -0
- package/operations/entry/dataLoader/createBatchScheduleFn.js.map +1 -0
- package/operations/entry/dataLoader/getAllEntryRevisions.d.ts +4 -0
- package/operations/entry/dataLoader/getAllEntryRevisions.js +43 -0
- package/operations/entry/dataLoader/getAllEntryRevisions.js.map +1 -0
- package/operations/entry/dataLoader/getLatestRevisionByEntryId.d.ts +4 -0
- package/operations/entry/dataLoader/getLatestRevisionByEntryId.js +57 -0
- package/operations/entry/dataLoader/getLatestRevisionByEntryId.js.map +1 -0
- package/operations/entry/dataLoader/getPublishedRevisionByEntryId.d.ts +4 -0
- package/operations/entry/dataLoader/getPublishedRevisionByEntryId.js +57 -0
- package/operations/entry/dataLoader/getPublishedRevisionByEntryId.js.map +1 -0
- package/operations/entry/dataLoader/getRevisionById.d.ts +4 -0
- package/operations/entry/dataLoader/getRevisionById.js +63 -0
- package/operations/entry/dataLoader/getRevisionById.js.map +1 -0
- package/operations/entry/dataLoader/index.d.ts +8 -0
- package/operations/entry/dataLoader/index.js +38 -0
- package/operations/entry/dataLoader/index.js.map +1 -0
- package/operations/entry/dataLoader/types.d.ts +6 -0
- package/operations/entry/dataLoader/types.js +5 -0
- package/operations/entry/dataLoader/types.js.map +1 -0
- package/operations/entry/dataLoaders.d.ts +11 -26
- package/operations/entry/dataLoaders.js +42 -205
- package/operations/entry/dataLoaders.js.map +1 -1
- package/operations/entry/index.d.ts +1 -1
- package/operations/entry/index.js +67 -4
- package/operations/entry/index.js.map +1 -1
- package/package.json +18 -18
- package/types.d.ts +10 -1
- package/types.js.map +1 -1
|
@@ -7,206 +7,45 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
exports.DataLoadersHandler = void 0;
|
|
8
8
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
9
9
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
10
|
-
var _dataloader = _interopRequireDefault(require("dataloader"));
|
|
11
10
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
12
|
-
var
|
|
13
|
-
var
|
|
14
|
-
var _cleanup = require("@webiny/db-dynamodb/utils/cleanup");
|
|
11
|
+
var _DataLoaderCache = require("./dataLoader/DataLoaderCache");
|
|
12
|
+
var _dataLoader = require("./dataLoader");
|
|
15
13
|
var _utils = require("@webiny/utils");
|
|
16
|
-
var _batchRead = require("@webiny/db-dynamodb/utils/batchRead");
|
|
17
|
-
const getAllEntryRevisions = params => {
|
|
18
|
-
const {
|
|
19
|
-
entity,
|
|
20
|
-
model
|
|
21
|
-
} = params;
|
|
22
|
-
const {
|
|
23
|
-
tenant,
|
|
24
|
-
locale
|
|
25
|
-
} = model;
|
|
26
|
-
return new _dataloader.default(async ids => {
|
|
27
|
-
const results = {};
|
|
28
|
-
for (const id of ids) {
|
|
29
|
-
const queryAllParams = {
|
|
30
|
-
entity,
|
|
31
|
-
partitionKey: (0, _keys.createPartitionKey)({
|
|
32
|
-
tenant,
|
|
33
|
-
locale,
|
|
34
|
-
id
|
|
35
|
-
}),
|
|
36
|
-
options: {
|
|
37
|
-
beginsWith: "REV#"
|
|
38
|
-
}
|
|
39
|
-
};
|
|
40
|
-
const items = await (0, _query.queryAll)(queryAllParams);
|
|
41
|
-
results[id] = (0, _cleanup.cleanupItems)(entity, items);
|
|
42
|
-
}
|
|
43
|
-
return ids.map(id => {
|
|
44
|
-
return results[id] || [];
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
};
|
|
48
|
-
const getRevisionById = params => {
|
|
49
|
-
const {
|
|
50
|
-
entity,
|
|
51
|
-
model
|
|
52
|
-
} = params;
|
|
53
|
-
const {
|
|
54
|
-
locale,
|
|
55
|
-
tenant
|
|
56
|
-
} = model;
|
|
57
|
-
return new _dataloader.default(async ids => {
|
|
58
|
-
const queries = ids.reduce((collection, id) => {
|
|
59
|
-
const partitionKey = (0, _keys.createPartitionKey)({
|
|
60
|
-
tenant,
|
|
61
|
-
locale,
|
|
62
|
-
id
|
|
63
|
-
});
|
|
64
|
-
const {
|
|
65
|
-
version
|
|
66
|
-
} = (0, _utils.parseIdentifier)(id);
|
|
67
|
-
if (version === null) {
|
|
68
|
-
return collection;
|
|
69
|
-
}
|
|
70
|
-
const sortKey = (0, _keys.createRevisionSortKey)({
|
|
71
|
-
version
|
|
72
|
-
});
|
|
73
|
-
const keys = `${partitionKey}__${sortKey}`;
|
|
74
|
-
if (collection[keys]) {
|
|
75
|
-
return collection;
|
|
76
|
-
}
|
|
77
|
-
collection[keys] = entity.getBatch({
|
|
78
|
-
PK: partitionKey,
|
|
79
|
-
SK: sortKey
|
|
80
|
-
});
|
|
81
|
-
return collection;
|
|
82
|
-
/**
|
|
83
|
-
* We cast as any because there is no return type defined.
|
|
84
|
-
*/
|
|
85
|
-
}, {});
|
|
86
|
-
const records = await (0, _batchRead.batchReadAll)({
|
|
87
|
-
table: entity.table,
|
|
88
|
-
items: Object.values(queries)
|
|
89
|
-
});
|
|
90
|
-
const items = (0, _cleanup.cleanupItems)(entity, records);
|
|
91
|
-
return ids.map(id => {
|
|
92
|
-
return items.filter(item => {
|
|
93
|
-
return id === item.id;
|
|
94
|
-
});
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
};
|
|
98
|
-
const getPublishedRevisionByEntryId = params => {
|
|
99
|
-
const {
|
|
100
|
-
entity,
|
|
101
|
-
model
|
|
102
|
-
} = params;
|
|
103
|
-
const {
|
|
104
|
-
locale,
|
|
105
|
-
tenant
|
|
106
|
-
} = model;
|
|
107
|
-
const publishedKey = (0, _keys.createPublishedSortKey)();
|
|
108
|
-
return new _dataloader.default(async ids => {
|
|
109
|
-
const queries = ids.reduce((collection, id) => {
|
|
110
|
-
const partitionKey = (0, _keys.createPartitionKey)({
|
|
111
|
-
tenant,
|
|
112
|
-
locale,
|
|
113
|
-
id
|
|
114
|
-
});
|
|
115
|
-
if (collection[partitionKey]) {
|
|
116
|
-
return collection;
|
|
117
|
-
}
|
|
118
|
-
collection[partitionKey] = entity.getBatch({
|
|
119
|
-
PK: partitionKey,
|
|
120
|
-
SK: publishedKey
|
|
121
|
-
});
|
|
122
|
-
return collection;
|
|
123
|
-
/**
|
|
124
|
-
* We cast as any because there is no return type defined.
|
|
125
|
-
*/
|
|
126
|
-
}, {});
|
|
127
|
-
const records = await (0, _batchRead.batchReadAll)({
|
|
128
|
-
table: entity.table,
|
|
129
|
-
items: Object.values(queries)
|
|
130
|
-
});
|
|
131
|
-
const items = (0, _cleanup.cleanupItems)(entity, records);
|
|
132
|
-
return ids.map(id => {
|
|
133
|
-
const {
|
|
134
|
-
id: entryId
|
|
135
|
-
} = (0, _utils.parseIdentifier)(id);
|
|
136
|
-
return items.filter(item => {
|
|
137
|
-
return entryId === item.entryId;
|
|
138
|
-
});
|
|
139
|
-
});
|
|
140
|
-
});
|
|
141
|
-
};
|
|
142
|
-
const getLatestRevisionByEntryId = params => {
|
|
143
|
-
const {
|
|
144
|
-
entity,
|
|
145
|
-
model
|
|
146
|
-
} = params;
|
|
147
|
-
const {
|
|
148
|
-
locale,
|
|
149
|
-
tenant
|
|
150
|
-
} = model;
|
|
151
|
-
const latestKey = (0, _keys.createLatestSortKey)();
|
|
152
|
-
return new _dataloader.default(async ids => {
|
|
153
|
-
const queries = ids.reduce((collection, id) => {
|
|
154
|
-
const partitionKey = (0, _keys.createPartitionKey)({
|
|
155
|
-
tenant,
|
|
156
|
-
locale,
|
|
157
|
-
id
|
|
158
|
-
});
|
|
159
|
-
if (collection[partitionKey]) {
|
|
160
|
-
return collection;
|
|
161
|
-
}
|
|
162
|
-
collection[partitionKey] = entity.getBatch({
|
|
163
|
-
PK: partitionKey,
|
|
164
|
-
SK: latestKey
|
|
165
|
-
});
|
|
166
|
-
return collection;
|
|
167
|
-
/**
|
|
168
|
-
* We cast as any because there is no return type defined.
|
|
169
|
-
*/
|
|
170
|
-
}, {});
|
|
171
|
-
const records = await (0, _batchRead.batchReadAll)({
|
|
172
|
-
table: entity.table,
|
|
173
|
-
items: Object.values(queries)
|
|
174
|
-
});
|
|
175
|
-
const items = (0, _cleanup.cleanupItems)(entity, records);
|
|
176
|
-
return ids.map(id => {
|
|
177
|
-
const {
|
|
178
|
-
id: entryId
|
|
179
|
-
} = (0, _utils.parseIdentifier)(id);
|
|
180
|
-
return items.filter(item => {
|
|
181
|
-
return entryId === item.entryId;
|
|
182
|
-
});
|
|
183
|
-
});
|
|
184
|
-
});
|
|
185
|
-
};
|
|
186
|
-
const dataLoaders = {
|
|
187
|
-
getAllEntryRevisions,
|
|
188
|
-
getRevisionById,
|
|
189
|
-
getPublishedRevisionByEntryId,
|
|
190
|
-
getLatestRevisionByEntryId
|
|
191
|
-
};
|
|
192
|
-
const loaderNames = Object.keys(dataLoaders);
|
|
193
14
|
class DataLoadersHandler {
|
|
194
15
|
constructor(params) {
|
|
195
|
-
(0, _defineProperty2.default)(this, "loaders", new Map());
|
|
196
16
|
(0, _defineProperty2.default)(this, "entity", void 0);
|
|
17
|
+
(0, _defineProperty2.default)(this, "cache", new _DataLoaderCache.DataLoaderCache());
|
|
197
18
|
this.entity = params.entity;
|
|
198
19
|
}
|
|
199
20
|
async getAllEntryRevisions(params) {
|
|
200
|
-
|
|
21
|
+
const ids = params.ids.map(id => {
|
|
22
|
+
const {
|
|
23
|
+
id: entryId
|
|
24
|
+
} = (0, _utils.parseIdentifier)(id);
|
|
25
|
+
return entryId;
|
|
26
|
+
});
|
|
27
|
+
return await this.loadMany("getAllEntryRevisions", params, ids);
|
|
201
28
|
}
|
|
202
29
|
async getRevisionById(params) {
|
|
203
30
|
return await this.loadMany("getRevisionById", params, params.ids);
|
|
204
31
|
}
|
|
205
32
|
async getPublishedRevisionByEntryId(params) {
|
|
206
|
-
|
|
33
|
+
const ids = params.ids.map(id => {
|
|
34
|
+
const {
|
|
35
|
+
id: entryId
|
|
36
|
+
} = (0, _utils.parseIdentifier)(id);
|
|
37
|
+
return entryId;
|
|
38
|
+
});
|
|
39
|
+
return await this.loadMany("getPublishedRevisionByEntryId", params, ids);
|
|
207
40
|
}
|
|
208
41
|
async getLatestRevisionByEntryId(params) {
|
|
209
|
-
|
|
42
|
+
const ids = params.ids.map(id => {
|
|
43
|
+
const {
|
|
44
|
+
id: entryId
|
|
45
|
+
} = (0, _utils.parseIdentifier)(id);
|
|
46
|
+
return entryId;
|
|
47
|
+
});
|
|
48
|
+
return await this.loadMany("getLatestRevisionByEntryId", params, ids);
|
|
210
49
|
}
|
|
211
50
|
|
|
212
51
|
/**
|
|
@@ -214,28 +53,29 @@ class DataLoadersHandler {
|
|
|
214
53
|
* Maybe pass on the generics to DataLoader definition?
|
|
215
54
|
*/
|
|
216
55
|
getLoader(name, params) {
|
|
217
|
-
if (!dataLoaders[name]) {
|
|
218
|
-
throw new _error.default("Unknown data loader.", "UNKNOWN_DATA_LOADER", {
|
|
219
|
-
name
|
|
220
|
-
});
|
|
221
|
-
}
|
|
222
56
|
const {
|
|
223
57
|
model
|
|
224
58
|
} = params;
|
|
225
|
-
const {
|
|
226
|
-
tenant,
|
|
227
|
-
locale
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
})));
|
|
59
|
+
const cacheParams = {
|
|
60
|
+
tenant: model.tenant,
|
|
61
|
+
locale: model.locale,
|
|
62
|
+
name
|
|
63
|
+
};
|
|
64
|
+
let loader = this.cache.getDataLoader(cacheParams);
|
|
65
|
+
if (loader) {
|
|
66
|
+
return loader;
|
|
234
67
|
}
|
|
235
|
-
|
|
68
|
+
const factory = (0, _dataLoader.getDataLoaderFactory)(name);
|
|
69
|
+
loader = factory({
|
|
70
|
+
entity: this.entity,
|
|
71
|
+
tenant: model.tenant,
|
|
72
|
+
locale: model.locale
|
|
73
|
+
});
|
|
74
|
+
this.cache.setDataLoader(cacheParams, loader);
|
|
75
|
+
return loader;
|
|
236
76
|
}
|
|
237
77
|
async loadMany(loader, params, ids) {
|
|
238
|
-
let results;
|
|
78
|
+
let results = [];
|
|
239
79
|
try {
|
|
240
80
|
results = await this.getLoader(loader, params).loadMany(ids);
|
|
241
81
|
if (Array.isArray(results) === true) {
|
|
@@ -269,10 +109,7 @@ class DataLoadersHandler {
|
|
|
269
109
|
});
|
|
270
110
|
}
|
|
271
111
|
clearAll(params) {
|
|
272
|
-
|
|
273
|
-
const loader = this.getLoader(name, params);
|
|
274
|
-
loader.clearAll();
|
|
275
|
-
}
|
|
112
|
+
this.cache.clearAll(params === null || params === void 0 ? void 0 : params.model);
|
|
276
113
|
}
|
|
277
114
|
}
|
|
278
115
|
exports.DataLoadersHandler = DataLoadersHandler;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["getAllEntryRevisions","params","entity","model","tenant","locale","DataLoader","ids","results","id","queryAllParams","partitionKey","createPartitionKey","options","beginsWith","items","queryAll","cleanupItems","map","getRevisionById","queries","reduce","collection","version","parseIdentifier","sortKey","createRevisionSortKey","keys","getBatch","PK","SK","records","batchReadAll","table","Object","values","filter","item","getPublishedRevisionByEntryId","publishedKey","createPublishedSortKey","entryId","getLatestRevisionByEntryId","latestKey","createLatestSortKey","dataLoaders","loaderNames","DataLoadersHandler","constructor","Map","loadMany","getLoader","name","WebinyError","loaderKey","modelId","loaders","has","set","get","loader","Array","isArray","acc","res","message","code","data","JSON","stringify","push","ex","error","clearAll"],"sources":["dataLoaders.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport { CmsStorageEntry, CmsModel } from \"@webiny/api-headless-cms/types\";\nimport WebinyError from \"@webiny/error\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport { queryAll, QueryAllParams } from \"@webiny/db-dynamodb/utils/query\";\nimport {\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"./keys\";\nimport { cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport { batchReadAll } from \"@webiny/db-dynamodb/utils/batchRead\";\n\nconst getAllEntryRevisions = (params: LoaderParams) => {\n const { entity, model } = params;\n const { tenant, locale } = model;\n return new DataLoader<string, CmsStorageEntry[]>(async (ids: readonly string[]) => {\n const results: Record<string, CmsStorageEntry[]> = {};\n for (const id of ids) {\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant,\n locale,\n id\n }),\n options: {\n beginsWith: \"REV#\"\n }\n };\n const items = await queryAll<CmsStorageEntry>(queryAllParams);\n results[id] = cleanupItems(entity, items);\n }\n\n return ids.map(id => {\n return results[id] || [];\n });\n });\n};\n\nconst getRevisionById = (params: LoaderParams) => {\n const { entity, model } = params;\n const { locale, tenant } = model;\n\n return new DataLoader<string, CmsStorageEntry[]>(async (ids: readonly string[]) => {\n const queries = ids.reduce((collection, id) => {\n const partitionKey = createPartitionKey({\n tenant,\n locale,\n id\n });\n const { version } = parseIdentifier(id);\n if (version === null) {\n return collection;\n }\n const sortKey = createRevisionSortKey({\n version\n });\n const keys = `${partitionKey}__${sortKey}`;\n if (collection[keys]) {\n return collection;\n }\n\n collection[keys] = entity.getBatch({\n PK: partitionKey,\n SK: sortKey\n });\n\n return collection;\n /**\n * We cast as any because there is no return type defined.\n */\n }, {} as Record<string, any>);\n\n const records = await batchReadAll<CmsStorageEntry>({\n table: entity.table,\n items: Object.values(queries)\n });\n const items = cleanupItems(entity, records);\n\n return ids.map(id => {\n return items.filter(item => {\n return id === item.id;\n });\n });\n });\n};\n\nconst getPublishedRevisionByEntryId = (params: LoaderParams) => {\n const { entity, model } = params;\n const { locale, tenant } = model;\n\n const publishedKey = createPublishedSortKey();\n\n return new DataLoader<string, CmsStorageEntry[]>(async (ids: readonly string[]) => {\n const queries = ids.reduce((collection, id) => {\n const partitionKey = createPartitionKey({\n tenant,\n locale,\n id\n });\n if (collection[partitionKey]) {\n return collection;\n }\n collection[partitionKey] = entity.getBatch({\n PK: partitionKey,\n SK: publishedKey\n });\n return collection;\n /**\n * We cast as any because there is no return type defined.\n */\n }, {} as Record<string, any>);\n\n const records = await batchReadAll<CmsStorageEntry>({\n table: entity.table,\n items: Object.values(queries)\n });\n const items = cleanupItems(entity, records);\n\n return ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return items.filter(item => {\n return entryId === item.entryId;\n });\n });\n });\n};\n\nconst getLatestRevisionByEntryId = (params: LoaderParams) => {\n const { entity, model } = params;\n const { locale, tenant } = model;\n\n const latestKey = createLatestSortKey();\n\n return new DataLoader<string, CmsStorageEntry[]>(async (ids: readonly string[]) => {\n const queries = ids.reduce((collection, id) => {\n const partitionKey = createPartitionKey({\n tenant,\n locale,\n id\n });\n if (collection[partitionKey]) {\n return collection;\n }\n collection[partitionKey] = entity.getBatch({\n PK: partitionKey,\n SK: latestKey\n });\n return collection;\n /**\n * We cast as any because there is no return type defined.\n */\n }, {} as Record<string, any>);\n\n const records = await batchReadAll<CmsStorageEntry>({\n table: entity.table,\n items: Object.values(queries)\n });\n const items = cleanupItems(entity, records);\n\n return ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return items.filter(item => {\n return entryId === item.entryId;\n });\n });\n });\n};\n\nconst dataLoaders: Record<Loaders, any> = {\n getAllEntryRevisions,\n getRevisionById,\n getPublishedRevisionByEntryId,\n getLatestRevisionByEntryId\n};\n\nexport interface GetAllEntryRevisionsParams {\n ids: readonly string[];\n model: CmsModel;\n}\n\nexport interface GetRevisionByIdParams {\n ids: readonly string[];\n model: CmsModel;\n}\n\nexport interface GetPublishedRevisionByEntryIdParams {\n ids: readonly string[];\n model: CmsModel;\n}\n\nexport interface GetLatestRevisionByEntryIdParams {\n ids: readonly string[];\n model: CmsModel;\n}\n\ninterface LoaderParams {\n entity: Entity<any>;\n model: CmsModel;\n}\n\ninterface GetLoaderParams {\n model: CmsModel;\n}\n\ninterface ClearLoaderParams {\n model: CmsModel;\n entry?: CmsStorageEntry;\n}\n\ntype Loaders =\n | \"getAllEntryRevisions\"\n | \"getRevisionById\"\n | \"getPublishedRevisionByEntryId\"\n | \"getLatestRevisionByEntryId\";\n\nconst loaderNames = Object.keys(dataLoaders) as Loaders[];\n\ninterface DataLoadersHandlerParams {\n entity: Entity<any>;\n}\nexport class DataLoadersHandler {\n private readonly loaders: Map<string, DataLoader<any, any>> = new Map();\n private readonly entity: Entity<any>;\n\n public constructor(params: DataLoadersHandlerParams) {\n this.entity = params.entity;\n }\n\n public async getAllEntryRevisions(\n params: GetAllEntryRevisionsParams\n ): Promise<CmsStorageEntry[]> {\n return await this.loadMany(\"getAllEntryRevisions\", params, params.ids);\n }\n\n public async getRevisionById(params: GetRevisionByIdParams): Promise<CmsStorageEntry[]> {\n return await this.loadMany(\"getRevisionById\", params, params.ids);\n }\n\n public async getPublishedRevisionByEntryId(\n params: GetPublishedRevisionByEntryIdParams\n ): Promise<CmsStorageEntry[]> {\n return await this.loadMany(\"getPublishedRevisionByEntryId\", params, params.ids);\n }\n\n public async getLatestRevisionByEntryId(\n params: GetLatestRevisionByEntryIdParams\n ): Promise<CmsStorageEntry[]> {\n return await this.loadMany(\"getLatestRevisionByEntryId\", params, params.ids);\n }\n\n /**\n * TODO @ts-refactor\n * Maybe pass on the generics to DataLoader definition?\n */\n private getLoader(name: Loaders, params: GetLoaderParams): DataLoader<any, any> {\n if (!dataLoaders[name]) {\n throw new WebinyError(\"Unknown data loader.\", \"UNKNOWN_DATA_LOADER\", {\n name\n });\n }\n const { model } = params;\n const { tenant, locale } = model;\n const loaderKey = `${name}-${tenant}-${locale}-${model.modelId}`;\n if (!this.loaders.has(loaderKey)) {\n this.loaders.set(\n loaderKey,\n dataLoaders[name]({\n ...params,\n entity: this.entity\n })\n );\n }\n return this.loaders.get(loaderKey) as DataLoader<any, any>;\n }\n\n private async loadMany(\n loader: Loaders,\n params: GetLoaderParams,\n ids: readonly string[]\n ): Promise<CmsStorageEntry[]> {\n let results;\n try {\n results = await this.getLoader(loader, params).loadMany(ids);\n if (Array.isArray(results) === true) {\n return results.reduce((acc, res) => {\n if (Array.isArray(res) === false) {\n if (res && res.message) {\n throw new WebinyError(res.message, res.code, {\n ...res,\n data: JSON.stringify(res.data || {})\n });\n }\n throw new WebinyError(\n \"Result from the data loader must be an array of arrays which contain requested items.\",\n \"DATA_LOADER_RESULTS_ERROR\",\n {\n ...params,\n loader\n }\n );\n }\n acc.push(...res);\n return acc;\n }, []);\n }\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Data loader error.\",\n ex.code || \"DATA_LOADER_ERROR\",\n {\n error: ex,\n ...params,\n loader,\n ids\n }\n );\n }\n throw new WebinyError(\n `Data loader did not return array of items or empty array.`,\n \"INVALID_DATA_LOADER_RESULT\",\n {\n loader,\n ids,\n results\n }\n );\n }\n\n public clearAll(params: Omit<ClearLoaderParams, \"entry\">): void {\n for (const name of loaderNames) {\n const loader = this.getLoader(name, params);\n loader.clearAll();\n }\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["DataLoadersHandler","constructor","params","DataLoaderCache","entity","getAllEntryRevisions","ids","map","id","entryId","parseIdentifier","loadMany","getRevisionById","getPublishedRevisionByEntryId","getLatestRevisionByEntryId","getLoader","name","model","cacheParams","tenant","locale","loader","cache","getDataLoader","factory","getDataLoaderFactory","setDataLoader","results","Array","isArray","reduce","acc","res","message","WebinyError","code","data","JSON","stringify","push","ex","error","clearAll"],"sources":["dataLoaders.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport WebinyError from \"@webiny/error\";\nimport { CmsModel, CmsStorageEntry } from \"@webiny/api-headless-cms/types\";\nimport { CacheKeyParams, DataLoaderCache } from \"~/operations/entry/dataLoader/DataLoaderCache\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport { DataLoaders, getDataLoaderFactory } from \"~/operations/entry/dataLoader\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport { DataLoadersHandlerInterface, DataLoadersHandlerInterfaceClearAllParams } from \"~/types\";\n\ninterface DataLoaderParams {\n model: Pick<CmsModel, \"tenant\" | \"locale\" | \"modelId\">;\n ids: readonly string[];\n}\n\ninterface GetLoaderParams {\n model: Pick<CmsModel, \"tenant\" | \"locale\" | \"modelId\">;\n}\n\ninterface DataLoadersHandlerParams {\n entity: Entity<any>;\n}\n\nexport class DataLoadersHandler implements DataLoadersHandlerInterface {\n private readonly entity: Entity<any>;\n private readonly cache: DataLoaderCache = new DataLoaderCache();\n\n public constructor(params: DataLoadersHandlerParams) {\n this.entity = params.entity;\n }\n\n public async getAllEntryRevisions(params: DataLoaderParams): Promise<CmsStorageEntry[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany(\"getAllEntryRevisions\", params, ids);\n }\n\n public async getRevisionById(params: DataLoaderParams): Promise<CmsStorageEntry[]> {\n return await this.loadMany(\"getRevisionById\", params, params.ids);\n }\n\n public async getPublishedRevisionByEntryId(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany(\"getPublishedRevisionByEntryId\", params, ids);\n }\n\n public async getLatestRevisionByEntryId(params: DataLoaderParams): Promise<CmsStorageEntry[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany(\"getLatestRevisionByEntryId\", params, ids);\n }\n\n /**\n * TODO @ts-refactor\n * Maybe pass on the generics to DataLoader definition?\n */\n private getLoader(name: DataLoaders, params: GetLoaderParams): DataLoader<any, any> {\n const { model } = params;\n const cacheParams: CacheKeyParams = {\n tenant: model.tenant,\n locale: model.locale,\n name\n };\n let loader = this.cache.getDataLoader(cacheParams);\n if (loader) {\n return loader;\n }\n const factory = getDataLoaderFactory(name);\n loader = factory({\n entity: this.entity,\n tenant: model.tenant,\n locale: model.locale\n });\n this.cache.setDataLoader(cacheParams, loader);\n return loader;\n }\n\n private async loadMany(\n loader: DataLoaders,\n params: GetLoaderParams,\n ids: readonly string[]\n ): Promise<CmsStorageEntry[]> {\n let results: any[] = [];\n try {\n results = await this.getLoader(loader, params).loadMany(ids);\n if (Array.isArray(results) === true) {\n return results.reduce((acc, res) => {\n if (Array.isArray(res) === false) {\n if (res && res.message) {\n throw new WebinyError(res.message, res.code, {\n ...res,\n data: JSON.stringify(res.data || {})\n });\n }\n throw new WebinyError(\n \"Result from the data loader must be an array of arrays which contain requested items.\",\n \"DATA_LOADER_RESULTS_ERROR\",\n {\n ...params,\n loader\n }\n );\n }\n acc.push(...res);\n return acc;\n }, []);\n }\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Data loader error.\",\n ex.code || \"DATA_LOADER_ERROR\",\n {\n error: ex,\n ...params,\n loader,\n ids\n }\n );\n }\n throw new WebinyError(\n `Data loader did not return array of items or empty array.`,\n \"INVALID_DATA_LOADER_RESULT\",\n {\n loader,\n ids,\n results\n }\n );\n }\n\n public clearAll(params?: DataLoadersHandlerInterfaceClearAllParams): void {\n this.cache.clearAll(params?.model);\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { CmsEntryStorageOperations } from "@webiny/api-headless-cms/types";
|
|
2
1
|
import { Entity } from "dynamodb-toolbox";
|
|
3
2
|
import { PluginsContainer } from "@webiny/plugins";
|
|
3
|
+
import { CmsEntryStorageOperations } from "../../types";
|
|
4
4
|
export interface CreateEntriesStorageOperationsParams {
|
|
5
5
|
entity: Entity<any>;
|
|
6
6
|
plugins: PluginsContainer;
|
|
@@ -291,11 +291,12 @@ const createEntriesStorageOperations = params => {
|
|
|
291
291
|
const {
|
|
292
292
|
entry
|
|
293
293
|
} = params;
|
|
294
|
+
const id = entry.id || entry.entryId;
|
|
294
295
|
const model = getStorageOperationsModel(initialModel);
|
|
295
296
|
const queryAllParams = {
|
|
296
297
|
entity,
|
|
297
298
|
partitionKey: (0, _keys.createPartitionKey)({
|
|
298
|
-
id
|
|
299
|
+
id,
|
|
299
300
|
locale: model.locale,
|
|
300
301
|
tenant: model.tenant
|
|
301
302
|
}),
|
|
@@ -309,7 +310,7 @@ const createEntriesStorageOperations = params => {
|
|
|
309
310
|
} catch (ex) {
|
|
310
311
|
throw new _error.default(ex.message || "Could not load all records.", ex.code || "LOAD_ALL_RECORDS_ERROR", {
|
|
311
312
|
error: ex,
|
|
312
|
-
|
|
313
|
+
id
|
|
313
314
|
});
|
|
314
315
|
}
|
|
315
316
|
const items = records.map(item => {
|
|
@@ -330,7 +331,7 @@ const createEntriesStorageOperations = params => {
|
|
|
330
331
|
throw new _error.default(ex.message || "Could not delete the entry.", ex.code || "DELETE_ENTRY_ERROR", {
|
|
331
332
|
error: ex,
|
|
332
333
|
partitionKey: queryAllParams.partitionKey,
|
|
333
|
-
|
|
334
|
+
id
|
|
334
335
|
});
|
|
335
336
|
}
|
|
336
337
|
};
|
|
@@ -390,6 +391,66 @@ const createEntriesStorageOperations = params => {
|
|
|
390
391
|
});
|
|
391
392
|
}
|
|
392
393
|
};
|
|
394
|
+
const deleteMultipleEntries = async (initialModel, params) => {
|
|
395
|
+
const {
|
|
396
|
+
entries
|
|
397
|
+
} = params;
|
|
398
|
+
const model = getStorageOperationsModel(initialModel);
|
|
399
|
+
/**
|
|
400
|
+
* First we need all the revisions of the entries we want to delete.
|
|
401
|
+
*/
|
|
402
|
+
const revisions = await dataLoaders.getAllEntryRevisions({
|
|
403
|
+
model,
|
|
404
|
+
ids: entries
|
|
405
|
+
});
|
|
406
|
+
/**
|
|
407
|
+
* Then we need to construct the queries for all the revisions and entries.
|
|
408
|
+
*/
|
|
409
|
+
const items = [];
|
|
410
|
+
for (const id of entries) {
|
|
411
|
+
/**
|
|
412
|
+
* Latest item.
|
|
413
|
+
*/
|
|
414
|
+
items.push(entity.deleteBatch({
|
|
415
|
+
PK: (0, _keys.createPartitionKey)({
|
|
416
|
+
id,
|
|
417
|
+
locale: model.locale,
|
|
418
|
+
tenant: model.tenant
|
|
419
|
+
}),
|
|
420
|
+
SK: "L"
|
|
421
|
+
}));
|
|
422
|
+
/**
|
|
423
|
+
* Published item.
|
|
424
|
+
*/
|
|
425
|
+
items.push(entity.deleteBatch({
|
|
426
|
+
PK: (0, _keys.createPartitionKey)({
|
|
427
|
+
id,
|
|
428
|
+
locale: model.locale,
|
|
429
|
+
tenant: model.tenant
|
|
430
|
+
}),
|
|
431
|
+
SK: "P"
|
|
432
|
+
}));
|
|
433
|
+
}
|
|
434
|
+
/**
|
|
435
|
+
* Exact revisions of all the entries
|
|
436
|
+
*/
|
|
437
|
+
for (const revision of revisions) {
|
|
438
|
+
items.push(entity.deleteBatch({
|
|
439
|
+
PK: (0, _keys.createPartitionKey)({
|
|
440
|
+
id: revision.id,
|
|
441
|
+
locale: model.locale,
|
|
442
|
+
tenant: model.tenant
|
|
443
|
+
}),
|
|
444
|
+
SK: (0, _keys.createRevisionSortKey)({
|
|
445
|
+
version: revision.version
|
|
446
|
+
})
|
|
447
|
+
}));
|
|
448
|
+
}
|
|
449
|
+
await (0, _batchWrite.batchWriteAll)({
|
|
450
|
+
table: entity.table,
|
|
451
|
+
items
|
|
452
|
+
});
|
|
453
|
+
};
|
|
393
454
|
const getLatestRevisionByEntryId = async (initialModel, params) => {
|
|
394
455
|
const model = getStorageOperationsModel(initialModel);
|
|
395
456
|
const items = await dataLoaders.getLatestRevisionByEntryId({
|
|
@@ -799,6 +860,7 @@ const createEntriesStorageOperations = params => {
|
|
|
799
860
|
update,
|
|
800
861
|
delete: deleteEntry,
|
|
801
862
|
deleteRevision,
|
|
863
|
+
deleteMultipleEntries,
|
|
802
864
|
getPreviousRevision,
|
|
803
865
|
getPublishedByIds,
|
|
804
866
|
getLatestByIds,
|
|
@@ -810,7 +872,8 @@ const createEntriesStorageOperations = params => {
|
|
|
810
872
|
getRevisions,
|
|
811
873
|
publish,
|
|
812
874
|
list,
|
|
813
|
-
unpublish
|
|
875
|
+
unpublish,
|
|
876
|
+
dataLoaders
|
|
814
877
|
};
|
|
815
878
|
};
|
|
816
879
|
exports.createEntriesStorageOperations = createEntriesStorageOperations;
|