@webiny/api-aco 0.0.0-unstable.2af142b57e → 0.0.0-unstable.496cf268ac

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.
Files changed (67) hide show
  1. package/context/folders.d.ts +2 -0
  2. package/context/folders.js +261 -0
  3. package/context/folders.js.map +1 -0
  4. package/context/index.d.ts +2 -0
  5. package/context/index.js +22 -0
  6. package/context/index.js.map +1 -0
  7. package/context/links.d.ts +2 -0
  8. package/context/links.js +270 -0
  9. package/context/links.js.map +1 -0
  10. package/createAcoGraphQL.js +10 -9
  11. package/createAcoGraphQL.js.map +1 -1
  12. package/folder/folder.gql.js +1 -1
  13. package/folder/folder.gql.js.map +1 -1
  14. package/folder/folder.model.d.ts +4 -2
  15. package/folder/folder.model.js +1 -1
  16. package/folder/folder.model.js.map +1 -1
  17. package/folder/folder.so.d.ts +1 -6
  18. package/folder/folder.so.js +103 -108
  19. package/folder/folder.so.js.map +1 -1
  20. package/folder/folder.types.d.ts +2 -2
  21. package/folder/folder.types.js.map +1 -1
  22. package/folder/onFolderBeforeDelete.hook.js +11 -11
  23. package/folder/onFolderBeforeDelete.hook.js.map +1 -1
  24. package/graphql/base.gql.d.ts +3 -0
  25. package/graphql/base.gql.js +63 -0
  26. package/graphql/base.gql.js.map +1 -0
  27. package/graphql/folders.gql.d.ts +3 -0
  28. package/graphql/folders.gql.js +126 -0
  29. package/graphql/folders.gql.js.map +1 -0
  30. package/graphql/index.d.ts +1 -0
  31. package/graphql/index.js +15 -0
  32. package/graphql/index.js.map +1 -0
  33. package/graphql/links.gql.d.ts +3 -0
  34. package/graphql/links.gql.js +123 -0
  35. package/graphql/links.gql.js.map +1 -0
  36. package/package.json +22 -21
  37. package/record/record.gql.js +2 -3
  38. package/record/record.gql.js.map +1 -1
  39. package/record/record.model.d.ts +4 -2
  40. package/record/record.model.js +4 -16
  41. package/record/record.model.js.map +1 -1
  42. package/record/record.so.d.ts +1 -6
  43. package/record/record.so.js +57 -59
  44. package/record/record.so.js.map +1 -1
  45. package/record/record.types.d.ts +3 -4
  46. package/record/record.types.js.map +1 -1
  47. package/subscriptions/afterFolderDelete.d.ts +3 -0
  48. package/subscriptions/afterFolderDelete.js +62 -0
  49. package/subscriptions/afterFolderDelete.js.map +1 -0
  50. package/subscriptions/index.d.ts +3 -0
  51. package/subscriptions/index.js +14 -0
  52. package/subscriptions/index.js.map +1 -0
  53. package/types.d.ts +5 -0
  54. package/types.js +8 -1
  55. package/types.js.map +1 -1
  56. package/utils/createListSort.d.ts +2 -0
  57. package/utils/createListSort.js +13 -0
  58. package/utils/createListSort.js.map +1 -0
  59. package/utils/createOperationsWrapper.d.ts +9 -0
  60. package/utils/createOperationsWrapper.js +29 -0
  61. package/utils/createOperationsWrapper.js.map +1 -0
  62. package/utils/getFieldValues.d.ts +1 -1
  63. package/utils/getFieldValues.js +9 -2
  64. package/utils/getFieldValues.js.map +1 -1
  65. package/utils/modelFactory.d.ts +3 -1
  66. package/utils/modelFactory.js.map +1 -1
  67. package/utils/resolve.d.ts +1 -1
@@ -0,0 +1,2 @@
1
+ import { FoldersConfig, IFolders } from "../types";
2
+ export declare const createFoldersContext: ({ getTenantId, getLocaleCode, getIdentity, storageOperations }: FoldersConfig) => Promise<IFolders>;
@@ -0,0 +1,261 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.createFoldersContext = void 0;
9
+
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
+
12
+ var _mdbid = _interopRequireDefault(require("mdbid"));
13
+
14
+ var _error = _interopRequireDefault(require("@webiny/error"));
15
+
16
+ var _handlerGraphql = require("@webiny/handler-graphql");
17
+
18
+ var _pubsub = require("@webiny/pubsub");
19
+
20
+ var _joi = _interopRequireDefault(require("joi"));
21
+
22
+ /**
23
+ * Package mdbid does not have types.
24
+ */
25
+ // @ts-ignore
26
+ const requiredString = _joi.default.string().required();
27
+
28
+ const createSchema = _joi.default.object({
29
+ name: requiredString.min(3),
30
+ slug: requiredString.min(3),
31
+ type: requiredString,
32
+ tenant: requiredString,
33
+ locale: requiredString
34
+ });
35
+
36
+ const updateSchema = _joi.default.object({
37
+ name: requiredString.min(3),
38
+ slug: requiredString.min(3)
39
+ });
40
+
41
+ const createFoldersContext = async ({
42
+ getTenantId,
43
+ getLocaleCode,
44
+ getIdentity,
45
+ storageOperations
46
+ }) => {
47
+ // create
48
+ const onFolderBeforeCreate = (0, _pubsub.createTopic)("folders.onFolderBeforeCreate");
49
+ const onFolderAfterCreate = (0, _pubsub.createTopic)("folders.onFolderAfterCreate"); // update
50
+
51
+ const onFolderBeforeUpdate = (0, _pubsub.createTopic)("folders.onFolderBeforeUpdate");
52
+ const onFolderAfterUpdate = (0, _pubsub.createTopic)("folders.onFolderAfterUpdate"); // delete
53
+
54
+ const onFolderBeforeDelete = (0, _pubsub.createTopic)("folders.onFolderBeforeDelete");
55
+ const onFolderAfterDelete = (0, _pubsub.createTopic)("folders.onFolderAfterDelete");
56
+ return {
57
+ onFolderBeforeCreate,
58
+ onFolderAfterCreate,
59
+ onFolderBeforeUpdate,
60
+ onFolderAfterUpdate,
61
+ onFolderBeforeDelete,
62
+ onFolderAfterDelete,
63
+
64
+ async getFolder({
65
+ id
66
+ }) {
67
+ const tenant = getTenantId();
68
+ const locale = getLocaleCode();
69
+ let folder;
70
+
71
+ try {
72
+ folder = await storageOperations.getFolder({
73
+ tenant,
74
+ locale,
75
+ id
76
+ });
77
+ } catch (error) {
78
+ throw _error.default.from(error, {
79
+ message: "Could not get folder.",
80
+ code: "GET_FOLDER_ERROR",
81
+ data: {
82
+ id
83
+ }
84
+ });
85
+ }
86
+
87
+ if (!folder) {
88
+ throw new _handlerGraphql.NotFoundError(`Unable to find folder with id: ${id}`);
89
+ }
90
+
91
+ return folder;
92
+ },
93
+
94
+ async listFolders({
95
+ where
96
+ }) {
97
+ const tenant = getTenantId();
98
+ const locale = getLocaleCode();
99
+
100
+ try {
101
+ return await storageOperations.listFolders({
102
+ where: (0, _objectSpread2.default)({
103
+ tenant,
104
+ locale
105
+ }, where),
106
+ sort: ["createdOn_ASC"]
107
+ });
108
+ } catch (error) {
109
+ throw _error.default.from(error, {
110
+ message: "Could not list folders.",
111
+ code: "LIST_FOLDERS_ERROR",
112
+ data: (0, _objectSpread2.default)({}, where)
113
+ });
114
+ }
115
+ },
116
+
117
+ async createFolder(input) {
118
+ await createSchema.validate(input);
119
+ const tenant = getTenantId();
120
+ const locale = getLocaleCode();
121
+ const {
122
+ type,
123
+ slug,
124
+ parentId
125
+ } = input;
126
+ const existing = await storageOperations.getFolder({
127
+ tenant,
128
+ locale,
129
+ type,
130
+ slug,
131
+ parentId
132
+ });
133
+
134
+ if (existing) {
135
+ throw new _error.default(`Folder with slug "${slug}" already exists at this level.`, "FOLDER_EXISTS");
136
+ }
137
+
138
+ const identity = getIdentity();
139
+ const folder = (0, _objectSpread2.default)((0, _objectSpread2.default)({
140
+ id: (0, _mdbid.default)(),
141
+ tenant,
142
+ locale
143
+ }, input), {}, {
144
+ webinyVersion: process.env.WEBINY_VERSION,
145
+ createdOn: new Date().toISOString(),
146
+ createdBy: {
147
+ id: identity.id,
148
+ displayName: identity.displayName,
149
+ type: identity.type
150
+ }
151
+ });
152
+
153
+ try {
154
+ await onFolderBeforeCreate.publish({
155
+ folder
156
+ });
157
+ const result = await storageOperations.createFolder({
158
+ folder
159
+ });
160
+ await onFolderAfterCreate.publish({
161
+ folder: result
162
+ });
163
+ return result;
164
+ } catch (error) {
165
+ throw _error.default.from(error, {
166
+ message: "Could not create folder.",
167
+ code: "CREATE_FOLDER_ERROR",
168
+ data: (0, _objectSpread2.default)({}, input)
169
+ });
170
+ }
171
+ },
172
+
173
+ async updateFolder(id, input) {
174
+ await updateSchema.validate(input);
175
+ const tenant = getTenantId();
176
+ const locale = getLocaleCode();
177
+ const {
178
+ slug,
179
+ parentId
180
+ } = input;
181
+ const original = await storageOperations.getFolder({
182
+ tenant,
183
+ locale,
184
+ id
185
+ });
186
+
187
+ if (!original) {
188
+ throw new _handlerGraphql.NotFoundError(`Folder "${id}" was not found!`);
189
+ }
190
+
191
+ const existing = await storageOperations.getFolder({
192
+ tenant,
193
+ locale,
194
+ type: original.type,
195
+ slug: slug || original.slug,
196
+ parentId: parentId !== undefined ? parentId : original.parentId // parentId can be `null`
197
+
198
+ }); // Check if another folder exists already inside the target
199
+
200
+ if (existing && (existing === null || existing === void 0 ? void 0 : existing.id) !== id) {
201
+ throw new _error.default(`Folder with slug "${slug}" already exists at this level.`, "FOLDER_EXISTS");
202
+ }
203
+
204
+ const folder = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, original), input);
205
+
206
+ try {
207
+ await onFolderBeforeUpdate.publish({
208
+ folder,
209
+ original
210
+ });
211
+ const result = await storageOperations.updateFolder({
212
+ original,
213
+ folder
214
+ });
215
+ await onFolderAfterUpdate.publish({
216
+ folder: result,
217
+ original
218
+ });
219
+ return result;
220
+ } catch (error) {
221
+ throw new _error.default(error.message || "Could not update folder.", error.code || "UPDATE_FOLDER_ERROR", {
222
+ folder
223
+ });
224
+ }
225
+ },
226
+
227
+ async deleteFolder(id) {
228
+ const tenant = getTenantId();
229
+ const locale = getLocaleCode();
230
+ const folder = await storageOperations.getFolder({
231
+ tenant,
232
+ locale,
233
+ id
234
+ });
235
+
236
+ if (!folder) {
237
+ throw new _handlerGraphql.NotFoundError(`Folder "${id}" was not found!`);
238
+ }
239
+
240
+ try {
241
+ await onFolderBeforeDelete.publish({
242
+ folder
243
+ });
244
+ const result = storageOperations.deleteFolder({
245
+ folder
246
+ });
247
+ await onFolderAfterDelete.publish({
248
+ folder
249
+ });
250
+ return result;
251
+ } catch (error) {
252
+ throw new _error.default(error.message || "Could not delete folder.", error.code || "DELETE_FOLDER_ERROR", {
253
+ folder
254
+ });
255
+ }
256
+ }
257
+
258
+ };
259
+ };
260
+
261
+ exports.createFoldersContext = createFoldersContext;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["requiredString","joi","string","required","createSchema","object","name","min","slug","type","tenant","locale","updateSchema","createFoldersContext","getTenantId","getLocaleCode","getIdentity","storageOperations","onFolderBeforeCreate","createTopic","onFolderAfterCreate","onFolderBeforeUpdate","onFolderAfterUpdate","onFolderBeforeDelete","onFolderAfterDelete","getFolder","id","folder","error","WebinyError","from","message","code","data","NotFoundError","listFolders","where","sort","createFolder","input","validate","parentId","existing","identity","mdbid","webinyVersion","process","env","WEBINY_VERSION","createdOn","Date","toISOString","createdBy","displayName","publish","result","updateFolder","original","undefined","deleteFolder"],"sources":["folders.ts"],"sourcesContent":["/**\n * Package mdbid does not have types.\n */\n// @ts-ignore\nimport mdbid from \"mdbid\";\nimport WebinyError from \"@webiny/error\";\nimport { NotFoundError } from \"@webiny/handler-graphql\";\nimport { createTopic } from \"@webiny/pubsub\";\nimport joi from \"joi\";\n\nimport {\n Folder,\n FolderInput,\n FoldersConfig,\n GetFolderParams,\n IFolders,\n ListFoldersParams,\n OnFolderAfterCreateTopicParams,\n OnFolderAfterDeleteTopicParams,\n OnFolderAfterUpdateTopicParams,\n OnFolderBeforeCreateTopicParams,\n OnFolderBeforeDeleteTopicParams,\n OnFolderBeforeUpdateTopicParams\n} from \"~/types\";\n\nconst requiredString = joi.string().required();\n\nconst createSchema = joi.object({\n name: requiredString.min(3),\n slug: requiredString.min(3),\n type: requiredString,\n tenant: requiredString,\n locale: requiredString\n});\n\nconst updateSchema = joi.object({\n name: requiredString.min(3),\n slug: requiredString.min(3)\n});\n\nexport const createFoldersContext = async ({\n getTenantId,\n getLocaleCode,\n getIdentity,\n storageOperations\n}: FoldersConfig): Promise<IFolders> => {\n // create\n const onFolderBeforeCreate = createTopic<OnFolderBeforeCreateTopicParams>(\n \"folders.onFolderBeforeCreate\"\n );\n const onFolderAfterCreate = createTopic<OnFolderAfterCreateTopicParams>(\n \"folders.onFolderAfterCreate\"\n );\n // update\n const onFolderBeforeUpdate = createTopic<OnFolderBeforeUpdateTopicParams>(\n \"folders.onFolderBeforeUpdate\"\n );\n const onFolderAfterUpdate = createTopic<OnFolderAfterUpdateTopicParams>(\n \"folders.onFolderAfterUpdate\"\n );\n // delete\n const onFolderBeforeDelete = createTopic<OnFolderBeforeDeleteTopicParams>(\n \"folders.onFolderBeforeDelete\"\n );\n const onFolderAfterDelete = createTopic<OnFolderAfterDeleteTopicParams>(\n \"folders.onFolderAfterDelete\"\n );\n\n return {\n onFolderBeforeCreate,\n onFolderAfterCreate,\n onFolderBeforeUpdate,\n onFolderAfterUpdate,\n onFolderBeforeDelete,\n onFolderAfterDelete,\n async getFolder({ id }: GetFolderParams): Promise<Folder> {\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n let folder: Folder | undefined;\n\n try {\n folder = await storageOperations.getFolder({ tenant, locale, id });\n } catch (error) {\n throw WebinyError.from(error, {\n message: \"Could not get folder.\",\n code: \"GET_FOLDER_ERROR\",\n data: { id }\n });\n }\n if (!folder) {\n throw new NotFoundError(`Unable to find folder with id: ${id}`);\n }\n return folder;\n },\n\n async listFolders({ where }: ListFoldersParams): Promise<Folder[]> {\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n try {\n return await storageOperations.listFolders({\n where: { tenant, locale, ...where },\n sort: [\"createdOn_ASC\"]\n });\n } catch (error) {\n throw WebinyError.from(error, {\n message: \"Could not list folders.\",\n code: \"LIST_FOLDERS_ERROR\",\n data: { ...where }\n });\n }\n },\n\n async createFolder(input: FolderInput): Promise<Folder> {\n await createSchema.validate(input);\n\n const tenant = getTenantId();\n const locale = getLocaleCode();\n const { type, slug, parentId } = input;\n\n const existing = await storageOperations.getFolder({\n tenant,\n locale,\n type,\n slug,\n parentId\n });\n\n if (existing) {\n throw new WebinyError(\n `Folder with slug \"${slug}\" already exists at this level.`,\n \"FOLDER_EXISTS\"\n );\n }\n\n const identity = getIdentity();\n\n const folder: Folder = {\n id: mdbid(),\n tenant,\n locale,\n ...input,\n webinyVersion: process.env.WEBINY_VERSION as string,\n createdOn: new Date().toISOString(),\n createdBy: {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n }\n };\n\n try {\n await onFolderBeforeCreate.publish({\n folder\n });\n const result = await storageOperations.createFolder({ folder });\n await onFolderAfterCreate.publish({\n folder: result\n });\n return result;\n } catch (error) {\n throw WebinyError.from(error, {\n message: \"Could not create folder.\",\n code: \"CREATE_FOLDER_ERROR\",\n data: { ...input }\n });\n }\n },\n\n async updateFolder(id: string, input: Record<string, any>): Promise<Folder> {\n await updateSchema.validate(input);\n\n const tenant = getTenantId();\n const locale = getLocaleCode();\n const { slug, parentId } = input;\n\n const original = await storageOperations.getFolder({ tenant, locale, id });\n\n if (!original) {\n throw new NotFoundError(`Folder \"${id}\" was not found!`);\n }\n\n const existing = await storageOperations.getFolder({\n tenant,\n locale,\n type: original.type,\n slug: slug || original.slug,\n parentId: parentId !== undefined ? parentId : original.parentId // parentId can be `null`\n });\n\n // Check if another folder exists already inside the target\n if (existing && existing?.id !== id) {\n throw new WebinyError(\n `Folder with slug \"${slug}\" already exists at this level.`,\n \"FOLDER_EXISTS\"\n );\n }\n\n const folder: Folder = {\n ...original,\n ...input\n };\n try {\n await onFolderBeforeUpdate.publish({\n folder,\n original\n });\n const result = await storageOperations.updateFolder({ original, folder });\n await onFolderAfterUpdate.publish({\n folder: result,\n original\n });\n return result;\n } catch (error) {\n throw new WebinyError(\n error.message || \"Could not update folder.\",\n error.code || \"UPDATE_FOLDER_ERROR\",\n {\n folder\n }\n );\n }\n },\n\n async deleteFolder(id: string): Promise<void> {\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n const folder = await storageOperations.getFolder({ tenant, locale, id });\n\n if (!folder) {\n throw new NotFoundError(`Folder \"${id}\" was not found!`);\n }\n\n try {\n await onFolderBeforeDelete.publish({\n folder\n });\n const result = storageOperations.deleteFolder({ folder });\n await onFolderAfterDelete.publish({\n folder\n });\n return result;\n } catch (error) {\n throw new WebinyError(\n error.message || \"Could not delete folder.\",\n error.code || \"DELETE_FOLDER_ERROR\",\n {\n folder\n }\n );\n }\n }\n };\n};\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Folders, FoldersConfig } from "../types";
2
+ export declare const createContext: (config: FoldersConfig) => Promise<Folders>;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.createContext = void 0;
9
+
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
+
12
+ var _folders = require("./folders");
13
+
14
+ var _links = require("./links");
15
+
16
+ const createContext = async config => {
17
+ const linksContext = await (0, _links.createLinksContext)(config);
18
+ const folderContext = await (0, _folders.createFoldersContext)(config);
19
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, linksContext), folderContext);
20
+ };
21
+
22
+ exports.createContext = createContext;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["createContext","config","linksContext","createLinksContext","folderContext","createFoldersContext"],"sources":["index.ts"],"sourcesContent":["import { createFoldersContext } from \"./folders\";\nimport { createLinksContext } from \"./links\";\n\nimport { Folders, FoldersConfig } from \"~/types\";\n\nexport const createContext = async (config: FoldersConfig): Promise<Folders> => {\n const linksContext = await createLinksContext(config);\n const folderContext = await createFoldersContext(config);\n\n return {\n ...linksContext,\n ...folderContext\n };\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AAIO,MAAMA,aAAa,GAAG,MAAOC,MAAP,IAAmD;EAC5E,MAAMC,YAAY,GAAG,MAAM,IAAAC,yBAAA,EAAmBF,MAAnB,CAA3B;EACA,MAAMG,aAAa,GAAG,MAAM,IAAAC,6BAAA,EAAqBJ,MAArB,CAA5B;EAEA,mEACOC,YADP,GAEOE,aAFP;AAIH,CARM"}
@@ -0,0 +1,2 @@
1
+ import { FoldersConfig, ILinks } from "../types";
2
+ export declare const createLinksContext: ({ getTenantId, getLocaleCode, getIdentity, storageOperations }: FoldersConfig) => Promise<ILinks>;
@@ -0,0 +1,270 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.createLinksContext = void 0;
9
+
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
+
12
+ var _mdbid = _interopRequireDefault(require("mdbid"));
13
+
14
+ var _error = _interopRequireDefault(require("@webiny/error"));
15
+
16
+ var _handlerGraphql = require("@webiny/handler-graphql");
17
+
18
+ var _pubsub = require("@webiny/pubsub");
19
+
20
+ var _joi = _interopRequireDefault(require("joi"));
21
+
22
+ /**
23
+ * Package mdbid does not have types.
24
+ */
25
+ // @ts-ignore
26
+ const requiredString = _joi.default.string().required();
27
+
28
+ const createSchema = _joi.default.object({
29
+ id: requiredString,
30
+ folderId: requiredString,
31
+ tenant: requiredString,
32
+ locale: requiredString
33
+ });
34
+
35
+ const updateSchema = _joi.default.object({
36
+ folderId: requiredString
37
+ });
38
+
39
+ const createLinksContext = async ({
40
+ getTenantId,
41
+ getLocaleCode,
42
+ getIdentity,
43
+ storageOperations
44
+ }) => {
45
+ // create
46
+ const onLinkBeforeCreate = (0, _pubsub.createTopic)("folders.onLinkBeforeCreate");
47
+ const onLinkAfterCreate = (0, _pubsub.createTopic)("folders.onLinkAfterCreate"); // update
48
+
49
+ const onLinkBeforeUpdate = (0, _pubsub.createTopic)("folders.onLinkBeforeUpdate");
50
+ const onLinkAfterUpdate = (0, _pubsub.createTopic)("folders.onLinkAfterUpdate"); // delete
51
+
52
+ const onLinkBeforeDelete = (0, _pubsub.createTopic)("folders.onLinkBeforeDelete");
53
+ const onLinkAfterDelete = (0, _pubsub.createTopic)("folders.onLinkAfterDelete"); // delete batch
54
+
55
+ const onLinkBeforeDeleteBatch = (0, _pubsub.createTopic)("folders.onLinkBeforeDeleteBatch");
56
+ const onLinkAfterDeleteBatch = (0, _pubsub.createTopic)("folders.onLinkAfterDeleteBatch");
57
+ return {
58
+ onLinkBeforeCreate,
59
+ onLinkAfterCreate,
60
+ onLinkBeforeUpdate,
61
+ onLinkAfterUpdate,
62
+ onLinkBeforeDelete,
63
+ onLinkAfterDelete,
64
+ onLinkBeforeDeleteBatch,
65
+ onLinkAfterDeleteBatch,
66
+
67
+ async getLink(id) {
68
+ const tenant = getTenantId();
69
+ const locale = getLocaleCode();
70
+ let link;
71
+
72
+ try {
73
+ link = await storageOperations.getLink({
74
+ tenant,
75
+ locale,
76
+ id
77
+ });
78
+ } catch (error) {
79
+ throw _error.default.from(error, {
80
+ message: "Could not get link.",
81
+ code: "GET_LINK_ERROR",
82
+ data: {
83
+ id
84
+ }
85
+ });
86
+ }
87
+
88
+ if (!link) {
89
+ throw new _handlerGraphql.NotFoundError(`Unable to find link with id: ${id}`);
90
+ }
91
+
92
+ return link;
93
+ },
94
+
95
+ async listLinks({
96
+ where,
97
+ limit,
98
+ after
99
+ }) {
100
+ const tenant = getTenantId();
101
+ const locale = getLocaleCode();
102
+
103
+ try {
104
+ return await storageOperations.listLinks({
105
+ where: (0, _objectSpread2.default)({
106
+ tenant,
107
+ locale
108
+ }, where),
109
+ sort: ["createdOn_ASC"],
110
+ limit,
111
+ after
112
+ });
113
+ } catch (error) {
114
+ throw _error.default.from(error, {
115
+ message: "Could not list links.",
116
+ code: "LIST_LINKS_ERROR",
117
+ data: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, where), {}, {
118
+ limit,
119
+ after
120
+ })
121
+ });
122
+ }
123
+ },
124
+
125
+ async createLink(input) {
126
+ await createSchema.validate(input);
127
+ const tenant = getTenantId();
128
+ const locale = getLocaleCode();
129
+ const existing = await storageOperations.getLink({
130
+ tenant,
131
+ locale,
132
+ folderId: input.folderId,
133
+ id: input.id
134
+ });
135
+
136
+ if (existing) {
137
+ throw new _error.default(`Link with id "${input.id}" already exists.`, "LINK_EXISTS");
138
+ }
139
+
140
+ const identity = getIdentity();
141
+ const link = (0, _objectSpread2.default)((0, _objectSpread2.default)({
142
+ linkId: (0, _mdbid.default)(),
143
+ tenant,
144
+ locale
145
+ }, input), {}, {
146
+ webinyVersion: process.env.WEBINY_VERSION,
147
+ createdOn: new Date().toISOString(),
148
+ createdBy: {
149
+ id: identity.id,
150
+ displayName: identity.displayName,
151
+ type: identity.type
152
+ }
153
+ });
154
+
155
+ try {
156
+ await onLinkBeforeCreate.publish({
157
+ link
158
+ });
159
+ const result = await storageOperations.createLink({
160
+ link
161
+ });
162
+ await onLinkAfterCreate.publish({
163
+ link: result
164
+ });
165
+ return result;
166
+ } catch (error) {
167
+ throw _error.default.from(error, {
168
+ message: "Could not create link.",
169
+ code: "CREATE_LINK_ERROR",
170
+ data: (0, _objectSpread2.default)({}, input)
171
+ });
172
+ }
173
+ },
174
+
175
+ async updateLink(id, input) {
176
+ const tenant = getTenantId();
177
+ const locale = getLocaleCode();
178
+ const original = await storageOperations.getLink({
179
+ tenant,
180
+ locale,
181
+ id
182
+ });
183
+
184
+ if (!original) {
185
+ throw new _handlerGraphql.NotFoundError(`Link "${id}" was not found!`);
186
+ }
187
+
188
+ await updateSchema.validate(input);
189
+ const link = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, original), input);
190
+
191
+ try {
192
+ await onLinkBeforeUpdate.publish({
193
+ link,
194
+ original
195
+ });
196
+ const result = await storageOperations.updateLink({
197
+ original,
198
+ link
199
+ });
200
+ await onLinkAfterUpdate.publish({
201
+ link: result,
202
+ original
203
+ });
204
+ return result;
205
+ } catch (error) {
206
+ throw new _error.default(error.message || "Could not update link.", error.code || "UPDATE_LINK_ERROR", {
207
+ link
208
+ });
209
+ }
210
+ },
211
+
212
+ async deleteLink(id) {
213
+ const tenant = getTenantId();
214
+ const locale = getLocaleCode();
215
+ const link = await storageOperations.getLink({
216
+ tenant,
217
+ locale,
218
+ id
219
+ });
220
+
221
+ if (!link) {
222
+ throw new _handlerGraphql.NotFoundError(`Link "${id}" was not found!`);
223
+ }
224
+
225
+ try {
226
+ await onLinkBeforeDelete.publish({
227
+ link
228
+ });
229
+ const result = await storageOperations.deleteLink({
230
+ link
231
+ });
232
+ await onLinkAfterDelete.publish({
233
+ link
234
+ });
235
+ return result;
236
+ } catch (error) {
237
+ throw new _error.default(error.message || "Could not delete link.", error.code || "DELETE_LINK_ERROR", {
238
+ link
239
+ });
240
+ }
241
+ },
242
+
243
+ async deleteLinks(folderIds) {
244
+ const tenant = getTenantId();
245
+ const locale = getLocaleCode();
246
+
247
+ try {
248
+ await onLinkBeforeDeleteBatch.publish({
249
+ folderIds
250
+ });
251
+ const result = await storageOperations.deleteLinks({
252
+ tenant,
253
+ locale,
254
+ folderIds
255
+ });
256
+ await onLinkAfterDeleteBatch.publish({
257
+ folderIds
258
+ });
259
+ return result;
260
+ } catch (error) {
261
+ throw new _error.default(error.message || "Could not batch delete links.", error.code || "DELETE_LINKS_ERROR", {
262
+ folderIds
263
+ });
264
+ }
265
+ }
266
+
267
+ };
268
+ };
269
+
270
+ exports.createLinksContext = createLinksContext;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["requiredString","joi","string","required","createSchema","object","id","folderId","tenant","locale","updateSchema","createLinksContext","getTenantId","getLocaleCode","getIdentity","storageOperations","onLinkBeforeCreate","createTopic","onLinkAfterCreate","onLinkBeforeUpdate","onLinkAfterUpdate","onLinkBeforeDelete","onLinkAfterDelete","onLinkBeforeDeleteBatch","onLinkAfterDeleteBatch","getLink","link","error","WebinyError","from","message","code","data","NotFoundError","listLinks","where","limit","after","sort","createLink","input","validate","existing","identity","linkId","mdbid","webinyVersion","process","env","WEBINY_VERSION","createdOn","Date","toISOString","createdBy","displayName","type","publish","result","updateLink","original","deleteLink","deleteLinks","folderIds"],"sources":["links.ts"],"sourcesContent":["/**\n * Package mdbid does not have types.\n */\n// @ts-ignore\nimport mdbid from \"mdbid\";\nimport WebinyError from \"@webiny/error\";\nimport { NotFoundError } from \"@webiny/handler-graphql\";\nimport { createTopic } from \"@webiny/pubsub\";\nimport joi from \"joi\";\n\nimport {\n FoldersConfig,\n ILinks,\n Link,\n LinkInput,\n ListLinksParams,\n ListLinksResponse,\n OnLinkAfterCreateTopicParams,\n OnLinkAfterDeleteBatchTopicParams,\n OnLinkAfterDeleteTopicParams,\n OnLinkAfterUpdateTopicParams,\n OnLinkBeforeCreateTopicParams,\n OnLinkBeforeDeleteBatchTopicParams,\n OnLinkBeforeDeleteTopicParams,\n OnLinkBeforeUpdateTopicParams\n} from \"~/types\";\n\nconst requiredString = joi.string().required();\n\nconst createSchema = joi.object({\n id: requiredString,\n folderId: requiredString,\n tenant: requiredString,\n locale: requiredString\n});\n\nconst updateSchema = joi.object({\n folderId: requiredString\n});\n\nexport const createLinksContext = async ({\n getTenantId,\n getLocaleCode,\n getIdentity,\n storageOperations\n}: FoldersConfig): Promise<ILinks> => {\n // create\n const onLinkBeforeCreate = createTopic<OnLinkBeforeCreateTopicParams>(\n \"folders.onLinkBeforeCreate\"\n );\n const onLinkAfterCreate = createTopic<OnLinkAfterCreateTopicParams>(\n \"folders.onLinkAfterCreate\"\n );\n // update\n const onLinkBeforeUpdate = createTopic<OnLinkBeforeUpdateTopicParams>(\n \"folders.onLinkBeforeUpdate\"\n );\n const onLinkAfterUpdate = createTopic<OnLinkAfterUpdateTopicParams>(\n \"folders.onLinkAfterUpdate\"\n );\n // delete\n const onLinkBeforeDelete = createTopic<OnLinkBeforeDeleteTopicParams>(\n \"folders.onLinkBeforeDelete\"\n );\n const onLinkAfterDelete = createTopic<OnLinkAfterDeleteTopicParams>(\n \"folders.onLinkAfterDelete\"\n );\n // delete batch\n const onLinkBeforeDeleteBatch = createTopic<OnLinkBeforeDeleteBatchTopicParams>(\n \"folders.onLinkBeforeDeleteBatch\"\n );\n const onLinkAfterDeleteBatch = createTopic<OnLinkAfterDeleteBatchTopicParams>(\n \"folders.onLinkAfterDeleteBatch\"\n );\n\n return {\n onLinkBeforeCreate,\n onLinkAfterCreate,\n onLinkBeforeUpdate,\n onLinkAfterUpdate,\n onLinkBeforeDelete,\n onLinkAfterDelete,\n onLinkBeforeDeleteBatch,\n onLinkAfterDeleteBatch,\n async getLink(id: string): Promise<Link> {\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n let link: Link | undefined;\n try {\n link = await storageOperations.getLink({ tenant, locale, id });\n } catch (error) {\n throw WebinyError.from(error, {\n message: \"Could not get link.\",\n code: \"GET_LINK_ERROR\",\n data: { id }\n });\n }\n if (!link) {\n throw new NotFoundError(`Unable to find link with id: ${id}`);\n }\n return link;\n },\n\n async listLinks({ where, limit, after }: ListLinksParams): Promise<ListLinksResponse> {\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n try {\n return await storageOperations.listLinks({\n where: { tenant, locale, ...where },\n sort: [\"createdOn_ASC\"],\n limit,\n after\n });\n } catch (error) {\n throw WebinyError.from(error, {\n message: \"Could not list links.\",\n code: \"LIST_LINKS_ERROR\",\n data: { ...where, limit, after }\n });\n }\n },\n\n async createLink(input: LinkInput): Promise<Link> {\n await createSchema.validate(input);\n\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n const existing = await storageOperations.getLink({\n tenant,\n locale,\n folderId: input.folderId,\n id: input.id\n });\n\n if (existing) {\n throw new WebinyError(`Link with id \"${input.id}\" already exists.`, \"LINK_EXISTS\");\n }\n\n const identity = getIdentity();\n\n const link: Link = {\n linkId: mdbid(),\n tenant,\n locale,\n ...input,\n webinyVersion: process.env.WEBINY_VERSION as string,\n createdOn: new Date().toISOString(),\n createdBy: {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n }\n };\n\n try {\n await onLinkBeforeCreate.publish({\n link\n });\n const result = await storageOperations.createLink({ link });\n await onLinkAfterCreate.publish({\n link: result\n });\n return result;\n } catch (error) {\n throw WebinyError.from(error, {\n message: \"Could not create link.\",\n code: \"CREATE_LINK_ERROR\",\n data: { ...input }\n });\n }\n },\n\n async updateLink(id: string, input: Record<string, any>): Promise<Link> {\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n const original = await storageOperations.getLink({ tenant, locale, id });\n\n if (!original) {\n throw new NotFoundError(`Link \"${id}\" was not found!`);\n }\n\n await updateSchema.validate(input);\n\n const link: Link = {\n ...original,\n ...input\n };\n\n try {\n await onLinkBeforeUpdate.publish({\n link,\n original\n });\n const result = await storageOperations.updateLink({ original, link });\n await onLinkAfterUpdate.publish({\n link: result,\n original\n });\n return result;\n } catch (error) {\n throw new WebinyError(\n error.message || \"Could not update link.\",\n error.code || \"UPDATE_LINK_ERROR\",\n {\n link\n }\n );\n }\n },\n\n async deleteLink(id: string): Promise<void> {\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n const link = await storageOperations.getLink({ tenant, locale, id });\n\n if (!link) {\n throw new NotFoundError(`Link \"${id}\" was not found!`);\n }\n\n try {\n await onLinkBeforeDelete.publish({\n link\n });\n const result = await storageOperations.deleteLink({ link });\n await onLinkAfterDelete.publish({\n link\n });\n return result;\n } catch (error) {\n throw new WebinyError(\n error.message || \"Could not delete link.\",\n error.code || \"DELETE_LINK_ERROR\",\n {\n link\n }\n );\n }\n },\n\n async deleteLinks(folderIds: string[]): Promise<void> {\n const tenant = getTenantId();\n const locale = getLocaleCode();\n\n try {\n await onLinkBeforeDeleteBatch.publish({\n folderIds\n });\n const result = await storageOperations.deleteLinks({ tenant, locale, folderIds });\n await onLinkAfterDeleteBatch.publish({\n folderIds\n });\n return result;\n } catch (error) {\n throw new WebinyError(\n error.message || \"Could not batch delete links.\",\n error.code || \"DELETE_LINKS_ERROR\",\n {\n folderIds\n }\n );\n }\n }\n };\n};\n"],"mappings":"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"}
@@ -51,15 +51,16 @@ const baseSchema = new _handlerGraphql.GraphQLSchemaPlugin({
51
51
  error: AcoError
52
52
  }
53
53
 
54
- enum AcoListSort {
55
- id_ASC
56
- id_DESC
57
- savedOn_ASC
58
- savedOn_DESC
59
- createdOn_ASC
60
- createdOn_DESC
61
- title_ASC
62
- title_DESC
54
+ enum AcoSortDirection {
55
+ ASC
56
+ DESC
57
+ }
58
+
59
+ input AcoSort {
60
+ id: AcoSortDirection
61
+ createdOn: AcoSortDirection
62
+ savedOn: AcoSortDirection
63
+ title: AcoSortDirection
63
64
  }
64
65
 
65
66
  extend type Query {