@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.
- package/createFileManager/checkBasePermissions.d.ts +5 -0
- package/createFileManager/checkBasePermissions.js +24 -0
- package/createFileManager/checkBasePermissions.js.map +1 -0
- package/createFileManager/files.crud.d.ts +3 -0
- package/createFileManager/files.crud.js +318 -0
- package/createFileManager/files.crud.js.map +1 -0
- package/createFileManager/filevalidation.disabled.d.ts +0 -0
- package/createFileManager/filevalidation.disabled.js +55 -0
- package/createFileManager/filevalidation.disabled.js.map +1 -0
- package/createFileManager/index.d.ts +13 -0
- package/createFileManager/index.js +20 -0
- package/createFileManager/index.js.map +1 -0
- package/createFileManager/settings.crud.d.ts +3 -0
- package/createFileManager/settings.crud.js +91 -0
- package/createFileManager/settings.crud.js.map +1 -0
- package/createFileManager/system.crud.d.ts +3 -0
- package/createFileManager/system.crud.js +86 -0
- package/createFileManager/system.crud.js.map +1 -0
- package/graphql/index.d.ts +3 -0
- package/graphql/index.js +288 -0
- package/graphql/index.js.map +1 -0
- package/handlers/download/byAlias.d.ts +6 -0
- package/handlers/download/byAlias.js +89 -0
- package/handlers/download/byAlias.js.map +1 -0
- package/handlers/download/byExactKey.d.ts +2 -0
- package/handlers/download/byExactKey.js +57 -0
- package/handlers/download/byExactKey.js.map +1 -0
- package/handlers/download/extractFileInformation.d.ts +9 -0
- package/handlers/download/extractFileInformation.js +20 -0
- package/handlers/download/extractFileInformation.js.map +1 -0
- package/handlers/download/getS3Object.d.ts +10 -0
- package/handlers/download/getS3Object.js +57 -0
- package/handlers/download/getS3Object.js.map +1 -0
- package/handlers/download/index.d.ts +2 -3
- package/handlers/download/index.js +21 -126
- package/handlers/download/index.js.map +1 -1
- package/handlers/manage/index.js +0 -16
- package/handlers/manage/index.js.map +1 -1
- package/handlers/transform/index.js +12 -19
- package/handlers/transform/index.js.map +1 -1
- package/handlers/transform/legacyUtils.d.ts +17 -0
- package/handlers/transform/legacyUtils.js +42 -0
- package/handlers/transform/legacyUtils.js.map +1 -0
- package/handlers/transform/loaders/imageLoader.d.ts +1 -1
- package/handlers/transform/loaders/imageLoader.js +12 -23
- package/handlers/transform/loaders/imageLoader.js.map +1 -1
- package/handlers/transform/loaders/index.d.ts +1 -1
- package/handlers/transform/loaders/index.js +0 -3
- package/handlers/transform/loaders/index.js.map +1 -1
- package/handlers/transform/loaders/sanitizeImageTransformations.js +0 -13
- package/handlers/transform/loaders/sanitizeImageTransformations.js.map +1 -1
- package/handlers/transform/managers/imageManager.js +32 -21
- package/handlers/transform/managers/imageManager.js.map +1 -1
- package/handlers/transform/managers/index.js +0 -3
- package/handlers/transform/managers/index.js.map +1 -1
- package/handlers/transform/optimizeImage.js +0 -6
- package/handlers/transform/optimizeImage.js.map +1 -1
- package/handlers/transform/transformImage.js +0 -5
- package/handlers/transform/transformImage.js.map +1 -1
- package/handlers/transform/utils.d.ts +1 -1
- package/handlers/transform/utils.js +7 -17
- package/handlers/transform/utils.js.map +1 -1
- package/handlers/utils/getEnvironment.js +0 -2
- package/handlers/utils/getEnvironment.js.map +1 -1
- package/handlers/utils/getObjectParams.js +0 -4
- package/handlers/utils/getObjectParams.js.map +1 -1
- package/handlers/utils/index.js +0 -3
- package/handlers/utils/index.js.map +1 -1
- package/index.d.ts +6 -0
- package/index.js +68 -0
- package/index.js.map +1 -0
- package/package.json +21 -23
- package/plugins/FilePhysicalStoragePlugin.d.ts +21 -0
- package/plugins/FilePhysicalStoragePlugin.js +31 -0
- package/plugins/FilePhysicalStoragePlugin.js.map +1 -0
- package/plugins/FileStorageTransformPlugin.d.ts +34 -0
- package/plugins/FileStorageTransformPlugin.js +40 -0
- package/plugins/FileStorageTransformPlugin.js.map +1 -0
- package/plugins/graphql.js +3 -3
- package/plugins/graphql.js.map +1 -1
- package/plugins/index.d.ts +2 -2
- package/plugins/index.js +22 -19
- package/plugins/index.js.map +1 -1
- package/storage/FileStorage.d.ts +32 -0
- package/storage/FileStorage.js +86 -0
- package/storage/FileStorage.js.map +1 -0
- package/types/file.d.ts +33 -0
- package/types/file.js +5 -0
- package/types/file.js.map +1 -0
- package/types/file.lifecycle.d.ts +40 -0
- package/types/file.lifecycle.js +5 -0
- package/types/file.lifecycle.js.map +1 -0
- package/types.d.ts +44 -45
- package/types.js +22 -0
- package/types.js.map +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["IMAGE_TRANSFORMER_FUNCTION","process","env","callImageTransformerLambda","key","transformations","context","handlerClient","invoke","name","payload","body","canProcess","
|
|
1
|
+
{"version":3,"names":["IMAGE_TRANSFORMER_FUNCTION","process","env","callImageTransformerLambda","key","transformations","context","handlerClient","invoke","name","payload","body","canProcess","file","utils","includes","newUtils","legacyUtils","SUPPORTED_IMAGES","extension","s3","options","objectParams","sanitizeImageTransformations","SUPPORTED_TRANSFORMABLE_IMAGES","getObjectParams","getImageKey","object","getObject","promise","params","e","imageTransformerLambdaResponse","error","Error","message"],"sources":["imageLoader.ts"],"sourcesContent":["import sanitizeImageTransformations from \"./sanitizeImageTransformations\";\nimport { getObjectParams } from \"../../utils\";\nimport * as newUtils from \"../utils\";\nimport * as legacyUtils from \"../legacyUtils\";\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: ({ file }: CanProcessParams) => {\n const utils = file.name.includes(\"/\") ? newUtils : legacyUtils;\n return utils.SUPPORTED_IMAGES.includes(file.extension);\n },\n async process({ s3, file, options, context }: ProcessParams) {\n // Loaders must return {object, params} object.\n let objectParams;\n\n const utils = file.name.includes(\"/\") ? newUtils : legacyUtils;\n\n const transformations = sanitizeImageTransformations(options);\n\n if (transformations && utils.SUPPORTED_TRANSFORMABLE_IMAGES.includes(file.extension)) {\n objectParams = getObjectParams(utils.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(utils.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":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
declare const _default: {
|
|
2
|
-
canProcess: (
|
|
2
|
+
canProcess: ({ file }: import("./imageLoader").CanProcessParams) => boolean;
|
|
3
3
|
process({ s3, file, options, context }: import("./imageLoader").ProcessParams): Promise<{
|
|
4
4
|
object: import("aws-sdk/lib/request").PromiseResult<import("aws-sdk/clients/s3").GetObjectOutput, import("aws-sdk/lib/error").AWSError>;
|
|
5
5
|
params: import("../../utils/getObjectParams").ObjectParamsResponse;
|
|
@@ -1,13 +1,10 @@
|
|
|
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.default = void 0;
|
|
9
|
-
|
|
10
8
|
var _imageLoader = _interopRequireDefault(require("./imageLoader"));
|
|
11
|
-
|
|
12
9
|
var _default = [_imageLoader.default];
|
|
13
10
|
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["imageLoader"],"sources":["index.ts"],"sourcesContent":["import imageLoader from \"./imageLoader\";\n\nexport default [imageLoader];\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":["imageLoader"],"sources":["index.ts"],"sourcesContent":["import imageLoader from \"./imageLoader\";\n\nexport default [imageLoader];\n"],"mappings":";;;;;;;AAAA;AAAwC,eAEzB,CAACA,oBAAW,CAAC;AAAA"}
|
|
@@ -5,54 +5,41 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
7
|
const SUPPORTED_IMAGE_RESIZE_WIDTHS = [100, 300, 500, 750, 1000, 1500, 2500];
|
|
8
|
-
|
|
9
8
|
/**
|
|
10
9
|
* Takes only allowed transformations into consideration, and discards the rest.
|
|
11
10
|
*/
|
|
12
11
|
var _default = args => {
|
|
13
12
|
const transformations = {};
|
|
14
|
-
|
|
15
13
|
if (!args || !args.width) {
|
|
16
14
|
return null;
|
|
17
15
|
}
|
|
18
|
-
|
|
19
16
|
const width = parseInt(args.width);
|
|
20
|
-
|
|
21
17
|
if (width <= 0) {
|
|
22
18
|
return null;
|
|
23
19
|
}
|
|
24
|
-
|
|
25
20
|
transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[0];
|
|
26
21
|
let i = SUPPORTED_IMAGE_RESIZE_WIDTHS.length;
|
|
27
|
-
|
|
28
22
|
while (i >= 0) {
|
|
29
23
|
if (width === SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {
|
|
30
24
|
transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];
|
|
31
25
|
break;
|
|
32
26
|
}
|
|
33
|
-
|
|
34
27
|
if (width > SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {
|
|
35
28
|
// Use next larger width. If there isn't any, use current.
|
|
36
29
|
transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i + 1];
|
|
37
|
-
|
|
38
30
|
if (!transformations.width) {
|
|
39
31
|
transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];
|
|
40
32
|
}
|
|
41
|
-
|
|
42
33
|
break;
|
|
43
34
|
}
|
|
44
|
-
|
|
45
35
|
i--;
|
|
46
36
|
}
|
|
47
|
-
|
|
48
37
|
if (Object.keys(transformations).length > 0) {
|
|
49
38
|
/**
|
|
50
39
|
* It is safe to cast.
|
|
51
40
|
*/
|
|
52
41
|
return transformations;
|
|
53
42
|
}
|
|
54
|
-
|
|
55
43
|
return null;
|
|
56
44
|
};
|
|
57
|
-
|
|
58
45
|
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["SUPPORTED_IMAGE_RESIZE_WIDTHS","args","transformations","width","parseInt","i","length","Object","keys"],"sources":["sanitizeImageTransformations.ts"],"sourcesContent":["const SUPPORTED_IMAGE_RESIZE_WIDTHS: number[] = [100, 300, 500, 750, 1000, 1500, 2500];\n\nexport interface SanitizeImageArgs {\n width?: string;\n}\n\nexport interface SanitizeImageTransformations {\n width: number;\n}\n/**\n * Takes only allowed transformations into consideration, and discards the rest.\n */\nexport default (args?: SanitizeImageArgs): SanitizeImageTransformations | null => {\n const transformations: Partial<SanitizeImageTransformations> = {};\n\n if (!args || !args.width) {\n return null;\n }\n const width = parseInt(args.width);\n if (width <= 0) {\n return null;\n }\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[0];\n let i = SUPPORTED_IMAGE_RESIZE_WIDTHS.length;\n while (i >= 0) {\n if (width === SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];\n break;\n }\n\n if (width > SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {\n // Use next larger width. If there isn't any, use current.\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i + 1];\n if (!transformations.width) {\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];\n }\n break;\n }\n\n i--;\n }\n\n if (Object.keys(transformations).length > 0) {\n /**\n * It is safe to cast.\n */\n return transformations as SanitizeImageTransformations;\n }\n\n return null;\n};\n"],"mappings":";;;;;;AAAA,MAAMA,6BAAuC,GAAG,CAAC,
|
|
1
|
+
{"version":3,"names":["SUPPORTED_IMAGE_RESIZE_WIDTHS","args","transformations","width","parseInt","i","length","Object","keys"],"sources":["sanitizeImageTransformations.ts"],"sourcesContent":["const SUPPORTED_IMAGE_RESIZE_WIDTHS: number[] = [100, 300, 500, 750, 1000, 1500, 2500];\n\nexport interface SanitizeImageArgs {\n width?: string;\n}\n\nexport interface SanitizeImageTransformations {\n width: number;\n}\n/**\n * Takes only allowed transformations into consideration, and discards the rest.\n */\nexport default (args?: SanitizeImageArgs): SanitizeImageTransformations | null => {\n const transformations: Partial<SanitizeImageTransformations> = {};\n\n if (!args || !args.width) {\n return null;\n }\n const width = parseInt(args.width);\n if (width <= 0) {\n return null;\n }\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[0];\n let i = SUPPORTED_IMAGE_RESIZE_WIDTHS.length;\n while (i >= 0) {\n if (width === SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];\n break;\n }\n\n if (width > SUPPORTED_IMAGE_RESIZE_WIDTHS[i]) {\n // Use next larger width. If there isn't any, use current.\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i + 1];\n if (!transformations.width) {\n transformations.width = SUPPORTED_IMAGE_RESIZE_WIDTHS[i];\n }\n break;\n }\n\n i--;\n }\n\n if (Object.keys(transformations).length > 0) {\n /**\n * It is safe to cast.\n */\n return transformations as SanitizeImageTransformations;\n }\n\n return null;\n};\n"],"mappings":";;;;;;AAAA,MAAMA,6BAAuC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;AAStF;AACA;AACA;AAFA,eAGgBC,IAAwB,IAA0C;EAC9E,MAAMC,eAAsD,GAAG,CAAC,CAAC;EAEjE,IAAI,CAACD,IAAI,IAAI,CAACA,IAAI,CAACE,KAAK,EAAE;IACtB,OAAO,IAAI;EACf;EACA,MAAMA,KAAK,GAAGC,QAAQ,CAACH,IAAI,CAACE,KAAK,CAAC;EAClC,IAAIA,KAAK,IAAI,CAAC,EAAE;IACZ,OAAO,IAAI;EACf;EACAD,eAAe,CAACC,KAAK,GAAGH,6BAA6B,CAAC,CAAC,CAAC;EACxD,IAAIK,CAAC,GAAGL,6BAA6B,CAACM,MAAM;EAC5C,OAAOD,CAAC,IAAI,CAAC,EAAE;IACX,IAAIF,KAAK,KAAKH,6BAA6B,CAACK,CAAC,CAAC,EAAE;MAC5CH,eAAe,CAACC,KAAK,GAAGH,6BAA6B,CAACK,CAAC,CAAC;MACxD;IACJ;IAEA,IAAIF,KAAK,GAAGH,6BAA6B,CAACK,CAAC,CAAC,EAAE;MAC1C;MACAH,eAAe,CAACC,KAAK,GAAGH,6BAA6B,CAACK,CAAC,GAAG,CAAC,CAAC;MAC5D,IAAI,CAACH,eAAe,CAACC,KAAK,EAAE;QACxBD,eAAe,CAACC,KAAK,GAAGH,6BAA6B,CAACK,CAAC,CAAC;MAC5D;MACA;IACJ;IAEAA,CAAC,EAAE;EACP;EAEA,IAAIE,MAAM,CAACC,IAAI,CAACN,eAAe,CAAC,CAACI,MAAM,GAAG,CAAC,EAAE;IACzC;AACR;AACA;IACQ,OAAOJ,eAAe;EAC1B;EAEA,OAAO,IAAI;AACf,CAAC;AAAA"}
|
|
@@ -1,63 +1,74 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
3
4
|
Object.defineProperty(exports, "__esModule", {
|
|
4
5
|
value: true
|
|
5
6
|
});
|
|
6
7
|
exports.default = void 0;
|
|
7
|
-
|
|
8
|
+
var _path = require("path");
|
|
8
9
|
var _utils = require("../../utils");
|
|
9
|
-
|
|
10
|
-
var
|
|
11
|
-
|
|
10
|
+
var newUtils = _interopRequireWildcard(require("../utils"));
|
|
11
|
+
var legacyUtils = _interopRequireWildcard(require("../legacyUtils"));
|
|
12
|
+
const isLegacyKey = key => {
|
|
13
|
+
return !key.includes("/");
|
|
14
|
+
};
|
|
12
15
|
var _default = {
|
|
13
16
|
canProcess: params => {
|
|
14
17
|
const {
|
|
15
18
|
key,
|
|
16
19
|
extension
|
|
17
20
|
} = params;
|
|
18
|
-
|
|
19
|
-
if (
|
|
21
|
+
const utils = key.includes("/") ? newUtils : legacyUtils;
|
|
22
|
+
if (!utils.SUPPORTED_IMAGES.includes(extension)) {
|
|
20
23
|
return false;
|
|
21
|
-
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// We only want to process original images, and delete all variations of it at once.
|
|
22
27
|
// We DO NOT want to process the event for the deletion of an optimized/transformed image.
|
|
23
28
|
// Unfortunately, there's no way to filter those events on the S3 bucket itself, so we have to do it this way.
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
return !(key.startsWith(_utils2.OPTIMIZED_IMAGE_PREFIX) || key.startsWith(_utils2.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX));
|
|
29
|
+
return !(key.startsWith(utils.OPTIMIZED_IMAGE_PREFIX) || key.startsWith(utils.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX));
|
|
27
30
|
},
|
|
28
|
-
|
|
29
31
|
async process({
|
|
30
32
|
s3,
|
|
31
33
|
key,
|
|
32
34
|
extension
|
|
33
35
|
}) {
|
|
34
|
-
|
|
35
|
-
await s3.deleteObject((0, _utils.getObjectParams)((0, _utils2.getImageKey)({
|
|
36
|
-
key
|
|
37
|
-
}))).promise(); // 2. Search for all transformed images and delete those too.
|
|
36
|
+
const utils = key.includes("/") ? newUtils : legacyUtils;
|
|
38
37
|
|
|
39
|
-
|
|
38
|
+
// 1. Get optimized image key.
|
|
39
|
+
await s3.deleteObject((0, _utils.getObjectParams)(utils.getImageKey({
|
|
40
|
+
key
|
|
41
|
+
}))).promise();
|
|
42
|
+
if (!utils.SUPPORTED_TRANSFORMABLE_IMAGES.includes(extension)) {
|
|
40
43
|
return;
|
|
41
44
|
}
|
|
42
45
|
|
|
46
|
+
/**
|
|
47
|
+
* Search for all transformed images and delete those too.
|
|
48
|
+
*
|
|
49
|
+
* For new keys, we take the entire path, up to, but not including, the file name:
|
|
50
|
+
* - demo-pages/60228148f98841000981c724/welcome-to-webiny__idp.svg
|
|
51
|
+
* - 60228148f98841000981c724/welcome-to-webiny__idp.svg
|
|
52
|
+
*
|
|
53
|
+
* Legacy keys don't have sub-folders:
|
|
54
|
+
* - 8ldc5n3w2-custom-field-renderers.mp4
|
|
55
|
+
*/
|
|
56
|
+
|
|
57
|
+
const prefix = isLegacyKey(key) ? utils.getOptimizedImageKeyPrefix(key) : (0, _path.dirname)(key) + "/";
|
|
43
58
|
const env = (0, _utils.getEnvironment)();
|
|
44
59
|
const imagesList = await s3.listObjects({
|
|
45
60
|
Bucket: env.bucket,
|
|
46
|
-
Prefix:
|
|
61
|
+
Prefix: prefix
|
|
47
62
|
}).promise();
|
|
48
|
-
|
|
49
63
|
if (!imagesList.Contents) {
|
|
50
64
|
return;
|
|
51
65
|
}
|
|
52
|
-
|
|
53
66
|
for (const imageObject of imagesList.Contents) {
|
|
54
67
|
if (!imageObject.Key) {
|
|
55
68
|
continue;
|
|
56
69
|
}
|
|
57
|
-
|
|
58
70
|
await s3.deleteObject((0, _utils.getObjectParams)(imageObject.Key)).promise();
|
|
59
71
|
}
|
|
60
72
|
}
|
|
61
|
-
|
|
62
73
|
};
|
|
63
74
|
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["canProcess","params","
|
|
1
|
+
{"version":3,"names":["isLegacyKey","key","includes","canProcess","params","extension","utils","newUtils","legacyUtils","SUPPORTED_IMAGES","startsWith","OPTIMIZED_IMAGE_PREFIX","OPTIMIZED_TRANSFORMED_IMAGE_PREFIX","process","s3","deleteObject","getObjectParams","getImageKey","promise","SUPPORTED_TRANSFORMABLE_IMAGES","prefix","getOptimizedImageKeyPrefix","dirname","env","getEnvironment","imagesList","listObjects","Bucket","bucket","Prefix","Contents","imageObject","Key"],"sources":["imageManager.ts"],"sourcesContent":["import { dirname } from \"path\";\nimport S3 from \"aws-sdk/clients/s3\";\nimport { getObjectParams, getEnvironment } from \"~/handlers/utils\";\nimport * as newUtils from \"../utils\";\nimport * as legacyUtils from \"../legacyUtils\";\n\nconst isLegacyKey = (key: string) => {\n return !key.includes(\"/\");\n};\n\nexport interface ImageManagerCanProcessParams {\n key: string;\n extension: string;\n}\nexport interface ImageManagerProcessParams {\n s3: S3;\n key: string;\n extension: string;\n}\nexport default {\n canProcess: (params: ImageManagerCanProcessParams) => {\n const { key, extension } = params;\n const utils = key.includes(\"/\") ? newUtils : legacyUtils;\n\n if (!utils.SUPPORTED_IMAGES.includes(extension)) {\n return false;\n }\n\n // We only want to process original images, and delete all variations of it at once.\n // We DO NOT want to process the event for the deletion of an optimized/transformed image.\n // Unfortunately, there's no way to filter those events on the S3 bucket itself, so we have to do it this way.\n return !(\n key.startsWith(utils.OPTIMIZED_IMAGE_PREFIX) ||\n key.startsWith(utils.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX)\n );\n },\n async process({ s3, key, extension }: ImageManagerProcessParams) {\n const utils = key.includes(\"/\") ? newUtils : legacyUtils;\n\n // 1. Get optimized image key.\n await s3.deleteObject(getObjectParams(utils.getImageKey({ key }))).promise();\n\n if (!utils.SUPPORTED_TRANSFORMABLE_IMAGES.includes(extension)) {\n return;\n }\n\n /**\n * Search for all transformed images and delete those too.\n *\n * For new keys, we take the entire path, up to, but not including, the file name:\n * - demo-pages/60228148f98841000981c724/welcome-to-webiny__idp.svg\n * - 60228148f98841000981c724/welcome-to-webiny__idp.svg\n *\n * Legacy keys don't have sub-folders:\n * - 8ldc5n3w2-custom-field-renderers.mp4\n */\n\n const prefix = isLegacyKey(key)\n ? utils.getOptimizedImageKeyPrefix(key)\n : dirname(key) + \"/\";\n\n const env = getEnvironment();\n const imagesList = await s3\n .listObjects({\n Bucket: env.bucket,\n Prefix: prefix\n })\n .promise();\n\n if (!imagesList.Contents) {\n return;\n }\n\n for (const imageObject of imagesList.Contents) {\n if (!imageObject.Key) {\n continue;\n }\n await s3.deleteObject(getObjectParams(imageObject.Key)).promise();\n }\n }\n};\n"],"mappings":";;;;;;;AAAA;AAEA;AACA;AACA;AAEA,MAAMA,WAAW,GAAIC,GAAW,IAAK;EACjC,OAAO,CAACA,GAAG,CAACC,QAAQ,CAAC,GAAG,CAAC;AAC7B,CAAC;AAAC,eAWa;EACXC,UAAU,EAAGC,MAAoC,IAAK;IAClD,MAAM;MAAEH,GAAG;MAAEI;IAAU,CAAC,GAAGD,MAAM;IACjC,MAAME,KAAK,GAAGL,GAAG,CAACC,QAAQ,CAAC,GAAG,CAAC,GAAGK,QAAQ,GAAGC,WAAW;IAExD,IAAI,CAACF,KAAK,CAACG,gBAAgB,CAACP,QAAQ,CAACG,SAAS,CAAC,EAAE;MAC7C,OAAO,KAAK;IAChB;;IAEA;IACA;IACA;IACA,OAAO,EACHJ,GAAG,CAACS,UAAU,CAACJ,KAAK,CAACK,sBAAsB,CAAC,IAC5CV,GAAG,CAACS,UAAU,CAACJ,KAAK,CAACM,kCAAkC,CAAC,CAC3D;EACL,CAAC;EACD,MAAMC,OAAO,CAAC;IAAEC,EAAE;IAAEb,GAAG;IAAEI;EAAqC,CAAC,EAAE;IAC7D,MAAMC,KAAK,GAAGL,GAAG,CAACC,QAAQ,CAAC,GAAG,CAAC,GAAGK,QAAQ,GAAGC,WAAW;;IAExD;IACA,MAAMM,EAAE,CAACC,YAAY,CAAC,IAAAC,sBAAe,EAACV,KAAK,CAACW,WAAW,CAAC;MAAEhB;IAAI,CAAC,CAAC,CAAC,CAAC,CAACiB,OAAO,EAAE;IAE5E,IAAI,CAACZ,KAAK,CAACa,8BAA8B,CAACjB,QAAQ,CAACG,SAAS,CAAC,EAAE;MAC3D;IACJ;;IAEA;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;IAEQ,MAAMe,MAAM,GAAGpB,WAAW,CAACC,GAAG,CAAC,GACzBK,KAAK,CAACe,0BAA0B,CAACpB,GAAG,CAAC,GACrC,IAAAqB,aAAO,EAACrB,GAAG,CAAC,GAAG,GAAG;IAExB,MAAMsB,GAAG,GAAG,IAAAC,qBAAc,GAAE;IAC5B,MAAMC,UAAU,GAAG,MAAMX,EAAE,CACtBY,WAAW,CAAC;MACTC,MAAM,EAAEJ,GAAG,CAACK,MAAM;MAClBC,MAAM,EAAET;IACZ,CAAC,CAAC,CACDF,OAAO,EAAE;IAEd,IAAI,CAACO,UAAU,CAACK,QAAQ,EAAE;MACtB;IACJ;IAEA,KAAK,MAAMC,WAAW,IAAIN,UAAU,CAACK,QAAQ,EAAE;MAC3C,IAAI,CAACC,WAAW,CAACC,GAAG,EAAE;QAClB;MACJ;MACA,MAAMlB,EAAE,CAACC,YAAY,CAAC,IAAAC,sBAAe,EAACe,WAAW,CAACC,GAAG,CAAC,CAAC,CAACd,OAAO,EAAE;IACrE;EACJ;AACJ,CAAC;AAAA"}
|
|
@@ -1,13 +1,10 @@
|
|
|
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.default = void 0;
|
|
9
|
-
|
|
10
8
|
var _imageManager = _interopRequireDefault(require("./imageManager"));
|
|
11
|
-
|
|
12
9
|
var _default = [_imageManager.default];
|
|
13
10
|
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["imageManager"],"sources":["index.ts"],"sourcesContent":["import imageManager from \"./imageManager\";\n\nexport default [imageManager];\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":["imageManager"],"sources":["index.ts"],"sourcesContent":["import imageManager from \"./imageManager\";\n\nexport default [imageManager];\n"],"mappings":";;;;;;;AAAA;AAA0C,eAE3B,CAACA,qBAAY,CAAC;AAAA"}
|
|
@@ -1,14 +1,11 @@
|
|
|
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.default = void 0;
|
|
9
|
-
|
|
10
8
|
var _sharp = _interopRequireDefault(require("sharp"));
|
|
11
|
-
|
|
12
9
|
/**
|
|
13
10
|
* Sharp is included in the AWS Lambda layer
|
|
14
11
|
*/
|
|
@@ -27,7 +24,6 @@ var _default = async (buffer, type) => {
|
|
|
27
24
|
force: true
|
|
28
25
|
}).withMetadata().toBuffer();
|
|
29
26
|
}
|
|
30
|
-
|
|
31
27
|
case "image/jpeg":
|
|
32
28
|
case "image/jpg":
|
|
33
29
|
{
|
|
@@ -39,10 +35,8 @@ var _default = async (buffer, type) => {
|
|
|
39
35
|
quality: 90
|
|
40
36
|
}).toBuffer();
|
|
41
37
|
}
|
|
42
|
-
|
|
43
38
|
default:
|
|
44
39
|
return buffer;
|
|
45
40
|
}
|
|
46
41
|
};
|
|
47
|
-
|
|
48
42
|
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["buffer","type","sharp","resize","width","withoutEnlargement","fit","png","compressionLevel","adaptiveFiltering","force","withMetadata","toBuffer","toFormat","quality"],"sources":["optimizeImage.ts"],"sourcesContent":["/**\n * Sharp is included in the AWS Lambda layer\n */\n// @ts-ignore\nimport sharp from \"sharp\";\nimport { Body } from \"aws-sdk/clients/s3\";\n\nexport default async (buffer: Body, type: string): Promise<Body> => {\n switch (type) {\n case \"image/png\": {\n return await sharp(buffer)\n .resize({ width: 2560, withoutEnlargement: true, fit: \"inside\" })\n .png({ compressionLevel: 9, adaptiveFiltering: true, force: true })\n .withMetadata()\n .toBuffer();\n }\n case \"image/jpeg\":\n case \"image/jpg\": {\n return await sharp(buffer)\n .resize({ width: 2560, withoutEnlargement: true, fit: \"inside\" })\n .toFormat(\"jpeg\", { quality: 90 })\n .toBuffer();\n }\n default:\n return buffer;\n }\n};\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":["buffer","type","sharp","resize","width","withoutEnlargement","fit","png","compressionLevel","adaptiveFiltering","force","withMetadata","toBuffer","toFormat","quality"],"sources":["optimizeImage.ts"],"sourcesContent":["/**\n * Sharp is included in the AWS Lambda layer\n */\n// @ts-ignore\nimport sharp from \"sharp\";\nimport { Body } from \"aws-sdk/clients/s3\";\n\nexport default async (buffer: Body, type: string): Promise<Body> => {\n switch (type) {\n case \"image/png\": {\n return await sharp(buffer)\n .resize({ width: 2560, withoutEnlargement: true, fit: \"inside\" })\n .png({ compressionLevel: 9, adaptiveFiltering: true, force: true })\n .withMetadata()\n .toBuffer();\n }\n case \"image/jpeg\":\n case \"image/jpg\": {\n return await sharp(buffer)\n .resize({ width: 2560, withoutEnlargement: true, fit: \"inside\" })\n .toFormat(\"jpeg\", { quality: 90 })\n .toBuffer();\n }\n default:\n return buffer;\n }\n};\n"],"mappings":";;;;;;;AAIA;AAJA;AACA;AACA;AACA;AAAA,eAIe,OAAOA,MAAY,EAAEC,IAAY,KAAoB;EAChE,QAAQA,IAAI;IACR,KAAK,WAAW;MAAE;QACd,OAAO,MAAM,IAAAC,cAAK,EAACF,MAAM,CAAC,CACrBG,MAAM,CAAC;UAAEC,KAAK,EAAE,IAAI;UAAEC,kBAAkB,EAAE,IAAI;UAAEC,GAAG,EAAE;QAAS,CAAC,CAAC,CAChEC,GAAG,CAAC;UAAEC,gBAAgB,EAAE,CAAC;UAAEC,iBAAiB,EAAE,IAAI;UAAEC,KAAK,EAAE;QAAK,CAAC,CAAC,CAClEC,YAAY,EAAE,CACdC,QAAQ,EAAE;MACnB;IACA,KAAK,YAAY;IACjB,KAAK,WAAW;MAAE;QACd,OAAO,MAAM,IAAAV,cAAK,EAACF,MAAM,CAAC,CACrBG,MAAM,CAAC;UAAEC,KAAK,EAAE,IAAI;UAAEC,kBAAkB,EAAE,IAAI;UAAEC,GAAG,EAAE;QAAS,CAAC,CAAC,CAChEO,QAAQ,CAAC,MAAM,EAAE;UAAEC,OAAO,EAAE;QAAG,CAAC,CAAC,CACjCF,QAAQ,EAAE;MACnB;IACA;MACI,OAAOZ,MAAM;EAAC;AAE1B,CAAC;AAAA"}
|
|
@@ -1,19 +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.default = void 0;
|
|
9
|
-
|
|
10
8
|
var _sharp = _interopRequireDefault(require("sharp"));
|
|
11
|
-
|
|
12
9
|
/**
|
|
13
10
|
* Sharp is included in the AWS Lambda layer
|
|
14
11
|
*/
|
|
15
12
|
// @ts-ignore
|
|
16
|
-
|
|
17
13
|
/**
|
|
18
14
|
* Only processing "width" at the moment.
|
|
19
15
|
* Check "sanitizeImageTransformations.js" to allow additional image processing transformations.
|
|
@@ -26,5 +22,4 @@ var _default = async (buffer, transformations) => {
|
|
|
26
22
|
width
|
|
27
23
|
}).toBuffer();
|
|
28
24
|
};
|
|
29
|
-
|
|
30
25
|
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["buffer","transformations","width","sharp","resize","toBuffer"],"sources":["transformImage.ts"],"sourcesContent":["/**\n * Sharp is included in the AWS Lambda layer\n */\n// @ts-ignore\nimport sharp from \"sharp\";\nimport { Body } from \"aws-sdk/clients/s3\";\n\ninterface Transformation {\n width: string;\n}\n/**\n * Only processing \"width\" at the moment.\n * Check \"sanitizeImageTransformations.js\" to allow additional image processing transformations.\n */\nexport default async (buffer: Body, transformations: Transformation): Promise<Body> => {\n const { width } = transformations;\n return await sharp(buffer).resize({ width }).toBuffer();\n};\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":["buffer","transformations","width","sharp","resize","toBuffer"],"sources":["transformImage.ts"],"sourcesContent":["/**\n * Sharp is included in the AWS Lambda layer\n */\n// @ts-ignore\nimport sharp from \"sharp\";\nimport { Body } from \"aws-sdk/clients/s3\";\n\ninterface Transformation {\n width: string;\n}\n/**\n * Only processing \"width\" at the moment.\n * Check \"sanitizeImageTransformations.js\" to allow additional image processing transformations.\n */\nexport default async (buffer: Body, transformations: Transformation): Promise<Body> => {\n const { width } = transformations;\n return await sharp(buffer).resize({ width }).toBuffer();\n};\n"],"mappings":";;;;;;;AAIA;AAJA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AAHA,eAIe,OAAOA,MAAY,EAAEC,eAA+B,KAAoB;EACnF,MAAM;IAAEC;EAAM,CAAC,GAAGD,eAAe;EACjC,OAAO,MAAM,IAAAE,cAAK,EAACH,MAAM,CAAC,CAACI,MAAM,CAAC;IAAEF;EAAM,CAAC,CAAC,CAACG,QAAQ,EAAE;AAC3D,CAAC;AAAA"}
|
|
@@ -3,7 +3,7 @@ declare const SUPPORTED_TRANSFORMABLE_IMAGES: string[];
|
|
|
3
3
|
declare const OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = "img-o-t-";
|
|
4
4
|
declare const OPTIMIZED_IMAGE_PREFIX = "img-o-";
|
|
5
5
|
declare const getOptimizedImageKeyPrefix: (key: string) => string;
|
|
6
|
-
declare const getOptimizedTransformedImageKeyPrefix: (key: string) => string;
|
|
6
|
+
declare const getOptimizedTransformedImageKeyPrefix: (key: string, transformationsHash: string) => string;
|
|
7
7
|
interface GetImageKeyParams {
|
|
8
8
|
key: string;
|
|
9
9
|
transformations?: any;
|
|
@@ -1,14 +1,11 @@
|
|
|
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.getOptimizedTransformedImageKeyPrefix = exports.getOptimizedImageKeyPrefix = exports.getImageKey = exports.SUPPORTED_TRANSFORMABLE_IMAGES = exports.SUPPORTED_IMAGES = exports.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = exports.OPTIMIZED_IMAGE_PREFIX = void 0;
|
|
9
|
-
|
|
10
8
|
var _objectHash = _interopRequireDefault(require("object-hash"));
|
|
11
|
-
|
|
12
9
|
const SUPPORTED_IMAGES = [".jpg", ".jpeg", ".png", ".svg", ".gif"];
|
|
13
10
|
exports.SUPPORTED_IMAGES = SUPPORTED_IMAGES;
|
|
14
11
|
const SUPPORTED_TRANSFORMABLE_IMAGES = [".jpg", ".jpeg", ".png"];
|
|
@@ -17,30 +14,23 @@ const OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = "img-o-t-";
|
|
|
17
14
|
exports.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = OPTIMIZED_TRANSFORMED_IMAGE_PREFIX;
|
|
18
15
|
const OPTIMIZED_IMAGE_PREFIX = "img-o-";
|
|
19
16
|
exports.OPTIMIZED_IMAGE_PREFIX = OPTIMIZED_IMAGE_PREFIX;
|
|
20
|
-
|
|
21
17
|
const getOptimizedImageKeyPrefix = key => {
|
|
22
|
-
|
|
18
|
+
const [id, name] = key.split("/");
|
|
19
|
+
return `${id}/${OPTIMIZED_IMAGE_PREFIX}${name}`;
|
|
23
20
|
};
|
|
24
|
-
|
|
25
21
|
exports.getOptimizedImageKeyPrefix = getOptimizedImageKeyPrefix;
|
|
26
|
-
|
|
27
|
-
const
|
|
28
|
-
return `${OPTIMIZED_TRANSFORMED_IMAGE_PREFIX}${
|
|
22
|
+
const getOptimizedTransformedImageKeyPrefix = (key, transformationsHash) => {
|
|
23
|
+
const [id, name] = key.split("/");
|
|
24
|
+
return `${id}/${OPTIMIZED_TRANSFORMED_IMAGE_PREFIX}${transformationsHash}-${name}`;
|
|
29
25
|
};
|
|
30
|
-
|
|
31
26
|
exports.getOptimizedTransformedImageKeyPrefix = getOptimizedTransformedImageKeyPrefix;
|
|
32
|
-
|
|
33
27
|
const getImageKey = ({
|
|
34
28
|
key,
|
|
35
29
|
transformations
|
|
36
30
|
}) => {
|
|
37
31
|
if (!transformations) {
|
|
38
|
-
|
|
39
|
-
return prefix + key;
|
|
32
|
+
return getOptimizedImageKeyPrefix(key);
|
|
40
33
|
}
|
|
41
|
-
|
|
42
|
-
const prefix = getOptimizedTransformedImageKeyPrefix(key);
|
|
43
|
-
return `${prefix}${(0, _objectHash.default)(transformations)}-${key}`;
|
|
34
|
+
return getOptimizedTransformedImageKeyPrefix(key, (0, _objectHash.default)(transformations));
|
|
44
35
|
};
|
|
45
|
-
|
|
46
36
|
exports.getImageKey = getImageKey;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["SUPPORTED_IMAGES","SUPPORTED_TRANSFORMABLE_IMAGES","OPTIMIZED_TRANSFORMED_IMAGE_PREFIX","OPTIMIZED_IMAGE_PREFIX","getOptimizedImageKeyPrefix","key","
|
|
1
|
+
{"version":3,"names":["SUPPORTED_IMAGES","SUPPORTED_TRANSFORMABLE_IMAGES","OPTIMIZED_TRANSFORMED_IMAGE_PREFIX","OPTIMIZED_IMAGE_PREFIX","getOptimizedImageKeyPrefix","key","id","name","split","getOptimizedTransformedImageKeyPrefix","transformationsHash","getImageKey","transformations","objectHash"],"sources":["utils.ts"],"sourcesContent":["import objectHash from \"object-hash\";\n\nconst SUPPORTED_IMAGES = [\".jpg\", \".jpeg\", \".png\", \".svg\", \".gif\"];\nconst SUPPORTED_TRANSFORMABLE_IMAGES = [\".jpg\", \".jpeg\", \".png\"];\n\nconst OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = \"img-o-t-\";\nconst OPTIMIZED_IMAGE_PREFIX = \"img-o-\";\n\nconst getOptimizedImageKeyPrefix = (key: string): string => {\n const [id, name] = key.split(\"/\");\n return `${id}/${OPTIMIZED_IMAGE_PREFIX}${name}`;\n};\n\nconst getOptimizedTransformedImageKeyPrefix = (\n key: string,\n transformationsHash: string\n): string => {\n const [id, name] = key.split(\"/\");\n return `${id}/${OPTIMIZED_TRANSFORMED_IMAGE_PREFIX}${transformationsHash}-${name}`;\n};\n\ninterface GetImageKeyParams {\n key: string;\n transformations?: any;\n}\n\nconst getImageKey = ({ key, transformations }: GetImageKeyParams): string => {\n if (!transformations) {\n return getOptimizedImageKeyPrefix(key);\n }\n\n return getOptimizedTransformedImageKeyPrefix(key, objectHash(transformations));\n};\n\nexport {\n SUPPORTED_IMAGES,\n SUPPORTED_TRANSFORMABLE_IMAGES,\n OPTIMIZED_TRANSFORMED_IMAGE_PREFIX,\n OPTIMIZED_IMAGE_PREFIX,\n getImageKey,\n getOptimizedImageKeyPrefix,\n getOptimizedTransformedImageKeyPrefix\n};\n"],"mappings":";;;;;;;AAAA;AAEA,MAAMA,gBAAgB,GAAG,CAAC,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,MAAM,CAACC,EAAE,EAAEC,IAAI,CAAC,GAAGF,GAAG,CAACG,KAAK,CAAC,GAAG,CAAC;EACjC,OAAQ,GAAEF,EAAG,IAAGH,sBAAuB,GAAEI,IAAK,EAAC;AACnD,CAAC;AAAC;AAEF,MAAME,qCAAqC,GAAG,CAC1CJ,GAAW,EACXK,mBAA2B,KAClB;EACT,MAAM,CAACJ,EAAE,EAAEC,IAAI,CAAC,GAAGF,GAAG,CAACG,KAAK,CAAC,GAAG,CAAC;EACjC,OAAQ,GAAEF,EAAG,IAAGJ,kCAAmC,GAAEQ,mBAAoB,IAAGH,IAAK,EAAC;AACtF,CAAC;AAAC;AAOF,MAAMI,WAAW,GAAG,CAAC;EAAEN,GAAG;EAAEO;AAAmC,CAAC,KAAa;EACzE,IAAI,CAACA,eAAe,EAAE;IAClB,OAAOR,0BAA0B,CAACC,GAAG,CAAC;EAC1C;EAEA,OAAOI,qCAAqC,CAACJ,GAAG,EAAE,IAAAQ,mBAAU,EAACD,eAAe,CAAC,CAAC;AAClF,CAAC;AAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["bucket","process","env","S3_BUCKET","region","AWS_REGION"],"sources":["getEnvironment.ts"],"sourcesContent":["export default () => ({\n bucket: process.env.S3_BUCKET as string,\n region: process.env.AWS_REGION as string\n});\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":["bucket","process","env","S3_BUCKET","region","AWS_REGION"],"sources":["getEnvironment.ts"],"sourcesContent":["export default () => ({\n bucket: process.env.S3_BUCKET as string,\n region: process.env.AWS_REGION as string\n});\n"],"mappings":";;;;;;eAAe,OAAO;EAClBA,MAAM,EAAEC,OAAO,CAACC,GAAG,CAACC,SAAmB;EACvCC,MAAM,EAAEH,OAAO,CAACC,GAAG,CAACG;AACxB,CAAC,CAAC;AAAA"}
|
|
@@ -1,14 +1,11 @@
|
|
|
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.default = void 0;
|
|
9
|
-
|
|
10
8
|
var _getEnvironment = _interopRequireDefault(require("./getEnvironment"));
|
|
11
|
-
|
|
12
9
|
/**
|
|
13
10
|
* Returns website's Bucket and file's Key values.
|
|
14
11
|
*/
|
|
@@ -21,5 +18,4 @@ var _default = filename => {
|
|
|
21
18
|
Key: `${filename}`
|
|
22
19
|
};
|
|
23
20
|
};
|
|
24
|
-
|
|
25
21
|
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["filename","bucket","Bucket","getEnvironment","Key"],"sources":["getObjectParams.ts"],"sourcesContent":["import getEnvironment from \"./getEnvironment\";\n\nexport interface ObjectParamsResponse {\n Bucket: string;\n Key: string;\n}\n/**\n * Returns website's Bucket and file's Key values.\n */\nexport default (filename: string): ObjectParamsResponse => {\n const { bucket: Bucket } = getEnvironment();\n\n return {\n Bucket,\n Key: `${filename}`\n };\n};\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":["filename","bucket","Bucket","getEnvironment","Key"],"sources":["getObjectParams.ts"],"sourcesContent":["import getEnvironment from \"./getEnvironment\";\n\nexport interface ObjectParamsResponse {\n Bucket: string;\n Key: string;\n}\n/**\n * Returns website's Bucket and file's Key values.\n */\nexport default (filename: string): ObjectParamsResponse => {\n const { bucket: Bucket } = getEnvironment();\n\n return {\n Bucket,\n Key: `${filename}`\n };\n};\n"],"mappings":";;;;;;;AAAA;AAMA;AACA;AACA;AAFA,eAGgBA,QAAgB,IAA2B;EACvD,MAAM;IAAEC,MAAM,EAAEC;EAAO,CAAC,GAAG,IAAAC,uBAAc,GAAE;EAE3C,OAAO;IACHD,MAAM;IACNE,GAAG,EAAG,GAAEJ,QAAS;EACrB,CAAC;AACL,CAAC;AAAA"}
|
package/handlers/utils/index.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
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
|
});
|
|
@@ -17,7 +16,5 @@ Object.defineProperty(exports, "getObjectParams", {
|
|
|
17
16
|
return _getObjectParams.default;
|
|
18
17
|
}
|
|
19
18
|
});
|
|
20
|
-
|
|
21
19
|
var _getEnvironment = _interopRequireDefault(require("./getEnvironment"));
|
|
22
|
-
|
|
23
20
|
var _getObjectParams = _interopRequireDefault(require("./getObjectParams"));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { default as getEnvironment } from \"./getEnvironment\";\nexport { default as getObjectParams } from \"./getObjectParams\";\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { default as getEnvironment } from \"./getEnvironment\";\nexport { default as getObjectParams } from \"./getObjectParams\";\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AACA"}
|
package/index.d.ts
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ContextPlugin } from "@webiny/api";
|
|
2
|
+
import { FileManagerConfig } from "./createFileManager";
|
|
3
|
+
import { FileManagerContext } from "./types";
|
|
4
|
+
export * from "./plugins";
|
|
5
|
+
export declare const createFileManagerContext: (config: Pick<FileManagerConfig, "storageOperations">) => ContextPlugin<FileManagerContext>;
|
|
6
|
+
export declare const createFileManagerGraphQL: () => import("@webiny/handler-graphql").GraphQLSchemaPlugin<FileManagerContext>;
|
package/index.js
ADDED
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
var _exportNames = {
|
|
8
|
+
createFileManagerContext: true,
|
|
9
|
+
createFileManagerGraphQL: true
|
|
10
|
+
};
|
|
11
|
+
exports.createFileManagerGraphQL = exports.createFileManagerContext = void 0;
|
|
12
|
+
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
13
|
+
var _api = require("@webiny/api");
|
|
14
|
+
var _createFileManager = require("./createFileManager");
|
|
15
|
+
var _graphql = require("./graphql");
|
|
16
|
+
var _FileStorage = require("./storage/FileStorage");
|
|
17
|
+
var _plugins = require("./plugins");
|
|
18
|
+
Object.keys(_plugins).forEach(function (key) {
|
|
19
|
+
if (key === "default" || key === "__esModule") return;
|
|
20
|
+
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
21
|
+
if (key in exports && exports[key] === _plugins[key]) return;
|
|
22
|
+
Object.defineProperty(exports, key, {
|
|
23
|
+
enumerable: true,
|
|
24
|
+
get: function () {
|
|
25
|
+
return _plugins[key];
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
const createFileManagerContext = config => {
|
|
30
|
+
return new _api.ContextPlugin(async context => {
|
|
31
|
+
const getLocaleCode = () => {
|
|
32
|
+
const locale = context.i18n.getContentLocale();
|
|
33
|
+
if (!locale) {
|
|
34
|
+
throw new _error.default("Missing locale on context.i18n locale in File Manager API.", "LOCALE_ERROR");
|
|
35
|
+
}
|
|
36
|
+
return locale.code;
|
|
37
|
+
};
|
|
38
|
+
const getIdentity = () => {
|
|
39
|
+
return context.security.getIdentity();
|
|
40
|
+
};
|
|
41
|
+
const getTenantId = () => {
|
|
42
|
+
return context.tenancy.getCurrentTenant().id;
|
|
43
|
+
};
|
|
44
|
+
const getPermission = async name => {
|
|
45
|
+
await context.i18n.checkI18NContentPermission();
|
|
46
|
+
return context.security.getPermission(name);
|
|
47
|
+
};
|
|
48
|
+
if (config.storageOperations.beforeInit) {
|
|
49
|
+
await config.storageOperations.beforeInit(context);
|
|
50
|
+
}
|
|
51
|
+
context.fileManager = (0, _createFileManager.createFileManager)({
|
|
52
|
+
storageOperations: config.storageOperations,
|
|
53
|
+
getTenantId,
|
|
54
|
+
getLocaleCode,
|
|
55
|
+
getIdentity,
|
|
56
|
+
getPermission,
|
|
57
|
+
storage: new _FileStorage.FileStorage({
|
|
58
|
+
context
|
|
59
|
+
}),
|
|
60
|
+
WEBINY_VERSION: context.WEBINY_VERSION
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
};
|
|
64
|
+
exports.createFileManagerContext = createFileManagerContext;
|
|
65
|
+
const createFileManagerGraphQL = () => {
|
|
66
|
+
return (0, _graphql.createGraphQLSchemaPlugin)();
|
|
67
|
+
};
|
|
68
|
+
exports.createFileManagerGraphQL = createFileManagerGraphQL;
|
package/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createFileManagerContext","config","ContextPlugin","context","getLocaleCode","locale","i18n","getContentLocale","WebinyError","code","getIdentity","security","getTenantId","tenancy","getCurrentTenant","id","getPermission","name","checkI18NContentPermission","storageOperations","beforeInit","fileManager","createFileManager","storage","FileStorage","WEBINY_VERSION","createFileManagerGraphQL","createGraphQLSchemaPlugin"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { ContextPlugin } from \"@webiny/api\";\nimport { SecurityPermission } from \"@webiny/api-security/types\";\nimport { FileManagerConfig, createFileManager } from \"~/createFileManager\";\nimport { FileManagerContext } from \"~/types\";\nimport { createGraphQLSchemaPlugin } from \"./graphql\";\nimport { FileStorage } from \"~/storage/FileStorage\";\n\nexport * from \"./plugins\";\n\nexport const createFileManagerContext = (config: Pick<FileManagerConfig, \"storageOperations\">) => {\n return new ContextPlugin<FileManagerContext>(async context => {\n const getLocaleCode = () => {\n const locale = context.i18n.getContentLocale();\n if (!locale) {\n throw new WebinyError(\n \"Missing locale on context.i18n locale in File Manager API.\",\n \"LOCALE_ERROR\"\n );\n }\n return locale.code;\n };\n\n const getIdentity = () => {\n return context.security.getIdentity();\n };\n\n const getTenantId = () => {\n return context.tenancy.getCurrentTenant().id;\n };\n\n const getPermission = async <T extends SecurityPermission = SecurityPermission>(\n name: string\n ): Promise<T | null> => {\n await context.i18n.checkI18NContentPermission();\n\n return context.security.getPermission(name);\n };\n\n if (config.storageOperations.beforeInit) {\n await config.storageOperations.beforeInit(context);\n }\n\n context.fileManager = createFileManager({\n storageOperations: config.storageOperations,\n getTenantId,\n getLocaleCode,\n getIdentity,\n getPermission,\n storage: new FileStorage({\n context\n }),\n WEBINY_VERSION: context.WEBINY_VERSION\n });\n });\n};\n\nexport const createFileManagerGraphQL = () => {\n return createGraphQLSchemaPlugin();\n};\n"],"mappings":";;;;;;;;;;;AAAA;AACA;AAEA;AAEA;AACA;AAEA;AAAA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;AAEO,MAAMA,wBAAwB,GAAIC,MAAoD,IAAK;EAC9F,OAAO,IAAIC,kBAAa,CAAqB,MAAMC,OAAO,IAAI;IAC1D,MAAMC,aAAa,GAAG,MAAM;MACxB,MAAMC,MAAM,GAAGF,OAAO,CAACG,IAAI,CAACC,gBAAgB,EAAE;MAC9C,IAAI,CAACF,MAAM,EAAE;QACT,MAAM,IAAIG,cAAW,CACjB,4DAA4D,EAC5D,cAAc,CACjB;MACL;MACA,OAAOH,MAAM,CAACI,IAAI;IACtB,CAAC;IAED,MAAMC,WAAW,GAAG,MAAM;MACtB,OAAOP,OAAO,CAACQ,QAAQ,CAACD,WAAW,EAAE;IACzC,CAAC;IAED,MAAME,WAAW,GAAG,MAAM;MACtB,OAAOT,OAAO,CAACU,OAAO,CAACC,gBAAgB,EAAE,CAACC,EAAE;IAChD,CAAC;IAED,MAAMC,aAAa,GAAG,MAClBC,IAAY,IACQ;MACpB,MAAMd,OAAO,CAACG,IAAI,CAACY,0BAA0B,EAAE;MAE/C,OAAOf,OAAO,CAACQ,QAAQ,CAACK,aAAa,CAACC,IAAI,CAAC;IAC/C,CAAC;IAED,IAAIhB,MAAM,CAACkB,iBAAiB,CAACC,UAAU,EAAE;MACrC,MAAMnB,MAAM,CAACkB,iBAAiB,CAACC,UAAU,CAACjB,OAAO,CAAC;IACtD;IAEAA,OAAO,CAACkB,WAAW,GAAG,IAAAC,oCAAiB,EAAC;MACpCH,iBAAiB,EAAElB,MAAM,CAACkB,iBAAiB;MAC3CP,WAAW;MACXR,aAAa;MACbM,WAAW;MACXM,aAAa;MACbO,OAAO,EAAE,IAAIC,wBAAW,CAAC;QACrBrB;MACJ,CAAC,CAAC;MACFsB,cAAc,EAAEtB,OAAO,CAACsB;IAC5B,CAAC,CAAC;EACN,CAAC,CAAC;AACN,CAAC;AAAC;AAEK,MAAMC,wBAAwB,GAAG,MAAM;EAC1C,OAAO,IAAAC,kCAAyB,GAAE;AACtC,CAAC;AAAC"}
|