@webiny/api-file-manager 5.35.0 → 5.35.1-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/package.json +27 -27
  2. package/plugins/crud/files/validation.d.ts +0 -3
  3. package/plugins/crud/files/validation.js +0 -41
  4. package/plugins/crud/files/validation.js.map +0 -1
  5. package/plugins/crud/files.crud.d.ts +0 -4
  6. package/plugins/crud/files.crud.js +0 -431
  7. package/plugins/crud/files.crud.js.map +0 -1
  8. package/plugins/crud/settings.crud.d.ts +0 -5
  9. package/plugins/crud/settings.crud.js +0 -116
  10. package/plugins/crud/settings.crud.js.map +0 -1
  11. package/plugins/crud/system.crud.d.ts +0 -4
  12. package/plugins/crud/system.crud.js +0 -153
  13. package/plugins/crud/system.crud.js.map +0 -1
  14. package/plugins/crud/utils/checkBasePermissions.d.ts +0 -5
  15. package/plugins/crud/utils/checkBasePermissions.js +0 -33
  16. package/plugins/crud/utils/checkBasePermissions.js.map +0 -1
  17. package/plugins/crud/utils/createFileModel.d.ts +0 -5
  18. package/plugins/crud/utils/createFileModel.js +0 -77
  19. package/plugins/crud/utils/createFileModel.js.map +0 -1
  20. package/plugins/crud/utils/lifecycleEvents.d.ts +0 -6
  21. package/plugins/crud/utils/lifecycleEvents.js +0 -38
  22. package/plugins/crud/utils/lifecycleEvents.js.map +0 -1
  23. package/plugins/definitions/FilePhysicalStoragePlugin.d.ts +0 -21
  24. package/plugins/definitions/FilePhysicalStoragePlugin.js +0 -42
  25. package/plugins/definitions/FilePhysicalStoragePlugin.js.map +0 -1
  26. package/plugins/definitions/FilePlugin.d.ts +0 -136
  27. package/plugins/definitions/FilePlugin.js +0 -70
  28. package/plugins/definitions/FilePlugin.js.map +0 -1
  29. package/plugins/definitions/FileStorageTransformPlugin.d.ts +0 -34
  30. package/plugins/definitions/FileStorageTransformPlugin.js +0 -51
  31. package/plugins/definitions/FileStorageTransformPlugin.js.map +0 -1
  32. package/plugins/definitions/FilesStorageOperationsProviderPlugin.d.ts +0 -9
  33. package/plugins/definitions/FilesStorageOperationsProviderPlugin.js +0 -17
  34. package/plugins/definitions/FilesStorageOperationsProviderPlugin.js.map +0 -1
  35. package/plugins/definitions/InstallationPlugin.d.ts +0 -19
  36. package/plugins/definitions/InstallationPlugin.js +0 -42
  37. package/plugins/definitions/InstallationPlugin.js.map +0 -1
  38. package/plugins/definitions/SettingsStorageOperationsProviderPlugin.d.ts +0 -9
  39. package/plugins/definitions/SettingsStorageOperationsProviderPlugin.js +0 -17
  40. package/plugins/definitions/SettingsStorageOperationsProviderPlugin.js.map +0 -1
  41. package/plugins/definitions/SystemStorageOperationsProviderPlugin.d.ts +0 -9
  42. package/plugins/definitions/SystemStorageOperationsProviderPlugin.js +0 -17
  43. package/plugins/definitions/SystemStorageOperationsProviderPlugin.js.map +0 -1
  44. package/plugins/graphql.d.ts +0 -4
  45. package/plugins/graphql.js +0 -290
  46. package/plugins/graphql.js.map +0 -1
  47. package/plugins/storage/FileStorage.d.ts +0 -30
  48. package/plugins/storage/FileStorage.js +0 -103
  49. package/plugins/storage/FileStorage.js.map +0 -1
  50. package/plugins/storage/index.d.ts +0 -4
  51. package/plugins/storage/index.js +0 -26
  52. package/plugins/storage/index.js.map +0 -1
  53. package/utils.d.ts +0 -4
  54. package/utils.js +0 -16
  55. package/utils.js.map +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webiny/api-file-manager",
3
- "version": "5.35.0",
3
+ "version": "5.35.1-beta.0",
4
4
  "main": "index.js",
5
5
  "keywords": [
6
6
  "fm:base"
@@ -20,35 +20,35 @@
20
20
  "dependencies": {
21
21
  "@babel/runtime": "7.20.13",
22
22
  "@commodo/fields": "1.1.2-beta.20",
23
- "@webiny/api": "5.35.0",
24
- "@webiny/api-security": "5.35.0",
25
- "@webiny/api-tenancy": "5.35.0",
26
- "@webiny/error": "5.35.0",
27
- "@webiny/handler": "5.35.0",
28
- "@webiny/handler-aws": "5.35.0",
29
- "@webiny/handler-client": "5.35.0",
30
- "@webiny/handler-graphql": "5.35.0",
31
- "@webiny/plugins": "5.35.0",
32
- "@webiny/project-utils": "5.35.0",
33
- "@webiny/pubsub": "5.35.0",
34
- "@webiny/validation": "5.35.0",
23
+ "@webiny/api": "^5.35.1-beta.0",
24
+ "@webiny/api-security": "^5.35.1-beta.0",
25
+ "@webiny/api-tenancy": "^5.35.1-beta.0",
26
+ "@webiny/error": "^5.35.1-beta.0",
27
+ "@webiny/handler": "^5.35.1-beta.0",
28
+ "@webiny/handler-aws": "^5.35.1-beta.0",
29
+ "@webiny/handler-client": "^5.35.1-beta.0",
30
+ "@webiny/handler-graphql": "^5.35.1-beta.0",
31
+ "@webiny/plugins": "^5.35.1-beta.0",
32
+ "@webiny/project-utils": "^5.35.1-beta.0",
33
+ "@webiny/pubsub": "^5.35.1-beta.0",
34
+ "@webiny/validation": "^5.35.1-beta.0",
35
35
  "aws-sdk": "2.1310.0",
36
36
  "object-hash": "2.2.0"
37
37
  },
38
38
  "devDependencies": {
39
- "@babel/cli": "^7.19.3",
40
- "@babel/core": "^7.19.3",
41
- "@babel/plugin-proposal-object-rest-spread": "^7.16.0",
42
- "@babel/plugin-transform-runtime": "^7.16.4",
43
- "@babel/preset-env": "^7.19.4",
44
- "@babel/preset-typescript": "^7.18.6",
45
- "@webiny/api-i18n": "^5.35.0",
46
- "@webiny/api-i18n-ddb": "^5.35.0",
47
- "@webiny/cli": "^5.35.0",
48
- "jest": "^28.1.0",
49
- "mdbid": "^1.0.0",
50
- "rimraf": "^3.0.2",
51
- "ttypescript": "^1.5.12",
39
+ "@babel/cli": "7.20.7",
40
+ "@babel/core": "7.20.12",
41
+ "@babel/plugin-proposal-object-rest-spread": "7.20.7",
42
+ "@babel/plugin-transform-runtime": "7.19.6",
43
+ "@babel/preset-env": "7.20.2",
44
+ "@babel/preset-typescript": "7.18.6",
45
+ "@webiny/api-i18n": "^5.35.1-beta.0",
46
+ "@webiny/api-i18n-ddb": "^5.35.1-beta.0",
47
+ "@webiny/cli": "^5.35.1-beta.0",
48
+ "jest": "28.1.3",
49
+ "mdbid": "1.0.0",
50
+ "rimraf": "3.0.2",
51
+ "ttypescript": "1.5.15",
52
52
  "typescript": "4.7.4"
53
53
  },
54
54
  "publishConfig": {
@@ -70,5 +70,5 @@
70
70
  ]
71
71
  }
72
72
  },
73
- "gitHead": "948cd1e05978e0ed25137ace7dd6c15ed0bf2cca"
73
+ "gitHead": "d6a257ebbb9e7aeccfaa33a7f83301cf1919b082"
74
74
  }
@@ -1,3 +0,0 @@
1
- import { FilePlugin } from "../../definitions/FilePlugin";
2
- declare const _default: () => FilePlugin[];
3
- export default _default;
@@ -1,41 +0,0 @@
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.default = void 0;
9
-
10
- var _FilePlugin = require("../../definitions/FilePlugin");
11
-
12
- var _createFileModel = _interopRequireDefault(require("../utils/createFileModel"));
13
-
14
- var _default = () => [new _FilePlugin.FilePlugin({
15
- beforeCreate: async ({
16
- data
17
- }) => {
18
- const FileModel = (0, _createFileModel.default)();
19
- const fileData = new FileModel().populate(data);
20
- await fileData.validate();
21
- },
22
- beforeUpdate: async ({
23
- data
24
- }) => {
25
- const FileModel = (0, _createFileModel.default)(false);
26
- const updatedFileData = new FileModel().populate(data);
27
- await updatedFileData.validate();
28
- },
29
- beforeBatchCreate: async ({
30
- data
31
- }) => {
32
- const FileModel = (0, _createFileModel.default)();
33
-
34
- for (const input of data) {
35
- const fileInstance = new FileModel().populate(input);
36
- await fileInstance.validate();
37
- }
38
- }
39
- })];
40
-
41
- exports.default = _default;
@@ -1 +0,0 @@
1
- {"version":3,"names":["FilePlugin","beforeCreate","data","FileModel","createFileModel","fileData","populate","validate","beforeUpdate","updatedFileData","beforeBatchCreate","input","fileInstance"],"sources":["validation.ts"],"sourcesContent":["import { FilePlugin } from \"~/plugins/definitions/FilePlugin\";\nimport createFileModel from \"~/plugins/crud/utils/createFileModel\";\n\nexport default (): FilePlugin[] => [\n new FilePlugin({\n beforeCreate: async ({ data }) => {\n const FileModel = createFileModel();\n const fileData = new FileModel().populate(data);\n await fileData.validate();\n },\n beforeUpdate: async ({ data }) => {\n const FileModel = createFileModel(false);\n const updatedFileData = new FileModel().populate(data);\n await updatedFileData.validate();\n },\n beforeBatchCreate: async ({ data }) => {\n const FileModel = createFileModel();\n for (const input of data) {\n const fileInstance = new FileModel().populate(input);\n await fileInstance.validate();\n }\n }\n })\n];\n"],"mappings":";;;;;;;;;AAAA;;AACA;;eAEe,MAAoB,CAC/B,IAAIA,sBAAJ,CAAe;EACXC,YAAY,EAAE,OAAO;IAAEC;EAAF,CAAP,KAAoB;IAC9B,MAAMC,SAAS,GAAG,IAAAC,wBAAA,GAAlB;IACA,MAAMC,QAAQ,GAAG,IAAIF,SAAJ,GAAgBG,QAAhB,CAAyBJ,IAAzB,CAAjB;IACA,MAAMG,QAAQ,CAACE,QAAT,EAAN;EACH,CALU;EAMXC,YAAY,EAAE,OAAO;IAAEN;EAAF,CAAP,KAAoB;IAC9B,MAAMC,SAAS,GAAG,IAAAC,wBAAA,EAAgB,KAAhB,CAAlB;IACA,MAAMK,eAAe,GAAG,IAAIN,SAAJ,GAAgBG,QAAhB,CAAyBJ,IAAzB,CAAxB;IACA,MAAMO,eAAe,CAACF,QAAhB,EAAN;EACH,CAVU;EAWXG,iBAAiB,EAAE,OAAO;IAAER;EAAF,CAAP,KAAoB;IACnC,MAAMC,SAAS,GAAG,IAAAC,wBAAA,GAAlB;;IACA,KAAK,MAAMO,KAAX,IAAoBT,IAApB,EAA0B;MACtB,MAAMU,YAAY,GAAG,IAAIT,SAAJ,GAAgBG,QAAhB,CAAyBK,KAAzB,CAArB;MACA,MAAMC,YAAY,CAACL,QAAb,EAAN;IACH;EACJ;AAjBU,CAAf,CAD+B,C"}
@@ -1,4 +0,0 @@
1
- import { FileManagerContext } from "../../types";
2
- import { ContextPlugin } from "@webiny/api";
3
- declare const filesContextCrudPlugin: ContextPlugin<FileManagerContext>;
4
- export default filesContextCrudPlugin;
@@ -1,431 +0,0 @@
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.default = void 0;
9
-
10
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
-
12
- var _mdbid = _interopRequireDefault(require("mdbid"));
13
-
14
- var _handlerGraphql = require("@webiny/handler-graphql");
15
-
16
- var _apiSecurity = require("@webiny/api-security");
17
-
18
- var _checkBasePermissions = _interopRequireDefault(require("./utils/checkBasePermissions"));
19
-
20
- var _api = require("@webiny/api");
21
-
22
- var _FilePlugin = require("../definitions/FilePlugin");
23
-
24
- var _FilesStorageOperationsProviderPlugin = require("../definitions/FilesStorageOperationsProviderPlugin");
25
-
26
- var _error = _interopRequireDefault(require("@webiny/error"));
27
-
28
- var _lifecycleEvents = require("./utils/lifecycleEvents");
29
-
30
- /**
31
- * Package mdbid does not have types.
32
- */
33
- // @ts-ignore
34
- const BATCH_CREATE_MAX_FILES = 20;
35
- /**
36
- * If permission is limited to "own" files only, check that current identity owns the file.
37
- */
38
-
39
- const checkOwnership = (file, permission, context) => {
40
- if ((permission === null || permission === void 0 ? void 0 : permission.own) === true) {
41
- const identity = context.security.getIdentity();
42
-
43
- if (file.createdBy.id !== identity.id) {
44
- throw new _apiSecurity.NotAuthorizedError();
45
- }
46
- }
47
- };
48
-
49
- const getLocaleCode = context => {
50
- if (!context.i18n) {
51
- throw new _error.default("Missing i18n on the FileManagerContext.", "MISSING_I18N");
52
- }
53
-
54
- const locale = context.i18n.getContentLocale();
55
-
56
- if (!locale) {
57
- throw new _error.default("Missing content locale on the FileManagerContext.", "MISSING_I18N_CONTENT_LOCALE");
58
- }
59
-
60
- if (!locale.code) {
61
- throw new _error.default("Missing content locale code on the FileManagerContext.", "MISSING_I18N_CONTENT_LOCALE_CODE");
62
- }
63
-
64
- return locale.code;
65
- };
66
-
67
- const filesContextCrudPlugin = new _api.ContextPlugin(async context => {
68
- const pluginType = _FilesStorageOperationsProviderPlugin.FilesStorageOperationsProviderPlugin.type;
69
- const providerPlugin = context.plugins.byType(pluginType).find(() => true);
70
-
71
- if (!providerPlugin) {
72
- throw new _error.default(`Missing "${pluginType}" plugin.`, "PLUGIN_NOT_FOUND", {
73
- type: pluginType
74
- });
75
- }
76
-
77
- const storageOperations = await providerPlugin.provide({
78
- context
79
- });
80
-
81
- if (!context.fileManager) {
82
- context.fileManager = {};
83
- }
84
-
85
- const filePlugins = context.plugins.byType(_FilePlugin.FilePlugin.type);
86
- context.fileManager.files = {
87
- async getFile(id) {
88
- const permission = await (0, _checkBasePermissions.default)(context, {
89
- rwd: "r"
90
- });
91
- const file = await storageOperations.get({
92
- where: {
93
- id,
94
- tenant: context.tenancy.getCurrentTenant().id,
95
- locale: getLocaleCode(context)
96
- }
97
- });
98
-
99
- if (!file) {
100
- throw new _handlerGraphql.NotFoundError(`File with id "${id}" does not exists.`);
101
- }
102
-
103
- checkOwnership(file, permission, context);
104
- return file;
105
- },
106
-
107
- async createFile(input) {
108
- await (0, _checkBasePermissions.default)(context, {
109
- rwd: "w"
110
- });
111
- const identity = context.security.getIdentity();
112
- const tenant = context.tenancy.getCurrentTenant();
113
- const id = (0, _mdbid.default)();
114
- const file = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, input), {}, {
115
- tags: Array.isArray(input.tags) ? input.tags : [],
116
- id,
117
- meta: (0, _objectSpread2.default)({
118
- private: false
119
- }, input.meta || {}),
120
- tenant: tenant.id,
121
- createdOn: new Date().toISOString(),
122
- createdBy: {
123
- id: identity.id,
124
- displayName: identity.displayName,
125
- type: identity.type
126
- },
127
- locale: getLocaleCode(context),
128
- webinyVersion: context.WEBINY_VERSION
129
- });
130
-
131
- try {
132
- await (0, _lifecycleEvents.runLifecycleEvent)("beforeCreate", {
133
- context,
134
- plugins: filePlugins,
135
- data: file
136
- });
137
- const result = await storageOperations.create({
138
- file
139
- });
140
- await (0, _lifecycleEvents.runLifecycleEvent)("afterCreate", {
141
- context,
142
- plugins: filePlugins,
143
- data: file,
144
- file: result
145
- });
146
- return result;
147
- } catch (ex) {
148
- throw new _error.default(ex.message || "Could not create a file.", ex.code || "CREATE_FILE_ERROR", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, ex.data || {}), {}, {
149
- file
150
- }));
151
- }
152
- },
153
-
154
- async updateFile(id, input) {
155
- const permission = await (0, _checkBasePermissions.default)(context, {
156
- rwd: "w"
157
- });
158
- const original = await storageOperations.get({
159
- where: {
160
- id,
161
- tenant: context.tenancy.getCurrentTenant().id,
162
- locale: getLocaleCode(context)
163
- }
164
- });
165
-
166
- if (!original) {
167
- throw new _handlerGraphql.NotFoundError(`File with id "${id}" does not exists.`);
168
- }
169
-
170
- checkOwnership(original, permission, context);
171
- const file = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, original), input), {}, {
172
- tags: Array.isArray(input.tags) ? input.tags : Array.isArray(original.tags) ? original.tags : [],
173
- id: original.id,
174
- webinyVersion: context.WEBINY_VERSION
175
- });
176
-
177
- try {
178
- await (0, _lifecycleEvents.runLifecycleEvent)("beforeUpdate", {
179
- context,
180
- plugins: filePlugins,
181
- original,
182
- data: file
183
- });
184
- const result = await storageOperations.update({
185
- original,
186
- file
187
- });
188
- await (0, _lifecycleEvents.runLifecycleEvent)("afterUpdate", {
189
- context,
190
- plugins: filePlugins,
191
- original,
192
- data: file,
193
- file: result
194
- });
195
- return result;
196
- } catch (ex) {
197
- throw new _error.default(ex.message || "Could not update a file.", ex.code || "UPDATE_FILE_ERROR", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, ex.data || {}), {}, {
198
- original,
199
- file
200
- }));
201
- }
202
- },
203
-
204
- async deleteFile(id) {
205
- const permission = await (0, _checkBasePermissions.default)(context, {
206
- rwd: "d"
207
- });
208
- const file = await storageOperations.get({
209
- where: {
210
- id,
211
- tenant: context.tenancy.getCurrentTenant().id,
212
- locale: getLocaleCode(context)
213
- }
214
- });
215
-
216
- if (!file) {
217
- throw new _handlerGraphql.NotFoundError(`File with id "${id}" does not exists.`);
218
- }
219
-
220
- checkOwnership(file, permission, context);
221
-
222
- try {
223
- await (0, _lifecycleEvents.runLifecycleEvent)("beforeDelete", {
224
- context,
225
- plugins: filePlugins,
226
- file
227
- });
228
- await storageOperations.delete({
229
- file
230
- });
231
- await (0, _lifecycleEvents.runLifecycleEvent)("afterDelete", {
232
- context,
233
- plugins: filePlugins,
234
- file
235
- });
236
- } catch (ex) {
237
- throw new _error.default(ex.message || "Could not delete a file.", ex.code || "DELETE_FILE_ERROR", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, ex.data || {}), {}, {
238
- id,
239
- file
240
- }));
241
- }
242
-
243
- return true;
244
- },
245
-
246
- async createFilesInBatch(inputs) {
247
- if (!Array.isArray(inputs)) {
248
- throw new _error.default(`"data" must be an array.`, "CREATE_FILES_NON_ARRAY");
249
- }
250
-
251
- if (inputs.length === 0) {
252
- throw new _error.default(`"data" argument must contain at least one file.`, "CREATE_FILES_MIN_FILES");
253
- }
254
-
255
- if (inputs.length > BATCH_CREATE_MAX_FILES) {
256
- throw new _error.default(`"data" argument must not contain more than ${BATCH_CREATE_MAX_FILES} files.`, "CREATE_FILES_MAX_FILES");
257
- }
258
-
259
- await (0, _checkBasePermissions.default)(context, {
260
- rwd: "w"
261
- });
262
- const identity = context.security.getIdentity();
263
- const tenant = context.tenancy.getCurrentTenant();
264
- const createdBy = {
265
- id: identity.id,
266
- displayName: identity.displayName,
267
- type: identity.type
268
- };
269
- const files = inputs.map(input => {
270
- return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, input), {}, {
271
- tags: Array.isArray(input.tags) ? input.tags : [],
272
- meta: (0, _objectSpread2.default)({
273
- private: false
274
- }, input.meta || {}),
275
- id: (0, _mdbid.default)(),
276
- tenant: tenant.id,
277
- createdOn: new Date().toISOString(),
278
- createdBy,
279
- locale: getLocaleCode(context),
280
- webinyVersion: context.WEBINY_VERSION
281
- });
282
- });
283
-
284
- try {
285
- await (0, _lifecycleEvents.runLifecycleEvent)("beforeBatchCreate", {
286
- context,
287
- plugins: filePlugins,
288
- data: files
289
- });
290
- const results = await storageOperations.createBatch({
291
- files
292
- });
293
- await (0, _lifecycleEvents.runLifecycleEvent)("afterBatchCreate", {
294
- context,
295
- plugins: filePlugins,
296
- data: files,
297
- files: results
298
- });
299
- return results;
300
- } catch (ex) {
301
- throw new _error.default(ex.message || "Could not create a batch of files.", ex.code || "CREATE_FILES_ERROR", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, ex.data || {}), {}, {
302
- files
303
- }));
304
- }
305
- },
306
-
307
- async listFiles(params = {}) {
308
- const permission = await (0, _checkBasePermissions.default)(context, {
309
- rwd: "r"
310
- });
311
- const {
312
- limit = 40,
313
- search = "",
314
- types = [],
315
- tags = [],
316
- ids = [],
317
- after = null,
318
- where: initialWhere,
319
- sort: initialSort
320
- } = params;
321
- const where = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, initialWhere), {}, {
322
- private: false,
323
- locale: getLocaleCode(context),
324
- tenant: context.tenancy.getCurrentTenant().id
325
- });
326
- /**
327
- * Always override the createdBy received from the user, if any.
328
- */
329
-
330
- if (permission.own === true) {
331
- const identity = context.security.getIdentity();
332
- where.createdBy = identity.id;
333
- }
334
- /**
335
- * We need to map the old GraphQL definition to the new one.
336
- * That GQL definition is marked as deprecated.
337
- */
338
-
339
- /**
340
- * To have standardized where objects across the applications, we transform the types into type_in.
341
- */
342
-
343
-
344
- if (Array.isArray(types) && types.length > 0 && !where.type_in) {
345
- where.type_in = types;
346
- }
347
- /**
348
- * We are assigning search to tag and name search.
349
- * This should be treated as OR condition in the storage operations.
350
- */
351
-
352
-
353
- if (search && !where.search) {
354
- where.search = search;
355
- }
356
- /**
357
- * Same as on types/type_in.
358
- */
359
-
360
-
361
- if (Array.isArray(tags) && tags.length > 0 && !where.tag_in) {
362
- where.tag_in = tags.map(tag => tag.toLowerCase());
363
- }
364
- /**
365
- * Same as on types/type_in.
366
- */
367
-
368
-
369
- if (Array.isArray(ids) && ids.length > 0 && !where.id_in) {
370
- where.id_in = ids;
371
- }
372
-
373
- const sort = Array.isArray(initialSort) && initialSort.length > 0 ? initialSort : ["id_DESC"];
374
-
375
- try {
376
- return await storageOperations.list({
377
- where,
378
- after,
379
- limit,
380
- sort
381
- });
382
- } catch (ex) {
383
- throw new _error.default(ex.message || "Could not list files by given parameters.", ex.code || "FILE_TAG_SEARCH_ERROR", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, ex.data || {}), {}, {
384
- where,
385
- after,
386
- limit,
387
- sort
388
- }));
389
- }
390
- },
391
-
392
- async listTags({
393
- where: initialWhere,
394
- after,
395
- limit
396
- }) {
397
- await (0, _checkBasePermissions.default)(context);
398
- const where = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, initialWhere), {}, {
399
- tenant: context.tenancy.getCurrentTenant().id,
400
- locale: getLocaleCode(context)
401
- });
402
- const params = {
403
- where,
404
- limit: limit || 100000,
405
- after
406
- };
407
-
408
- try {
409
- const [tags] = await storageOperations.tags(params);
410
-
411
- if (Array.isArray(tags) === false) {
412
- return [];
413
- }
414
- /**
415
- * just to keep it standardized, sort by the tag ASC
416
- */
417
-
418
-
419
- return tags.sort();
420
- } catch (ex) {
421
- throw new _error.default(ex.message || "Could not search for tags.", ex.code || "FILE_TAG_SEARCH_ERROR", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, ex.data || {}), {}, {
422
- params
423
- }));
424
- }
425
- }
426
-
427
- };
428
- });
429
- filesContextCrudPlugin.name = "FileManagerFilesCrud";
430
- var _default = filesContextCrudPlugin;
431
- exports.default = _default;
@@ -1 +0,0 @@
1
- {"version":3,"names":["BATCH_CREATE_MAX_FILES","checkOwnership","file","permission","context","own","identity","security","getIdentity","createdBy","id","NotAuthorizedError","getLocaleCode","i18n","WebinyError","locale","getContentLocale","code","filesContextCrudPlugin","ContextPlugin","pluginType","FilesStorageOperationsProviderPlugin","type","providerPlugin","plugins","byType","find","storageOperations","provide","fileManager","filePlugins","FilePlugin","files","getFile","checkBasePermissions","rwd","get","where","tenant","tenancy","getCurrentTenant","NotFoundError","createFile","input","mdbid","tags","Array","isArray","meta","private","createdOn","Date","toISOString","displayName","webinyVersion","WEBINY_VERSION","runLifecycleEvent","data","result","create","ex","message","updateFile","original","update","deleteFile","delete","createFilesInBatch","inputs","length","map","results","createBatch","listFiles","params","limit","search","types","ids","after","initialWhere","sort","initialSort","type_in","tag_in","tag","toLowerCase","id_in","list","listTags","name"],"sources":["files.crud.ts"],"sourcesContent":["/**\n * Package mdbid does not have types.\n */\n// @ts-ignore\nimport mdbid from \"mdbid\";\nimport { NotFoundError } from \"@webiny/handler-graphql\";\nimport { NotAuthorizedError } from \"@webiny/api-security\";\nimport {\n CreatedBy,\n File,\n FileManagerContext,\n FileManagerFilesStorageOperationsListParamsWhere,\n FileManagerFilesStorageOperationsTagsParamsWhere,\n FilePermission,\n FilesListOpts\n} from \"~/types\";\nimport checkBasePermissions from \"./utils/checkBasePermissions\";\nimport { ContextPlugin } from \"@webiny/api\";\nimport { FilePlugin } from \"~/plugins/definitions/FilePlugin\";\nimport { FilesStorageOperationsProviderPlugin } from \"~/plugins/definitions/FilesStorageOperationsProviderPlugin\";\nimport WebinyError from \"@webiny/error\";\nimport { runLifecycleEvent } from \"~/plugins/crud/utils/lifecycleEvents\";\n\nconst BATCH_CREATE_MAX_FILES = 20;\n\n/**\n * If permission is limited to \"own\" files only, check that current identity owns the file.\n */\nconst checkOwnership = (file: File, permission: FilePermission, context: FileManagerContext) => {\n if (permission?.own === true) {\n const identity = context.security.getIdentity();\n if (file.createdBy.id !== identity.id) {\n throw new NotAuthorizedError();\n }\n }\n};\n\nconst getLocaleCode = (context: FileManagerContext): string => {\n if (!context.i18n) {\n throw new WebinyError(\"Missing i18n on the FileManagerContext.\", \"MISSING_I18N\");\n }\n\n const locale = context.i18n.getContentLocale();\n if (!locale) {\n throw new WebinyError(\n \"Missing content locale on the FileManagerContext.\",\n \"MISSING_I18N_CONTENT_LOCALE\"\n );\n }\n\n if (!locale.code) {\n throw new WebinyError(\n \"Missing content locale code on the FileManagerContext.\",\n \"MISSING_I18N_CONTENT_LOCALE_CODE\"\n );\n }\n return locale.code;\n};\n\nconst filesContextCrudPlugin = new ContextPlugin<FileManagerContext>(async context => {\n const pluginType = FilesStorageOperationsProviderPlugin.type;\n\n const providerPlugin = context.plugins\n .byType<FilesStorageOperationsProviderPlugin>(pluginType)\n .find(() => true);\n\n if (!providerPlugin) {\n throw new WebinyError(`Missing \"${pluginType}\" plugin.`, \"PLUGIN_NOT_FOUND\", {\n type: pluginType\n });\n }\n\n const storageOperations = await providerPlugin.provide({\n context\n });\n\n if (!context.fileManager) {\n context.fileManager = {} as any;\n }\n\n const filePlugins = context.plugins.byType<FilePlugin>(FilePlugin.type);\n\n context.fileManager.files = {\n async getFile(id: string) {\n const permission = await checkBasePermissions(context, { rwd: \"r\" });\n\n const file = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n\n if (!file) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(file, permission, context);\n\n return file;\n },\n async createFile(input) {\n await checkBasePermissions(context, { rwd: \"w\" });\n const identity = context.security.getIdentity();\n const tenant = context.tenancy.getCurrentTenant();\n\n const id = mdbid();\n\n const file: File = {\n ...input,\n tags: Array.isArray(input.tags) ? input.tags : [],\n id,\n meta: {\n private: false,\n ...(input.meta || {})\n },\n tenant: tenant.id,\n createdOn: new Date().toISOString(),\n createdBy: {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n },\n locale: getLocaleCode(context),\n webinyVersion: context.WEBINY_VERSION\n };\n\n try {\n await runLifecycleEvent(\"beforeCreate\", {\n context,\n plugins: filePlugins,\n data: file\n });\n const result = await storageOperations.create({\n file\n });\n await runLifecycleEvent(\"afterCreate\", {\n context,\n plugins: filePlugins,\n data: file,\n file: result\n });\n return result;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create a file.\",\n ex.code || \"CREATE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n file\n }\n );\n }\n },\n async updateFile(id, input) {\n const permission = await checkBasePermissions(context, { rwd: \"w\" });\n\n const original = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n\n if (!original) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(original, permission, context);\n\n const file: File = {\n ...original,\n ...input,\n tags: Array.isArray(input.tags)\n ? input.tags\n : Array.isArray(original.tags)\n ? original.tags\n : [],\n id: original.id,\n webinyVersion: context.WEBINY_VERSION\n };\n\n try {\n await runLifecycleEvent(\"beforeUpdate\", {\n context,\n plugins: filePlugins,\n original,\n data: file\n });\n const result = await storageOperations.update({\n original,\n file\n });\n await runLifecycleEvent(\"afterUpdate\", {\n context,\n plugins: filePlugins,\n original,\n data: file,\n file: result\n });\n return result;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update a file.\",\n ex.code || \"UPDATE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n original,\n file\n }\n );\n }\n },\n async deleteFile(id) {\n const permission = await checkBasePermissions(context, { rwd: \"d\" });\n\n const file = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n if (!file) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(file, permission, context);\n\n try {\n await runLifecycleEvent(\"beforeDelete\", {\n context,\n plugins: filePlugins,\n file\n });\n await storageOperations.delete({\n file\n });\n await runLifecycleEvent(\"afterDelete\", {\n context,\n plugins: filePlugins,\n file\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete a file.\",\n ex.code || \"DELETE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n id,\n file\n }\n );\n }\n\n return true;\n },\n async createFilesInBatch(inputs) {\n if (!Array.isArray(inputs)) {\n throw new WebinyError(`\"data\" must be an array.`, \"CREATE_FILES_NON_ARRAY\");\n }\n\n if (inputs.length === 0) {\n throw new WebinyError(\n `\"data\" argument must contain at least one file.`,\n \"CREATE_FILES_MIN_FILES\"\n );\n }\n\n if (inputs.length > BATCH_CREATE_MAX_FILES) {\n throw new WebinyError(\n `\"data\" argument must not contain more than ${BATCH_CREATE_MAX_FILES} files.`,\n \"CREATE_FILES_MAX_FILES\"\n );\n }\n\n await checkBasePermissions(context, { rwd: \"w\" });\n\n const identity = context.security.getIdentity();\n const tenant = context.tenancy.getCurrentTenant();\n const createdBy: CreatedBy = {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n };\n\n const files: File[] = inputs.map(input => {\n return {\n ...input,\n tags: Array.isArray(input.tags) ? input.tags : [],\n meta: {\n private: false,\n ...(input.meta || {})\n },\n id: mdbid(),\n tenant: tenant.id,\n createdOn: new Date().toISOString(),\n createdBy,\n locale: getLocaleCode(context),\n webinyVersion: context.WEBINY_VERSION\n };\n });\n\n try {\n await runLifecycleEvent(\"beforeBatchCreate\", {\n context,\n plugins: filePlugins,\n data: files\n });\n const results = await storageOperations.createBatch({\n files\n });\n await runLifecycleEvent(\"afterBatchCreate\", {\n context,\n plugins: filePlugins,\n data: files,\n files: results\n });\n return results;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create a batch of files.\",\n ex.code || \"CREATE_FILES_ERROR\",\n {\n ...(ex.data || {}),\n files\n }\n );\n }\n },\n async listFiles(params: FilesListOpts = {}) {\n const permission = await checkBasePermissions(context, { rwd: \"r\" });\n\n const {\n limit = 40,\n search = \"\",\n types = [],\n tags = [],\n ids = [],\n after = null,\n where: initialWhere,\n sort: initialSort\n } = params;\n\n const where: FileManagerFilesStorageOperationsListParamsWhere = {\n ...initialWhere,\n private: false,\n locale: getLocaleCode(context),\n tenant: context.tenancy.getCurrentTenant().id\n };\n /**\n * Always override the createdBy received from the user, if any.\n */\n if (permission.own === true) {\n const identity = context.security.getIdentity();\n where.createdBy = identity.id;\n }\n /**\n * We need to map the old GraphQL definition to the new one.\n * That GQL definition is marked as deprecated.\n */\n /**\n * To have standardized where objects across the applications, we transform the types into type_in.\n */\n if (Array.isArray(types) && types.length > 0 && !where.type_in) {\n where.type_in = types;\n }\n /**\n * We are assigning search to tag and name search.\n * This should be treated as OR condition in the storage operations.\n */\n if (search && !where.search) {\n where.search = search;\n }\n /**\n * Same as on types/type_in.\n */\n if (Array.isArray(tags) && tags.length > 0 && !where.tag_in) {\n where.tag_in = tags.map(tag => tag.toLowerCase());\n }\n /**\n * Same as on types/type_in.\n */\n if (Array.isArray(ids) && ids.length > 0 && !where.id_in) {\n where.id_in = ids;\n }\n\n const sort =\n Array.isArray(initialSort) && initialSort.length > 0 ? initialSort : [\"id_DESC\"];\n try {\n return await storageOperations.list({\n where,\n after,\n limit,\n sort\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not list files by given parameters.\",\n ex.code || \"FILE_TAG_SEARCH_ERROR\",\n {\n ...(ex.data || {}),\n where,\n after,\n limit,\n sort\n }\n );\n }\n },\n async listTags({ where: initialWhere, after, limit }) {\n await checkBasePermissions(context);\n\n const where: FileManagerFilesStorageOperationsTagsParamsWhere = {\n ...initialWhere,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n };\n\n const params = {\n where,\n limit: limit || 100000,\n after\n };\n\n try {\n const [tags] = await storageOperations.tags(params);\n if (Array.isArray(tags) === false) {\n return [];\n }\n /**\n * just to keep it standardized, sort by the tag ASC\n */\n return tags.sort();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not search for tags.\",\n ex.code || \"FILE_TAG_SEARCH_ERROR\",\n {\n ...(ex.data || {}),\n params\n }\n );\n }\n }\n };\n});\n\nfilesContextCrudPlugin.name = \"FileManagerFilesCrud\";\n\nexport default filesContextCrudPlugin;\n"],"mappings":"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"}
@@ -1,5 +0,0 @@
1
- import { FileManagerContext } from "../../types";
2
- import { ContextPlugin } from "@webiny/api";
3
- export declare const SETTINGS_KEY = "file-manager";
4
- declare const settingsCrudContextPlugin: ContextPlugin<FileManagerContext>;
5
- export default settingsCrudContextPlugin;