@webiny/api-file-manager 0.0.0-unstable.d7f521b032 → 0.0.0-unstable.ecd8734205
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/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 +6 -16
- package/handlers/transform/index.js.map +1 -1
- package/handlers/transform/loaders/imageLoader.js +0 -17
- package/handlers/transform/loaders/imageLoader.js.map +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 +8 -15
- 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/package.json +18 -20
- package/plugins/crud/files/validation.js +0 -6
- package/plugins/crud/files/validation.js.map +1 -1
- package/plugins/crud/files.crud.js +8 -69
- package/plugins/crud/files.crud.js.map +1 -1
- package/plugins/crud/settings.crud.js +1 -18
- package/plugins/crud/settings.crud.js.map +1 -1
- package/plugins/crud/system.crud.js +0 -49
- package/plugins/crud/system.crud.js.map +1 -1
- package/plugins/crud/utils/checkBasePermissions.js +0 -8
- package/plugins/crud/utils/checkBasePermissions.js.map +1 -1
- package/plugins/crud/utils/createFileModel.js +0 -12
- package/plugins/crud/utils/createFileModel.js.map +1 -1
- package/plugins/crud/utils/lifecycleEvents.js +4 -12
- package/plugins/crud/utils/lifecycleEvents.js.map +1 -1
- package/plugins/definitions/FilePhysicalStoragePlugin.js +0 -11
- package/plugins/definitions/FilePhysicalStoragePlugin.js.map +1 -1
- package/plugins/definitions/FilePlugin.js +0 -18
- package/plugins/definitions/FilePlugin.js.map +1 -1
- package/plugins/definitions/FileStorageTransformPlugin.js +1 -12
- package/plugins/definitions/FileStorageTransformPlugin.js.map +1 -1
- package/plugins/definitions/FilesStorageOperationsProviderPlugin.js +0 -5
- package/plugins/definitions/FilesStorageOperationsProviderPlugin.js.map +1 -1
- package/plugins/definitions/InstallationPlugin.js +0 -11
- package/plugins/definitions/InstallationPlugin.js.map +1 -1
- package/plugins/definitions/SettingsStorageOperationsProviderPlugin.js +0 -5
- package/plugins/definitions/SettingsStorageOperationsProviderPlugin.js.map +1 -1
- package/plugins/definitions/SystemStorageOperationsProviderPlugin.js +0 -5
- package/plugins/definitions/SystemStorageOperationsProviderPlugin.js.map +1 -1
- package/plugins/graphql.js +33 -47
- package/plugins/graphql.js.map +1 -1
- package/plugins/index.js +0 -9
- package/plugins/index.js.map +1 -1
- package/plugins/storage/FileStorage.js +14 -32
- package/plugins/storage/FileStorage.js.map +1 -1
- package/plugins/storage/index.js +0 -4
- package/plugins/storage/index.js.map +1 -1
- package/types.d.ts +9 -1
- package/types.js.map +1 -1
- package/utils.js +0 -2
- package/utils.js.map +1 -1
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { DocumentClient } from "aws-sdk/clients/dynamodb";
|
|
2
|
+
import { RoutePlugin } from "@webiny/handler-aws/gateway";
|
|
3
|
+
export interface DownloadByFileAliasConfig {
|
|
4
|
+
documentClient: DocumentClient;
|
|
5
|
+
}
|
|
6
|
+
export declare const createDownloadFileByAliasPlugins: ({ documentClient }: DownloadByFileAliasConfig) => RoutePlugin<import("@webiny/handler/types").Context>[];
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.createDownloadFileByAliasPlugins = void 0;
|
|
8
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
9
|
+
var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
|
|
10
|
+
var _utils = require("../utils");
|
|
11
|
+
var _gateway = require("@webiny/handler-aws/gateway");
|
|
12
|
+
var _extractFileInformation = require("./extractFileInformation");
|
|
13
|
+
var _getS3Object = require("./getS3Object");
|
|
14
|
+
const DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year
|
|
15
|
+
const PRESIGNED_URL_EXPIRATION = 900; // 15 minutes
|
|
16
|
+
|
|
17
|
+
const createDownloadFileByAliasPlugins = ({
|
|
18
|
+
documentClient
|
|
19
|
+
}) => {
|
|
20
|
+
async function getFileByAlias(tenant, alias) {
|
|
21
|
+
const {
|
|
22
|
+
Items,
|
|
23
|
+
Count
|
|
24
|
+
} = await documentClient.query({
|
|
25
|
+
TableName: String(process.env.DB_TABLE),
|
|
26
|
+
IndexName: "GSI1",
|
|
27
|
+
Limit: 1,
|
|
28
|
+
KeyConditionExpression: "GSI1_PK = :GSI1_PK AND GSI1_SK = :GSI1_SK",
|
|
29
|
+
ExpressionAttributeValues: {
|
|
30
|
+
":GSI1_PK": `T#${tenant}#FM#FILE_ALIASES`,
|
|
31
|
+
":GSI1_SK": `/${alias}`
|
|
32
|
+
}
|
|
33
|
+
}).promise();
|
|
34
|
+
if (!Items || Count === 0) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
return Items[0].data.key ?? null;
|
|
38
|
+
}
|
|
39
|
+
return [new _gateway.RoutePlugin(({
|
|
40
|
+
onGet,
|
|
41
|
+
context
|
|
42
|
+
}) => {
|
|
43
|
+
onGet("/*", async (request, reply) => {
|
|
44
|
+
const {
|
|
45
|
+
region
|
|
46
|
+
} = (0, _utils.getEnvironment)();
|
|
47
|
+
const fileInfo = (0, _extractFileInformation.extractFileInformation)(request);
|
|
48
|
+
|
|
49
|
+
// TODO: `root` tenant is hardcoded for now, to satisfy the basic use case.
|
|
50
|
+
// We need to find a way to send tenant via `x-tenant` header, when images are being requested from
|
|
51
|
+
// the frontend (website, admin, etc.) by alias.
|
|
52
|
+
const realFilename = await getFileByAlias("root", fileInfo.filename);
|
|
53
|
+
if (!realFilename) {
|
|
54
|
+
return reply.code(404).type("text/html").send("Not Found");
|
|
55
|
+
}
|
|
56
|
+
const s3 = new _s.default({
|
|
57
|
+
region
|
|
58
|
+
});
|
|
59
|
+
const {
|
|
60
|
+
params,
|
|
61
|
+
object
|
|
62
|
+
} = await (0, _getS3Object.getS3Object)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, fileInfo), {}, {
|
|
63
|
+
filename: realFilename
|
|
64
|
+
}), s3, context);
|
|
65
|
+
|
|
66
|
+
// If there's an "object", it means we can return its body directly.
|
|
67
|
+
if (object) {
|
|
68
|
+
return reply.headers({
|
|
69
|
+
"Content-Type": object.ContentType,
|
|
70
|
+
"Cache-Control": `public, max-age=${DEFAULT_CACHE_MAX_AGE}`,
|
|
71
|
+
"x-webiny-base64-encoded": true
|
|
72
|
+
}).send(object.Body || "");
|
|
73
|
+
}
|
|
74
|
+
const presignedUrl = s3.getSignedUrl("getObject", {
|
|
75
|
+
Bucket: params.Bucket,
|
|
76
|
+
Key: params.Key,
|
|
77
|
+
Expires: PRESIGNED_URL_EXPIRATION
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
// Lambda can return max 6MB of content, so if our object's size is larger, we are sending
|
|
81
|
+
// a 301 Redirect, redirecting the user to the public URL of the object in S3.
|
|
82
|
+
return reply.code(301).headers({
|
|
83
|
+
Location: presignedUrl,
|
|
84
|
+
"Cache-Control": "public, max-age=" + PRESIGNED_URL_EXPIRATION
|
|
85
|
+
}).send("");
|
|
86
|
+
});
|
|
87
|
+
})];
|
|
88
|
+
};
|
|
89
|
+
exports.createDownloadFileByAliasPlugins = createDownloadFileByAliasPlugins;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["DEFAULT_CACHE_MAX_AGE","PRESIGNED_URL_EXPIRATION","createDownloadFileByAliasPlugins","documentClient","getFileByAlias","tenant","alias","Items","Count","query","TableName","String","process","env","DB_TABLE","IndexName","Limit","KeyConditionExpression","ExpressionAttributeValues","promise","data","key","RoutePlugin","onGet","context","request","reply","region","getEnvironment","fileInfo","extractFileInformation","realFilename","filename","code","type","send","s3","S3","params","object","getS3Object","headers","ContentType","Body","presignedUrl","getSignedUrl","Bucket","Key","Expires","Location"],"sources":["byAlias.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport { DocumentClient } from \"aws-sdk/clients/dynamodb\";\nimport { getEnvironment } from \"../utils\";\nimport { RoutePlugin } from \"@webiny/handler-aws/gateway\";\nimport { extractFileInformation } from \"./extractFileInformation\";\nimport { getS3Object } from \"./getS3Object\";\n\nconst DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year\nconst PRESIGNED_URL_EXPIRATION = 900; // 15 minutes\n\nexport interface DownloadByFileAliasConfig {\n documentClient: DocumentClient;\n}\n\nexport const createDownloadFileByAliasPlugins = ({ documentClient }: DownloadByFileAliasConfig) => {\n async function getFileByAlias(tenant: string, alias: string): Promise<string | null> {\n const { Items, Count } = await documentClient\n .query({\n TableName: String(process.env.DB_TABLE),\n IndexName: \"GSI1\",\n Limit: 1,\n KeyConditionExpression: \"GSI1_PK = :GSI1_PK AND GSI1_SK = :GSI1_SK\",\n ExpressionAttributeValues: {\n \":GSI1_PK\": `T#${tenant}#FM#FILE_ALIASES`,\n \":GSI1_SK\": `/${alias}`\n }\n })\n .promise();\n\n if (!Items || Count === 0) {\n return null;\n }\n\n return Items[0].data.key ?? null;\n }\n\n return [\n new RoutePlugin(({ onGet, context }) => {\n onGet(\"/*\", async (request, reply) => {\n const { region } = getEnvironment();\n const fileInfo = extractFileInformation(request);\n\n // TODO: `root` tenant is hardcoded for now, to satisfy the basic use case.\n // We need to find a way to send tenant via `x-tenant` header, when images are being requested from\n // the frontend (website, admin, etc.) by alias.\n const realFilename = await getFileByAlias(\"root\", fileInfo.filename);\n\n if (!realFilename) {\n return reply.code(404).type(\"text/html\").send(\"Not Found\");\n }\n\n const s3 = new S3({ region });\n const { params, object } = await getS3Object(\n { ...fileInfo, filename: realFilename },\n s3,\n context\n );\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":";;;;;;;;AAAA;AAEA;AACA;AACA;AACA;AAEA,MAAMA,qBAAqB,GAAG,QAAQ,CAAC,CAAC;AACxC,MAAMC,wBAAwB,GAAG,GAAG,CAAC,CAAC;;AAM/B,MAAMC,gCAAgC,GAAG,CAAC;EAAEC;AAA0C,CAAC,KAAK;EAC/F,eAAeC,cAAc,CAACC,MAAc,EAAEC,KAAa,EAA0B;IACjF,MAAM;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAG,MAAML,cAAc,CACxCM,KAAK,CAAC;MACHC,SAAS,EAAEC,MAAM,CAACC,OAAO,CAACC,GAAG,CAACC,QAAQ,CAAC;MACvCC,SAAS,EAAE,MAAM;MACjBC,KAAK,EAAE,CAAC;MACRC,sBAAsB,EAAE,2CAA2C;MACnEC,yBAAyB,EAAE;QACvB,UAAU,EAAG,KAAIb,MAAO,kBAAiB;QACzC,UAAU,EAAG,IAAGC,KAAM;MAC1B;IACJ,CAAC,CAAC,CACDa,OAAO,EAAE;IAEd,IAAI,CAACZ,KAAK,IAAIC,KAAK,KAAK,CAAC,EAAE;MACvB,OAAO,IAAI;IACf;IAEA,OAAOD,KAAK,CAAC,CAAC,CAAC,CAACa,IAAI,CAACC,GAAG,IAAI,IAAI;EACpC;EAEA,OAAO,CACH,IAAIC,oBAAW,CAAC,CAAC;IAAEC,KAAK;IAAEC;EAAQ,CAAC,KAAK;IACpCD,KAAK,CAAC,IAAI,EAAE,OAAOE,OAAO,EAAEC,KAAK,KAAK;MAClC,MAAM;QAAEC;MAAO,CAAC,GAAG,IAAAC,qBAAc,GAAE;MACnC,MAAMC,QAAQ,GAAG,IAAAC,8CAAsB,EAACL,OAAO,CAAC;;MAEhD;MACA;MACA;MACA,MAAMM,YAAY,GAAG,MAAM3B,cAAc,CAAC,MAAM,EAAEyB,QAAQ,CAACG,QAAQ,CAAC;MAEpE,IAAI,CAACD,YAAY,EAAE;QACf,OAAOL,KAAK,CAACO,IAAI,CAAC,GAAG,CAAC,CAACC,IAAI,CAAC,WAAW,CAAC,CAACC,IAAI,CAAC,WAAW,CAAC;MAC9D;MAEA,MAAMC,EAAE,GAAG,IAAIC,UAAE,CAAC;QAAEV;MAAO,CAAC,CAAC;MAC7B,MAAM;QAAEW,MAAM;QAAEC;MAAO,CAAC,GAAG,MAAM,IAAAC,wBAAW,8DACnCX,QAAQ;QAAEG,QAAQ,EAAED;MAAY,IACrCK,EAAE,EACFZ,OAAO,CACV;;MAED;MACA,IAAIe,MAAM,EAAE;QACR,OAAOb,KAAK,CACPe,OAAO,CAAC;UACL,cAAc,EAAEF,MAAM,CAACG,WAAW;UAClC,eAAe,EAAG,mBAAkB1C,qBAAsB,EAAC;UAC3D,yBAAyB,EAAE;QAC/B,CAAC,CAAC,CACDmC,IAAI,CAACI,MAAM,CAACI,IAAI,IAAI,EAAE,CAAC;MAChC;MAEA,MAAMC,YAAY,GAAGR,EAAE,CAACS,YAAY,CAAC,WAAW,EAAE;QAC9CC,MAAM,EAAER,MAAM,CAACQ,MAAM;QACrBC,GAAG,EAAET,MAAM,CAACS,GAAG;QACfC,OAAO,EAAE/C;MACb,CAAC,CAAC;;MAEF;MACA;MACA,OAAOyB,KAAK,CACPO,IAAI,CAAC,GAAG,CAAC,CACTQ,OAAO,CAAC;QACLQ,QAAQ,EAAEL,YAAY;QACtB,eAAe,EAAE,kBAAkB,GAAG3C;MAC1C,CAAC,CAAC,CACDkC,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC,CAAC;EACN,CAAC,CAAC,CACL;AACL,CAAC;AAAC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.createDownloadFileByExactKeyPlugins = void 0;
|
|
8
|
+
var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
|
|
9
|
+
var _utils = require("../utils");
|
|
10
|
+
var _gateway = require("@webiny/handler-aws/gateway");
|
|
11
|
+
var _getS3Object = require("./getS3Object");
|
|
12
|
+
var _extractFileInformation = require("./extractFileInformation");
|
|
13
|
+
const DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year
|
|
14
|
+
const PRESIGNED_URL_EXPIRATION = 900; // 15 minutes
|
|
15
|
+
|
|
16
|
+
const createDownloadFileByExactKeyPlugins = () => {
|
|
17
|
+
return [new _gateway.RoutePlugin(({
|
|
18
|
+
onGet,
|
|
19
|
+
context
|
|
20
|
+
}) => {
|
|
21
|
+
onGet("/files/*", async (request, reply) => {
|
|
22
|
+
const {
|
|
23
|
+
region
|
|
24
|
+
} = (0, _utils.getEnvironment)();
|
|
25
|
+
const fileInfo = (0, _extractFileInformation.extractFileInformation)(request);
|
|
26
|
+
const s3 = new _s.default({
|
|
27
|
+
region
|
|
28
|
+
});
|
|
29
|
+
const {
|
|
30
|
+
params,
|
|
31
|
+
object
|
|
32
|
+
} = await (0, _getS3Object.getS3Object)(fileInfo, s3, context);
|
|
33
|
+
|
|
34
|
+
// If there's an "object", it means we can return its body directly.
|
|
35
|
+
if (object) {
|
|
36
|
+
return reply.headers({
|
|
37
|
+
"Content-Type": object.ContentType,
|
|
38
|
+
"Cache-Control": `public, max-age=${DEFAULT_CACHE_MAX_AGE}`,
|
|
39
|
+
"x-webiny-base64-encoded": true
|
|
40
|
+
}).send(object.Body || "");
|
|
41
|
+
}
|
|
42
|
+
const presignedUrl = s3.getSignedUrl("getObject", {
|
|
43
|
+
Bucket: params.Bucket,
|
|
44
|
+
Key: params.Key,
|
|
45
|
+
Expires: PRESIGNED_URL_EXPIRATION
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
// Lambda can return max 6MB of content, so if our object's size is larger, we are sending
|
|
49
|
+
// a 301 Redirect, redirecting the user to the public URL of the object in S3.
|
|
50
|
+
return reply.code(301).headers({
|
|
51
|
+
Location: presignedUrl,
|
|
52
|
+
"Cache-Control": "public, max-age=" + PRESIGNED_URL_EXPIRATION
|
|
53
|
+
}).send("");
|
|
54
|
+
});
|
|
55
|
+
})];
|
|
56
|
+
};
|
|
57
|
+
exports.createDownloadFileByExactKeyPlugins = createDownloadFileByExactKeyPlugins;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["DEFAULT_CACHE_MAX_AGE","PRESIGNED_URL_EXPIRATION","createDownloadFileByExactKeyPlugins","RoutePlugin","onGet","context","request","reply","region","getEnvironment","fileInfo","extractFileInformation","s3","S3","params","object","getS3Object","headers","ContentType","send","Body","presignedUrl","getSignedUrl","Bucket","Key","Expires","code","Location"],"sources":["byExactKey.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport { getEnvironment } from \"../utils\";\nimport { RoutePlugin } from \"@webiny/handler-aws/gateway\";\nimport { getS3Object } from \"~/handlers/download/getS3Object\";\nimport { extractFileInformation } from \"~/handlers/download/extractFileInformation\";\n\nconst DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year\nconst PRESIGNED_URL_EXPIRATION = 900; // 15 minutes\n\nexport const createDownloadFileByExactKeyPlugins = () => {\n return [\n new RoutePlugin(({ onGet, context }) => {\n onGet(\"/files/*\", async (request, reply) => {\n const { region } = getEnvironment();\n const fileInfo = extractFileInformation(request);\n const s3 = new S3({ region });\n\n const { params, object } = await getS3Object(fileInfo, 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":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AAEA,MAAMA,qBAAqB,GAAG,QAAQ,CAAC,CAAC;AACxC,MAAMC,wBAAwB,GAAG,GAAG,CAAC,CAAC;;AAE/B,MAAMC,mCAAmC,GAAG,MAAM;EACrD,OAAO,CACH,IAAIC,oBAAW,CAAC,CAAC;IAAEC,KAAK;IAAEC;EAAQ,CAAC,KAAK;IACpCD,KAAK,CAAC,UAAU,EAAE,OAAOE,OAAO,EAAEC,KAAK,KAAK;MACxC,MAAM;QAAEC;MAAO,CAAC,GAAG,IAAAC,qBAAc,GAAE;MACnC,MAAMC,QAAQ,GAAG,IAAAC,8CAAsB,EAACL,OAAO,CAAC;MAChD,MAAMM,EAAE,GAAG,IAAIC,UAAE,CAAC;QAAEL;MAAO,CAAC,CAAC;MAE7B,MAAM;QAAEM,MAAM;QAAEC;MAAO,CAAC,GAAG,MAAM,IAAAC,wBAAW,EAACN,QAAQ,EAAEE,EAAE,EAAEP,OAAO,CAAC;;MAEnE;MACA,IAAIU,MAAM,EAAE;QACR,OAAOR,KAAK,CACPU,OAAO,CAAC;UACL,cAAc,EAAEF,MAAM,CAACG,WAAW;UAClC,eAAe,EAAG,mBAAkBlB,qBAAsB,EAAC;UAC3D,yBAAyB,EAAE;QAC/B,CAAC,CAAC,CACDmB,IAAI,CAACJ,MAAM,CAACK,IAAI,IAAI,EAAE,CAAC;MAChC;MAEA,MAAMC,YAAY,GAAGT,EAAE,CAACU,YAAY,CAAC,WAAW,EAAE;QAC9CC,MAAM,EAAET,MAAM,CAACS,MAAM;QACrBC,GAAG,EAAEV,MAAM,CAACU,GAAG;QACfC,OAAO,EAAExB;MACb,CAAC,CAAC;;MAEF;MACA;MACA,OAAOM,KAAK,CACPmB,IAAI,CAAC,GAAG,CAAC,CACTT,OAAO,CAAC;QACLU,QAAQ,EAAEN,YAAY;QACtB,eAAe,EAAE,kBAAkB,GAAGpB;MAC1C,CAAC,CAAC,CACDkB,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC,CAAC;EACN,CAAC,CAAC,CACL;AACL,CAAC;AAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Request } from "@webiny/handler/types";
|
|
2
|
+
/**
|
|
3
|
+
* Based on given request path, extracts file key and additional options sent via query params.
|
|
4
|
+
*/
|
|
5
|
+
export declare const extractFileInformation: (request: Request) => {
|
|
6
|
+
filename: string;
|
|
7
|
+
options: any;
|
|
8
|
+
extension: string;
|
|
9
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.extractFileInformation = void 0;
|
|
8
|
+
var _path = _interopRequireDefault(require("path"));
|
|
9
|
+
/**
|
|
10
|
+
* Based on given request path, extracts file key and additional options sent via query params.
|
|
11
|
+
*/
|
|
12
|
+
const extractFileInformation = request => {
|
|
13
|
+
const path = request.params["*"];
|
|
14
|
+
return {
|
|
15
|
+
filename: decodeURI(path),
|
|
16
|
+
options: request.query,
|
|
17
|
+
extension: _path.default.extname(path)
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
exports.extractFileInformation = extractFileInformation;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["extractFileInformation","request","path","params","filename","decodeURI","options","query","extension","pathLib","extname"],"sources":["extractFileInformation.ts"],"sourcesContent":["import pathLib from \"path\";\nimport { Request } from \"@webiny/handler/types\";\n\n/**\n * Based on given request path, extracts file key and additional options sent via query params.\n */\nexport const extractFileInformation = (request: Request) => {\n const path = (request.params as any)[\"*\"];\n return {\n filename: decodeURI(path),\n options: request.query as any,\n extension: pathLib.extname(path)\n };\n};\n"],"mappings":";;;;;;;AAAA;AAGA;AACA;AACA;AACO,MAAMA,sBAAsB,GAAIC,OAAgB,IAAK;EACxD,MAAMC,IAAI,GAAID,OAAO,CAACE,MAAM,CAAS,GAAG,CAAC;EACzC,OAAO;IACHC,QAAQ,EAAEC,SAAS,CAACH,IAAI,CAAC;IACzBI,OAAO,EAAEL,OAAO,CAACM,KAAY;IAC7BC,SAAS,EAAEC,aAAO,CAACC,OAAO,CAACR,IAAI;EACnC,CAAC;AACL,CAAC;AAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import S3 from "aws-sdk/clients/s3";
|
|
2
|
+
import { Context } from "@webiny/handler/types";
|
|
3
|
+
import { ObjectParamsResponse } from "../utils/getObjectParams";
|
|
4
|
+
import { extractFileInformation } from "./extractFileInformation";
|
|
5
|
+
interface S3Object {
|
|
6
|
+
object?: S3.Types.GetObjectOutput;
|
|
7
|
+
params: ObjectParamsResponse;
|
|
8
|
+
}
|
|
9
|
+
export declare const getS3Object: (fileInfo: ReturnType<typeof extractFileInformation>, s3: S3, context: Context) => Promise<S3Object>;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.getS3Object = void 0;
|
|
8
|
+
var _utils = require("../utils");
|
|
9
|
+
var _loaders = _interopRequireDefault(require("../transform/loaders"));
|
|
10
|
+
const MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB
|
|
11
|
+
|
|
12
|
+
const getS3Object = async (fileInfo, s3, context) => {
|
|
13
|
+
const {
|
|
14
|
+
filename,
|
|
15
|
+
options,
|
|
16
|
+
extension
|
|
17
|
+
} = fileInfo;
|
|
18
|
+
const params = (0, _utils.getObjectParams)(filename);
|
|
19
|
+
const objectHead = await s3.headObject(params).promise();
|
|
20
|
+
const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;
|
|
21
|
+
for (const loader of _loaders.default) {
|
|
22
|
+
const canProcess = loader.canProcess({
|
|
23
|
+
context,
|
|
24
|
+
s3,
|
|
25
|
+
options,
|
|
26
|
+
file: {
|
|
27
|
+
name: filename,
|
|
28
|
+
extension,
|
|
29
|
+
contentLength
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
if (!canProcess) {
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
return loader.process({
|
|
36
|
+
context,
|
|
37
|
+
s3,
|
|
38
|
+
options,
|
|
39
|
+
file: {
|
|
40
|
+
name: filename,
|
|
41
|
+
extension,
|
|
42
|
+
contentLength
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// If no processors handled the file request, just return the S3 object taking its size into consideration.
|
|
48
|
+
let object;
|
|
49
|
+
if (contentLength < MAX_RETURN_CONTENT_LENGTH) {
|
|
50
|
+
object = await s3.getObject(params).promise();
|
|
51
|
+
}
|
|
52
|
+
return {
|
|
53
|
+
object,
|
|
54
|
+
params
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
exports.getS3Object = getS3Object;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["MAX_RETURN_CONTENT_LENGTH","getS3Object","fileInfo","s3","context","filename","options","extension","params","getObjectParams","objectHead","headObject","promise","contentLength","ContentLength","loader","loaders","canProcess","file","name","process","object","getObject"],"sources":["getS3Object.ts"],"sourcesContent":["import S3 from \"aws-sdk/clients/s3\";\nimport { Context } from \"@webiny/handler/types\";\nimport { getObjectParams } from \"~/handlers/utils\";\nimport loaders from \"~/handlers/transform/loaders\";\nimport { ObjectParamsResponse } from \"~/handlers/utils/getObjectParams\";\nimport { extractFileInformation } from \"./extractFileInformation\";\n\ninterface S3Object {\n object?: S3.Types.GetObjectOutput;\n params: ObjectParamsResponse;\n}\n\nconst MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB\n\nexport const getS3Object = async (\n fileInfo: ReturnType<typeof extractFileInformation>,\n s3: S3,\n context: Context\n): Promise<S3Object> => {\n const { filename, options, extension } = fileInfo;\n const params = getObjectParams(filename);\n\n const objectHead = await s3.headObject(params).promise();\n const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;\n\n for (const loader of loaders) {\n const canProcess = loader.canProcess({\n context,\n s3,\n options,\n file: {\n name: filename,\n extension,\n contentLength\n }\n });\n\n if (!canProcess) {\n continue;\n }\n return loader.process({\n context,\n s3,\n options,\n file: {\n name: filename,\n extension,\n contentLength\n }\n });\n }\n\n // If no processors handled the file request, just return the S3 object taking its size into consideration.\n let object;\n if (contentLength < MAX_RETURN_CONTENT_LENGTH) {\n object = await s3.getObject(params).promise();\n }\n\n return { object, params };\n};\n"],"mappings":";;;;;;;AAEA;AACA;AASA,MAAMA,yBAAyB,GAAG,OAAO,CAAC,CAAC;;AAEpC,MAAMC,WAAW,GAAG,OACvBC,QAAmD,EACnDC,EAAM,EACNC,OAAgB,KACI;EACpB,MAAM;IAAEC,QAAQ;IAAEC,OAAO;IAAEC;EAAU,CAAC,GAAGL,QAAQ;EACjD,MAAMM,MAAM,GAAG,IAAAC,sBAAe,EAACJ,QAAQ,CAAC;EAExC,MAAMK,UAAU,GAAG,MAAMP,EAAE,CAACQ,UAAU,CAACH,MAAM,CAAC,CAACI,OAAO,EAAE;EACxD,MAAMC,aAAa,GAAGH,UAAU,CAACI,aAAa,GAAGJ,UAAU,CAACI,aAAa,GAAG,CAAC;EAE7E,KAAK,MAAMC,MAAM,IAAIC,gBAAO,EAAE;IAC1B,MAAMC,UAAU,GAAGF,MAAM,CAACE,UAAU,CAAC;MACjCb,OAAO;MACPD,EAAE;MACFG,OAAO;MACPY,IAAI,EAAE;QACFC,IAAI,EAAEd,QAAQ;QACdE,SAAS;QACTM;MACJ;IACJ,CAAC,CAAC;IAEF,IAAI,CAACI,UAAU,EAAE;MACb;IACJ;IACA,OAAOF,MAAM,CAACK,OAAO,CAAC;MAClBhB,OAAO;MACPD,EAAE;MACFG,OAAO;MACPY,IAAI,EAAE;QACFC,IAAI,EAAEd,QAAQ;QACdE,SAAS;QACTM;MACJ;IACJ,CAAC,CAAC;EACN;;EAEA;EACA,IAAIQ,MAAM;EACV,IAAIR,aAAa,GAAGb,yBAAyB,EAAE;IAC3CqB,MAAM,GAAG,MAAMlB,EAAE,CAACmB,SAAS,CAACd,MAAM,CAAC,CAACI,OAAO,EAAE;EACjD;EAEA,OAAO;IAAES,MAAM;IAAEb;EAAO,CAAC;AAC7B,CAAC;AAAC"}
|
|
@@ -1,3 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
export declare const createDownloadFilePlugins: () => RoutePlugin<Context>[];
|
|
1
|
+
export * from "./byExactKey";
|
|
2
|
+
export * from "./byAlias";
|
|
@@ -1,132 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
3
|
Object.defineProperty(exports, "__esModule", {
|
|
6
4
|
value: true
|
|
7
5
|
});
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
var _utils = require("../utils");
|
|
17
|
-
|
|
18
|
-
var _loaders = _interopRequireDefault(require("../transform/loaders"));
|
|
19
|
-
|
|
20
|
-
var _gateway = require("@webiny/handler-aws/gateway");
|
|
21
|
-
|
|
22
|
-
const MAX_RETURN_CONTENT_LENGTH = 5000000; // ~4.77MB
|
|
23
|
-
|
|
24
|
-
const DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year
|
|
25
|
-
|
|
26
|
-
const PRESIGNED_URL_EXPIRATION = 900; // 15 minutes
|
|
27
|
-
|
|
28
|
-
/**
|
|
29
|
-
* Based on given path, extracts file key and additional options sent via query params.
|
|
30
|
-
*/
|
|
31
|
-
|
|
32
|
-
const extractFilenameOptions = request => {
|
|
33
|
-
const path = (0, _sanitizeFilename.default)(request.params.path);
|
|
34
|
-
return {
|
|
35
|
-
filename: decodeURI(path),
|
|
36
|
-
options: request.query,
|
|
37
|
-
extension: _path.default.extname(path)
|
|
38
|
-
};
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
const getS3Object = async (request, s3, context) => {
|
|
42
|
-
const {
|
|
43
|
-
options,
|
|
44
|
-
filename,
|
|
45
|
-
extension
|
|
46
|
-
} = extractFilenameOptions(request);
|
|
47
|
-
const params = (0, _utils.getObjectParams)(filename);
|
|
48
|
-
const objectHead = await s3.headObject(params).promise();
|
|
49
|
-
const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;
|
|
50
|
-
|
|
51
|
-
for (const loader of _loaders.default) {
|
|
52
|
-
const canProcess = loader.canProcess({
|
|
53
|
-
context,
|
|
54
|
-
s3,
|
|
55
|
-
options,
|
|
56
|
-
file: {
|
|
57
|
-
name: filename,
|
|
58
|
-
extension,
|
|
59
|
-
contentLength
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
if (!canProcess) {
|
|
64
|
-
continue;
|
|
6
|
+
var _byExactKey = require("./byExactKey");
|
|
7
|
+
Object.keys(_byExactKey).forEach(function (key) {
|
|
8
|
+
if (key === "default" || key === "__esModule") return;
|
|
9
|
+
if (key in exports && exports[key] === _byExactKey[key]) return;
|
|
10
|
+
Object.defineProperty(exports, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function () {
|
|
13
|
+
return _byExactKey[key];
|
|
65
14
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
let object;
|
|
81
|
-
|
|
82
|
-
if (contentLength < MAX_RETURN_CONTENT_LENGTH) {
|
|
83
|
-
object = await s3.getObject(params).promise();
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
return {
|
|
87
|
-
object,
|
|
88
|
-
params
|
|
89
|
-
};
|
|
90
|
-
};
|
|
91
|
-
|
|
92
|
-
const createDownloadFilePlugins = () => {
|
|
93
|
-
return [new _gateway.RoutePlugin(({
|
|
94
|
-
onGet,
|
|
95
|
-
context
|
|
96
|
-
}) => {
|
|
97
|
-
onGet("/files/:path", async (request, reply) => {
|
|
98
|
-
const {
|
|
99
|
-
region
|
|
100
|
-
} = (0, _utils.getEnvironment)();
|
|
101
|
-
const s3 = new _s.default({
|
|
102
|
-
region
|
|
103
|
-
});
|
|
104
|
-
const {
|
|
105
|
-
params,
|
|
106
|
-
object
|
|
107
|
-
} = await getS3Object(request, s3, context); // If there's an "object", it means we can return its body directly.
|
|
108
|
-
|
|
109
|
-
if (object) {
|
|
110
|
-
return reply.headers({
|
|
111
|
-
"Content-Type": object.ContentType,
|
|
112
|
-
"Cache-Control": `public, max-age=${DEFAULT_CACHE_MAX_AGE}`,
|
|
113
|
-
"x-webiny-base64-encoded": true
|
|
114
|
-
}).send(object.Body || "");
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
const presignedUrl = s3.getSignedUrl("getObject", {
|
|
118
|
-
Bucket: params.Bucket,
|
|
119
|
-
Key: params.Key,
|
|
120
|
-
Expires: PRESIGNED_URL_EXPIRATION
|
|
121
|
-
}); // Lambda can return max 6MB of content, so if our object's size is larger, we are sending
|
|
122
|
-
// a 301 Redirect, redirecting the user to the public URL of the object in S3.
|
|
123
|
-
|
|
124
|
-
return reply.code(301).headers({
|
|
125
|
-
Location: presignedUrl,
|
|
126
|
-
"Cache-Control": "public, max-age=" + PRESIGNED_URL_EXPIRATION
|
|
127
|
-
}).send("");
|
|
128
|
-
});
|
|
129
|
-
})];
|
|
130
|
-
};
|
|
131
|
-
|
|
132
|
-
exports.createDownloadFilePlugins = createDownloadFilePlugins;
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
var _byAlias = require("./byAlias");
|
|
18
|
+
Object.keys(_byAlias).forEach(function (key) {
|
|
19
|
+
if (key === "default" || key === "__esModule") return;
|
|
20
|
+
if (key in exports && exports[key] === _byAlias[key]) return;
|
|
21
|
+
Object.defineProperty(exports, key, {
|
|
22
|
+
enumerable: true,
|
|
23
|
+
get: function () {
|
|
24
|
+
return _byAlias[key];
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./byExactKey\";\nexport * from \"./byAlias\";\n"],"mappings":";;;;;AAAA;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;AACA;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
|
package/handlers/manage/index.js
CHANGED
|
@@ -1,22 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.createManageFilePlugins = void 0;
|
|
9
|
-
|
|
10
8
|
var _path = _interopRequireDefault(require("path"));
|
|
11
|
-
|
|
12
9
|
var _s = _interopRequireDefault(require("aws-sdk/clients/s3"));
|
|
13
|
-
|
|
14
10
|
var _utils = require("../utils");
|
|
15
|
-
|
|
16
11
|
var _managers = _interopRequireDefault(require("../transform/managers"));
|
|
17
|
-
|
|
18
12
|
var _handlerAws = require("@webiny/handler-aws");
|
|
19
|
-
|
|
20
13
|
/**
|
|
21
14
|
* This handler must be run through @webiny/handler-aws/s3
|
|
22
15
|
*/
|
|
@@ -25,39 +18,31 @@ const createManageFilePlugins = () => {
|
|
|
25
18
|
event
|
|
26
19
|
}) => {
|
|
27
20
|
const keys = [];
|
|
28
|
-
|
|
29
21
|
for (let i = 0; i < event.Records.length; i++) {
|
|
30
22
|
const record = event.Records[i];
|
|
31
|
-
|
|
32
23
|
if (typeof record.s3.object.key === "string") {
|
|
33
24
|
keys.push(record.s3.object.key);
|
|
34
25
|
}
|
|
35
26
|
}
|
|
36
|
-
|
|
37
27
|
if (keys.length === 0) {
|
|
38
28
|
return;
|
|
39
29
|
}
|
|
40
|
-
|
|
41
30
|
const {
|
|
42
31
|
region
|
|
43
32
|
} = (0, _utils.getEnvironment)();
|
|
44
33
|
const s3 = new _s.default({
|
|
45
34
|
region
|
|
46
35
|
});
|
|
47
|
-
|
|
48
36
|
for (const key of keys) {
|
|
49
37
|
const extension = _path.default.extname(key);
|
|
50
|
-
|
|
51
38
|
for (const manager of _managers.default) {
|
|
52
39
|
const canProcess = manager.canProcess({
|
|
53
40
|
key,
|
|
54
41
|
extension
|
|
55
42
|
});
|
|
56
|
-
|
|
57
43
|
if (!canProcess) {
|
|
58
44
|
continue;
|
|
59
45
|
}
|
|
60
|
-
|
|
61
46
|
await manager.process({
|
|
62
47
|
s3,
|
|
63
48
|
key,
|
|
@@ -67,5 +52,4 @@ const createManageFilePlugins = () => {
|
|
|
67
52
|
}
|
|
68
53
|
})];
|
|
69
54
|
};
|
|
70
|
-
|
|
71
55
|
exports.createManageFilePlugins = createManageFilePlugins;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createManageFilePlugins","S3EventHandler","event","keys","i","Records","length","record","s3","object","key","push","region","getEnvironment","S3","extension","path","extname","manager","managers","canProcess","process"],"sources":["index.ts"],"sourcesContent":["import path from \"path\";\nimport S3 from \"aws-sdk/clients/s3\";\nimport { getEnvironment } from \"../utils\";\nimport managers from \"../transform/managers\";\nimport { S3EventHandler } from \"@webiny/handler-aws\";\n\n/**\n * This handler must be run through @webiny/handler-aws/s3\n */\nexport const createManageFilePlugins = () => {\n return [\n new S3EventHandler(async ({ event }) => {\n const keys: string[] = [];\n for (let i = 0; i < event.Records.length; i++) {\n const record = event.Records[i];\n if (typeof record.s3.object.key === \"string\") {\n keys.push(record.s3.object.key);\n }\n }\n\n if (keys.length === 0) {\n return;\n }\n\n const { region } = getEnvironment();\n const s3 = new S3({ region });\n\n for (const key of keys) {\n const extension = path.extname(key);\n\n for (const manager of managers) {\n const canProcess = manager.canProcess({\n key,\n extension\n });\n\n if (!canProcess) {\n continue;\n }\n await manager.process({\n s3,\n key,\n extension\n });\n }\n }\n })\n ];\n};\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":["createManageFilePlugins","S3EventHandler","event","keys","i","Records","length","record","s3","object","key","push","region","getEnvironment","S3","extension","path","extname","manager","managers","canProcess","process"],"sources":["index.ts"],"sourcesContent":["import path from \"path\";\nimport S3 from \"aws-sdk/clients/s3\";\nimport { getEnvironment } from \"../utils\";\nimport managers from \"../transform/managers\";\nimport { S3EventHandler } from \"@webiny/handler-aws\";\n\n/**\n * This handler must be run through @webiny/handler-aws/s3\n */\nexport const createManageFilePlugins = () => {\n return [\n new S3EventHandler(async ({ event }) => {\n const keys: string[] = [];\n for (let i = 0; i < event.Records.length; i++) {\n const record = event.Records[i];\n if (typeof record.s3.object.key === \"string\") {\n keys.push(record.s3.object.key);\n }\n }\n\n if (keys.length === 0) {\n return;\n }\n\n const { region } = getEnvironment();\n const s3 = new S3({ region });\n\n for (const key of keys) {\n const extension = path.extname(key);\n\n for (const manager of managers) {\n const canProcess = manager.canProcess({\n key,\n extension\n });\n\n if (!canProcess) {\n continue;\n }\n await manager.process({\n s3,\n key,\n extension\n });\n }\n }\n })\n ];\n};\n"],"mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACO,MAAMA,uBAAuB,GAAG,MAAM;EACzC,OAAO,CACH,IAAIC,0BAAc,CAAC,OAAO;IAAEC;EAAM,CAAC,KAAK;IACpC,MAAMC,IAAc,GAAG,EAAE;IACzB,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGF,KAAK,CAACG,OAAO,CAACC,MAAM,EAAEF,CAAC,EAAE,EAAE;MAC3C,MAAMG,MAAM,GAAGL,KAAK,CAACG,OAAO,CAACD,CAAC,CAAC;MAC/B,IAAI,OAAOG,MAAM,CAACC,EAAE,CAACC,MAAM,CAACC,GAAG,KAAK,QAAQ,EAAE;QAC1CP,IAAI,CAACQ,IAAI,CAACJ,MAAM,CAACC,EAAE,CAACC,MAAM,CAACC,GAAG,CAAC;MACnC;IACJ;IAEA,IAAIP,IAAI,CAACG,MAAM,KAAK,CAAC,EAAE;MACnB;IACJ;IAEA,MAAM;MAAEM;IAAO,CAAC,GAAG,IAAAC,qBAAc,GAAE;IACnC,MAAML,EAAE,GAAG,IAAIM,UAAE,CAAC;MAAEF;IAAO,CAAC,CAAC;IAE7B,KAAK,MAAMF,GAAG,IAAIP,IAAI,EAAE;MACpB,MAAMY,SAAS,GAAGC,aAAI,CAACC,OAAO,CAACP,GAAG,CAAC;MAEnC,KAAK,MAAMQ,OAAO,IAAIC,iBAAQ,EAAE;QAC5B,MAAMC,UAAU,GAAGF,OAAO,CAACE,UAAU,CAAC;UAClCV,GAAG;UACHK;QACJ,CAAC,CAAC;QAEF,IAAI,CAACK,UAAU,EAAE;UACb;QACJ;QACA,MAAMF,OAAO,CAACG,OAAO,CAAC;UAClBb,EAAE;UACFE,GAAG;UACHK;QACJ,CAAC,CAAC;MACN;IACJ;EACJ,CAAC,CAAC,CACL;AACL,CAAC;AAAC"}
|
|
@@ -1,26 +1,17 @@
|
|
|
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.createTransformFilePlugins = void 0;
|
|
9
|
-
|
|
10
8
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
-
|
|
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
14
|
var _handler = require("@webiny/handler");
|
|
23
|
-
|
|
24
15
|
const createTransformFilePlugins = () => {
|
|
25
16
|
return [(0, _handler.createEvent)(async ({
|
|
26
17
|
payload
|
|
@@ -32,7 +23,6 @@ const createTransformFilePlugins = () => {
|
|
|
32
23
|
key,
|
|
33
24
|
transformations
|
|
34
25
|
} = body;
|
|
35
|
-
|
|
36
26
|
try {
|
|
37
27
|
const env = (0, _utils.getEnvironment)();
|
|
38
28
|
const s3 = new _s.default({
|
|
@@ -48,8 +38,9 @@ const createTransformFilePlugins = () => {
|
|
|
48
38
|
key,
|
|
49
39
|
transformations
|
|
50
40
|
}))
|
|
51
|
-
};
|
|
41
|
+
};
|
|
52
42
|
|
|
43
|
+
// 1. Get optimized image.
|
|
53
44
|
try {
|
|
54
45
|
optimizedImageObject = await s3.getObject(params.optimized).promise();
|
|
55
46
|
} catch (e) {
|
|
@@ -60,17 +51,17 @@ const createTransformFilePlugins = () => {
|
|
|
60
51
|
Body: await (0, _optimizeImage.default)(optimizedImageObject.Body, optimizedImageObject.ContentType)
|
|
61
52
|
})).promise();
|
|
62
53
|
optimizedImageObject = await s3.getObject(params.optimized).promise();
|
|
63
|
-
}
|
|
64
|
-
|
|
54
|
+
}
|
|
65
55
|
|
|
56
|
+
// 2. If no transformations requested, just exit.
|
|
66
57
|
if (!transformations) {
|
|
67
58
|
return {
|
|
68
59
|
error: false,
|
|
69
60
|
message: ""
|
|
70
61
|
};
|
|
71
|
-
}
|
|
72
|
-
|
|
62
|
+
}
|
|
73
63
|
|
|
64
|
+
// 3. If transformations requested, apply them in save it into the bucket.
|
|
74
65
|
await s3.putObject((0, _objectSpread2.default)((0, _objectSpread2.default)({}, params.optimizedTransformed), {}, {
|
|
75
66
|
ContentType: optimizedImageObject.ContentType,
|
|
76
67
|
Body: await (0, _transformImage.default)(optimizedImageObject.Body, transformations)
|
|
@@ -87,5 +78,4 @@ const createTransformFilePlugins = () => {
|
|
|
87
78
|
}
|
|
88
79
|
})];
|
|
89
80
|
};
|
|
90
|
-
|
|
91
81
|
exports.createTransformFilePlugins = createTransformFilePlugins;
|