@webiny/api-headless-cms-ddb 0.0.0-unstable.c59b9cc5b9 → 0.0.0-unstable.c7dec08bb0
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/definitions/entry.js +3 -0
- package/definitions/entry.js.map +1 -1
- package/dynamoDb/index.js +2 -1
- package/dynamoDb/index.js.map +1 -1
- package/dynamoDb/path/locationFolderId.d.ts +2 -0
- package/dynamoDb/path/locationFolderId.js +41 -0
- package/dynamoDb/path/locationFolderId.js.map +1 -0
- package/dynamoDb/storage/date.js +2 -11
- package/dynamoDb/storage/date.js.map +1 -1
- package/operations/entry/filtering/createFields.d.ts +3 -1
- package/operations/entry/filtering/createFields.js +72 -72
- package/operations/entry/filtering/createFields.js.map +1 -1
- package/operations/entry/filtering/plugins/defaultFilterCreate.js +3 -1
- package/operations/entry/filtering/plugins/defaultFilterCreate.js.map +1 -1
- package/operations/entry/filtering/plugins/objectFilterCreate.js +3 -1
- package/operations/entry/filtering/plugins/objectFilterCreate.js.map +1 -1
- package/operations/entry/filtering/plugins/refFilterCreate.js +3 -1
- package/operations/entry/filtering/plugins/refFilterCreate.js.map +1 -1
- package/operations/entry/filtering/systemFields.js +18 -0
- package/operations/entry/filtering/systemFields.js.map +1 -1
- package/operations/entry/filtering/where.js +3 -2
- package/operations/entry/filtering/where.js.map +1 -1
- package/operations/entry/index.js +19 -1
- package/operations/entry/index.js.map +1 -1
- package/package.json +12 -12
- package/plugins/CmsEntryFieldFilterPathPlugin.d.ts +2 -1
- package/plugins/CmsEntryFieldFilterPathPlugin.js +3 -1
- package/plugins/CmsEntryFieldFilterPathPlugin.js.map +1 -1
- package/operations/entry/systemFields.d.ts +0 -2
- package/operations/entry/systemFields.js +0 -72
- package/operations/entry/systemFields.js.map +0 -1
package/definitions/entry.js
CHANGED
package/definitions/entry.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createEntryEntity","params","table","entityName","attributes","Entity","name","PK","type","partitionKey","SK","sortKey","GSI1_PK","GSI1_SK","TYPE","__type","webinyVersion","tenant","entryId","id","createdBy","ownedBy","modifiedBy","createdOn","savedOn","modelId","locale","publishedOn","version","locked","status","values","meta"],"sources":["entry.ts"],"sourcesContent":["import { Entity, Table } from \"dynamodb-toolbox\";\nimport { Attributes } from \"~/types\";\n\ninterface Params {\n table: Table;\n entityName: string;\n attributes: Attributes;\n}\nexport const createEntryEntity = (params: Params): Entity<any> => {\n const { table, entityName, attributes } = params;\n return new Entity({\n name: entityName,\n table,\n attributes: {\n PK: {\n type: \"string\",\n partitionKey: true\n },\n SK: {\n type: \"string\",\n sortKey: true\n },\n GSI1_PK: {\n type: \"string\"\n },\n GSI1_SK: {\n type: \"string\"\n },\n TYPE: {\n type: \"string\"\n },\n __type: {\n type: \"string\"\n },\n webinyVersion: {\n type: \"string\"\n },\n tenant: {\n type: \"string\"\n },\n entryId: {\n type: \"string\"\n },\n id: {\n type: \"string\"\n },\n createdBy: {\n type: \"map\"\n },\n ownedBy: {\n type: \"map\"\n },\n modifiedBy: {\n type: \"map\"\n },\n createdOn: {\n type: \"string\"\n },\n savedOn: {\n type: \"string\"\n },\n modelId: {\n type: \"string\"\n },\n locale: {\n type: \"string\"\n },\n publishedOn: {\n type: \"string\"\n },\n version: {\n type: \"number\"\n },\n locked: {\n type: \"boolean\"\n },\n status: {\n type: \"string\"\n },\n values: {\n type: \"map\"\n },\n meta: {\n type: \"map\"\n },\n ...(attributes || {})\n }\n });\n};\n"],"mappings":";;;;;;;;AAAA;AAQO,MAAMA,iBAAiB,GAAIC,MAAc,IAAkB;EAC9D,MAAM;IAAEC,KAAK;IAAEC,UAAU;IAAEC;EAAW,CAAC,GAAGH,MAAM;EAChD,OAAO,IAAII,uBAAM,CAAC;IACdC,IAAI,EAAEH,UAAU;IAChBD,KAAK;IACLE,UAAU;MACNG,EAAE,EAAE;QACAC,IAAI,EAAE,QAAQ;QACdC,YAAY,EAAE;MAClB,CAAC;MACDC,EAAE,EAAE;QACAF,IAAI,EAAE,QAAQ;QACdG,OAAO,EAAE;MACb,CAAC;MACDC,OAAO,EAAE;QACLJ,IAAI,EAAE;MACV,CAAC;MACDK,OAAO,EAAE;QACLL,IAAI,EAAE;MACV,CAAC;MACDM,IAAI,EAAE;QACFN,IAAI,EAAE;MACV,CAAC;MACDO,MAAM,EAAE;QACJP,IAAI,EAAE;MACV,CAAC;MACDQ,aAAa,EAAE;QACXR,IAAI,EAAE;MACV,CAAC;MACDS,MAAM,EAAE;QACJT,IAAI,EAAE;MACV,CAAC;MACDU,OAAO,EAAE;QACLV,IAAI,EAAE;MACV,CAAC;MACDW,EAAE,EAAE;QACAX,IAAI,EAAE;MACV,CAAC;MACDY,SAAS,EAAE;QACPZ,IAAI,EAAE;MACV,CAAC;MACDa,OAAO,EAAE;QACLb,IAAI,EAAE;MACV,CAAC;MACDc,UAAU,EAAE;QACRd,IAAI,EAAE;MACV,CAAC;MACDe,SAAS,EAAE;QACPf,IAAI,EAAE;MACV,CAAC;MACDgB,OAAO,EAAE;QACLhB,IAAI,EAAE;MACV,CAAC;MACDiB,OAAO,EAAE;QACLjB,IAAI,EAAE;MACV,CAAC;MACDkB,MAAM,EAAE;QACJlB,IAAI,EAAE;MACV,CAAC;MACDmB,WAAW,EAAE;QACTnB,IAAI,EAAE;MACV,CAAC;MACDoB,OAAO,EAAE;QACLpB,IAAI,EAAE;MACV,CAAC;MACDqB,MAAM,EAAE;QACJrB,IAAI,EAAE;MACV,CAAC;MACDsB,MAAM,EAAE;QACJtB,IAAI,EAAE;MACV,CAAC;MACDuB,
|
|
1
|
+
{"version":3,"names":["createEntryEntity","params","table","entityName","attributes","Entity","name","PK","type","partitionKey","SK","sortKey","GSI1_PK","GSI1_SK","TYPE","__type","webinyVersion","tenant","entryId","id","createdBy","ownedBy","modifiedBy","createdOn","savedOn","modelId","locale","publishedOn","version","locked","status","location","values","meta"],"sources":["entry.ts"],"sourcesContent":["import { Entity, Table } from \"dynamodb-toolbox\";\nimport { Attributes } from \"~/types\";\n\ninterface Params {\n table: Table;\n entityName: string;\n attributes: Attributes;\n}\nexport const createEntryEntity = (params: Params): Entity<any> => {\n const { table, entityName, attributes } = params;\n return new Entity({\n name: entityName,\n table,\n attributes: {\n PK: {\n type: \"string\",\n partitionKey: true\n },\n SK: {\n type: \"string\",\n sortKey: true\n },\n GSI1_PK: {\n type: \"string\"\n },\n GSI1_SK: {\n type: \"string\"\n },\n TYPE: {\n type: \"string\"\n },\n __type: {\n type: \"string\"\n },\n webinyVersion: {\n type: \"string\"\n },\n tenant: {\n type: \"string\"\n },\n entryId: {\n type: \"string\"\n },\n id: {\n type: \"string\"\n },\n createdBy: {\n type: \"map\"\n },\n ownedBy: {\n type: \"map\"\n },\n modifiedBy: {\n type: \"map\"\n },\n createdOn: {\n type: \"string\"\n },\n savedOn: {\n type: \"string\"\n },\n modelId: {\n type: \"string\"\n },\n locale: {\n type: \"string\"\n },\n publishedOn: {\n type: \"string\"\n },\n version: {\n type: \"number\"\n },\n locked: {\n type: \"boolean\"\n },\n status: {\n type: \"string\"\n },\n location: {\n type: \"map\"\n },\n values: {\n type: \"map\"\n },\n meta: {\n type: \"map\"\n },\n ...(attributes || {})\n }\n });\n};\n"],"mappings":";;;;;;;;AAAA;AAQO,MAAMA,iBAAiB,GAAIC,MAAc,IAAkB;EAC9D,MAAM;IAAEC,KAAK;IAAEC,UAAU;IAAEC;EAAW,CAAC,GAAGH,MAAM;EAChD,OAAO,IAAII,uBAAM,CAAC;IACdC,IAAI,EAAEH,UAAU;IAChBD,KAAK;IACLE,UAAU;MACNG,EAAE,EAAE;QACAC,IAAI,EAAE,QAAQ;QACdC,YAAY,EAAE;MAClB,CAAC;MACDC,EAAE,EAAE;QACAF,IAAI,EAAE,QAAQ;QACdG,OAAO,EAAE;MACb,CAAC;MACDC,OAAO,EAAE;QACLJ,IAAI,EAAE;MACV,CAAC;MACDK,OAAO,EAAE;QACLL,IAAI,EAAE;MACV,CAAC;MACDM,IAAI,EAAE;QACFN,IAAI,EAAE;MACV,CAAC;MACDO,MAAM,EAAE;QACJP,IAAI,EAAE;MACV,CAAC;MACDQ,aAAa,EAAE;QACXR,IAAI,EAAE;MACV,CAAC;MACDS,MAAM,EAAE;QACJT,IAAI,EAAE;MACV,CAAC;MACDU,OAAO,EAAE;QACLV,IAAI,EAAE;MACV,CAAC;MACDW,EAAE,EAAE;QACAX,IAAI,EAAE;MACV,CAAC;MACDY,SAAS,EAAE;QACPZ,IAAI,EAAE;MACV,CAAC;MACDa,OAAO,EAAE;QACLb,IAAI,EAAE;MACV,CAAC;MACDc,UAAU,EAAE;QACRd,IAAI,EAAE;MACV,CAAC;MACDe,SAAS,EAAE;QACPf,IAAI,EAAE;MACV,CAAC;MACDgB,OAAO,EAAE;QACLhB,IAAI,EAAE;MACV,CAAC;MACDiB,OAAO,EAAE;QACLjB,IAAI,EAAE;MACV,CAAC;MACDkB,MAAM,EAAE;QACJlB,IAAI,EAAE;MACV,CAAC;MACDmB,WAAW,EAAE;QACTnB,IAAI,EAAE;MACV,CAAC;MACDoB,OAAO,EAAE;QACLpB,IAAI,EAAE;MACV,CAAC;MACDqB,MAAM,EAAE;QACJrB,IAAI,EAAE;MACV,CAAC;MACDsB,MAAM,EAAE;QACJtB,IAAI,EAAE;MACV,CAAC;MACDuB,QAAQ,EAAE;QACNvB,IAAI,EAAE;MACV,CAAC;MACDwB,MAAM,EAAE;QACJxB,IAAI,EAAE;MACV,CAAC;MACDyB,IAAI,EAAE;QACFzB,IAAI,EAAE;MACV;IAAC,GACGJ,UAAU,IAAI,CAAC,CAAC;EAE5B,CAAC,CAAC;AACN,CAAC;AAAC"}
|
package/dynamoDb/index.js
CHANGED
|
@@ -9,5 +9,6 @@ var _longText = require("./storage/longText");
|
|
|
9
9
|
var _date = require("./storage/date");
|
|
10
10
|
var _plainObject = require("./path/plainObject");
|
|
11
11
|
var _datetime = require("./transformValue/datetime");
|
|
12
|
-
var
|
|
12
|
+
var _locationFolderId = require("./path/locationFolderId");
|
|
13
|
+
var _default = () => [(0, _richText.createRichTextStorageTransformPlugin)(), (0, _longText.createLongTextStorageTransformPlugin)(), (0, _date.createDateStorageTransformPlugin)(), (0, _plainObject.createPlainObjectPathPlugin)(), (0, _locationFolderId.createLocationFolderIdPathPlugin)(), (0, _datetime.createDatetimeTransformValuePlugin)()];
|
|
13
14
|
exports.default = _default;
|
package/dynamoDb/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createRichTextStorageTransformPlugin","createLongTextStorageTransformPlugin","createDateStorageTransformPlugin","createPlainObjectPathPlugin","createDatetimeTransformValuePlugin"],"sources":["index.ts"],"sourcesContent":["import { createRichTextStorageTransformPlugin } from \"./storage/richText\";\nimport { createLongTextStorageTransformPlugin } from \"./storage/longText\";\nimport { createDateStorageTransformPlugin } from \"./storage/date\";\nimport { createPlainObjectPathPlugin } from \"./path/plainObject\";\nimport { createDatetimeTransformValuePlugin } from \"./transformValue/datetime\";\n\nexport default () => [\n createRichTextStorageTransformPlugin(),\n createLongTextStorageTransformPlugin(),\n createDateStorageTransformPlugin(),\n createPlainObjectPathPlugin(),\n createDatetimeTransformValuePlugin()\n];\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;
|
|
1
|
+
{"version":3,"names":["createRichTextStorageTransformPlugin","createLongTextStorageTransformPlugin","createDateStorageTransformPlugin","createPlainObjectPathPlugin","createLocationFolderIdPathPlugin","createDatetimeTransformValuePlugin"],"sources":["index.ts"],"sourcesContent":["import { createRichTextStorageTransformPlugin } from \"./storage/richText\";\nimport { createLongTextStorageTransformPlugin } from \"./storage/longText\";\nimport { createDateStorageTransformPlugin } from \"./storage/date\";\nimport { createPlainObjectPathPlugin } from \"./path/plainObject\";\nimport { createDatetimeTransformValuePlugin } from \"./transformValue/datetime\";\nimport { createLocationFolderIdPathPlugin } from \"~/dynamoDb/path/locationFolderId\";\n\nexport default () => [\n createRichTextStorageTransformPlugin(),\n createLongTextStorageTransformPlugin(),\n createDateStorageTransformPlugin(),\n createPlainObjectPathPlugin(),\n createLocationFolderIdPathPlugin(),\n createDatetimeTransformValuePlugin()\n];\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AAAoF,eAErE,MAAM,CACjB,IAAAA,8CAAoC,GAAE,EACtC,IAAAC,8CAAoC,GAAE,EACtC,IAAAC,sCAAgC,GAAE,EAClC,IAAAC,wCAA2B,GAAE,EAC7B,IAAAC,kDAAgC,GAAE,EAClC,IAAAC,4CAAkC,GAAE,CACvC;AAAA"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.createLocationFolderIdPathPlugin = void 0;
|
|
8
|
+
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
9
|
+
var _CmsEntryFieldFilterPathPlugin = require("../../plugins/CmsEntryFieldFilterPathPlugin");
|
|
10
|
+
/**
|
|
11
|
+
* File is @internal
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
const createPath = ({
|
|
15
|
+
field
|
|
16
|
+
}) => {
|
|
17
|
+
const {
|
|
18
|
+
path
|
|
19
|
+
} = field.settings || {};
|
|
20
|
+
if (!path) {
|
|
21
|
+
throw new _error.default("Missing path settings value.", "FIELD_SETTINGS_ERROR", {
|
|
22
|
+
field
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
return path;
|
|
26
|
+
};
|
|
27
|
+
const createLocationFolderIdPathPlugin = () => {
|
|
28
|
+
return new _CmsEntryFieldFilterPathPlugin.CmsEntryFieldFilterPathPlugin({
|
|
29
|
+
fieldType: "text",
|
|
30
|
+
path: createPath,
|
|
31
|
+
canUse: (field, parents) => {
|
|
32
|
+
if (field.fieldId !== "folderId") {
|
|
33
|
+
return false;
|
|
34
|
+
} else if (!(parents !== null && parents !== void 0 && parents.length)) {
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
return parents[0] === "wbyAco_location";
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
exports.createLocationFolderIdPathPlugin = createLocationFolderIdPathPlugin;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createPath","field","path","settings","WebinyError","createLocationFolderIdPathPlugin","CmsEntryFieldFilterPathPlugin","fieldType","canUse","parents","fieldId","length"],"sources":["locationFolderId.ts"],"sourcesContent":["/**\n * File is @internal\n */\nimport WebinyError from \"@webiny/error\";\nimport {\n CmsEntryFieldFilterPathPlugin,\n CreatePathCallable\n} from \"~/plugins/CmsEntryFieldFilterPathPlugin\";\n\nconst createPath: CreatePathCallable = ({ field }) => {\n const { path } = field.settings || {};\n if (!path) {\n throw new WebinyError(\"Missing path settings value.\", \"FIELD_SETTINGS_ERROR\", {\n field\n });\n }\n return path;\n};\n\nexport const createLocationFolderIdPathPlugin = (): CmsEntryFieldFilterPathPlugin => {\n return new CmsEntryFieldFilterPathPlugin({\n fieldType: \"text\",\n path: createPath,\n canUse: (field, parents) => {\n if (field.fieldId !== \"folderId\") {\n return false;\n } else if (!parents?.length) {\n return false;\n }\n return parents[0] === \"wbyAco_location\";\n }\n });\n};\n"],"mappings":";;;;;;;AAGA;AACA;AAJA;AACA;AACA;;AAOA,MAAMA,UAA8B,GAAG,CAAC;EAAEC;AAAM,CAAC,KAAK;EAClD,MAAM;IAAEC;EAAK,CAAC,GAAGD,KAAK,CAACE,QAAQ,IAAI,CAAC,CAAC;EACrC,IAAI,CAACD,IAAI,EAAE;IACP,MAAM,IAAIE,cAAW,CAAC,8BAA8B,EAAE,sBAAsB,EAAE;MAC1EH;IACJ,CAAC,CAAC;EACN;EACA,OAAOC,IAAI;AACf,CAAC;AAEM,MAAMG,gCAAgC,GAAG,MAAqC;EACjF,OAAO,IAAIC,4DAA6B,CAAC;IACrCC,SAAS,EAAE,MAAM;IACjBL,IAAI,EAAEF,UAAU;IAChBQ,MAAM,EAAE,CAACP,KAAK,EAAEQ,OAAO,KAAK;MACxB,IAAIR,KAAK,CAACS,OAAO,KAAK,UAAU,EAAE;QAC9B,OAAO,KAAK;MAChB,CAAC,MAAM,IAAI,EAACD,OAAO,aAAPA,OAAO,eAAPA,OAAO,CAAEE,MAAM,GAAE;QACzB,OAAO,KAAK;MAChB;MACA,OAAOF,OAAO,CAAC,CAAC,CAAC,KAAK,iBAAiB;IAC3C;EACJ,CAAC,CAAC;AACN,CAAC;AAAC"}
|
package/dynamoDb/storage/date.js
CHANGED
|
@@ -33,7 +33,7 @@ const convertFromStorage = (field, value) => {
|
|
|
33
33
|
}
|
|
34
34
|
};
|
|
35
35
|
const convertValueToStorage = (field, value) => {
|
|
36
|
-
if (value.toISOString) {
|
|
36
|
+
if (value instanceof Date || value.toISOString) {
|
|
37
37
|
return value.toISOString();
|
|
38
38
|
} else if (typeof value === "string") {
|
|
39
39
|
return value;
|
|
@@ -75,16 +75,7 @@ const createDateStorageTransformPlugin = () => {
|
|
|
75
75
|
return convertValueToStorage(field, v);
|
|
76
76
|
});
|
|
77
77
|
}
|
|
78
|
-
|
|
79
|
-
return value.toISOString();
|
|
80
|
-
} else if (typeof value === "string") {
|
|
81
|
-
return value;
|
|
82
|
-
}
|
|
83
|
-
throw new _error.default("Error converting value to a storage type.", "TO_STORAGE_ERROR", {
|
|
84
|
-
value,
|
|
85
|
-
fieldId: field.fieldId,
|
|
86
|
-
storageId: field.storageId
|
|
87
|
-
});
|
|
78
|
+
return convertValueToStorage(field, value);
|
|
88
79
|
}
|
|
89
80
|
});
|
|
90
81
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["excludeTypes","convertFromStorage","field","value","multipleValues","result","v","push","Date","console","log","convertValueToStorage","toISOString","WebinyError","fieldId","storageId","createDateStorageTransformPlugin","StorageTransformPlugin","fieldType","fromStorage","type","settings","includes","toStorage","filter","map"],"sources":["date.ts"],"sourcesContent":["/**\n * File is @internal\n */\nimport WebinyError from \"@webiny/error\";\nimport { StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\nconst excludeTypes = [\"time\", \"dateTimeWithTimezone\"];\n\nconst convertFromStorage = (\n field: Pick<CmsModelField, \"multipleValues\">,\n value: string | string[]\n) => {\n try {\n if (field.multipleValues) {\n const result: Date[] = [];\n for (const v of value) {\n if (!v) {\n continue;\n }\n try {\n result.push(new Date(v));\n } catch {}\n }\n return result;\n }\n return new Date(value as string);\n } catch {\n console.log(`Could not transform from storage for field type`);\n return value;\n }\n};\n\nconst convertValueToStorage = (field: CmsModelField, value: any): any => {\n if ((value as any).toISOString) {\n return (value as Date).toISOString();\n } else if (typeof value === \"string\") {\n return value as string;\n }\n throw new WebinyError(\"Error converting value to a storage type.\", \"TO_STORAGE_ERROR\", {\n value: value,\n fieldId: field.fieldId,\n storageId: field.storageId\n });\n};\n\nexport const createDateStorageTransformPlugin = () => {\n return new StorageTransformPlugin({\n fieldType: \"datetime\",\n fromStorage: async ({ value, field }) => {\n const { type } = field.settings || {};\n if (!value || !type || excludeTypes.includes(type)) {\n return value;\n }\n return convertFromStorage(field, value);\n },\n toStorage: async ({ value, field }) => {\n const { type } = field.settings || {};\n if (!value || !type || excludeTypes.includes(type)) {\n return value;\n }\n if (field.multipleValues) {\n const multipleValues = value as (string | Date | null | undefined)[];\n return (multipleValues || [])\n .filter(v => !!v)\n .map(v => {\n return convertValueToStorage(field, v);\n });\n }\n
|
|
1
|
+
{"version":3,"names":["excludeTypes","convertFromStorage","field","value","multipleValues","result","v","push","Date","console","log","convertValueToStorage","toISOString","WebinyError","fieldId","storageId","createDateStorageTransformPlugin","StorageTransformPlugin","fieldType","fromStorage","type","settings","includes","toStorage","filter","map"],"sources":["date.ts"],"sourcesContent":["/**\n * File is @internal\n */\nimport WebinyError from \"@webiny/error\";\nimport { StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\nconst excludeTypes = [\"time\", \"dateTimeWithTimezone\"];\n\nconst convertFromStorage = (\n field: Pick<CmsModelField, \"multipleValues\">,\n value: string | string[]\n) => {\n try {\n if (field.multipleValues) {\n const result: Date[] = [];\n for (const v of value) {\n if (!v) {\n continue;\n }\n try {\n result.push(new Date(v));\n } catch {}\n }\n return result;\n }\n return new Date(value as string);\n } catch {\n console.log(`Could not transform from storage for field type`);\n return value;\n }\n};\n\nconst convertValueToStorage = (field: CmsModelField, value: any): any => {\n if (value instanceof Date || (value as any).toISOString) {\n return (value as Date).toISOString();\n } else if (typeof value === \"string\") {\n return value as string;\n }\n throw new WebinyError(\"Error converting value to a storage type.\", \"TO_STORAGE_ERROR\", {\n value: value,\n fieldId: field.fieldId,\n storageId: field.storageId\n });\n};\n\nexport const createDateStorageTransformPlugin = () => {\n return new StorageTransformPlugin({\n fieldType: \"datetime\",\n fromStorage: async ({ value, field }) => {\n const { type } = field.settings || {};\n if (!value || !type || excludeTypes.includes(type)) {\n return value;\n }\n return convertFromStorage(field, value);\n },\n toStorage: async ({ value, field }) => {\n const { type } = field.settings || {};\n if (!value || !type || excludeTypes.includes(type)) {\n return value;\n }\n if (field.multipleValues) {\n const multipleValues = value as (string | Date | null | undefined)[];\n return (multipleValues || [])\n .filter(v => !!v)\n .map(v => {\n return convertValueToStorage(field, v);\n });\n }\n return convertValueToStorage(field, value);\n }\n });\n};\n"],"mappings":";;;;;;;AAGA;AACA;AAJA;AACA;AACA;;AAKA,MAAMA,YAAY,GAAG,CAAC,MAAM,EAAE,sBAAsB,CAAC;AAErD,MAAMC,kBAAkB,GAAG,CACvBC,KAA4C,EAC5CC,KAAwB,KACvB;EACD,IAAI;IACA,IAAID,KAAK,CAACE,cAAc,EAAE;MACtB,MAAMC,MAAc,GAAG,EAAE;MACzB,KAAK,MAAMC,CAAC,IAAIH,KAAK,EAAE;QACnB,IAAI,CAACG,CAAC,EAAE;UACJ;QACJ;QACA,IAAI;UACAD,MAAM,CAACE,IAAI,CAAC,IAAIC,IAAI,CAACF,CAAC,CAAC,CAAC;QAC5B,CAAC,CAAC,MAAM,CAAC;MACb;MACA,OAAOD,MAAM;IACjB;IACA,OAAO,IAAIG,IAAI,CAACL,KAAK,CAAW;EACpC,CAAC,CAAC,MAAM;IACJM,OAAO,CAACC,GAAG,CAAE,iDAAgD,CAAC;IAC9D,OAAOP,KAAK;EAChB;AACJ,CAAC;AAED,MAAMQ,qBAAqB,GAAG,CAACT,KAAoB,EAAEC,KAAU,KAAU;EACrE,IAAIA,KAAK,YAAYK,IAAI,IAAKL,KAAK,CAASS,WAAW,EAAE;IACrD,OAAQT,KAAK,CAAUS,WAAW,EAAE;EACxC,CAAC,MAAM,IAAI,OAAOT,KAAK,KAAK,QAAQ,EAAE;IAClC,OAAOA,KAAK;EAChB;EACA,MAAM,IAAIU,cAAW,CAAC,2CAA2C,EAAE,kBAAkB,EAAE;IACnFV,KAAK,EAAEA,KAAK;IACZW,OAAO,EAAEZ,KAAK,CAACY,OAAO;IACtBC,SAAS,EAAEb,KAAK,CAACa;EACrB,CAAC,CAAC;AACN,CAAC;AAEM,MAAMC,gCAAgC,GAAG,MAAM;EAClD,OAAO,IAAIC,sCAAsB,CAAC;IAC9BC,SAAS,EAAE,UAAU;IACrBC,WAAW,EAAE,OAAO;MAAEhB,KAAK;MAAED;IAAM,CAAC,KAAK;MACrC,MAAM;QAAEkB;MAAK,CAAC,GAAGlB,KAAK,CAACmB,QAAQ,IAAI,CAAC,CAAC;MACrC,IAAI,CAAClB,KAAK,IAAI,CAACiB,IAAI,IAAIpB,YAAY,CAACsB,QAAQ,CAACF,IAAI,CAAC,EAAE;QAChD,OAAOjB,KAAK;MAChB;MACA,OAAOF,kBAAkB,CAACC,KAAK,EAAEC,KAAK,CAAC;IAC3C,CAAC;IACDoB,SAAS,EAAE,OAAO;MAAEpB,KAAK;MAAED;IAAM,CAAC,KAAK;MACnC,MAAM;QAAEkB;MAAK,CAAC,GAAGlB,KAAK,CAACmB,QAAQ,IAAI,CAAC,CAAC;MACrC,IAAI,CAAClB,KAAK,IAAI,CAACiB,IAAI,IAAIpB,YAAY,CAACsB,QAAQ,CAACF,IAAI,CAAC,EAAE;QAChD,OAAOjB,KAAK;MAChB;MACA,IAAID,KAAK,CAACE,cAAc,EAAE;QACtB,MAAMA,cAAc,GAAGD,KAA6C;QACpE,OAAO,CAACC,cAAc,IAAI,EAAE,EACvBoB,MAAM,CAAClB,CAAC,IAAI,CAAC,CAACA,CAAC,CAAC,CAChBmB,GAAG,CAACnB,CAAC,IAAI;UACN,OAAOK,qBAAqB,CAACT,KAAK,EAAEI,CAAC,CAAC;QAC1C,CAAC,CAAC;MACV;MACA,OAAOK,qBAAqB,CAACT,KAAK,EAAEC,KAAK,CAAC;IAC9C;EACJ,CAAC,CAAC;AACN,CAAC;AAAC"}
|
|
@@ -10,5 +10,7 @@ interface Params {
|
|
|
10
10
|
*
|
|
11
11
|
* In case of nested fields, fieldId is all the parent fieldIds + current one, joined by the dot (.).
|
|
12
12
|
*/
|
|
13
|
-
export declare const createFields: (params: Params) =>
|
|
13
|
+
export declare const createFields: (params: Params) => {
|
|
14
|
+
[x: string]: Field;
|
|
15
|
+
};
|
|
14
16
|
export {};
|
|
@@ -9,6 +9,63 @@ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/obje
|
|
|
9
9
|
var _systemFields = require("./systemFields");
|
|
10
10
|
var _plugins = require("../../../plugins");
|
|
11
11
|
var _mapPlugins = require("./mapPlugins");
|
|
12
|
+
const createFieldCollection = params => {
|
|
13
|
+
const {
|
|
14
|
+
fields,
|
|
15
|
+
parents,
|
|
16
|
+
transformValuePlugins,
|
|
17
|
+
valuePathPlugins,
|
|
18
|
+
system
|
|
19
|
+
} = params;
|
|
20
|
+
return fields.reduce((collection, field) => {
|
|
21
|
+
var _field$settings;
|
|
22
|
+
const transformPlugin = transformValuePlugins[field.type];
|
|
23
|
+
const valuePathPlugin = valuePathPlugins[field.type];
|
|
24
|
+
const basePath = system ? [] : ["values"];
|
|
25
|
+
/**
|
|
26
|
+
* The required fieldId is a product of all of its parents and its own fieldId.
|
|
27
|
+
*/
|
|
28
|
+
const fieldId = [...parents, {
|
|
29
|
+
fieldId: field.fieldId,
|
|
30
|
+
multipleValues: field.multipleValues
|
|
31
|
+
}].map(f => f.fieldId).join(".");
|
|
32
|
+
collection[fieldId] = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, field), {}, {
|
|
33
|
+
parents,
|
|
34
|
+
system,
|
|
35
|
+
createPath: params => {
|
|
36
|
+
if (valuePathPlugin && valuePathPlugin.canUse(field, parents.map(p => p.fieldId))) {
|
|
37
|
+
return valuePathPlugin.createPath(params);
|
|
38
|
+
}
|
|
39
|
+
return basePath.concat(parents.map(parent => parent.fieldId)).concat([params.field.fieldId]).join(".");
|
|
40
|
+
},
|
|
41
|
+
transform: value => {
|
|
42
|
+
if (!transformPlugin) {
|
|
43
|
+
return value;
|
|
44
|
+
}
|
|
45
|
+
return transformPlugin.transform({
|
|
46
|
+
field,
|
|
47
|
+
value
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
const childFields = (_field$settings = field.settings) === null || _field$settings === void 0 ? void 0 : _field$settings.fields;
|
|
52
|
+
if (!(childFields !== null && childFields !== void 0 && childFields.length)) {
|
|
53
|
+
return collection;
|
|
54
|
+
}
|
|
55
|
+
const result = createFieldCollection({
|
|
56
|
+
fields: childFields,
|
|
57
|
+
parents: [...parents, {
|
|
58
|
+
fieldId: field.fieldId,
|
|
59
|
+
multipleValues: field.multipleValues
|
|
60
|
+
}],
|
|
61
|
+
transformValuePlugins,
|
|
62
|
+
valuePathPlugins,
|
|
63
|
+
system
|
|
64
|
+
});
|
|
65
|
+
Object.assign(collection, result);
|
|
66
|
+
return collection;
|
|
67
|
+
}, {});
|
|
68
|
+
};
|
|
12
69
|
/**
|
|
13
70
|
* This method will map the fieldId (fieldId -> field) to the actual field.
|
|
14
71
|
*
|
|
@@ -29,77 +86,20 @@ const createFields = params => {
|
|
|
29
86
|
type: _plugins.CmsEntryFieldFilterPathPlugin.type,
|
|
30
87
|
property: "fieldType"
|
|
31
88
|
});
|
|
32
|
-
const collection = (
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
return transformPlugin.transform({
|
|
48
|
-
field,
|
|
49
|
-
value
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
return fields;
|
|
54
|
-
}, {});
|
|
55
|
-
const addFieldsToCollection = (fields, parents = []) => {
|
|
56
|
-
/**
|
|
57
|
-
* Exit early if no fields are sent.
|
|
58
|
-
*/
|
|
59
|
-
if (fields.length === 0) {
|
|
60
|
-
return;
|
|
61
|
-
}
|
|
62
|
-
for (const field of fields) {
|
|
63
|
-
var _field$settings2;
|
|
64
|
-
const transformPlugin = transformValuePlugins[field.type];
|
|
65
|
-
const valuePathPlugin = valuePathPlugins[field.type];
|
|
66
|
-
/**
|
|
67
|
-
* The required fieldId is a product of all of its parents and its own fieldId.
|
|
68
|
-
*/
|
|
69
|
-
const fieldId = [...parents, {
|
|
70
|
-
fieldId: field.fieldId,
|
|
71
|
-
multipleValues: field.multipleValues
|
|
72
|
-
}].map(f => f.fieldId).join(".");
|
|
73
|
-
collection[fieldId] = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, field), {}, {
|
|
74
|
-
parents,
|
|
75
|
-
system: false,
|
|
76
|
-
createPath: params => {
|
|
77
|
-
if (valuePathPlugin) {
|
|
78
|
-
return valuePathPlugin.createPath(params);
|
|
79
|
-
}
|
|
80
|
-
return ["values"].concat(parents.map(parent => parent.fieldId)).concat([params.field.fieldId]).join(".");
|
|
81
|
-
},
|
|
82
|
-
transform: value => {
|
|
83
|
-
if (!transformPlugin) {
|
|
84
|
-
return value;
|
|
85
|
-
}
|
|
86
|
-
return transformPlugin.transform({
|
|
87
|
-
field,
|
|
88
|
-
value
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
});
|
|
92
|
-
const childFields = (_field$settings2 = field.settings) === null || _field$settings2 === void 0 ? void 0 : _field$settings2.fields;
|
|
93
|
-
if (!childFields || childFields.length === 0) {
|
|
94
|
-
continue;
|
|
95
|
-
}
|
|
96
|
-
addFieldsToCollection(childFields, [...parents, {
|
|
97
|
-
fieldId: field.fieldId,
|
|
98
|
-
multipleValues: field.multipleValues
|
|
99
|
-
}]);
|
|
100
|
-
}
|
|
101
|
-
};
|
|
102
|
-
addFieldsToCollection(fields);
|
|
103
|
-
return collection;
|
|
89
|
+
const collection = createFieldCollection({
|
|
90
|
+
fields: (0, _systemFields.createSystemFields)(),
|
|
91
|
+
transformValuePlugins,
|
|
92
|
+
valuePathPlugins,
|
|
93
|
+
parents: [],
|
|
94
|
+
system: true
|
|
95
|
+
});
|
|
96
|
+
const result = createFieldCollection({
|
|
97
|
+
fields,
|
|
98
|
+
transformValuePlugins,
|
|
99
|
+
valuePathPlugins,
|
|
100
|
+
parents: [],
|
|
101
|
+
system: false
|
|
102
|
+
});
|
|
103
|
+
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, collection), result);
|
|
104
104
|
};
|
|
105
105
|
exports.createFields = createFields;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["createFieldCollection","params","fields","parents","transformValuePlugins","valuePathPlugins","system","reduce","collection","field","transformPlugin","type","valuePathPlugin","basePath","fieldId","multipleValues","map","f","join","createPath","canUse","p","concat","parent","transform","value","childFields","settings","length","result","Object","assign","createFields","plugins","getMappedPlugins","property","CmsEntryFieldFilterPathPlugin","createSystemFields"],"sources":["createFields.ts"],"sourcesContent":["import { CmsModelField } from \"@webiny/api-headless-cms/types\";\nimport { createSystemFields } from \"./systemFields\";\nimport { Field, FieldParent } from \"./types\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { CmsFieldFilterValueTransformPlugin } from \"~/types\";\nimport { CmsEntryFieldFilterPathPlugin } from \"~/plugins\";\nimport { getMappedPlugins } from \"./mapPlugins\";\n\ninterface Params {\n fields: CmsModelField[];\n plugins: PluginsContainer;\n}\n\ninterface FieldCollection {\n [key: string]: Field;\n}\n\ninterface AddFieldsToCollectionParams {\n fields: CmsModelField[];\n parents: FieldParent[];\n transformValuePlugins: Record<string, CmsFieldFilterValueTransformPlugin>;\n valuePathPlugins: Record<string, CmsEntryFieldFilterPathPlugin>;\n system: boolean;\n}\n\nconst createFieldCollection = (params: AddFieldsToCollectionParams): FieldCollection => {\n const { fields, parents, transformValuePlugins, valuePathPlugins, system } = params;\n return fields.reduce<FieldCollection>((collection, field) => {\n const transformPlugin = transformValuePlugins[field.type];\n const valuePathPlugin = valuePathPlugins[field.type];\n\n const basePath = system ? [] : [\"values\"];\n /**\n * The required fieldId is a product of all of its parents and its own fieldId.\n */\n const fieldId = [\n ...parents,\n {\n fieldId: field.fieldId,\n multipleValues: field.multipleValues\n }\n ]\n .map(f => f.fieldId)\n .join(\".\");\n\n collection[fieldId] = {\n ...field,\n parents,\n system,\n createPath: params => {\n if (\n valuePathPlugin &&\n valuePathPlugin.canUse(\n field,\n parents.map(p => p.fieldId)\n )\n ) {\n return valuePathPlugin.createPath(params);\n }\n\n return basePath\n .concat(parents.map(parent => parent.fieldId))\n .concat([params.field.fieldId])\n .join(\".\");\n },\n transform: value => {\n if (!transformPlugin) {\n return value;\n }\n return transformPlugin.transform({\n field,\n value\n });\n }\n };\n const childFields = field.settings?.fields;\n if (!childFields?.length) {\n return collection;\n }\n\n const result = createFieldCollection({\n fields: childFields,\n parents: [\n ...parents,\n {\n fieldId: field.fieldId,\n multipleValues: field.multipleValues\n }\n ],\n transformValuePlugins,\n valuePathPlugins,\n system\n });\n Object.assign(collection, result);\n return collection;\n }, {});\n};\n/**\n * This method will map the fieldId (fieldId -> field) to the actual field.\n *\n * In case of nested fields, fieldId is all the parent fieldIds + current one, joined by the dot (.).\n */\nexport const createFields = (params: Params) => {\n const { fields, plugins } = params;\n\n const transformValuePlugins = getMappedPlugins<CmsFieldFilterValueTransformPlugin>({\n plugins,\n type: \"cms-field-filter-value-transform\",\n property: \"fieldType\"\n });\n const valuePathPlugins = getMappedPlugins<CmsEntryFieldFilterPathPlugin>({\n plugins,\n type: CmsEntryFieldFilterPathPlugin.type,\n property: \"fieldType\"\n });\n\n const collection = createFieldCollection({\n fields: createSystemFields(),\n transformValuePlugins,\n valuePathPlugins,\n parents: [],\n system: true\n });\n\n const result = createFieldCollection({\n fields,\n transformValuePlugins,\n valuePathPlugins,\n parents: [],\n system: false\n });\n\n return {\n ...collection,\n ...result\n };\n};\n"],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@ exports.createDefaultFilterCreate = void 0;
|
|
|
8
8
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
9
9
|
var _CmsEntryFieldFilterPlugin = require("../../../../plugins/CmsEntryFieldFilterPlugin");
|
|
10
10
|
const createDefaultFilterCreate = () => {
|
|
11
|
-
|
|
11
|
+
const plugin = new _CmsEntryFieldFilterPlugin.CmsEntryFieldFilterPlugin({
|
|
12
12
|
fieldType: _CmsEntryFieldFilterPlugin.CmsEntryFieldFilterPlugin.ALL,
|
|
13
13
|
create: params => {
|
|
14
14
|
const {
|
|
@@ -37,5 +37,7 @@ const createDefaultFilterCreate = () => {
|
|
|
37
37
|
};
|
|
38
38
|
}
|
|
39
39
|
});
|
|
40
|
+
plugin.name = `headless-cms.ddb.filter.default`;
|
|
41
|
+
return plugin;
|
|
40
42
|
};
|
|
41
43
|
exports.createDefaultFilterCreate = createDefaultFilterCreate;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createDefaultFilterCreate","CmsEntryFieldFilterPlugin","fieldType","ALL","create","params","negate","transformValue","field","compareValue","valueFilterPlugins","
|
|
1
|
+
{"version":3,"names":["createDefaultFilterCreate","plugin","CmsEntryFieldFilterPlugin","fieldType","ALL","create","params","negate","transformValue","field","compareValue","valueFilterPlugins","operation","WebinyError","fieldPathId","parents","map","f","fieldId","join","path","createPath","name"],"sources":["defaultFilterCreate.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { CmsEntryFieldFilterPlugin } from \"~/plugins/CmsEntryFieldFilterPlugin\";\n\nexport const createDefaultFilterCreate = () => {\n const plugin = new CmsEntryFieldFilterPlugin({\n fieldType: CmsEntryFieldFilterPlugin.ALL,\n create: params => {\n const { negate, transformValue, field, compareValue, valueFilterPlugins } = params;\n const plugin = valueFilterPlugins[params.operation];\n if (!plugin) {\n throw new WebinyError(\n `Missing ValueFilterPlugin for operation \"${params.operation}\".`,\n \"MISSING_OPERATION_PLUGIN\",\n {\n operation: params.operation\n }\n );\n }\n return {\n negate,\n transformValue,\n field,\n compareValue,\n fieldPathId: [...field.parents.map(f => f.fieldId), field.fieldId].join(\".\"),\n path: field.createPath({\n field\n }),\n plugin\n };\n }\n });\n\n plugin.name = `headless-cms.ddb.filter.default`;\n\n return plugin;\n};\n"],"mappings":";;;;;;;AAAA;AACA;AAEO,MAAMA,yBAAyB,GAAG,MAAM;EAC3C,MAAMC,MAAM,GAAG,IAAIC,oDAAyB,CAAC;IACzCC,SAAS,EAAED,oDAAyB,CAACE,GAAG;IACxCC,MAAM,EAAEC,MAAM,IAAI;MACd,MAAM;QAAEC,MAAM;QAAEC,cAAc;QAAEC,KAAK;QAAEC,YAAY;QAAEC;MAAmB,CAAC,GAAGL,MAAM;MAClF,MAAML,MAAM,GAAGU,kBAAkB,CAACL,MAAM,CAACM,SAAS,CAAC;MACnD,IAAI,CAACX,MAAM,EAAE;QACT,MAAM,IAAIY,cAAW,CAChB,4CAA2CP,MAAM,CAACM,SAAU,IAAG,EAChE,0BAA0B,EAC1B;UACIA,SAAS,EAAEN,MAAM,CAACM;QACtB,CAAC,CACJ;MACL;MACA,OAAO;QACHL,MAAM;QACNC,cAAc;QACdC,KAAK;QACLC,YAAY;QACZI,WAAW,EAAE,CAAC,GAAGL,KAAK,CAACM,OAAO,CAACC,GAAG,CAACC,CAAC,IAAIA,CAAC,CAACC,OAAO,CAAC,EAAET,KAAK,CAACS,OAAO,CAAC,CAACC,IAAI,CAAC,GAAG,CAAC;QAC5EC,IAAI,EAAEX,KAAK,CAACY,UAAU,CAAC;UACnBZ;QACJ,CAAC,CAAC;QACFR;MACJ,CAAC;IACL;EACJ,CAAC,CAAC;EAEFA,MAAM,CAACqB,IAAI,GAAI,iCAAgC;EAE/C,OAAOrB,MAAM;AACjB,CAAC;AAAC"}
|
|
@@ -10,7 +10,7 @@ var _where = require("../where");
|
|
|
10
10
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
11
11
|
var _transform = require("../transform");
|
|
12
12
|
const objectFilterCreate = () => {
|
|
13
|
-
|
|
13
|
+
const plugin = new _CmsEntryFieldFilterPlugin.CmsEntryFieldFilterPlugin({
|
|
14
14
|
fieldType: "object",
|
|
15
15
|
create: params => {
|
|
16
16
|
const {
|
|
@@ -82,5 +82,7 @@ const objectFilterCreate = () => {
|
|
|
82
82
|
return filters;
|
|
83
83
|
}
|
|
84
84
|
});
|
|
85
|
+
plugin.name = `headless-cms.ddb.filter.object`;
|
|
86
|
+
return plugin;
|
|
85
87
|
};
|
|
86
88
|
exports.objectFilterCreate = objectFilterCreate;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["objectFilterCreate","CmsEntryFieldFilterPlugin","fieldType","create","params","value","objectValue","valueFilterPlugins","transformValuePlugins","getFilterCreatePlugin","field","parentField","fields","filters","key","undefined","whereParams","extractWhereParams","negate","fieldId","operation","fieldPath","parents","map","p","concat","join","WebinyError","filterCreatePlugin","type","transformValuePlugin","transformValueCallable","transform","result","compareValue","transformValue","Array","isArray","push"],"sources":["objectFilterCreate.ts"],"sourcesContent":["import { CmsEntryFieldFilterPlugin } from \"~/plugins/CmsEntryFieldFilterPlugin\";\nimport { extractWhereParams } from \"~/operations/entry/filtering/where\";\nimport WebinyError from \"@webiny/error\";\nimport { CmsFieldFilterValueTransformPlugin } from \"~/types\";\nimport { transformValue } from \"~/operations/entry/filtering/transform\";\n\nexport const objectFilterCreate = () => {\n
|
|
1
|
+
{"version":3,"names":["objectFilterCreate","plugin","CmsEntryFieldFilterPlugin","fieldType","create","params","value","objectValue","valueFilterPlugins","transformValuePlugins","getFilterCreatePlugin","field","parentField","fields","filters","key","undefined","whereParams","extractWhereParams","negate","fieldId","operation","fieldPath","parents","map","p","concat","join","WebinyError","filterCreatePlugin","type","transformValuePlugin","transformValueCallable","transform","result","compareValue","transformValue","Array","isArray","push","name"],"sources":["objectFilterCreate.ts"],"sourcesContent":["import { CmsEntryFieldFilterPlugin } from \"~/plugins/CmsEntryFieldFilterPlugin\";\nimport { extractWhereParams } from \"~/operations/entry/filtering/where\";\nimport WebinyError from \"@webiny/error\";\nimport { CmsFieldFilterValueTransformPlugin } from \"~/types\";\nimport { transformValue } from \"~/operations/entry/filtering/transform\";\n\nexport const objectFilterCreate = () => {\n const plugin = new CmsEntryFieldFilterPlugin({\n fieldType: \"object\",\n create: params => {\n const {\n value: objectValue,\n valueFilterPlugins,\n transformValuePlugins,\n getFilterCreatePlugin,\n field: parentField,\n fields\n } = params;\n\n const filters = [];\n\n for (const key in objectValue) {\n const value = objectValue[key];\n if (value === undefined) {\n continue;\n }\n const whereParams = extractWhereParams(key);\n if (!whereParams) {\n continue;\n }\n const { negate, fieldId, operation } = whereParams;\n\n const fieldPath = parentField.parents\n .map(p => p.fieldId)\n .concat([parentField.fieldId, fieldId])\n .join(\".\");\n\n const field = fields[fieldPath];\n if (!field) {\n throw new WebinyError(\n `There is no field with the field path \"${fieldPath}\".`,\n \"FIELD_ERROR\",\n {\n fieldId\n }\n );\n }\n\n const filterCreatePlugin = getFilterCreatePlugin(field.type);\n\n const transformValuePlugin: CmsFieldFilterValueTransformPlugin =\n transformValuePlugins[field.type];\n\n const transformValueCallable = (value: any) => {\n if (!transformValuePlugin) {\n return value;\n }\n return transformValuePlugin.transform({\n field,\n value\n });\n };\n\n const result = filterCreatePlugin.create({\n key,\n value,\n valueFilterPlugins,\n transformValuePlugins,\n getFilterCreatePlugin,\n operation,\n negate,\n field,\n fields,\n compareValue: transformValue({\n value,\n transform: transformValueCallable\n }),\n transformValue: transformValueCallable\n });\n if (!result) {\n continue;\n }\n if (Array.isArray(result)) {\n filters.push(...result);\n continue;\n }\n\n filters.push(result);\n }\n return filters;\n }\n });\n\n plugin.name = `headless-cms.ddb.filter.object`;\n\n return plugin;\n};\n"],"mappings":";;;;;;;AAAA;AACA;AACA;AAEA;AAEO,MAAMA,kBAAkB,GAAG,MAAM;EACpC,MAAMC,MAAM,GAAG,IAAIC,oDAAyB,CAAC;IACzCC,SAAS,EAAE,QAAQ;IACnBC,MAAM,EAAEC,MAAM,IAAI;MACd,MAAM;QACFC,KAAK,EAAEC,WAAW;QAClBC,kBAAkB;QAClBC,qBAAqB;QACrBC,qBAAqB;QACrBC,KAAK,EAAEC,WAAW;QAClBC;MACJ,CAAC,GAAGR,MAAM;MAEV,MAAMS,OAAO,GAAG,EAAE;MAElB,KAAK,MAAMC,GAAG,IAAIR,WAAW,EAAE;QAC3B,MAAMD,KAAK,GAAGC,WAAW,CAACQ,GAAG,CAAC;QAC9B,IAAIT,KAAK,KAAKU,SAAS,EAAE;UACrB;QACJ;QACA,MAAMC,WAAW,GAAG,IAAAC,yBAAkB,EAACH,GAAG,CAAC;QAC3C,IAAI,CAACE,WAAW,EAAE;UACd;QACJ;QACA,MAAM;UAAEE,MAAM;UAAEC,OAAO;UAAEC;QAAU,CAAC,GAAGJ,WAAW;QAElD,MAAMK,SAAS,GAAGV,WAAW,CAACW,OAAO,CAChCC,GAAG,CAACC,CAAC,IAAIA,CAAC,CAACL,OAAO,CAAC,CACnBM,MAAM,CAAC,CAACd,WAAW,CAACQ,OAAO,EAAEA,OAAO,CAAC,CAAC,CACtCO,IAAI,CAAC,GAAG,CAAC;QAEd,MAAMhB,KAAK,GAAGE,MAAM,CAACS,SAAS,CAAC;QAC/B,IAAI,CAACX,KAAK,EAAE;UACR,MAAM,IAAIiB,cAAW,CAChB,0CAAyCN,SAAU,IAAG,EACvD,aAAa,EACb;YACIF;UACJ,CAAC,CACJ;QACL;QAEA,MAAMS,kBAAkB,GAAGnB,qBAAqB,CAACC,KAAK,CAACmB,IAAI,CAAC;QAE5D,MAAMC,oBAAwD,GAC1DtB,qBAAqB,CAACE,KAAK,CAACmB,IAAI,CAAC;QAErC,MAAME,sBAAsB,GAAI1B,KAAU,IAAK;UAC3C,IAAI,CAACyB,oBAAoB,EAAE;YACvB,OAAOzB,KAAK;UAChB;UACA,OAAOyB,oBAAoB,CAACE,SAAS,CAAC;YAClCtB,KAAK;YACLL;UACJ,CAAC,CAAC;QACN,CAAC;QAED,MAAM4B,MAAM,GAAGL,kBAAkB,CAACzB,MAAM,CAAC;UACrCW,GAAG;UACHT,KAAK;UACLE,kBAAkB;UAClBC,qBAAqB;UACrBC,qBAAqB;UACrBW,SAAS;UACTF,MAAM;UACNR,KAAK;UACLE,MAAM;UACNsB,YAAY,EAAE,IAAAC,yBAAc,EAAC;YACzB9B,KAAK;YACL2B,SAAS,EAAED;UACf,CAAC,CAAC;UACFI,cAAc,EAAEJ;QACpB,CAAC,CAAC;QACF,IAAI,CAACE,MAAM,EAAE;UACT;QACJ;QACA,IAAIG,KAAK,CAACC,OAAO,CAACJ,MAAM,CAAC,EAAE;UACvBpB,OAAO,CAACyB,IAAI,CAAC,GAAGL,MAAM,CAAC;UACvB;QACJ;QAEApB,OAAO,CAACyB,IAAI,CAACL,MAAM,CAAC;MACxB;MACA,OAAOpB,OAAO;IAClB;EACJ,CAAC,CAAC;EAEFb,MAAM,CAACuC,IAAI,GAAI,gCAA+B;EAE9C,OAAOvC,MAAM;AACjB,CAAC;AAAC"}
|
|
@@ -10,7 +10,7 @@ var _CmsEntryFieldFilterPlugin = require("../../../../plugins/CmsEntryFieldFilte
|
|
|
10
10
|
var _where = require("../where");
|
|
11
11
|
var _transform = require("../transform");
|
|
12
12
|
const createRefFilterCreate = () => {
|
|
13
|
-
|
|
13
|
+
const plugin = new _CmsEntryFieldFilterPlugin.CmsEntryFieldFilterPlugin({
|
|
14
14
|
fieldType: "ref",
|
|
15
15
|
create: params => {
|
|
16
16
|
const {
|
|
@@ -67,5 +67,7 @@ const createRefFilterCreate = () => {
|
|
|
67
67
|
return filters;
|
|
68
68
|
}
|
|
69
69
|
});
|
|
70
|
+
plugin.name = `headless-cms.ddb.filter.ref`;
|
|
71
|
+
return plugin;
|
|
70
72
|
};
|
|
71
73
|
exports.createRefFilterCreate = createRefFilterCreate;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createRefFilterCreate","CmsEntryFieldFilterPlugin","fieldType","create","params","value","valueFilterPlugins","transformValuePlugins","field","propertyFilters","Object","keys","length","filters","propertyFilter","whereParams","extractWhereParams","fieldId","propertyId","operation","propertyOperation","negate","transformValuePlugin","type","transformValueCallable","transform","filterPlugin","WebinyError","paths","createPath","push","path","join","fieldPathId","parents","map","f","
|
|
1
|
+
{"version":3,"names":["createRefFilterCreate","plugin","CmsEntryFieldFilterPlugin","fieldType","create","params","value","valueFilterPlugins","transformValuePlugins","field","propertyFilters","Object","keys","length","filters","propertyFilter","whereParams","extractWhereParams","fieldId","propertyId","operation","propertyOperation","negate","transformValuePlugin","type","transformValueCallable","transform","filterPlugin","WebinyError","paths","createPath","push","path","join","fieldPathId","parents","map","f","compareValue","transformValue","name"],"sources":["refFilterCreate.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport {\n CmsEntryFieldFilterPlugin,\n CmsEntryFieldFilterPluginCreateResponse\n} from \"~/plugins/CmsEntryFieldFilterPlugin\";\nimport { extractWhereParams } from \"~/operations/entry/filtering/where\";\nimport { transformValue } from \"~/operations/entry/filtering/transform\";\n\nexport const createRefFilterCreate = () => {\n const plugin = new CmsEntryFieldFilterPlugin({\n fieldType: \"ref\",\n create: params => {\n const { value, valueFilterPlugins, transformValuePlugins, field } = params;\n const propertyFilters = Object.keys(value);\n if (propertyFilters.length === 0) {\n return null;\n }\n\n const filters: CmsEntryFieldFilterPluginCreateResponse[] = [];\n\n for (const propertyFilter of propertyFilters) {\n const whereParams = extractWhereParams(propertyFilter);\n if (!whereParams) {\n continue;\n }\n const { fieldId: propertyId, operation: propertyOperation, negate } = whereParams;\n\n const transformValuePlugin = transformValuePlugins[field.type];\n\n const transformValueCallable = (value: any) => {\n if (!transformValuePlugin) {\n return value;\n }\n return transformValuePlugin.transform({\n field,\n value\n });\n };\n\n const filterPlugin = valueFilterPlugins[propertyOperation];\n if (!filterPlugin) {\n throw new WebinyError(\n `Missing operation filter for \"${propertyOperation}\".`,\n \"MISSING_OPERATION_FILTER\"\n );\n }\n\n const paths = [\n field.createPath({\n field\n }),\n propertyId\n ];\n\n filters.push({\n field,\n path: paths.join(\".\"),\n fieldPathId: [...field.parents.map(f => f.fieldId), field.fieldId].join(\".\"),\n plugin: filterPlugin,\n negate,\n compareValue: transformValue({\n value: value[propertyFilter],\n transform: transformValueCallable\n }),\n transformValue: transformValueCallable\n });\n }\n\n return filters;\n }\n });\n\n plugin.name = `headless-cms.ddb.filter.ref`;\n\n return plugin;\n};\n"],"mappings":";;;;;;;AAAA;AACA;AAIA;AACA;AAEO,MAAMA,qBAAqB,GAAG,MAAM;EACvC,MAAMC,MAAM,GAAG,IAAIC,oDAAyB,CAAC;IACzCC,SAAS,EAAE,KAAK;IAChBC,MAAM,EAAEC,MAAM,IAAI;MACd,MAAM;QAAEC,KAAK;QAAEC,kBAAkB;QAAEC,qBAAqB;QAAEC;MAAM,CAAC,GAAGJ,MAAM;MAC1E,MAAMK,eAAe,GAAGC,MAAM,CAACC,IAAI,CAACN,KAAK,CAAC;MAC1C,IAAII,eAAe,CAACG,MAAM,KAAK,CAAC,EAAE;QAC9B,OAAO,IAAI;MACf;MAEA,MAAMC,OAAkD,GAAG,EAAE;MAE7D,KAAK,MAAMC,cAAc,IAAIL,eAAe,EAAE;QAC1C,MAAMM,WAAW,GAAG,IAAAC,yBAAkB,EAACF,cAAc,CAAC;QACtD,IAAI,CAACC,WAAW,EAAE;UACd;QACJ;QACA,MAAM;UAAEE,OAAO,EAAEC,UAAU;UAAEC,SAAS,EAAEC,iBAAiB;UAAEC;QAAO,CAAC,GAAGN,WAAW;QAEjF,MAAMO,oBAAoB,GAAGf,qBAAqB,CAACC,KAAK,CAACe,IAAI,CAAC;QAE9D,MAAMC,sBAAsB,GAAInB,KAAU,IAAK;UAC3C,IAAI,CAACiB,oBAAoB,EAAE;YACvB,OAAOjB,KAAK;UAChB;UACA,OAAOiB,oBAAoB,CAACG,SAAS,CAAC;YAClCjB,KAAK;YACLH;UACJ,CAAC,CAAC;QACN,CAAC;QAED,MAAMqB,YAAY,GAAGpB,kBAAkB,CAACc,iBAAiB,CAAC;QAC1D,IAAI,CAACM,YAAY,EAAE;UACf,MAAM,IAAIC,cAAW,CAChB,iCAAgCP,iBAAkB,IAAG,EACtD,0BAA0B,CAC7B;QACL;QAEA,MAAMQ,KAAK,GAAG,CACVpB,KAAK,CAACqB,UAAU,CAAC;UACbrB;QACJ,CAAC,CAAC,EACFU,UAAU,CACb;QAEDL,OAAO,CAACiB,IAAI,CAAC;UACTtB,KAAK;UACLuB,IAAI,EAAEH,KAAK,CAACI,IAAI,CAAC,GAAG,CAAC;UACrBC,WAAW,EAAE,CAAC,GAAGzB,KAAK,CAAC0B,OAAO,CAACC,GAAG,CAACC,CAAC,IAAIA,CAAC,CAACnB,OAAO,CAAC,EAAET,KAAK,CAACS,OAAO,CAAC,CAACe,IAAI,CAAC,GAAG,CAAC;UAC5EhC,MAAM,EAAE0B,YAAY;UACpBL,MAAM;UACNgB,YAAY,EAAE,IAAAC,yBAAc,EAAC;YACzBjC,KAAK,EAAEA,KAAK,CAACS,cAAc,CAAC;YAC5BW,SAAS,EAAED;UACf,CAAC,CAAC;UACFc,cAAc,EAAEd;QACpB,CAAC,CAAC;MACN;MAEA,OAAOX,OAAO;IAClB;EACJ,CAAC,CAAC;EAEFb,MAAM,CAACuC,IAAI,GAAI,6BAA4B;EAE3C,OAAOvC,MAAM;AACjB,CAAC;AAAC"}
|
|
@@ -44,6 +44,24 @@ const createSystemFields = () => {
|
|
|
44
44
|
storageId: "meta",
|
|
45
45
|
fieldId: "meta",
|
|
46
46
|
label: "Meta"
|
|
47
|
+
}, {
|
|
48
|
+
id: "wbyAco_location",
|
|
49
|
+
type: "object",
|
|
50
|
+
storageId: "location",
|
|
51
|
+
label: "Location",
|
|
52
|
+
fieldId: "wbyAco_location",
|
|
53
|
+
settings: {
|
|
54
|
+
fields: [{
|
|
55
|
+
id: "folderId",
|
|
56
|
+
type: "text",
|
|
57
|
+
fieldId: "folderId",
|
|
58
|
+
label: "Folder ID",
|
|
59
|
+
storageId: "folderId",
|
|
60
|
+
settings: {
|
|
61
|
+
path: "location.folderId"
|
|
62
|
+
}
|
|
63
|
+
}]
|
|
64
|
+
}
|
|
47
65
|
}, {
|
|
48
66
|
id: "ownedBy",
|
|
49
67
|
type: "plainObject",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createSystemFields","id","type","storageId","fieldId","label","settings","path"],"sources":["systemFields.ts"],"sourcesContent":["import { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\ntype Field = Pick<CmsModelField, \"id\" | \"type\" | \"storageId\" | \"fieldId\" | \"settings\" | \"label\">;\n\nexport const createSystemFields = (): Field[] => {\n return [\n {\n id: \"id\",\n type: \"text\",\n storageId: \"id\",\n fieldId: \"id\",\n label: \"ID\"\n },\n {\n id: \"entryId\",\n type: \"text\",\n storageId: \"entryId\",\n fieldId: \"entryId\",\n label: \"Entry ID\"\n },\n {\n id: \"createdOn\",\n type: \"datetime\",\n storageId: \"createdOn\",\n fieldId: \"createdOn\",\n label: \"Created On\"\n },\n {\n id: \"savedOn\",\n type: \"datetime\",\n storageId: \"savedOn\",\n fieldId: \"savedOn\",\n label: \"Saved On\"\n },\n {\n id: \"createdBy\",\n type: \"plainObject\",\n storageId: \"createdBy\",\n fieldId: \"createdBy\",\n label: \"Created By\",\n settings: {\n path: \"createdBy.id\"\n }\n },\n {\n id: \"meta\",\n type: \"plainObject\",\n storageId: \"meta\",\n fieldId: \"meta\",\n label: \"Meta\"\n },\n {\n id: \"ownedBy\",\n type: \"plainObject\",\n storageId: \"ownedBy\",\n fieldId: \"ownedBy\",\n label: \"Owned By\",\n settings: {\n path: \"ownedBy.id\"\n }\n },\n {\n id: \"version\",\n type: \"number\",\n storageId: \"version\",\n fieldId: \"version\",\n label: \"Version\"\n },\n {\n id: \"status\",\n type: \"text\",\n storageId: \"status\",\n fieldId: \"status\",\n label: \"Status\"\n }\n ];\n};\n"],"mappings":";;;;;;AAIO,MAAMA,kBAAkB,GAAG,MAAe;EAC7C,OAAO,CACH;IACIC,EAAE,EAAE,IAAI;IACRC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,IAAI;IACfC,OAAO,EAAE,IAAI;IACbC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,WAAW;IACfC,IAAI,EAAE,UAAU;IAChBC,SAAS,EAAE,WAAW;IACtBC,OAAO,EAAE,WAAW;IACpBC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,UAAU;IAChBC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,WAAW;IACfC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,WAAW;IACtBC,OAAO,EAAE,WAAW;IACpBC,KAAK,EAAE,YAAY;IACnBC,QAAQ,EAAE;MACNC,IAAI,EAAE;IACV;EACJ,CAAC,EACD;IACIN,EAAE,EAAE,MAAM;IACVC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,MAAM;IACjBC,OAAO,EAAE,MAAM;IACfC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBC,KAAK,EAAE,UAAU;IACjBC,QAAQ,EAAE;MACNC,IAAI,EAAE;IACV;EACJ,CAAC,EACD;IACIN,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,QAAQ;IACdC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,QAAQ;IACZC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,QAAQ;IACnBC,OAAO,EAAE,QAAQ;IACjBC,KAAK,EAAE;EACX,CAAC,CACJ;AACL,CAAC;AAAC"}
|
|
1
|
+
{"version":3,"names":["createSystemFields","id","type","storageId","fieldId","label","settings","path","fields"],"sources":["systemFields.ts"],"sourcesContent":["import { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\ntype Field = Pick<CmsModelField, \"id\" | \"type\" | \"storageId\" | \"fieldId\" | \"settings\" | \"label\">;\n\nexport const createSystemFields = (): Field[] => {\n return [\n {\n id: \"id\",\n type: \"text\",\n storageId: \"id\",\n fieldId: \"id\",\n label: \"ID\"\n },\n {\n id: \"entryId\",\n type: \"text\",\n storageId: \"entryId\",\n fieldId: \"entryId\",\n label: \"Entry ID\"\n },\n {\n id: \"createdOn\",\n type: \"datetime\",\n storageId: \"createdOn\",\n fieldId: \"createdOn\",\n label: \"Created On\"\n },\n {\n id: \"savedOn\",\n type: \"datetime\",\n storageId: \"savedOn\",\n fieldId: \"savedOn\",\n label: \"Saved On\"\n },\n {\n id: \"createdBy\",\n type: \"plainObject\",\n storageId: \"createdBy\",\n fieldId: \"createdBy\",\n label: \"Created By\",\n settings: {\n path: \"createdBy.id\"\n }\n },\n {\n id: \"meta\",\n type: \"plainObject\",\n storageId: \"meta\",\n fieldId: \"meta\",\n label: \"Meta\"\n },\n {\n id: \"wbyAco_location\",\n type: \"object\",\n storageId: \"location\",\n label: \"Location\",\n fieldId: \"wbyAco_location\",\n settings: {\n fields: [\n {\n id: \"folderId\",\n type: \"text\",\n fieldId: \"folderId\",\n label: \"Folder ID\",\n storageId: \"folderId\",\n settings: {\n path: \"location.folderId\"\n }\n }\n ]\n }\n },\n {\n id: \"ownedBy\",\n type: \"plainObject\",\n storageId: \"ownedBy\",\n fieldId: \"ownedBy\",\n label: \"Owned By\",\n settings: {\n path: \"ownedBy.id\"\n }\n },\n {\n id: \"version\",\n type: \"number\",\n storageId: \"version\",\n fieldId: \"version\",\n label: \"Version\"\n },\n {\n id: \"status\",\n type: \"text\",\n storageId: \"status\",\n fieldId: \"status\",\n label: \"Status\"\n }\n ];\n};\n"],"mappings":";;;;;;AAIO,MAAMA,kBAAkB,GAAG,MAAe;EAC7C,OAAO,CACH;IACIC,EAAE,EAAE,IAAI;IACRC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,IAAI;IACfC,OAAO,EAAE,IAAI;IACbC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,WAAW;IACfC,IAAI,EAAE,UAAU;IAChBC,SAAS,EAAE,WAAW;IACtBC,OAAO,EAAE,WAAW;IACpBC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,UAAU;IAChBC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,WAAW;IACfC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,WAAW;IACtBC,OAAO,EAAE,WAAW;IACpBC,KAAK,EAAE,YAAY;IACnBC,QAAQ,EAAE;MACNC,IAAI,EAAE;IACV;EACJ,CAAC,EACD;IACIN,EAAE,EAAE,MAAM;IACVC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,MAAM;IACjBC,OAAO,EAAE,MAAM;IACfC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,iBAAiB;IACrBC,IAAI,EAAE,QAAQ;IACdC,SAAS,EAAE,UAAU;IACrBE,KAAK,EAAE,UAAU;IACjBD,OAAO,EAAE,iBAAiB;IAC1BE,QAAQ,EAAE;MACNE,MAAM,EAAE,CACJ;QACIP,EAAE,EAAE,UAAU;QACdC,IAAI,EAAE,MAAM;QACZE,OAAO,EAAE,UAAU;QACnBC,KAAK,EAAE,WAAW;QAClBF,SAAS,EAAE,UAAU;QACrBG,QAAQ,EAAE;UACNC,IAAI,EAAE;QACV;MACJ,CAAC;IAET;EACJ,CAAC,EACD;IACIN,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBC,KAAK,EAAE,UAAU;IACjBC,QAAQ,EAAE;MACNC,IAAI,EAAE;IACV;EACJ,CAAC,EACD;IACIN,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,QAAQ;IACdC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBC,KAAK,EAAE;EACX,CAAC,EACD;IACIJ,EAAE,EAAE,QAAQ;IACZC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,QAAQ;IACnBC,OAAO,EAAE,QAAQ;IACjBC,KAAK,EAAE;EACX,CAAC,CACJ;AACL,CAAC;AAAC"}
|
|
@@ -5,7 +5,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.extractWhereParams = void 0;
|
|
7
7
|
const extractWhereParams = key => {
|
|
8
|
-
const
|
|
8
|
+
const isWbyAco = key.match("wbyAco_") !== null;
|
|
9
|
+
const result = key.replace("wbyAco_", "").split("_");
|
|
9
10
|
const fieldId = result.shift();
|
|
10
11
|
if (!fieldId) {
|
|
11
12
|
return null;
|
|
@@ -24,7 +25,7 @@ const extractWhereParams = key => {
|
|
|
24
25
|
const negate = rawOp.match("not_") !== null;
|
|
25
26
|
const operation = rawOp.replace("not_", "");
|
|
26
27
|
return {
|
|
27
|
-
fieldId,
|
|
28
|
+
fieldId: isWbyAco ? `wbyAco_${fieldId}` : fieldId,
|
|
28
29
|
operation,
|
|
29
30
|
negate
|
|
30
31
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["extractWhereParams","key","result","split","fieldId","shift","rawOp","length","join","operation","negate"
|
|
1
|
+
{"version":3,"names":["extractWhereParams","key","isWbyAco","match","result","replace","split","fieldId","shift","rawOp","length","join","operation","negate"],"sources":["where.ts"],"sourcesContent":["export const extractWhereParams = (key: string) => {\n const isWbyAco = key.match(\"wbyAco_\") !== null;\n const result = key.replace(\"wbyAco_\", \"\").split(\"_\");\n const fieldId = result.shift();\n if (!fieldId) {\n return null;\n }\n const rawOp = result.length === 0 ? \"eq\" : result.join(\"_\");\n /**\n * When rawOp is not, it means it is equal negated so just return that.\n */\n if (rawOp === \"not\") {\n return {\n fieldId,\n operation: \"eq\",\n negate: true\n };\n }\n const negate = rawOp.match(\"not_\") !== null;\n const operation = rawOp.replace(\"not_\", \"\");\n return {\n fieldId: isWbyAco ? `wbyAco_${fieldId}` : fieldId,\n operation,\n negate\n };\n};\n"],"mappings":";;;;;;AAAO,MAAMA,kBAAkB,GAAIC,GAAW,IAAK;EAC/C,MAAMC,QAAQ,GAAGD,GAAG,CAACE,KAAK,CAAC,SAAS,CAAC,KAAK,IAAI;EAC9C,MAAMC,MAAM,GAAGH,GAAG,CAACI,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAACC,KAAK,CAAC,GAAG,CAAC;EACpD,MAAMC,OAAO,GAAGH,MAAM,CAACI,KAAK,EAAE;EAC9B,IAAI,CAACD,OAAO,EAAE;IACV,OAAO,IAAI;EACf;EACA,MAAME,KAAK,GAAGL,MAAM,CAACM,MAAM,KAAK,CAAC,GAAG,IAAI,GAAGN,MAAM,CAACO,IAAI,CAAC,GAAG,CAAC;EAC3D;AACJ;AACA;EACI,IAAIF,KAAK,KAAK,KAAK,EAAE;IACjB,OAAO;MACHF,OAAO;MACPK,SAAS,EAAE,IAAI;MACfC,MAAM,EAAE;IACZ,CAAC;EACL;EACA,MAAMA,MAAM,GAAGJ,KAAK,CAACN,KAAK,CAAC,MAAM,CAAC,KAAK,IAAI;EAC3C,MAAMS,SAAS,GAAGH,KAAK,CAACJ,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;EAC3C,OAAO;IACHE,OAAO,EAAEL,QAAQ,GAAI,UAASK,OAAQ,EAAC,GAAGA,OAAO;IACjDK,SAAS;IACTC;EACJ,CAAC;AACL,CAAC;AAAC"}
|
|
@@ -872,7 +872,25 @@ const createEntriesStorageOperations = params => {
|
|
|
872
872
|
where,
|
|
873
873
|
limit: MAX_LIST_LIMIT
|
|
874
874
|
});
|
|
875
|
-
|
|
875
|
+
const result = {};
|
|
876
|
+
for (const item of items) {
|
|
877
|
+
const fieldValue = item.values[field.fieldId];
|
|
878
|
+
if (!fieldValue) {
|
|
879
|
+
continue;
|
|
880
|
+
}
|
|
881
|
+
const values = Array.isArray(fieldValue) ? fieldValue : [fieldValue];
|
|
882
|
+
if (values.length === 0) {
|
|
883
|
+
continue;
|
|
884
|
+
}
|
|
885
|
+
for (const value of values) {
|
|
886
|
+
var _result$value;
|
|
887
|
+
result[value] = {
|
|
888
|
+
value,
|
|
889
|
+
count: (((_result$value = result[value]) === null || _result$value === void 0 ? void 0 : _result$value.count) || 0) + 1
|
|
890
|
+
};
|
|
891
|
+
}
|
|
892
|
+
}
|
|
893
|
+
return Object.values(result).sort((a, b) => a.value > b.value ? 1 : b.value > a.value ? -1 : 0).sort((a, b) => b.count - a.count);
|
|
876
894
|
};
|
|
877
895
|
return {
|
|
878
896
|
create,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createType","createLatestType","createPublishedType","convertToStorageEntry","params","model","storageEntry","values","convertValueKeyToStorage","fields","convertFromStorageEntry","convertValueKeyFromStorage","MAX_LIST_LIMIT","createEntriesStorageOperations","entity","plugins","storageOperationsCmsModelPlugin","getStorageOperationsCmsModelPlugin","oneByType","StorageOperationsCmsModelPlugin","type","getStorageOperationsModel","plugin","getModel","dataLoaders","DataLoadersHandler","storageTransformPlugins","byType","StorageTransformPlugin","reduce","collection","fieldType","createStorageTransformCallable","field","value","fromStorage","getStoragePlugin","create","initialModel","entry","initialStorageEntry","partitionKey","createPartitionKey","id","locale","tenant","isPublished","status","locked","items","putBatch","PK","SK","createRevisionSortKey","TYPE","GSI1_PK","createGSIPartitionKey","GSI1_SK","createGSISortKey","createLatestSortKey","push","createPublishedSortKey","batchWriteAll","table","clearAll","ex","WebinyError","message","code","error","createRevisionFrom","update","latestStorageEntry","getLatestRevisionByEntryId","deleteEntry","entryId","queryAllParams","options","gte","records","queryAll","map","item","deleteBatch","deleteRevision","latestEntry","initialLatestStorageEntry","publishedStorageEntry","getPublishedRevisionByEntryId","deleteMultipleEntries","entries","revisions","getAllEntryRevisions","ids","revision","version","shift","getRevisionById","getRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","queryParams","lt","zeroPad","filters","attr","eq","reverse","result","queryOne","cleanupItem","list","limit","initialLimit","where","initialWhere","after","sort","sortBy","search","published","index","storageEntries","length","hasMoreItems","totalCount","cursor","modelFields","createFields","Promise","all","fieldId","filteredItems","filter","fullTextSearch","term","sortedItems","start","parseInt","decodeCursor","end","undefined","slicedItems","slice","encodeCursor","cleanupItems","get","publish","initialPublishedStorageEntry","CONTENT_ENTRY_STATUS","UNPUBLISHED","unpublish","getUniqueFieldValues","find","f","Array","from","Set","delete"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { DataLoadersHandler } from \"./dataLoaders\";\nimport {\n CmsEntry,\n CmsEntryListWhere,\n CmsModel,\n CmsStorageEntry,\n CONTENT_ENTRY_STATUS,\n StorageOperationsCmsModel\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport {\n createGSIPartitionKey,\n createGSISortKey,\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys\";\nimport { batchWriteAll } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport {\n DbItem,\n queryAll,\n QueryAllParams,\n queryOne,\n QueryOneParams\n} from \"@webiny/db-dynamodb/utils/query\";\nimport { cleanupItem, cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils/cursor\";\nimport { zeroPad } from \"@webiny/utils/zeroPad\";\nimport { StorageOperationsCmsModelPlugin, StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport { FilterItemFromStorage } from \"./filtering/types\";\nimport { createFields } from \"~/operations/entry/filtering/createFields\";\nimport { filter, sort } from \"~/operations/entry/filtering\";\nimport { DocumentClient } from \"aws-sdk/clients/dynamodb\";\nimport { CmsEntryStorageOperations } from \"~/types\";\n\nconst createType = (): string => {\n return \"cms.entry\";\n};\nconst createLatestType = (): string => {\n return `${createType()}.l`;\n};\nconst createPublishedType = (): string => {\n return `${createType()}.p`;\n};\n\ninterface ConvertStorageEntryParams {\n storageEntry: CmsStorageEntry;\n model: StorageOperationsCmsModel;\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 = (params: ConvertStorageEntryParams): CmsStorageEntry => {\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 = 10000;\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: Entity<any>;\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 = (model: CmsModel): StorageOperationsCmsModel => {\n const plugin = getStorageOperationsCmsModelPlugin();\n return plugin.getModel(model);\n };\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const storageTransformPlugins = plugins\n .byType<StorageTransformPlugin>(StorageTransformPlugin.type)\n .reduce((collection, plugin) => {\n collection[plugin.fieldType] = plugin;\n return collection;\n }, {} as Record<string, StorageTransformPlugin>);\n\n const createStorageTransformCallable = (\n model: StorageOperationsCmsModel\n ): FilterItemFromStorage => {\n return (field, value) => {\n const plugin: StorageTransformPlugin = storageTransformPlugins[field.type];\n if (!plugin) {\n return value;\n }\n return plugin.fromStorage({\n model,\n field,\n value,\n getStoragePlugin(fieldType: string): StorageTransformPlugin {\n return storageTransformPlugins[fieldType] || storageTransformPlugins[\"*\"];\n },\n plugins\n });\n };\n };\n\n const create: CmsEntryStorageOperations[\"create\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const 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 * We need to:\n * - create new main entry item\n * - create new or update the latest entry item\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n\n /**\n * We need to create published entry if\n */\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert 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 partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - create the main entry item\n * - update the last entry item to a current one\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create revision from given entry.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n 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 partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const items = [];\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 items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\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 && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return 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 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 queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n };\n\n let records: DbItem<CmsEntry>[] = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n const items = records.map(item => {\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete the entry.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n id\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 locale: model.locale,\n tenant: model.tenant\n });\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n })\n ];\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n /**\n * If revision we are deleting is the published one as well, we need to delete those records as well.\n */\n if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (initialLatestStorageEntry) {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...latestStorageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(latestStorageEntry)\n })\n );\n }\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, {\n error: ex,\n entry,\n latestEntry\n });\n }\n };\n\n const deleteMultipleEntries: CmsEntryStorageOperations[\"deleteMultipleEntries\"] = async (\n initialModel,\n params\n ) => {\n const { entries } = params;\n const model = getStorageOperationsModel(initialModel);\n /**\n * First we need all the revisions of the entries we want to delete.\n */\n const revisions = await dataLoaders.getAllEntryRevisions({\n model,\n ids: entries\n });\n /**\n * Then we need to construct the queries for all the revisions and entries.\n */\n const items: Record<string, DocumentClient.WriteRequest>[] = [];\n for (const id of entries) {\n /**\n * Latest item.\n */\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"L\"\n })\n );\n /**\n * Published item.\n */\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"P\"\n })\n );\n }\n /**\n * Exact revisions of all the entries\n */\n for (const revision of revisions) {\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id: revision.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey({\n version: revision.version\n })\n })\n );\n }\n\n await batchWriteAll({\n table: entity.table,\n items\n });\n };\n\n const getLatestRevisionByEntryId: CmsEntryStorageOperations[\"getLatestRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getLatestRevisionByEntryId({\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: CmsEntryStorageOperations[\"getPublishedRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getPublishedRevisionByEntryId({\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: CmsEntryStorageOperations[\"getRevisionById\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getRevisionById({\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: CmsEntryStorageOperations[\"getRevisions\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getAllEntryRevisions({\n model,\n ids: [params.id]\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getByIds: CmsEntryStorageOperations[\"getByIds\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getRevisionById({\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: CmsEntryStorageOperations[\"getLatestByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getLatestRevisionByEntryId({\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: CmsEntryStorageOperations[\"getPublishedByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getPublishedRevisionByEntryId({\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: CmsEntryStorageOperations[\"getPreviousRevision\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { entryId, version } = params;\n const queryParams: QueryOneParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant: model.tenant,\n locale: model.locale,\n id: entryId\n }),\n options: {\n lt: `REV#${zeroPad(version)}`,\n /**\n * We need to have extra checks because DynamoDB will return published or latest record if there is no REV# record.\n */\n filters: [\n {\n attr: \"TYPE\",\n eq: createType()\n },\n {\n attr: \"version\",\n lt: version\n }\n ],\n reverse: true\n }\n };\n\n try {\n const result = await queryOne<CmsEntry>(queryParams);\n\n const storageEntry = cleanupItem(entity, result);\n if (!storageEntry) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry,\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get previous version of given entry.\",\n ex.code || \"GET_PREVIOUS_VERSION_ERROR\",\n {\n ...params,\n error: ex,\n partitionKey: queryParams.partitionKey,\n options: queryParams.options,\n model\n }\n );\n }\n };\n\n const list: CmsEntryStorageOperations[\"list\"] = async (initialModel, params) => {\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 queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createGSIPartitionKey(model, type),\n options: {\n index: \"GSI1\",\n gte: \" \"\n }\n };\n let storageEntries: CmsStorageEntry[] = [];\n try {\n storageEntries = await queryAll<CmsStorageEntry>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(ex.message, \"QUERY_ENTRIES_ERROR\", {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n });\n }\n if (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,\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;\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({\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({\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 = totalCount > start + limit ? encodeCursor(`${start + limit}`) : null;\n return {\n hasMoreItems,\n totalCount,\n cursor,\n items: cleanupItems(entity, slicedItems)\n };\n };\n\n const get: CmsEntryStorageOperations[\"get\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish: CmsEntryStorageOperations[\"publish\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n /**\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 const initialPublishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to update:\n * - current entry revision sort key\n * - published sort key\n * - the latest sort key - if entry updated is actually latest\n * - previous published entry to unpublished status - if any previously published entry\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n if (initialLatestStorageEntry && entry.id === initialLatestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n if (initialPublishedStorageEntry && initialPublishedStorageEntry.id !== entry.id) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...publishedStorageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(publishedStorageEntry),\n TYPE: createType(),\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED,\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(publishedStorageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return 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: CmsEntryStorageOperations[\"unpublish\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const 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 items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated alongside the unpublishing one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && entry.id === latestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return 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 return Array.from(new Set(items.map(item => item.values[field.fieldId])));\n };\n\n return {\n create,\n createRevisionFrom,\n update,\n delete: deleteEntry,\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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"}
|
|
1
|
+
{"version":3,"names":["createType","createLatestType","createPublishedType","convertToStorageEntry","params","model","storageEntry","values","convertValueKeyToStorage","fields","convertFromStorageEntry","convertValueKeyFromStorage","MAX_LIST_LIMIT","createEntriesStorageOperations","entity","plugins","storageOperationsCmsModelPlugin","getStorageOperationsCmsModelPlugin","oneByType","StorageOperationsCmsModelPlugin","type","getStorageOperationsModel","plugin","getModel","dataLoaders","DataLoadersHandler","storageTransformPlugins","byType","StorageTransformPlugin","reduce","collection","fieldType","createStorageTransformCallable","field","value","fromStorage","getStoragePlugin","create","initialModel","entry","initialStorageEntry","partitionKey","createPartitionKey","id","locale","tenant","isPublished","status","locked","items","putBatch","PK","SK","createRevisionSortKey","TYPE","GSI1_PK","createGSIPartitionKey","GSI1_SK","createGSISortKey","createLatestSortKey","push","createPublishedSortKey","batchWriteAll","table","clearAll","ex","WebinyError","message","code","error","createRevisionFrom","update","latestStorageEntry","getLatestRevisionByEntryId","deleteEntry","entryId","queryAllParams","options","gte","records","queryAll","map","item","deleteBatch","deleteRevision","latestEntry","initialLatestStorageEntry","publishedStorageEntry","getPublishedRevisionByEntryId","deleteMultipleEntries","entries","revisions","getAllEntryRevisions","ids","revision","version","shift","getRevisionById","getRevisions","getByIds","getLatestByIds","getPublishedByIds","getPreviousRevision","queryParams","lt","zeroPad","filters","attr","eq","reverse","result","queryOne","cleanupItem","list","limit","initialLimit","where","initialWhere","after","sort","sortBy","search","published","index","storageEntries","length","hasMoreItems","totalCount","cursor","modelFields","createFields","Promise","all","fieldId","filteredItems","filter","fullTextSearch","term","sortedItems","start","parseInt","decodeCursor","end","undefined","slicedItems","slice","encodeCursor","cleanupItems","get","publish","initialPublishedStorageEntry","CONTENT_ENTRY_STATUS","UNPUBLISHED","unpublish","getUniqueFieldValues","find","f","fieldValue","Array","isArray","count","Object","a","b","delete"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { DataLoadersHandler } from \"./dataLoaders\";\nimport {\n CmsEntry,\n CmsEntryListWhere,\n CmsEntryUniqueValue,\n CmsModel,\n CmsStorageEntry,\n CONTENT_ENTRY_STATUS,\n StorageOperationsCmsModel\n} from \"@webiny/api-headless-cms/types\";\nimport { Entity } from \"dynamodb-toolbox\";\nimport {\n createGSIPartitionKey,\n createGSISortKey,\n createLatestSortKey,\n createPartitionKey,\n createPublishedSortKey,\n createRevisionSortKey\n} from \"~/operations/entry/keys\";\nimport { batchWriteAll } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport {\n DbItem,\n queryAll,\n QueryAllParams,\n queryOne,\n QueryOneParams\n} from \"@webiny/db-dynamodb/utils/query\";\nimport { cleanupItem, cleanupItems } from \"@webiny/db-dynamodb/utils/cleanup\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils/cursor\";\nimport { zeroPad } from \"@webiny/utils/zeroPad\";\nimport { StorageOperationsCmsModelPlugin, StorageTransformPlugin } from \"@webiny/api-headless-cms\";\nimport { FilterItemFromStorage } from \"./filtering/types\";\nimport { createFields } from \"~/operations/entry/filtering/createFields\";\nimport { filter, sort } from \"~/operations/entry/filtering\";\nimport { DocumentClient } from \"aws-sdk/clients/dynamodb\";\nimport { CmsEntryStorageOperations } from \"~/types\";\n\nconst createType = (): string => {\n return \"cms.entry\";\n};\nconst createLatestType = (): string => {\n return `${createType()}.l`;\n};\nconst createPublishedType = (): string => {\n return `${createType()}.p`;\n};\n\ninterface ConvertStorageEntryParams {\n storageEntry: CmsStorageEntry;\n model: StorageOperationsCmsModel;\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 = (params: ConvertStorageEntryParams): CmsStorageEntry => {\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 = 10000;\n\nexport interface CreateEntriesStorageOperationsParams {\n entity: Entity<any>;\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 = (model: CmsModel): StorageOperationsCmsModel => {\n const plugin = getStorageOperationsCmsModelPlugin();\n return plugin.getModel(model);\n };\n\n const dataLoaders = new DataLoadersHandler({\n entity\n });\n\n const storageTransformPlugins = plugins\n .byType<StorageTransformPlugin>(StorageTransformPlugin.type)\n .reduce((collection, plugin) => {\n collection[plugin.fieldType] = plugin;\n return collection;\n }, {} as Record<string, StorageTransformPlugin>);\n\n const createStorageTransformCallable = (\n model: StorageOperationsCmsModel\n ): FilterItemFromStorage => {\n return (field, value) => {\n const plugin: StorageTransformPlugin = storageTransformPlugins[field.type];\n if (!plugin) {\n return value;\n }\n return plugin.fromStorage({\n model,\n field,\n value,\n getStoragePlugin(fieldType: string): StorageTransformPlugin {\n return storageTransformPlugins[fieldType] || storageTransformPlugins[\"*\"];\n },\n plugins\n });\n };\n };\n\n const create: CmsEntryStorageOperations[\"create\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const 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 * We need to:\n * - create new main entry item\n * - create new or update the latest entry item\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n\n /**\n * We need to create published entry if\n */\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert 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 partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const storageEntry = convertToStorageEntry({\n storageEntry: initialStorageEntry,\n model\n });\n /**\n * We need to:\n * - create the main entry item\n * - update the last entry item to a current one\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n ];\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create revision from given entry.\",\n ex.code || \"CREATE_REVISION_ERROR\",\n {\n error: ex,\n 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 partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const isPublished = entry.status === \"published\";\n const locked = isPublished ? true : entry.locked;\n\n const items = [];\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 items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createRevisionSortKey(storageEntry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(storageEntry)\n })\n );\n\n if (isPublished) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(storageEntry)\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 && latestStorageEntry.id === entry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n locked,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return 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 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 queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n options: {\n gte: \" \"\n }\n };\n\n let records: DbItem<CmsEntry>[] = [];\n try {\n records = await queryAll(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not load all records.\",\n ex.code || \"LOAD_ALL_RECORDS_ERROR\",\n {\n error: ex,\n id\n }\n );\n }\n const items = records.map(item => {\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete the entry.\",\n ex.code || \"DELETE_ENTRY_ERROR\",\n {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n id\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 locale: model.locale,\n tenant: model.tenant\n });\n\n const items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createRevisionSortKey(entry)\n })\n ];\n\n const publishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n /**\n * If revision we are deleting is the published one as well, we need to delete those records as well.\n */\n if (publishedStorageEntry && entry.id === publishedStorageEntry.id) {\n items.push(\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n })\n );\n }\n if (initialLatestStorageEntry) {\n const latestStorageEntry = convertToStorageEntry({\n storageEntry: initialLatestStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...latestStorageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(latestStorageEntry)\n })\n );\n }\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, {\n error: ex,\n entry,\n latestEntry\n });\n }\n };\n\n const deleteMultipleEntries: CmsEntryStorageOperations[\"deleteMultipleEntries\"] = async (\n initialModel,\n params\n ) => {\n const { entries } = params;\n const model = getStorageOperationsModel(initialModel);\n /**\n * First we need all the revisions of the entries we want to delete.\n */\n const revisions = await dataLoaders.getAllEntryRevisions({\n model,\n ids: entries\n });\n /**\n * Then we need to construct the queries for all the revisions and entries.\n */\n const items: Record<string, DocumentClient.WriteRequest>[] = [];\n for (const id of entries) {\n /**\n * Latest item.\n */\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"L\"\n })\n );\n /**\n * Published item.\n */\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: \"P\"\n })\n );\n }\n /**\n * Exact revisions of all the entries\n */\n for (const revision of revisions) {\n items.push(\n entity.deleteBatch({\n PK: createPartitionKey({\n id: revision.id,\n locale: model.locale,\n tenant: model.tenant\n }),\n SK: createRevisionSortKey({\n version: revision.version\n })\n })\n );\n }\n\n await batchWriteAll({\n table: entity.table,\n items\n });\n };\n\n const getLatestRevisionByEntryId: CmsEntryStorageOperations[\"getLatestRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getLatestRevisionByEntryId({\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: CmsEntryStorageOperations[\"getPublishedRevisionByEntryId\"] =\n async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getPublishedRevisionByEntryId({\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: CmsEntryStorageOperations[\"getRevisionById\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getRevisionById({\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: CmsEntryStorageOperations[\"getRevisions\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getAllEntryRevisions({\n model,\n ids: [params.id]\n });\n\n return items.map(item => {\n return convertFromStorageEntry({\n storageEntry: item,\n model\n });\n });\n };\n\n const getByIds: CmsEntryStorageOperations[\"getByIds\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getRevisionById({\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: CmsEntryStorageOperations[\"getLatestByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getLatestRevisionByEntryId({\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: CmsEntryStorageOperations[\"getPublishedByIds\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const items = await dataLoaders.getPublishedRevisionByEntryId({\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: CmsEntryStorageOperations[\"getPreviousRevision\"] = async (\n initialModel,\n params\n ) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { entryId, version } = params;\n const queryParams: QueryOneParams = {\n entity,\n partitionKey: createPartitionKey({\n tenant: model.tenant,\n locale: model.locale,\n id: entryId\n }),\n options: {\n lt: `REV#${zeroPad(version)}`,\n /**\n * We need to have extra checks because DynamoDB will return published or latest record if there is no REV# record.\n */\n filters: [\n {\n attr: \"TYPE\",\n eq: createType()\n },\n {\n attr: \"version\",\n lt: version\n }\n ],\n reverse: true\n }\n };\n\n try {\n const result = await queryOne<CmsEntry>(queryParams);\n\n const storageEntry = cleanupItem(entity, result);\n if (!storageEntry) {\n return null;\n }\n return convertFromStorageEntry({\n storageEntry,\n model\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get previous version of given entry.\",\n ex.code || \"GET_PREVIOUS_VERSION_ERROR\",\n {\n ...params,\n error: ex,\n partitionKey: queryParams.partitionKey,\n options: queryParams.options,\n model\n }\n );\n }\n };\n\n const list: CmsEntryStorageOperations[\"list\"] = async (initialModel, params) => {\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 queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createGSIPartitionKey(model, type),\n options: {\n index: \"GSI1\",\n gte: \" \"\n }\n };\n let storageEntries: CmsStorageEntry[] = [];\n try {\n storageEntries = await queryAll<CmsStorageEntry>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(ex.message, \"QUERY_ENTRIES_ERROR\", {\n error: ex,\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n });\n }\n if (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,\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;\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({\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({\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 = totalCount > start + limit ? encodeCursor(`${start + limit}`) : null;\n return {\n hasMoreItems,\n totalCount,\n cursor,\n items: cleanupItems(entity, slicedItems)\n };\n };\n\n const get: CmsEntryStorageOperations[\"get\"] = async (initialModel, params) => {\n const model = getStorageOperationsModel(initialModel);\n\n const { items } = await list(model, {\n ...params,\n limit: 1\n });\n return items.shift() || null;\n };\n\n const publish: CmsEntryStorageOperations[\"publish\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n /**\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 const initialPublishedStorageEntry = await getPublishedRevisionByEntryId(model, entry);\n\n const storageEntry = convertToStorageEntry({\n model,\n storageEntry: initialStorageEntry\n });\n /**\n * We need to update:\n * - current entry revision sort key\n * - published sort key\n * - the latest sort key - if entry updated is actually latest\n * - previous published entry to unpublished status - if any previously published entry\n */\n const items = [\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createPublishedSortKey(),\n TYPE: createPublishedType(),\n GSI1_PK: createGSIPartitionKey(model, \"P\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n if (initialLatestStorageEntry && entry.id === initialLatestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n if (initialPublishedStorageEntry && initialPublishedStorageEntry.id !== entry.id) {\n const publishedStorageEntry = convertToStorageEntry({\n storageEntry: initialPublishedStorageEntry,\n model\n });\n items.push(\n entity.putBatch({\n ...publishedStorageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(publishedStorageEntry),\n TYPE: createType(),\n status: CONTENT_ENTRY_STATUS.UNPUBLISHED,\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(publishedStorageEntry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return 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: CmsEntryStorageOperations[\"unpublish\"] = async (initialModel, params) => {\n const { entry, storageEntry: initialStorageEntry } = params;\n const model = getStorageOperationsModel(initialModel);\n\n const partitionKey = createPartitionKey({\n id: entry.id,\n locale: model.locale,\n tenant: model.tenant\n });\n\n const 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 items = [\n entity.deleteBatch({\n PK: partitionKey,\n SK: createPublishedSortKey()\n }),\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createRevisionSortKey(entry),\n TYPE: createType(),\n GSI1_PK: createGSIPartitionKey(model, \"A\"),\n GSI1_SK: createGSISortKey(entry)\n })\n ];\n\n /**\n * We need the latest entry to see if something needs to be updated alongside the unpublishing one.\n */\n const latestStorageEntry = await getLatestRevisionByEntryId(model, entry);\n\n if (latestStorageEntry && entry.id === latestStorageEntry.id) {\n items.push(\n entity.putBatch({\n ...storageEntry,\n PK: partitionKey,\n SK: createLatestSortKey(),\n TYPE: createLatestType(),\n GSI1_PK: createGSIPartitionKey(model, \"L\"),\n GSI1_SK: createGSISortKey(entry)\n })\n );\n }\n\n try {\n await batchWriteAll({\n table: entity.table,\n items\n });\n dataLoaders.clearAll({\n model\n });\n return 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 delete: deleteEntry,\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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"}
|
package/package.json
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/api-headless-cms-ddb",
|
|
3
|
-
"version": "0.0.0-unstable.
|
|
3
|
+
"version": "0.0.0-unstable.c7dec08bb0",
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"@webiny/api-headless-cms",
|
|
7
7
|
"storage-operations",
|
|
8
8
|
"dynamodb",
|
|
9
|
+
"ddb",
|
|
9
10
|
"cms:ddb"
|
|
10
11
|
],
|
|
11
12
|
"repository": {
|
|
@@ -22,11 +23,11 @@
|
|
|
22
23
|
"license": "MIT",
|
|
23
24
|
"dependencies": {
|
|
24
25
|
"@babel/runtime": "7.20.13",
|
|
25
|
-
"@webiny/api-headless-cms": "0.0.0-unstable.
|
|
26
|
-
"@webiny/db-dynamodb": "0.0.0-unstable.
|
|
27
|
-
"@webiny/error": "0.0.0-unstable.
|
|
28
|
-
"@webiny/handler-db": "0.0.0-unstable.
|
|
29
|
-
"@webiny/utils": "0.0.0-unstable.
|
|
26
|
+
"@webiny/api-headless-cms": "0.0.0-unstable.c7dec08bb0",
|
|
27
|
+
"@webiny/db-dynamodb": "0.0.0-unstable.c7dec08bb0",
|
|
28
|
+
"@webiny/error": "0.0.0-unstable.c7dec08bb0",
|
|
29
|
+
"@webiny/handler-db": "0.0.0-unstable.c7dec08bb0",
|
|
30
|
+
"@webiny/utils": "0.0.0-unstable.c7dec08bb0",
|
|
30
31
|
"aws-sdk": "2.1310.0",
|
|
31
32
|
"dataloader": "2.2.1",
|
|
32
33
|
"dot-prop": "6.0.1",
|
|
@@ -39,12 +40,11 @@
|
|
|
39
40
|
"@babel/core": "7.20.12",
|
|
40
41
|
"@babel/preset-env": "7.20.2",
|
|
41
42
|
"@types/jsonpack": "1.1.2",
|
|
42
|
-
"@webiny/cli": "0.0.0-unstable.
|
|
43
|
-
"@webiny/plugins": "0.0.0-unstable.
|
|
44
|
-
"@webiny/project-utils": "0.0.0-unstable.
|
|
45
|
-
"jest": "
|
|
43
|
+
"@webiny/cli": "0.0.0-unstable.c7dec08bb0",
|
|
44
|
+
"@webiny/plugins": "0.0.0-unstable.c7dec08bb0",
|
|
45
|
+
"@webiny/project-utils": "0.0.0-unstable.c7dec08bb0",
|
|
46
|
+
"jest": "29.5.0",
|
|
46
47
|
"jest-dynalite": "3.6.1",
|
|
47
|
-
"jest-environment-node": "27.5.1",
|
|
48
48
|
"ttypescript": "1.5.15",
|
|
49
49
|
"typescript": "4.7.4"
|
|
50
50
|
},
|
|
@@ -56,5 +56,5 @@
|
|
|
56
56
|
"build": "yarn webiny run build",
|
|
57
57
|
"watch": "yarn webiny run watch"
|
|
58
58
|
},
|
|
59
|
-
"gitHead": "
|
|
59
|
+
"gitHead": "c7dec08bb095467cca6a61381bd399d66b7bb147"
|
|
60
60
|
}
|
|
@@ -11,12 +11,13 @@ export interface CmsEntryFieldFilterPathPluginParams {
|
|
|
11
11
|
fieldType: string;
|
|
12
12
|
fieldId?: string[];
|
|
13
13
|
path: string | CreatePathCallable;
|
|
14
|
+
canUse?: (field: Pick<CmsModelField, "fieldId" | "type">, parents?: string[]) => boolean;
|
|
14
15
|
}
|
|
15
16
|
export declare class CmsEntryFieldFilterPathPlugin extends Plugin {
|
|
16
17
|
static readonly type: string;
|
|
17
18
|
private readonly config;
|
|
18
19
|
get fieldType(): string;
|
|
19
20
|
constructor(config: CmsEntryFieldFilterPathPluginParams);
|
|
20
|
-
canUse(field: Pick<CmsModelField, "fieldId" | "type"
|
|
21
|
+
canUse(field: Pick<CmsModelField, "fieldId" | "type">, parents: string[]): boolean;
|
|
21
22
|
createPath(params: CreatePathCallableParams): string;
|
|
22
23
|
}
|
|
@@ -18,9 +18,11 @@ class CmsEntryFieldFilterPathPlugin extends _Plugin.Plugin {
|
|
|
18
18
|
this.config = config;
|
|
19
19
|
this.name = `${this.constructor.type}-${this.config.fieldType}`;
|
|
20
20
|
}
|
|
21
|
-
canUse(field) {
|
|
21
|
+
canUse(field, parents) {
|
|
22
22
|
if (field.type !== this.config.fieldType) {
|
|
23
23
|
return false;
|
|
24
|
+
} else if (this.config.canUse) {
|
|
25
|
+
return this.config.canUse(field, parents);
|
|
24
26
|
}
|
|
25
27
|
const fieldId = this.config.fieldId;
|
|
26
28
|
if (!fieldId || Array.isArray(fieldId) === false || fieldId.length === 0) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["CmsEntryFieldFilterPathPlugin","Plugin","fieldType","config","constructor","name","type","canUse","field","fieldId","Array","isArray","length","includes","createPath","params","path","WebinyError"],"sources":["CmsEntryFieldFilterPathPlugin.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { Plugin } from \"@webiny/plugins/Plugin\";\nimport { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\nexport interface CreatePathCallableParams {\n field: Partial<CmsModelField> & Pick<CmsModelField, \"fieldId\" | \"storageId\" | \"id\">;\n index?: number;\n}\nexport interface CreatePathCallable {\n (params: CreatePathCallableParams): string;\n}\nexport interface CmsEntryFieldFilterPathPluginParams {\n fieldType: string;\n fieldId?: string[];\n path: string | CreatePathCallable;\n}\nexport class CmsEntryFieldFilterPathPlugin extends Plugin {\n public static override readonly type: string = \"cms-field-filter-path\";\n\n private readonly config: CmsEntryFieldFilterPathPluginParams;\n\n public get fieldType(): string {\n return this.config.fieldType;\n }\n\n public constructor(config: CmsEntryFieldFilterPathPluginParams) {\n super();\n\n this.config = config;\n\n this.name = `${(this.constructor as any).type}-${this.config.fieldType}`;\n }\n\n public canUse(field: Pick<CmsModelField, \"fieldId\" | \"type\"
|
|
1
|
+
{"version":3,"names":["CmsEntryFieldFilterPathPlugin","Plugin","fieldType","config","constructor","name","type","canUse","field","parents","fieldId","Array","isArray","length","includes","createPath","params","path","WebinyError"],"sources":["CmsEntryFieldFilterPathPlugin.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { Plugin } from \"@webiny/plugins/Plugin\";\nimport { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\nexport interface CreatePathCallableParams {\n field: Partial<CmsModelField> & Pick<CmsModelField, \"fieldId\" | \"storageId\" | \"id\">;\n index?: number;\n}\nexport interface CreatePathCallable {\n (params: CreatePathCallableParams): string;\n}\nexport interface CmsEntryFieldFilterPathPluginParams {\n fieldType: string;\n fieldId?: string[];\n path: string | CreatePathCallable;\n canUse?: (field: Pick<CmsModelField, \"fieldId\" | \"type\">, parents?: string[]) => boolean;\n}\nexport class CmsEntryFieldFilterPathPlugin extends Plugin {\n public static override readonly type: string = \"cms-field-filter-path\";\n\n private readonly config: CmsEntryFieldFilterPathPluginParams;\n\n public get fieldType(): string {\n return this.config.fieldType;\n }\n\n public constructor(config: CmsEntryFieldFilterPathPluginParams) {\n super();\n\n this.config = config;\n\n this.name = `${(this.constructor as any).type}-${this.config.fieldType}`;\n }\n\n public canUse(field: Pick<CmsModelField, \"fieldId\" | \"type\">, parents: string[]): boolean {\n if (field.type !== this.config.fieldType) {\n return false;\n } else if (this.config.canUse) {\n return this.config.canUse(field, parents);\n }\n const fieldId = this.config.fieldId;\n if (!fieldId || Array.isArray(fieldId) === false || fieldId.length === 0) {\n return true;\n }\n return fieldId.includes(field.fieldId);\n }\n\n public createPath(params: CreatePathCallableParams): string {\n if (typeof this.config.path === \"function\") {\n return this.config.path(params);\n } else if (typeof this.config.path === \"string\") {\n return this.config.path;\n }\n throw new WebinyError(`Missing path in \"${this.name}\" plugin.`);\n }\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AAgBO,MAAMA,6BAA6B,SAASC,cAAM,CAAC;EAKtD,IAAWC,SAAS,GAAW;IAC3B,OAAO,IAAI,CAACC,MAAM,CAACD,SAAS;EAChC;EAEOE,WAAW,CAACD,MAA2C,EAAE;IAC5D,KAAK,EAAE;IAAC;IAER,IAAI,CAACA,MAAM,GAAGA,MAAM;IAEpB,IAAI,CAACE,IAAI,GAAI,GAAG,IAAI,CAACD,WAAW,CAASE,IAAK,IAAG,IAAI,CAACH,MAAM,CAACD,SAAU,EAAC;EAC5E;EAEOK,MAAM,CAACC,KAA8C,EAAEC,OAAiB,EAAW;IACtF,IAAID,KAAK,CAACF,IAAI,KAAK,IAAI,CAACH,MAAM,CAACD,SAAS,EAAE;MACtC,OAAO,KAAK;IAChB,CAAC,MAAM,IAAI,IAAI,CAACC,MAAM,CAACI,MAAM,EAAE;MAC3B,OAAO,IAAI,CAACJ,MAAM,CAACI,MAAM,CAACC,KAAK,EAAEC,OAAO,CAAC;IAC7C;IACA,MAAMC,OAAO,GAAG,IAAI,CAACP,MAAM,CAACO,OAAO;IACnC,IAAI,CAACA,OAAO,IAAIC,KAAK,CAACC,OAAO,CAACF,OAAO,CAAC,KAAK,KAAK,IAAIA,OAAO,CAACG,MAAM,KAAK,CAAC,EAAE;MACtE,OAAO,IAAI;IACf;IACA,OAAOH,OAAO,CAACI,QAAQ,CAACN,KAAK,CAACE,OAAO,CAAC;EAC1C;EAEOK,UAAU,CAACC,MAAgC,EAAU;IACxD,IAAI,OAAO,IAAI,CAACb,MAAM,CAACc,IAAI,KAAK,UAAU,EAAE;MACxC,OAAO,IAAI,CAACd,MAAM,CAACc,IAAI,CAACD,MAAM,CAAC;IACnC,CAAC,MAAM,IAAI,OAAO,IAAI,CAACb,MAAM,CAACc,IAAI,KAAK,QAAQ,EAAE;MAC7C,OAAO,IAAI,CAACd,MAAM,CAACc,IAAI;IAC3B;IACA,MAAM,IAAIC,cAAW,CAAE,oBAAmB,IAAI,CAACb,IAAK,WAAU,CAAC;EACnE;AACJ;AAAC;AAAA,8BAtCYL,6BAA6B,UACS,uBAAuB"}
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.systemFields = void 0;
|
|
7
|
-
const createSystemField = field => {
|
|
8
|
-
return field;
|
|
9
|
-
};
|
|
10
|
-
const systemFields = {
|
|
11
|
-
id: createSystemField({
|
|
12
|
-
id: "id",
|
|
13
|
-
type: "text",
|
|
14
|
-
storageId: "id",
|
|
15
|
-
fieldId: "id"
|
|
16
|
-
}),
|
|
17
|
-
entryId: createSystemField({
|
|
18
|
-
id: "entryId",
|
|
19
|
-
type: "text",
|
|
20
|
-
storageId: "entryId",
|
|
21
|
-
fieldId: "entryId"
|
|
22
|
-
}),
|
|
23
|
-
createdOn: createSystemField({
|
|
24
|
-
id: "createdOn",
|
|
25
|
-
type: "datetime",
|
|
26
|
-
storageId: "createdOn",
|
|
27
|
-
fieldId: "createdOn"
|
|
28
|
-
}),
|
|
29
|
-
savedOn: createSystemField({
|
|
30
|
-
id: "savedOn",
|
|
31
|
-
type: "datetime",
|
|
32
|
-
storageId: "savedOn",
|
|
33
|
-
fieldId: "savedOn"
|
|
34
|
-
}),
|
|
35
|
-
createdBy: createSystemField({
|
|
36
|
-
id: "createdBy",
|
|
37
|
-
type: "plainObject",
|
|
38
|
-
storageId: "createdBy",
|
|
39
|
-
fieldId: "createdBy",
|
|
40
|
-
settings: {
|
|
41
|
-
path: "createdBy.id"
|
|
42
|
-
}
|
|
43
|
-
}),
|
|
44
|
-
meta: createSystemField({
|
|
45
|
-
id: "meta",
|
|
46
|
-
type: "plainObject",
|
|
47
|
-
storageId: "meta",
|
|
48
|
-
fieldId: "meta"
|
|
49
|
-
}),
|
|
50
|
-
ownedBy: createSystemField({
|
|
51
|
-
id: "ownedBy",
|
|
52
|
-
type: "plainObject",
|
|
53
|
-
storageId: "ownedBy",
|
|
54
|
-
fieldId: "ownedBy",
|
|
55
|
-
settings: {
|
|
56
|
-
path: "ownedBy.id"
|
|
57
|
-
}
|
|
58
|
-
}),
|
|
59
|
-
version: createSystemField({
|
|
60
|
-
id: "version",
|
|
61
|
-
type: "number",
|
|
62
|
-
storageId: "version",
|
|
63
|
-
fieldId: "version"
|
|
64
|
-
}),
|
|
65
|
-
status: createSystemField({
|
|
66
|
-
id: "status",
|
|
67
|
-
type: "string",
|
|
68
|
-
storageId: "status",
|
|
69
|
-
fieldId: "status"
|
|
70
|
-
})
|
|
71
|
-
};
|
|
72
|
-
exports.systemFields = systemFields;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["createSystemField","field","systemFields","id","type","storageId","fieldId","entryId","createdOn","savedOn","createdBy","settings","path","meta","ownedBy","version","status"],"sources":["systemFields.ts"],"sourcesContent":["import { CmsModelField } from \"@webiny/api-headless-cms/types\";\n\ntype CmsModelFieldInput = Partial<CmsModelField> &\n Pick<CmsModelField, \"id\" | \"type\" | \"storageId\" | \"fieldId\">;\nconst createSystemField = (field: CmsModelFieldInput): CmsModelField => {\n return field as CmsModelField;\n};\n\nexport const systemFields: Record<string, CmsModelField> = {\n id: createSystemField({\n id: \"id\",\n type: \"text\",\n storageId: \"id\",\n fieldId: \"id\"\n }),\n entryId: createSystemField({\n id: \"entryId\",\n type: \"text\",\n storageId: \"entryId\",\n fieldId: \"entryId\"\n }),\n createdOn: createSystemField({\n id: \"createdOn\",\n type: \"datetime\",\n storageId: \"createdOn\",\n fieldId: \"createdOn\"\n }),\n savedOn: createSystemField({\n id: \"savedOn\",\n type: \"datetime\",\n storageId: \"savedOn\",\n fieldId: \"savedOn\"\n }),\n createdBy: createSystemField({\n id: \"createdBy\",\n type: \"plainObject\",\n storageId: \"createdBy\",\n fieldId: \"createdBy\",\n settings: {\n path: \"createdBy.id\"\n }\n }),\n meta: createSystemField({\n id: \"meta\",\n type: \"plainObject\",\n storageId: \"meta\",\n fieldId: \"meta\"\n }),\n ownedBy: createSystemField({\n id: \"ownedBy\",\n type: \"plainObject\",\n storageId: \"ownedBy\",\n fieldId: \"ownedBy\",\n settings: {\n path: \"ownedBy.id\"\n }\n }),\n version: createSystemField({\n id: \"version\",\n type: \"number\",\n storageId: \"version\",\n fieldId: \"version\"\n }),\n status: createSystemField({\n id: \"status\",\n type: \"string\",\n storageId: \"status\",\n fieldId: \"status\"\n })\n};\n"],"mappings":";;;;;;AAIA,MAAMA,iBAAiB,GAAIC,KAAyB,IAAoB;EACpE,OAAOA,KAAK;AAChB,CAAC;AAEM,MAAMC,YAA2C,GAAG;EACvDC,EAAE,EAAEH,iBAAiB,CAAC;IAClBG,EAAE,EAAE,IAAI;IACRC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,IAAI;IACfC,OAAO,EAAE;EACb,CAAC,CAAC;EACFC,OAAO,EAAEP,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFE,SAAS,EAAER,iBAAiB,CAAC;IACzBG,EAAE,EAAE,WAAW;IACfC,IAAI,EAAE,UAAU;IAChBC,SAAS,EAAE,WAAW;IACtBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFG,OAAO,EAAET,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,UAAU;IAChBC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFI,SAAS,EAAEV,iBAAiB,CAAC;IACzBG,EAAE,EAAE,WAAW;IACfC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,WAAW;IACtBC,OAAO,EAAE,WAAW;IACpBK,QAAQ,EAAE;MACNC,IAAI,EAAE;IACV;EACJ,CAAC,CAAC;EACFC,IAAI,EAAEb,iBAAiB,CAAC;IACpBG,EAAE,EAAE,MAAM;IACVC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,MAAM;IACjBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFQ,OAAO,EAAEd,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,aAAa;IACnBC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE,SAAS;IAClBK,QAAQ,EAAE;MACNC,IAAI,EAAE;IACV;EACJ,CAAC,CAAC;EACFG,OAAO,EAAEf,iBAAiB,CAAC;IACvBG,EAAE,EAAE,SAAS;IACbC,IAAI,EAAE,QAAQ;IACdC,SAAS,EAAE,SAAS;IACpBC,OAAO,EAAE;EACb,CAAC,CAAC;EACFU,MAAM,EAAEhB,iBAAiB,CAAC;IACtBG,EAAE,EAAE,QAAQ;IACZC,IAAI,EAAE,QAAQ;IACdC,SAAS,EAAE,QAAQ;IACnBC,OAAO,EAAE;EACb,CAAC;AACL,CAAC;AAAC"}
|