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