@webiny/api-file-manager 0.0.0-mt-3 → 0.0.0-unstable.8c4d9f045a

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 (90) hide show
  1. package/handlers/download/index.d.ts +3 -3
  2. package/handlers/download/index.js +66 -59
  3. package/handlers/download/index.js.map +1 -0
  4. package/handlers/manage/index.d.ts +5 -3
  5. package/handlers/manage/index.js +47 -46
  6. package/handlers/manage/index.js.map +1 -0
  7. package/handlers/transform/index.d.ts +2 -3
  8. package/handlers/transform/index.js +67 -68
  9. package/handlers/transform/index.js.map +1 -0
  10. package/handlers/transform/loaders/imageLoader.d.ts +26 -9
  11. package/handlers/transform/loaders/imageLoader.js +2 -3
  12. package/handlers/transform/loaders/imageLoader.js.map +1 -0
  13. package/handlers/transform/loaders/index.d.ts +4 -9
  14. package/handlers/transform/loaders/index.js.map +1 -0
  15. package/handlers/transform/loaders/sanitizeImageTransformations.d.ts +7 -3
  16. package/handlers/transform/loaders/sanitizeImageTransformations.js +27 -20
  17. package/handlers/transform/loaders/sanitizeImageTransformations.js.map +1 -0
  18. package/handlers/transform/managers/imageManager.d.ts +12 -6
  19. package/handlers/transform/managers/imageManager.js +25 -17
  20. package/handlers/transform/managers/imageManager.js.map +1 -0
  21. package/handlers/transform/managers/index.d.ts +2 -6
  22. package/handlers/transform/managers/index.js.map +1 -0
  23. package/handlers/transform/optimizeImage.d.ts +2 -1
  24. package/handlers/transform/optimizeImage.js +3 -0
  25. package/handlers/transform/optimizeImage.js.map +1 -0
  26. package/handlers/transform/transformImage.d.ts +5 -4
  27. package/handlers/transform/transformImage.js +3 -3
  28. package/handlers/transform/transformImage.js.map +1 -0
  29. package/handlers/transform/utils.d.ts +2 -2
  30. package/handlers/transform/utils.js.map +1 -0
  31. package/handlers/types.d.ts +8 -0
  32. package/handlers/types.js +5 -0
  33. package/handlers/types.js.map +1 -0
  34. package/handlers/utils/getEnvironment.js.map +1 -0
  35. package/handlers/utils/getObjectParams.d.ts +3 -4
  36. package/handlers/utils/getObjectParams.js +0 -2
  37. package/handlers/utils/getObjectParams.js.map +1 -0
  38. package/handlers/utils/index.d.ts +0 -1
  39. package/handlers/utils/index.js +0 -8
  40. package/handlers/utils/index.js.map +1 -0
  41. package/package.json +28 -27
  42. package/plugins/crud/files/validation.js.map +1 -0
  43. package/plugins/crud/files.crud.d.ts +1 -1
  44. package/plugins/crud/files.crud.js +34 -24
  45. package/plugins/crud/files.crud.js.map +1 -0
  46. package/plugins/crud/settings.crud.d.ts +1 -1
  47. package/plugins/crud/settings.crud.js +5 -4
  48. package/plugins/crud/settings.crud.js.map +1 -0
  49. package/plugins/crud/system.crud.d.ts +1 -1
  50. package/plugins/crud/system.crud.js +17 -5
  51. package/plugins/crud/system.crud.js.map +1 -0
  52. package/plugins/crud/utils/checkBasePermissions.js +1 -1
  53. package/plugins/crud/utils/checkBasePermissions.js.map +1 -0
  54. package/plugins/crud/utils/createFileModel.d.ts +3 -0
  55. package/plugins/crud/utils/createFileModel.js +13 -0
  56. package/plugins/crud/utils/createFileModel.js.map +1 -0
  57. package/plugins/crud/utils/lifecycleEvents.d.ts +2 -2
  58. package/plugins/crud/utils/lifecycleEvents.js +5 -0
  59. package/plugins/crud/utils/lifecycleEvents.js.map +1 -0
  60. package/plugins/definitions/FilePhysicalStoragePlugin.d.ts +10 -11
  61. package/plugins/definitions/FilePhysicalStoragePlugin.js.map +1 -0
  62. package/plugins/definitions/FilePlugin.d.ts +6 -3
  63. package/plugins/definitions/FilePlugin.js +8 -2
  64. package/plugins/definitions/FilePlugin.js.map +1 -0
  65. package/plugins/definitions/FileStorageTransformPlugin.d.ts +9 -9
  66. package/plugins/definitions/FileStorageTransformPlugin.js.map +1 -0
  67. package/plugins/definitions/FilesStorageOperationsProviderPlugin.d.ts +4 -4
  68. package/plugins/definitions/FilesStorageOperationsProviderPlugin.js.map +1 -0
  69. package/plugins/definitions/InstallationPlugin.d.ts +9 -9
  70. package/plugins/definitions/InstallationPlugin.js +4 -2
  71. package/plugins/definitions/InstallationPlugin.js.map +1 -0
  72. package/plugins/definitions/SettingsStorageOperationsProviderPlugin.d.ts +4 -4
  73. package/plugins/definitions/SettingsStorageOperationsProviderPlugin.js.map +1 -0
  74. package/plugins/definitions/SystemStorageOperationsProviderPlugin.d.ts +4 -4
  75. package/plugins/definitions/SystemStorageOperationsProviderPlugin.js.map +1 -0
  76. package/plugins/graphql.js +20 -4
  77. package/plugins/graphql.js.map +1 -0
  78. package/plugins/index.d.ts +1 -1
  79. package/plugins/index.js.map +1 -0
  80. package/plugins/storage/FileStorage.d.ts +23 -24
  81. package/plugins/storage/FileStorage.js +25 -15
  82. package/plugins/storage/FileStorage.js.map +1 -0
  83. package/plugins/storage/index.d.ts +1 -1
  84. package/plugins/storage/index.js +6 -2
  85. package/plugins/storage/index.js.map +1 -0
  86. package/types.d.ts +16 -12
  87. package/types.js.map +1 -0
  88. package/utils.js.map +1 -0
  89. package/handlers/utils/createHandler.d.ts +0 -24
  90. package/handlers/utils/createHandler.js +0 -68
@@ -5,43 +5,50 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = void 0;
7
7
  const SUPPORTED_IMAGE_RESIZE_WIDTHS = [100, 300, 500, 750, 1000, 1500, 2500];
8
+
8
9
  /**
9
10
  * Takes only allowed transformations into consideration, and discards the rest.
10
11
  */
11
-
12
12
  var _default = args => {
13
13
  const transformations = {};
14
14
 
15
- if (args) {
16
- const width = parseInt(args.width);
15
+ if (!args || !args.width) {
16
+ return null;
17
+ }
17
18
 
18
- if (width > 0) {
19
- transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[0];
20
- let i = SUPPORTED_IMAGE_RESIZE_WIDTHS.length;
19
+ const width = parseInt(args.width);
21
20
 
22
- while (i >= 0) {
23
- if (width === SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {
24
- transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];
25
- break;
26
- }
21
+ if (width <= 0) {
22
+ return null;
23
+ }
27
24
 
28
- if (width > SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {
29
- // Use next larger width. If there isn't any, use current.
30
- transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i + 1];
25
+ transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[0];
26
+ let i = SUPPORTED_IMAGE_RESIZE_WIDTHS.length;
31
27
 
32
- if (!transformations.width) {
33
- transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];
34
- }
28
+ while (i >= 0) {
29
+ if (width === SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {
30
+ transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];
31
+ break;
32
+ }
35
33
 
36
- break;
37
- }
34
+ if (width > SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {
35
+ // Use next larger width. If there isn't any, use current.
36
+ transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i + 1];
38
37
 
39
- i--;
38
+ if (!transformations.width) {
39
+ transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];
40
40
  }
41
+
42
+ break;
41
43
  }
44
+
45
+ i--;
42
46
  }
43
47
 
44
48
  if (Object.keys(transformations).length > 0) {
49
+ /**
50
+ * It is safe to cast.
51
+ */
45
52
  return transformations;
46
53
  }
47
54
 
@@ -0,0 +1 @@
1
+ {"version":3,"names":["SUPPORTED_IMAGE_RESIZE_WIDTHS","args","transformations","width","parseInt","i","length","Object","keys"],"sources":["sanitizeImageTransformations.ts"],"sourcesContent":["const SUPPORTED_IMAGE_RESIZE_WIDTHS: number[] = [100, 300, 500, 750, 1000, 1500, 2500];\n\nexport interface SanitizeImageArgs {\n width?: string;\n}\n\nexport interface SanitizeImageTransformations {\n width: number;\n}\n/**\n * Takes only allowed transformations into consideration, and discards the rest.\n */\nexport default (args?: SanitizeImageArgs): SanitizeImageTransformations | null => {\n const transformations: Partial<SanitizeImageTransformations> = {};\n\n if (!args || !args.width) {\n return null;\n }\n const width = parseInt(args.width);\n if (width <= 0) {\n return null;\n }\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[0];\n let i = SUPPORTED_IMAGE_RESIZE_WIDTHS.length;\n while (i >= 0) {\n if (width === SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];\n break;\n }\n\n if (width > SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {\n // Use next larger width. If there isn't any, use current.\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i + 1];\n if (!transformations.width) {\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];\n }\n break;\n }\n\n i--;\n }\n\n if (Object.keys(transformations).length > 0) {\n /**\n * It is safe to cast.\n */\n return transformations as SanitizeImageTransformations;\n }\n\n return null;\n};\n"],"mappings":";;;;;;AAAA,MAAMA,6BAAuC,GAAG,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,EAAgB,GAAhB,EAAqB,IAArB,EAA2B,IAA3B,EAAiC,IAAjC,CAAhD;;AASA;AACA;AACA;eACgBC,IAAD,IAAmE;EAC9E,MAAMC,eAAsD,GAAG,EAA/D;;EAEA,IAAI,CAACD,IAAD,IAAS,CAACA,IAAI,CAACE,KAAnB,EAA0B;IACtB,OAAO,IAAP;EACH;;EACD,MAAMA,KAAK,GAAGC,QAAQ,CAACH,IAAI,CAACE,KAAN,CAAtB;;EACA,IAAIA,KAAK,IAAI,CAAb,EAAgB;IACZ,OAAO,IAAP;EACH;;EACDD,eAAe,CAACC,KAAhB,GAAwBH,6BAA6B,CAAC,CAAD,CAArD;EACA,IAAIK,CAAC,GAAGL,6BAA6B,CAACM,MAAtC;;EACA,OAAOD,CAAC,IAAI,CAAZ,EAAe;IACX,IAAIF,KAAK,KAAKH,6BAA6B,CAACK,CAAD,CAA3C,EAAgD;MAC5CH,eAAe,CAACC,KAAhB,GAAwBH,6BAA6B,CAACK,CAAD,CAArD;MACA;IACH;;IAED,IAAIF,KAAK,GAAGH,6BAA6B,CAACK,CAAD,CAAzC,EAA8C;MAC1C;MACAH,eAAe,CAACC,KAAhB,GAAwBH,6BAA6B,CAACK,CAAC,GAAG,CAAL,CAArD;;MACA,IAAI,CAACH,eAAe,CAACC,KAArB,EAA4B;QACxBD,eAAe,CAACC,KAAhB,GAAwBH,6BAA6B,CAACK,CAAD,CAArD;MACH;;MACD;IACH;;IAEDA,CAAC;EACJ;;EAED,IAAIE,MAAM,CAACC,IAAP,CAAYN,eAAZ,EAA6BI,MAA7B,GAAsC,CAA1C,EAA6C;IACzC;AACR;AACA;IACQ,OAAOJ,eAAP;EACH;;EAED,OAAO,IAAP;AACH,C"}
@@ -1,9 +1,15 @@
1
+ import S3 from "aws-sdk/clients/s3";
2
+ export interface ImageManagerCanProcessParams {
3
+ key: string;
4
+ extension: string;
5
+ }
6
+ export interface ImageManagerProcessParams {
7
+ s3: S3;
8
+ key: string;
9
+ extension: string;
10
+ }
1
11
  declare const _default: {
2
- canProcess: (opts: any) => boolean;
3
- process({ s3, key, extension }: {
4
- s3: any;
5
- key: any;
6
- extension: any;
7
- }): Promise<void>;
12
+ canProcess: (params: ImageManagerCanProcessParams) => boolean;
13
+ process({ s3, key, extension }: ImageManagerProcessParams): Promise<void>;
8
14
  };
9
15
  export default _default;
@@ -10,21 +10,20 @@ var _utils = require("../../utils");
10
10
  var _utils2 = require("../utils");
11
11
 
12
12
  var _default = {
13
- canProcess: opts => {
13
+ canProcess: params => {
14
14
  const {
15
15
  key,
16
16
  extension
17
- } = opts;
17
+ } = params;
18
18
 
19
- if (!_utils2.SUPPORTED_IMAGES.includes(extension)) {
19
+ if (_utils2.SUPPORTED_IMAGES.includes(extension) === false) {
20
20
  return false;
21
- }
21
+ } // We only want to process original images, and delete all variations of it at once.
22
+ // We DO NOT want to process the event for the deletion of an optimized/transformed image.
23
+ // Unfortunately, there's no way to filter those events on the S3 bucket itself, so we have to do it this way.
22
24
 
23
- if (key.startsWith(_utils2.OPTIMIZED_IMAGE_PREFIX || key.startsWith(_utils2.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX))) {
24
- return false;
25
- }
26
25
 
27
- return true;
26
+ return !(key.startsWith(_utils2.OPTIMIZED_IMAGE_PREFIX) || key.startsWith(_utils2.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX));
28
27
  },
29
28
 
30
29
  async process({
@@ -37,17 +36,26 @@ var _default = {
37
36
  key
38
37
  }))).promise(); // 2. Search for all transformed images and delete those too.
39
38
 
40
- if (_utils2.SUPPORTED_TRANSFORMABLE_IMAGES.includes(extension)) {
41
- const env = (0, _utils.getEnvironment)();
42
- const imagesList = await s3.listObjects({
43
- Bucket: env.bucket,
44
- Prefix: (0, _utils2.getOptimizedTransformedImageKeyPrefix)(key)
45
- }).promise();
39
+ if (_utils2.SUPPORTED_TRANSFORMABLE_IMAGES.includes(extension) === false) {
40
+ return;
41
+ }
42
+
43
+ const env = (0, _utils.getEnvironment)();
44
+ const imagesList = await s3.listObjects({
45
+ Bucket: env.bucket,
46
+ Prefix: (0, _utils2.getOptimizedTransformedImageKeyPrefix)(key)
47
+ }).promise();
48
+
49
+ if (!imagesList.Contents) {
50
+ return;
51
+ }
46
52
 
47
- for (let i = 0; i < imagesList.Contents.length; i++) {
48
- const imageObject = imagesList.Contents[i];
49
- await s3.deleteObject((0, _utils.getObjectParams)(imageObject.Key)).promise();
53
+ for (const imageObject of imagesList.Contents) {
54
+ if (!imageObject.Key) {
55
+ continue;
50
56
  }
57
+
58
+ await s3.deleteObject((0, _utils.getObjectParams)(imageObject.Key)).promise();
51
59
  }
52
60
  }
53
61
 
@@ -0,0 +1 @@
1
+ {"version":3,"names":["canProcess","params","key","extension","SUPPORTED_IMAGES","includes","startsWith","OPTIMIZED_IMAGE_PREFIX","OPTIMIZED_TRANSFORMED_IMAGE_PREFIX","process","s3","deleteObject","getObjectParams","getImageKey","promise","SUPPORTED_TRANSFORMABLE_IMAGES","env","getEnvironment","imagesList","listObjects","Bucket","bucket","Prefix","getOptimizedTransformedImageKeyPrefix","Contents","imageObject","Key"],"sources":["imageManager.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport { getObjectParams, getEnvironment } from \"~/handlers/utils\";\nimport {\n SUPPORTED_IMAGES,\n SUPPORTED_TRANSFORMABLE_IMAGES,\n OPTIMIZED_IMAGE_PREFIX,\n OPTIMIZED_TRANSFORMED_IMAGE_PREFIX,\n getImageKey,\n getOptimizedTransformedImageKeyPrefix\n} from \"../utils\";\n\nexport interface ImageManagerCanProcessParams {\n key: string;\n extension: string;\n}\nexport interface ImageManagerProcessParams {\n s3: S3;\n key: string;\n extension: string;\n}\nexport default {\n canProcess: (params: ImageManagerCanProcessParams) => {\n const { key, extension } = params;\n if (SUPPORTED_IMAGES.includes(extension) === false) {\n return false;\n }\n\n // We only want to process original images, and delete all variations of it at once.\n // We DO NOT want to process the event for the deletion of an optimized/transformed image.\n // Unfortunately, there's no way to filter those events on the S3 bucket itself, so we have to do it this way.\n return !(\n key.startsWith(OPTIMIZED_IMAGE_PREFIX) ||\n key.startsWith(OPTIMIZED_TRANSFORMED_IMAGE_PREFIX)\n );\n },\n async process({ s3, key, extension }: ImageManagerProcessParams) {\n // 1. Get optimized image's key.\n\n await s3.deleteObject(getObjectParams(getImageKey({ key }))).promise();\n\n // 2. Search for all transformed images and delete those too.\n if (SUPPORTED_TRANSFORMABLE_IMAGES.includes(extension) === false) {\n return;\n }\n const env = getEnvironment();\n const imagesList = await s3\n .listObjects({\n Bucket: env.bucket,\n Prefix: getOptimizedTransformedImageKeyPrefix(key)\n })\n .promise();\n\n if (!imagesList.Contents) {\n return;\n }\n\n for (const imageObject of imagesList.Contents) {\n if (!imageObject.Key) {\n continue;\n }\n await s3.deleteObject(getObjectParams(imageObject.Key)).promise();\n }\n }\n};\n"],"mappings":";;;;;;;AACA;;AACA;;eAkBe;EACXA,UAAU,EAAGC,MAAD,IAA0C;IAClD,MAAM;MAAEC,GAAF;MAAOC;IAAP,IAAqBF,MAA3B;;IACA,IAAIG,wBAAA,CAAiBC,QAAjB,CAA0BF,SAA1B,MAAyC,KAA7C,EAAoD;MAChD,OAAO,KAAP;IACH,CAJiD,CAMlD;IACA;IACA;;;IACA,OAAO,EACHD,GAAG,CAACI,UAAJ,CAAeC,8BAAf,KACAL,GAAG,CAACI,UAAJ,CAAeE,0CAAf,CAFG,CAAP;EAIH,CAdU;;EAeX,MAAMC,OAAN,CAAc;IAAEC,EAAF;IAAMR,GAAN;IAAWC;EAAX,CAAd,EAAiE;IAC7D;IAEA,MAAMO,EAAE,CAACC,YAAH,CAAgB,IAAAC,sBAAA,EAAgB,IAAAC,mBAAA,EAAY;MAAEX;IAAF,CAAZ,CAAhB,CAAhB,EAAuDY,OAAvD,EAAN,CAH6D,CAK7D;;IACA,IAAIC,sCAAA,CAA+BV,QAA/B,CAAwCF,SAAxC,MAAuD,KAA3D,EAAkE;MAC9D;IACH;;IACD,MAAMa,GAAG,GAAG,IAAAC,qBAAA,GAAZ;IACA,MAAMC,UAAU,GAAG,MAAMR,EAAE,CACtBS,WADoB,CACR;MACTC,MAAM,EAAEJ,GAAG,CAACK,MADH;MAETC,MAAM,EAAE,IAAAC,6CAAA,EAAsCrB,GAAtC;IAFC,CADQ,EAKpBY,OALoB,EAAzB;;IAOA,IAAI,CAACI,UAAU,CAACM,QAAhB,EAA0B;MACtB;IACH;;IAED,KAAK,MAAMC,WAAX,IAA0BP,UAAU,CAACM,QAArC,EAA+C;MAC3C,IAAI,CAACC,WAAW,CAACC,GAAjB,EAAsB;QAClB;MACH;;MACD,MAAMhB,EAAE,CAACC,YAAH,CAAgB,IAAAC,sBAAA,EAAgBa,WAAW,CAACC,GAA5B,CAAhB,EAAkDZ,OAAlD,EAAN;IACH;EACJ;;AA1CU,C"}
@@ -1,9 +1,5 @@
1
1
  declare const _default: {
2
- canProcess: (opts: any) => boolean;
3
- process({ s3, key, extension }: {
4
- s3: any;
5
- key: any;
6
- extension: any;
7
- }): Promise<void>;
2
+ canProcess: (params: import("./imageManager").ImageManagerCanProcessParams) => boolean;
3
+ process({ s3, key, extension }: import("./imageManager").ImageManagerProcessParams): Promise<void>;
8
4
  }[];
9
5
  export default _default;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["imageManager"],"sources":["index.ts"],"sourcesContent":["import imageManager from \"./imageManager\";\n\nexport default [imageManager];\n"],"mappings":";;;;;;;;;AAAA;;eAEe,CAACA,qBAAD,C"}
@@ -1,2 +1,3 @@
1
- declare const _default: (buffer: any, type: any) => Promise<any>;
1
+ import { Body } from "aws-sdk/clients/s3";
2
+ declare const _default: (buffer: Body, type: string) => Promise<Body>;
2
3
  export default _default;
@@ -9,6 +9,9 @@ exports.default = void 0;
9
9
 
10
10
  var _sharp = _interopRequireDefault(require("sharp"));
11
11
 
12
+ /**
13
+ * Sharp is included in the AWS Lambda layer
14
+ */
12
15
  // @ts-ignore
13
16
  var _default = async (buffer, type) => {
14
17
  switch (type) {
@@ -0,0 +1 @@
1
+ {"version":3,"names":["buffer","type","sharp","resize","width","withoutEnlargement","fit","png","compressionLevel","adaptiveFiltering","force","withMetadata","toBuffer","toFormat","quality"],"sources":["optimizeImage.ts"],"sourcesContent":["/**\n * Sharp is included in the AWS Lambda layer\n */\n// @ts-ignore\nimport sharp from \"sharp\";\nimport { Body } from \"aws-sdk/clients/s3\";\n\nexport default async (buffer: Body, type: string): Promise<Body> => {\n switch (type) {\n case \"image/png\": {\n return await sharp(buffer)\n .resize({ width: 2560, withoutEnlargement: true, fit: \"inside\" })\n .png({ compressionLevel: 9, adaptiveFiltering: true, force: true })\n .withMetadata()\n .toBuffer();\n }\n case \"image/jpeg\":\n case \"image/jpg\": {\n return await sharp(buffer)\n .resize({ width: 2560, withoutEnlargement: true, fit: \"inside\" })\n .toFormat(\"jpeg\", { quality: 90 })\n .toBuffer();\n }\n default:\n return buffer;\n }\n};\n"],"mappings":";;;;;;;;;AAIA;;AAJA;AACA;AACA;AACA;eAIe,OAAOA,MAAP,EAAqBC,IAArB,KAAqD;EAChE,QAAQA,IAAR;IACI,KAAK,WAAL;MAAkB;QACd,OAAO,MAAM,IAAAC,cAAA,EAAMF,MAAN,EACRG,MADQ,CACD;UAAEC,KAAK,EAAE,IAAT;UAAeC,kBAAkB,EAAE,IAAnC;UAAyCC,GAAG,EAAE;QAA9C,CADC,EAERC,GAFQ,CAEJ;UAAEC,gBAAgB,EAAE,CAApB;UAAuBC,iBAAiB,EAAE,IAA1C;UAAgDC,KAAK,EAAE;QAAvD,CAFI,EAGRC,YAHQ,GAIRC,QAJQ,EAAb;MAKH;;IACD,KAAK,YAAL;IACA,KAAK,WAAL;MAAkB;QACd,OAAO,MAAM,IAAAV,cAAA,EAAMF,MAAN,EACRG,MADQ,CACD;UAAEC,KAAK,EAAE,IAAT;UAAeC,kBAAkB,EAAE,IAAnC;UAAyCC,GAAG,EAAE;QAA9C,CADC,EAERO,QAFQ,CAEC,MAFD,EAES;UAAEC,OAAO,EAAE;QAAX,CAFT,EAGRF,QAHQ,EAAb;MAIH;;IACD;MACI,OAAOZ,MAAP;EAhBR;AAkBH,C"}
@@ -1,9 +1,10 @@
1
- declare const _default: (buffer: any, transformations: any) => Promise<any>;
1
+ import { Body } from "aws-sdk/clients/s3";
2
+ interface Transformation {
3
+ width: string;
4
+ }
2
5
  /**
3
6
  * Only processing "width" at the moment.
4
7
  * Check "sanitizeImageTransformations.js" to allow additional image processing transformations.
5
- * @param buffer
6
- * @param transformations
7
- * @returns {Promise<Buffer>}
8
8
  */
9
+ declare const _default: (buffer: Body, transformations: Transformation) => Promise<Body>;
9
10
  export default _default;
@@ -9,14 +9,14 @@ exports.default = void 0;
9
9
 
10
10
  var _sharp = _interopRequireDefault(require("sharp"));
11
11
 
12
+ /**
13
+ * Sharp is included in the AWS Lambda layer
14
+ */
12
15
  // @ts-ignore
13
16
 
14
17
  /**
15
18
  * Only processing "width" at the moment.
16
19
  * Check "sanitizeImageTransformations.js" to allow additional image processing transformations.
17
- * @param buffer
18
- * @param transformations
19
- * @returns {Promise<Buffer>}
20
20
  */
21
21
  var _default = async (buffer, transformations) => {
22
22
  const {
@@ -0,0 +1 @@
1
+ {"version":3,"names":["buffer","transformations","width","sharp","resize","toBuffer"],"sources":["transformImage.ts"],"sourcesContent":["/**\n * Sharp is included in the AWS Lambda layer\n */\n// @ts-ignore\nimport sharp from \"sharp\";\nimport { Body } from \"aws-sdk/clients/s3\";\n\ninterface Transformation {\n width: string;\n}\n/**\n * Only processing \"width\" at the moment.\n * Check \"sanitizeImageTransformations.js\" to allow additional image processing transformations.\n */\nexport default async (buffer: Body, transformations: Transformation): Promise<Body> => {\n const { width } = transformations;\n return await sharp(buffer).resize({ width }).toBuffer();\n};\n"],"mappings":";;;;;;;;;AAIA;;AAJA;AACA;AACA;AACA;;AAOA;AACA;AACA;AACA;eACe,OAAOA,MAAP,EAAqBC,eAArB,KAAwE;EACnF,MAAM;IAAEC;EAAF,IAAYD,eAAlB;EACA,OAAO,MAAM,IAAAE,cAAA,EAAMH,MAAN,EAAcI,MAAd,CAAqB;IAAEF;EAAF,CAArB,EAAgCG,QAAhC,EAAb;AACH,C"}
@@ -2,8 +2,8 @@ declare const SUPPORTED_IMAGES: string[];
2
2
  declare const SUPPORTED_TRANSFORMABLE_IMAGES: string[];
3
3
  declare const OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = "img-o-t-";
4
4
  declare const OPTIMIZED_IMAGE_PREFIX = "img-o-";
5
- declare const getOptimizedImageKeyPrefix: (key: any) => string;
6
- declare const getOptimizedTransformedImageKeyPrefix: (key: any) => string;
5
+ declare const getOptimizedImageKeyPrefix: (key: string) => string;
6
+ declare const getOptimizedTransformedImageKeyPrefix: (key: string) => string;
7
7
  interface GetImageKeyParams {
8
8
  key: string;
9
9
  transformations?: any;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["SUPPORTED_IMAGES","SUPPORTED_TRANSFORMABLE_IMAGES","OPTIMIZED_TRANSFORMED_IMAGE_PREFIX","OPTIMIZED_IMAGE_PREFIX","getOptimizedImageKeyPrefix","key","objectHash","getOptimizedTransformedImageKeyPrefix","getImageKey","transformations","prefix"],"sources":["utils.ts"],"sourcesContent":["import objectHash from \"object-hash\";\n\nconst SUPPORTED_IMAGES = [\".jpg\", \".jpeg\", \".png\", \".svg\", \".gif\"];\nconst SUPPORTED_TRANSFORMABLE_IMAGES = [\".jpg\", \".jpeg\", \".png\"];\n\nconst OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = \"img-o-t-\";\nconst OPTIMIZED_IMAGE_PREFIX = \"img-o-\";\n\nconst getOptimizedImageKeyPrefix = (key: string): string => {\n return `${OPTIMIZED_IMAGE_PREFIX}${objectHash(key)}-`;\n};\n\nconst getOptimizedTransformedImageKeyPrefix = (key: string): string => {\n return `${OPTIMIZED_TRANSFORMED_IMAGE_PREFIX}${objectHash(key)}-`;\n};\n\ninterface GetImageKeyParams {\n key: string;\n transformations?: any;\n}\n\nconst getImageKey = ({ key, transformations }: GetImageKeyParams): string => {\n if (!transformations) {\n const prefix = getOptimizedImageKeyPrefix(key);\n return prefix + key;\n }\n\n const prefix = getOptimizedTransformedImageKeyPrefix(key);\n return `${prefix}${objectHash(transformations)}-${key}`;\n};\n\nexport {\n SUPPORTED_IMAGES,\n SUPPORTED_TRANSFORMABLE_IMAGES,\n OPTIMIZED_TRANSFORMED_IMAGE_PREFIX,\n OPTIMIZED_IMAGE_PREFIX,\n getImageKey,\n getOptimizedImageKeyPrefix,\n getOptimizedTransformedImageKeyPrefix\n};\n"],"mappings":";;;;;;;;;AAAA;;AAEA,MAAMA,gBAAgB,GAAG,CAAC,MAAD,EAAS,OAAT,EAAkB,MAAlB,EAA0B,MAA1B,EAAkC,MAAlC,CAAzB;;AACA,MAAMC,8BAA8B,GAAG,CAAC,MAAD,EAAS,OAAT,EAAkB,MAAlB,CAAvC;;AAEA,MAAMC,kCAAkC,GAAG,UAA3C;;AACA,MAAMC,sBAAsB,GAAG,QAA/B;;;AAEA,MAAMC,0BAA0B,GAAIC,GAAD,IAAyB;EACxD,OAAQ,GAAEF,sBAAuB,GAAE,IAAAG,mBAAA,EAAWD,GAAX,CAAgB,GAAnD;AACH,CAFD;;;;AAIA,MAAME,qCAAqC,GAAIF,GAAD,IAAyB;EACnE,OAAQ,GAAEH,kCAAmC,GAAE,IAAAI,mBAAA,EAAWD,GAAX,CAAgB,GAA/D;AACH,CAFD;;;;AASA,MAAMG,WAAW,GAAG,CAAC;EAAEH,GAAF;EAAOI;AAAP,CAAD,KAAyD;EACzE,IAAI,CAACA,eAAL,EAAsB;IAClB,MAAMC,MAAM,GAAGN,0BAA0B,CAACC,GAAD,CAAzC;IACA,OAAOK,MAAM,GAAGL,GAAhB;EACH;;EAED,MAAMK,MAAM,GAAGH,qCAAqC,CAACF,GAAD,CAApD;EACA,OAAQ,GAAEK,MAAO,GAAE,IAAAJ,mBAAA,EAAWG,eAAX,CAA4B,IAAGJ,GAAI,EAAtD;AACH,CARD"}
@@ -0,0 +1,8 @@
1
+ export interface TransformHandlerEventPayload {
2
+ body: {
3
+ key: string;
4
+ transformations: {
5
+ width: string;
6
+ };
7
+ };
8
+ }
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["export interface TransformHandlerEventPayload {\n body: {\n key: string;\n transformations: {\n width: string;\n };\n };\n}\n"],"mappings":""}
@@ -0,0 +1 @@
1
+ {"version":3,"names":["bucket","process","env","S3_BUCKET","region","AWS_REGION"],"sources":["getEnvironment.ts"],"sourcesContent":["export default () => ({\n bucket: process.env.S3_BUCKET as string,\n region: process.env.AWS_REGION as string\n});\n"],"mappings":";;;;;;;eAAe,OAAO;EAClBA,MAAM,EAAEC,OAAO,CAACC,GAAR,CAAYC,SADF;EAElBC,MAAM,EAAEH,OAAO,CAACC,GAAR,CAAYG;AAFF,CAAP,C"}
@@ -1,10 +1,9 @@
1
- declare const _default: (filename: any) => {
1
+ export interface ObjectParamsResponse {
2
2
  Bucket: string;
3
3
  Key: string;
4
- };
4
+ }
5
5
  /**
6
6
  * Returns website's Bucket and file's Key values.
7
- * @param filename
8
- * @returns {{Bucket: string, Key: string}}
9
7
  */
8
+ declare const _default: (filename: string) => ObjectParamsResponse;
10
9
  export default _default;
@@ -11,8 +11,6 @@ var _getEnvironment = _interopRequireDefault(require("./getEnvironment"));
11
11
 
12
12
  /**
13
13
  * Returns website's Bucket and file's Key values.
14
- * @param filename
15
- * @returns {{Bucket: string, Key: string}}
16
14
  */
17
15
  var _default = filename => {
18
16
  const {
@@ -0,0 +1 @@
1
+ {"version":3,"names":["filename","bucket","Bucket","getEnvironment","Key"],"sources":["getObjectParams.ts"],"sourcesContent":["import getEnvironment from \"./getEnvironment\";\n\nexport interface ObjectParamsResponse {\n Bucket: string;\n Key: string;\n}\n/**\n * Returns website's Bucket and file's Key values.\n */\nexport default (filename: string): ObjectParamsResponse => {\n const { bucket: Bucket } = getEnvironment();\n\n return {\n Bucket,\n Key: `${filename}`\n };\n};\n"],"mappings":";;;;;;;;;AAAA;;AAMA;AACA;AACA;eACgBA,QAAD,IAA4C;EACvD,MAAM;IAAEC,MAAM,EAAEC;EAAV,IAAqB,IAAAC,uBAAA,GAA3B;EAEA,OAAO;IACHD,MADG;IAEHE,GAAG,EAAG,GAAEJ,QAAS;EAFd,CAAP;AAIH,C"}
@@ -1,3 +1,2 @@
1
1
  export { default as getEnvironment } from "./getEnvironment";
2
- export { default as createHandler } from "./createHandler";
3
2
  export { default as getObjectParams } from "./getObjectParams";
@@ -5,12 +5,6 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- Object.defineProperty(exports, "createHandler", {
9
- enumerable: true,
10
- get: function () {
11
- return _createHandler.default;
12
- }
13
- });
14
8
  Object.defineProperty(exports, "getEnvironment", {
15
9
  enumerable: true,
16
10
  get: function () {
@@ -26,6 +20,4 @@ Object.defineProperty(exports, "getObjectParams", {
26
20
 
27
21
  var _getEnvironment = _interopRequireDefault(require("./getEnvironment"));
28
22
 
29
- var _createHandler = _interopRequireDefault(require("./createHandler"));
30
-
31
23
  var _getObjectParams = _interopRequireDefault(require("./getObjectParams"));
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { default as getEnvironment } from \"./getEnvironment\";\nexport { default as getObjectParams } from \"./getObjectParams\";\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;;AACA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webiny/api-file-manager",
3
- "version": "0.0.0-mt-3",
3
+ "version": "0.0.0-unstable.8c4d9f045a",
4
4
  "main": "index.js",
5
5
  "keywords": [
6
6
  "fm:base"
@@ -18,39 +18,40 @@
18
18
  ],
19
19
  "license": "MIT",
20
20
  "dependencies": {
21
- "@babel/runtime": "7.15.4",
21
+ "@babel/runtime": "7.18.9",
22
22
  "@commodo/fields": "1.1.2-beta.20",
23
- "@webiny/api-i18n-content": "0.0.0-mt-3",
24
- "@webiny/api-security": "0.0.0-mt-3",
25
- "@webiny/api-tenancy": "0.0.0-mt-3",
26
- "@webiny/api-upgrade": "0.0.0-mt-3",
27
- "@webiny/error": "0.0.0-mt-3",
28
- "@webiny/handler": "0.0.0-mt-3",
29
- "@webiny/handler-client": "0.0.0-mt-3",
30
- "@webiny/handler-graphql": "0.0.0-mt-3",
31
- "@webiny/plugins": "0.0.0-mt-3",
32
- "@webiny/project-utils": "0.0.0-mt-3",
33
- "@webiny/validation": "0.0.0-mt-3",
34
- "aws-sdk": "2.1026.0",
23
+ "@webiny/api": "0.0.0-unstable.8c4d9f045a",
24
+ "@webiny/api-security": "0.0.0-unstable.8c4d9f045a",
25
+ "@webiny/api-tenancy": "0.0.0-unstable.8c4d9f045a",
26
+ "@webiny/api-upgrade": "0.0.0-unstable.8c4d9f045a",
27
+ "@webiny/error": "0.0.0-unstable.8c4d9f045a",
28
+ "@webiny/handler": "0.0.0-unstable.8c4d9f045a",
29
+ "@webiny/handler-aws": "0.0.0-unstable.8c4d9f045a",
30
+ "@webiny/handler-client": "0.0.0-unstable.8c4d9f045a",
31
+ "@webiny/handler-graphql": "0.0.0-unstable.8c4d9f045a",
32
+ "@webiny/plugins": "0.0.0-unstable.8c4d9f045a",
33
+ "@webiny/project-utils": "0.0.0-unstable.8c4d9f045a",
34
+ "@webiny/validation": "0.0.0-unstable.8c4d9f045a",
35
+ "aws-sdk": "2.1188.0",
35
36
  "commodo-fields-object": "1.0.6",
36
37
  "mdbid": "1.0.0",
37
- "object-hash": "1.3.1",
38
+ "object-hash": "2.2.0",
38
39
  "sanitize-filename": "1.6.3"
39
40
  },
40
41
  "devDependencies": {
41
- "@babel/cli": "^7.5.5",
42
- "@babel/core": "^7.5.5",
43
- "@babel/plugin-proposal-object-rest-spread": "^7.5.5",
44
- "@babel/plugin-transform-runtime": "^7.5.5",
45
- "@babel/preset-env": "^7.5.5",
46
- "@babel/preset-typescript": "^7.0.0",
47
- "@webiny/api-i18n": "^0.0.0-mt-3",
48
- "@webiny/api-i18n-ddb": "^0.0.0-mt-3",
49
- "@webiny/cli": "^0.0.0-mt-3",
50
- "jest": "^26.6.3",
42
+ "@babel/cli": "^7.16.0",
43
+ "@babel/core": "^7.16.0",
44
+ "@babel/plugin-proposal-object-rest-spread": "^7.16.0",
45
+ "@babel/plugin-transform-runtime": "^7.16.4",
46
+ "@babel/preset-env": "^7.16.4",
47
+ "@babel/preset-typescript": "^7.16.0",
48
+ "@webiny/api-i18n": "^0.0.0-unstable.8c4d9f045a",
49
+ "@webiny/api-i18n-ddb": "^0.0.0-unstable.8c4d9f045a",
50
+ "@webiny/cli": "^0.0.0-unstable.8c4d9f045a",
51
+ "jest": "^28.1.0",
51
52
  "rimraf": "^3.0.2",
52
53
  "ttypescript": "^1.5.12",
53
- "typescript": "^4.1.3"
54
+ "typescript": "4.7.4"
54
55
  },
55
56
  "publishConfig": {
56
57
  "access": "public",
@@ -71,5 +72,5 @@
71
72
  ]
72
73
  }
73
74
  },
74
- "gitHead": "ebea815be2be99404591cba465cc1fe88355bd48"
75
+ "gitHead": "5f904a53a5956269bd80a9c084cc04f92b824d36"
75
76
  }
@@ -0,0 +1 @@
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 +1,4 @@
1
1
  import { FileManagerContext } from "../../types";
2
- import { ContextPlugin } from "@webiny/handler/plugins/ContextPlugin";
2
+ import { ContextPlugin } from "@webiny/api";
3
3
  declare const filesContextCrudPlugin: ContextPlugin<FileManagerContext>;
4
4
  export default filesContextCrudPlugin;
@@ -15,21 +15,21 @@ var _handlerGraphql = require("@webiny/handler-graphql");
15
15
 
16
16
  var _apiSecurity = require("@webiny/api-security");
17
17
 
18
- var _error = _interopRequireDefault(require("@webiny/error"));
19
-
20
18
  var _checkBasePermissions = _interopRequireDefault(require("./utils/checkBasePermissions"));
21
19
 
22
- var _ContextPlugin = require("@webiny/handler/plugins/ContextPlugin");
20
+ var _api = require("@webiny/api");
23
21
 
24
22
  var _FilePlugin = require("../definitions/FilePlugin");
25
23
 
26
24
  var _FilesStorageOperationsProviderPlugin = require("../definitions/FilesStorageOperationsProviderPlugin");
27
25
 
26
+ var _error = _interopRequireDefault(require("@webiny/error"));
27
+
28
28
  var _lifecycleEvents = require("./utils/lifecycleEvents");
29
29
 
30
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
30
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
31
31
 
32
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
32
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
33
33
 
34
34
  const BATCH_CREATE_MAX_FILES = 20;
35
35
  /**
@@ -47,18 +47,24 @@ const checkOwnership = (file, permission, context) => {
47
47
  };
48
48
 
49
49
  const getLocaleCode = context => {
50
- if (!context.i18nContent) {
51
- throw new _error.default("Missing i18nContent on the FileManagerContext.", "MISSING_I18N_CONTENT");
52
- } else if (!context.i18nContent.locale) {
53
- throw new _error.default("Missing i18nContent.locale on the FileManagerContext.", "MISSING_I18N_CONTENT_LOCALE");
54
- } else if (!context.i18nContent.locale.code) {
55
- throw new _error.default("Missing i18nContent.locale.code on the FileManagerContext.", "MISSING_I18N_CONTENT_LOCALE_CODE");
50
+ if (!context.i18n) {
51
+ throw new _error.default("Missing i18n on the FileManagerContext.", "MISSING_I18N");
56
52
  }
57
53
 
58
- return context.i18nContent.locale.code;
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;
59
65
  };
60
66
 
61
- const filesContextCrudPlugin = new _ContextPlugin.ContextPlugin(async context => {
67
+ const filesContextCrudPlugin = new _api.ContextPlugin(async context => {
62
68
  const pluginType = _FilesStorageOperationsProviderPlugin.FilesStorageOperationsProviderPlugin.type;
63
69
  const providerPlugin = context.plugins.byType(pluginType).find(() => true);
64
70
 
@@ -107,6 +113,7 @@ const filesContextCrudPlugin = new _ContextPlugin.ContextPlugin(async context =>
107
113
  const id = (0, _mdbid.default)();
108
114
 
109
115
  const file = _objectSpread(_objectSpread({}, input), {}, {
116
+ tags: Array.isArray(input.tags) ? input.tags : [],
110
117
  id,
111
118
  meta: _objectSpread({
112
119
  private: false
@@ -164,6 +171,7 @@ const filesContextCrudPlugin = new _ContextPlugin.ContextPlugin(async context =>
164
171
  checkOwnership(original, permission, context);
165
172
 
166
173
  const file = _objectSpread(_objectSpread(_objectSpread({}, original), input), {}, {
174
+ tags: Array.isArray(input.tags) ? input.tags : Array.isArray(original.tags) ? original.tags : [],
167
175
  id: original.id,
168
176
  webinyVersion: context.WEBINY_VERSION
169
177
  });
@@ -262,6 +270,7 @@ const filesContextCrudPlugin = new _ContextPlugin.ContextPlugin(async context =>
262
270
  };
263
271
  const files = inputs.map(input => {
264
272
  return _objectSpread(_objectSpread({}, input), {}, {
273
+ tags: Array.isArray(input.tags) ? input.tags : [],
265
274
  meta: _objectSpread({
266
275
  private: false
267
276
  }, input.meta || {}),
@@ -314,7 +323,7 @@ const filesContextCrudPlugin = new _ContextPlugin.ContextPlugin(async context =>
314
323
 
315
324
  const where = _objectSpread(_objectSpread({}, initialWhere), {}, {
316
325
  private: false,
317
- locale: context.i18nContent.getLocale().code,
326
+ locale: getLocaleCode(context),
318
327
  tenant: context.tenancy.getCurrentTenant().id
319
328
  });
320
329
  /**
@@ -385,17 +394,17 @@ const filesContextCrudPlugin = new _ContextPlugin.ContextPlugin(async context =>
385
394
  },
386
395
 
387
396
  async listTags({
397
+ where: initialWhere,
388
398
  after,
389
399
  limit
390
400
  }) {
391
401
  await (0, _checkBasePermissions.default)(context);
392
- const {
393
- i18nContent
394
- } = context;
395
- const where = {
402
+
403
+ const where = _objectSpread(_objectSpread({}, initialWhere), {}, {
396
404
  tenant: context.tenancy.getCurrentTenant().id,
397
- locale: i18nContent.locale.code
398
- };
405
+ locale: getLocaleCode(context)
406
+ });
407
+
399
408
  const params = {
400
409
  where,
401
410
  limit: limit || 100000,
@@ -403,15 +412,16 @@ const filesContextCrudPlugin = new _ContextPlugin.ContextPlugin(async context =>
403
412
  };
404
413
 
405
414
  try {
406
- /**
407
- * There is a meta object on the second key.
408
- * TODO: use when changing GraphQL output of the tags.
409
- */
410
415
  const [tags] = await storageOperations.tags(params);
416
+
417
+ if (Array.isArray(tags) === false) {
418
+ return [];
419
+ }
411
420
  /**
412
421
  * just to keep it standardized, sort by the tag ASC
413
422
  */
414
423
 
424
+
415
425
  return tags.sort();
416
426
  } catch (ex) {
417
427
  throw new _error.default(ex.message || "Could not search for tags.", ex.code || "FILE_TAG_SEARCH_ERROR", _objectSpread(_objectSpread({}, ex.data || {}), {}, {