@webiny/api-file-manager 5.30.0 → 5.31.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 (37) hide show
  1. package/handlers/download/index.d.ts +3 -8
  2. package/handlers/download/index.js +55 -54
  3. package/handlers/download/index.js.map +1 -1
  4. package/handlers/manage/index.d.ts +5 -5
  5. package/handlers/manage/index.js +48 -48
  6. package/handlers/manage/index.js.map +1 -1
  7. package/handlers/transform/index.d.ts +2 -5
  8. package/handlers/transform/index.js +64 -68
  9. package/handlers/transform/index.js.map +1 -1
  10. package/handlers/transform/loaders/imageLoader.d.ts +1 -0
  11. package/handlers/transform/loaders/imageLoader.js.map +1 -1
  12. package/handlers/transform/managers/imageManager.js +5 -2
  13. package/handlers/transform/managers/imageManager.js.map +1 -1
  14. package/handlers/types.d.ts +1 -26
  15. package/handlers/types.js.map +1 -1
  16. package/handlers/utils/index.d.ts +0 -1
  17. package/handlers/utils/index.js +0 -18
  18. package/handlers/utils/index.js.map +1 -1
  19. package/package.json +20 -19
  20. package/plugins/crud/files.crud.d.ts +1 -1
  21. package/plugins/crud/files.crud.js +2 -2
  22. package/plugins/crud/files.crud.js.map +1 -1
  23. package/plugins/crud/settings.crud.d.ts +1 -1
  24. package/plugins/crud/settings.crud.js +2 -2
  25. package/plugins/crud/settings.crud.js.map +1 -1
  26. package/plugins/crud/system.crud.d.ts +1 -1
  27. package/plugins/crud/system.crud.js +2 -2
  28. package/plugins/crud/system.crud.js.map +1 -1
  29. package/plugins/index.d.ts +1 -1
  30. package/plugins/storage/index.d.ts +1 -1
  31. package/plugins/storage/index.js +2 -2
  32. package/plugins/storage/index.js.map +1 -1
  33. package/types.d.ts +1 -1
  34. package/types.js.map +1 -1
  35. package/handlers/utils/createHandler.d.ts +0 -24
  36. package/handlers/utils/createHandler.js +0 -69
  37. package/handlers/utils/createHandler.js.map +0 -1
@@ -1,8 +1,3 @@
1
- import { HandlerPlugin } from "@webiny/handler/types";
2
- import { ArgsContext } from "@webiny/handler-args/types";
3
- import { DownloadHandlerEventArgs } from "../types";
4
- import { ClientContext } from "@webiny/handler-client/types";
5
- interface Context extends ClientContext, ArgsContext<DownloadHandlerEventArgs> {
6
- }
7
- declare const _default: () => HandlerPlugin<Context>;
8
- export default _default;
1
+ import { RoutePlugin } from "@webiny/handler-aws/gateway";
2
+ import { Context } from "@webiny/handler/types";
3
+ export declare const createDownloadFilePlugins: () => RoutePlugin<Context>[];
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = void 0;
8
+ exports.createDownloadFilePlugins = void 0;
9
9
 
10
10
  var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
11
11
 
@@ -17,29 +17,36 @@ var _utils = require("../utils");
17
17
 
18
18
  var _loaders = _interopRequireDefault(require("../transform/loaders"));
19
19
 
20
+ var _gateway = require("@webiny/handler-aws/gateway");
21
+
20
22
  const MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB
21
23
 
22
24
  const DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year
23
25
 
26
+ const PRESIGNED_URL_EXPIRATION = 900; // 15 minutes
27
+
24
28
  /**
25
29
  * Based on given path, extracts file key and additional options sent via query params.
26
- * @param event
27
30
  */
28
- const extractFilenameOptions = event => {
29
- const path = (0, _sanitizeFilename.default)(event.pathParameters.path);
31
+
32
+ const extractFilenameOptions = request => {
33
+ const path = (0, _sanitizeFilename.default)(request.params.path);
30
34
  return {
31
35
  filename: decodeURI(path),
32
- options: event.queryStringParameters,
36
+ options: request.query,
33
37
  extension: _path.default.extname(path)
34
38
  };
35
39
  };
36
40
 
37
- const getS3Object = async (event, s3, context) => {
41
+ const getS3Object = async (request, s3, context) => {
38
42
  const {
39
43
  options,
40
44
  filename,
41
45
  extension
42
- } = extractFilenameOptions(event);
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;
43
50
 
44
51
  for (const loader of _loaders.default) {
45
52
  const canProcess = loader.canProcess({
@@ -48,7 +55,8 @@ const getS3Object = async (event, s3, context) => {
48
55
  options,
49
56
  file: {
50
57
  name: filename,
51
- extension
58
+ extension,
59
+ contentLength
52
60
  }
53
61
  });
54
62
 
@@ -62,25 +70,31 @@ const getS3Object = async (event, s3, context) => {
62
70
  options,
63
71
  file: {
64
72
  name: filename,
65
- extension
73
+ extension,
74
+ contentLength
66
75
  }
67
76
  });
68
- } // If no processors handled the file request, just return the S3 object by default.
77
+ } // If no processors handled the file request, just return the S3 object taking its size into consideration.
69
78
 
70
79
 
71
- const params = (0, _utils.getObjectParams)(filename);
80
+ let object;
81
+
82
+ if (contentLength < MAX_RETURN_CONTENT_LENGTH) {
83
+ object = await s3.getObject(params).promise();
84
+ }
85
+
72
86
  return {
73
- object: await s3.getObject(params).promise(),
74
- params: params
87
+ object,
88
+ params
75
89
  };
76
90
  };
77
91
 
78
- var _default = () => ({
79
- type: "handler",
80
- name: "handler-download-file",
81
-
82
- async handle(context) {
83
- const eventHandler = async event => {
92
+ const createDownloadFilePlugins = () => {
93
+ return [new _gateway.RoutePlugin(({
94
+ onGet,
95
+ context
96
+ }) => {
97
+ onGet("/files/:path", async (request, reply) => {
84
98
  const {
85
99
  region
86
100
  } = (0, _utils.getEnvironment)();
@@ -90,42 +104,29 @@ var _default = () => ({
90
104
  const {
91
105
  params,
92
106
  object
93
- } = await getS3Object(event, s3, context);
94
- const contentLength = object.ContentLength === undefined ? 0 : object.ContentLength;
95
-
96
- if (contentLength < MAX_RETURN_CONTENT_LENGTH) {
97
- return {
98
- /**
99
- * It is safe to cast as buffer or unknown
100
- */
101
- data: object.Body || null,
102
- headers: {
103
- "Content-Type": object.ContentType,
104
- "Cache-Control": "public, max-age=" + DEFAULT_CACHE_MAX_AGE
105
- }
106
- };
107
- } // Lambda can return max 6MB of content, so if our object's size is larger, we are sending
108
- // a 301 Redirect, redirecting the user to the public URL of the object in S3.
109
-
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
+ }
110
116
 
111
- await s3.putObjectAcl({
117
+ const presignedUrl = s3.getSignedUrl("getObject", {
112
118
  Bucket: params.Bucket,
113
- ACL: "public-read",
114
- Key: params.Key
115
- }).promise();
116
- return {
117
- data: null,
118
- statusCode: 301,
119
- headers: {
120
- Location: `https://${params.Bucket}.s3.amazonaws.com/${params.Key}`
121
- }
122
- };
123
- };
124
-
125
- const handler = (0, _utils.createHandler)(eventHandler);
126
- return await handler(context.invocationArgs);
127
- }
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.
128
123
 
129
- });
124
+ return reply.code(301).headers({
125
+ Location: presignedUrl,
126
+ "Cache-Control": "public, max-age=" + PRESIGNED_URL_EXPIRATION
127
+ }).send("");
128
+ });
129
+ })];
130
+ };
130
131
 
131
- exports.default = _default;
132
+ exports.createDownloadFilePlugins = createDownloadFilePlugins;
@@ -1 +1 @@
1
- {"version":3,"names":["MAX_RETURN_CONTENT_LENGTH","DEFAULT_CACHE_MAX_AGE","extractFilenameOptions","event","path","sanitizeFilename","pathParameters","filename","decodeURI","options","queryStringParameters","extension","pathLib","extname","getS3Object","s3","context","loader","loaders","canProcess","file","name","process","params","getObjectParams","object","getObject","promise","type","handle","eventHandler","region","getEnvironment","S3","contentLength","ContentLength","undefined","data","Body","headers","ContentType","putObjectAcl","Bucket","ACL","Key","statusCode","Location","handler","createHandler","invocationArgs"],"sources":["index.ts"],"sourcesContent":["import { HandlerPlugin } from \"@webiny/handler/types\";\nimport S3 from \"aws-sdk/clients/s3\";\nimport sanitizeFilename from \"sanitize-filename\";\nimport pathLib from \"path\";\nimport { createHandler, getEnvironment, getObjectParams, EventHandlerCallable } from \"../utils\";\nimport loaders from \"../transform/loaders\";\nimport { ArgsContext } from \"@webiny/handler-args/types\";\nimport { DownloadHandlerEventArgs } from \"~/handlers/types\";\nimport { ClientContext } from \"@webiny/handler-client/types\";\n\nconst MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB\nconst DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year\n\ninterface Context extends ClientContext, ArgsContext<DownloadHandlerEventArgs> {}\n/**\n * Based on given path, extracts file key and additional options sent via query params.\n * @param event\n */\nconst extractFilenameOptions = (event: DownloadHandlerEventArgs) => {\n const path = sanitizeFilename(event.pathParameters.path);\n return {\n filename: decodeURI(path),\n options: event.queryStringParameters,\n extension: pathLib.extname(path)\n };\n};\n\nconst getS3Object = async (event: DownloadHandlerEventArgs, s3: S3, context: Context) => {\n const { options, filename, extension } = extractFilenameOptions(event);\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 }\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 }\n });\n }\n\n // If no processors handled the file request, just return the S3 object by default.\n const params = getObjectParams(filename);\n return {\n object: await s3.getObject(params).promise(),\n params: params\n };\n};\n\nexport default (): HandlerPlugin<Context> => ({\n type: \"handler\",\n name: \"handler-download-file\",\n async handle(context) {\n const eventHandler: EventHandlerCallable<DownloadHandlerEventArgs> = async event => {\n const { region } = getEnvironment();\n const s3 = new S3({ region });\n\n const { params, object } = await getS3Object(event, s3, context);\n\n const contentLength = object.ContentLength === undefined ? 0 : object.ContentLength;\n if (contentLength < MAX_RETURN_CONTENT_LENGTH) {\n return {\n /**\n * It is safe to cast as buffer or unknown\n */\n data: object.Body || null,\n headers: {\n \"Content-Type\": object.ContentType,\n \"Cache-Control\": \"public, max-age=\" + DEFAULT_CACHE_MAX_AGE\n }\n };\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 await s3\n .putObjectAcl({\n Bucket: params.Bucket,\n ACL: \"public-read\",\n Key: params.Key\n })\n .promise();\n\n return {\n data: null,\n statusCode: 301,\n headers: {\n Location: `https://${params.Bucket}.s3.amazonaws.com/${params.Key}`\n }\n };\n };\n const handler = createHandler(eventHandler);\n\n return await handler(context.invocationArgs);\n }\n});\n"],"mappings":"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"}
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,5 +1,5 @@
1
- import { HandlerPlugin } from "@webiny/handler/types";
2
- import { ArgsContext } from "@webiny/handler-args/types";
3
- import { ManageHandlerEventArgs } from "../types";
4
- declare const _default: () => HandlerPlugin<ArgsContext<ManageHandlerEventArgs>>;
5
- export default _default;
1
+ import { S3EventHandler } from "@webiny/handler-aws";
2
+ /**
3
+ * This handler must be run through @webiny/handler-aws/s3
4
+ */
5
+ export declare const createManageFilePlugins: () => S3EventHandler<void>[];
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = void 0;
8
+ exports.createManageFilePlugins = void 0;
9
9
 
10
10
  var _path = _interopRequireDefault(require("path"));
11
11
 
@@ -15,57 +15,57 @@ var _utils = require("../utils");
15
15
 
16
16
  var _managers = _interopRequireDefault(require("../transform/managers"));
17
17
 
18
- var _default = () => ({
19
- type: "handler",
20
- name: "handler-download-file",
18
+ var _handlerAws = require("@webiny/handler-aws");
21
19
 
22
- async handle(context) {
23
- // TODO @ts-refactor check in createHandler for returns types that eventHandler must return
24
- // @ts-ignore
25
- const eventHandler = async event => {
26
- const keys = [];
20
+ /**
21
+ * This handler must be run through @webiny/handler-aws/s3
22
+ */
23
+ const createManageFilePlugins = () => {
24
+ return [new _handlerAws.S3EventHandler(async ({
25
+ event
26
+ }) => {
27
+ const keys = [];
27
28
 
28
- for (let i = 0; i < event.Records.length; i++) {
29
- const record = event.Records[i];
29
+ for (let i = 0; i < event.Records.length; i++) {
30
+ const record = event.Records[i];
30
31
 
31
- if (typeof record.s3.object.key === "string") {
32
- keys.push(record.s3.object.key);
33
- }
32
+ if (typeof record.s3.object.key === "string") {
33
+ keys.push(record.s3.object.key);
34
34
  }
35
-
36
- const {
37
- region
38
- } = (0, _utils.getEnvironment)();
39
- const s3 = new _s.default({
40
- region
41
- });
42
-
43
- for (const key of keys) {
44
- const extension = _path.default.extname(key);
45
-
46
- for (const manager of _managers.default) {
47
- const canProcess = manager.canProcess({
48
- key,
49
- extension
50
- });
51
-
52
- if (!canProcess) {
53
- continue;
54
- }
55
-
56
- await manager.process({
57
- s3,
58
- key,
59
- extension
60
- });
35
+ }
36
+
37
+ if (keys.length === 0) {
38
+ return;
39
+ }
40
+
41
+ const {
42
+ region
43
+ } = (0, _utils.getEnvironment)();
44
+ const s3 = new _s.default({
45
+ region
46
+ });
47
+
48
+ for (const key of keys) {
49
+ const extension = _path.default.extname(key);
50
+
51
+ for (const manager of _managers.default) {
52
+ const canProcess = manager.canProcess({
53
+ key,
54
+ extension
55
+ });
56
+
57
+ if (!canProcess) {
58
+ continue;
61
59
  }
62
- }
63
- };
64
60
 
65
- const handler = (0, _utils.createHandler)(eventHandler);
66
- return await handler(context.invocationArgs);
67
- }
68
-
69
- });
61
+ await manager.process({
62
+ s3,
63
+ key,
64
+ extension
65
+ });
66
+ }
67
+ }
68
+ })];
69
+ };
70
70
 
71
- exports.default = _default;
71
+ exports.createManageFilePlugins = createManageFilePlugins;
@@ -1 +1 @@
1
- {"version":3,"names":["type","name","handle","context","eventHandler","event","keys","i","Records","length","record","s3","object","key","push","region","getEnvironment","S3","extension","path","extname","manager","managers","canProcess","process","handler","createHandler","invocationArgs"],"sources":["index.ts"],"sourcesContent":["import path from \"path\";\nimport S3 from \"aws-sdk/clients/s3\";\nimport { HandlerPlugin } from \"@webiny/handler/types\";\nimport { createHandler, getEnvironment, EventHandlerCallable } from \"../utils\";\nimport managers from \"../transform/managers\";\nimport { ArgsContext } from \"@webiny/handler-args/types\";\nimport { ManageHandlerEventArgs } from \"~/handlers/types\";\n\nexport default (): HandlerPlugin<ArgsContext<ManageHandlerEventArgs>> => ({\n type: \"handler\",\n name: \"handler-download-file\",\n async handle(context) {\n // TODO @ts-refactor check in createHandler for returns types that eventHandler must return\n // @ts-ignore\n const eventHandler: EventHandlerCallable<ManageHandlerEventArgs> = 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 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 const handler = createHandler(eventHandler);\n\n return await handler(context.invocationArgs);\n }\n});\n"],"mappings":";;;;;;;;;AAAA;;AACA;;AAEA;;AACA;;eAIe,OAA2D;EACtEA,IAAI,EAAE,SADgE;EAEtEC,IAAI,EAAE,uBAFgE;;EAGtE,MAAMC,MAAN,CAAaC,OAAb,EAAsB;IAClB;IACA;IACA,MAAMC,YAA0D,GAAG,MAAMC,KAAN,IAAe;MAC9E,MAAMC,IAAc,GAAG,EAAvB;;MACA,KAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGF,KAAK,CAACG,OAAN,CAAcC,MAAlC,EAA0CF,CAAC,EAA3C,EAA+C;QAC3C,MAAMG,MAAM,GAAGL,KAAK,CAACG,OAAN,CAAcD,CAAd,CAAf;;QACA,IAAI,OAAOG,MAAM,CAACC,EAAP,CAAUC,MAAV,CAAiBC,GAAxB,KAAgC,QAApC,EAA8C;UAC1CP,IAAI,CAACQ,IAAL,CAAUJ,MAAM,CAACC,EAAP,CAAUC,MAAV,CAAiBC,GAA3B;QACH;MACJ;;MAED,MAAM;QAAEE;MAAF,IAAa,IAAAC,qBAAA,GAAnB;MACA,MAAML,EAAE,GAAG,IAAIM,UAAJ,CAAO;QAAEF;MAAF,CAAP,CAAX;;MAEA,KAAK,MAAMF,GAAX,IAAkBP,IAAlB,EAAwB;QACpB,MAAMY,SAAS,GAAGC,aAAA,CAAKC,OAAL,CAAaP,GAAb,CAAlB;;QAEA,KAAK,MAAMQ,OAAX,IAAsBC,iBAAtB,EAAgC;UAC5B,MAAMC,UAAU,GAAGF,OAAO,CAACE,UAAR,CAAmB;YAClCV,GADkC;YAElCK;UAFkC,CAAnB,CAAnB;;UAKA,IAAI,CAACK,UAAL,EAAiB;YACb;UACH;;UACD,MAAMF,OAAO,CAACG,OAAR,CAAgB;YAClBb,EADkB;YAElBE,GAFkB;YAGlBK;UAHkB,CAAhB,CAAN;QAKH;MACJ;IACJ,CA/BD;;IAiCA,MAAMO,OAAO,GAAG,IAAAC,oBAAA,EAActB,YAAd,CAAhB;IAEA,OAAO,MAAMqB,OAAO,CAACtB,OAAO,CAACwB,cAAT,CAApB;EACH;;AA1CqE,CAA3D,C"}
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,5 +1,2 @@
1
- import { HandlerPlugin } from "@webiny/handler/types";
2
- import { ArgsContext } from "@webiny/handler-args/types";
3
- import { TransformHandlerEventArgs } from "../types";
4
- declare const _default: () => HandlerPlugin<ArgsContext<TransformHandlerEventArgs>>;
5
- export default _default;
1
+ import { TransformHandlerEventPayload } from "../types";
2
+ export declare const createTransformFilePlugins: () => import("@webiny/handler").EventPlugin<TransformHandlerEventPayload, import("@webiny/handler/types").Context, any>[];
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = void 0;
8
+ exports.createTransformFilePlugins = void 0;
9
9
 
10
10
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
11
 
@@ -19,81 +19,77 @@ var _utils = require("../utils");
19
19
 
20
20
  var _utils2 = require("./utils");
21
21
 
22
+ var _handler = require("@webiny/handler");
23
+
22
24
  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; }
23
25
 
24
26
  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; }
25
27
 
26
- var _default = () => ({
27
- type: "handler",
28
- name: "handler-download-file",
29
-
30
- async handle(context) {
31
- // TODO @ts-refactor check in createHandler for returns types that eventHandler must return
32
- // @ts-ignore
33
- const eventHandler = async ({
34
- body: {
35
- transformations,
36
- key
37
- }
38
- }) => {
28
+ const createTransformFilePlugins = () => {
29
+ return [(0, _handler.createEvent)(async ({
30
+ payload
31
+ }) => {
32
+ const {
33
+ body
34
+ } = payload;
35
+ const {
36
+ key,
37
+ transformations
38
+ } = body;
39
+
40
+ try {
41
+ const env = (0, _utils.getEnvironment)();
42
+ const s3 = new _s.default({
43
+ region: env.region
44
+ });
45
+ let optimizedImageObject;
46
+ const params = {
47
+ initial: (0, _utils.getObjectParams)(key),
48
+ optimized: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
49
+ key
50
+ })),
51
+ optimizedTransformed: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
52
+ key,
53
+ transformations
54
+ }))
55
+ }; // 1. Get optimized image.
56
+
39
57
  try {
40
- const env = (0, _utils.getEnvironment)();
41
- const s3 = new _s.default({
42
- region: env.region
43
- });
44
- let optimizedImageObject;
45
- const params = {
46
- initial: (0, _utils.getObjectParams)(key),
47
- optimized: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
48
- key
49
- })),
50
- optimizedTransformed: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
51
- key,
52
- transformations
53
- }))
54
- }; // 1. Get optimized image.
55
-
56
- try {
57
- optimizedImageObject = await s3.getObject(params.optimized).promise();
58
- } catch (e) {
59
- // If not found, try to create it by loading the initially uploaded image.
60
- optimizedImageObject = await s3.getObject(params.initial).promise();
61
- await s3.putObject(_objectSpread(_objectSpread({}, params.optimized), {}, {
62
- ContentType: optimizedImageObject.ContentType,
63
- Body: await (0, _optimizeImage.default)(optimizedImageObject.Body, optimizedImageObject.ContentType)
64
- })).promise();
65
- optimizedImageObject = await s3.getObject(params.optimized).promise();
66
- } // 2. If no transformations requested, just exit.
67
-
68
-
69
- if (!transformations) {
70
- return {
71
- error: false,
72
- message: ""
73
- };
74
- } // 3. If transformations requested, apply them in save it into the bucket.
75
-
76
-
77
- await s3.putObject(_objectSpread(_objectSpread({}, params.optimizedTransformed), {}, {
58
+ optimizedImageObject = await s3.getObject(params.optimized).promise();
59
+ } catch (e) {
60
+ // If not found, try to create it by loading the initially uploaded image.
61
+ optimizedImageObject = await s3.getObject(params.initial).promise();
62
+ await s3.putObject(_objectSpread(_objectSpread({}, params.optimized), {}, {
78
63
  ContentType: optimizedImageObject.ContentType,
79
- Body: await (0, _transformImage.default)(optimizedImageObject.Body, transformations)
64
+ Body: await (0, _optimizeImage.default)(optimizedImageObject.Body, optimizedImageObject.ContentType)
80
65
  })).promise();
66
+ optimizedImageObject = await s3.getObject(params.optimized).promise();
67
+ } // 2. If no transformations requested, just exit.
68
+
69
+
70
+ if (!transformations) {
81
71
  return {
82
72
  error: false,
83
73
  message: ""
84
74
  };
85
- } catch (e) {
86
- return {
87
- error: true,
88
- message: e.message
89
- };
90
- }
91
- };
92
-
93
- const handler = (0, _utils.createHandler)(eventHandler);
94
- return await handler(context.invocationArgs);
95
- }
96
-
97
- });
98
-
99
- exports.default = _default;
75
+ } // 3. If transformations requested, apply them in save it into the bucket.
76
+
77
+
78
+ await s3.putObject(_objectSpread(_objectSpread({}, params.optimizedTransformed), {}, {
79
+ ContentType: optimizedImageObject.ContentType,
80
+ Body: await (0, _transformImage.default)(optimizedImageObject.Body, transformations)
81
+ })).promise();
82
+ return {
83
+ error: false,
84
+ message: ""
85
+ };
86
+ } catch (e) {
87
+ return {
88
+ error: true,
89
+ message: e.message
90
+ };
91
+ }
92
+ })];
93
+ };
94
+
95
+ exports.createTransformFilePlugins = createTransformFilePlugins;
@@ -1 +1 @@
1
- {"version":3,"names":["type","name","handle","context","eventHandler","body","transformations","key","env","getEnvironment","s3","S3","region","optimizedImageObject","params","initial","getObjectParams","optimized","getImageKey","optimizedTransformed","getObject","promise","e","putObject","ContentType","Body","optimizeImage","error","message","transformImage","handler","createHandler","invocationArgs"],"sources":["index.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport transformImage from \"./transformImage\";\nimport optimizeImage from \"./optimizeImage\";\nimport { createHandler, EventHandlerCallable, getEnvironment, getObjectParams } from \"../utils\";\nimport { getImageKey } from \"./utils\";\nimport { HandlerPlugin } from \"@webiny/handler/types\";\nimport { ArgsContext } from \"@webiny/handler-args/types\";\nimport { TransformHandlerEventArgs } from \"~/handlers/types\";\n\nexport default (): HandlerPlugin<ArgsContext<TransformHandlerEventArgs>> => ({\n type: \"handler\",\n name: \"handler-download-file\",\n async handle(context) {\n // TODO @ts-refactor check in createHandler for returns types that eventHandler must return\n // @ts-ignore\n const eventHandler: EventHandlerCallable<TransformHandlerEventArgs> = async ({\n body: { transformations, key }\n }) => {\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 { error: false, message: \"\" };\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 { error: false, message: \"\" };\n } catch (e) {\n return { error: true, message: e.message };\n }\n };\n const handler = createHandler(eventHandler);\n\n return await handler(context.invocationArgs);\n }\n});\n"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;;;eAKe,OAA8D;EACzEA,IAAI,EAAE,SADmE;EAEzEC,IAAI,EAAE,uBAFmE;;EAGzE,MAAMC,MAAN,CAAaC,OAAb,EAAsB;IAClB;IACA;IACA,MAAMC,YAA6D,GAAG,OAAO;MACzEC,IAAI,EAAE;QAAEC,eAAF;QAAmBC;MAAnB;IADmE,CAAP,KAEhE;MACF,IAAI;QACA,MAAMC,GAAG,GAAG,IAAAC,qBAAA,GAAZ;QACA,MAAMC,EAAE,GAAG,IAAIC,UAAJ,CAAO;UAAEC,MAAM,EAAEJ,GAAG,CAACI;QAAd,CAAP,CAAX;QAEA,IAAIC,oBAAJ;QAEA,MAAMC,MAAM,GAAG;UACXC,OAAO,EAAE,IAAAC,sBAAA,EAAgBT,GAAhB,CADE;UAEXU,SAAS,EAAE,IAAAD,sBAAA,EAAgB,IAAAE,mBAAA,EAAY;YAAEX;UAAF,CAAZ,CAAhB,CAFA;UAGXY,oBAAoB,EAAE,IAAAH,sBAAA,EAAgB,IAAAE,mBAAA,EAAY;YAAEX,GAAF;YAAOD;UAAP,CAAZ,CAAhB;QAHX,CAAf,CANA,CAYA;;QACA,IAAI;UACAO,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAH,CAAaN,MAAM,CAACG,SAApB,EAA+BI,OAA/B,EAA7B;QACH,CAFD,CAEE,OAAOC,CAAP,EAAU;UACR;UACAT,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAH,CAAaN,MAAM,CAACC,OAApB,EAA6BM,OAA7B,EAA7B;UAEA,MAAMX,EAAE,CACHa,SADC,iCAEKT,MAAM,CAACG,SAFZ;YAGEO,WAAW,EAAEX,oBAAoB,CAACW,WAHpC;YAIEC,IAAI,EAAE,MAAM,IAAAC,sBAAA,EACRb,oBAAoB,CAACY,IADb,EAERZ,oBAAoB,CAACW,WAFb;UAJd,IASDH,OATC,EAAN;UAWAR,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAH,CAAaN,MAAM,CAACG,SAApB,EAA+BI,OAA/B,EAA7B;QACH,CA/BD,CAiCA;;;QACA,IAAI,CAACf,eAAL,EAAsB;UAClB,OAAO;YAAEqB,KAAK,EAAE,KAAT;YAAgBC,OAAO,EAAE;UAAzB,CAAP;QACH,CApCD,CAsCA;;;QACA,MAAMlB,EAAE,CACHa,SADC,iCAEKT,MAAM,CAACK,oBAFZ;UAGEK,WAAW,EAAEX,oBAAoB,CAACW,WAHpC;UAIEC,IAAI,EAAE,MAAM,IAAAI,uBAAA,EACRhB,oBAAoB,CAACY,IADb,EAERnB,eAFQ;QAJd,IASDe,OATC,EAAN;QAWA,OAAO;UAAEM,KAAK,EAAE,KAAT;UAAgBC,OAAO,EAAE;QAAzB,CAAP;MACH,CAnDD,CAmDE,OAAON,CAAP,EAAU;QACR,OAAO;UAAEK,KAAK,EAAE,IAAT;UAAeC,OAAO,EAAEN,CAAC,CAACM;QAA1B,CAAP;MACH;IACJ,CAzDD;;IA0DA,MAAME,OAAO,GAAG,IAAAC,oBAAA,EAAc3B,YAAd,CAAhB;IAEA,OAAO,MAAM0B,OAAO,CAAC3B,OAAO,CAAC6B,cAAT,CAApB;EACH;;AAnEwE,CAA9D,C"}
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"],"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 (e) {\n return {\n error: true,\n message: e.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,iCAEKT,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,iCAEKT,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,OAAON,CAAP,EAAU;MACR,OAAO;QACHK,KAAK,EAAE,IADJ;QAEHC,OAAO,EAAEN,CAAC,CAACM;MAFR,CAAP;IAIH;EACJ,CAlED,CADG,CAAP;AAqEH,CAtEM"}
@@ -3,6 +3,7 @@ import S3 from "aws-sdk/clients/s3";
3
3
  interface File {
4
4
  extension: string;
5
5
  name: string;
6
+ contentLength: number;
6
7
  }
7
8
  interface Options {
8
9
  width?: string;
@@ -1 +1 @@
1
- {"version":3,"names":["IMAGE_TRANSFORMER_FUNCTION","process","env","callImageTransformerLambda","key","transformations","context","handlerClient","invoke","name","payload","body","canProcess","params","SUPPORTED_IMAGES","includes","file","extension","s3","options","objectParams","sanitizeImageTransformations","SUPPORTED_TRANSFORMABLE_IMAGES","getObjectParams","getImageKey","object","getObject","promise","e","imageTransformerLambdaResponse","error","Error","message"],"sources":["imageLoader.ts"],"sourcesContent":["import sanitizeImageTransformations from \"./sanitizeImageTransformations\";\nimport { getObjectParams } from \"../../utils\";\nimport { SUPPORTED_IMAGES, SUPPORTED_TRANSFORMABLE_IMAGES, getImageKey } from \"../utils\";\nimport { ClientContext } from \"@webiny/handler-client/types\";\nimport S3 from \"aws-sdk/clients/s3\";\n\nconst IMAGE_TRANSFORMER_FUNCTION = process.env.IMAGE_TRANSFORMER_FUNCTION as string;\n\ninterface TransformerParams {\n context: ClientContext;\n key: string;\n transformations?: any;\n}\n\nconst callImageTransformerLambda = async ({ key, transformations, context }: TransformerParams) => {\n return await context.handlerClient.invoke({\n name: IMAGE_TRANSFORMER_FUNCTION,\n payload: {\n body: {\n key,\n transformations\n }\n }\n });\n};\ninterface File {\n extension: string;\n name: string;\n}\ninterface Options {\n width?: string;\n}\nexport interface CanProcessParams {\n s3: S3;\n file: File;\n options?: Options;\n context: ClientContext;\n}\nexport interface ProcessParams {\n s3: S3;\n file: File;\n options?: Options;\n context: ClientContext;\n}\nexport default {\n canProcess: (params: CanProcessParams) => {\n return SUPPORTED_IMAGES.includes(params.file.extension);\n },\n async process({ s3, file, options, context }: ProcessParams) {\n // Loaders must return {object, params} object.\n let objectParams;\n\n const transformations = sanitizeImageTransformations(options);\n\n if (transformations && SUPPORTED_TRANSFORMABLE_IMAGES.includes(file.extension)) {\n objectParams = getObjectParams(getImageKey({ key: file.name, transformations }));\n try {\n return {\n object: await s3.getObject(objectParams).promise(),\n params: objectParams\n };\n } catch (e) {\n const imageTransformerLambdaResponse = await callImageTransformerLambda({\n key: file.name,\n transformations,\n context\n });\n\n if (imageTransformerLambdaResponse.error) {\n throw Error(imageTransformerLambdaResponse.message);\n }\n\n return {\n object: await s3.getObject(objectParams).promise(),\n params: objectParams\n };\n }\n }\n\n objectParams = getObjectParams(getImageKey({ key: file.name }));\n try {\n return {\n object: await s3.getObject(objectParams).promise(),\n params: objectParams\n };\n } catch (e) {\n const imageTransformerLambdaResponse = await callImageTransformerLambda({\n key: file.name,\n context\n });\n\n if (imageTransformerLambdaResponse.error) {\n throw Error(imageTransformerLambdaResponse.message);\n }\n\n return {\n object: await s3.getObject(objectParams).promise(),\n params: objectParams\n };\n }\n }\n};\n"],"mappings":";;;;;;;;;AAAA;;AACA;;AACA;;AAIA,MAAMA,0BAA0B,GAAGC,OAAO,CAACC,GAAR,CAAYF,0BAA/C;;AAQA,MAAMG,0BAA0B,GAAG,OAAO;EAAEC,GAAF;EAAOC,eAAP;EAAwBC;AAAxB,CAAP,KAAgE;EAC/F,OAAO,MAAMA,OAAO,CAACC,aAAR,CAAsBC,MAAtB,CAA6B;IACtCC,IAAI,EAAET,0BADgC;IAEtCU,OAAO,EAAE;MACLC,IAAI,EAAE;QACFP,GADE;QAEFC;MAFE;IADD;EAF6B,CAA7B,CAAb;AASH,CAVD;;eA8Be;EACXO,UAAU,EAAGC,MAAD,IAA8B;IACtC,OAAOC,wBAAA,CAAiBC,QAAjB,CAA0BF,MAAM,CAACG,IAAP,CAAYC,SAAtC,CAAP;EACH,CAHU;;EAIX,MAAMhB,OAAN,CAAc;IAAEiB,EAAF;IAAMF,IAAN;IAAYG,OAAZ;IAAqBb;EAArB,CAAd,EAA6D;IACzD;IACA,IAAIc,YAAJ;IAEA,MAAMf,eAAe,GAAG,IAAAgB,qCAAA,EAA6BF,OAA7B,CAAxB;;IAEA,IAAId,eAAe,IAAIiB,sCAAA,CAA+BP,QAA/B,CAAwCC,IAAI,CAACC,SAA7C,CAAvB,EAAgF;MAC5EG,YAAY,GAAG,IAAAG,sBAAA,EAAgB,IAAAC,mBAAA,EAAY;QAAEpB,GAAG,EAAEY,IAAI,CAACP,IAAZ;QAAkBJ;MAAlB,CAAZ,CAAhB,CAAf;;MACA,IAAI;QACA,OAAO;UACHoB,MAAM,EAAE,MAAMP,EAAE,CAACQ,SAAH,CAAaN,YAAb,EAA2BO,OAA3B,EADX;UAEHd,MAAM,EAAEO;QAFL,CAAP;MAIH,CALD,CAKE,OAAOQ,CAAP,EAAU;QACR,MAAMC,8BAA8B,GAAG,MAAM1B,0BAA0B,CAAC;UACpEC,GAAG,EAAEY,IAAI,CAACP,IAD0D;UAEpEJ,eAFoE;UAGpEC;QAHoE,CAAD,CAAvE;;QAMA,IAAIuB,8BAA8B,CAACC,KAAnC,EAA0C;UACtC,MAAMC,KAAK,CAACF,8BAA8B,CAACG,OAAhC,CAAX;QACH;;QAED,OAAO;UACHP,MAAM,EAAE,MAAMP,EAAE,CAACQ,SAAH,CAAaN,YAAb,EAA2BO,OAA3B,EADX;UAEHd,MAAM,EAAEO;QAFL,CAAP;MAIH;IACJ;;IAEDA,YAAY,GAAG,IAAAG,sBAAA,EAAgB,IAAAC,mBAAA,EAAY;MAAEpB,GAAG,EAAEY,IAAI,CAACP;IAAZ,CAAZ,CAAhB,CAAf;;IACA,IAAI;MACA,OAAO;QACHgB,MAAM,EAAE,MAAMP,EAAE,CAACQ,SAAH,CAAaN,YAAb,EAA2BO,OAA3B,EADX;QAEHd,MAAM,EAAEO;MAFL,CAAP;IAIH,CALD,CAKE,OAAOQ,CAAP,EAAU;MACR,MAAMC,8BAA8B,GAAG,MAAM1B,0BAA0B,CAAC;QACpEC,GAAG,EAAEY,IAAI,CAACP,IAD0D;QAEpEH;MAFoE,CAAD,CAAvE;;MAKA,IAAIuB,8BAA8B,CAACC,KAAnC,EAA0C;QACtC,MAAMC,KAAK,CAACF,8BAA8B,CAACG,OAAhC,CAAX;MACH;;MAED,OAAO;QACHP,MAAM,EAAE,MAAMP,EAAE,CAACQ,SAAH,CAAaN,YAAb,EAA2BO,OAA3B,EADX;QAEHd,MAAM,EAAEO;MAFL,CAAP;IAIH;EACJ;;AAxDU,C"}
1
+ {"version":3,"names":["IMAGE_TRANSFORMER_FUNCTION","process","env","callImageTransformerLambda","key","transformations","context","handlerClient","invoke","name","payload","body","canProcess","params","SUPPORTED_IMAGES","includes","file","extension","s3","options","objectParams","sanitizeImageTransformations","SUPPORTED_TRANSFORMABLE_IMAGES","getObjectParams","getImageKey","object","getObject","promise","e","imageTransformerLambdaResponse","error","Error","message"],"sources":["imageLoader.ts"],"sourcesContent":["import sanitizeImageTransformations from \"./sanitizeImageTransformations\";\nimport { getObjectParams } from \"../../utils\";\nimport { SUPPORTED_IMAGES, SUPPORTED_TRANSFORMABLE_IMAGES, getImageKey } from \"../utils\";\nimport { ClientContext } from \"@webiny/handler-client/types\";\nimport S3 from \"aws-sdk/clients/s3\";\n\nconst IMAGE_TRANSFORMER_FUNCTION = process.env.IMAGE_TRANSFORMER_FUNCTION as string;\n\ninterface TransformerParams {\n context: ClientContext;\n key: string;\n transformations?: {\n width?: number;\n };\n}\n\nconst callImageTransformerLambda = async ({ key, transformations, context }: TransformerParams) => {\n return await context.handlerClient.invoke({\n name: IMAGE_TRANSFORMER_FUNCTION,\n payload: {\n body: {\n key,\n transformations\n }\n }\n });\n};\ninterface File {\n extension: string;\n name: string;\n contentLength: number;\n}\ninterface Options {\n width?: string;\n}\nexport interface CanProcessParams {\n s3: S3;\n file: File;\n options?: Options;\n context: ClientContext;\n}\nexport interface ProcessParams {\n s3: S3;\n file: File;\n options?: Options;\n context: ClientContext;\n}\nexport default {\n canProcess: (params: CanProcessParams) => {\n return SUPPORTED_IMAGES.includes(params.file.extension);\n },\n async process({ s3, file, options, context }: ProcessParams) {\n // Loaders must return {object, params} object.\n let objectParams;\n\n const transformations = sanitizeImageTransformations(options);\n\n if (transformations && SUPPORTED_TRANSFORMABLE_IMAGES.includes(file.extension)) {\n objectParams = getObjectParams(getImageKey({ key: file.name, transformations }));\n try {\n return {\n object: await s3.getObject(objectParams).promise(),\n params: objectParams\n };\n } catch (e) {\n const imageTransformerLambdaResponse = await callImageTransformerLambda({\n key: file.name,\n transformations,\n context\n });\n\n if (imageTransformerLambdaResponse.error) {\n throw Error(imageTransformerLambdaResponse.message);\n }\n\n return {\n object: await s3.getObject(objectParams).promise(),\n params: objectParams\n };\n }\n }\n\n objectParams = getObjectParams(getImageKey({ key: file.name }));\n try {\n return {\n object: await s3.getObject(objectParams).promise(),\n params: objectParams\n };\n } catch (e) {\n const imageTransformerLambdaResponse = await callImageTransformerLambda({\n key: file.name,\n context\n });\n\n if (imageTransformerLambdaResponse.error) {\n throw Error(imageTransformerLambdaResponse.message);\n }\n\n return {\n object: await s3.getObject(objectParams).promise(),\n params: objectParams\n };\n }\n }\n};\n"],"mappings":";;;;;;;;;AAAA;;AACA;;AACA;;AAIA,MAAMA,0BAA0B,GAAGC,OAAO,CAACC,GAAR,CAAYF,0BAA/C;;AAUA,MAAMG,0BAA0B,GAAG,OAAO;EAAEC,GAAF;EAAOC,eAAP;EAAwBC;AAAxB,CAAP,KAAgE;EAC/F,OAAO,MAAMA,OAAO,CAACC,aAAR,CAAsBC,MAAtB,CAA6B;IACtCC,IAAI,EAAET,0BADgC;IAEtCU,OAAO,EAAE;MACLC,IAAI,EAAE;QACFP,GADE;QAEFC;MAFE;IADD;EAF6B,CAA7B,CAAb;AASH,CAVD;;eA+Be;EACXO,UAAU,EAAGC,MAAD,IAA8B;IACtC,OAAOC,wBAAA,CAAiBC,QAAjB,CAA0BF,MAAM,CAACG,IAAP,CAAYC,SAAtC,CAAP;EACH,CAHU;;EAIX,MAAMhB,OAAN,CAAc;IAAEiB,EAAF;IAAMF,IAAN;IAAYG,OAAZ;IAAqBb;EAArB,CAAd,EAA6D;IACzD;IACA,IAAIc,YAAJ;IAEA,MAAMf,eAAe,GAAG,IAAAgB,qCAAA,EAA6BF,OAA7B,CAAxB;;IAEA,IAAId,eAAe,IAAIiB,sCAAA,CAA+BP,QAA/B,CAAwCC,IAAI,CAACC,SAA7C,CAAvB,EAAgF;MAC5EG,YAAY,GAAG,IAAAG,sBAAA,EAAgB,IAAAC,mBAAA,EAAY;QAAEpB,GAAG,EAAEY,IAAI,CAACP,IAAZ;QAAkBJ;MAAlB,CAAZ,CAAhB,CAAf;;MACA,IAAI;QACA,OAAO;UACHoB,MAAM,EAAE,MAAMP,EAAE,CAACQ,SAAH,CAAaN,YAAb,EAA2BO,OAA3B,EADX;UAEHd,MAAM,EAAEO;QAFL,CAAP;MAIH,CALD,CAKE,OAAOQ,CAAP,EAAU;QACR,MAAMC,8BAA8B,GAAG,MAAM1B,0BAA0B,CAAC;UACpEC,GAAG,EAAEY,IAAI,CAACP,IAD0D;UAEpEJ,eAFoE;UAGpEC;QAHoE,CAAD,CAAvE;;QAMA,IAAIuB,8BAA8B,CAACC,KAAnC,EAA0C;UACtC,MAAMC,KAAK,CAACF,8BAA8B,CAACG,OAAhC,CAAX;QACH;;QAED,OAAO;UACHP,MAAM,EAAE,MAAMP,EAAE,CAACQ,SAAH,CAAaN,YAAb,EAA2BO,OAA3B,EADX;UAEHd,MAAM,EAAEO;QAFL,CAAP;MAIH;IACJ;;IAEDA,YAAY,GAAG,IAAAG,sBAAA,EAAgB,IAAAC,mBAAA,EAAY;MAAEpB,GAAG,EAAEY,IAAI,CAACP;IAAZ,CAAZ,CAAhB,CAAf;;IACA,IAAI;MACA,OAAO;QACHgB,MAAM,EAAE,MAAMP,EAAE,CAACQ,SAAH,CAAaN,YAAb,EAA2BO,OAA3B,EADX;QAEHd,MAAM,EAAEO;MAFL,CAAP;IAIH,CALD,CAKE,OAAOQ,CAAP,EAAU;MACR,MAAMC,8BAA8B,GAAG,MAAM1B,0BAA0B,CAAC;QACpEC,GAAG,EAAEY,IAAI,CAACP,IAD0D;QAEpEH;MAFoE,CAAD,CAAvE;;MAKA,IAAIuB,8BAA8B,CAACC,KAAnC,EAA0C;QACtC,MAAMC,KAAK,CAACF,8BAA8B,CAACG,OAAhC,CAAX;MACH;;MAED,OAAO;QACHP,MAAM,EAAE,MAAMP,EAAE,CAACQ,SAAH,CAAaN,YAAb,EAA2BO,OAA3B,EADX;QAEHd,MAAM,EAAEO;MAFL,CAAP;IAIH;EACJ;;AAxDU,C"}
@@ -18,9 +18,12 @@ var _default = {
18
18
 
19
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.
24
+
22
25
 
23
- return key.startsWith(_utils2.OPTIMIZED_IMAGE_PREFIX) || key.startsWith(_utils2.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX);
26
+ return !(key.startsWith(_utils2.OPTIMIZED_IMAGE_PREFIX) || key.startsWith(_utils2.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX));
24
27
  },
25
28
 
26
29
  async process({