@webiny/api-file-manager 0.0.0-mt-3 → 0.0.0-unstable.2af142b57e

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 (102) hide show
  1. package/handlers/download/index.d.ts +3 -3
  2. package/handlers/download/index.js +64 -76
  3. package/handlers/download/index.js.map +1 -0
  4. package/handlers/manage/index.d.ts +5 -3
  5. package/handlers/manage/index.js +43 -58
  6. package/handlers/manage/index.js.map +1 -0
  7. package/handlers/transform/index.d.ts +2 -3
  8. package/handlers/transform/index.js +62 -77
  9. package/handlers/transform/index.js.map +1 -0
  10. package/handlers/transform/loaders/imageLoader.d.ts +26 -9
  11. package/handlers/transform/loaders/imageLoader.js +3 -21
  12. package/handlers/transform/loaders/imageLoader.js.map +1 -0
  13. package/handlers/transform/loaders/index.d.ts +4 -9
  14. package/handlers/transform/loaders/index.js +1 -4
  15. package/handlers/transform/loaders/index.js.map +1 -0
  16. package/handlers/transform/loaders/sanitizeImageTransformations.d.ts +7 -3
  17. package/handlers/transform/loaders/sanitizeImageTransformations.js +24 -30
  18. package/handlers/transform/loaders/sanitizeImageTransformations.js.map +1 -0
  19. package/handlers/transform/managers/imageManager.d.ts +12 -6
  20. package/handlers/transform/managers/imageManager.js +25 -25
  21. package/handlers/transform/managers/imageManager.js.map +1 -0
  22. package/handlers/transform/managers/index.d.ts +2 -6
  23. package/handlers/transform/managers/index.js +1 -4
  24. package/handlers/transform/managers/index.js.map +1 -0
  25. package/handlers/transform/optimizeImage.d.ts +2 -1
  26. package/handlers/transform/optimizeImage.js +4 -7
  27. package/handlers/transform/optimizeImage.js.map +1 -0
  28. package/handlers/transform/transformImage.d.ts +5 -4
  29. package/handlers/transform/transformImage.js +4 -9
  30. package/handlers/transform/transformImage.js.map +1 -0
  31. package/handlers/transform/utils.d.ts +2 -2
  32. package/handlers/transform/utils.js +1 -11
  33. package/handlers/transform/utils.js.map +1 -0
  34. package/handlers/types.d.ts +8 -0
  35. package/handlers/types.js +5 -0
  36. package/handlers/types.js.map +1 -0
  37. package/handlers/utils/getEnvironment.js +0 -2
  38. package/handlers/utils/getEnvironment.js.map +1 -0
  39. package/handlers/utils/getObjectParams.d.ts +3 -4
  40. package/handlers/utils/getObjectParams.js +1 -7
  41. package/handlers/utils/getObjectParams.js.map +1 -0
  42. package/handlers/utils/index.d.ts +0 -1
  43. package/handlers/utils/index.js +1 -12
  44. package/handlers/utils/index.js.map +1 -0
  45. package/package.json +28 -27
  46. package/plugins/crud/files/validation.js +1 -7
  47. package/plugins/crud/files/validation.js.map +1 -0
  48. package/plugins/crud/files.crud.d.ts +1 -1
  49. package/plugins/crud/files.crud.js +43 -98
  50. package/plugins/crud/files.crud.js.map +1 -0
  51. package/plugins/crud/settings.crud.d.ts +1 -1
  52. package/plugins/crud/settings.crud.js +10 -26
  53. package/plugins/crud/settings.crud.js.map +1 -0
  54. package/plugins/crud/system.crud.d.ts +1 -1
  55. package/plugins/crud/system.crud.js +17 -39
  56. package/plugins/crud/system.crud.js.map +1 -0
  57. package/plugins/crud/utils/checkBasePermissions.js +1 -9
  58. package/plugins/crud/utils/checkBasePermissions.js.map +1 -0
  59. package/plugins/crud/utils/createFileModel.d.ts +3 -0
  60. package/plugins/crud/utils/createFileModel.js +11 -10
  61. package/plugins/crud/utils/createFileModel.js.map +1 -0
  62. package/plugins/crud/utils/lifecycleEvents.d.ts +2 -2
  63. package/plugins/crud/utils/lifecycleEvents.js +8 -11
  64. package/plugins/crud/utils/lifecycleEvents.js.map +1 -0
  65. package/plugins/definitions/FilePhysicalStoragePlugin.d.ts +10 -11
  66. package/plugins/definitions/FilePhysicalStoragePlugin.js +1 -12
  67. package/plugins/definitions/FilePhysicalStoragePlugin.js.map +1 -0
  68. package/plugins/definitions/FilePlugin.d.ts +6 -3
  69. package/plugins/definitions/FilePlugin.js +7 -19
  70. package/plugins/definitions/FilePlugin.js.map +1 -0
  71. package/plugins/definitions/FileStorageTransformPlugin.d.ts +9 -9
  72. package/plugins/definitions/FileStorageTransformPlugin.js +2 -13
  73. package/plugins/definitions/FileStorageTransformPlugin.js.map +1 -0
  74. package/plugins/definitions/FilesStorageOperationsProviderPlugin.d.ts +4 -4
  75. package/plugins/definitions/FilesStorageOperationsProviderPlugin.js +1 -6
  76. package/plugins/definitions/FilesStorageOperationsProviderPlugin.js.map +1 -0
  77. package/plugins/definitions/InstallationPlugin.d.ts +9 -9
  78. package/plugins/definitions/InstallationPlugin.js +4 -13
  79. package/plugins/definitions/InstallationPlugin.js.map +1 -0
  80. package/plugins/definitions/SettingsStorageOperationsProviderPlugin.d.ts +4 -4
  81. package/plugins/definitions/SettingsStorageOperationsProviderPlugin.js +1 -6
  82. package/plugins/definitions/SettingsStorageOperationsProviderPlugin.js.map +1 -0
  83. package/plugins/definitions/SystemStorageOperationsProviderPlugin.d.ts +4 -4
  84. package/plugins/definitions/SystemStorageOperationsProviderPlugin.js +1 -6
  85. package/plugins/definitions/SystemStorageOperationsProviderPlugin.js.map +1 -0
  86. package/plugins/graphql.js +21 -25
  87. package/plugins/graphql.js.map +1 -0
  88. package/plugins/index.d.ts +1 -1
  89. package/plugins/index.js +1 -10
  90. package/plugins/index.js.map +1 -0
  91. package/plugins/storage/FileStorage.d.ts +23 -24
  92. package/plugins/storage/FileStorage.js +35 -45
  93. package/plugins/storage/FileStorage.js.map +1 -0
  94. package/plugins/storage/index.d.ts +1 -1
  95. package/plugins/storage/index.js +6 -6
  96. package/plugins/storage/index.js.map +1 -0
  97. package/types.d.ts +16 -12
  98. package/types.js.map +1 -0
  99. package/utils.js +0 -2
  100. package/utils.js.map +1 -0
  101. package/handlers/utils/createHandler.d.ts +0 -24
  102. package/handlers/utils/createHandler.js +0 -68
@@ -1,3 +1,3 @@
1
- import { HandlerPlugin } from "@webiny/handler/types";
2
- declare const _default: () => HandlerPlugin;
3
- 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>[];
@@ -1,87 +1,81 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
- exports.default = void 0;
9
-
7
+ exports.createDownloadFilePlugins = void 0;
10
8
  var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
11
-
12
9
  var _sanitizeFilename = _interopRequireDefault(require("sanitize-filename"));
13
-
14
10
  var _path = _interopRequireDefault(require("path"));
15
-
16
11
  var _utils = require("../utils");
17
-
18
12
  var _loaders = _interopRequireDefault(require("../transform/loaders"));
19
-
13
+ var _gateway = require("@webiny/handler-aws/gateway");
20
14
  const MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB
21
-
22
15
  const DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year
23
-
16
+ const PRESIGNED_URL_EXPIRATION = 900; // 15 minutes
24
17
  /**
25
18
  * Based on given path, extracts file key and additional options sent via query params.
26
- * @param event
27
19
  */
28
-
29
- const extractFilenameOptions = event => {
30
- const path = (0, _sanitizeFilename.default)(event.pathParameters.path);
20
+ const extractFilenameOptions = request => {
21
+ const path = (0, _sanitizeFilename.default)(request.params.path);
31
22
  return {
32
23
  filename: decodeURI(path),
33
- options: event.queryStringParameters,
24
+ options: request.query,
34
25
  extension: _path.default.extname(path)
35
26
  };
36
27
  };
37
-
38
- const getS3Object = async (event, s3, context) => {
28
+ const getS3Object = async (request, s3, context) => {
39
29
  const {
40
30
  options,
41
31
  filename,
42
32
  extension
43
- } = extractFilenameOptions(event);
44
-
45
- for (let i = 0; i < _loaders.default.length; i++) {
46
- const loader = _loaders.default[i];
33
+ } = extractFilenameOptions(request);
34
+ const params = (0, _utils.getObjectParams)(filename);
35
+ const objectHead = await s3.headObject(params).promise();
36
+ const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;
37
+ for (const loader of _loaders.default) {
47
38
  const canProcess = loader.canProcess({
48
39
  context,
49
40
  s3,
50
41
  options,
51
42
  file: {
52
43
  name: filename,
53
- extension
44
+ extension,
45
+ contentLength
54
46
  }
55
47
  });
56
-
57
- if (canProcess) {
58
- return loader.process({
59
- context,
60
- s3,
61
- options,
62
- file: {
63
- name: filename,
64
- extension
65
- }
66
- });
48
+ if (!canProcess) {
49
+ continue;
67
50
  }
68
- } // If no processors handled the file request, just return the S3 object by default.
69
-
51
+ return loader.process({
52
+ context,
53
+ s3,
54
+ options,
55
+ file: {
56
+ name: filename,
57
+ extension,
58
+ contentLength
59
+ }
60
+ });
61
+ }
70
62
 
71
- const params = (0, _utils.getObjectParams)(filename);
63
+ // If no processors handled the file request, just return the S3 object taking its size into consideration.
64
+ let object;
65
+ if (contentLength < MAX_RETURN_CONTENT_LENGTH) {
66
+ object = await s3.getObject(params).promise();
67
+ }
72
68
  return {
73
- object: await s3.getObject(params).promise(),
74
- params: params
69
+ object,
70
+ params
75
71
  };
76
72
  };
77
-
78
- var _default = () => ({
79
- type: "handler",
80
- name: "handler-download-file",
81
-
82
- async handle(context) {
83
- const event = context.invocationArgs;
84
- const handler = (0, _utils.createHandler)(async event => {
73
+ const createDownloadFilePlugins = () => {
74
+ return [new _gateway.RoutePlugin(({
75
+ onGet,
76
+ context
77
+ }) => {
78
+ onGet("/files/:path", async (request, reply) => {
85
79
  const {
86
80
  region
87
81
  } = (0, _utils.getEnvironment)();
@@ -91,35 +85,29 @@ var _default = () => ({
91
85
  const {
92
86
  params,
93
87
  object
94
- } = await getS3Object(event, s3, context);
88
+ } = await getS3Object(request, s3, context);
89
+
90
+ // If there's an "object", it means we can return its body directly.
91
+ if (object) {
92
+ return reply.headers({
93
+ "Content-Type": object.ContentType,
94
+ "Cache-Control": `public, max-age=${DEFAULT_CACHE_MAX_AGE}`,
95
+ "x-webiny-base64-encoded": true
96
+ }).send(object.Body || "");
97
+ }
98
+ const presignedUrl = s3.getSignedUrl("getObject", {
99
+ Bucket: params.Bucket,
100
+ Key: params.Key,
101
+ Expires: PRESIGNED_URL_EXPIRATION
102
+ });
95
103
 
96
- if (object.ContentLength < MAX_RETURN_CONTENT_LENGTH) {
97
- return {
98
- data: object.Body,
99
- headers: {
100
- "Content-Type": object.ContentType,
101
- "Cache-Control": "public, max-age=" + DEFAULT_CACHE_MAX_AGE
102
- }
103
- };
104
- } // Lambda can return max 6MB of content, so if our object's size is larger, we are sending
104
+ // Lambda can return max 6MB of content, so if our object's size is larger, we are sending
105
105
  // a 301 Redirect, redirecting the user to the public URL of the object in S3.
106
-
107
-
108
- await s3.putObjectAcl({
109
- Bucket: params.Bucket,
110
- ACL: "public-read",
111
- Key: params.Key
112
- }).promise();
113
- return {
114
- statusCode: 301,
115
- headers: {
116
- Location: `https://${params.Bucket}.s3.amazonaws.com/${params.Key}`
117
- }
118
- };
106
+ return reply.code(301).headers({
107
+ Location: presignedUrl,
108
+ "Cache-Control": "public, max-age=" + PRESIGNED_URL_EXPIRATION
109
+ }).send("");
119
110
  });
120
- return await handler(event);
121
- }
122
-
123
- });
124
-
125
- exports.default = _default;
111
+ })];
112
+ };
113
+ exports.createDownloadFilePlugins = createDownloadFilePlugins;
@@ -0,0 +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,3 +1,5 @@
1
- import { HandlerPlugin } from "@webiny/handler/types";
2
- declare const _default: () => HandlerPlugin;
3
- 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>[];
@@ -1,70 +1,55 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
- exports.default = void 0;
9
-
7
+ exports.createManageFilePlugins = void 0;
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
- var _default = () => ({
19
- type: "handler",
20
- name: "handler-download-file",
21
-
22
- async handle(context) {
23
- const event = context.invocationArgs;
24
- const handler = (0, _utils.createHandler)(async event => {
25
- const keys = [];
26
-
27
- for (let i = 0; i < event.Records.length; i++) {
28
- const record = event.Records[i];
29
-
30
- if (typeof record.s3.object.key === "string") {
31
- keys.push(record.s3.object.key);
32
- }
12
+ var _handlerAws = require("@webiny/handler-aws");
13
+ /**
14
+ * This handler must be run through @webiny/handler-aws/s3
15
+ */
16
+ const createManageFilePlugins = () => {
17
+ return [new _handlerAws.S3EventHandler(async ({
18
+ event
19
+ }) => {
20
+ const keys = [];
21
+ for (let i = 0; i < event.Records.length; i++) {
22
+ const record = event.Records[i];
23
+ if (typeof record.s3.object.key === "string") {
24
+ keys.push(record.s3.object.key);
33
25
  }
34
-
35
- const {
36
- region
37
- } = (0, _utils.getEnvironment)();
38
- const s3 = new _s.default({
39
- region
40
- });
41
-
42
- for (let i = 0; i < keys.length; i++) {
43
- const key = keys[i];
44
-
45
- const extension = _path.default.extname(key);
46
-
47
- for (let j = 0; j < _managers.default.length; j++) {
48
- const manager = _managers.default[j];
49
- const canProcess = manager.canProcess({
50
- s3,
51
- key,
52
- extension
53
- });
54
-
55
- if (canProcess) {
56
- await manager.process({
57
- s3,
58
- key,
59
- extension
60
- });
61
- }
26
+ }
27
+ if (keys.length === 0) {
28
+ return;
29
+ }
30
+ const {
31
+ region
32
+ } = (0, _utils.getEnvironment)();
33
+ const s3 = new _s.default({
34
+ region
35
+ });
36
+ for (const key of keys) {
37
+ const extension = _path.default.extname(key);
38
+ for (const manager of _managers.default) {
39
+ const canProcess = manager.canProcess({
40
+ key,
41
+ extension
42
+ });
43
+ if (!canProcess) {
44
+ continue;
62
45
  }
46
+ await manager.process({
47
+ s3,
48
+ key,
49
+ extension
50
+ });
63
51
  }
64
- });
65
- return await handler(event);
66
- }
67
-
68
- });
69
-
70
- exports.default = _default;
52
+ }
53
+ })];
54
+ };
55
+ exports.createManageFilePlugins = createManageFilePlugins;
@@ -0,0 +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,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,3 +1,2 @@
1
- import { HandlerPlugin } from "@webiny/handler/types";
2
- declare const _default: () => HandlerPlugin;
3
- export default _default;
1
+ import { TransformHandlerEventPayload } from "../types";
2
+ export declare const createTransformFilePlugins: () => import("@webiny/handler").EventPlugin<TransformHandlerEventPayload, import("@webiny/handler/types").Context, any>[];
@@ -1,96 +1,81 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
- exports.default = void 0;
9
-
10
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
-
7
+ exports.createTransformFilePlugins = void 0;
8
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
12
9
  var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
13
-
14
10
  var _transformImage = _interopRequireDefault(require("./transformImage"));
15
-
16
11
  var _optimizeImage = _interopRequireDefault(require("./optimizeImage"));
17
-
18
12
  var _utils = require("../utils");
19
-
20
13
  var _utils2 = require("./utils");
21
-
22
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
23
-
24
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
25
-
26
- var _default = () => ({
27
- type: "handler",
28
- name: "handler-download-file",
29
-
30
- async handle(context) {
31
- const event = context.invocationArgs;
32
- const handler = (0, _utils.createHandler)(async ({
33
- body: {
34
- transformations,
35
- key
36
- }
37
- }) => {
14
+ var _handler = require("@webiny/handler");
15
+ const createTransformFilePlugins = () => {
16
+ return [(0, _handler.createEvent)(async ({
17
+ payload
18
+ }) => {
19
+ const {
20
+ body
21
+ } = payload;
22
+ const {
23
+ key,
24
+ transformations
25
+ } = body;
26
+ try {
27
+ const env = (0, _utils.getEnvironment)();
28
+ const s3 = new _s.default({
29
+ region: env.region
30
+ });
31
+ let optimizedImageObject;
32
+ const params = {
33
+ initial: (0, _utils.getObjectParams)(key),
34
+ optimized: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
35
+ key
36
+ })),
37
+ optimizedTransformed: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
38
+ key,
39
+ transformations
40
+ }))
41
+ };
42
+
43
+ // 1. Get optimized image.
38
44
  try {
39
- const env = (0, _utils.getEnvironment)();
40
- const s3 = new _s.default({
41
- region: env.region
42
- });
43
- let optimizedImageObject;
44
- const params = {
45
- initial: (0, _utils.getObjectParams)(key),
46
- optimized: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
47
- key
48
- })),
49
- optimizedTransformed: (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
50
- key,
51
- transformations
52
- }))
53
- }; // 1. Get optimized image.
54
-
55
- try {
56
- optimizedImageObject = await s3.getObject(params.optimized).promise();
57
- } catch (e) {
58
- // If not found, try to create it by loading the initially uploaded image.
59
- optimizedImageObject = await s3.getObject(params.initial).promise();
60
- await s3.putObject(_objectSpread(_objectSpread({}, params.optimized), {}, {
61
- ContentType: optimizedImageObject.ContentType,
62
- Body: await (0, _optimizeImage.default)(optimizedImageObject.Body, optimizedImageObject.ContentType)
63
- })).promise();
64
- optimizedImageObject = await s3.getObject(params.optimized).promise();
65
- } // 2. If no transformations requested, just exit.
66
-
67
-
68
- if (!transformations) {
69
- return {
70
- error: false,
71
- message: ""
72
- };
73
- } // 3. If transformations requested, apply them in save it into the bucket.
74
-
75
-
76
- await s3.putObject(_objectSpread(_objectSpread({}, params.optimizedTransformed), {}, {
45
+ optimizedImageObject = await s3.getObject(params.optimized).promise();
46
+ } catch (e) {
47
+ // If not found, try to create it by loading the initially uploaded image.
48
+ optimizedImageObject = await s3.getObject(params.initial).promise();
49
+ await s3.putObject((0, _objectSpread2.default)((0, _objectSpread2.default)({}, params.optimized), {}, {
77
50
  ContentType: optimizedImageObject.ContentType,
78
- Body: await (0, _transformImage.default)(optimizedImageObject.Body, transformations)
51
+ Body: await (0, _optimizeImage.default)(optimizedImageObject.Body, optimizedImageObject.ContentType)
79
52
  })).promise();
53
+ optimizedImageObject = await s3.getObject(params.optimized).promise();
54
+ }
55
+
56
+ // 2. If no transformations requested, just exit.
57
+ if (!transformations) {
80
58
  return {
81
59
  error: false,
82
60
  message: ""
83
61
  };
84
- } catch (e) {
85
- return {
86
- error: true,
87
- message: e.message
88
- };
89
62
  }
90
- });
91
- return await handler(event);
92
- }
93
-
94
- });
95
63
 
96
- exports.default = _default;
64
+ // 3. If transformations requested, apply them in save it into the bucket.
65
+ await s3.putObject((0, _objectSpread2.default)((0, _objectSpread2.default)({}, params.optimizedTransformed), {}, {
66
+ ContentType: optimizedImageObject.ContentType,
67
+ Body: await (0, _transformImage.default)(optimizedImageObject.Body, transformations)
68
+ })).promise();
69
+ return {
70
+ error: false,
71
+ message: ""
72
+ };
73
+ } catch (e) {
74
+ return {
75
+ error: true,
76
+ message: e.message
77
+ };
78
+ }
79
+ })];
80
+ };
81
+ exports.createTransformFilePlugins = createTransformFilePlugins;
@@ -0,0 +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"],"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,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,MAAM,GAAG;QACXC,OAAO,EAAE,IAAAC,sBAAe,EAACV,GAAG,CAAC;QAC7BW,SAAS,EAAE,IAAAD,sBAAe,EAAC,IAAAE,mBAAW,EAAC;UAAEZ;QAAI,CAAC,CAAC,CAAC;QAChDa,oBAAoB,EAAE,IAAAH,sBAAe,EAAC,IAAAE,mBAAW,EAAC;UAAEZ,GAAG;UAAEC;QAAgB,CAAC,CAAC;MAC/E,CAAC;;MAED;MACA,IAAI;QACAM,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAS,CAACN,MAAM,CAACG,SAAS,CAAC,CAACI,OAAO,EAAE;MACzE,CAAC,CAAC,OAAOC,CAAC,EAAE;QACR;QACAT,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAS,CAACN,MAAM,CAACC,OAAO,CAAC,CAACM,OAAO,EAAE;QAEnE,MAAMX,EAAE,CACHa,SAAS,6DACHT,MAAM,CAACG,SAAS;UACnBO,WAAW,EAAEX,oBAAoB,CAACW,WAAW;UAC7CC,IAAI,EAAE,MAAM,IAAAC,sBAAa,EACrBb,oBAAoB,CAACY,IAAI,EACzBZ,oBAAoB,CAACW,WAAW;QACnC,GACH,CACDH,OAAO,EAAE;QAEdR,oBAAoB,GAAG,MAAMH,EAAE,CAACU,SAAS,CAACN,MAAM,CAACG,SAAS,CAAC,CAACI,OAAO,EAAE;MACzE;;MAEA;MACA,IAAI,CAACd,eAAe,EAAE;QAClB,OAAO;UACHoB,KAAK,EAAE,KAAK;UACZC,OAAO,EAAE;QACb,CAAC;MACL;;MAEA;MACA,MAAMlB,EAAE,CACHa,SAAS,6DACHT,MAAM,CAACK,oBAAoB;QAC9BK,WAAW,EAAEX,oBAAoB,CAACW,WAAW;QAC7CC,IAAI,EAAE,MAAM,IAAAI,uBAAc,EACtBhB,oBAAoB,CAACY,IAAI,EACzBlB,eAAe;MAClB,GACH,CACDc,OAAO,EAAE;MAEd,OAAO;QACHM,KAAK,EAAE,KAAK;QACZC,OAAO,EAAE;MACb,CAAC;IACL,CAAC,CAAC,OAAON,CAAC,EAAE;MACR,OAAO;QACHK,KAAK,EAAE,IAAI;QACXC,OAAO,EAAEN,CAAC,CAACM;MACf,CAAC;IACL;EACJ,CAAC,CAAC,CACL;AACL,CAAC;AAAC"}
@@ -1,13 +1,30 @@
1
+ import { ClientContext } from "@webiny/handler-client/types";
2
+ import S3 from "aws-sdk/clients/s3";
3
+ interface File {
4
+ extension: string;
5
+ name: string;
6
+ contentLength: number;
7
+ }
8
+ interface Options {
9
+ width?: string;
10
+ }
11
+ export interface CanProcessParams {
12
+ s3: S3;
13
+ file: File;
14
+ options?: Options;
15
+ context: ClientContext;
16
+ }
17
+ export interface ProcessParams {
18
+ s3: S3;
19
+ file: File;
20
+ options?: Options;
21
+ context: ClientContext;
22
+ }
1
23
  declare const _default: {
2
- canProcess: (opts: any) => boolean;
3
- process({ s3, file, options, context }: {
4
- s3: any;
5
- file: any;
6
- options: any;
7
- context: any;
8
- }): Promise<{
9
- object: any;
10
- params: any;
24
+ canProcess: (params: CanProcessParams) => boolean;
25
+ process({ s3, file, options, context }: ProcessParams): Promise<{
26
+ object: import("aws-sdk/lib/request").PromiseResult<S3.GetObjectOutput, import("aws-sdk/lib/error").AWSError>;
27
+ params: import("../../utils/getObjectParams").ObjectParamsResponse;
11
28
  }>;
12
29
  };
13
30
  export default _default;
@@ -1,21 +1,14 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.default = void 0;
9
-
10
8
  var _sanitizeImageTransformations = _interopRequireDefault(require("./sanitizeImageTransformations"));
11
-
12
9
  var _utils = require("../../utils");
13
-
14
10
  var _utils2 = require("../utils");
15
-
16
- // @ts-ignore
17
11
  const IMAGE_TRANSFORMER_FUNCTION = process.env.IMAGE_TRANSFORMER_FUNCTION;
18
-
19
12
  const callImageTransformerLambda = async ({
20
13
  key,
21
14
  transformations,
@@ -31,12 +24,10 @@ const callImageTransformerLambda = async ({
31
24
  }
32
25
  });
33
26
  };
34
-
35
27
  var _default = {
36
- canProcess: opts => {
37
- return _utils2.SUPPORTED_IMAGES.includes(opts.file.extension);
28
+ canProcess: params => {
29
+ return _utils2.SUPPORTED_IMAGES.includes(params.file.extension);
38
30
  },
39
-
40
31
  async process({
41
32
  s3,
42
33
  file,
@@ -46,13 +37,11 @@ var _default = {
46
37
  // Loaders must return {object, params} object.
47
38
  let objectParams;
48
39
  const transformations = (0, _sanitizeImageTransformations.default)(options);
49
-
50
40
  if (transformations && _utils2.SUPPORTED_TRANSFORMABLE_IMAGES.includes(file.extension)) {
51
41
  objectParams = (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
52
42
  key: file.name,
53
43
  transformations
54
44
  }));
55
-
56
45
  try {
57
46
  return {
58
47
  object: await s3.getObject(objectParams).promise(),
@@ -64,22 +53,18 @@ var _default = {
64
53
  transformations,
65
54
  context
66
55
  });
67
-
68
56
  if (imageTransformerLambdaResponse.error) {
69
57
  throw Error(imageTransformerLambdaResponse.message);
70
58
  }
71
-
72
59
  return {
73
60
  object: await s3.getObject(objectParams).promise(),
74
61
  params: objectParams
75
62
  };
76
63
  }
77
64
  }
78
-
79
65
  objectParams = (0, _utils.getObjectParams)((0, _utils2.getImageKey)({
80
66
  key: file.name
81
67
  }));
82
-
83
68
  try {
84
69
  return {
85
70
  object: await s3.getObject(objectParams).promise(),
@@ -90,17 +75,14 @@ var _default = {
90
75
  key: file.name,
91
76
  context
92
77
  });
93
-
94
78
  if (imageTransformerLambdaResponse.error) {
95
79
  throw Error(imageTransformerLambdaResponse.message);
96
80
  }
97
-
98
81
  return {
99
82
  object: await s3.getObject(objectParams).promise(),
100
83
  params: objectParams
101
84
  };
102
85
  }
103
86
  }
104
-
105
87
  };
106
88
  exports.default = _default;