@webiny/api-file-manager 0.0.0-unstable.e3f4727c56 → 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 -107
- package/handlers/download/index.js.map +1 -1
- package/handlers/transform/managers/imageManager.js +2 -1
- package/handlers/transform/managers/imageManager.js.map +1 -1
- package/handlers/transform/utils.d.ts +1 -1
- package/handlers/transform/utils.js +7 -7
- package/handlers/transform/utils.js.map +1 -1
- package/package.json +18 -19
- package/plugins/crud/files.crud.js +7 -9
- package/plugins/crud/files.crud.js.map +1 -1
- package/plugins/graphql.js +31 -17
- package/plugins/graphql.js.map +1 -1
- package/types.d.ts +9 -0
- package/types.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,113 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
const DEFAULT_CACHE_MAX_AGE = 30758400; // 1 year
|
|
16
|
-
const PRESIGNED_URL_EXPIRATION = 900; // 15 minutes
|
|
17
|
-
/**
|
|
18
|
-
* Based on given path, extracts file key and additional options sent via query params.
|
|
19
|
-
*/
|
|
20
|
-
const extractFilenameOptions = request => {
|
|
21
|
-
const path = (0, _sanitizeFilename.default)(request.params.path);
|
|
22
|
-
return {
|
|
23
|
-
filename: decodeURI(path),
|
|
24
|
-
options: request.query,
|
|
25
|
-
extension: _path.default.extname(path)
|
|
26
|
-
};
|
|
27
|
-
};
|
|
28
|
-
const getS3Object = async (request, s3, context) => {
|
|
29
|
-
const {
|
|
30
|
-
options,
|
|
31
|
-
filename,
|
|
32
|
-
extension
|
|
33
|
-
} = extractFilenameOptions(request);
|
|
34
|
-
const params = (0, _utils.getObjectParams)(filename);
|
|
35
|
-
const objectHead = await s3.headObject(params).promise();
|
|
36
|
-
const contentLength = objectHead.ContentLength ? objectHead.ContentLength : 0;
|
|
37
|
-
for (const loader of _loaders.default) {
|
|
38
|
-
const canProcess = loader.canProcess({
|
|
39
|
-
context,
|
|
40
|
-
s3,
|
|
41
|
-
options,
|
|
42
|
-
file: {
|
|
43
|
-
name: filename,
|
|
44
|
-
extension,
|
|
45
|
-
contentLength
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
if (!canProcess) {
|
|
49
|
-
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];
|
|
50
14
|
}
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
let object;
|
|
65
|
-
if (contentLength < MAX_RETURN_CONTENT_LENGTH) {
|
|
66
|
-
object = await s3.getObject(params).promise();
|
|
67
|
-
}
|
|
68
|
-
return {
|
|
69
|
-
object,
|
|
70
|
-
params
|
|
71
|
-
};
|
|
72
|
-
};
|
|
73
|
-
const createDownloadFilePlugins = () => {
|
|
74
|
-
return [new _gateway.RoutePlugin(({
|
|
75
|
-
onGet,
|
|
76
|
-
context
|
|
77
|
-
}) => {
|
|
78
|
-
onGet("/files/:path", async (request, reply) => {
|
|
79
|
-
const {
|
|
80
|
-
region
|
|
81
|
-
} = (0, _utils.getEnvironment)();
|
|
82
|
-
const s3 = new _s.default({
|
|
83
|
-
region
|
|
84
|
-
});
|
|
85
|
-
const {
|
|
86
|
-
params,
|
|
87
|
-
object
|
|
88
|
-
} = await getS3Object(request, s3, context);
|
|
89
|
-
|
|
90
|
-
// If there's an "object", it means we can return its body directly.
|
|
91
|
-
if (object) {
|
|
92
|
-
return reply.headers({
|
|
93
|
-
"Content-Type": object.ContentType,
|
|
94
|
-
"Cache-Control": `public, max-age=${DEFAULT_CACHE_MAX_AGE}`,
|
|
95
|
-
"x-webiny-base64-encoded": true
|
|
96
|
-
}).send(object.Body || "");
|
|
97
|
-
}
|
|
98
|
-
const presignedUrl = s3.getSignedUrl("getObject", {
|
|
99
|
-
Bucket: params.Bucket,
|
|
100
|
-
Key: params.Key,
|
|
101
|
-
Expires: PRESIGNED_URL_EXPIRATION
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
// Lambda can return max 6MB of content, so if our object's size is larger, we are sending
|
|
105
|
-
// a 301 Redirect, redirecting the user to the public URL of the object in S3.
|
|
106
|
-
return reply.code(301).headers({
|
|
107
|
-
Location: presignedUrl,
|
|
108
|
-
"Cache-Control": "public, max-age=" + PRESIGNED_URL_EXPIRATION
|
|
109
|
-
}).send("");
|
|
110
|
-
});
|
|
111
|
-
})];
|
|
112
|
-
};
|
|
113
|
-
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"}
|
|
@@ -36,10 +36,11 @@ var _default = {
|
|
|
36
36
|
if (_utils2.SUPPORTED_TRANSFORMABLE_IMAGES.includes(extension) === false) {
|
|
37
37
|
return;
|
|
38
38
|
}
|
|
39
|
+
const [id] = key.split("/");
|
|
39
40
|
const env = (0, _utils.getEnvironment)();
|
|
40
41
|
const imagesList = await s3.listObjects({
|
|
41
42
|
Bucket: env.bucket,
|
|
42
|
-
Prefix:
|
|
43
|
+
Prefix: `${id}/`
|
|
43
44
|
}).promise();
|
|
44
45
|
if (!imagesList.Contents) {
|
|
45
46
|
return;
|
|
@@ -1 +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","
|
|
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","id","split","env","getEnvironment","imagesList","listObjects","Bucket","bucket","Prefix","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} 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 [id] = key.split(\"/\");\n const env = getEnvironment();\n const imagesList = await s3\n .listObjects({\n Bucket: env.bucket,\n Prefix: `${id}/`\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;AAMkB,eAWH;EACXA,UAAU,EAAGC,MAAoC,IAAK;IAClD,MAAM;MAAEC,GAAG;MAAEC;IAAU,CAAC,GAAGF,MAAM;IACjC,IAAIG,wBAAgB,CAACC,QAAQ,CAACF,SAAS,CAAC,KAAK,KAAK,EAAE;MAChD,OAAO,KAAK;IAChB;;IAEA;IACA;IACA;IACA,OAAO,EACHD,GAAG,CAACI,UAAU,CAACC,8BAAsB,CAAC,IACtCL,GAAG,CAACI,UAAU,CAACE,0CAAkC,CAAC,CACrD;EACL,CAAC;EACD,MAAMC,OAAO,CAAC;IAAEC,EAAE;IAAER,GAAG;IAAEC;EAAqC,CAAC,EAAE;IAC7D;;IAEA,MAAMO,EAAE,CAACC,YAAY,CAAC,IAAAC,sBAAe,EAAC,IAAAC,mBAAW,EAAC;MAAEX;IAAI,CAAC,CAAC,CAAC,CAAC,CAACY,OAAO,EAAE;;IAEtE;IACA,IAAIC,sCAA8B,CAACV,QAAQ,CAACF,SAAS,CAAC,KAAK,KAAK,EAAE;MAC9D;IACJ;IACA,MAAM,CAACa,EAAE,CAAC,GAAGd,GAAG,CAACe,KAAK,CAAC,GAAG,CAAC;IAC3B,MAAMC,GAAG,GAAG,IAAAC,qBAAc,GAAE;IAC5B,MAAMC,UAAU,GAAG,MAAMV,EAAE,CACtBW,WAAW,CAAC;MACTC,MAAM,EAAEJ,GAAG,CAACK,MAAM;MAClBC,MAAM,EAAG,GAAER,EAAG;IAClB,CAAC,CAAC,CACDF,OAAO,EAAE;IAEd,IAAI,CAACM,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,MAAMjB,EAAE,CAACC,YAAY,CAAC,IAAAC,sBAAe,EAACc,WAAW,CAACC,GAAG,CAAC,CAAC,CAACb,OAAO,EAAE;IACrE;EACJ;AACJ,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;
|
|
@@ -15,11 +15,13 @@ exports.OPTIMIZED_TRANSFORMED_IMAGE_PREFIX = OPTIMIZED_TRANSFORMED_IMAGE_PREFIX;
|
|
|
15
15
|
const OPTIMIZED_IMAGE_PREFIX = "img-o-";
|
|
16
16
|
exports.OPTIMIZED_IMAGE_PREFIX = OPTIMIZED_IMAGE_PREFIX;
|
|
17
17
|
const getOptimizedImageKeyPrefix = key => {
|
|
18
|
-
|
|
18
|
+
const [id, name] = key.split("/");
|
|
19
|
+
return `${id}/${OPTIMIZED_IMAGE_PREFIX}${name}`;
|
|
19
20
|
};
|
|
20
21
|
exports.getOptimizedImageKeyPrefix = getOptimizedImageKeyPrefix;
|
|
21
|
-
const getOptimizedTransformedImageKeyPrefix = key => {
|
|
22
|
-
|
|
22
|
+
const getOptimizedTransformedImageKeyPrefix = (key, transformationsHash) => {
|
|
23
|
+
const [id, name] = key.split("/");
|
|
24
|
+
return `${id}/${OPTIMIZED_TRANSFORMED_IMAGE_PREFIX}${transformationsHash}-${name}`;
|
|
23
25
|
};
|
|
24
26
|
exports.getOptimizedTransformedImageKeyPrefix = getOptimizedTransformedImageKeyPrefix;
|
|
25
27
|
const getImageKey = ({
|
|
@@ -27,10 +29,8 @@ const getImageKey = ({
|
|
|
27
29
|
transformations
|
|
28
30
|
}) => {
|
|
29
31
|
if (!transformations) {
|
|
30
|
-
|
|
31
|
-
return prefix + key;
|
|
32
|
+
return getOptimizedImageKeyPrefix(key);
|
|
32
33
|
}
|
|
33
|
-
|
|
34
|
-
return `${prefix}${(0, _objectHash.default)(transformations)}-${key}`;
|
|
34
|
+
return getOptimizedTransformedImageKeyPrefix(key, (0, _objectHash.default)(transformations));
|
|
35
35
|
};
|
|
36
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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/api-file-manager",
|
|
3
|
-
"version": "0.0.0-unstable.
|
|
3
|
+
"version": "0.0.0-unstable.ecd8734205",
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"fm:base"
|
|
@@ -20,22 +20,20 @@
|
|
|
20
20
|
"dependencies": {
|
|
21
21
|
"@babel/runtime": "7.20.13",
|
|
22
22
|
"@commodo/fields": "1.1.2-beta.20",
|
|
23
|
-
"@webiny/api": "0.0.0-unstable.
|
|
24
|
-
"@webiny/api-security": "0.0.0-unstable.
|
|
25
|
-
"@webiny/api-tenancy": "0.0.0-unstable.
|
|
26
|
-
"@webiny/error": "0.0.0-unstable.
|
|
27
|
-
"@webiny/handler": "0.0.0-unstable.
|
|
28
|
-
"@webiny/handler-aws": "0.0.0-unstable.
|
|
29
|
-
"@webiny/handler-client": "0.0.0-unstable.
|
|
30
|
-
"@webiny/handler-graphql": "0.0.0-unstable.
|
|
31
|
-
"@webiny/plugins": "0.0.0-unstable.
|
|
32
|
-
"@webiny/project-utils": "0.0.0-unstable.
|
|
33
|
-
"@webiny/validation": "0.0.0-unstable.
|
|
23
|
+
"@webiny/api": "0.0.0-unstable.ecd8734205",
|
|
24
|
+
"@webiny/api-security": "0.0.0-unstable.ecd8734205",
|
|
25
|
+
"@webiny/api-tenancy": "0.0.0-unstable.ecd8734205",
|
|
26
|
+
"@webiny/error": "0.0.0-unstable.ecd8734205",
|
|
27
|
+
"@webiny/handler": "0.0.0-unstable.ecd8734205",
|
|
28
|
+
"@webiny/handler-aws": "0.0.0-unstable.ecd8734205",
|
|
29
|
+
"@webiny/handler-client": "0.0.0-unstable.ecd8734205",
|
|
30
|
+
"@webiny/handler-graphql": "0.0.0-unstable.ecd8734205",
|
|
31
|
+
"@webiny/plugins": "0.0.0-unstable.ecd8734205",
|
|
32
|
+
"@webiny/project-utils": "0.0.0-unstable.ecd8734205",
|
|
33
|
+
"@webiny/validation": "0.0.0-unstable.ecd8734205",
|
|
34
34
|
"aws-sdk": "2.1310.0",
|
|
35
35
|
"commodo-fields-object": "1.0.6",
|
|
36
|
-
"
|
|
37
|
-
"object-hash": "2.2.0",
|
|
38
|
-
"sanitize-filename": "1.6.3"
|
|
36
|
+
"object-hash": "2.2.0"
|
|
39
37
|
},
|
|
40
38
|
"devDependencies": {
|
|
41
39
|
"@babel/cli": "^7.19.3",
|
|
@@ -44,10 +42,11 @@
|
|
|
44
42
|
"@babel/plugin-transform-runtime": "^7.16.4",
|
|
45
43
|
"@babel/preset-env": "^7.19.4",
|
|
46
44
|
"@babel/preset-typescript": "^7.18.6",
|
|
47
|
-
"@webiny/api-i18n": "^0.0.0-unstable.
|
|
48
|
-
"@webiny/api-i18n-ddb": "^0.0.0-unstable.
|
|
49
|
-
"@webiny/cli": "^0.0.0-unstable.
|
|
45
|
+
"@webiny/api-i18n": "^0.0.0-unstable.ecd8734205",
|
|
46
|
+
"@webiny/api-i18n-ddb": "^0.0.0-unstable.ecd8734205",
|
|
47
|
+
"@webiny/cli": "^0.0.0-unstable.ecd8734205",
|
|
50
48
|
"jest": "^28.1.0",
|
|
49
|
+
"mdbid": "^1.0.0",
|
|
51
50
|
"rimraf": "^3.0.2",
|
|
52
51
|
"ttypescript": "^1.5.12",
|
|
53
52
|
"typescript": "4.7.4"
|
|
@@ -71,5 +70,5 @@
|
|
|
71
70
|
]
|
|
72
71
|
}
|
|
73
72
|
},
|
|
74
|
-
"gitHead": "
|
|
73
|
+
"gitHead": "ecd8734205e0e21ae04076c28ff9806dad07a730"
|
|
75
74
|
}
|
|
@@ -6,7 +6,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
});
|
|
7
7
|
exports.default = void 0;
|
|
8
8
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
9
|
-
var _mdbid = _interopRequireDefault(require("mdbid"));
|
|
10
9
|
var _handlerGraphql = require("@webiny/handler-graphql");
|
|
11
10
|
var _apiSecurity = require("@webiny/api-security");
|
|
12
11
|
var _checkBasePermissions = _interopRequireDefault(require("./utils/checkBasePermissions"));
|
|
@@ -15,11 +14,6 @@ var _FilePlugin = require("../definitions/FilePlugin");
|
|
|
15
14
|
var _FilesStorageOperationsProviderPlugin = require("../definitions/FilesStorageOperationsProviderPlugin");
|
|
16
15
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
17
16
|
var _lifecycleEvents = require("./utils/lifecycleEvents");
|
|
18
|
-
/**
|
|
19
|
-
* Package mdbid does not have types.
|
|
20
|
-
*/
|
|
21
|
-
// @ts-ignore
|
|
22
|
-
|
|
23
17
|
const BATCH_CREATE_MAX_FILES = 20;
|
|
24
18
|
|
|
25
19
|
/**
|
|
@@ -85,10 +79,13 @@ const filesContextCrudPlugin = new _api.ContextPlugin(async context => {
|
|
|
85
79
|
});
|
|
86
80
|
const identity = context.security.getIdentity();
|
|
87
81
|
const tenant = context.tenancy.getCurrentTenant();
|
|
88
|
-
|
|
82
|
+
|
|
83
|
+
// Extract ID from file key
|
|
84
|
+
const [id] = input.key.split("/");
|
|
89
85
|
const file = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, input), {}, {
|
|
90
86
|
tags: Array.isArray(input.tags) ? input.tags : [],
|
|
91
|
-
|
|
87
|
+
aliases: Array.isArray(input.aliases) ? input.aliases : [],
|
|
88
|
+
id: input.id || id,
|
|
92
89
|
meta: (0, _objectSpread2.default)({
|
|
93
90
|
private: false
|
|
94
91
|
}, input.meta || {}),
|
|
@@ -141,6 +138,7 @@ const filesContextCrudPlugin = new _api.ContextPlugin(async context => {
|
|
|
141
138
|
checkOwnership(original, permission, context);
|
|
142
139
|
const file = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, original), input), {}, {
|
|
143
140
|
tags: Array.isArray(input.tags) ? input.tags : Array.isArray(original.tags) ? original.tags : [],
|
|
141
|
+
aliases: Array.isArray(input.aliases) ? input.aliases : Array.isArray(original.aliases) ? original.aliases : [],
|
|
144
142
|
id: original.id,
|
|
145
143
|
webinyVersion: context.WEBINY_VERSION
|
|
146
144
|
});
|
|
@@ -230,10 +228,10 @@ const filesContextCrudPlugin = new _api.ContextPlugin(async context => {
|
|
|
230
228
|
const files = inputs.map(input => {
|
|
231
229
|
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, input), {}, {
|
|
232
230
|
tags: Array.isArray(input.tags) ? input.tags : [],
|
|
231
|
+
aliases: Array.isArray(input.aliases) ? input.aliases : [],
|
|
233
232
|
meta: (0, _objectSpread2.default)({
|
|
234
233
|
private: false
|
|
235
234
|
}, input.meta || {}),
|
|
236
|
-
id: (0, _mdbid.default)(),
|
|
237
235
|
tenant: tenant.id,
|
|
238
236
|
createdOn: new Date().toISOString(),
|
|
239
237
|
createdBy,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["BATCH_CREATE_MAX_FILES","checkOwnership","file","permission","context","own","identity","security","getIdentity","createdBy","id","NotAuthorizedError","getLocaleCode","i18n","WebinyError","locale","getContentLocale","code","filesContextCrudPlugin","ContextPlugin","pluginType","FilesStorageOperationsProviderPlugin","type","providerPlugin","plugins","byType","find","storageOperations","provide","fileManager","filePlugins","FilePlugin","files","getFile","checkBasePermissions","rwd","get","where","tenant","tenancy","getCurrentTenant","NotFoundError","createFile","input","mdbid","tags","Array","isArray","meta","private","createdOn","Date","toISOString","displayName","webinyVersion","WEBINY_VERSION","runLifecycleEvent","data","result","create","ex","message","updateFile","original","update","deleteFile","delete","createFilesInBatch","inputs","length","map","results","createBatch","listFiles","params","limit","search","types","ids","after","initialWhere","sort","initialSort","type_in","tag_in","tag","toLowerCase","id_in","list","listTags","name"],"sources":["files.crud.ts"],"sourcesContent":["/**\n * Package mdbid does not have types.\n */\n// @ts-ignore\nimport mdbid from \"mdbid\";\nimport { NotFoundError } from \"@webiny/handler-graphql\";\nimport { NotAuthorizedError } from \"@webiny/api-security\";\nimport {\n CreatedBy,\n File,\n FileManagerContext,\n FileManagerFilesStorageOperationsListParamsWhere,\n FileManagerFilesStorageOperationsTagsParamsWhere,\n FilePermission,\n FilesListOpts\n} from \"~/types\";\nimport checkBasePermissions from \"./utils/checkBasePermissions\";\nimport { ContextPlugin } from \"@webiny/api\";\nimport { FilePlugin } from \"~/plugins/definitions/FilePlugin\";\nimport { FilesStorageOperationsProviderPlugin } from \"~/plugins/definitions/FilesStorageOperationsProviderPlugin\";\nimport WebinyError from \"@webiny/error\";\nimport { runLifecycleEvent } from \"~/plugins/crud/utils/lifecycleEvents\";\n\nconst BATCH_CREATE_MAX_FILES = 20;\n\n/**\n * If permission is limited to \"own\" files only, check that current identity owns the file.\n */\nconst checkOwnership = (file: File, permission: FilePermission, context: FileManagerContext) => {\n if (permission?.own === true) {\n const identity = context.security.getIdentity();\n if (file.createdBy.id !== identity.id) {\n throw new NotAuthorizedError();\n }\n }\n};\n\nconst getLocaleCode = (context: FileManagerContext): string => {\n if (!context.i18n) {\n throw new WebinyError(\"Missing i18n on the FileManagerContext.\", \"MISSING_I18N\");\n }\n\n const locale = context.i18n.getContentLocale();\n if (!locale) {\n throw new WebinyError(\n \"Missing content locale on the FileManagerContext.\",\n \"MISSING_I18N_CONTENT_LOCALE\"\n );\n }\n\n if (!locale.code) {\n throw new WebinyError(\n \"Missing content locale code on the FileManagerContext.\",\n \"MISSING_I18N_CONTENT_LOCALE_CODE\"\n );\n }\n return locale.code;\n};\n\nconst filesContextCrudPlugin = new ContextPlugin<FileManagerContext>(async context => {\n const pluginType = FilesStorageOperationsProviderPlugin.type;\n\n const providerPlugin = context.plugins\n .byType<FilesStorageOperationsProviderPlugin>(pluginType)\n .find(() => true);\n\n if (!providerPlugin) {\n throw new WebinyError(`Missing \"${pluginType}\" plugin.`, \"PLUGIN_NOT_FOUND\", {\n type: pluginType\n });\n }\n\n const storageOperations = await providerPlugin.provide({\n context\n });\n\n if (!context.fileManager) {\n context.fileManager = {} as any;\n }\n\n const filePlugins = context.plugins.byType<FilePlugin>(FilePlugin.type);\n\n context.fileManager.files = {\n async getFile(id: string) {\n const permission = await checkBasePermissions(context, { rwd: \"r\" });\n\n const file = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n\n if (!file) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(file, permission, context);\n\n return file;\n },\n async createFile(input) {\n await checkBasePermissions(context, { rwd: \"w\" });\n const identity = context.security.getIdentity();\n const tenant = context.tenancy.getCurrentTenant();\n\n const id = mdbid();\n\n const file: File = {\n ...input,\n tags: Array.isArray(input.tags) ? input.tags : [],\n id,\n meta: {\n private: false,\n ...(input.meta || {})\n },\n tenant: tenant.id,\n createdOn: new Date().toISOString(),\n createdBy: {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n },\n locale: getLocaleCode(context),\n webinyVersion: context.WEBINY_VERSION\n };\n\n try {\n await runLifecycleEvent(\"beforeCreate\", {\n context,\n plugins: filePlugins,\n data: file\n });\n const result = await storageOperations.create({\n file\n });\n await runLifecycleEvent(\"afterCreate\", {\n context,\n plugins: filePlugins,\n data: file,\n file: result\n });\n return result;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create a file.\",\n ex.code || \"CREATE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n file\n }\n );\n }\n },\n async updateFile(id, input) {\n const permission = await checkBasePermissions(context, { rwd: \"w\" });\n\n const original = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n\n if (!original) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(original, permission, context);\n\n const file: File = {\n ...original,\n ...input,\n tags: Array.isArray(input.tags)\n ? input.tags\n : Array.isArray(original.tags)\n ? original.tags\n : [],\n id: original.id,\n webinyVersion: context.WEBINY_VERSION\n };\n\n try {\n await runLifecycleEvent(\"beforeUpdate\", {\n context,\n plugins: filePlugins,\n original,\n data: file\n });\n const result = await storageOperations.update({\n original,\n file\n });\n await runLifecycleEvent(\"afterUpdate\", {\n context,\n plugins: filePlugins,\n original,\n data: file,\n file: result\n });\n return result;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update a file.\",\n ex.code || \"UPDATE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n original,\n file\n }\n );\n }\n },\n async deleteFile(id) {\n const permission = await checkBasePermissions(context, { rwd: \"d\" });\n\n const file = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n if (!file) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(file, permission, context);\n\n try {\n await runLifecycleEvent(\"beforeDelete\", {\n context,\n plugins: filePlugins,\n file\n });\n await storageOperations.delete({\n file\n });\n await runLifecycleEvent(\"afterDelete\", {\n context,\n plugins: filePlugins,\n file\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete a file.\",\n ex.code || \"DELETE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n id,\n file\n }\n );\n }\n\n return true;\n },\n async createFilesInBatch(inputs) {\n if (!Array.isArray(inputs)) {\n throw new WebinyError(`\"data\" must be an array.`, \"CREATE_FILES_NON_ARRAY\");\n }\n\n if (inputs.length === 0) {\n throw new WebinyError(\n `\"data\" argument must contain at least one file.`,\n \"CREATE_FILES_MIN_FILES\"\n );\n }\n\n if (inputs.length > BATCH_CREATE_MAX_FILES) {\n throw new WebinyError(\n `\"data\" argument must not contain more than ${BATCH_CREATE_MAX_FILES} files.`,\n \"CREATE_FILES_MAX_FILES\"\n );\n }\n\n await checkBasePermissions(context, { rwd: \"w\" });\n\n const identity = context.security.getIdentity();\n const tenant = context.tenancy.getCurrentTenant();\n const createdBy: CreatedBy = {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n };\n\n const files: File[] = inputs.map(input => {\n return {\n ...input,\n tags: Array.isArray(input.tags) ? input.tags : [],\n meta: {\n private: false,\n ...(input.meta || {})\n },\n id: mdbid(),\n tenant: tenant.id,\n createdOn: new Date().toISOString(),\n createdBy,\n locale: getLocaleCode(context),\n webinyVersion: context.WEBINY_VERSION\n };\n });\n\n try {\n await runLifecycleEvent(\"beforeBatchCreate\", {\n context,\n plugins: filePlugins,\n data: files\n });\n const results = await storageOperations.createBatch({\n files\n });\n await runLifecycleEvent(\"afterBatchCreate\", {\n context,\n plugins: filePlugins,\n data: files,\n files: results\n });\n return results;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create a batch of files.\",\n ex.code || \"CREATE_FILES_ERROR\",\n {\n ...(ex.data || {}),\n files\n }\n );\n }\n },\n async listFiles(params: FilesListOpts = {}) {\n const permission = await checkBasePermissions(context, { rwd: \"r\" });\n\n const {\n limit = 40,\n search = \"\",\n types = [],\n tags = [],\n ids = [],\n after = null,\n where: initialWhere,\n sort: initialSort\n } = params;\n\n const where: FileManagerFilesStorageOperationsListParamsWhere = {\n ...initialWhere,\n private: false,\n locale: getLocaleCode(context),\n tenant: context.tenancy.getCurrentTenant().id\n };\n /**\n * Always override the createdBy received from the user, if any.\n */\n if (permission.own === true) {\n const identity = context.security.getIdentity();\n where.createdBy = identity.id;\n }\n /**\n * We need to map the old GraphQL definition to the new one.\n * That GQL definition is marked as deprecated.\n */\n /**\n * To have standardized where objects across the applications, we transform the types into type_in.\n */\n if (Array.isArray(types) && types.length > 0 && !where.type_in) {\n where.type_in = types;\n }\n /**\n * We are assigning search to tag and name search.\n * This should be treated as OR condition in the storage operations.\n */\n if (search && !where.search) {\n where.search = search;\n }\n /**\n * Same as on types/type_in.\n */\n if (Array.isArray(tags) && tags.length > 0 && !where.tag_in) {\n where.tag_in = tags.map(tag => tag.toLowerCase());\n }\n /**\n * Same as on types/type_in.\n */\n if (Array.isArray(ids) && ids.length > 0 && !where.id_in) {\n where.id_in = ids;\n }\n\n const sort =\n Array.isArray(initialSort) && initialSort.length > 0 ? initialSort : [\"id_DESC\"];\n try {\n return await storageOperations.list({\n where,\n after,\n limit,\n sort\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not list files by given parameters.\",\n ex.code || \"FILE_TAG_SEARCH_ERROR\",\n {\n ...(ex.data || {}),\n where,\n after,\n limit,\n sort\n }\n );\n }\n },\n async listTags({ where: initialWhere, after, limit }) {\n await checkBasePermissions(context);\n\n const where: FileManagerFilesStorageOperationsTagsParamsWhere = {\n ...initialWhere,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n };\n\n const params = {\n where,\n limit: limit || 100000,\n after\n };\n\n try {\n const [tags] = await storageOperations.tags(params);\n if (Array.isArray(tags) === false) {\n return [];\n }\n /**\n * just to keep it standardized, sort by the tag ASC\n */\n return tags.sort();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not search for tags.\",\n ex.code || \"FILE_TAG_SEARCH_ERROR\",\n {\n ...(ex.data || {}),\n params\n }\n );\n }\n }\n };\n});\n\nfilesContextCrudPlugin.name = \"FileManagerFilesCrud\";\n\nexport default filesContextCrudPlugin;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["BATCH_CREATE_MAX_FILES","checkOwnership","file","permission","context","own","identity","security","getIdentity","createdBy","id","NotAuthorizedError","getLocaleCode","i18n","WebinyError","locale","getContentLocale","code","filesContextCrudPlugin","ContextPlugin","pluginType","FilesStorageOperationsProviderPlugin","type","providerPlugin","plugins","byType","find","storageOperations","provide","fileManager","filePlugins","FilePlugin","files","getFile","checkBasePermissions","rwd","get","where","tenant","tenancy","getCurrentTenant","NotFoundError","createFile","input","key","split","tags","Array","isArray","aliases","meta","private","createdOn","Date","toISOString","displayName","webinyVersion","WEBINY_VERSION","runLifecycleEvent","data","result","create","ex","message","updateFile","original","update","deleteFile","delete","createFilesInBatch","inputs","length","map","results","createBatch","listFiles","params","limit","search","types","ids","after","initialWhere","sort","initialSort","type_in","tag_in","tag","toLowerCase","id_in","list","listTags","name"],"sources":["files.crud.ts"],"sourcesContent":["import { NotFoundError } from \"@webiny/handler-graphql\";\nimport { NotAuthorizedError } from \"@webiny/api-security\";\nimport {\n CreatedBy,\n File,\n FileManagerContext,\n FileManagerFilesStorageOperationsListParamsWhere,\n FileManagerFilesStorageOperationsTagsParamsWhere,\n FilePermission,\n FilesListOpts\n} from \"~/types\";\nimport checkBasePermissions from \"./utils/checkBasePermissions\";\nimport { ContextPlugin } from \"@webiny/api\";\nimport { FilePlugin } from \"~/plugins/definitions/FilePlugin\";\nimport { FilesStorageOperationsProviderPlugin } from \"~/plugins/definitions/FilesStorageOperationsProviderPlugin\";\nimport WebinyError from \"@webiny/error\";\nimport { runLifecycleEvent } from \"~/plugins/crud/utils/lifecycleEvents\";\n\nconst BATCH_CREATE_MAX_FILES = 20;\n\n/**\n * If permission is limited to \"own\" files only, check that current identity owns the file.\n */\nconst checkOwnership = (file: File, permission: FilePermission, context: FileManagerContext) => {\n if (permission?.own === true) {\n const identity = context.security.getIdentity();\n if (file.createdBy.id !== identity.id) {\n throw new NotAuthorizedError();\n }\n }\n};\n\nconst getLocaleCode = (context: FileManagerContext): string => {\n if (!context.i18n) {\n throw new WebinyError(\"Missing i18n on the FileManagerContext.\", \"MISSING_I18N\");\n }\n\n const locale = context.i18n.getContentLocale();\n if (!locale) {\n throw new WebinyError(\n \"Missing content locale on the FileManagerContext.\",\n \"MISSING_I18N_CONTENT_LOCALE\"\n );\n }\n\n if (!locale.code) {\n throw new WebinyError(\n \"Missing content locale code on the FileManagerContext.\",\n \"MISSING_I18N_CONTENT_LOCALE_CODE\"\n );\n }\n return locale.code;\n};\n\nconst filesContextCrudPlugin = new ContextPlugin<FileManagerContext>(async context => {\n const pluginType = FilesStorageOperationsProviderPlugin.type;\n\n const providerPlugin = context.plugins\n .byType<FilesStorageOperationsProviderPlugin>(pluginType)\n .find(() => true);\n\n if (!providerPlugin) {\n throw new WebinyError(`Missing \"${pluginType}\" plugin.`, \"PLUGIN_NOT_FOUND\", {\n type: pluginType\n });\n }\n\n const storageOperations = await providerPlugin.provide({\n context\n });\n\n if (!context.fileManager) {\n context.fileManager = {} as any;\n }\n\n const filePlugins = context.plugins.byType<FilePlugin>(FilePlugin.type);\n\n context.fileManager.files = {\n async getFile(id: string) {\n const permission = await checkBasePermissions(context, { rwd: \"r\" });\n\n const file = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n\n if (!file) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(file, permission, context);\n\n return file;\n },\n async createFile(input) {\n await checkBasePermissions(context, { rwd: \"w\" });\n const identity = context.security.getIdentity();\n const tenant = context.tenancy.getCurrentTenant();\n\n // Extract ID from file key\n const [id] = input.key.split(\"/\");\n\n const file: File = {\n ...input,\n tags: Array.isArray(input.tags) ? input.tags : [],\n aliases: Array.isArray(input.aliases) ? input.aliases : [],\n id: input.id || id,\n meta: {\n private: false,\n ...(input.meta || {})\n },\n tenant: tenant.id,\n createdOn: new Date().toISOString(),\n createdBy: {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n },\n locale: getLocaleCode(context),\n webinyVersion: context.WEBINY_VERSION\n };\n\n try {\n await runLifecycleEvent(\"beforeCreate\", {\n context,\n plugins: filePlugins,\n data: file\n });\n const result = await storageOperations.create({\n file\n });\n await runLifecycleEvent(\"afterCreate\", {\n context,\n plugins: filePlugins,\n data: file,\n file: result\n });\n return result;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create a file.\",\n ex.code || \"CREATE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n file\n }\n );\n }\n },\n async updateFile(id, input) {\n const permission = await checkBasePermissions(context, { rwd: \"w\" });\n\n const original = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n\n if (!original) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(original, permission, context);\n\n const file: File = {\n ...original,\n ...input,\n tags: Array.isArray(input.tags)\n ? input.tags\n : Array.isArray(original.tags)\n ? original.tags\n : [],\n aliases: Array.isArray(input.aliases)\n ? input.aliases\n : Array.isArray(original.aliases)\n ? original.aliases\n : [],\n id: original.id,\n webinyVersion: context.WEBINY_VERSION\n };\n\n try {\n await runLifecycleEvent(\"beforeUpdate\", {\n context,\n plugins: filePlugins,\n original,\n data: file\n });\n const result = await storageOperations.update({\n original,\n file\n });\n await runLifecycleEvent(\"afterUpdate\", {\n context,\n plugins: filePlugins,\n original,\n data: file,\n file: result\n });\n return result;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update a file.\",\n ex.code || \"UPDATE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n original,\n file\n }\n );\n }\n },\n async deleteFile(id) {\n const permission = await checkBasePermissions(context, { rwd: \"d\" });\n\n const file = await storageOperations.get({\n where: {\n id,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n }\n });\n if (!file) {\n throw new NotFoundError(`File with id \"${id}\" does not exists.`);\n }\n\n checkOwnership(file, permission, context);\n\n try {\n await runLifecycleEvent(\"beforeDelete\", {\n context,\n plugins: filePlugins,\n file\n });\n await storageOperations.delete({\n file\n });\n await runLifecycleEvent(\"afterDelete\", {\n context,\n plugins: filePlugins,\n file\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete a file.\",\n ex.code || \"DELETE_FILE_ERROR\",\n {\n ...(ex.data || {}),\n id,\n file\n }\n );\n }\n\n return true;\n },\n async createFilesInBatch(inputs) {\n if (!Array.isArray(inputs)) {\n throw new WebinyError(`\"data\" must be an array.`, \"CREATE_FILES_NON_ARRAY\");\n }\n\n if (inputs.length === 0) {\n throw new WebinyError(\n `\"data\" argument must contain at least one file.`,\n \"CREATE_FILES_MIN_FILES\"\n );\n }\n\n if (inputs.length > BATCH_CREATE_MAX_FILES) {\n throw new WebinyError(\n `\"data\" argument must not contain more than ${BATCH_CREATE_MAX_FILES} files.`,\n \"CREATE_FILES_MAX_FILES\"\n );\n }\n\n await checkBasePermissions(context, { rwd: \"w\" });\n\n const identity = context.security.getIdentity();\n const tenant = context.tenancy.getCurrentTenant();\n const createdBy: CreatedBy = {\n id: identity.id,\n displayName: identity.displayName,\n type: identity.type\n };\n\n const files: File[] = inputs.map(input => {\n return {\n ...input,\n tags: Array.isArray(input.tags) ? input.tags : [],\n aliases: Array.isArray(input.aliases) ? input.aliases : [],\n meta: {\n private: false,\n ...(input.meta || {})\n },\n tenant: tenant.id,\n createdOn: new Date().toISOString(),\n createdBy,\n locale: getLocaleCode(context),\n webinyVersion: context.WEBINY_VERSION\n };\n });\n\n try {\n await runLifecycleEvent(\"beforeBatchCreate\", {\n context,\n plugins: filePlugins,\n data: files\n });\n const results = await storageOperations.createBatch({\n files\n });\n await runLifecycleEvent(\"afterBatchCreate\", {\n context,\n plugins: filePlugins,\n data: files,\n files: results\n });\n return results;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create a batch of files.\",\n ex.code || \"CREATE_FILES_ERROR\",\n {\n ...(ex.data || {}),\n files\n }\n );\n }\n },\n async listFiles(params: FilesListOpts = {}) {\n const permission = await checkBasePermissions(context, { rwd: \"r\" });\n\n const {\n limit = 40,\n search = \"\",\n types = [],\n tags = [],\n ids = [],\n after = null,\n where: initialWhere,\n sort: initialSort\n } = params;\n\n const where: FileManagerFilesStorageOperationsListParamsWhere = {\n ...initialWhere,\n private: false,\n locale: getLocaleCode(context),\n tenant: context.tenancy.getCurrentTenant().id\n };\n /**\n * Always override the createdBy received from the user, if any.\n */\n if (permission.own === true) {\n const identity = context.security.getIdentity();\n where.createdBy = identity.id;\n }\n /**\n * We need to map the old GraphQL definition to the new one.\n * That GQL definition is marked as deprecated.\n */\n /**\n * To have standardized where objects across the applications, we transform the types into type_in.\n */\n if (Array.isArray(types) && types.length > 0 && !where.type_in) {\n where.type_in = types;\n }\n /**\n * We are assigning search to tag and name search.\n * This should be treated as OR condition in the storage operations.\n */\n if (search && !where.search) {\n where.search = search;\n }\n /**\n * Same as on types/type_in.\n */\n if (Array.isArray(tags) && tags.length > 0 && !where.tag_in) {\n where.tag_in = tags.map(tag => tag.toLowerCase());\n }\n /**\n * Same as on types/type_in.\n */\n if (Array.isArray(ids) && ids.length > 0 && !where.id_in) {\n where.id_in = ids;\n }\n\n const sort =\n Array.isArray(initialSort) && initialSort.length > 0 ? initialSort : [\"id_DESC\"];\n try {\n return await storageOperations.list({\n where,\n after,\n limit,\n sort\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not list files by given parameters.\",\n ex.code || \"FILE_TAG_SEARCH_ERROR\",\n {\n ...(ex.data || {}),\n where,\n after,\n limit,\n sort\n }\n );\n }\n },\n async listTags({ where: initialWhere, after, limit }) {\n await checkBasePermissions(context);\n\n const where: FileManagerFilesStorageOperationsTagsParamsWhere = {\n ...initialWhere,\n tenant: context.tenancy.getCurrentTenant().id,\n locale: getLocaleCode(context)\n };\n\n const params = {\n where,\n limit: limit || 100000,\n after\n };\n\n try {\n const [tags] = await storageOperations.tags(params);\n if (Array.isArray(tags) === false) {\n return [];\n }\n /**\n * just to keep it standardized, sort by the tag ASC\n */\n return tags.sort();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not search for tags.\",\n ex.code || \"FILE_TAG_SEARCH_ERROR\",\n {\n ...(ex.data || {}),\n params\n }\n );\n }\n }\n };\n});\n\nfilesContextCrudPlugin.name = \"FileManagerFilesCrud\";\n\nexport default filesContextCrudPlugin;\n"],"mappings":"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"}
|
package/plugins/graphql.js
CHANGED
|
@@ -28,20 +28,33 @@ const plugin = {
|
|
|
28
28
|
displayName: String
|
|
29
29
|
}
|
|
30
30
|
|
|
31
|
-
input
|
|
31
|
+
input CreateFileInput {
|
|
32
|
+
id: ID!
|
|
33
|
+
key: String!
|
|
34
|
+
name: String!
|
|
35
|
+
size: Int!
|
|
36
|
+
type: String!
|
|
37
|
+
tags: [String!]
|
|
38
|
+
aliases: [String!]
|
|
39
|
+
meta: JSON
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
input UpdateFileInput {
|
|
32
43
|
key: String
|
|
33
44
|
name: String
|
|
34
45
|
size: Int
|
|
35
46
|
type: String
|
|
36
|
-
tags: [String]
|
|
47
|
+
tags: [String!]
|
|
48
|
+
aliases: [String!]
|
|
37
49
|
meta: JSON
|
|
38
50
|
}
|
|
39
51
|
|
|
40
52
|
type UploadFileResponseDataFile {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
53
|
+
id: ID!
|
|
54
|
+
name: String!
|
|
55
|
+
type: String!
|
|
56
|
+
size: Int!
|
|
57
|
+
key: String!
|
|
45
58
|
}
|
|
46
59
|
|
|
47
60
|
type UploadFileResponseData {
|
|
@@ -75,18 +88,19 @@ const plugin = {
|
|
|
75
88
|
}
|
|
76
89
|
|
|
77
90
|
type CreateFilesResponse {
|
|
78
|
-
data: [File]
|
|
91
|
+
data: [File]
|
|
79
92
|
error: FileError
|
|
80
93
|
}
|
|
81
94
|
|
|
82
95
|
type File {
|
|
83
|
-
id: ID
|
|
84
|
-
key: String
|
|
85
|
-
name: String
|
|
86
|
-
size: Int
|
|
87
|
-
type: String
|
|
88
|
-
src: String
|
|
89
|
-
tags: [String]
|
|
96
|
+
id: ID!
|
|
97
|
+
key: String!
|
|
98
|
+
name: String!
|
|
99
|
+
size: Int!
|
|
100
|
+
type: String!
|
|
101
|
+
src: String!
|
|
102
|
+
tags: [String!]
|
|
103
|
+
aliases: [String!]
|
|
90
104
|
meta: JSON
|
|
91
105
|
createdOn: DateTime
|
|
92
106
|
createdBy: FmCreatedBy
|
|
@@ -160,9 +174,9 @@ const plugin = {
|
|
|
160
174
|
}
|
|
161
175
|
|
|
162
176
|
type FmMutation {
|
|
163
|
-
createFile(data:
|
|
164
|
-
createFiles(data: [
|
|
165
|
-
updateFile(id: ID!, data:
|
|
177
|
+
createFile(data: CreateFileInput!): FileResponse
|
|
178
|
+
createFiles(data: [CreateFileInput]!): CreateFilesResponse
|
|
179
|
+
updateFile(id: ID!, data: UpdateFileInput!): FileResponse
|
|
166
180
|
deleteFile(id: ID!): FilesDeleteResponse
|
|
167
181
|
install(srcPrefix: String): FileManagerBooleanResponse
|
|
168
182
|
updateSettings(data: FileManagerSettingsInput): FileManagerSettingsResponse
|
package/plugins/graphql.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["emptyResolver","resolve","fn","Response","e","ErrorResponse","plugin","type","schema","typeDefs","resolvers","File","src","file","_","context","settings","fileManager","getSettings","srcPrefix","key","Query","Mutation","FmQuery","getFile","args","files","id","listFiles","data","meta","ListResponse","listTags","error","version","__","i18n","tenancy","getCurrentTenant","getContentLocale","system","getVersion","FmMutation","createFile","updateFile","createFiles","createFilesInBatch","deleteFile","storage","delete","install","updateSettings"],"sources":["graphql.ts"],"sourcesContent":["import { Response, ErrorResponse, ListResponse } from \"@webiny/handler-graphql\";\nimport { FileManagerContext, FilesListOpts } from \"~/types\";\nimport { GraphQLSchemaPlugin } from \"@webiny/handler-graphql/types\";\n\nconst emptyResolver = () => ({});\n\n/**\n * Use any because it really can be any.\n * TODO @ts-refactor maybe use generics at some point?\n */\ninterface ResolveCallable {\n (): Promise<any>;\n}\n\nconst resolve = async (fn: ResolveCallable) => {\n try {\n return new Response(await fn());\n } catch (e) {\n return new ErrorResponse(e);\n }\n};\n\nconst plugin: GraphQLSchemaPlugin<FileManagerContext> = {\n type: \"graphql-schema\",\n schema: {\n typeDefs: /* GraphQL */ `\n type FmCreatedBy {\n id: ID\n displayName: String\n }\n\n input FileInput {\n key: String\n name: String\n size: Int\n type: String\n tags: [String]\n meta: JSON\n }\n\n type UploadFileResponseDataFile {\n name: String\n type: String\n size: Int\n key: String\n }\n\n type UploadFileResponseData {\n # Contains data that is necessary for initiating a file upload.\n data: JSON\n file: UploadFileResponseDataFile\n }\n\n type FileListMeta {\n cursor: String\n totalCount: Int\n hasMoreItems: Boolean\n }\n\n type FileError {\n code: String\n message: String\n data: JSON\n stack: String\n }\n\n type FileListResponse {\n data: [File]\n meta: FileListMeta\n error: FileError\n }\n\n type FileResponse {\n data: File\n error: FileError\n }\n\n type CreateFilesResponse {\n data: [File]!\n error: FileError\n }\n\n type File {\n id: ID\n key: String\n name: String\n size: Int\n type: String\n src: String\n tags: [String]\n meta: JSON\n createdOn: DateTime\n createdBy: FmCreatedBy\n }\n\n type FileManagerBooleanResponse {\n data: Boolean\n error: FileError\n }\n\n type FileManagerSettings {\n uploadMinFileSize: Number\n uploadMaxFileSize: Number\n srcPrefix: String\n }\n\n input FileManagerSettingsInput {\n uploadMinFileSize: Number\n uploadMaxFileSize: Number\n srcPrefix: String\n }\n\n type FileManagerSettingsResponse {\n data: FileManagerSettings\n error: FileError\n }\n\n input FileWhereInput {\n search: String\n type: String\n type_in: [String!]\n tag: String\n tag_in: [String!]\n tag_and_in: [String!]\n tag_startsWith: String\n tag_not_startsWith: String\n id_in: [ID!]\n id: ID\n createdBy: ID\n }\n\n input TagWhereInput {\n tag_startsWith: String\n tag_not_startsWith: String\n }\n\n type FmQuery {\n getFile(id: ID, where: JSON, sort: String): FileResponse\n\n listFiles(\n limit: Int\n after: String\n types: [String]\n tags: [String]\n ids: [ID]\n search: String\n where: FileWhereInput\n ): FileListResponse\n\n listTags(where: TagWhereInput): [String]\n\n # Get installed version\n version: String\n\n getSettings: FileManagerSettingsResponse\n }\n\n type FilesDeleteResponse {\n data: Boolean\n error: FileError\n }\n\n type FmMutation {\n createFile(data: FileInput!): FileResponse\n createFiles(data: [FileInput]!): CreateFilesResponse\n updateFile(id: ID!, data: FileInput!): FileResponse\n deleteFile(id: ID!): FilesDeleteResponse\n install(srcPrefix: String): FileManagerBooleanResponse\n updateSettings(data: FileManagerSettingsInput): FileManagerSettingsResponse\n }\n\n input FilesInstallInput {\n srcPrefix: String!\n }\n\n extend type Query {\n fileManager: FmQuery\n }\n\n extend type Mutation {\n fileManager: FmMutation\n }\n `,\n resolvers: {\n File: {\n async src(file, _, context: FileManagerContext) {\n const settings = await context.fileManager.settings.getSettings();\n return (settings?.srcPrefix || \"\") + file.key;\n }\n },\n Query: {\n fileManager: emptyResolver\n },\n Mutation: {\n fileManager: emptyResolver\n },\n FmQuery: {\n getFile(_, args: any, context) {\n return resolve(() => context.fileManager.files.getFile(args.id));\n },\n async listFiles(_, args: FilesListOpts, context) {\n try {\n const [data, meta] = await context.fileManager.files.listFiles(args);\n return new ListResponse(data, meta);\n } catch (e) {\n return new ErrorResponse(e);\n }\n },\n async listTags(_, args: any, context) {\n try {\n return await context.fileManager.files.listTags(args || {});\n } catch (error) {\n return new ErrorResponse(error);\n }\n },\n async version(_, __, context) {\n const { i18n, tenancy, fileManager } = context;\n if (!tenancy.getCurrentTenant() || !i18n.getContentLocale()) {\n return null;\n }\n\n return await fileManager.system.getVersion();\n },\n async getSettings(_, __, context) {\n return resolve(() => context.fileManager.settings.getSettings());\n }\n },\n FmMutation: {\n async createFile(_, args: any, context) {\n return resolve(() => context.fileManager.files.createFile(args.data));\n },\n async updateFile(_, args: any, context) {\n return resolve(() => context.fileManager.files.updateFile(args.id, args.data));\n },\n async createFiles(_, args: any, context) {\n return resolve(() => context.fileManager.files.createFilesInBatch(args.data));\n },\n async deleteFile(_, args: any, context) {\n return resolve(async () => {\n const file = await context.fileManager.files.getFile(args.id);\n return await context.fileManager.storage.delete({\n id: file.id,\n key: file.key\n });\n });\n },\n async install(_, args: any, context) {\n return resolve(() =>\n context.fileManager.system.install({ srcPrefix: args.srcPrefix })\n );\n },\n async updateSettings(_, args: any, context) {\n return resolve(() => context.fileManager.settings.updateSettings(args.data));\n }\n }\n }\n }\n};\n\nexport default plugin;\n"],"mappings":";;;;;;AAAA;AAIA,MAAMA,aAAa,GAAG,OAAO,CAAC,CAAC,CAAC;;AAEhC;AACA;AACA;AACA;;AAKA,MAAMC,OAAO,GAAG,MAAOC,EAAmB,IAAK;EAC3C,IAAI;IACA,OAAO,IAAIC,wBAAQ,CAAC,MAAMD,EAAE,EAAE,CAAC;EACnC,CAAC,CAAC,OAAOE,CAAC,EAAE;IACR,OAAO,IAAIC,6BAAa,CAACD,CAAC,CAAC;EAC/B;AACJ,CAAC;AAED,MAAME,MAA+C,GAAG;EACpDC,IAAI,EAAE,gBAAgB;EACtBC,MAAM,EAAE;IACJC,QAAQ,EAAE,aAAe;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;IACDC,SAAS,EAAE;MACPC,IAAI,EAAE;QACF,MAAMC,GAAG,CAACC,IAAI,EAAEC,CA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"}
|
|
1
|
+
{"version":3,"names":["emptyResolver","resolve","fn","Response","e","ErrorResponse","plugin","type","schema","typeDefs","resolvers","File","src","file","_","context","settings","fileManager","getSettings","srcPrefix","key","Query","Mutation","FmQuery","getFile","args","files","id","listFiles","data","meta","ListResponse","listTags","error","version","__","i18n","tenancy","getCurrentTenant","getContentLocale","system","getVersion","FmMutation","createFile","updateFile","createFiles","createFilesInBatch","deleteFile","storage","delete","install","updateSettings"],"sources":["graphql.ts"],"sourcesContent":["import { Response, ErrorResponse, ListResponse } from \"@webiny/handler-graphql\";\nimport { FileManagerContext, FilesListOpts } from \"~/types\";\nimport { GraphQLSchemaPlugin } from \"@webiny/handler-graphql/types\";\n\nconst emptyResolver = () => ({});\n\n/**\n * Use any because it really can be any.\n * TODO @ts-refactor maybe use generics at some point?\n */\ninterface ResolveCallable {\n (): Promise<any>;\n}\n\nconst resolve = async (fn: ResolveCallable) => {\n try {\n return new Response(await fn());\n } catch (e) {\n return new ErrorResponse(e);\n }\n};\n\nconst plugin: GraphQLSchemaPlugin<FileManagerContext> = {\n type: \"graphql-schema\",\n schema: {\n typeDefs: /* GraphQL */ `\n type FmCreatedBy {\n id: ID\n displayName: String\n }\n\n input CreateFileInput {\n id: ID!\n key: String!\n name: String!\n size: Int!\n type: String!\n tags: [String!]\n aliases: [String!]\n meta: JSON\n }\n\n input UpdateFileInput {\n key: String\n name: String\n size: Int\n type: String\n tags: [String!]\n aliases: [String!]\n meta: JSON\n }\n\n type UploadFileResponseDataFile {\n id: ID!\n name: String!\n type: String!\n size: Int!\n key: String!\n }\n\n type UploadFileResponseData {\n # Contains data that is necessary for initiating a file upload.\n data: JSON\n file: UploadFileResponseDataFile\n }\n\n type FileListMeta {\n cursor: String\n totalCount: Int\n hasMoreItems: Boolean\n }\n\n type FileError {\n code: String\n message: String\n data: JSON\n stack: String\n }\n\n type FileListResponse {\n data: [File]\n meta: FileListMeta\n error: FileError\n }\n\n type FileResponse {\n data: File\n error: FileError\n }\n\n type CreateFilesResponse {\n data: [File]\n error: FileError\n }\n\n type File {\n id: ID!\n key: String!\n name: String!\n size: Int!\n type: String!\n src: String!\n tags: [String!]\n aliases: [String!]\n meta: JSON\n createdOn: DateTime\n createdBy: FmCreatedBy\n }\n\n type FileManagerBooleanResponse {\n data: Boolean\n error: FileError\n }\n\n type FileManagerSettings {\n uploadMinFileSize: Number\n uploadMaxFileSize: Number\n srcPrefix: String\n }\n\n input FileManagerSettingsInput {\n uploadMinFileSize: Number\n uploadMaxFileSize: Number\n srcPrefix: String\n }\n\n type FileManagerSettingsResponse {\n data: FileManagerSettings\n error: FileError\n }\n\n input FileWhereInput {\n search: String\n type: String\n type_in: [String!]\n tag: String\n tag_in: [String!]\n tag_and_in: [String!]\n tag_startsWith: String\n tag_not_startsWith: String\n id_in: [ID!]\n id: ID\n createdBy: ID\n }\n\n input TagWhereInput {\n tag_startsWith: String\n tag_not_startsWith: String\n }\n\n type FmQuery {\n getFile(id: ID, where: JSON, sort: String): FileResponse\n\n listFiles(\n limit: Int\n after: String\n types: [String]\n tags: [String]\n ids: [ID]\n search: String\n where: FileWhereInput\n ): FileListResponse\n\n listTags(where: TagWhereInput): [String]\n\n # Get installed version\n version: String\n\n getSettings: FileManagerSettingsResponse\n }\n\n type FilesDeleteResponse {\n data: Boolean\n error: FileError\n }\n\n type FmMutation {\n createFile(data: CreateFileInput!): FileResponse\n createFiles(data: [CreateFileInput]!): CreateFilesResponse\n updateFile(id: ID!, data: UpdateFileInput!): FileResponse\n deleteFile(id: ID!): FilesDeleteResponse\n install(srcPrefix: String): FileManagerBooleanResponse\n updateSettings(data: FileManagerSettingsInput): FileManagerSettingsResponse\n }\n\n input FilesInstallInput {\n srcPrefix: String!\n }\n\n extend type Query {\n fileManager: FmQuery\n }\n\n extend type Mutation {\n fileManager: FmMutation\n }\n `,\n resolvers: {\n File: {\n async src(file, _, context: FileManagerContext) {\n const settings = await context.fileManager.settings.getSettings();\n return (settings?.srcPrefix || \"\") + file.key;\n }\n },\n Query: {\n fileManager: emptyResolver\n },\n Mutation: {\n fileManager: emptyResolver\n },\n FmQuery: {\n getFile(_, args: any, context) {\n return resolve(() => context.fileManager.files.getFile(args.id));\n },\n async listFiles(_, args: FilesListOpts, context) {\n try {\n const [data, meta] = await context.fileManager.files.listFiles(args);\n return new ListResponse(data, meta);\n } catch (e) {\n return new ErrorResponse(e);\n }\n },\n async listTags(_, args: any, context) {\n try {\n return await context.fileManager.files.listTags(args || {});\n } catch (error) {\n return new ErrorResponse(error);\n }\n },\n async version(_, __, context) {\n const { i18n, tenancy, fileManager } = context;\n if (!tenancy.getCurrentTenant() || !i18n.getContentLocale()) {\n return null;\n }\n\n return await fileManager.system.getVersion();\n },\n async getSettings(_, __, context) {\n return resolve(() => context.fileManager.settings.getSettings());\n }\n },\n FmMutation: {\n async createFile(_, args: any, context) {\n return resolve(() => context.fileManager.files.createFile(args.data));\n },\n async updateFile(_, args: any, context) {\n return resolve(() => context.fileManager.files.updateFile(args.id, args.data));\n },\n async createFiles(_, args: any, context) {\n return resolve(() => context.fileManager.files.createFilesInBatch(args.data));\n },\n async deleteFile(_, args: any, context) {\n return resolve(async () => {\n const file = await context.fileManager.files.getFile(args.id);\n return await context.fileManager.storage.delete({\n id: file.id,\n key: file.key\n });\n });\n },\n async install(_, args: any, context) {\n return resolve(() =>\n context.fileManager.system.install({ srcPrefix: args.srcPrefix })\n );\n },\n async updateSettings(_, args: any, context) {\n return resolve(() => context.fileManager.settings.updateSettings(args.data));\n }\n }\n }\n }\n};\n\nexport default plugin;\n"],"mappings":";;;;;;AAAA;AAIA,MAAMA,aAAa,GAAG,OAAO,CAAC,CAAC,CAAC;;AAEhC;AACA;AACA;AACA;;AAKA,MAAMC,OAAO,GAAG,MAAOC,EAAmB,IAAK;EAC3C,IAAI;IACA,OAAO,IAAIC,wBAAQ,CAAC,MAAMD,EAAE,EAAE,CAAC;EACnC,CAAC,CAAC,OAAOE,CAAC,EAAE;IACR,OAAO,IAAIC,6BAAa,CAACD,CAAC,CAAC;EAC/B;AACJ,CAAC;AAED,MAAME,MAA+C,GAAG;EACpDC,IAAI,EAAE,gBAAgB;EACtBC,MAAM,EAAE;IACJC,QAAQ,EAAE,aAAe;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SA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"}
|
package/types.d.ts
CHANGED
|
@@ -24,6 +24,7 @@ export interface File {
|
|
|
24
24
|
name: string;
|
|
25
25
|
meta: Record<string, any>;
|
|
26
26
|
tags: string[];
|
|
27
|
+
aliases: string[];
|
|
27
28
|
createdOn: string;
|
|
28
29
|
createdBy: CreatedBy;
|
|
29
30
|
/**
|
|
@@ -37,18 +38,26 @@ export interface File {
|
|
|
37
38
|
*/
|
|
38
39
|
[key: string]: any;
|
|
39
40
|
}
|
|
41
|
+
export interface FileAlias {
|
|
42
|
+
tenant: string;
|
|
43
|
+
locale: string;
|
|
44
|
+
fileId: string;
|
|
45
|
+
alias: string;
|
|
46
|
+
}
|
|
40
47
|
export interface CreatedBy {
|
|
41
48
|
id: string;
|
|
42
49
|
displayName: string | null;
|
|
43
50
|
type: string;
|
|
44
51
|
}
|
|
45
52
|
export interface FileInput {
|
|
53
|
+
id: string;
|
|
46
54
|
key: string;
|
|
47
55
|
name: string;
|
|
48
56
|
size: number;
|
|
49
57
|
type: string;
|
|
50
58
|
meta: Record<string, any>;
|
|
51
59
|
tags: string[];
|
|
60
|
+
aliases: string[];
|
|
52
61
|
}
|
|
53
62
|
export interface FileListWhereParams {
|
|
54
63
|
search?: string;
|
package/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import { I18NContext } from \"@webiny/api-i18n/types\";\nimport { FileStorage } from \"./plugins/storage/FileStorage\";\nimport { TenancyContext } from \"@webiny/api-tenancy/types\";\nimport { SecurityContext, SecurityPermission } from \"@webiny/api-security/types\";\nimport { Context } from \"@webiny/api/types\";\n\nexport interface FileManagerContext extends Context, SecurityContext, TenancyContext, I18NContext {\n fileManager: {\n files: FilesCRUD;\n settings: SettingsCRUD;\n storage: FileStorage;\n system: SystemCRUD;\n };\n}\n\nexport interface FilePermission extends SecurityPermission {\n name: \"fm.file\";\n rwd?: string;\n own?: boolean;\n}\n\nexport interface File {\n id: string;\n key: string;\n size: number;\n type: string;\n name: string;\n meta: Record<string, any>;\n tags: string[];\n createdOn: string;\n createdBy: CreatedBy;\n /**\n * Added with new storage operations refactoring.\n */\n tenant: string;\n locale: string;\n webinyVersion: string;\n /**\n * User can add new fields to the File object so we must allow it in the types.\n */\n [key: string]: any;\n}\n\nexport interface CreatedBy {\n id: string;\n displayName: string | null;\n type: string;\n}\n\nexport interface FileInput {\n key: string;\n name: string;\n size: number;\n type: string;\n meta: Record<string, any>;\n tags: string[];\n}\n\nexport interface FileListWhereParams {\n search?: string;\n type?: string;\n type_in?: string[];\n tag?: string;\n tag_in?: string[];\n tag_and_in?: string[];\n id_in?: string[];\n id?: string;\n}\nexport interface FilesListOpts {\n search?: string;\n types?: string[];\n tags?: string[];\n ids?: string[];\n limit?: number;\n after?: string;\n where?: FileListWhereParams;\n sort?: string[];\n}\n\nexport interface FileListMeta {\n cursor: string | null;\n totalCount: number;\n hasMoreItems: boolean;\n}\n\ninterface FilesCrudListTagsWhere {\n tag?: string;\n tag_contains?: string;\n tag_in?: string[];\n tag_not_startsWith?: string;\n tag_startsWith?: string;\n}\ninterface FilesCrudListTagsParams {\n where?: FilesCrudListTagsWhere;\n limit?: number;\n after?: string;\n}\n\nexport interface FilesCRUD {\n getFile(id: string): Promise<File>;\n listFiles(opts?: FilesListOpts): Promise<[File[], FileListMeta]>;\n listTags(params: FilesCrudListTagsParams): Promise<string[]>;\n createFile(data: FileInput): Promise<File>;\n updateFile(id: string, data: Partial<FileInput>): Promise<File>;\n deleteFile(id: string): Promise<boolean>;\n createFilesInBatch(data: FileInput[]): Promise<File[]>;\n}\n\nexport interface SystemCRUD {\n getVersion(): Promise<string | null>;\n setVersion(version: string): Promise<void>;\n install(args: { srcPrefix: string }): Promise<boolean>;\n}\n\nexport interface FileManagerSettings {\n key: string;\n uploadMinFileSize: number;\n uploadMaxFileSize: number;\n srcPrefix: string;\n}\n\nexport interface FileManagerSystem {\n version: string;\n tenant: string;\n}\n\nexport type SettingsCRUD = {\n getSettings(): Promise<FileManagerSettings | null>;\n createSettings(data?: Partial<FileManagerSettings>): Promise<FileManagerSettings>;\n updateSettings(data: Partial<FileManagerSettings>): Promise<FileManagerSettings>;\n deleteSettings(): Promise<boolean>;\n};\n/********\n * Storage operations\n *******/\n\n/**\n * @category StorageOperations\n * @category SystemStorageOperations\n * @category SystemStorageOperationsParams\n */\nexport interface FileManagerSystemStorageOperationsUpdateParams {\n /**\n * The system data to be updated.\n */\n original: FileManagerSystem;\n /**\n * The system data with the updated fields.\n */\n data: FileManagerSystem;\n}\n/**\n * @category StorageOperations\n * @category SystemStorageOperations\n * @category SystemStorageOperationsParams\n */\nexport interface FileManagerSystemStorageOperationsCreateParams {\n /**\n * The system fields.\n */\n data: FileManagerSystem;\n}\n\n/**\n * @category StorageOperations\n * @category SystemStorageOperations\n */\nexport interface FileManagerSystemStorageOperations {\n /**\n * Get the FileManager system data.\n */\n get: () => Promise<FileManagerSystem | null>;\n /**\n * Update the FileManager system data..\n */\n update: (params: FileManagerSystemStorageOperationsUpdateParams) => Promise<FileManagerSystem>;\n /**\n * Create the FileManagerSystemData\n */\n create: (params: FileManagerSystemStorageOperationsCreateParams) => Promise<FileManagerSystem>;\n}\n\n/**\n * @category StorageOperations\n * @category SettingsStorageOperations\n * @category SettingsStorageOperationsParams\n */\nexport interface FileManagerSettingsStorageOperationsUpdateParams {\n /**\n * Original settings to be updated.\n */\n original: FileManagerSettings;\n /**\n * The settings with the updated fields.\n */\n data: FileManagerSettings;\n}\n/**\n * @category StorageOperations\n * @category SettingsStorageOperations\n * @category SettingsStorageOperationsParams\n */\nexport interface FileManagerSettingsStorageOperationsCreateParams {\n /**\n * The settings fields.\n */\n data: FileManagerSettings;\n}\n\n/**\n * @category StorageOperations\n * @category SettingsStorageOperations\n */\nexport interface FileManagerSettingsStorageOperations {\n /**\n * Get the FileManager system data.\n */\n get: () => Promise<FileManagerSettings | null>;\n /**\n * Create the FileManagerSettingsData\n */\n create: (\n params: FileManagerSettingsStorageOperationsCreateParams\n ) => Promise<FileManagerSettings>;\n /**\n * Update the FileManager system data..\n */\n update: (\n params: FileManagerSettingsStorageOperationsUpdateParams\n ) => Promise<FileManagerSettings>;\n /**\n * Delete the existing settings.\n */\n delete: () => Promise<void>;\n}\n\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsGetParams {\n where: {\n id: string;\n tenant: string;\n locale: string;\n };\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsCreateParams {\n file: File;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsUpdateParams {\n original: File;\n file: File;\n}\n\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsDeleteParams {\n file: File;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsCreateBatchParams {\n files: File[];\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsListParamsWhere {\n id?: string;\n id_in?: string[];\n name?: string;\n name_contains?: string;\n tag?: string;\n tag_contains?: string;\n tag_in?: string[];\n createdBy?: string;\n locale: string;\n tenant: string;\n private?: boolean;\n type?: string;\n type_in?: string[];\n search?: string;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsListParams {\n where: FileManagerFilesStorageOperationsListParamsWhere;\n sort: string[];\n limit: number;\n after: string | null;\n}\n\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsListResponseMeta {\n hasMoreItems: boolean;\n totalCount: number;\n cursor: string | null;\n}\nexport type FileManagerFilesStorageOperationsListResponse = [\n File[],\n FileManagerFilesStorageOperationsListResponseMeta\n];\n\nexport type FileManagerFilesStorageOperationsTagsResponse = [\n string[],\n FileManagerFilesStorageOperationsListResponseMeta\n];\n\nexport interface FileManagerFilesStorageOperationsTagsParamsWhere extends FilesCrudListTagsWhere {\n locale: string;\n tenant: string;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsTagsParams {\n where: FileManagerFilesStorageOperationsTagsParamsWhere;\n limit: number;\n after?: string;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n */\nexport interface FileManagerFilesStorageOperations {\n /**\n * Get a single file with given ID from the storage.\n */\n get: (params: FileManagerFilesStorageOperationsGetParams) => Promise<File | null>;\n /**\n * Insert the file data into the database.\n */\n create: (params: FileManagerFilesStorageOperationsCreateParams) => Promise<File>;\n /**\n * Update the file data in the database.\n */\n update: (params: FileManagerFilesStorageOperationsUpdateParams) => Promise<File>;\n /**\n * Delete the file from the database.\n */\n delete: (params: FileManagerFilesStorageOperationsDeleteParams) => Promise<void>;\n /**\n * Store multiple files at once to the database.\n */\n createBatch: (params: FileManagerFilesStorageOperationsCreateBatchParams) => Promise<File[]>;\n /**\n * Get a list of files filtered by given parameters.\n */\n list: (\n params: FileManagerFilesStorageOperationsListParams\n ) => Promise<FileManagerFilesStorageOperationsListResponse>;\n /**\n * Get a list of all file tags filtered by given parameters.\n */\n tags: (\n params: FileManagerFilesStorageOperationsTagsParams\n ) => Promise<FileManagerFilesStorageOperationsTagsResponse>;\n}\n"],"mappings":""}
|
|
1
|
+
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import { I18NContext } from \"@webiny/api-i18n/types\";\nimport { FileStorage } from \"./plugins/storage/FileStorage\";\nimport { TenancyContext } from \"@webiny/api-tenancy/types\";\nimport { SecurityContext, SecurityPermission } from \"@webiny/api-security/types\";\nimport { Context } from \"@webiny/api/types\";\n\nexport interface FileManagerContext extends Context, SecurityContext, TenancyContext, I18NContext {\n fileManager: {\n files: FilesCRUD;\n settings: SettingsCRUD;\n storage: FileStorage;\n system: SystemCRUD;\n };\n}\n\nexport interface FilePermission extends SecurityPermission {\n name: \"fm.file\";\n rwd?: string;\n own?: boolean;\n}\n\nexport interface File {\n id: string;\n key: string;\n size: number;\n type: string;\n name: string;\n meta: Record<string, any>;\n tags: string[];\n aliases: string[];\n createdOn: string;\n createdBy: CreatedBy;\n /**\n * Added with new storage operations refactoring.\n */\n tenant: string;\n locale: string;\n webinyVersion: string;\n /**\n * User can add new fields to the File object so we must allow it in the types.\n */\n [key: string]: any;\n}\n\nexport interface FileAlias {\n tenant: string;\n locale: string;\n fileId: string;\n alias: string;\n}\n\nexport interface CreatedBy {\n id: string;\n displayName: string | null;\n type: string;\n}\n\nexport interface FileInput {\n id: string;\n key: string;\n name: string;\n size: number;\n type: string;\n meta: Record<string, any>;\n tags: string[];\n aliases: string[];\n}\n\nexport interface FileListWhereParams {\n search?: string;\n type?: string;\n type_in?: string[];\n tag?: string;\n tag_in?: string[];\n tag_and_in?: string[];\n id_in?: string[];\n id?: string;\n}\nexport interface FilesListOpts {\n search?: string;\n types?: string[];\n tags?: string[];\n ids?: string[];\n limit?: number;\n after?: string;\n where?: FileListWhereParams;\n sort?: string[];\n}\n\nexport interface FileListMeta {\n cursor: string | null;\n totalCount: number;\n hasMoreItems: boolean;\n}\n\ninterface FilesCrudListTagsWhere {\n tag?: string;\n tag_contains?: string;\n tag_in?: string[];\n tag_not_startsWith?: string;\n tag_startsWith?: string;\n}\ninterface FilesCrudListTagsParams {\n where?: FilesCrudListTagsWhere;\n limit?: number;\n after?: string;\n}\n\nexport interface FilesCRUD {\n getFile(id: string): Promise<File>;\n listFiles(opts?: FilesListOpts): Promise<[File[], FileListMeta]>;\n listTags(params: FilesCrudListTagsParams): Promise<string[]>;\n createFile(data: FileInput): Promise<File>;\n updateFile(id: string, data: Partial<FileInput>): Promise<File>;\n deleteFile(id: string): Promise<boolean>;\n createFilesInBatch(data: FileInput[]): Promise<File[]>;\n}\n\nexport interface SystemCRUD {\n getVersion(): Promise<string | null>;\n setVersion(version: string): Promise<void>;\n install(args: { srcPrefix: string }): Promise<boolean>;\n}\n\nexport interface FileManagerSettings {\n key: string;\n uploadMinFileSize: number;\n uploadMaxFileSize: number;\n srcPrefix: string;\n}\n\nexport interface FileManagerSystem {\n version: string;\n tenant: string;\n}\n\nexport type SettingsCRUD = {\n getSettings(): Promise<FileManagerSettings | null>;\n createSettings(data?: Partial<FileManagerSettings>): Promise<FileManagerSettings>;\n updateSettings(data: Partial<FileManagerSettings>): Promise<FileManagerSettings>;\n deleteSettings(): Promise<boolean>;\n};\n/********\n * Storage operations\n *******/\n\n/**\n * @category StorageOperations\n * @category SystemStorageOperations\n * @category SystemStorageOperationsParams\n */\nexport interface FileManagerSystemStorageOperationsUpdateParams {\n /**\n * The system data to be updated.\n */\n original: FileManagerSystem;\n /**\n * The system data with the updated fields.\n */\n data: FileManagerSystem;\n}\n/**\n * @category StorageOperations\n * @category SystemStorageOperations\n * @category SystemStorageOperationsParams\n */\nexport interface FileManagerSystemStorageOperationsCreateParams {\n /**\n * The system fields.\n */\n data: FileManagerSystem;\n}\n\n/**\n * @category StorageOperations\n * @category SystemStorageOperations\n */\nexport interface FileManagerSystemStorageOperations {\n /**\n * Get the FileManager system data.\n */\n get: () => Promise<FileManagerSystem | null>;\n /**\n * Update the FileManager system data..\n */\n update: (params: FileManagerSystemStorageOperationsUpdateParams) => Promise<FileManagerSystem>;\n /**\n * Create the FileManagerSystemData\n */\n create: (params: FileManagerSystemStorageOperationsCreateParams) => Promise<FileManagerSystem>;\n}\n\n/**\n * @category StorageOperations\n * @category SettingsStorageOperations\n * @category SettingsStorageOperationsParams\n */\nexport interface FileManagerSettingsStorageOperationsUpdateParams {\n /**\n * Original settings to be updated.\n */\n original: FileManagerSettings;\n /**\n * The settings with the updated fields.\n */\n data: FileManagerSettings;\n}\n/**\n * @category StorageOperations\n * @category SettingsStorageOperations\n * @category SettingsStorageOperationsParams\n */\nexport interface FileManagerSettingsStorageOperationsCreateParams {\n /**\n * The settings fields.\n */\n data: FileManagerSettings;\n}\n\n/**\n * @category StorageOperations\n * @category SettingsStorageOperations\n */\nexport interface FileManagerSettingsStorageOperations {\n /**\n * Get the FileManager system data.\n */\n get: () => Promise<FileManagerSettings | null>;\n /**\n * Create the FileManagerSettingsData\n */\n create: (\n params: FileManagerSettingsStorageOperationsCreateParams\n ) => Promise<FileManagerSettings>;\n /**\n * Update the FileManager system data..\n */\n update: (\n params: FileManagerSettingsStorageOperationsUpdateParams\n ) => Promise<FileManagerSettings>;\n /**\n * Delete the existing settings.\n */\n delete: () => Promise<void>;\n}\n\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsGetParams {\n where: {\n id: string;\n tenant: string;\n locale: string;\n };\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsCreateParams {\n file: File;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsUpdateParams {\n original: File;\n file: File;\n}\n\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsDeleteParams {\n file: File;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsCreateBatchParams {\n files: File[];\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsListParamsWhere {\n id?: string;\n id_in?: string[];\n name?: string;\n name_contains?: string;\n tag?: string;\n tag_contains?: string;\n tag_in?: string[];\n createdBy?: string;\n locale: string;\n tenant: string;\n private?: boolean;\n type?: string;\n type_in?: string[];\n search?: string;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsListParams {\n where: FileManagerFilesStorageOperationsListParamsWhere;\n sort: string[];\n limit: number;\n after: string | null;\n}\n\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsListResponseMeta {\n hasMoreItems: boolean;\n totalCount: number;\n cursor: string | null;\n}\nexport type FileManagerFilesStorageOperationsListResponse = [\n File[],\n FileManagerFilesStorageOperationsListResponseMeta\n];\n\nexport type FileManagerFilesStorageOperationsTagsResponse = [\n string[],\n FileManagerFilesStorageOperationsListResponseMeta\n];\n\nexport interface FileManagerFilesStorageOperationsTagsParamsWhere extends FilesCrudListTagsWhere {\n locale: string;\n tenant: string;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n * @category FilesStorageOperationsParams\n */\nexport interface FileManagerFilesStorageOperationsTagsParams {\n where: FileManagerFilesStorageOperationsTagsParamsWhere;\n limit: number;\n after?: string;\n}\n/**\n * @category StorageOperations\n * @category FilesStorageOperations\n */\nexport interface FileManagerFilesStorageOperations {\n /**\n * Get a single file with given ID from the storage.\n */\n get: (params: FileManagerFilesStorageOperationsGetParams) => Promise<File | null>;\n /**\n * Insert the file data into the database.\n */\n create: (params: FileManagerFilesStorageOperationsCreateParams) => Promise<File>;\n /**\n * Update the file data in the database.\n */\n update: (params: FileManagerFilesStorageOperationsUpdateParams) => Promise<File>;\n /**\n * Delete the file from the database.\n */\n delete: (params: FileManagerFilesStorageOperationsDeleteParams) => Promise<void>;\n /**\n * Store multiple files at once to the database.\n */\n createBatch: (params: FileManagerFilesStorageOperationsCreateBatchParams) => Promise<File[]>;\n /**\n * Get a list of files filtered by given parameters.\n */\n list: (\n params: FileManagerFilesStorageOperationsListParams\n ) => Promise<FileManagerFilesStorageOperationsListResponse>;\n /**\n * Get a list of all file tags filtered by given parameters.\n */\n tags: (\n params: FileManagerFilesStorageOperationsTagsParams\n ) => Promise<FileManagerFilesStorageOperationsTagsResponse>;\n}\n"],"mappings":""}
|