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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. package/createFileManager/checkBasePermissions.d.ts +5 -0
  2. package/createFileManager/checkBasePermissions.js +24 -0
  3. package/createFileManager/checkBasePermissions.js.map +1 -0
  4. package/createFileManager/files.crud.d.ts +3 -0
  5. package/createFileManager/files.crud.js +318 -0
  6. package/createFileManager/files.crud.js.map +1 -0
  7. package/createFileManager/filevalidation.disabled.d.ts +0 -0
  8. package/createFileManager/filevalidation.disabled.js +55 -0
  9. package/createFileManager/filevalidation.disabled.js.map +1 -0
  10. package/createFileManager/index.d.ts +13 -0
  11. package/createFileManager/index.js +20 -0
  12. package/createFileManager/index.js.map +1 -0
  13. package/createFileManager/settings.crud.d.ts +3 -0
  14. package/createFileManager/settings.crud.js +91 -0
  15. package/createFileManager/settings.crud.js.map +1 -0
  16. package/createFileManager/system.crud.d.ts +3 -0
  17. package/createFileManager/system.crud.js +86 -0
  18. package/createFileManager/system.crud.js.map +1 -0
  19. package/graphql/index.d.ts +3 -0
  20. package/graphql/index.js +288 -0
  21. package/graphql/index.js.map +1 -0
  22. package/handlers/download/byAlias.d.ts +6 -0
  23. package/handlers/download/byAlias.js +89 -0
  24. package/handlers/download/byAlias.js.map +1 -0
  25. package/handlers/download/byExactKey.d.ts +2 -0
  26. package/handlers/download/byExactKey.js +57 -0
  27. package/handlers/download/byExactKey.js.map +1 -0
  28. package/handlers/download/extractFileInformation.d.ts +9 -0
  29. package/handlers/download/extractFileInformation.js +20 -0
  30. package/handlers/download/extractFileInformation.js.map +1 -0
  31. package/handlers/download/getS3Object.d.ts +10 -0
  32. package/handlers/download/getS3Object.js +57 -0
  33. package/handlers/download/getS3Object.js.map +1 -0
  34. package/handlers/download/index.d.ts +2 -3
  35. package/handlers/download/index.js +21 -126
  36. package/handlers/download/index.js.map +1 -1
  37. package/handlers/manage/index.js +0 -16
  38. package/handlers/manage/index.js.map +1 -1
  39. package/handlers/transform/index.js +12 -19
  40. package/handlers/transform/index.js.map +1 -1
  41. package/handlers/transform/legacyUtils.d.ts +17 -0
  42. package/handlers/transform/legacyUtils.js +42 -0
  43. package/handlers/transform/legacyUtils.js.map +1 -0
  44. package/handlers/transform/loaders/imageLoader.d.ts +1 -1
  45. package/handlers/transform/loaders/imageLoader.js +12 -23
  46. package/handlers/transform/loaders/imageLoader.js.map +1 -1
  47. package/handlers/transform/loaders/index.d.ts +1 -1
  48. package/handlers/transform/loaders/index.js +0 -3
  49. package/handlers/transform/loaders/index.js.map +1 -1
  50. package/handlers/transform/loaders/sanitizeImageTransformations.js +0 -13
  51. package/handlers/transform/loaders/sanitizeImageTransformations.js.map +1 -1
  52. package/handlers/transform/managers/imageManager.js +32 -21
  53. package/handlers/transform/managers/imageManager.js.map +1 -1
  54. package/handlers/transform/managers/index.js +0 -3
  55. package/handlers/transform/managers/index.js.map +1 -1
  56. package/handlers/transform/optimizeImage.js +0 -6
  57. package/handlers/transform/optimizeImage.js.map +1 -1
  58. package/handlers/transform/transformImage.js +0 -5
  59. package/handlers/transform/transformImage.js.map +1 -1
  60. package/handlers/transform/utils.d.ts +1 -1
  61. package/handlers/transform/utils.js +7 -17
  62. package/handlers/transform/utils.js.map +1 -1
  63. package/handlers/utils/getEnvironment.js +0 -2
  64. package/handlers/utils/getEnvironment.js.map +1 -1
  65. package/handlers/utils/getObjectParams.js +0 -4
  66. package/handlers/utils/getObjectParams.js.map +1 -1
  67. package/handlers/utils/index.js +0 -3
  68. package/handlers/utils/index.js.map +1 -1
  69. package/index.d.ts +6 -0
  70. package/index.js +68 -0
  71. package/index.js.map +1 -0
  72. package/package.json +21 -23
  73. package/plugins/FilePhysicalStoragePlugin.d.ts +21 -0
  74. package/plugins/FilePhysicalStoragePlugin.js +31 -0
  75. package/plugins/FilePhysicalStoragePlugin.js.map +1 -0
  76. package/plugins/FileStorageTransformPlugin.d.ts +34 -0
  77. package/plugins/FileStorageTransformPlugin.js +40 -0
  78. package/plugins/FileStorageTransformPlugin.js.map +1 -0
  79. package/plugins/graphql.js +3 -3
  80. package/plugins/graphql.js.map +1 -1
  81. package/plugins/index.d.ts +2 -2
  82. package/plugins/index.js +22 -19
  83. package/plugins/index.js.map +1 -1
  84. package/storage/FileStorage.d.ts +32 -0
  85. package/storage/FileStorage.js +86 -0
  86. package/storage/FileStorage.js.map +1 -0
  87. package/types/file.d.ts +33 -0
  88. package/types/file.js +5 -0
  89. package/types/file.js.map +1 -0
  90. package/types/file.lifecycle.d.ts +40 -0
  91. package/types/file.lifecycle.js +5 -0
  92. package/types/file.lifecycle.js.map +1 -0
  93. package/types.d.ts +44 -45
  94. package/types.js +22 -0
  95. package/types.js.map +1 -1
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.getS3Object = void 0;
8
+ var _utils = require("../utils");
9
+ var _loaders = _interopRequireDefault(require("../transform/loaders"));
10
+ const MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB
11
+
12
+ const getS3Object = async (fileInfo, s3, context) => {
13
+ const {
14
+ filename,
15
+ options,
16
+ extension
17
+ } = fileInfo;
18
+ const params = (0, _utils.getObjectParams)(filename);
19
+ const objectHead = await s3.headObject(params).promise();
20
+ const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;
21
+ for (const loader of _loaders.default) {
22
+ const canProcess = loader.canProcess({
23
+ context,
24
+ s3,
25
+ options,
26
+ file: {
27
+ name: filename,
28
+ extension,
29
+ contentLength
30
+ }
31
+ });
32
+ if (!canProcess) {
33
+ continue;
34
+ }
35
+ return loader.process({
36
+ context,
37
+ s3,
38
+ options,
39
+ file: {
40
+ name: filename,
41
+ extension,
42
+ contentLength
43
+ }
44
+ });
45
+ }
46
+
47
+ // If no processors handled the file request, just return the S3 object taking its size into consideration.
48
+ let object;
49
+ if (contentLength < MAX_RETURN_CONTENT_LENGTH) {
50
+ object = await s3.getObject(params).promise();
51
+ }
52
+ return {
53
+ object,
54
+ params
55
+ };
56
+ };
57
+ exports.getS3Object = getS3Object;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["MAX_RETURN_CONTENT_LENGTH","getS3Object","fileInfo","s3","context","filename","options","extension","params","getObjectParams","objectHead","headObject","promise","contentLength","ContentLength","loader","loaders","canProcess","file","name","process","object","getObject"],"sources":["getS3Object.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport { Context } from \"@webiny/handler/types\";\nimport { getObjectParams } from \"~/handlers/utils\";\nimport loaders from \"~/handlers/transform/loaders\";\nimport { ObjectParamsResponse } from \"~/handlers/utils/getObjectParams\";\nimport { extractFileInformation } from \"./extractFileInformation\";\n\ninterface S3Object {\n object?: S3.Types.GetObjectOutput;\n params: ObjectParamsResponse;\n}\n\nconst MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB\n\nexport const getS3Object = async (\n fileInfo: ReturnType<typeof extractFileInformation>,\n s3: S3,\n context: Context\n): Promise<S3Object> => {\n const { filename, options, extension } = fileInfo;\n const params = getObjectParams(filename);\n\n const objectHead = await s3.headObject(params).promise();\n const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;\n\n for (const loader of loaders) {\n const canProcess = loader.canProcess({\n context,\n s3,\n options,\n file: {\n name: filename,\n extension,\n contentLength\n }\n });\n\n if (!canProcess) {\n continue;\n }\n return loader.process({\n context,\n s3,\n options,\n file: {\n name: filename,\n extension,\n contentLength\n }\n });\n }\n\n // If no processors handled the file request, just return the S3 object taking its size into consideration.\n let object;\n if (contentLength < MAX_RETURN_CONTENT_LENGTH) {\n object = await s3.getObject(params).promise();\n }\n\n return { object, params };\n};\n"],"mappings":";;;;;;;AAEA;AACA;AASA,MAAMA,yBAAyB,GAAG,OAAO,CAAC,CAAC;;AAEpC,MAAMC,WAAW,GAAG,OACvBC,QAAmD,EACnDC,EAAM,EACNC,OAAgB,KACI;EACpB,MAAM;IAAEC,QAAQ;IAAEC,OAAO;IAAEC;EAAU,CAAC,GAAGL,QAAQ;EACjD,MAAMM,MAAM,GAAG,IAAAC,sBAAe,EAACJ,QAAQ,CAAC;EAExC,MAAMK,UAAU,GAAG,MAAMP,EAAE,CAACQ,UAAU,CAACH,MAAM,CAAC,CAACI,OAAO,EAAE;EACxD,MAAMC,aAAa,GAAGH,UAAU,CAACI,aAAa,GAAGJ,UAAU,CAACI,aAAa,GAAG,CAAC;EAE7E,KAAK,MAAMC,MAAM,IAAIC,gBAAO,EAAE;IAC1B,MAAMC,UAAU,GAAGF,MAAM,CAACE,UAAU,CAAC;MACjCb,OAAO;MACPD,EAAE;MACFG,OAAO;MACPY,IAAI,EAAE;QACFC,IAAI,EAAEd,QAAQ;QACdE,SAAS;QACTM;MACJ;IACJ,CAAC,CAAC;IAEF,IAAI,CAACI,UAAU,EAAE;MACb;IACJ;IACA,OAAOF,MAAM,CAACK,OAAO,CAAC;MAClBhB,OAAO;MACPD,EAAE;MACFG,OAAO;MACPY,IAAI,EAAE;QACFC,IAAI,EAAEd,QAAQ;QACdE,SAAS;QACTM;MACJ;IACJ,CAAC,CAAC;EACN;;EAEA;EACA,IAAIQ,MAAM;EACV,IAAIR,aAAa,GAAGb,yBAAyB,EAAE;IAC3CqB,MAAM,GAAG,MAAMlB,EAAE,CAACmB,SAAS,CAACd,MAAM,CAAC,CAACI,OAAO,EAAE;EACjD;EAEA,OAAO;IAAES,MAAM;IAAEb;EAAO,CAAC;AAC7B,CAAC;AAAC"}
@@ -1,3 +1,2 @@
1
- import { RoutePlugin } from "@webiny/handler-aws/gateway";
2
- import { Context } from "@webiny/handler/types";
3
- export declare const createDownloadFilePlugins: () => RoutePlugin<Context>[];
1
+ export * from "./byExactKey";
2
+ export * from "./byAlias";
@@ -1,132 +1,27 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
3
  Object.defineProperty(exports, "__esModule", {
6
4
  value: true
7
5
  });
8
- exports.createDownloadFilePlugins = void 0;
9
-
10
- var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
11
-
12
- var _sanitizeFilename = _interopRequireDefault(require("sanitize-filename"));
13
-
14
- var _path = _interopRequireDefault(require("path"));
15
-
16
- var _utils = require("../utils");
17
-
18
- var _loaders = _interopRequireDefault(require("../transform/loaders"));
19
-
20
- var _gateway = require("@webiny/handler-aws/gateway");
21
-
22
- const MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB
23
-
24
- const DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year
25
-
26
- const PRESIGNED_URL_EXPIRATION = 900; // 15 minutes
27
-
28
- /**
29
- * Based on given path, extracts file key and additional options sent via query params.
30
- */
31
-
32
- const extractFilenameOptions = request => {
33
- const path = (0, _sanitizeFilename.default)(request.params.path);
34
- return {
35
- filename: decodeURI(path),
36
- options: request.query,
37
- extension: _path.default.extname(path)
38
- };
39
- };
40
-
41
- const getS3Object = async (request, s3, context) => {
42
- const {
43
- options,
44
- filename,
45
- extension
46
- } = extractFilenameOptions(request);
47
- const params = (0, _utils.getObjectParams)(filename);
48
- const objectHead = await s3.headObject(params).promise();
49
- const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;
50
-
51
- for (const loader of _loaders.default) {
52
- const canProcess = loader.canProcess({
53
- context,
54
- s3,
55
- options,
56
- file: {
57
- name: filename,
58
- extension,
59
- contentLength
60
- }
61
- });
62
-
63
- if (!canProcess) {
64
- continue;
6
+ var _byExactKey = require("./byExactKey");
7
+ Object.keys(_byExactKey).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _byExactKey[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function () {
13
+ return _byExactKey[key];
65
14
  }
66
-
67
- return loader.process({
68
- context,
69
- s3,
70
- options,
71
- file: {
72
- name: filename,
73
- extension,
74
- contentLength
75
- }
76
- });
77
- } // If no processors handled the file request, just return the S3 object taking its size into consideration.
78
-
79
-
80
- let object;
81
-
82
- if (contentLength < MAX_RETURN_CONTENT_LENGTH) {
83
- object = await s3.getObject(params).promise();
84
- }
85
-
86
- return {
87
- object,
88
- params
89
- };
90
- };
91
-
92
- const createDownloadFilePlugins = () => {
93
- return [new _gateway.RoutePlugin(({
94
- onGet,
95
- context
96
- }) => {
97
- onGet("/files/:path", async (request, reply) => {
98
- const {
99
- region
100
- } = (0, _utils.getEnvironment)();
101
- const s3 = new _s.default({
102
- region
103
- });
104
- const {
105
- params,
106
- object
107
- } = await getS3Object(request, s3, context); // If there's an "object", it means we can return its body directly.
108
-
109
- if (object) {
110
- return reply.headers({
111
- "Content-Type": object.ContentType,
112
- "Cache-Control": `public, max-age=${DEFAULT_CACHE_MAX_AGE}`,
113
- "x-webiny-base64-encoded": true
114
- }).send(object.Body || "");
115
- }
116
-
117
- const presignedUrl = s3.getSignedUrl("getObject", {
118
- Bucket: params.Bucket,
119
- Key: params.Key,
120
- Expires: PRESIGNED_URL_EXPIRATION
121
- }); // Lambda can return max 6MB of content, so if our object's size is larger, we are sending
122
- // a 301 Redirect, redirecting the user to the public URL of the object in S3.
123
-
124
- return reply.code(301).headers({
125
- Location: presignedUrl,
126
- "Cache-Control": "public, max-age=" + PRESIGNED_URL_EXPIRATION
127
- }).send("");
128
- });
129
- })];
130
- };
131
-
132
- exports.createDownloadFilePlugins = createDownloadFilePlugins;
15
+ });
16
+ });
17
+ var _byAlias = require("./byAlias");
18
+ Object.keys(_byAlias).forEach(function (key) {
19
+ if (key === "default" || key === "__esModule") return;
20
+ if (key in exports && exports[key] === _byAlias[key]) return;
21
+ Object.defineProperty(exports, key, {
22
+ enumerable: true,
23
+ get: function () {
24
+ return _byAlias[key];
25
+ }
26
+ });
27
+ });
@@ -1 +1 @@
1
- {"version":3,"names":["MAX_RETURN_CONTENT_LENGTH","DEFAULT_CACHE_MAX_AGE","PRESIGNED_URL_EXPIRATION","extractFilenameOptions","request","path","sanitizeFilename","params","filename","decodeURI","options","query","extension","pathLib","extname","getS3Object","s3","context","getObjectParams","objectHead","headObject","promise","contentLength","ContentLength","loader","loaders","canProcess","file","name","process","object","getObject","createDownloadFilePlugins","RoutePlugin","onGet","reply","region","getEnvironment","S3","headers","ContentType","send","Body","presignedUrl","getSignedUrl","Bucket","Key","Expires","code","Location"],"sources":["index.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport sanitizeFilename from \"sanitize-filename\";\nimport pathLib from \"path\";\nimport { getEnvironment, getObjectParams } from \"../utils\";\nimport loaders from \"../transform/loaders\";\nimport { RoutePlugin } from \"@webiny/handler-aws/gateway\";\nimport { Context, Request } from \"@webiny/handler/types\";\nimport { ObjectParamsResponse } from \"~/handlers/utils/getObjectParams\";\n\nconst MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB\nconst DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year\nconst PRESIGNED_URL_EXPIRATION = 900; // 15 minutes\n/**\n * Based on given path, extracts file key and additional options sent via query params.\n */\nconst extractFilenameOptions = (request: Request) => {\n const path = sanitizeFilename((request.params as any).path);\n return {\n filename: decodeURI(path),\n options: request.query as any,\n extension: pathLib.extname(path)\n };\n};\n\ninterface S3Object {\n object?: S3.Types.GetObjectOutput;\n params: ObjectParamsResponse;\n}\n\nconst getS3Object = async (request: Request, s3: S3, context: Context): Promise<S3Object> => {\n const { options, filename, extension } = extractFilenameOptions(request);\n const params = getObjectParams(filename);\n const objectHead = await s3.headObject(params).promise();\n const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;\n\n for (const loader of loaders) {\n const canProcess = loader.canProcess({\n context,\n s3,\n options,\n file: {\n name: filename,\n extension,\n contentLength\n }\n });\n\n if (!canProcess) {\n continue;\n }\n return loader.process({\n context,\n s3,\n options,\n file: {\n name: filename,\n extension,\n contentLength\n }\n });\n }\n\n // If no processors handled the file request, just return the S3 object taking its size into consideration.\n let object;\n if (contentLength < MAX_RETURN_CONTENT_LENGTH) {\n object = await s3.getObject(params).promise();\n }\n\n return { object, params };\n};\n\nexport const createDownloadFilePlugins = () => {\n return [\n new RoutePlugin(({ onGet, context }) => {\n onGet(\"/files/:path\", async (request, reply) => {\n const { region } = getEnvironment();\n const s3 = new S3({ region });\n\n const { params, object } = await getS3Object(request, s3, context);\n\n // If there's an \"object\", it means we can return its body directly.\n if (object) {\n return reply\n .headers({\n \"Content-Type\": object.ContentType,\n \"Cache-Control\": `public, max-age=${DEFAULT_CACHE_MAX_AGE}`,\n \"x-webiny-base64-encoded\": true\n })\n .send(object.Body || \"\");\n }\n\n const presignedUrl = s3.getSignedUrl(\"getObject\", {\n Bucket: params.Bucket,\n Key: params.Key,\n Expires: PRESIGNED_URL_EXPIRATION\n });\n\n // Lambda can return max 6MB of content, so if our object's size is larger, we are sending\n // a 301 Redirect, redirecting the user to the public URL of the object in S3.\n return reply\n .code(301)\n .headers({\n Location: presignedUrl,\n \"Cache-Control\": \"public, max-age=\" + PRESIGNED_URL_EXPIRATION\n })\n .send(\"\");\n });\n })\n ];\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./byExactKey\";\nexport * from \"./byAlias\";\n"],"mappings":";;;;;AAAA;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;AACA;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
@@ -1,22 +1,15 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.createManageFilePlugins = void 0;
9
-
10
8
  var _path = _interopRequireDefault(require("path"));
11
-
12
9
  var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
13
-
14
10
  var _utils = require("../utils");
15
-
16
11
  var _managers = _interopRequireDefault(require("../transform/managers"));
17
-
18
12
  var _handlerAws = require("@webiny/handler-aws");
19
-
20
13
  /**
21
14
  * This handler must be run through @webiny/handler-aws/s3
22
15
  */
@@ -25,39 +18,31 @@ const createManageFilePlugins = () => {
25
18
  event
26
19
  }) => {
27
20
  const keys = [];
28
-
29
21
  for (let i = 0; i < event.Records.length; i++) {
30
22
  const record = event.Records[i];
31
-
32
23
  if (typeof record.s3.object.key === "string") {
33
24
  keys.push(record.s3.object.key);
34
25
  }
35
26
  }
36
-
37
27
  if (keys.length === 0) {
38
28
  return;
39
29
  }
40
-
41
30
  const {
42
31
  region
43
32
  } = (0, _utils.getEnvironment)();
44
33
  const s3 = new _s.default({
45
34
  region
46
35
  });
47
-
48
36
  for (const key of keys) {
49
37
  const extension = _path.default.extname(key);
50
-
51
38
  for (const manager of _managers.default) {
52
39
  const canProcess = manager.canProcess({
53
40
  key,
54
41
  extension
55
42
  });
56
-
57
43
  if (!canProcess) {
58
44
  continue;
59
45
  }
60
-
61
46
  await manager.process({
62
47
  s3,
63
48
  key,
@@ -67,5 +52,4 @@ const createManageFilePlugins = () => {
67
52
  }
68
53
  })];
69
54
  };
70
-
71
55
  exports.createManageFilePlugins = createManageFilePlugins;
@@ -1 +1 @@
1
- {"version":3,"names":["createManageFilePlugins","S3EventHandler","event","keys","i","Records","length","record","s3","object","key","push","region","getEnvironment","S3","extension","path","extname","manager","managers","canProcess","process"],"sources":["index.ts"],"sourcesContent":["import path from \"path\";\nimport S3 from \"aws-sdk/clients/s3\";\nimport { getEnvironment } from \"../utils\";\nimport managers from \"../transform/managers\";\nimport { S3EventHandler } from \"@webiny/handler-aws\";\n\n/**\n * This handler must be run through @webiny/handler-aws/s3\n */\nexport const createManageFilePlugins = () => {\n return [\n new S3EventHandler(async ({ event }) => {\n const keys: string[] = [];\n for (let i = 0; i < event.Records.length; i++) {\n const record = event.Records[i];\n if (typeof record.s3.object.key === \"string\") {\n keys.push(record.s3.object.key);\n }\n }\n\n if (keys.length === 0) {\n return;\n }\n\n const { region } = getEnvironment();\n const s3 = new S3({ region });\n\n for (const key of keys) {\n const extension = path.extname(key);\n\n for (const manager of managers) {\n const canProcess = manager.canProcess({\n key,\n extension\n });\n\n if (!canProcess) {\n continue;\n }\n await manager.process({\n s3,\n key,\n extension\n });\n }\n }\n })\n ];\n};\n"],"mappings":";;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AAEA;AACA;AACA;AACO,MAAMA,uBAAuB,GAAG,MAAM;EACzC,OAAO,CACH,IAAIC,0BAAJ,CAAmB,OAAO;IAAEC;EAAF,CAAP,KAAqB;IACpC,MAAMC,IAAc,GAAG,EAAvB;;IACA,KAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGF,KAAK,CAACG,OAAN,CAAcC,MAAlC,EAA0CF,CAAC,EAA3C,EAA+C;MAC3C,MAAMG,MAAM,GAAGL,KAAK,CAACG,OAAN,CAAcD,CAAd,CAAf;;MACA,IAAI,OAAOG,MAAM,CAACC,EAAP,CAAUC,MAAV,CAAiBC,GAAxB,KAAgC,QAApC,EAA8C;QAC1CP,IAAI,CAACQ,IAAL,CAAUJ,MAAM,CAACC,EAAP,CAAUC,MAAV,CAAiBC,GAA3B;MACH;IACJ;;IAED,IAAIP,IAAI,CAACG,MAAL,KAAgB,CAApB,EAAuB;MACnB;IACH;;IAED,MAAM;MAAEM;IAAF,IAAa,IAAAC,qBAAA,GAAnB;IACA,MAAML,EAAE,GAAG,IAAIM,UAAJ,CAAO;MAAEF;IAAF,CAAP,CAAX;;IAEA,KAAK,MAAMF,GAAX,IAAkBP,IAAlB,EAAwB;MACpB,MAAMY,SAAS,GAAGC,aAAA,CAAKC,OAAL,CAAaP,GAAb,CAAlB;;MAEA,KAAK,MAAMQ,OAAX,IAAsBC,iBAAtB,EAAgC;QAC5B,MAAMC,UAAU,GAAGF,OAAO,CAACE,UAAR,CAAmB;UAClCV,GADkC;UAElCK;QAFkC,CAAnB,CAAnB;;QAKA,IAAI,CAACK,UAAL,EAAiB;UACb;QACH;;QACD,MAAMF,OAAO,CAACG,OAAR,CAAgB;UAClBb,EADkB;UAElBE,GAFkB;UAGlBK;QAHkB,CAAhB,CAAN;MAKH;IACJ;EACJ,CAnCD,CADG,CAAP;AAsCH,CAvCM"}
1
+ {"version":3,"names":["createManageFilePlugins","S3EventHandler","event","keys","i","Records","length","record","s3","object","key","push","region","getEnvironment","S3","extension","path","extname","manager","managers","canProcess","process"],"sources":["index.ts"],"sourcesContent":["import path from \"path\";\nimport S3 from \"aws-sdk/clients/s3\";\nimport { getEnvironment } from \"../utils\";\nimport managers from \"../transform/managers\";\nimport { S3EventHandler } from \"@webiny/handler-aws\";\n\n/**\n * This handler must be run through @webiny/handler-aws/s3\n */\nexport const createManageFilePlugins = () => {\n return [\n new S3EventHandler(async ({ event }) => {\n const keys: string[] = [];\n for (let i = 0; i < event.Records.length; i++) {\n const record = event.Records[i];\n if (typeof record.s3.object.key === \"string\") {\n keys.push(record.s3.object.key);\n }\n }\n\n if (keys.length === 0) {\n return;\n }\n\n const { region } = getEnvironment();\n const s3 = new S3({ region });\n\n for (const key of keys) {\n const extension = path.extname(key);\n\n for (const manager of managers) {\n const canProcess = manager.canProcess({\n key,\n extension\n });\n\n if (!canProcess) {\n continue;\n }\n await manager.process({\n s3,\n key,\n extension\n });\n }\n }\n })\n ];\n};\n"],"mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACO,MAAMA,uBAAuB,GAAG,MAAM;EACzC,OAAO,CACH,IAAIC,0BAAc,CAAC,OAAO;IAAEC;EAAM,CAAC,KAAK;IACpC,MAAMC,IAAc,GAAG,EAAE;IACzB,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGF,KAAK,CAACG,OAAO,CAACC,MAAM,EAAEF,CAAC,EAAE,EAAE;MAC3C,MAAMG,MAAM,GAAGL,KAAK,CAACG,OAAO,CAACD,CAAC,CAAC;MAC/B,IAAI,OAAOG,MAAM,CAACC,EAAE,CAACC,MAAM,CAACC,GAAG,KAAK,QAAQ,EAAE;QAC1CP,IAAI,CAACQ,IAAI,CAACJ,MAAM,CAACC,EAAE,CAACC,MAAM,CAACC,GAAG,CAAC;MACnC;IACJ;IAEA,IAAIP,IAAI,CAACG,MAAM,KAAK,CAAC,EAAE;MACnB;IACJ;IAEA,MAAM;MAAEM;IAAO,CAAC,GAAG,IAAAC,qBAAc,GAAE;IACnC,MAAML,EAAE,GAAG,IAAIM,UAAE,CAAC;MAAEF;IAAO,CAAC,CAAC;IAE7B,KAAK,MAAMF,GAAG,IAAIP,IAAI,EAAE;MACpB,MAAMY,SAAS,GAAGC,aAAI,CAACC,OAAO,CAACP,GAAG,CAAC;MAEnC,KAAK,MAAMQ,OAAO,IAAIC,iBAAQ,EAAE;QAC5B,MAAMC,UAAU,GAAGF,OAAO,CAACE,UAAU,CAAC;UAClCV,GAAG;UACHK;QACJ,CAAC,CAAC;QAEF,IAAI,CAACK,UAAU,EAAE;UACb;QACJ;QACA,MAAMF,OAAO,CAACG,OAAO,CAAC;UAClBb,EAAE;UACFE,GAAG;UACHK;QACJ,CAAC,CAAC;MACN;IACJ;EACJ,CAAC,CAAC,CACL;AACL,CAAC;AAAC"}
@@ -1,26 +1,19 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
3
4
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
8
  exports.createTransformFilePlugins = void 0;
9
-
10
9
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
-
12
10
  var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
13
-
14
11
  var _transformImage = _interopRequireDefault(require("./transformImage"));
15
-
16
12
  var _optimizeImage = _interopRequireDefault(require("./optimizeImage"));
17
-
18
13
  var _utils = require("../utils");
19
-
20
- var _utils2 = require("./utils");
21
-
14
+ var newUtils = _interopRequireWildcard(require("./utils"));
15
+ var legacyUtils = _interopRequireWildcard(require("./legacyUtils"));
22
16
  var _handler = require("@webiny/handler");
23
-
24
17
  const createTransformFilePlugins = () => {
25
18
  return [(0, _handler.createEvent)(async ({
26
19
  payload
@@ -32,24 +25,25 @@ const createTransformFilePlugins = () => {
32
25
  key,
33
26
  transformations
34
27
  } = body;
35
-
36
28
  try {
37
29
  const env = (0, _utils.getEnvironment)();
38
30
  const s3 = new _s.default({
39
31
  region: env.region
40
32
  });
41
33
  let optimizedImageObject;
34
+ const utils = key.includes("/") ? newUtils : legacyUtils;
42
35
  const params = {
43
36
  initial: (0, _utils.getObjectParams)(key),
44
- optimized: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
37
+ optimized: (0, _utils.getObjectParams)(utils.getImageKey({
45
38
  key
46
39
  })),
47
- optimizedTransformed: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
40
+ optimizedTransformed: (0, _utils.getObjectParams)(utils.getImageKey({
48
41
  key,
49
42
  transformations
50
43
  }))
51
- }; // 1. Get optimized image.
44
+ };
52
45
 
46
+ // 1. Get optimized image.
53
47
  try {
54
48
  optimizedImageObject = await s3.getObject(params.optimized).promise();
55
49
  } catch (e) {
@@ -60,17 +54,17 @@ const createTransformFilePlugins = () => {
60
54
  Body: await (0, _optimizeImage.default)(optimizedImageObject.Body, optimizedImageObject.ContentType)
61
55
  })).promise();
62
56
  optimizedImageObject = await s3.getObject(params.optimized).promise();
63
- } // 2. If no transformations requested, just exit.
64
-
57
+ }
65
58
 
59
+ // 2. If no transformations requested, just exit.
66
60
  if (!transformations) {
67
61
  return {
68
62
  error: false,
69
63
  message: ""
70
64
  };
71
- } // 3. If transformations requested, apply them in save it into the bucket.
72
-
65
+ }
73
66
 
67
+ // 3. If transformations requested, apply them in save it into the bucket.
74
68
  await s3.putObject((0, _objectSpread2.default)((0, _objectSpread2.default)({}, params.optimizedTransformed), {}, {
75
69
  ContentType: optimizedImageObject.ContentType,
76
70
  Body: await (0, _transformImage.default)(optimizedImageObject.Body, transformations)
@@ -92,5 +86,4 @@ const createTransformFilePlugins = () => {
92
86
  }
93
87
  })];
94
88
  };
95
-
96
89
  exports.createTransformFilePlugins = createTransformFilePlugins;
@@ -1 +1 @@
1
- {"version":3,"names":["createTransformFilePlugins","createEvent","payload","body","key","transformations","env","getEnvironment","s3","S3","region","optimizedImageObject","params","initial","getObjectParams","optimized","getImageKey","optimizedTransformed","getObject","promise","e","putObject","ContentType","Body","optimizeImage","error","message","transformImage","ex","console","JSON","stringify","code","data"],"sources":["index.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport transformImage from \"./transformImage\";\nimport optimizeImage from \"./optimizeImage\";\nimport { getEnvironment, getObjectParams } from \"../utils\";\nimport { getImageKey } from \"./utils\";\nimport { TransformHandlerEventPayload } from \"~/handlers/types\";\nimport { createEvent } from \"@webiny/handler\";\n\nexport const createTransformFilePlugins = () => {\n return [\n createEvent<TransformHandlerEventPayload>(async ({ payload }) => {\n const { body } = payload;\n const { key, transformations } = body;\n try {\n const env = getEnvironment();\n const s3 = new S3({ region: env.region });\n\n let optimizedImageObject: S3.Types.GetObjectOutput;\n\n const params = {\n initial: getObjectParams(key),\n optimized: getObjectParams(getImageKey({ key })),\n optimizedTransformed: getObjectParams(getImageKey({ key, transformations }))\n };\n\n // 1. Get optimized image.\n try {\n optimizedImageObject = await s3.getObject(params.optimized).promise();\n } catch (e) {\n // If not found, try to create it by loading the initially uploaded image.\n optimizedImageObject = await s3.getObject(params.initial).promise();\n\n await s3\n .putObject({\n ...params.optimized,\n ContentType: optimizedImageObject.ContentType,\n Body: await optimizeImage(\n optimizedImageObject.Body as Buffer,\n optimizedImageObject.ContentType as string\n )\n })\n .promise();\n\n optimizedImageObject = await s3.getObject(params.optimized).promise();\n }\n\n // 2. If no transformations requested, just exit.\n if (!transformations) {\n return {\n error: false,\n message: \"\"\n };\n }\n\n // 3. If transformations requested, apply them in save it into the bucket.\n await s3\n .putObject({\n ...params.optimizedTransformed,\n ContentType: optimizedImageObject.ContentType,\n Body: await transformImage(\n optimizedImageObject.Body as Buffer,\n transformations\n )\n })\n .promise();\n\n return {\n error: false,\n message: \"\"\n };\n } catch (ex) {\n console.error(\n JSON.stringify({\n message: ex.message,\n code: ex.code,\n data: ex.data\n })\n );\n return {\n error: true,\n message: ex.message\n };\n }\n })\n ];\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AAEO,MAAMA,0BAA0B,GAAG,MAAM;EAC5C,OAAO,CACH,IAAAC,oBAAA,EAA0C,OAAO;IAAEC;EAAF,CAAP,KAAuB;IAC7D,MAAM;MAAEC;IAAF,IAAWD,OAAjB;IACA,MAAM;MAAEE,GAAF;MAAOC;IAAP,IAA2BF,IAAjC;;IACA,IAAI;MACA,MAAMG,GAAG,GAAG,IAAAC,qBAAA,GAAZ;MACA,MAAMC,EAAE,GAAG,IAAIC,UAAJ,CAAO;QAAEC,MAAM,EAAEJ,GAAG,CAACI;MAAd,CAAP,CAAX;MAEA,IAAIC,oBAAJ;MAEA,MAAMC,MAAM,GAAG;QACXC,OAAO,EAAE,IAAAC,sBAAA,EAAgBV,GAAhB,CADE;QAEXW,SAAS,EAAE,IAAAD,sBAAA,EAAgB,IAAAE,mBAAA,EAAY;UAAEZ;QAAF,CAAZ,CAAhB,CAFA;QAGXa,oBAAoB,EAAE,IAAAH,sBAAA,EAAgB,IAAAE,mBAAA,EAAY;UAAEZ,GAAF;UAAOC;QAAP,CAAZ,CAAhB;MAHX,CAAf,CANA,CAYA;;MACA,IAAI;QACAM,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAH,CAAaN,MAAM,CAACG,SAApB,EAA+BI,OAA/B,EAA7B;MACH,CAFD,CAEE,OAAOC,CAAP,EAAU;QACR;QACAT,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAH,CAAaN,MAAM,CAACC,OAApB,EAA6BM,OAA7B,EAA7B;QAEA,MAAMX,EAAE,CACHa,SADC,6DAEKT,MAAM,CAACG,SAFZ;UAGEO,WAAW,EAAEX,oBAAoB,CAACW,WAHpC;UAIEC,IAAI,EAAE,MAAM,IAAAC,sBAAA,EACRb,oBAAoB,CAACY,IADb,EAERZ,oBAAoB,CAACW,WAFb;QAJd,IASDH,OATC,EAAN;QAWAR,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAH,CAAaN,MAAM,CAACG,SAApB,EAA+BI,OAA/B,EAA7B;MACH,CA/BD,CAiCA;;;MACA,IAAI,CAACd,eAAL,EAAsB;QAClB,OAAO;UACHoB,KAAK,EAAE,KADJ;UAEHC,OAAO,EAAE;QAFN,CAAP;MAIH,CAvCD,CAyCA;;;MACA,MAAMlB,EAAE,CACHa,SADC,6DAEKT,MAAM,CAACK,oBAFZ;QAGEK,WAAW,EAAEX,oBAAoB,CAACW,WAHpC;QAIEC,IAAI,EAAE,MAAM,IAAAI,uBAAA,EACRhB,oBAAoB,CAACY,IADb,EAERlB,eAFQ;MAJd,IASDc,OATC,EAAN;MAWA,OAAO;QACHM,KAAK,EAAE,KADJ;QAEHC,OAAO,EAAE;MAFN,CAAP;IAIH,CAzDD,CAyDE,OAAOE,EAAP,EAAW;MACTC,OAAO,CAACJ,KAAR,CACIK,IAAI,CAACC,SAAL,CAAe;QACXL,OAAO,EAAEE,EAAE,CAACF,OADD;QAEXM,IAAI,EAAEJ,EAAE,CAACI,IAFE;QAGXC,IAAI,EAAEL,EAAE,CAACK;MAHE,CAAf,CADJ;MAOA,OAAO;QACHR,KAAK,EAAE,IADJ;QAEHC,OAAO,EAAEE,EAAE,CAACF;MAFT,CAAP;IAIH;EACJ,CAzED,CADG,CAAP;AA4EH,CA7EM"}
1
+ {"version":3,"names":["createTransformFilePlugins","createEvent","payload","body","key","transformations","env","getEnvironment","s3","S3","region","optimizedImageObject","utils","includes","newUtils","legacyUtils","params","initial","getObjectParams","optimized","getImageKey","optimizedTransformed","getObject","promise","e","putObject","ContentType","Body","optimizeImage","error","message","transformImage","ex","console","JSON","stringify","code","data"],"sources":["index.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport transformImage from \"./transformImage\";\nimport optimizeImage from \"./optimizeImage\";\nimport { getEnvironment, getObjectParams } from \"../utils\";\nimport * as newUtils from \"./utils\";\nimport * as legacyUtils from \"./legacyUtils\";\nimport { TransformHandlerEventPayload } from \"~/handlers/types\";\nimport { createEvent } from \"@webiny/handler\";\n\nexport const createTransformFilePlugins = () => {\n return [\n createEvent<TransformHandlerEventPayload>(async ({ payload }) => {\n const { body } = payload;\n const { key, transformations } = body;\n try {\n const env = getEnvironment();\n const s3 = new S3({ region: env.region });\n\n let optimizedImageObject: S3.Types.GetObjectOutput;\n\n const utils = key.includes(\"/\") ? newUtils : legacyUtils;\n\n const params = {\n initial: getObjectParams(key),\n optimized: getObjectParams(utils.getImageKey({ key })),\n optimizedTransformed: getObjectParams(\n utils.getImageKey({ key, transformations })\n )\n };\n\n // 1. Get optimized image.\n try {\n optimizedImageObject = await s3.getObject(params.optimized).promise();\n } catch (e) {\n // If not found, try to create it by loading the initially uploaded image.\n optimizedImageObject = await s3.getObject(params.initial).promise();\n\n await s3\n .putObject({\n ...params.optimized,\n ContentType: optimizedImageObject.ContentType,\n Body: await optimizeImage(\n optimizedImageObject.Body as Buffer,\n optimizedImageObject.ContentType as string\n )\n })\n .promise();\n\n optimizedImageObject = await s3.getObject(params.optimized).promise();\n }\n\n // 2. If no transformations requested, just exit.\n if (!transformations) {\n return {\n error: false,\n message: \"\"\n };\n }\n\n // 3. If transformations requested, apply them in save it into the bucket.\n await s3\n .putObject({\n ...params.optimizedTransformed,\n ContentType: optimizedImageObject.ContentType,\n Body: await transformImage(\n optimizedImageObject.Body as Buffer,\n transformations\n )\n })\n .promise();\n\n return {\n error: false,\n message: \"\"\n };\n } catch (ex) {\n console.error(\n JSON.stringify({\n message: ex.message,\n code: ex.code,\n data: ex.data\n })\n );\n return {\n error: true,\n message: ex.message\n };\n }\n })\n ];\n};\n"],"mappings":";;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEO,MAAMA,0BAA0B,GAAG,MAAM;EAC5C,OAAO,CACH,IAAAC,oBAAW,EAA+B,OAAO;IAAEC;EAAQ,CAAC,KAAK;IAC7D,MAAM;MAAEC;IAAK,CAAC,GAAGD,OAAO;IACxB,MAAM;MAAEE,GAAG;MAAEC;IAAgB,CAAC,GAAGF,IAAI;IACrC,IAAI;MACA,MAAMG,GAAG,GAAG,IAAAC,qBAAc,GAAE;MAC5B,MAAMC,EAAE,GAAG,IAAIC,UAAE,CAAC;QAAEC,MAAM,EAAEJ,GAAG,CAACI;MAAO,CAAC,CAAC;MAEzC,IAAIC,oBAA8C;MAElD,MAAMC,KAAK,GAAGR,GAAG,CAACS,QAAQ,CAAC,GAAG,CAAC,GAAGC,QAAQ,GAAGC,WAAW;MAExD,MAAMC,MAAM,GAAG;QACXC,OAAO,EAAE,IAAAC,sBAAe,EAACd,GAAG,CAAC;QAC7Be,SAAS,EAAE,IAAAD,sBAAe,EAACN,KAAK,CAACQ,WAAW,CAAC;UAAEhB;QAAI,CAAC,CAAC,CAAC;QACtDiB,oBAAoB,EAAE,IAAAH,sBAAe,EACjCN,KAAK,CAACQ,WAAW,CAAC;UAAEhB,GAAG;UAAEC;QAAgB,CAAC,CAAC;MAEnD,CAAC;;MAED;MACA,IAAI;QACAM,oBAAoB,GAAG,MAAMH,EAAE,CAACc,SAAS,CAACN,MAAM,CAACG,SAAS,CAAC,CAACI,OAAO,EAAE;MACzE,CAAC,CAAC,OAAOC,CAAC,EAAE;QACR;QACAb,oBAAoB,GAAG,MAAMH,EAAE,CAACc,SAAS,CAACN,MAAM,CAACC,OAAO,CAAC,CAACM,OAAO,EAAE;QAEnE,MAAMf,EAAE,CACHiB,SAAS,6DACHT,MAAM,CAACG,SAAS;UACnBO,WAAW,EAAEf,oBAAoB,CAACe,WAAW;UAC7CC,IAAI,EAAE,MAAM,IAAAC,sBAAa,EACrBjB,oBAAoB,CAACgB,IAAI,EACzBhB,oBAAoB,CAACe,WAAW;QACnC,GACH,CACDH,OAAO,EAAE;QAEdZ,oBAAoB,GAAG,MAAMH,EAAE,CAACc,SAAS,CAACN,MAAM,CAACG,SAAS,CAAC,CAACI,OAAO,EAAE;MACzE;;MAEA;MACA,IAAI,CAAClB,eAAe,EAAE;QAClB,OAAO;UACHwB,KAAK,EAAE,KAAK;UACZC,OAAO,EAAE;QACb,CAAC;MACL;;MAEA;MACA,MAAMtB,EAAE,CACHiB,SAAS,6DACHT,MAAM,CAACK,oBAAoB;QAC9BK,WAAW,EAAEf,oBAAoB,CAACe,WAAW;QAC7CC,IAAI,EAAE,MAAM,IAAAI,uBAAc,EACtBpB,oBAAoB,CAACgB,IAAI,EACzBtB,eAAe;MAClB,GACH,CACDkB,OAAO,EAAE;MAEd,OAAO;QACHM,KAAK,EAAE,KAAK;QACZC,OAAO,EAAE;MACb,CAAC;IACL,CAAC,CAAC,OAAOE,EAAE,EAAE;MACTC,OAAO,CAACJ,KAAK,CACTK,IAAI,CAACC,SAAS,CAAC;QACXL,OAAO,EAAEE,EAAE,CAACF,OAAO;QACnBM,IAAI,EAAEJ,EAAE,CAACI,IAAI;QACbC,IAAI,EAAEL,EAAE,CAACK;MACb,CAAC,CAAC,CACL;MACD,OAAO;QACHR,KAAK,EAAE,IAAI;QACXC,OAAO,EAAEE,EAAE,CAACF;MAChB,CAAC;IACL;EACJ,CAAC,CAAC,CACL;AACL,CAAC;AAAC"}
@@ -0,0 +1,17 @@
1
+ /**
2
+ * BACKWARDS-COMPATIBILITY!
3
+ *
4
+ * This file contains utilities for files that don't have `id/key` structure, meaning, all files created before 5.35.0 release.
5
+ */
6
+ declare const SUPPORTED_IMAGES: string[];
7
+ declare const SUPPORTED_TRANSFORMABLE_IMAGES: string[];
8
+ declare const OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = "img-o-t-";
9
+ declare const OPTIMIZED_IMAGE_PREFIX = "img-o-";
10
+ declare const getOptimizedImageKeyPrefix: (key: string) => string;
11
+ declare const getOptimizedTransformedImageKeyPrefix: (key: string) => string;
12
+ interface GetImageKeyParams {
13
+ key: string;
14
+ transformations?: any;
15
+ }
16
+ declare const getImageKey: ({ key, transformations }: GetImageKeyParams) => string;
17
+ export { SUPPORTED_IMAGES, SUPPORTED_TRANSFORMABLE_IMAGES, OPTIMIZED_TRANSFORMED_IMAGE_PREFIX, OPTIMIZED_IMAGE_PREFIX, getImageKey, getOptimizedImageKeyPrefix, getOptimizedTransformedImageKeyPrefix };
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.getOptimizedTransformedImageKeyPrefix = exports.getOptimizedImageKeyPrefix = exports.getImageKey = exports.SUPPORTED_TRANSFORMABLE_IMAGES = exports.SUPPORTED_IMAGES = exports.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = exports.OPTIMIZED_IMAGE_PREFIX = void 0;
8
+ var _objectHash = _interopRequireDefault(require("object-hash"));
9
+ /**
10
+ * BACKWARDS-COMPATIBILITY!
11
+ *
12
+ * This file contains utilities for files that don't have `id/key` structure, meaning, all files created before 5.35.0 release.
13
+ */
14
+
15
+ const SUPPORTED_IMAGES = [".jpg", ".jpeg", ".png", ".svg", ".gif"];
16
+ exports.SUPPORTED_IMAGES = SUPPORTED_IMAGES;
17
+ const SUPPORTED_TRANSFORMABLE_IMAGES = [".jpg", ".jpeg", ".png"];
18
+ exports.SUPPORTED_TRANSFORMABLE_IMAGES = SUPPORTED_TRANSFORMABLE_IMAGES;
19
+ const OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = "img-o-t-";
20
+ exports.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = OPTIMIZED_TRANSFORMED_IMAGE_PREFIX;
21
+ const OPTIMIZED_IMAGE_PREFIX = "img-o-";
22
+ exports.OPTIMIZED_IMAGE_PREFIX = OPTIMIZED_IMAGE_PREFIX;
23
+ const getOptimizedImageKeyPrefix = key => {
24
+ return `${OPTIMIZED_IMAGE_PREFIX}${(0, _objectHash.default)(key)}-`;
25
+ };
26
+ exports.getOptimizedImageKeyPrefix = getOptimizedImageKeyPrefix;
27
+ const getOptimizedTransformedImageKeyPrefix = key => {
28
+ return `${OPTIMIZED_TRANSFORMED_IMAGE_PREFIX}${(0, _objectHash.default)(key)}-`;
29
+ };
30
+ exports.getOptimizedTransformedImageKeyPrefix = getOptimizedTransformedImageKeyPrefix;
31
+ const getImageKey = ({
32
+ key,
33
+ transformations
34
+ }) => {
35
+ if (!transformations) {
36
+ const prefix = getOptimizedImageKeyPrefix(key);
37
+ return prefix + key;
38
+ }
39
+ const prefix = getOptimizedTransformedImageKeyPrefix(key);
40
+ return `${prefix}${(0, _objectHash.default)(transformations)}-${key}`;
41
+ };
42
+ exports.getImageKey = getImageKey;
@@ -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":["legacyUtils.ts"],"sourcesContent":["/**\n * BACKWARDS-COMPATIBILITY!\n *\n * This file contains utilities for files that don't have `id/key` structure, meaning, all files created before 5.35.0 release.\n */\n\nimport 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":";;;;;;;AAMA;AANA;AACA;AACA;AACA;AACA;;AAIA,MAAMA,gBAAgB,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;AAAC;AACnE,MAAMC,8BAA8B,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC;AAAC;AAEjE,MAAMC,kCAAkC,GAAG,UAAU;AAAC;AACtD,MAAMC,sBAAsB,GAAG,QAAQ;AAAC;AAExC,MAAMC,0BAA0B,GAAIC,GAAW,IAAa;EACxD,OAAQ,GAAEF,sBAAuB,GAAE,IAAAG,mBAAU,EAACD,GAAG,CAAE,GAAE;AACzD,CAAC;AAAC;AAEF,MAAME,qCAAqC,GAAIF,GAAW,IAAa;EACnE,OAAQ,GAAEH,kCAAmC,GAAE,IAAAI,mBAAU,EAACD,GAAG,CAAE,GAAE;AACrE,CAAC;AAAC;AAOF,MAAMG,WAAW,GAAG,CAAC;EAAEH,GAAG;EAAEI;AAAmC,CAAC,KAAa;EACzE,IAAI,CAACA,eAAe,EAAE;IAClB,MAAMC,MAAM,GAAGN,0BAA0B,CAACC,GAAG,CAAC;IAC9C,OAAOK,MAAM,GAAGL,GAAG;EACvB;EAEA,MAAMK,MAAM,GAAGH,qCAAqC,CAACF,GAAG,CAAC;EACzD,OAAQ,GAAEK,MAAO,GAAE,IAAAJ,mBAAU,EAACG,eAAe,CAAE,IAAGJ,GAAI,EAAC;AAC3D,CAAC;AAAC"}
@@ -21,7 +21,7 @@ export interface ProcessParams {
21
21
  context: ClientContext;
22
22
  }
23
23
  declare const _default: {
24
- canProcess: (params: CanProcessParams) => boolean;
24
+ canProcess: ({ file }: CanProcessParams) => boolean;
25
25
  process({ s3, file, options, context }: ProcessParams): Promise<{
26
26
  object: import("aws-sdk/lib/request").PromiseResult<S3.GetObjectOutput, import("aws-sdk/lib/error").AWSError>;
27
27
  params: import("../../utils/getObjectParams").ObjectParamsResponse;
@@ -1,20 +1,16 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
3
4
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
8
  exports.default = void 0;
9
-
10
9
  var _sanitizeImageTransformations = _interopRequireDefault(require("./sanitizeImageTransformations"));
11
-
12
10
  var _utils = require("../../utils");
13
-
14
- var _utils2 = require("../utils");
15
-
11
+ var newUtils = _interopRequireWildcard(require("../utils"));
12
+ var legacyUtils = _interopRequireWildcard(require("../legacyUtils"));
16
13
  const IMAGE_TRANSFORMER_FUNCTION = process.env.IMAGE_TRANSFORMER_FUNCTION;
17
-
18
14
  const callImageTransformerLambda = async ({
19
15
  key,
20
16
  transformations,
@@ -30,12 +26,13 @@ const callImageTransformerLambda = async ({
30
26
  }
31
27
  });
32
28
  };
33
-
34
29
  var _default = {
35
- canProcess: params => {
36
- return _utils2.SUPPORTED_IMAGES.includes(params.file.extension);
30
+ canProcess: ({
31
+ file
32
+ }) => {
33
+ const utils = file.name.includes("/") ? newUtils : legacyUtils;
34
+ return utils.SUPPORTED_IMAGES.includes(file.extension);
37
35
  },
38
-
39
36
  async process({
40
37
  s3,
41
38
  file,
@@ -44,14 +41,13 @@ var _default = {
44
41
  }) {
45
42
  // Loaders must return {object, params} object.
46
43
  let objectParams;
44
+ const utils = file.name.includes("/") ? newUtils : legacyUtils;
47
45
  const transformations = (0, _sanitizeImageTransformations.default)(options);
48
-
49
- if (transformations && _utils2.SUPPORTED_TRANSFORMABLE_IMAGES.includes(file.extension)) {
50
- objectParams = (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
46
+ if (transformations && utils.SUPPORTED_TRANSFORMABLE_IMAGES.includes(file.extension)) {
47
+ objectParams = (0, _utils.getObjectParams)(utils.getImageKey({
51
48
  key: file.name,
52
49
  transformations
53
50
  }));
54
-
55
51
  try {
56
52
  return {
57
53
  object: await s3.getObject(objectParams).promise(),
@@ -63,22 +59,18 @@ var _default = {
63
59
  transformations,
64
60
  context
65
61
  });
66
-
67
62
  if (imageTransformerLambdaResponse.error) {
68
63
  throw Error(imageTransformerLambdaResponse.message);
69
64
  }
70
-
71
65
  return {
72
66
  object: await s3.getObject(objectParams).promise(),
73
67
  params: objectParams
74
68
  };
75
69
  }
76
70
  }
77
-
78
- objectParams = (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
71
+ objectParams = (0, _utils.getObjectParams)(utils.getImageKey({
79
72
  key: file.name
80
73
  }));
81
-
82
74
  try {
83
75
  return {
84
76
  object: await s3.getObject(objectParams).promise(),
@@ -89,17 +81,14 @@ var _default = {
89
81
  key: file.name,
90
82
  context
91
83
  });
92
-
93
84
  if (imageTransformerLambdaResponse.error) {
94
85
  throw Error(imageTransformerLambdaResponse.message);
95
86
  }
96
-
97
87
  return {
98
88
  object: await s3.getObject(objectParams).promise(),
99
89
  params: objectParams
100
90
  };
101
91
  }
102
92
  }
103
-
104
93
  };
105
94
  exports.default = _default;