@webiny/api-headless-cms-ddb 6.0.0-rc.7 → 6.1.0-beta.0
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/operations/entry/dataLoader/DataLoaderCache.d.ts +1 -0
- package/operations/entry/dataLoader/DataLoaderCache.js +2 -5
- package/operations/entry/dataLoader/DataLoaderCache.js.map +1 -1
- package/operations/entry/dataLoader/getAllEntryRevisions.js +5 -2
- package/operations/entry/dataLoader/getAllEntryRevisions.js.map +1 -1
- package/operations/entry/dataLoader/getLatestRevisionByEntryId.js +5 -1
- package/operations/entry/dataLoader/getLatestRevisionByEntryId.js.map +1 -1
- package/operations/entry/dataLoader/getPublishedRevisionByEntryId.js +5 -1
- package/operations/entry/dataLoader/getPublishedRevisionByEntryId.js.map +1 -1
- package/operations/entry/dataLoader/getRevisionById.js +5 -1
- package/operations/entry/dataLoader/getRevisionById.js.map +1 -1
- package/operations/entry/dataLoader/types.d.ts +1 -0
- package/operations/entry/dataLoader/types.js.map +1 -1
- package/operations/entry/dataLoaders.js +3 -1
- package/operations/entry/dataLoaders.js.map +1 -1
- package/operations/entry/filtering/sort.js +2 -2
- package/operations/entry/filtering/sort.js.map +1 -1
- package/operations/entry/index.js +3 -0
- package/operations/entry/index.js.map +1 -1
- package/package.json +14 -14
|
@@ -15,10 +15,7 @@ export class DataLoaderCache {
|
|
|
15
15
|
}
|
|
16
16
|
return;
|
|
17
17
|
}
|
|
18
|
-
const key =
|
|
19
|
-
...params,
|
|
20
|
-
name: ""
|
|
21
|
-
});
|
|
18
|
+
const key = `${params.tenant}_`;
|
|
22
19
|
for (const current in this.cache) {
|
|
23
20
|
if (current.startsWith(key) === false) {
|
|
24
21
|
continue;
|
|
@@ -27,7 +24,7 @@ export class DataLoaderCache {
|
|
|
27
24
|
}
|
|
28
25
|
}
|
|
29
26
|
createKey(params) {
|
|
30
|
-
return `${params.tenant}_${params.name}`;
|
|
27
|
+
return `${params.tenant}_${params.modelId}_${params.name}`;
|
|
31
28
|
}
|
|
32
29
|
}
|
|
33
30
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DataLoaderCache","cache","getDataLoader","params","key","createKey","setDataLoader","dataLoader","clearAll","current","
|
|
1
|
+
{"version":3,"names":["DataLoaderCache","cache","getDataLoader","params","key","createKey","setDataLoader","dataLoader","clearAll","current","tenant","startsWith","modelId","name"],"sources":["DataLoaderCache.ts"],"sourcesContent":["import type DataLoader from \"dataloader\";\n\nexport interface CacheKeyParams {\n name: string;\n tenant: string;\n modelId: string;\n}\n\nexport interface ClearAllParams {\n tenant: string;\n}\n\nexport class DataLoaderCache {\n private readonly cache: Record<string, DataLoader<any, any>> = {};\n\n public getDataLoader<I = any, R = any>(params: CacheKeyParams): DataLoader<I, R> | null {\n const key = this.createKey(params);\n\n return this.cache[key] || null;\n }\n\n public setDataLoader(params: CacheKeyParams, dataLoader: DataLoader<any, any>): void {\n const key = this.createKey(params);\n this.cache[key] = dataLoader;\n }\n\n public clearAll(params?: ClearAllParams): void {\n if (!params) {\n for (const current in this.cache) {\n this.cache[current].clearAll();\n }\n return;\n }\n const key = `${params.tenant}_`;\n for (const current in this.cache) {\n if (current.startsWith(key) === false) {\n continue;\n }\n this.cache[current].clearAll();\n }\n }\n\n private createKey(params: CacheKeyParams): string {\n return `${params.tenant}_${params.modelId}_${params.name}`;\n }\n}\n"],"mappings":"AAYA,OAAO,MAAMA,eAAe,CAAC;EACRC,KAAK,GAAyC,CAAC,CAAC;EAE1DC,aAAaA,CAAmBC,MAAsB,EAA2B;IACpF,MAAMC,GAAG,GAAG,IAAI,CAACC,SAAS,CAACF,MAAM,CAAC;IAElC,OAAO,IAAI,CAACF,KAAK,CAACG,GAAG,CAAC,IAAI,IAAI;EAClC;EAEOE,aAAaA,CAACH,MAAsB,EAAEI,UAAgC,EAAQ;IACjF,MAAMH,GAAG,GAAG,IAAI,CAACC,SAAS,CAACF,MAAM,CAAC;IAClC,IAAI,CAACF,KAAK,CAACG,GAAG,CAAC,GAAGG,UAAU;EAChC;EAEOC,QAAQA,CAACL,MAAuB,EAAQ;IAC3C,IAAI,CAACA,MAAM,EAAE;MACT,KAAK,MAAMM,OAAO,IAAI,IAAI,CAACR,KAAK,EAAE;QAC9B,IAAI,CAACA,KAAK,CAACQ,OAAO,CAAC,CAACD,QAAQ,CAAC,CAAC;MAClC;MACA;IACJ;IACA,MAAMJ,GAAG,GAAG,GAAGD,MAAM,CAACO,MAAM,GAAG;IAC/B,KAAK,MAAMD,OAAO,IAAI,IAAI,CAACR,KAAK,EAAE;MAC9B,IAAIQ,OAAO,CAACE,UAAU,CAACP,GAAG,CAAC,KAAK,KAAK,EAAE;QACnC;MACJ;MACA,IAAI,CAACH,KAAK,CAACQ,OAAO,CAAC,CAACD,QAAQ,CAAC,CAAC;IAClC;EACJ;EAEQH,SAASA,CAACF,MAAsB,EAAU;IAC9C,OAAO,GAAGA,MAAM,CAACO,MAAM,IAAIP,MAAM,CAACS,OAAO,IAAIT,MAAM,CAACU,IAAI,EAAE;EAC9D;AACJ","ignoreList":[]}
|
|
@@ -4,7 +4,8 @@ import { createBatchScheduleFn } from "./createBatchScheduleFn.js";
|
|
|
4
4
|
export const createGetAllEntryRevisions = params => {
|
|
5
5
|
const {
|
|
6
6
|
entity,
|
|
7
|
-
tenant
|
|
7
|
+
tenant,
|
|
8
|
+
modelId
|
|
8
9
|
} = params;
|
|
9
10
|
return new DataLoader(async ids => {
|
|
10
11
|
const results = {};
|
|
@@ -22,7 +23,9 @@ export const createGetAllEntryRevisions = params => {
|
|
|
22
23
|
});
|
|
23
24
|
}
|
|
24
25
|
return ids.map(id => {
|
|
25
|
-
return results[id] || []
|
|
26
|
+
return (results[id] || []).filter(item => {
|
|
27
|
+
return item.modelId === modelId;
|
|
28
|
+
});
|
|
26
29
|
});
|
|
27
30
|
}, {
|
|
28
31
|
batchScheduleFn: createBatchScheduleFn()
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DataLoader","createPartitionKey","createBatchScheduleFn","createGetAllEntryRevisions","params","entity","tenant","ids","results","id","queryAllClean","partitionKey","options","beginsWith","map","result","data","batchScheduleFn"],"sources":["getAllEntryRevisions.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport type { CmsStorageEntry } from \"@webiny/api-headless-cms/types/index.js\";\nimport { createPartitionKey } from \"~/operations/entry/keys.js\";\nimport type { IDataLoaderParams } from \"./types.js\";\nimport { createBatchScheduleFn } from \"./createBatchScheduleFn.js\";\n\nexport const createGetAllEntryRevisions = (params: IDataLoaderParams) => {\n const { entity, tenant } = params;\n return new DataLoader<string, CmsStorageEntry[]>(\n async ids => {\n const results: Record<string, CmsStorageEntry[]> = {};\n\n for (const id of ids) {\n results[id] = (\n await entity.queryAllClean({\n partitionKey: createPartitionKey({\n tenant,\n id\n }),\n options: {\n beginsWith: \"REV#\"\n }\n })\n ).map(result => {\n return result.data;\n });\n }\n\n return ids.map(id => {\n return results[id] || [];\n });\n },\n {\n batchScheduleFn: createBatchScheduleFn()\n }\n );\n};\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AAEnC,SAASC,kBAAkB;AAE3B,SAASC,qBAAqB;AAE9B,OAAO,MAAMC,0BAA0B,GAAIC,MAAyB,IAAK;EACrE,MAAM;IAAEC,MAAM;IAAEC;
|
|
1
|
+
{"version":3,"names":["DataLoader","createPartitionKey","createBatchScheduleFn","createGetAllEntryRevisions","params","entity","tenant","modelId","ids","results","id","queryAllClean","partitionKey","options","beginsWith","map","result","data","filter","item","batchScheduleFn"],"sources":["getAllEntryRevisions.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport type { CmsStorageEntry } from \"@webiny/api-headless-cms/types/index.js\";\nimport { createPartitionKey } from \"~/operations/entry/keys.js\";\nimport type { IDataLoaderParams } from \"./types.js\";\nimport { createBatchScheduleFn } from \"./createBatchScheduleFn.js\";\n\nexport const createGetAllEntryRevisions = (params: IDataLoaderParams) => {\n const { entity, tenant, modelId } = params;\n return new DataLoader<string, CmsStorageEntry[]>(\n async ids => {\n const results: Record<string, CmsStorageEntry[]> = {};\n\n for (const id of ids) {\n results[id] = (\n await entity.queryAllClean({\n partitionKey: createPartitionKey({\n tenant,\n id\n }),\n options: {\n beginsWith: \"REV#\"\n }\n })\n ).map(result => {\n return result.data;\n });\n }\n\n return ids.map(id => {\n return (results[id] || []).filter(item => {\n return item.modelId === modelId;\n });\n });\n },\n {\n batchScheduleFn: createBatchScheduleFn()\n }\n );\n};\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AAEnC,SAASC,kBAAkB;AAE3B,SAASC,qBAAqB;AAE9B,OAAO,MAAMC,0BAA0B,GAAIC,MAAyB,IAAK;EACrE,MAAM;IAAEC,MAAM;IAAEC,MAAM;IAAEC;EAAQ,CAAC,GAAGH,MAAM;EAC1C,OAAO,IAAIJ,UAAU,CACjB,MAAMQ,GAAG,IAAI;IACT,MAAMC,OAA0C,GAAG,CAAC,CAAC;IAErD,KAAK,MAAMC,EAAE,IAAIF,GAAG,EAAE;MAClBC,OAAO,CAACC,EAAE,CAAC,GAAG,CACV,MAAML,MAAM,CAACM,aAAa,CAAC;QACvBC,YAAY,EAAEX,kBAAkB,CAAC;UAC7BK,MAAM;UACNI;QACJ,CAAC,CAAC;QACFG,OAAO,EAAE;UACLC,UAAU,EAAE;QAChB;MACJ,CAAC,CAAC,EACJC,GAAG,CAACC,MAAM,IAAI;QACZ,OAAOA,MAAM,CAACC,IAAI;MACtB,CAAC,CAAC;IACN;IAEA,OAAOT,GAAG,CAACO,GAAG,CAACL,EAAE,IAAI;MACjB,OAAO,CAACD,OAAO,CAACC,EAAE,CAAC,IAAI,EAAE,EAAEQ,MAAM,CAACC,IAAI,IAAI;QACtC,OAAOA,IAAI,CAACZ,OAAO,KAAKA,OAAO;MACnC,CAAC,CAAC;IACN,CAAC,CAAC;EACN,CAAC,EACD;IACIa,eAAe,EAAElB,qBAAqB,CAAC;EAC3C,CACJ,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -6,7 +6,8 @@ import { parseIdentifier } from "@webiny/utils";
|
|
|
6
6
|
export const createGetLatestRevisionByEntryId = params => {
|
|
7
7
|
const {
|
|
8
8
|
entity,
|
|
9
|
-
tenant
|
|
9
|
+
tenant,
|
|
10
|
+
modelId
|
|
10
11
|
} = params;
|
|
11
12
|
const latestKey = createLatestSortKey();
|
|
12
13
|
return new DataLoader(async ids => {
|
|
@@ -35,6 +36,9 @@ export const createGetLatestRevisionByEntryId = params => {
|
|
|
35
36
|
id: entryId
|
|
36
37
|
} = parseIdentifier(id);
|
|
37
38
|
return items.filter(item => {
|
|
39
|
+
if (item.modelId !== modelId) {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
38
42
|
return entryId === item.entryId;
|
|
39
43
|
});
|
|
40
44
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DataLoader","cleanupItems","createBatchScheduleFn","createLatestSortKey","createPartitionKey","parseIdentifier","createGetLatestRevisionByEntryId","params","entity","tenant","latestKey","ids","reader","createEntityReader","keys","Set","id","partitionKey","has","add","get","PK","SK","records","execute","items","map","item","data","entryId","filter","batchScheduleFn"],"sources":["getLatestRevisionByEntryId.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport { cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup.js\";\nimport type { CmsStorageEntry } from \"@webiny/api-headless-cms/types/index.js\";\nimport { createBatchScheduleFn } from \"./createBatchScheduleFn.js\";\nimport { createLatestSortKey, createPartitionKey } from \"~/operations/entry/keys.js\";\nimport type { IDataLoaderParams } from \"./types.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\n\nexport const createGetLatestRevisionByEntryId = (params: IDataLoaderParams) => {\n const { entity, tenant } = params;\n\n const latestKey = createLatestSortKey();\n\n return new DataLoader<string, CmsStorageEntry[]>(\n async ids => {\n const reader = entity.createEntityReader();\n\n const keys = new Set<string>();\n\n for (const id of ids) {\n const partitionKey = createPartitionKey({\n tenant,\n id\n });\n if (keys.has(partitionKey)) {\n continue;\n }\n keys.add(partitionKey);\n\n reader.get({\n PK: partitionKey,\n SK: latestKey\n });\n }\n\n const records = await reader.execute();\n const items = cleanupItems(entity.entity, records).map(item => {\n return item.data;\n });\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 batchScheduleFn: createBatchScheduleFn()\n }\n );\n};\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AACnC,SAASC,YAAY,QAAQ,sCAAsC;AAEnE,SAASC,qBAAqB;AAC9B,SAASC,mBAAmB,EAAEC,kBAAkB;AAEhD,SAASC,eAAe,QAAQ,eAAe;AAE/C,OAAO,MAAMC,gCAAgC,GAAIC,MAAyB,IAAK;EAC3E,MAAM;IAAEC,MAAM;IAAEC;
|
|
1
|
+
{"version":3,"names":["DataLoader","cleanupItems","createBatchScheduleFn","createLatestSortKey","createPartitionKey","parseIdentifier","createGetLatestRevisionByEntryId","params","entity","tenant","modelId","latestKey","ids","reader","createEntityReader","keys","Set","id","partitionKey","has","add","get","PK","SK","records","execute","items","map","item","data","entryId","filter","batchScheduleFn"],"sources":["getLatestRevisionByEntryId.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport { cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup.js\";\nimport type { CmsStorageEntry } from \"@webiny/api-headless-cms/types/index.js\";\nimport { createBatchScheduleFn } from \"./createBatchScheduleFn.js\";\nimport { createLatestSortKey, createPartitionKey } from \"~/operations/entry/keys.js\";\nimport type { IDataLoaderParams } from \"./types.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\n\nexport const createGetLatestRevisionByEntryId = (params: IDataLoaderParams) => {\n const { entity, tenant, modelId } = params;\n\n const latestKey = createLatestSortKey();\n\n return new DataLoader<string, CmsStorageEntry[]>(\n async ids => {\n const reader = entity.createEntityReader();\n\n const keys = new Set<string>();\n\n for (const id of ids) {\n const partitionKey = createPartitionKey({\n tenant,\n id\n });\n if (keys.has(partitionKey)) {\n continue;\n }\n keys.add(partitionKey);\n\n reader.get({\n PK: partitionKey,\n SK: latestKey\n });\n }\n\n const records = await reader.execute();\n const items = cleanupItems(entity.entity, records).map(item => {\n return item.data;\n });\n\n return ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return items.filter(item => {\n if (item.modelId !== modelId) {\n return false;\n }\n return entryId === item.entryId;\n });\n });\n },\n {\n batchScheduleFn: createBatchScheduleFn()\n }\n );\n};\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AACnC,SAASC,YAAY,QAAQ,sCAAsC;AAEnE,SAASC,qBAAqB;AAC9B,SAASC,mBAAmB,EAAEC,kBAAkB;AAEhD,SAASC,eAAe,QAAQ,eAAe;AAE/C,OAAO,MAAMC,gCAAgC,GAAIC,MAAyB,IAAK;EAC3E,MAAM;IAAEC,MAAM;IAAEC,MAAM;IAAEC;EAAQ,CAAC,GAAGH,MAAM;EAE1C,MAAMI,SAAS,GAAGR,mBAAmB,CAAC,CAAC;EAEvC,OAAO,IAAIH,UAAU,CACjB,MAAMY,GAAG,IAAI;IACT,MAAMC,MAAM,GAAGL,MAAM,CAACM,kBAAkB,CAAC,CAAC;IAE1C,MAAMC,IAAI,GAAG,IAAIC,GAAG,CAAS,CAAC;IAE9B,KAAK,MAAMC,EAAE,IAAIL,GAAG,EAAE;MAClB,MAAMM,YAAY,GAAGd,kBAAkB,CAAC;QACpCK,MAAM;QACNQ;MACJ,CAAC,CAAC;MACF,IAAIF,IAAI,CAACI,GAAG,CAACD,YAAY,CAAC,EAAE;QACxB;MACJ;MACAH,IAAI,CAACK,GAAG,CAACF,YAAY,CAAC;MAEtBL,MAAM,CAACQ,GAAG,CAAC;QACPC,EAAE,EAAEJ,YAAY;QAChBK,EAAE,EAAEZ;MACR,CAAC,CAAC;IACN;IAEA,MAAMa,OAAO,GAAG,MAAMX,MAAM,CAACY,OAAO,CAAC,CAAC;IACtC,MAAMC,KAAK,GAAGzB,YAAY,CAACO,MAAM,CAACA,MAAM,EAAEgB,OAAO,CAAC,CAACG,GAAG,CAACC,IAAI,IAAI;MAC3D,OAAOA,IAAI,CAACC,IAAI;IACpB,CAAC,CAAC;IAEF,OAAOjB,GAAG,CAACe,GAAG,CAACV,EAAE,IAAI;MACjB,MAAM;QAAEA,EAAE,EAAEa;MAAQ,CAAC,GAAGzB,eAAe,CAACY,EAAE,CAAC;MAC3C,OAAOS,KAAK,CAACK,MAAM,CAACH,IAAI,IAAI;QACxB,IAAIA,IAAI,CAAClB,OAAO,KAAKA,OAAO,EAAE;UAC1B,OAAO,KAAK;QAChB;QACA,OAAOoB,OAAO,KAAKF,IAAI,CAACE,OAAO;MACnC,CAAC,CAAC;IACN,CAAC,CAAC;EACN,CAAC,EACD;IACIE,eAAe,EAAE9B,qBAAqB,CAAC;EAC3C,CACJ,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -6,7 +6,8 @@ import { createBatchScheduleFn } from "./createBatchScheduleFn.js";
|
|
|
6
6
|
export const createGetPublishedRevisionByEntryId = params => {
|
|
7
7
|
const {
|
|
8
8
|
entity,
|
|
9
|
-
tenant
|
|
9
|
+
tenant,
|
|
10
|
+
modelId
|
|
10
11
|
} = params;
|
|
11
12
|
const publishedKey = createPublishedSortKey();
|
|
12
13
|
return new DataLoader(async ids => {
|
|
@@ -35,6 +36,9 @@ export const createGetPublishedRevisionByEntryId = params => {
|
|
|
35
36
|
id: entryId
|
|
36
37
|
} = parseIdentifier(id);
|
|
37
38
|
return items.filter(item => {
|
|
39
|
+
if (item.modelId !== modelId) {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
38
42
|
return entryId === item.entryId;
|
|
39
43
|
});
|
|
40
44
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DataLoader","cleanupItems","createPartitionKey","createPublishedSortKey","parseIdentifier","createBatchScheduleFn","createGetPublishedRevisionByEntryId","params","entity","tenant","publishedKey","ids","reader","createEntityReader","keys","Set","id","partitionKey","has","add","get","PK","SK","records","execute","items","map","item","data","entryId","filter","batchScheduleFn"],"sources":["getPublishedRevisionByEntryId.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport { cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup.js\";\nimport type { CmsStorageEntry } from \"@webiny/api-headless-cms/types/index.js\";\nimport { createPartitionKey, createPublishedSortKey } from \"~/operations/entry/keys.js\";\nimport type { IDataLoaderParams } from \"./types.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport { createBatchScheduleFn } from \"./createBatchScheduleFn.js\";\n\nexport const createGetPublishedRevisionByEntryId = (params: IDataLoaderParams) => {\n const { entity, tenant } = params;\n\n const publishedKey = createPublishedSortKey();\n return new DataLoader<string, CmsStorageEntry[]>(\n async ids => {\n const reader = entity.createEntityReader();\n\n const keys = new Set<string>();\n\n for (const id of ids) {\n const partitionKey = createPartitionKey({\n tenant,\n id\n });\n if (keys.has(partitionKey)) {\n continue;\n }\n keys.add(partitionKey);\n reader.get({\n PK: partitionKey,\n SK: publishedKey\n });\n }\n\n const records = await reader.execute();\n const items = cleanupItems(entity.entity, records).map(item => {\n return item.data;\n });\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 batchScheduleFn: createBatchScheduleFn()\n }\n );\n};\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AACnC,SAASC,YAAY,QAAQ,sCAAsC;AAEnE,SAASC,kBAAkB,EAAEC,sBAAsB;AAEnD,SAASC,eAAe,QAAQ,eAAe;AAC/C,SAASC,qBAAqB;AAE9B,OAAO,MAAMC,mCAAmC,GAAIC,MAAyB,IAAK;EAC9E,MAAM;IAAEC,MAAM;IAAEC;
|
|
1
|
+
{"version":3,"names":["DataLoader","cleanupItems","createPartitionKey","createPublishedSortKey","parseIdentifier","createBatchScheduleFn","createGetPublishedRevisionByEntryId","params","entity","tenant","modelId","publishedKey","ids","reader","createEntityReader","keys","Set","id","partitionKey","has","add","get","PK","SK","records","execute","items","map","item","data","entryId","filter","batchScheduleFn"],"sources":["getPublishedRevisionByEntryId.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport { cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup.js\";\nimport type { CmsStorageEntry } from \"@webiny/api-headless-cms/types/index.js\";\nimport { createPartitionKey, createPublishedSortKey } from \"~/operations/entry/keys.js\";\nimport type { IDataLoaderParams } from \"./types.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport { createBatchScheduleFn } from \"./createBatchScheduleFn.js\";\n\nexport const createGetPublishedRevisionByEntryId = (params: IDataLoaderParams) => {\n const { entity, tenant, modelId } = params;\n\n const publishedKey = createPublishedSortKey();\n return new DataLoader<string, CmsStorageEntry[]>(\n async ids => {\n const reader = entity.createEntityReader();\n\n const keys = new Set<string>();\n\n for (const id of ids) {\n const partitionKey = createPartitionKey({\n tenant,\n id\n });\n if (keys.has(partitionKey)) {\n continue;\n }\n keys.add(partitionKey);\n reader.get({\n PK: partitionKey,\n SK: publishedKey\n });\n }\n\n const records = await reader.execute();\n const items = cleanupItems(entity.entity, records).map(item => {\n return item.data;\n });\n\n return ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return items.filter(item => {\n if (item.modelId !== modelId) {\n return false;\n }\n return entryId === item.entryId;\n });\n });\n },\n {\n batchScheduleFn: createBatchScheduleFn()\n }\n );\n};\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AACnC,SAASC,YAAY,QAAQ,sCAAsC;AAEnE,SAASC,kBAAkB,EAAEC,sBAAsB;AAEnD,SAASC,eAAe,QAAQ,eAAe;AAC/C,SAASC,qBAAqB;AAE9B,OAAO,MAAMC,mCAAmC,GAAIC,MAAyB,IAAK;EAC9E,MAAM;IAAEC,MAAM;IAAEC,MAAM;IAAEC;EAAQ,CAAC,GAAGH,MAAM;EAE1C,MAAMI,YAAY,GAAGR,sBAAsB,CAAC,CAAC;EAC7C,OAAO,IAAIH,UAAU,CACjB,MAAMY,GAAG,IAAI;IACT,MAAMC,MAAM,GAAGL,MAAM,CAACM,kBAAkB,CAAC,CAAC;IAE1C,MAAMC,IAAI,GAAG,IAAIC,GAAG,CAAS,CAAC;IAE9B,KAAK,MAAMC,EAAE,IAAIL,GAAG,EAAE;MAClB,MAAMM,YAAY,GAAGhB,kBAAkB,CAAC;QACpCO,MAAM;QACNQ;MACJ,CAAC,CAAC;MACF,IAAIF,IAAI,CAACI,GAAG,CAACD,YAAY,CAAC,EAAE;QACxB;MACJ;MACAH,IAAI,CAACK,GAAG,CAACF,YAAY,CAAC;MACtBL,MAAM,CAACQ,GAAG,CAAC;QACPC,EAAE,EAAEJ,YAAY;QAChBK,EAAE,EAAEZ;MACR,CAAC,CAAC;IACN;IAEA,MAAMa,OAAO,GAAG,MAAMX,MAAM,CAACY,OAAO,CAAC,CAAC;IACtC,MAAMC,KAAK,GAAGzB,YAAY,CAACO,MAAM,CAACA,MAAM,EAAEgB,OAAO,CAAC,CAACG,GAAG,CAACC,IAAI,IAAI;MAC3D,OAAOA,IAAI,CAACC,IAAI;IACpB,CAAC,CAAC;IAEF,OAAOjB,GAAG,CAACe,GAAG,CAACV,EAAE,IAAI;MACjB,MAAM;QAAEA,EAAE,EAAEa;MAAQ,CAAC,GAAG1B,eAAe,CAACa,EAAE,CAAC;MAC3C,OAAOS,KAAK,CAACK,MAAM,CAACH,IAAI,IAAI;QACxB,IAAIA,IAAI,CAAClB,OAAO,KAAKA,OAAO,EAAE;UAC1B,OAAO,KAAK;QAChB;QACA,OAAOoB,OAAO,KAAKF,IAAI,CAACE,OAAO;MACnC,CAAC,CAAC;IACN,CAAC,CAAC;EACN,CAAC,EACD;IACIE,eAAe,EAAE3B,qBAAqB,CAAC;EAC3C,CACJ,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -6,7 +6,8 @@ import { createBatchScheduleFn } from "./createBatchScheduleFn.js";
|
|
|
6
6
|
export const createGetRevisionById = params => {
|
|
7
7
|
const {
|
|
8
8
|
entity,
|
|
9
|
-
tenant
|
|
9
|
+
tenant,
|
|
10
|
+
modelId
|
|
10
11
|
} = params;
|
|
11
12
|
return new DataLoader(async ids => {
|
|
12
13
|
const reader = entity.createEntityReader();
|
|
@@ -41,6 +42,9 @@ export const createGetRevisionById = params => {
|
|
|
41
42
|
});
|
|
42
43
|
return ids.map(id => {
|
|
43
44
|
return items.filter(item => {
|
|
45
|
+
if (item.modelId !== modelId) {
|
|
46
|
+
return false;
|
|
47
|
+
}
|
|
44
48
|
return id === item.id;
|
|
45
49
|
});
|
|
46
50
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DataLoader","cleanupItems","createPartitionKey","createRevisionSortKey","parseIdentifier","createBatchScheduleFn","createGetRevisionById","params","entity","tenant","ids","reader","createEntityReader","keys","Set","id","partitionKey","version","sortKey","key","has","add","get","PK","SK","records","execute","items","map","item","data","filter","batchScheduleFn"],"sources":["getRevisionById.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport type { CmsStorageEntry } from \"@webiny/api-headless-cms/types/index.js\";\nimport { cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup.js\";\nimport { createPartitionKey, createRevisionSortKey } from \"~/operations/entry/keys.js\";\nimport type { IDataLoaderParams } from \"./types.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport { createBatchScheduleFn } from \"./createBatchScheduleFn.js\";\n\nexport const createGetRevisionById = (params: IDataLoaderParams) => {\n const { entity, tenant } = params;\n\n return new DataLoader<string, CmsStorageEntry[]>(\n async ids => {\n const reader = entity.createEntityReader();\n\n const keys = new Set<string>();\n\n for (const id of ids) {\n const partitionKey = createPartitionKey({\n tenant,\n id\n });\n const { version } = parseIdentifier(id);\n if (version === null) {\n continue;\n }\n const sortKey = createRevisionSortKey({\n version\n });\n const key = `${partitionKey}__${sortKey}`;\n if (keys.has(key)) {\n continue;\n }\n keys.add(key);\n\n reader.get({\n PK: partitionKey,\n SK: sortKey\n });\n }\n\n const records = await reader.execute();\n const items = cleanupItems(entity.entity, records).map(item => {\n return item.data;\n });\n\n return ids.map(id => {\n return items.filter(item => {\n return id === item.id;\n });\n });\n },\n {\n batchScheduleFn: createBatchScheduleFn()\n }\n );\n};\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AAEnC,SAASC,YAAY,QAAQ,sCAAsC;AACnE,SAASC,kBAAkB,EAAEC,qBAAqB;AAElD,SAASC,eAAe,QAAQ,eAAe;AAC/C,SAASC,qBAAqB;AAE9B,OAAO,MAAMC,qBAAqB,GAAIC,MAAyB,IAAK;EAChE,MAAM;IAAEC,MAAM;IAAEC;
|
|
1
|
+
{"version":3,"names":["DataLoader","cleanupItems","createPartitionKey","createRevisionSortKey","parseIdentifier","createBatchScheduleFn","createGetRevisionById","params","entity","tenant","modelId","ids","reader","createEntityReader","keys","Set","id","partitionKey","version","sortKey","key","has","add","get","PK","SK","records","execute","items","map","item","data","filter","batchScheduleFn"],"sources":["getRevisionById.ts"],"sourcesContent":["import DataLoader from \"dataloader\";\nimport type { CmsStorageEntry } from \"@webiny/api-headless-cms/types/index.js\";\nimport { cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup.js\";\nimport { createPartitionKey, createRevisionSortKey } from \"~/operations/entry/keys.js\";\nimport type { IDataLoaderParams } from \"./types.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport { createBatchScheduleFn } from \"./createBatchScheduleFn.js\";\n\nexport const createGetRevisionById = (params: IDataLoaderParams) => {\n const { entity, tenant, modelId } = params;\n\n return new DataLoader<string, CmsStorageEntry[]>(\n async ids => {\n const reader = entity.createEntityReader();\n\n const keys = new Set<string>();\n\n for (const id of ids) {\n const partitionKey = createPartitionKey({\n tenant,\n id\n });\n const { version } = parseIdentifier(id);\n if (version === null) {\n continue;\n }\n const sortKey = createRevisionSortKey({\n version\n });\n const key = `${partitionKey}__${sortKey}`;\n if (keys.has(key)) {\n continue;\n }\n keys.add(key);\n\n reader.get({\n PK: partitionKey,\n SK: sortKey\n });\n }\n\n const records = await reader.execute();\n const items = cleanupItems(entity.entity, records).map(item => {\n return item.data;\n });\n\n return ids.map(id => {\n return items.filter(item => {\n if (item.modelId !== modelId) {\n return false;\n }\n return id === item.id;\n });\n });\n },\n {\n batchScheduleFn: createBatchScheduleFn()\n }\n );\n};\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,YAAY;AAEnC,SAASC,YAAY,QAAQ,sCAAsC;AACnE,SAASC,kBAAkB,EAAEC,qBAAqB;AAElD,SAASC,eAAe,QAAQ,eAAe;AAC/C,SAASC,qBAAqB;AAE9B,OAAO,MAAMC,qBAAqB,GAAIC,MAAyB,IAAK;EAChE,MAAM;IAAEC,MAAM;IAAEC,MAAM;IAAEC;EAAQ,CAAC,GAAGH,MAAM;EAE1C,OAAO,IAAIP,UAAU,CACjB,MAAMW,GAAG,IAAI;IACT,MAAMC,MAAM,GAAGJ,MAAM,CAACK,kBAAkB,CAAC,CAAC;IAE1C,MAAMC,IAAI,GAAG,IAAIC,GAAG,CAAS,CAAC;IAE9B,KAAK,MAAMC,EAAE,IAAIL,GAAG,EAAE;MAClB,MAAMM,YAAY,GAAGf,kBAAkB,CAAC;QACpCO,MAAM;QACNO;MACJ,CAAC,CAAC;MACF,MAAM;QAAEE;MAAQ,CAAC,GAAGd,eAAe,CAACY,EAAE,CAAC;MACvC,IAAIE,OAAO,KAAK,IAAI,EAAE;QAClB;MACJ;MACA,MAAMC,OAAO,GAAGhB,qBAAqB,CAAC;QAClCe;MACJ,CAAC,CAAC;MACF,MAAME,GAAG,GAAG,GAAGH,YAAY,KAAKE,OAAO,EAAE;MACzC,IAAIL,IAAI,CAACO,GAAG,CAACD,GAAG,CAAC,EAAE;QACf;MACJ;MACAN,IAAI,CAACQ,GAAG,CAACF,GAAG,CAAC;MAEbR,MAAM,CAACW,GAAG,CAAC;QACPC,EAAE,EAAEP,YAAY;QAChBQ,EAAE,EAAEN;MACR,CAAC,CAAC;IACN;IAEA,MAAMO,OAAO,GAAG,MAAMd,MAAM,CAACe,OAAO,CAAC,CAAC;IACtC,MAAMC,KAAK,GAAG3B,YAAY,CAACO,MAAM,CAACA,MAAM,EAAEkB,OAAO,CAAC,CAACG,GAAG,CAACC,IAAI,IAAI;MAC3D,OAAOA,IAAI,CAACC,IAAI;IACpB,CAAC,CAAC;IAEF,OAAOpB,GAAG,CAACkB,GAAG,CAACb,EAAE,IAAI;MACjB,OAAOY,KAAK,CAACI,MAAM,CAACF,IAAI,IAAI;QACxB,IAAIA,IAAI,CAACpB,OAAO,KAAKA,OAAO,EAAE;UAC1B,OAAO,KAAK;QAChB;QACA,OAAOM,EAAE,KAAKc,IAAI,CAACd,EAAE;MACzB,CAAC,CAAC;IACN,CAAC,CAAC;EACN,CAAC,EACD;IACIiB,eAAe,EAAE5B,qBAAqB,CAAC;EAC3C,CACJ,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import type { IEntryEntity } from \"~/definitions/types.js\";\n\nexport interface IDataLoaderParams {\n entity: IEntryEntity;\n tenant: string;\n}\n"],"mappings":"","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import type { IEntryEntity } from \"~/definitions/types.js\";\n\nexport interface IDataLoaderParams {\n entity: IEntryEntity;\n tenant: string;\n modelId: string;\n}\n"],"mappings":"","ignoreList":[]}
|
|
@@ -48,6 +48,7 @@ export class DataLoadersHandler {
|
|
|
48
48
|
} = params;
|
|
49
49
|
const cacheParams = {
|
|
50
50
|
tenant: model.tenant,
|
|
51
|
+
modelId: model.modelId,
|
|
51
52
|
name
|
|
52
53
|
};
|
|
53
54
|
let loader = this.cache.getDataLoader(cacheParams);
|
|
@@ -57,7 +58,8 @@ export class DataLoadersHandler {
|
|
|
57
58
|
const factory = getDataLoaderFactory(name);
|
|
58
59
|
loader = factory({
|
|
59
60
|
entity: this.entity,
|
|
60
|
-
tenant: model.tenant
|
|
61
|
+
tenant: model.tenant,
|
|
62
|
+
modelId: model.modelId
|
|
61
63
|
});
|
|
62
64
|
this.cache.setDataLoader(cacheParams, loader);
|
|
63
65
|
return loader;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["WebinyError","DataLoaderCache","getDataLoaderFactory","parseIdentifier","DataLoadersHandler","cache","constructor","params","entity","getAllEntryRevisions","ids","map","id","entryId","loadMany","getRevisionById","getPublishedRevisionByEntryId","getLatestRevisionByEntryId","getLoader","name","model","cacheParams","tenant","loader","getDataLoader","factory","setDataLoader","results","Array","isArray","reduce","acc","res","message","code","data","JSON","stringify","push","ex","error","clearAll"],"sources":["dataLoaders.ts"],"sourcesContent":["import type DataLoader from \"dataloader\";\nimport WebinyError from \"@webiny/error\";\nimport type {\n CmsEntryValues,\n CmsModel,\n CmsStorageEntry\n} from \"@webiny/api-headless-cms/types/index.js\";\nimport type { CacheKeyParams } from \"~/operations/entry/dataLoader/DataLoaderCache.js\";\nimport { DataLoaderCache } from \"~/operations/entry/dataLoader/DataLoaderCache.js\";\nimport type { DataLoaders } from \"~/operations/entry/dataLoader/index.js\";\nimport { getDataLoaderFactory } from \"~/operations/entry/dataLoader/index.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport type {\n DataLoadersHandlerInterfaceClearAllParams,\n IDataLoadersHandler,\n IEntryEntity\n} from \"~/types.js\";\n\ninterface DataLoaderParams {\n model: Pick<CmsModel, \"tenant\" | \"modelId\">;\n ids: readonly string[];\n}\n\ninterface GetLoaderParams {\n model: Pick<CmsModel, \"tenant\" | \"modelId\">;\n}\n\ninterface IDataLoadersHandlerParams {\n entity: IEntryEntity;\n}\n\nexport class DataLoadersHandler implements IDataLoadersHandler {\n private readonly entity;\n private readonly cache = new DataLoaderCache();\n\n public constructor(params: IDataLoadersHandlerParams) {\n this.entity = params.entity;\n }\n\n public async getAllEntryRevisions<T extends CmsEntryValues = CmsEntryValues>(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry<T>[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany<T>(\"getAllEntryRevisions\", params, ids);\n }\n\n public async getRevisionById<T extends CmsEntryValues = CmsEntryValues>(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry<T>[]> {\n return await this.loadMany<T>(\"getRevisionById\", params, params.ids);\n }\n\n public async getPublishedRevisionByEntryId<T extends CmsEntryValues = CmsEntryValues>(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry<T>[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany<T>(\"getPublishedRevisionByEntryId\", params, ids);\n }\n\n public async getLatestRevisionByEntryId<T extends CmsEntryValues = CmsEntryValues>(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry<T>[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany<T>(\"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 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 });\n this.cache.setDataLoader(cacheParams, loader);\n return loader;\n }\n\n private async loadMany<T extends CmsEntryValues = CmsEntryValues>(\n loader: DataLoaders,\n params: GetLoaderParams,\n ids: readonly string[]\n ): Promise<CmsStorageEntry<T>[]> {\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":"AACA,OAAOA,WAAW,MAAM,eAAe;AAOvC,SAASC,eAAe;AAExB,SAASC,oBAAoB;AAC7B,SAASC,eAAe,QAAQ,eAAe;AAoB/C,OAAO,MAAMC,kBAAkB,CAAgC;EAE1CC,KAAK,GAAG,IAAIJ,eAAe,CAAC,CAAC;EAEvCK,WAAWA,CAACC,MAAiC,EAAE;IAClD,IAAI,CAACC,MAAM,GAAGD,MAAM,CAACC,MAAM;EAC/B;EAEA,MAAaC,oBAAoBA,CAC7BF,MAAwB,EACK;IAC7B,MAAMG,GAAG,GAAGH,MAAM,CAACG,GAAG,CAACC,GAAG,CAACC,EAAE,IAAI;MAC7B,MAAM;QAAEA,EAAE,EAAEC;MAAQ,CAAC,GAAGV,eAAe,CAACS,EAAE,CAAC;MAC3C,OAAOC,OAAO;IAClB,CAAC,CAAC;IACF,OAAO,MAAM,IAAI,CAACC,QAAQ,CAAI,sBAAsB,EAAEP,MAAM,EAAEG,GAAG,CAAC;EACtE;EAEA,MAAaK,eAAeA,CACxBR,MAAwB,EACK;IAC7B,OAAO,MAAM,IAAI,CAACO,QAAQ,CAAI,iBAAiB,EAAEP,MAAM,EAAEA,MAAM,CAACG,GAAG,CAAC;EACxE;EAEA,MAAaM,6BAA6BA,CACtCT,MAAwB,EACK;IAC7B,MAAMG,GAAG,GAAGH,MAAM,CAACG,GAAG,CAACC,GAAG,CAACC,EAAE,IAAI;MAC7B,MAAM;QAAEA,EAAE,EAAEC;MAAQ,CAAC,GAAGV,eAAe,CAACS,EAAE,CAAC;MAC3C,OAAOC,OAAO;IAClB,CAAC,CAAC;IACF,OAAO,MAAM,IAAI,CAACC,QAAQ,CAAI,+BAA+B,EAAEP,MAAM,EAAEG,GAAG,CAAC;EAC/E;EAEA,MAAaO,0BAA0BA,CACnCV,MAAwB,EACK;IAC7B,MAAMG,GAAG,GAAGH,MAAM,CAACG,GAAG,CAACC,GAAG,CAACC,EAAE,IAAI;MAC7B,MAAM;QAAEA,EAAE,EAAEC;MAAQ,CAAC,GAAGV,eAAe,CAACS,EAAE,CAAC;MAC3C,OAAOC,OAAO;IAClB,CAAC,CAAC;IACF,OAAO,MAAM,IAAI,CAACC,QAAQ,CAAI,4BAA4B,EAAEP,MAAM,EAAEG,GAAG,CAAC;EAC5E;;EAEA;AACJ;AACA;AACA;EACYQ,SAASA,CAACC,IAAiB,EAAEZ,MAAuB,EAAwB;IAChF,MAAM;MAAEa;IAAM,CAAC,GAAGb,MAAM;IACxB,MAAMc,WAA2B,GAAG;MAChCC,MAAM,EAAEF,KAAK,CAACE,MAAM;
|
|
1
|
+
{"version":3,"names":["WebinyError","DataLoaderCache","getDataLoaderFactory","parseIdentifier","DataLoadersHandler","cache","constructor","params","entity","getAllEntryRevisions","ids","map","id","entryId","loadMany","getRevisionById","getPublishedRevisionByEntryId","getLatestRevisionByEntryId","getLoader","name","model","cacheParams","tenant","modelId","loader","getDataLoader","factory","setDataLoader","results","Array","isArray","reduce","acc","res","message","code","data","JSON","stringify","push","ex","error","clearAll"],"sources":["dataLoaders.ts"],"sourcesContent":["import type DataLoader from \"dataloader\";\nimport WebinyError from \"@webiny/error\";\nimport type {\n CmsEntryValues,\n CmsModel,\n CmsStorageEntry\n} from \"@webiny/api-headless-cms/types/index.js\";\nimport type { CacheKeyParams } from \"~/operations/entry/dataLoader/DataLoaderCache.js\";\nimport { DataLoaderCache } from \"~/operations/entry/dataLoader/DataLoaderCache.js\";\nimport type { DataLoaders } from \"~/operations/entry/dataLoader/index.js\";\nimport { getDataLoaderFactory } from \"~/operations/entry/dataLoader/index.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport type {\n DataLoadersHandlerInterfaceClearAllParams,\n IDataLoadersHandler,\n IEntryEntity\n} from \"~/types.js\";\n\ninterface DataLoaderParams {\n model: Pick<CmsModel, \"tenant\" | \"modelId\">;\n ids: readonly string[];\n}\n\ninterface GetLoaderParams {\n model: Pick<CmsModel, \"tenant\" | \"modelId\">;\n}\n\ninterface IDataLoadersHandlerParams {\n entity: IEntryEntity;\n}\n\nexport class DataLoadersHandler implements IDataLoadersHandler {\n private readonly entity;\n private readonly cache = new DataLoaderCache();\n\n public constructor(params: IDataLoadersHandlerParams) {\n this.entity = params.entity;\n }\n\n public async getAllEntryRevisions<T extends CmsEntryValues = CmsEntryValues>(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry<T>[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany<T>(\"getAllEntryRevisions\", params, ids);\n }\n\n public async getRevisionById<T extends CmsEntryValues = CmsEntryValues>(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry<T>[]> {\n return await this.loadMany<T>(\"getRevisionById\", params, params.ids);\n }\n\n public async getPublishedRevisionByEntryId<T extends CmsEntryValues = CmsEntryValues>(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry<T>[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany<T>(\"getPublishedRevisionByEntryId\", params, ids);\n }\n\n public async getLatestRevisionByEntryId<T extends CmsEntryValues = CmsEntryValues>(\n params: DataLoaderParams\n ): Promise<CmsStorageEntry<T>[]> {\n const ids = params.ids.map(id => {\n const { id: entryId } = parseIdentifier(id);\n return entryId;\n });\n return await this.loadMany<T>(\"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 modelId: model.modelId,\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 modelId: model.modelId\n });\n this.cache.setDataLoader(cacheParams, loader);\n return loader;\n }\n\n private async loadMany<T extends CmsEntryValues = CmsEntryValues>(\n loader: DataLoaders,\n params: GetLoaderParams,\n ids: readonly string[]\n ): Promise<CmsStorageEntry<T>[]> {\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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","ignoreList":[]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import WebinyError from "@webiny/error";
|
|
2
|
-
import dotProp from "dot-prop";
|
|
2
|
+
import * as dotProp from "dot-prop";
|
|
3
3
|
import lodashSortBy from "lodash/sortBy.js";
|
|
4
4
|
import { extractSort } from "./extractSort.js";
|
|
5
5
|
export const sort = params => {
|
|
@@ -39,7 +39,7 @@ export const sort = params => {
|
|
|
39
39
|
const itemsToSort = items.map(item => {
|
|
40
40
|
return {
|
|
41
41
|
id: item.id,
|
|
42
|
-
value: field.transform(dotProp.
|
|
42
|
+
value: field.transform(dotProp.getProperty(item, valuePath))
|
|
43
43
|
};
|
|
44
44
|
});
|
|
45
45
|
const sortedItems = lodashSortBy(itemsToSort, "value");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["WebinyError","dotProp","lodashSortBy","extractSort","sort","params","model","items","fields","plugins","length","push","firstSort","fieldId","field","valuePath","reverse","sortBy","itemsToSort","map","item","id","value","transform","
|
|
1
|
+
{"version":3,"names":["WebinyError","dotProp","lodashSortBy","extractSort","sort","params","model","items","fields","plugins","length","push","firstSort","fieldId","field","valuePath","reverse","sortBy","itemsToSort","map","item","id","value","transform","getProperty","sortedItems","newItems","s","find","i","sortingBy"],"sources":["sort.ts"],"sourcesContent":["import type { CmsEntry, CmsEntryValues, CmsModel } from \"@webiny/api-headless-cms/types/index.js\";\nimport WebinyError from \"@webiny/error\";\nimport * as dotProp from \"dot-prop\";\nimport lodashSortBy from \"lodash/sortBy.js\";\nimport { extractSort } from \"./extractSort.js\";\nimport type { Field } from \"./types.js\";\nimport type { PluginsContainer } from \"@webiny/plugins\";\n\ninterface Params<T extends CmsEntryValues = CmsEntryValues> {\n model: CmsModel;\n items: CmsEntry<T>[];\n sort?: string[];\n fields: Record<string, Field>;\n plugins: PluginsContainer;\n}\n\ninterface SortedItem {\n id: string;\n value: any;\n}\n\nexport const sort = <T extends CmsEntryValues = CmsEntryValues>(\n params: Params<T>\n): CmsEntry<T>[] => {\n const { model, items, sort = [], fields, plugins } = params;\n if (items.length <= 1) {\n return items;\n } else if (sort.length === 0) {\n sort.push(\"savedOn_DESC\");\n } else if (sort.length > 1) {\n throw new WebinyError(\n \"Sorting is limited to a single field on DynamoDB only system.\",\n \"SORT_MULTIPLE_FIELDS_ERROR\",\n {\n sort\n }\n );\n }\n const [firstSort] = sort;\n if (!firstSort) {\n throw new WebinyError(\"Empty sort array item.\", \"SORT_EMPTY_ERROR\", {\n sort\n });\n }\n\n const { fieldId, field, valuePath, reverse } = extractSort({\n model,\n sortBy: firstSort,\n fields,\n plugins\n });\n\n const itemsToSort = items.map(item => {\n return {\n id: item.id,\n value: field.transform(dotProp.getProperty(item, valuePath))\n };\n });\n const sortedItems: SortedItem[] = lodashSortBy(itemsToSort, \"value\");\n const newItems = sortedItems.map(s => {\n const item = items.find(i => i.id === s.id);\n if (item) {\n return item;\n }\n /**\n * This is impossible to happen because sorting items does not remove the items.\n * BUT, we need to have this check just in case for development purposes.\n */\n throw new WebinyError(\n \"Could not find item by given id after the sorting.\",\n \"SORTING_ITEMS_ERROR\",\n {\n id: s.id,\n sortingBy: fieldId,\n reverse\n }\n );\n });\n if (!reverse) {\n return newItems;\n }\n return newItems.reverse();\n};\n"],"mappings":"AACA,OAAOA,WAAW,MAAM,eAAe;AACvC,OAAO,KAAKC,OAAO,MAAM,UAAU;AACnC,OAAOC,YAAY,MAAM,kBAAkB;AAC3C,SAASC,WAAW;AAiBpB,OAAO,MAAMC,IAAI,GACbC,MAAiB,IACD;EAChB,MAAM;IAAEC,KAAK;IAAEC,KAAK;IAAEH,IAAI,GAAG,EAAE;IAAEI,MAAM;IAAEC;EAAQ,CAAC,GAAGJ,MAAM;EAC3D,IAAIE,KAAK,CAACG,MAAM,IAAI,CAAC,EAAE;IACnB,OAAOH,KAAK;EAChB,CAAC,MAAM,IAAIH,IAAI,CAACM,MAAM,KAAK,CAAC,EAAE;IAC1BN,IAAI,CAACO,IAAI,CAAC,cAAc,CAAC;EAC7B,CAAC,MAAM,IAAIP,IAAI,CAACM,MAAM,GAAG,CAAC,EAAE;IACxB,MAAM,IAAIV,WAAW,CACjB,+DAA+D,EAC/D,4BAA4B,EAC5B;MACII;IACJ,CACJ,CAAC;EACL;EACA,MAAM,CAACQ,SAAS,CAAC,GAAGR,IAAI;EACxB,IAAI,CAACQ,SAAS,EAAE;IACZ,MAAM,IAAIZ,WAAW,CAAC,wBAAwB,EAAE,kBAAkB,EAAE;MAChEI;IACJ,CAAC,CAAC;EACN;EAEA,MAAM;IAAES,OAAO;IAAEC,KAAK;IAAEC,SAAS;IAAEC;EAAQ,CAAC,GAAGb,WAAW,CAAC;IACvDG,KAAK;IACLW,MAAM,EAAEL,SAAS;IACjBJ,MAAM;IACNC;EACJ,CAAC,CAAC;EAEF,MAAMS,WAAW,GAAGX,KAAK,CAACY,GAAG,CAACC,IAAI,IAAI;IAClC,OAAO;MACHC,EAAE,EAAED,IAAI,CAACC,EAAE;MACXC,KAAK,EAAER,KAAK,CAACS,SAAS,CAACtB,OAAO,CAACuB,WAAW,CAACJ,IAAI,EAAEL,SAAS,CAAC;IAC/D,CAAC;EACL,CAAC,CAAC;EACF,MAAMU,WAAyB,GAAGvB,YAAY,CAACgB,WAAW,EAAE,OAAO,CAAC;EACpE,MAAMQ,QAAQ,GAAGD,WAAW,CAACN,GAAG,CAACQ,CAAC,IAAI;IAClC,MAAMP,IAAI,GAAGb,KAAK,CAACqB,IAAI,CAACC,CAAC,IAAIA,CAAC,CAACR,EAAE,KAAKM,CAAC,CAACN,EAAE,CAAC;IAC3C,IAAID,IAAI,EAAE;MACN,OAAOA,IAAI;IACf;IACA;AACR;AACA;AACA;IACQ,MAAM,IAAIpB,WAAW,CACjB,oDAAoD,EACpD,qBAAqB,EACrB;MACIqB,EAAE,EAAEM,CAAC,CAACN,EAAE;MACRS,SAAS,EAAEjB,OAAO;MAClBG;IACJ,CACJ,CAAC;EACL,CAAC,CAAC;EACF,IAAI,CAACA,OAAO,EAAE;IACV,OAAOU,QAAQ;EACnB;EACA,OAAOA,QAAQ,CAACV,OAAO,CAAC,CAAC;AAC7B,CAAC","ignoreList":[]}
|
|
@@ -423,6 +423,9 @@ export const createEntriesStorageOperations = params => {
|
|
|
423
423
|
*/
|
|
424
424
|
try {
|
|
425
425
|
await entityBatch.execute();
|
|
426
|
+
dataLoaders.clearAll({
|
|
427
|
+
model
|
|
428
|
+
});
|
|
426
429
|
} catch (ex) {
|
|
427
430
|
throw new WebinyError(ex.message || "Could not move the entry to the bin.", ex.code || "MOVE_ENTRY_TO_BIN_ERROR", {
|
|
428
431
|
error: ex,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["WebinyError","DataLoadersHandler","CONTENT_ENTRY_STATUS","createEntryLatestKeys","createEntryPublishedKeys","createEntryRevisionKeys","createGSIPartitionKey","createPartitionKey","createPublishedSortKey","createRevisionSortKey","decodeCursor","encodeCursor","StorageOperationsCmsModelPlugin","StorageTransformPlugin","createFields","filter","sort","isDeletedEntryMetaField","isEntryLevelEntryMetaField","isRestoredEntryMetaField","pickEntryMetaFields","getBaseFieldType","convertToStorageEntry","params","model","storageEntry","values","convertValueKeyToStorage","fields","convertFromStorageEntry","convertValueKeyFromStorage","MAX_LIST_LIMIT","createEntriesStorageOperations","entity","plugins","storageOperationsCmsModelPlugin","getStorageOperationsCmsModelPlugin","oneByType","type","getStorageOperationsModel","plugin","getModel","dataLoaders","createStorageTransformCallable","storageTransformPlugins","byType","reduce","collection","fieldType","field","value","fromStorage","getStoragePlugin","create","initialModel","entry","initialStorageEntry","isPublished","status","locked","storageEntryRevisionKeys","storageEntryLatestKeys","entityBatch","createEntityWriter","put","data","storageEntryPublishedKeys","execute","clearAll","ex","message","code","error","createRevisionFrom","publishedRevisionStorageEntry","getPublishedRevisionByEntryId","ids","id","UNPUBLISHED","update","latestStorageEntry","getLatestRevisionByEntryId","updatingLatestRevision","updatedEntryLevelMetaFields","move","folderId","partitionKey","tenant","records","queryAll","options","gte","map","item","location","from","moveToBin","length","updatedDeletedMetaFields","record","wbyDeleted","binOriginalFolderId","deleteEntry","entryId","delete","PK","SK","restoreFromBin","updatedRestoredMetaFields","deleteRevision","latestEntry","initialLatestStorageEntry","publishedStorageEntry","deleteMultipleEntries","entries","revisions","getAllEntryRevisions","revision","version","items","shift","getRevisionById","getRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","unfilteredRevisions","beginsWith","reverse","filteredRevisions","list","limit","initialLimit","where","initialWhere","after","sortBy","search","published","index","storageEntries","hasMoreItems","totalCount","cursor","modelFields","Promise","all","fieldId","filteredItems","fullTextSearch","term","sortedItems","start","parseInt","end","undefined","slicedItems","slice","get","publish","initialPublishedStorageEntry","publishedRevisionId","publishingLatestRevision","latestRevisionStatus","PUBLISHED","latestStorageEntryFields","publishedRevisionDifferentFromLatest","unpublish","unpublishingLatestRevision","getUniqueFieldValues","find","f","result","fieldValue","Array","isArray","count","Object","a","b"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { DataLoadersHandler } from \"./dataLoaders.js\";\nimport type {\n CmsEntry,\n CmsEntryListWhere,\n CmsEntryStorageOperationsGetByIdsParams,\n CmsEntryStorageOperationsGetLatestByIdsParams,\n CmsEntryStorageOperationsGetLatestRevisionParams,\n CmsEntryStorageOperationsGetParams,\n CmsEntryStorageOperationsGetPreviousRevisionParams,\n CmsEntryStorageOperationsGetPublishedByIdsParams,\n CmsEntryStorageOperationsGetPublishedRevisionParams,\n CmsEntryStorageOperationsGetRevisionParams,\n CmsEntryStorageOperationsGetRevisionsParams,\n CmsEntryStorageOperationsListParams,\n CmsEntryStorageOperationsPublishParams,\n CmsEntryStorageOperationsRestoreFromBinParams,\n CmsEntryStorageOperationsUnpublishParams,\n CmsEntryUniqueValue,\n CmsEntryValues,\n CmsModel,\n CmsStorageEntry,\n StorageOperationsCmsModel\n} from \"@webiny/api-headless-cms/types/index.js\";\nimport { CONTENT_ENTRY_STATUS } from \"@webiny/api-headless-cms/types/index.js\";\nimport {\n createEntryLatestKeys,\n createEntryPublishedKeys,\n createEntryRevisionKeys,\n createGSIPartitionKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys.js\";\nimport type { PluginsContainer } from \"@webiny/plugins\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils\";\nimport { StorageOperationsCmsModelPlugin, StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport type { FilterItemFromStorage } from \"./filtering/types.js\";\nimport { createFields } from \"~/operations/entry/filtering/createFields.js\";\nimport { filter, sort } from \"~/operations/entry/filtering/index.js\";\nimport type { CmsEntryStorageOperations, IEntryEntity } from \"~/types.js\";\nimport {\n isDeletedEntryMetaField,\n isEntryLevelEntryMetaField,\n isRestoredEntryMetaField,\n pickEntryMetaFields\n} from \"@webiny/api-headless-cms/constants.js\";\nimport { getBaseFieldType } from \"@webiny/api-headless-cms/utils/getBaseFieldType.js\";\n\ninterface ConvertStorageEntryParams<T extends CmsEntryValues = CmsEntryValues> {\n storageEntry: CmsStorageEntry<T>;\n model: StorageOperationsCmsModel<T>;\n}\n\nconst convertToStorageEntry = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyToStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nconst convertFromStorageEntry = <T extends CmsEntryValues = CmsEntryValues>(\n params: ConvertStorageEntryParams<T>\n): CmsStorageEntry<T> => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyFromStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nconst MAX_LIST_LIMIT = 1000000;\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: IEntryEntity;\n plugins: PluginsContainer;\n}\n\nexport const createEntriesStorageOperations = (\n params: CreateEntriesStorageOperationsParams\n): CmsEntryStorageOperations => {\n const { entity, plugins } = params;\n\n let storageOperationsCmsModelPlugin: StorageOperationsCmsModelPlugin | undefined;\n const getStorageOperationsCmsModelPlugin = () => {\n if (storageOperationsCmsModelPlugin) {\n return storageOperationsCmsModelPlugin;\n }\n storageOperationsCmsModelPlugin = plugins.oneByType<StorageOperationsCmsModelPlugin>(\n StorageOperationsCmsModelPlugin.type\n );\n return storageOperationsCmsModelPlugin;\n };\n\n const getStorageOperationsModel = <T extends CmsEntryValues = CmsEntryValues>(\n model: CmsModel\n ): StorageOperationsCmsModel<T> => {\n const plugin = getStorageOperationsCmsModelPlugin();\n return plugin.getModel<T>(model);\n };\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const createStorageTransformCallable = (\n model: StorageOperationsCmsModel\n ): FilterItemFromStorage => {\n // Cache StorageTransformPlugin to optimize execution.\n const storageTransformPlugins = plugins\n .byType<StorageTransformPlugin>(StorageTransformPlugin.type)\n .reduce(\n (collection, plugin) => {\n collection[plugin.fieldType] = plugin;\n return collection;\n },\n {} as Record<string, StorageTransformPlugin>\n );\n\n return (field, value) => {\n const fieldType = getBaseFieldType(field);\n\n const plugin: StorageTransformPlugin = storageTransformPlugins[fieldType];\n if (!plugin) {\n return value;\n }\n return plugin.fromStorage({\n model,\n field,\n value,\n getStoragePlugin(fieldType: string): StorageTransformPlugin {\n return storageTransformPlugins[fieldType] || storageTransformPlugins[\"*\"];\n },\n plugins\n });\n };\n };\n\n const create: CmsEntryStorageOperations[\"create\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const isPublished = entry.status === \"published\";\n\n const locked = isPublished ? true : entry.locked;\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n\n const storageEntryRevisionKeys = createEntryRevisionKeys(entry);\n const storageEntryLatestKeys = createEntryLatestKeys(entry);\n /**\n * We need to:\n * - create new main entry item\n * - create new or update the latest entry item\n */\n const entityBatch = entity.createEntityWriter({\n put: [\n {\n ...storageEntryRevisionKeys,\n data: {\n ...storageEntry,\n locked\n }\n },\n {\n ...storageEntryLatestKeys,\n data: {\n ...storageEntry,\n locked\n }\n }\n ]\n });\n\n /**\n * We need to create published entry if\n */\n if (isPublished) {\n const storageEntryPublishedKeys = createEntryPublishedKeys(storageEntry);\n entityBatch.put({\n ...storageEntryPublishedKeys,\n data: {\n ...storageEntry,\n locked\n }\n });\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert data into the DynamoDB.\",\n ex.code || \"CREATE_ENTRY_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n\n return initialStorageEntry;\n };\n\n const createRevisionFrom: CmsEntryStorageOperations[\"createRevisionFrom\"] = async (\n initialModel,\n params\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n\n /**\n * We need to:\n * - create the main entry item\n * - update the latest entry item to the current one\n * - if the entry's status was set to \"published\":\n * - update the published entry item to the current one\n * - unpublish previously published revision (if any)\n */\n const entityBatch = entity.createEntityWriter({\n put: [\n {\n ...createEntryRevisionKeys(storageEntry),\n data: {\n ...storageEntry\n }\n },\n {\n ...createEntryLatestKeys(storageEntry),\n data: {\n ...storageEntry\n }\n }\n ]\n });\n\n const isPublished = entry.status === \"published\";\n if (isPublished) {\n entityBatch.put({\n ...createEntryPublishedKeys(storageEntry),\n data: {\n ...storageEntry\n }\n });\n\n // Unpublish previously published revision (if any).\n const [publishedRevisionStorageEntry] = await dataLoaders.getPublishedRevisionByEntryId(\n {\n model,\n ids: [entry.id]\n }\n );\n\n if (publishedRevisionStorageEntry) {\n entityBatch.put({\n ...createEntryRevisionKeys(publishedRevisionStorageEntry),\n data: {\n ...publishedRevisionStorageEntry,\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED\n }\n });\n }\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create revision from given entry.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n /**\n * There are no modifications on the entry created so just return the data.\n */\n return initialStorageEntry;\n };\n\n const update: CmsEntryStorageOperations[\"update\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to:\n * - update the current entry\n * - update the latest entry if the current entry is the latest one\n */\n\n const entityBatch = entity.createEntityWriter({\n put: [\n {\n ...createEntryRevisionKeys(storageEntry),\n data: {\n ...storageEntry,\n locked\n }\n }\n ]\n });\n\n if (isPublished) {\n entityBatch.put({\n ...createEntryPublishedKeys(storageEntry),\n data: {\n ...storageEntry,\n locked\n }\n });\n }\n\n /**\n * We need the latest entry to update it as well if necessary.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry) {\n const updatingLatestRevision = latestStorageEntry.id === entry.id;\n if (updatingLatestRevision) {\n entityBatch.put({\n ...createEntryLatestKeys(storageEntry),\n data: {\n ...storageEntry,\n locked\n }\n });\n } else {\n /**\n * If not updating latest revision, we still want to update the latest revision's\n * entry-level meta fields to match the current revision's entry-level meta fields.\n */\n const updatedEntryLevelMetaFields = pickEntryMetaFields(\n entry,\n isEntryLevelEntryMetaField\n );\n\n /**\n * First we update the regular DynamoDB table. Two updates are needed:\n * - one for the actual revision record\n * - one for the latest record\n */\n entityBatch.put({\n ...createEntryRevisionKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields\n }\n });\n\n entityBatch.put({\n ...createEntryLatestKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields\n }\n });\n }\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update entry.\",\n ex.code || \"UPDATE_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry\n }\n );\n }\n };\n\n const move: CmsEntryStorageOperations[\"move\"] = async (initialModel, id, folderId) => {\n /**\n * We need to:\n * - load all the revisions of the entry, including published and latest\n * - update all the revisions (published and latest ) of the entry with new folderId\n */\n const model = getStorageOperationsModel(initialModel);\n /**\n * First we need to load all the revisions and published / latest entry.\n */\n const partitionKey = createPartitionKey({\n id,\n tenant: model.tenant\n });\n const records = await entity.queryAll({\n partitionKey,\n options: {\n gte: \" \"\n }\n });\n /**\n * Then create the batch writes for the DynamoDB, with the updated folderId.\n */\n const entityBatch = entity.createEntityWriter({\n put: records.map(item => {\n return {\n ...item,\n data: {\n ...item.data,\n location: {\n ...item.data.location,\n folderId\n }\n }\n };\n })\n });\n\n /**\n * And finally write it...\n */\n try {\n await entityBatch.execute();\n } catch (ex) {\n throw WebinyError.from(ex, {\n message: \"Could not move records to a new folder.\",\n data: {\n id,\n folderId\n }\n });\n }\n };\n\n const moveToBin: CmsEntryStorageOperations[\"moveToBin\"] = async (\n initialModel,\n params\n ): Promise<void> => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n /**\n * First we need to load all the revisions and published / latest entries.\n */\n\n let records: Awaited<ReturnType<typeof entity.queryAll>> = [];\n try {\n records = await entity.queryAll({\n partitionKey: createPartitionKey({\n id: entry.id,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n id: entry.id\n }\n );\n }\n if (records.length === 0) {\n return;\n }\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n\n /**\n * Let's pick the `deleted` meta fields from the storage entry.\n */\n const updatedDeletedMetaFields = pickEntryMetaFields(storageEntry, isDeletedEntryMetaField);\n\n /**\n * Then create the batch writes for the DynamoDB, with the updated data.\n */\n const entityBatch = entity.createEntityWriter({\n put: records.map(record => {\n return {\n ...record,\n data: {\n ...record.data,\n ...updatedDeletedMetaFields,\n wbyDeleted: storageEntry.wbyDeleted,\n location: storageEntry.location,\n binOriginalFolderId: storageEntry.binOriginalFolderId\n }\n };\n })\n });\n /**\n * And finally write it...\n */\n try {\n await entityBatch.execute();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not move the entry to the bin.\",\n ex.code || \"MOVE_ENTRY_TO_BIN_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\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 tenant: model.tenant\n });\n\n let records: Awaited<ReturnType<typeof entity.queryAll>> = [];\n try {\n records = await entity.queryAll({\n partitionKey,\n options: {\n gte: \" \"\n }\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n\n const entityBatch = entity.createEntityWriter({\n delete: records.map(item => {\n return {\n PK: item.PK,\n SK: item.SK\n };\n })\n });\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete the entry.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey,\n id\n }\n );\n }\n };\n\n const restoreFromBin = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsRestoreFromBinParams<T>\n ): Promise<CmsStorageEntry<T>> => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n /**\n * First we need to load all the revisions and published / latest entries.\n */\n let records: Awaited<ReturnType<typeof entity.queryAll>> = [];\n try {\n records = await entity.queryAll({\n partitionKey: createPartitionKey({\n id: entry.id,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n id: entry.id\n }\n );\n }\n if (records.length === 0) {\n return initialStorageEntry;\n }\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n\n /**\n * Let's pick the `restored` meta fields from the storage entry.\n */\n const updatedRestoredMetaFields = pickEntryMetaFields(\n storageEntry,\n isRestoredEntryMetaField\n );\n\n const entityBatch = entity.createEntityWriter({\n put: records.map(record => {\n return {\n ...record,\n data: {\n ...record.data,\n ...updatedRestoredMetaFields,\n wbyDeleted: storageEntry.wbyDeleted,\n location: storageEntry.location,\n binOriginalFolderId: storageEntry.binOriginalFolderId\n }\n };\n })\n });\n\n /**\n * And finally write it...\n */\n try {\n await entityBatch.execute();\n\n dataLoaders.clearAll({\n model\n });\n\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not restore the entry from the bin.\",\n ex.code || \"RESTORE_ENTRY_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n };\n\n const deleteRevision: CmsEntryStorageOperations[\"deleteRevision\"] = async (\n initialModel,\n params\n ) => {\n const { entry, latestEntry, latestStorageEntry: initialLatestStorageEntry } = params;\n\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n tenant: model.tenant\n });\n\n const entityBatch = entity.createEntityWriter({\n delete: [\n {\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n }\n ]\n });\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n /**\n * If revision we are deleting is the published one as well, we need to delete those records as well.\n */\n if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {\n entityBatch.delete({\n PK: partitionKey,\n SK: createPublishedSortKey()\n });\n }\n\n if (initialLatestStorageEntry) {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n entityBatch.put({\n ...createEntryLatestKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry\n }\n });\n\n // Do an update on the latest revision. We need to update the latest revision's\n // entry-level meta fields to match the previous revision's entry-level meta fields.\n entityBatch.put({\n ...createEntryRevisionKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry\n }\n });\n }\n try {\n await entityBatch.execute();\n\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, {\n error: ex,\n entry,\n latestEntry\n });\n }\n };\n\n const 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\n const entityBatch = entity.createEntityWriter();\n\n for (const id of entries) {\n const partitionKey = createPartitionKey({\n id,\n tenant: model.tenant\n });\n entityBatch.delete({\n PK: partitionKey,\n SK: \"L\"\n });\n entityBatch.delete({\n PK: partitionKey,\n SK: \"P\"\n });\n }\n /**\n * Exact revisions of all the entries\n */\n for (const revision of revisions) {\n entityBatch.delete({\n PK: createPartitionKey({\n id: revision.id,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey({\n version: revision.version\n })\n });\n }\n\n await entityBatch.execute();\n };\n\n const getLatestRevisionByEntryId = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getLatestRevisionByEntryId<T>({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n const getPublishedRevisionByEntryId = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetPublishedRevisionParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getPublishedRevisionByEntryId<T>({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisionById = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetRevisionParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getRevisionById<T>({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisions = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetRevisionsParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getAllEntryRevisions<T>({\n model,\n ids: [params.id]\n });\n\n return items.map(item => {\n return convertFromStorageEntry<T>({\n storageEntry: item,\n model\n });\n });\n };\n\n const getByIds = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetByIdsParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getRevisionById<T>({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getLatestByIds = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetLatestByIdsParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getLatestRevisionByEntryId<T>({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPublishedByIds = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetPublishedByIdsParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getPublishedRevisionByEntryId<T>({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPreviousRevision = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetPreviousRevisionParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const { entryId, version } = params;\n const partitionKey = createPartitionKey({\n tenant: model.tenant,\n id: entryId\n });\n\n const unfilteredRevisions = await entity.queryAll({\n partitionKey,\n options: {\n beginsWith: `REV#`,\n reverse: true\n }\n });\n const filteredRevisions = unfilteredRevisions.filter(item => {\n return item.data.version < version;\n });\n const storageEntry = filteredRevisions[0];\n if (!storageEntry) {\n return null;\n }\n\n try {\n return convertFromStorageEntry({\n storageEntry: storageEntry.data,\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,\n model\n }\n );\n }\n };\n\n const list = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsListParams\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const {\n limit: initialLimit = 10,\n where: initialWhere,\n after,\n sort: sortBy,\n fields,\n search\n } = params;\n const limit =\n initialLimit <= 0 || initialLimit >= MAX_LIST_LIMIT ? MAX_LIST_LIMIT : initialLimit;\n\n const type = initialWhere.published ? \"P\" : \"L\";\n\n const partitionKey = createGSIPartitionKey(model, type);\n const options = {\n index: \"GSI1\",\n gte: \" \"\n };\n\n let storageEntries: Awaited<ReturnType<typeof entity.queryAll>> = [];\n try {\n storageEntries = await entity.queryAll({\n partitionKey,\n options\n });\n } catch (ex) {\n throw new WebinyError(ex.message, \"QUERY_ENTRIES_ERROR\", {\n error: ex,\n partitionKey,\n options\n });\n }\n if (storageEntries.length === 0) {\n return {\n hasMoreItems: false,\n totalCount: 0,\n cursor: null,\n items: []\n };\n }\n const where: Partial<CmsEntryListWhere> = {\n ...initialWhere\n };\n delete where[\"published\"];\n delete where[\"latest\"];\n /**\n * We need an object containing field, transformers and paths.\n * Just build it here and pass on into other methods that require it to avoid mapping multiple times.\n */\n const modelFields = createFields({\n plugins,\n fields: model.fields\n });\n\n const fromStorage = createStorageTransformCallable(model);\n /**\n * Let's transform records from storage ones to regular ones, so we do not need to do it later.\n *\n * This is always being done, but at least its in parallel.\n */\n const records = await Promise.all(\n storageEntries.map(async storageEntry => {\n const entry = convertFromStorageEntry({\n storageEntry: storageEntry.data,\n model\n });\n\n for (const field of model.fields) {\n entry.values[field.fieldId] = await fromStorage(\n field,\n entry.values[field.fieldId]\n );\n }\n\n return entry as CmsEntry<T>;\n })\n );\n /**\n * Filter the read items via the code.\n * It will build the filters out of the where input and transform the values it is using.\n */\n const filteredItems = filter<T>({\n items: records,\n where,\n plugins,\n fields: modelFields,\n fullTextSearch: {\n term: search,\n fields: fields || []\n }\n });\n\n const totalCount = filteredItems.length;\n\n /**\n * Sorting is also done via the code.\n * It takes the sort input and sorts by it via the lodash sortBy method.\n */\n const sortedItems = sort<T>({\n model,\n plugins,\n items: filteredItems,\n sort: sortBy,\n fields: modelFields\n });\n\n const start = parseInt((decodeCursor(after) as string) || \"0\") || 0;\n const hasMoreItems = totalCount > start + limit;\n const end = limit > totalCount + start + limit ? undefined : start + limit;\n const slicedItems = sortedItems.slice(start, end);\n /**\n * Although we do not need a cursor here, we will use it as such to keep it standardized.\n * Number is simply encoded.\n */\n const cursor = encodeCursor(`${start + limit}`);\n return {\n hasMoreItems,\n totalCount,\n cursor,\n items: slicedItems\n };\n };\n\n const get = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetParams\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { items } = await list<T>(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsPublishParams<T>\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n /**\n * We need the latest and published entries to see if something needs to be updated alongside the publishing one.\n */\n const initialLatestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n if (!initialLatestStorageEntry) {\n throw new WebinyError(\n `Could not publish entry. Could not load latest (\"L\") record.`,\n \"PUBLISH_ERROR\",\n { entry }\n );\n }\n\n const initialPublishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n\n // 1. Update REV# and P records with new data.\n const entityBatch = entity.createEntityWriter({\n put: [\n {\n ...createEntryRevisionKeys(storageEntry),\n data: {\n ...storageEntry\n }\n },\n {\n ...createEntryPublishedKeys(storageEntry),\n data: {\n ...storageEntry\n }\n }\n ]\n });\n\n // 2. When it comes to the latest record, we need to perform a couple of different\n // updates, based on whether the entry being published is the latest revision or not.\n const publishedRevisionId = initialPublishedStorageEntry?.id;\n const publishingLatestRevision = entry.id === initialLatestStorageEntry.id;\n\n if (publishingLatestRevision) {\n // 2.1 If we're publishing the latest revision, we first need to update the L record.\n entityBatch.put({\n ...createEntryLatestKeys(storageEntry),\n data: {\n ...storageEntry\n }\n });\n\n // 2.2 Additionally, if we have a previously published entry, we need to mark it as unpublished.\n if (publishedRevisionId && publishedRevisionId !== entry.id) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n\n entityBatch.put({\n ...createEntryRevisionKeys(publishedStorageEntry),\n data: {\n ...publishedStorageEntry,\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED\n }\n });\n }\n } else {\n // 2.3 If the published revision is not the latest one, the situation is a bit\n // more complex. We first need to update the L and REV# records with the new\n // values of *only entry-level* meta fields.\n const updatedEntryLevelMetaFields = pickEntryMetaFields(\n entry,\n isEntryLevelEntryMetaField\n );\n\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n\n // 2.3.1 Update L record. Apart from updating the entry-level meta fields, we also need\n // to change the status from \"published\" to \"unpublished\" (if the status is set to \"published\").\n let latestRevisionStatus = latestStorageEntry.status;\n if (latestRevisionStatus === CONTENT_ENTRY_STATUS.PUBLISHED) {\n latestRevisionStatus = CONTENT_ENTRY_STATUS.UNPUBLISHED;\n }\n\n const latestStorageEntryFields = {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields,\n status: latestRevisionStatus\n };\n\n entityBatch.put({\n ...createEntryLatestKeys(latestStorageEntryFields),\n data: {\n ...latestStorageEntryFields\n }\n });\n\n // 2.3.2 Update REV# record.\n entityBatch.put({\n ...createEntryRevisionKeys(latestStorageEntryFields),\n data: {\n ...latestStorageEntryFields\n }\n });\n\n // 2.3.3 Finally, if we got a published entry, but it wasn't the latest one, we need to take\n // an extra step and mark it as unpublished.\n const publishedRevisionDifferentFromLatest =\n publishedRevisionId && publishedRevisionId !== latestStorageEntry.id;\n if (publishedRevisionDifferentFromLatest) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n\n entityBatch.put({\n ...createEntryRevisionKeys(publishedStorageEntry),\n data: {\n ...publishedStorageEntry,\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED\n }\n });\n }\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute the publishing batch.\",\n ex.code || \"PUBLISH_ERROR\",\n {\n entry,\n latestStorageEntry: initialLatestStorageEntry,\n publishedStorageEntry: initialPublishedStorageEntry\n }\n );\n }\n };\n\n const unpublish = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsUnpublishParams<T>\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - delete currently published entry\n * - update current entry revision with new data\n * - update the latest entry status - if entry being unpublished is latest\n */\n const entityBatch = entity.createEntityWriter({\n delete: [\n {\n PK: partitionKey,\n SK: createPublishedSortKey()\n }\n ],\n put: [\n {\n ...createEntryRevisionKeys(storageEntry),\n data: {\n ...storageEntry\n }\n }\n ]\n });\n\n /**\n * We need the latest entry to see if something needs to be updated alongside the unpublishing one.\n */\n const initialLatestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (initialLatestStorageEntry) {\n const unpublishingLatestRevision = entry.id === initialLatestStorageEntry.id;\n if (unpublishingLatestRevision) {\n entityBatch.put({\n ...createEntryLatestKeys(storageEntry),\n data: {\n ...storageEntry\n }\n });\n } else {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n\n // If the unpublished revision is not the latest one, we still need to\n // update the latest record with the new values of entry-level meta fields.\n const updatedEntryLevelMetaFields = pickEntryMetaFields(\n entry,\n isEntryLevelEntryMetaField\n );\n\n // 1. Update actual revision record.\n entityBatch.put({\n ...createEntryRevisionKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields\n }\n });\n\n // 2. Update latest record.\n entityBatch.put({\n ...createEntryLatestKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields\n }\n });\n }\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute unpublish batch.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n };\n\n const getUniqueFieldValues: CmsEntryStorageOperations[\"getUniqueFieldValues\"] = async (\n model,\n params\n ) => {\n const { where, fieldId } = params;\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 { items } = await list(model, {\n where,\n limit: MAX_LIST_LIMIT\n });\n\n const result: Record<string, CmsEntryUniqueValue> = {};\n for (const item of items) {\n const fieldValue = item.values[field.fieldId] as string[] | string | undefined;\n if (!fieldValue) {\n continue;\n }\n const values = Array.isArray(fieldValue) ? fieldValue : [fieldValue];\n if (values.length === 0) {\n continue;\n }\n for (const value of values) {\n result[value] = {\n value,\n count: (result[value]?.count || 0) + 1\n };\n }\n }\n\n return Object.values(result)\n .sort((a, b) => (a.value > b.value ? 1 : b.value > a.value ? -1 : 0))\n .sort((a, b) => b.count - a.count);\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n move,\n delete: deleteEntry,\n moveToBin,\n restoreFromBin,\n deleteRevision,\n deleteMultipleEntries,\n getPreviousRevision,\n getPublishedByIds,\n getLatestByIds,\n getByIds,\n getRevisionById,\n getPublishedRevisionByEntryId,\n getLatestRevisionByEntryId,\n get,\n getRevisions,\n publish,\n list,\n unpublish,\n dataLoaders,\n getUniqueFieldValues\n };\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["WebinyError","DataLoadersHandler","CONTENT_ENTRY_STATUS","createEntryLatestKeys","createEntryPublishedKeys","createEntryRevisionKeys","createGSIPartitionKey","createPartitionKey","createPublishedSortKey","createRevisionSortKey","decodeCursor","encodeCursor","StorageOperationsCmsModelPlugin","StorageTransformPlugin","createFields","filter","sort","isDeletedEntryMetaField","isEntryLevelEntryMetaField","isRestoredEntryMetaField","pickEntryMetaFields","getBaseFieldType","convertToStorageEntry","params","model","storageEntry","values","convertValueKeyToStorage","fields","convertFromStorageEntry","convertValueKeyFromStorage","MAX_LIST_LIMIT","createEntriesStorageOperations","entity","plugins","storageOperationsCmsModelPlugin","getStorageOperationsCmsModelPlugin","oneByType","type","getStorageOperationsModel","plugin","getModel","dataLoaders","createStorageTransformCallable","storageTransformPlugins","byType","reduce","collection","fieldType","field","value","fromStorage","getStoragePlugin","create","initialModel","entry","initialStorageEntry","isPublished","status","locked","storageEntryRevisionKeys","storageEntryLatestKeys","entityBatch","createEntityWriter","put","data","storageEntryPublishedKeys","execute","clearAll","ex","message","code","error","createRevisionFrom","publishedRevisionStorageEntry","getPublishedRevisionByEntryId","ids","id","UNPUBLISHED","update","latestStorageEntry","getLatestRevisionByEntryId","updatingLatestRevision","updatedEntryLevelMetaFields","move","folderId","partitionKey","tenant","records","queryAll","options","gte","map","item","location","from","moveToBin","length","updatedDeletedMetaFields","record","wbyDeleted","binOriginalFolderId","deleteEntry","entryId","delete","PK","SK","restoreFromBin","updatedRestoredMetaFields","deleteRevision","latestEntry","initialLatestStorageEntry","publishedStorageEntry","deleteMultipleEntries","entries","revisions","getAllEntryRevisions","revision","version","items","shift","getRevisionById","getRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","unfilteredRevisions","beginsWith","reverse","filteredRevisions","list","limit","initialLimit","where","initialWhere","after","sortBy","search","published","index","storageEntries","hasMoreItems","totalCount","cursor","modelFields","Promise","all","fieldId","filteredItems","fullTextSearch","term","sortedItems","start","parseInt","end","undefined","slicedItems","slice","get","publish","initialPublishedStorageEntry","publishedRevisionId","publishingLatestRevision","latestRevisionStatus","PUBLISHED","latestStorageEntryFields","publishedRevisionDifferentFromLatest","unpublish","unpublishingLatestRevision","getUniqueFieldValues","find","f","result","fieldValue","Array","isArray","count","Object","a","b"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { DataLoadersHandler } from \"./dataLoaders.js\";\nimport type {\n CmsEntry,\n CmsEntryListWhere,\n CmsEntryStorageOperationsGetByIdsParams,\n CmsEntryStorageOperationsGetLatestByIdsParams,\n CmsEntryStorageOperationsGetLatestRevisionParams,\n CmsEntryStorageOperationsGetParams,\n CmsEntryStorageOperationsGetPreviousRevisionParams,\n CmsEntryStorageOperationsGetPublishedByIdsParams,\n CmsEntryStorageOperationsGetPublishedRevisionParams,\n CmsEntryStorageOperationsGetRevisionParams,\n CmsEntryStorageOperationsGetRevisionsParams,\n CmsEntryStorageOperationsListParams,\n CmsEntryStorageOperationsPublishParams,\n CmsEntryStorageOperationsRestoreFromBinParams,\n CmsEntryStorageOperationsUnpublishParams,\n CmsEntryUniqueValue,\n CmsEntryValues,\n CmsModel,\n CmsStorageEntry,\n StorageOperationsCmsModel\n} from \"@webiny/api-headless-cms/types/index.js\";\nimport { CONTENT_ENTRY_STATUS } from \"@webiny/api-headless-cms/types/index.js\";\nimport {\n createEntryLatestKeys,\n createEntryPublishedKeys,\n createEntryRevisionKeys,\n createGSIPartitionKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys.js\";\nimport type { PluginsContainer } from \"@webiny/plugins\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils\";\nimport { StorageOperationsCmsModelPlugin, StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport type { FilterItemFromStorage } from \"./filtering/types.js\";\nimport { createFields } from \"~/operations/entry/filtering/createFields.js\";\nimport { filter, sort } from \"~/operations/entry/filtering/index.js\";\nimport type { CmsEntryStorageOperations, IEntryEntity } from \"~/types.js\";\nimport {\n isDeletedEntryMetaField,\n isEntryLevelEntryMetaField,\n isRestoredEntryMetaField,\n pickEntryMetaFields\n} from \"@webiny/api-headless-cms/constants.js\";\nimport { getBaseFieldType } from \"@webiny/api-headless-cms/utils/getBaseFieldType.js\";\n\ninterface ConvertStorageEntryParams<T extends CmsEntryValues = CmsEntryValues> {\n storageEntry: CmsStorageEntry<T>;\n model: StorageOperationsCmsModel<T>;\n}\n\nconst convertToStorageEntry = (params: ConvertStorageEntryParams): CmsStorageEntry => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyToStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nconst convertFromStorageEntry = <T extends CmsEntryValues = CmsEntryValues>(\n params: ConvertStorageEntryParams<T>\n): CmsStorageEntry<T> => {\n const { model, storageEntry } = params;\n\n const values = model.convertValueKeyFromStorage({\n fields: model.fields,\n values: storageEntry.values\n });\n return {\n ...storageEntry,\n values\n };\n};\n\nconst MAX_LIST_LIMIT = 1000000;\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: IEntryEntity;\n plugins: PluginsContainer;\n}\n\nexport const createEntriesStorageOperations = (\n params: CreateEntriesStorageOperationsParams\n): CmsEntryStorageOperations => {\n const { entity, plugins } = params;\n\n let storageOperationsCmsModelPlugin: StorageOperationsCmsModelPlugin | undefined;\n const getStorageOperationsCmsModelPlugin = () => {\n if (storageOperationsCmsModelPlugin) {\n return storageOperationsCmsModelPlugin;\n }\n storageOperationsCmsModelPlugin = plugins.oneByType<StorageOperationsCmsModelPlugin>(\n StorageOperationsCmsModelPlugin.type\n );\n return storageOperationsCmsModelPlugin;\n };\n\n const getStorageOperationsModel = <T extends CmsEntryValues = CmsEntryValues>(\n model: CmsModel\n ): StorageOperationsCmsModel<T> => {\n const plugin = getStorageOperationsCmsModelPlugin();\n return plugin.getModel<T>(model);\n };\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const createStorageTransformCallable = (\n model: StorageOperationsCmsModel\n ): FilterItemFromStorage => {\n // Cache StorageTransformPlugin to optimize execution.\n const storageTransformPlugins = plugins\n .byType<StorageTransformPlugin>(StorageTransformPlugin.type)\n .reduce(\n (collection, plugin) => {\n collection[plugin.fieldType] = plugin;\n return collection;\n },\n {} as Record<string, StorageTransformPlugin>\n );\n\n return (field, value) => {\n const fieldType = getBaseFieldType(field);\n\n const plugin: StorageTransformPlugin = storageTransformPlugins[fieldType];\n if (!plugin) {\n return value;\n }\n return plugin.fromStorage({\n model,\n field,\n value,\n getStoragePlugin(fieldType: string): StorageTransformPlugin {\n return storageTransformPlugins[fieldType] || storageTransformPlugins[\"*\"];\n },\n plugins\n });\n };\n };\n\n const create: CmsEntryStorageOperations[\"create\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const isPublished = entry.status === \"published\";\n\n const locked = isPublished ? true : entry.locked;\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n\n const storageEntryRevisionKeys = createEntryRevisionKeys(entry);\n const storageEntryLatestKeys = createEntryLatestKeys(entry);\n /**\n * We need to:\n * - create new main entry item\n * - create new or update the latest entry item\n */\n const entityBatch = entity.createEntityWriter({\n put: [\n {\n ...storageEntryRevisionKeys,\n data: {\n ...storageEntry,\n locked\n }\n },\n {\n ...storageEntryLatestKeys,\n data: {\n ...storageEntry,\n locked\n }\n }\n ]\n });\n\n /**\n * We need to create published entry if\n */\n if (isPublished) {\n const storageEntryPublishedKeys = createEntryPublishedKeys(storageEntry);\n entityBatch.put({\n ...storageEntryPublishedKeys,\n data: {\n ...storageEntry,\n locked\n }\n });\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert data into the DynamoDB.\",\n ex.code || \"CREATE_ENTRY_ERROR\",\n {\n error: ex,\n entry\n }\n );\n }\n\n return initialStorageEntry;\n };\n\n const createRevisionFrom: CmsEntryStorageOperations[\"createRevisionFrom\"] = async (\n initialModel,\n params\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n\n /**\n * We need to:\n * - create the main entry item\n * - update the latest entry item to the current one\n * - if the entry's status was set to \"published\":\n * - update the published entry item to the current one\n * - unpublish previously published revision (if any)\n */\n const entityBatch = entity.createEntityWriter({\n put: [\n {\n ...createEntryRevisionKeys(storageEntry),\n data: {\n ...storageEntry\n }\n },\n {\n ...createEntryLatestKeys(storageEntry),\n data: {\n ...storageEntry\n }\n }\n ]\n });\n\n const isPublished = entry.status === \"published\";\n if (isPublished) {\n entityBatch.put({\n ...createEntryPublishedKeys(storageEntry),\n data: {\n ...storageEntry\n }\n });\n\n // Unpublish previously published revision (if any).\n const [publishedRevisionStorageEntry] = await dataLoaders.getPublishedRevisionByEntryId(\n {\n model,\n ids: [entry.id]\n }\n );\n\n if (publishedRevisionStorageEntry) {\n entityBatch.put({\n ...createEntryRevisionKeys(publishedRevisionStorageEntry),\n data: {\n ...publishedRevisionStorageEntry,\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED\n }\n });\n }\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create revision from given entry.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n /**\n * There are no modifications on the entry created so just return the data.\n */\n return initialStorageEntry;\n };\n\n const update: CmsEntryStorageOperations[\"update\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to:\n * - update the current entry\n * - update the latest entry if the current entry is the latest one\n */\n\n const entityBatch = entity.createEntityWriter({\n put: [\n {\n ...createEntryRevisionKeys(storageEntry),\n data: {\n ...storageEntry,\n locked\n }\n }\n ]\n });\n\n if (isPublished) {\n entityBatch.put({\n ...createEntryPublishedKeys(storageEntry),\n data: {\n ...storageEntry,\n locked\n }\n });\n }\n\n /**\n * We need the latest entry to update it as well if necessary.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry) {\n const updatingLatestRevision = latestStorageEntry.id === entry.id;\n if (updatingLatestRevision) {\n entityBatch.put({\n ...createEntryLatestKeys(storageEntry),\n data: {\n ...storageEntry,\n locked\n }\n });\n } else {\n /**\n * If not updating latest revision, we still want to update the latest revision's\n * entry-level meta fields to match the current revision's entry-level meta fields.\n */\n const updatedEntryLevelMetaFields = pickEntryMetaFields(\n entry,\n isEntryLevelEntryMetaField\n );\n\n /**\n * First we update the regular DynamoDB table. Two updates are needed:\n * - one for the actual revision record\n * - one for the latest record\n */\n entityBatch.put({\n ...createEntryRevisionKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields\n }\n });\n\n entityBatch.put({\n ...createEntryLatestKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields\n }\n });\n }\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update entry.\",\n ex.code || \"UPDATE_ERROR\",\n {\n error: ex,\n entry,\n latestStorageEntry\n }\n );\n }\n };\n\n const move: CmsEntryStorageOperations[\"move\"] = async (initialModel, id, folderId) => {\n /**\n * We need to:\n * - load all the revisions of the entry, including published and latest\n * - update all the revisions (published and latest ) of the entry with new folderId\n */\n const model = getStorageOperationsModel(initialModel);\n /**\n * First we need to load all the revisions and published / latest entry.\n */\n const partitionKey = createPartitionKey({\n id,\n tenant: model.tenant\n });\n const records = await entity.queryAll({\n partitionKey,\n options: {\n gte: \" \"\n }\n });\n /**\n * Then create the batch writes for the DynamoDB, with the updated folderId.\n */\n const entityBatch = entity.createEntityWriter({\n put: records.map(item => {\n return {\n ...item,\n data: {\n ...item.data,\n location: {\n ...item.data.location,\n folderId\n }\n }\n };\n })\n });\n\n /**\n * And finally write it...\n */\n try {\n await entityBatch.execute();\n } catch (ex) {\n throw WebinyError.from(ex, {\n message: \"Could not move records to a new folder.\",\n data: {\n id,\n folderId\n }\n });\n }\n };\n\n const moveToBin: CmsEntryStorageOperations[\"moveToBin\"] = async (\n initialModel,\n params\n ): Promise<void> => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n /**\n * First we need to load all the revisions and published / latest entries.\n */\n\n let records: Awaited<ReturnType<typeof entity.queryAll>> = [];\n try {\n records = await entity.queryAll({\n partitionKey: createPartitionKey({\n id: entry.id,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n id: entry.id\n }\n );\n }\n if (records.length === 0) {\n return;\n }\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n\n /**\n * Let's pick the `deleted` meta fields from the storage entry.\n */\n const updatedDeletedMetaFields = pickEntryMetaFields(storageEntry, isDeletedEntryMetaField);\n\n /**\n * Then create the batch writes for the DynamoDB, with the updated data.\n */\n const entityBatch = entity.createEntityWriter({\n put: records.map(record => {\n return {\n ...record,\n data: {\n ...record.data,\n ...updatedDeletedMetaFields,\n wbyDeleted: storageEntry.wbyDeleted,\n location: storageEntry.location,\n binOriginalFolderId: storageEntry.binOriginalFolderId\n }\n };\n })\n });\n /**\n * And finally write it...\n */\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not move the entry to the bin.\",\n ex.code || \"MOVE_ENTRY_TO_BIN_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\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 tenant: model.tenant\n });\n\n let records: Awaited<ReturnType<typeof entity.queryAll>> = [];\n try {\n records = await entity.queryAll({\n partitionKey,\n options: {\n gte: \" \"\n }\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n\n const entityBatch = entity.createEntityWriter({\n delete: records.map(item => {\n return {\n PK: item.PK,\n SK: item.SK\n };\n })\n });\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete the entry.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey,\n id\n }\n );\n }\n };\n\n const restoreFromBin = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsRestoreFromBinParams<T>\n ): Promise<CmsStorageEntry<T>> => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n /**\n * First we need to load all the revisions and published / latest entries.\n */\n let records: Awaited<ReturnType<typeof entity.queryAll>> = [];\n try {\n records = await entity.queryAll({\n partitionKey: createPartitionKey({\n id: entry.id,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n id: entry.id\n }\n );\n }\n if (records.length === 0) {\n return initialStorageEntry;\n }\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n\n /**\n * Let's pick the `restored` meta fields from the storage entry.\n */\n const updatedRestoredMetaFields = pickEntryMetaFields(\n storageEntry,\n isRestoredEntryMetaField\n );\n\n const entityBatch = entity.createEntityWriter({\n put: records.map(record => {\n return {\n ...record,\n data: {\n ...record.data,\n ...updatedRestoredMetaFields,\n wbyDeleted: storageEntry.wbyDeleted,\n location: storageEntry.location,\n binOriginalFolderId: storageEntry.binOriginalFolderId\n }\n };\n })\n });\n\n /**\n * And finally write it...\n */\n try {\n await entityBatch.execute();\n\n dataLoaders.clearAll({\n model\n });\n\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not restore the entry from the bin.\",\n ex.code || \"RESTORE_ENTRY_ERROR\",\n {\n error: ex,\n entry,\n storageEntry\n }\n );\n }\n };\n\n const deleteRevision: CmsEntryStorageOperations[\"deleteRevision\"] = async (\n initialModel,\n params\n ) => {\n const { entry, latestEntry, latestStorageEntry: initialLatestStorageEntry } = params;\n\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n tenant: model.tenant\n });\n\n const entityBatch = entity.createEntityWriter({\n delete: [\n {\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n }\n ]\n });\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n /**\n * If revision we are deleting is the published one as well, we need to delete those records as well.\n */\n if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {\n entityBatch.delete({\n PK: partitionKey,\n SK: createPublishedSortKey()\n });\n }\n\n if (initialLatestStorageEntry) {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n entityBatch.put({\n ...createEntryLatestKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry\n }\n });\n\n // Do an update on the latest revision. We need to update the latest revision's\n // entry-level meta fields to match the previous revision's entry-level meta fields.\n entityBatch.put({\n ...createEntryRevisionKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry\n }\n });\n }\n try {\n await entityBatch.execute();\n\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, {\n error: ex,\n entry,\n latestEntry\n });\n }\n };\n\n const 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\n const entityBatch = entity.createEntityWriter();\n\n for (const id of entries) {\n const partitionKey = createPartitionKey({\n id,\n tenant: model.tenant\n });\n entityBatch.delete({\n PK: partitionKey,\n SK: \"L\"\n });\n entityBatch.delete({\n PK: partitionKey,\n SK: \"P\"\n });\n }\n /**\n * Exact revisions of all the entries\n */\n for (const revision of revisions) {\n entityBatch.delete({\n PK: createPartitionKey({\n id: revision.id,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey({\n version: revision.version\n })\n });\n }\n\n await entityBatch.execute();\n };\n\n const getLatestRevisionByEntryId = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetLatestRevisionParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getLatestRevisionByEntryId<T>({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n const getPublishedRevisionByEntryId = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetPublishedRevisionParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getPublishedRevisionByEntryId<T>({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisionById = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetRevisionParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getRevisionById<T>({\n model,\n ids: [params.id]\n });\n const item = items.shift() || null;\n if (!item) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n };\n\n const getRevisions = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetRevisionsParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getAllEntryRevisions<T>({\n model,\n ids: [params.id]\n });\n\n return items.map(item => {\n return convertFromStorageEntry<T>({\n storageEntry: item,\n model\n });\n });\n };\n\n const getByIds = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetByIdsParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getRevisionById<T>({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getLatestByIds = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetLatestByIdsParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getLatestRevisionByEntryId<T>({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPublishedByIds = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetPublishedByIdsParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const items = await dataLoaders.getPublishedRevisionByEntryId<T>({\n model,\n ids: params.ids\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getPreviousRevision = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetPreviousRevisionParams\n ) => {\n const model = getStorageOperationsModel<T>(initialModel);\n\n const { entryId, version } = params;\n const partitionKey = createPartitionKey({\n tenant: model.tenant,\n id: entryId\n });\n\n const unfilteredRevisions = await entity.queryAll({\n partitionKey,\n options: {\n beginsWith: `REV#`,\n reverse: true\n }\n });\n const filteredRevisions = unfilteredRevisions.filter(item => {\n return item.data.version < version;\n });\n const storageEntry = filteredRevisions[0];\n if (!storageEntry) {\n return null;\n }\n\n try {\n return convertFromStorageEntry({\n storageEntry: storageEntry.data,\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,\n model\n }\n );\n }\n };\n\n const list = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsListParams\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const {\n limit: initialLimit = 10,\n where: initialWhere,\n after,\n sort: sortBy,\n fields,\n search\n } = params;\n const limit =\n initialLimit <= 0 || initialLimit >= MAX_LIST_LIMIT ? MAX_LIST_LIMIT : initialLimit;\n\n const type = initialWhere.published ? \"P\" : \"L\";\n\n const partitionKey = createGSIPartitionKey(model, type);\n const options = {\n index: \"GSI1\",\n gte: \" \"\n };\n\n let storageEntries: Awaited<ReturnType<typeof entity.queryAll>> = [];\n try {\n storageEntries = await entity.queryAll({\n partitionKey,\n options\n });\n } catch (ex) {\n throw new WebinyError(ex.message, \"QUERY_ENTRIES_ERROR\", {\n error: ex,\n partitionKey,\n options\n });\n }\n if (storageEntries.length === 0) {\n return {\n hasMoreItems: false,\n totalCount: 0,\n cursor: null,\n items: []\n };\n }\n const where: Partial<CmsEntryListWhere> = {\n ...initialWhere\n };\n delete where[\"published\"];\n delete where[\"latest\"];\n /**\n * We need an object containing field, transformers and paths.\n * Just build it here and pass on into other methods that require it to avoid mapping multiple times.\n */\n const modelFields = createFields({\n plugins,\n fields: model.fields\n });\n\n const fromStorage = createStorageTransformCallable(model);\n /**\n * Let's transform records from storage ones to regular ones, so we do not need to do it later.\n *\n * This is always being done, but at least its in parallel.\n */\n const records = await Promise.all(\n storageEntries.map(async storageEntry => {\n const entry = convertFromStorageEntry({\n storageEntry: storageEntry.data,\n model\n });\n\n for (const field of model.fields) {\n entry.values[field.fieldId] = await fromStorage(\n field,\n entry.values[field.fieldId]\n );\n }\n\n return entry as CmsEntry<T>;\n })\n );\n /**\n * Filter the read items via the code.\n * It will build the filters out of the where input and transform the values it is using.\n */\n const filteredItems = filter<T>({\n items: records,\n where,\n plugins,\n fields: modelFields,\n fullTextSearch: {\n term: search,\n fields: fields || []\n }\n });\n\n const totalCount = filteredItems.length;\n\n /**\n * Sorting is also done via the code.\n * It takes the sort input and sorts by it via the lodash sortBy method.\n */\n const sortedItems = sort<T>({\n model,\n plugins,\n items: filteredItems,\n sort: sortBy,\n fields: modelFields\n });\n\n const start = parseInt((decodeCursor(after) as string) || \"0\") || 0;\n const hasMoreItems = totalCount > start + limit;\n const end = limit > totalCount + start + limit ? undefined : start + limit;\n const slicedItems = sortedItems.slice(start, end);\n /**\n * Although we do not need a cursor here, we will use it as such to keep it standardized.\n * Number is simply encoded.\n */\n const cursor = encodeCursor(`${start + limit}`);\n return {\n hasMoreItems,\n totalCount,\n cursor,\n items: slicedItems\n };\n };\n\n const get = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsGetParams\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { items } = await list<T>(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsPublishParams<T>\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n /**\n * We need the latest and published entries to see if something needs to be updated alongside the publishing one.\n */\n const initialLatestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n if (!initialLatestStorageEntry) {\n throw new WebinyError(\n `Could not publish entry. Could not load latest (\"L\") record.`,\n \"PUBLISH_ERROR\",\n { entry }\n );\n }\n\n const initialPublishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n\n // 1. Update REV# and P records with new data.\n const entityBatch = entity.createEntityWriter({\n put: [\n {\n ...createEntryRevisionKeys(storageEntry),\n data: {\n ...storageEntry\n }\n },\n {\n ...createEntryPublishedKeys(storageEntry),\n data: {\n ...storageEntry\n }\n }\n ]\n });\n\n // 2. When it comes to the latest record, we need to perform a couple of different\n // updates, based on whether the entry being published is the latest revision or not.\n const publishedRevisionId = initialPublishedStorageEntry?.id;\n const publishingLatestRevision = entry.id === initialLatestStorageEntry.id;\n\n if (publishingLatestRevision) {\n // 2.1 If we're publishing the latest revision, we first need to update the L record.\n entityBatch.put({\n ...createEntryLatestKeys(storageEntry),\n data: {\n ...storageEntry\n }\n });\n\n // 2.2 Additionally, if we have a previously published entry, we need to mark it as unpublished.\n if (publishedRevisionId && publishedRevisionId !== entry.id) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n\n entityBatch.put({\n ...createEntryRevisionKeys(publishedStorageEntry),\n data: {\n ...publishedStorageEntry,\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED\n }\n });\n }\n } else {\n // 2.3 If the published revision is not the latest one, the situation is a bit\n // more complex. We first need to update the L and REV# records with the new\n // values of *only entry-level* meta fields.\n const updatedEntryLevelMetaFields = pickEntryMetaFields(\n entry,\n isEntryLevelEntryMetaField\n );\n\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n\n // 2.3.1 Update L record. Apart from updating the entry-level meta fields, we also need\n // to change the status from \"published\" to \"unpublished\" (if the status is set to \"published\").\n let latestRevisionStatus = latestStorageEntry.status;\n if (latestRevisionStatus === CONTENT_ENTRY_STATUS.PUBLISHED) {\n latestRevisionStatus = CONTENT_ENTRY_STATUS.UNPUBLISHED;\n }\n\n const latestStorageEntryFields = {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields,\n status: latestRevisionStatus\n };\n\n entityBatch.put({\n ...createEntryLatestKeys(latestStorageEntryFields),\n data: {\n ...latestStorageEntryFields\n }\n });\n\n // 2.3.2 Update REV# record.\n entityBatch.put({\n ...createEntryRevisionKeys(latestStorageEntryFields),\n data: {\n ...latestStorageEntryFields\n }\n });\n\n // 2.3.3 Finally, if we got a published entry, but it wasn't the latest one, we need to take\n // an extra step and mark it as unpublished.\n const publishedRevisionDifferentFromLatest =\n publishedRevisionId && publishedRevisionId !== latestStorageEntry.id;\n if (publishedRevisionDifferentFromLatest) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n\n entityBatch.put({\n ...createEntryRevisionKeys(publishedStorageEntry),\n data: {\n ...publishedStorageEntry,\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED\n }\n });\n }\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute the publishing batch.\",\n ex.code || \"PUBLISH_ERROR\",\n {\n entry,\n latestStorageEntry: initialLatestStorageEntry,\n publishedStorageEntry: initialPublishedStorageEntry\n }\n );\n }\n };\n\n const unpublish = async <T extends CmsEntryValues = CmsEntryValues>(\n initialModel: CmsModel,\n params: CmsEntryStorageOperationsUnpublishParams<T>\n ) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - delete currently published entry\n * - update current entry revision with new data\n * - update the latest entry status - if entry being unpublished is latest\n */\n const entityBatch = entity.createEntityWriter({\n delete: [\n {\n PK: partitionKey,\n SK: createPublishedSortKey()\n }\n ],\n put: [\n {\n ...createEntryRevisionKeys(storageEntry),\n data: {\n ...storageEntry\n }\n }\n ]\n });\n\n /**\n * We need the latest entry to see if something needs to be updated alongside the unpublishing one.\n */\n const initialLatestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (initialLatestStorageEntry) {\n const unpublishingLatestRevision = entry.id === initialLatestStorageEntry.id;\n if (unpublishingLatestRevision) {\n entityBatch.put({\n ...createEntryLatestKeys(storageEntry),\n data: {\n ...storageEntry\n }\n });\n } else {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n\n // If the unpublished revision is not the latest one, we still need to\n // update the latest record with the new values of entry-level meta fields.\n const updatedEntryLevelMetaFields = pickEntryMetaFields(\n entry,\n isEntryLevelEntryMetaField\n );\n\n // 1. Update actual revision record.\n entityBatch.put({\n ...createEntryRevisionKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields\n }\n });\n\n // 2. Update latest record.\n entityBatch.put({\n ...createEntryLatestKeys(latestStorageEntry),\n data: {\n ...latestStorageEntry,\n ...updatedEntryLevelMetaFields\n }\n });\n }\n }\n\n try {\n await entityBatch.execute();\n dataLoaders.clearAll({\n model\n });\n return initialStorageEntry;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not execute unpublish batch.\",\n ex.code || \"UNPUBLISH_ERROR\",\n {\n entry,\n storageEntry\n }\n );\n }\n };\n\n const getUniqueFieldValues: CmsEntryStorageOperations[\"getUniqueFieldValues\"] = async (\n model,\n params\n ) => {\n const { where, fieldId } = params;\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 { items } = await list(model, {\n where,\n limit: MAX_LIST_LIMIT\n });\n\n const result: Record<string, CmsEntryUniqueValue> = {};\n for (const item of items) {\n const fieldValue = item.values[field.fieldId] as string[] | string | undefined;\n if (!fieldValue) {\n continue;\n }\n const values = Array.isArray(fieldValue) ? fieldValue : [fieldValue];\n if (values.length === 0) {\n continue;\n }\n for (const value of values) {\n result[value] = {\n value,\n count: (result[value]?.count || 0) + 1\n };\n }\n }\n\n return Object.values(result)\n .sort((a, b) => (a.value > b.value ? 1 : b.value > a.value ? -1 : 0))\n .sort((a, b) => b.count - a.count);\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n move,\n delete: deleteEntry,\n moveToBin,\n restoreFromBin,\n deleteRevision,\n deleteMultipleEntries,\n getPreviousRevision,\n getPublishedByIds,\n getLatestByIds,\n getByIds,\n getRevisionById,\n getPublishedRevisionByEntryId,\n getLatestRevisionByEntryId,\n get,\n getRevisions,\n publish,\n list,\n unpublish,\n dataLoaders,\n getUniqueFieldValues\n };\n};\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/api-headless-cms-ddb",
|
|
3
|
-
"version": "6.
|
|
3
|
+
"version": "6.1.0-beta.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"keywords": [
|
|
@@ -23,31 +23,31 @@
|
|
|
23
23
|
],
|
|
24
24
|
"license": "MIT",
|
|
25
25
|
"dependencies": {
|
|
26
|
-
"@webiny/api": "6.
|
|
27
|
-
"@webiny/api-headless-cms": "6.
|
|
28
|
-
"@webiny/aws-sdk": "6.
|
|
29
|
-
"@webiny/db-dynamodb": "6.
|
|
30
|
-
"@webiny/error": "6.
|
|
31
|
-
"@webiny/handler-db": "6.
|
|
32
|
-
"@webiny/utils": "6.
|
|
26
|
+
"@webiny/api": "6.1.0-beta.0",
|
|
27
|
+
"@webiny/api-headless-cms": "6.1.0-beta.0",
|
|
28
|
+
"@webiny/aws-sdk": "6.1.0-beta.0",
|
|
29
|
+
"@webiny/db-dynamodb": "6.1.0-beta.0",
|
|
30
|
+
"@webiny/error": "6.1.0-beta.0",
|
|
31
|
+
"@webiny/handler-db": "6.1.0-beta.0",
|
|
32
|
+
"@webiny/utils": "6.1.0-beta.0",
|
|
33
33
|
"dataloader": "2.2.3",
|
|
34
34
|
"dot-object": "2.1.5",
|
|
35
|
-
"dot-prop": "
|
|
35
|
+
"dot-prop": "10.1.0",
|
|
36
36
|
"lodash": "4.17.23"
|
|
37
37
|
},
|
|
38
38
|
"devDependencies": {
|
|
39
39
|
"@types/dot-object": "2.1.6",
|
|
40
40
|
"@types/jsonpack": "1.1.6",
|
|
41
|
-
"@webiny/build-tools": "6.
|
|
42
|
-
"@webiny/plugins": "6.
|
|
43
|
-
"@webiny/project-utils": "6.
|
|
41
|
+
"@webiny/build-tools": "6.1.0-beta.0",
|
|
42
|
+
"@webiny/plugins": "6.1.0-beta.0",
|
|
43
|
+
"@webiny/project-utils": "6.1.0-beta.0",
|
|
44
44
|
"jest-dynalite": "3.6.1",
|
|
45
45
|
"typescript": "5.9.3",
|
|
46
|
-
"vitest": "4.
|
|
46
|
+
"vitest": "4.1.2"
|
|
47
47
|
},
|
|
48
48
|
"publishConfig": {
|
|
49
49
|
"access": "public",
|
|
50
50
|
"directory": "dist"
|
|
51
51
|
},
|
|
52
|
-
"gitHead": "
|
|
52
|
+
"gitHead": "a3bd3695c66c79238e380d7360d9731b5fcf9c87"
|
|
53
53
|
}
|