@webiny/handler-aws 6.3.0-beta.4 → 6.4.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/createHandler.js +16 -22
- package/createHandler.js.map +1 -1
- package/dynamodb/index.js +34 -49
- package/dynamodb/index.js.map +1 -1
- package/dynamodb/plugins/DynamoDBEventHandler.js +10 -9
- package/dynamodb/plugins/DynamoDBEventHandler.js.map +1 -1
- package/dynamodb/register.js +8 -18
- package/dynamodb/register.js.map +1 -1
- package/eventBridge/index.js +34 -49
- package/eventBridge/index.js.map +1 -1
- package/eventBridge/plugins/EventBridgeEventHandler.js +10 -9
- package/eventBridge/plugins/EventBridgeEventHandler.js.map +1 -1
- package/eventBridge/register.js +3 -11
- package/eventBridge/register.js.map +1 -1
- package/execute.js +52 -60
- package/execute.js.map +1 -1
- package/gateway/index.js +39 -67
- package/gateway/index.js.map +1 -1
- package/gateway/register.js +3 -11
- package/gateway/register.js.map +1 -1
- package/index.js +8 -39
- package/package.json +8 -8
- package/plugins/index.js +3 -4
- package/plugins/index.js.map +1 -1
- package/raw/index.js +38 -63
- package/raw/index.js.map +1 -1
- package/raw/plugins/RawEventHandler.js +11 -21
- package/raw/plugins/RawEventHandler.js.map +1 -1
- package/registry.js +17 -32
- package/registry.js.map +1 -1
- package/s3/index.js +34 -49
- package/s3/index.js.map +1 -1
- package/s3/plugins/S3EventHandler.js +10 -9
- package/s3/plugins/S3EventHandler.js.map +1 -1
- package/s3/register.js +7 -15
- package/s3/register.js.map +1 -1
- package/sns/index.js +34 -49
- package/sns/index.js.map +1 -1
- package/sns/plugins/SNSEventHandler.js +10 -9
- package/sns/plugins/SNSEventHandler.js.map +1 -1
- package/sns/register.js +7 -15
- package/sns/register.js.map +1 -1
- package/sourceHandler.js +2 -3
- package/sourceHandler.js.map +1 -1
- package/sqs/index.js +35 -52
- package/sqs/index.js.map +1 -1
- package/sqs/plugins/SQSEventHandler.js +10 -9
- package/sqs/plugins/SQSEventHandler.js.map +1 -1
- package/sqs/register.js +8 -18
- package/sqs/register.js.map +1 -1
- package/types.js +5 -4
- package/types.js.map +1 -1
- package/utils/composedHandler.js +5 -14
- package/utils/composedHandler.js.map +1 -1
- package/utils/index.js +0 -2
- package/utils/timer/CustomTimer.js +9 -8
- package/utils/timer/CustomTimer.js.map +1 -1
- package/utils/timer/Timer.js +12 -13
- package/utils/timer/Timer.js.map +1 -1
- package/utils/timer/abstractions/ITimer.js +0 -3
- package/utils/timer/factory.js +7 -8
- package/utils/timer/factory.js.map +1 -1
- package/utils/timer/index.js +0 -2
- package/index.js.map +0 -1
- package/utils/index.js.map +0 -1
- package/utils/timer/abstractions/ITimer.js.map +0 -1
- package/utils/timer/index.js.map +0 -1
package/createHandler.js
CHANGED
|
@@ -1,29 +1,23 @@
|
|
|
1
1
|
import { AsyncPluginsContainer } from "@webiny/plugins";
|
|
2
2
|
import { registry } from "./registry.js";
|
|
3
|
-
|
|
4
|
-
// TODO: Once we have a better infrastructure for handling such cases, we should refactor this.
|
|
5
|
-
// Ideally, the DI container should already be ready to be used in these `handler` packages.
|
|
6
|
-
// At the moment, that is not the case, so we have to hardcode `pino-lambda` here.
|
|
7
3
|
import { lambdaRequestTracker } from "pino-lambda";
|
|
8
4
|
const withRequest = lambdaRequestTracker();
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
context
|
|
25
|
-
});
|
|
26
|
-
};
|
|
5
|
+
const createHandler = ({ plugins, ...params })=>{
|
|
6
|
+
const pluginsContainer = new AsyncPluginsContainer(plugins);
|
|
7
|
+
return async (event, context = {})=>{
|
|
8
|
+
withRequest(event, context);
|
|
9
|
+
const plugins = await pluginsContainer.init();
|
|
10
|
+
const handler = registry.getHandler(event, context);
|
|
11
|
+
return handler.handle({
|
|
12
|
+
params: {
|
|
13
|
+
...params,
|
|
14
|
+
plugins
|
|
15
|
+
},
|
|
16
|
+
event,
|
|
17
|
+
context
|
|
18
|
+
});
|
|
19
|
+
};
|
|
27
20
|
};
|
|
21
|
+
export { createHandler };
|
|
28
22
|
|
|
29
23
|
//# sourceMappingURL=createHandler.js.map
|
package/createHandler.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"createHandler.js","sources":["../src/createHandler.ts"],"sourcesContent":["import { AsyncPluginsContainer } from \"@webiny/plugins\";\nimport type { HandlerFactory, LambdaContext } from \"~/types.js\";\nimport { registry } from \"./registry.js\";\n\n// TODO: Once we have a better infrastructure for handling such cases, we should refactor this.\n// Ideally, the DI container should already be ready to be used in these `handler` packages.\n// At the moment, that is not the case, so we have to hardcode `pino-lambda` here.\nimport { lambdaRequestTracker } from \"pino-lambda\";\n\nconst withRequest = lambdaRequestTracker();\n\nexport const createHandler: HandlerFactory = ({ plugins, ...params }) => {\n const pluginsContainer = new AsyncPluginsContainer(plugins);\n\n return async (event, context = {} as LambdaContext) => {\n withRequest(event, context);\n\n const plugins = await pluginsContainer.init();\n const handler = registry.getHandler(event, context);\n return handler.handle({\n params: {\n ...params,\n plugins\n },\n event,\n context\n });\n };\n};\n"],"names":["withRequest","lambdaRequestTracker","createHandler","plugins","params","pluginsContainer","AsyncPluginsContainer","event","context","handler","registry"],"mappings":";;;AASA,MAAMA,cAAcC;AAEb,MAAMC,gBAAgC,CAAC,EAAEC,OAAO,EAAE,GAAGC,QAAQ;IAChE,MAAMC,mBAAmB,IAAIC,sBAAsBH;IAEnD,OAAO,OAAOI,OAAOC,UAAU,CAAC,CAAkB;QAC9CR,YAAYO,OAAOC;QAEnB,MAAML,UAAU,MAAME,iBAAiB,IAAI;QAC3C,MAAMI,UAAUC,SAAS,UAAU,CAACH,OAAOC;QAC3C,OAAOC,QAAQ,MAAM,CAAC;YAClB,QAAQ;gBACJ,GAAGL,MAAM;gBACTD;YACJ;YACAI;YACAC;QACJ;IACJ;AACJ"}
|
package/dynamodb/index.js
CHANGED
|
@@ -1,57 +1,42 @@
|
|
|
1
|
-
import { createHandler
|
|
1
|
+
import { createHandler } from "@webiny/handler";
|
|
2
2
|
import { registerDefaultPlugins } from "../plugins/index.js";
|
|
3
3
|
import { DynamoDBEventHandler } from "./plugins/DynamoDBEventHandler.js";
|
|
4
|
-
|
|
5
|
-
* We need a class, not an interface exported from types.
|
|
6
|
-
*/
|
|
7
|
-
// @ts-expect-error
|
|
8
|
-
import Reply from "fastify/lib/reply.js";
|
|
4
|
+
import lib_reply from "fastify/lib/reply.js";
|
|
9
5
|
import { execute } from "../execute.js";
|
|
10
6
|
import { createComposedHandler } from "../utils/composedHandler.js";
|
|
11
7
|
export * from "./plugins/DynamoDBEventHandler.js";
|
|
12
8
|
const url = "/webiny-dynamodb-event";
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
}
|
|
46
|
-
app.__webiny_raw_result = result;
|
|
47
|
-
return reply.send({});
|
|
48
|
-
});
|
|
49
|
-
return execute({
|
|
50
|
-
app,
|
|
51
|
-
url,
|
|
52
|
-
payload
|
|
53
|
-
});
|
|
54
|
-
};
|
|
55
|
-
};
|
|
9
|
+
const dynamodb_createHandler = (params)=>(payload, context)=>{
|
|
10
|
+
const app = createHandler({
|
|
11
|
+
...params,
|
|
12
|
+
options: {
|
|
13
|
+
logger: true === params.debug,
|
|
14
|
+
...params.options || {}
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
registerDefaultPlugins(app.webiny);
|
|
18
|
+
const plugins = app.webiny.plugins.byType(DynamoDBEventHandler.type).reverse();
|
|
19
|
+
if (0 === plugins.length) throw new Error("To run @webiny/handler-aws/dynamodb, you must have DynamoDBHandler set.");
|
|
20
|
+
const handler = createComposedHandler(plugins);
|
|
21
|
+
app.post(url, async (request, reply)=>{
|
|
22
|
+
const params = {
|
|
23
|
+
request,
|
|
24
|
+
context: app.webiny,
|
|
25
|
+
event: payload,
|
|
26
|
+
lambdaContext: context,
|
|
27
|
+
reply
|
|
28
|
+
};
|
|
29
|
+
const result = await handler(params);
|
|
30
|
+
if (result instanceof lib_reply) return result;
|
|
31
|
+
app.__webiny_raw_result = result;
|
|
32
|
+
return reply.send({});
|
|
33
|
+
});
|
|
34
|
+
return execute({
|
|
35
|
+
app,
|
|
36
|
+
url: url,
|
|
37
|
+
payload
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
export { dynamodb_createHandler as createHandler };
|
|
56
41
|
|
|
57
42
|
//# sourceMappingURL=index.js.map
|
package/dynamodb/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"dynamodb/index.js","sources":["../../src/dynamodb/index.ts"],"sourcesContent":["import type {\n APIGatewayProxyResult,\n Context as LambdaContext,\n DynamoDBStreamEvent\n} from \"@webiny/aws-sdk/types/index.js\";\nimport type { HandlerFactoryParams } from \"~/types.js\";\nimport { createHandler as createBaseHandler } from \"@webiny/handler\";\nimport { registerDefaultPlugins } from \"~/plugins/index.js\";\nimport type { DynamoDBEventHandlerCallableParams } from \"./plugins/DynamoDBEventHandler.js\";\nimport { DynamoDBEventHandler } from \"./plugins/DynamoDBEventHandler.js\";\n/**\n * We need a class, not an interface exported from types.\n */\n// @ts-expect-error\nimport Reply from \"fastify/lib/reply.js\";\nimport { execute } from \"~/execute.js\";\nimport { createComposedHandler } from \"~/utils/composedHandler.js\";\n\nexport * from \"./plugins/DynamoDBEventHandler.js\";\n\nconst url = \"/webiny-dynamodb-event\";\n\nexport type HandlerParams = HandlerFactoryParams;\n\nexport interface HandlerCallable {\n (event: DynamoDBStreamEvent, context: LambdaContext): Promise<APIGatewayProxyResult>;\n}\n\nexport const createHandler = (params: HandlerParams): HandlerCallable => {\n return (payload, context) => {\n const app = createBaseHandler({\n ...params,\n options: {\n logger: params.debug === true,\n ...(params.options || {})\n }\n });\n /**\n * We always must add our default plugins to the app.\n */\n registerDefaultPlugins(app.webiny);\n /**\n * There must be an event plugin for this handler to work.\n */\n const plugins = app.webiny.plugins\n .byType<DynamoDBEventHandler>(DynamoDBEventHandler.type)\n .reverse();\n if (plugins.length === 0) {\n throw new Error(\n `To run @webiny/handler-aws/dynamodb, you must have DynamoDBHandler set.`\n );\n }\n\n const handler = createComposedHandler<\n DynamoDBEventHandler,\n DynamoDBEventHandlerCallableParams<APIGatewayProxyResult>,\n APIGatewayProxyResult\n >(plugins);\n\n app.post(url, async (request, reply) => {\n const params: Omit<\n DynamoDBEventHandlerCallableParams<APIGatewayProxyResult>,\n \"next\"\n > = {\n request,\n context: app.webiny,\n event: payload,\n lambdaContext: context,\n reply\n };\n const result = await handler(\n params as unknown as DynamoDBEventHandlerCallableParams<APIGatewayProxyResult>\n );\n\n if (result instanceof Reply) {\n return result;\n }\n\n app.__webiny_raw_result = result;\n return reply.send({});\n });\n return execute({\n app,\n url,\n payload\n });\n };\n};\n"],"names":["url","createHandler","params","payload","context","app","createBaseHandler","registerDefaultPlugins","plugins","DynamoDBEventHandler","Error","handler","createComposedHandler","request","reply","result","Reply","execute"],"mappings":";;;;;;;AAoBA,MAAMA,MAAM;AAQL,MAAMC,yBAAgB,CAACC,SACnB,CAACC,SAASC;QACb,MAAMC,MAAMC,cAAkB;YAC1B,GAAGJ,MAAM;YACT,SAAS;gBACL,QAAQA,AAAiB,SAAjBA,OAAO,KAAK;gBACpB,GAAIA,OAAO,OAAO,IAAI,CAAC,CAAC;YAC5B;QACJ;QAIAK,uBAAuBF,IAAI,MAAM;QAIjC,MAAMG,UAAUH,IAAI,MAAM,CAAC,OAAO,CAC7B,MAAM,CAAuBI,qBAAqB,IAAI,EACtD,OAAO;QACZ,IAAID,AAAmB,MAAnBA,QAAQ,MAAM,EACd,MAAM,IAAIE,MACN;QAIR,MAAMC,UAAUC,sBAIdJ;QAEFH,IAAI,IAAI,CAACL,KAAK,OAAOa,SAASC;YAC1B,MAAMZ,SAGF;gBACAW;gBACA,SAASR,IAAI,MAAM;gBACnB,OAAOF;gBACP,eAAeC;gBACfU;YACJ;YACA,MAAMC,SAAS,MAAMJ,QACjBT;YAGJ,IAAIa,kBAAkBC,WAClB,OAAOD;YAGXV,IAAI,mBAAmB,GAAGU;YAC1B,OAAOD,MAAM,IAAI,CAAC,CAAC;QACvB;QACA,OAAOG,QAAQ;YACXZ;YACAL,KAAAA;YACAG;QACJ;IACJ"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { Plugin } from "@webiny/plugins/Plugin.js";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
2
|
+
class DynamoDBEventHandler extends Plugin {
|
|
3
|
+
static{
|
|
4
|
+
this.type = "handler.fastify.aws.dynamodb.eventHandler";
|
|
5
|
+
}
|
|
6
|
+
constructor(cb){
|
|
7
|
+
super();
|
|
8
|
+
this.cb = cb;
|
|
9
|
+
}
|
|
8
10
|
}
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
};
|
|
11
|
+
const createEventHandler = (cb)=>new DynamoDBEventHandler(cb);
|
|
12
|
+
export { DynamoDBEventHandler, createEventHandler };
|
|
12
13
|
|
|
13
14
|
//# sourceMappingURL=DynamoDBEventHandler.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"dynamodb/plugins/DynamoDBEventHandler.js","sources":["../../../src/dynamodb/plugins/DynamoDBEventHandler.ts"],"sourcesContent":["import { Plugin } from \"@webiny/plugins/Plugin.js\";\nimport type { Context, Reply, Request } from \"@webiny/handler/types.js\";\nimport type { Context as LambdaContext, DynamoDBStreamEvent } from \"@webiny/aws-sdk/types/index.js\";\n\nexport interface DynamoDBEventHandlerCallableParams<Response = Reply> {\n request: Request;\n context: Context;\n event: DynamoDBStreamEvent;\n lambdaContext: LambdaContext;\n reply: Reply;\n next: () => Promise<Response>;\n}\n\nexport interface DynamoDBEventHandlerCallable<Response = Reply> {\n (params: DynamoDBEventHandlerCallableParams<Response>): Promise<Response>;\n}\n\nexport class DynamoDBEventHandler<Response = any> extends Plugin {\n public static override type = \"handler.fastify.aws.dynamodb.eventHandler\";\n\n public readonly cb: DynamoDBEventHandlerCallable<Response>;\n\n public constructor(cb: DynamoDBEventHandlerCallable<Response>) {\n super();\n this.cb = cb;\n }\n}\n\nexport const createEventHandler = <Response>(cb: DynamoDBEventHandlerCallable<Response>) => {\n return new DynamoDBEventHandler<Response>(cb);\n};\n"],"names":["DynamoDBEventHandler","Plugin","cb","createEventHandler"],"mappings":";AAiBO,MAAMA,6BAA6CC;;aAC/B,IAAI,GAAG;;IAI9B,YAAmBC,EAA0C,CAAE;QAC3D,KAAK;QACL,IAAI,CAAC,EAAE,GAAGA;IACd;AACJ;AAEO,MAAMC,qBAAqB,CAAWD,KAClC,IAAIF,qBAA+BE"}
|
package/dynamodb/register.js
CHANGED
|
@@ -2,24 +2,14 @@ import { registry } from "../registry.js";
|
|
|
2
2
|
import { createSourceHandler } from "../sourceHandler.js";
|
|
3
3
|
import { createHandler } from "./index.js";
|
|
4
4
|
const handler = createSourceHandler({
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
}
|
|
14
|
-
return record.eventSource.toLowerCase() === "aws:dynamodb";
|
|
15
|
-
},
|
|
16
|
-
handle: async ({
|
|
17
|
-
params,
|
|
18
|
-
event,
|
|
19
|
-
context
|
|
20
|
-
}) => {
|
|
21
|
-
return createHandler(params)(event, context);
|
|
22
|
-
}
|
|
5
|
+
name: "handler-aws-dynamodb-stream",
|
|
6
|
+
canUse: (event)=>{
|
|
7
|
+
if (!Array.isArray(event.Records) || 0 === event.Records.length) return false;
|
|
8
|
+
const [record] = event.Records;
|
|
9
|
+
if ("string" != typeof record.eventSource) return false;
|
|
10
|
+
return "aws:dynamodb" === record.eventSource.toLowerCase();
|
|
11
|
+
},
|
|
12
|
+
handle: async ({ params, event, context })=>createHandler(params)(event, context)
|
|
23
13
|
});
|
|
24
14
|
registry.register(handler);
|
|
25
15
|
|
package/dynamodb/register.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"dynamodb/register.js","sources":["../../src/dynamodb/register.ts"],"sourcesContent":["import { registry } from \"~/registry.js\";\nimport type { DynamoDBStreamEvent } from \"@webiny/aws-sdk/types/index.js\";\nimport { createSourceHandler } from \"~/sourceHandler.js\";\nimport type { HandlerParams } from \"~/dynamodb/index.js\";\nimport { createHandler } from \"~/dynamodb/index.js\";\n\nconst handler = createSourceHandler<DynamoDBStreamEvent, HandlerParams>({\n name: \"handler-aws-dynamodb-stream\",\n canUse: event => {\n if (!Array.isArray(event.Records) || event.Records.length === 0) {\n return false;\n }\n const [record] = event.Records;\n if (typeof record.eventSource !== \"string\") {\n return false;\n }\n return record.eventSource.toLowerCase() === \"aws:dynamodb\";\n },\n handle: async ({ params, event, context }) => {\n return createHandler(params)(event, context);\n }\n});\n\nregistry.register(handler);\n"],"names":["handler","createSourceHandler","event","Array","record","params","context","createHandler","registry"],"mappings":";;;AAMA,MAAMA,UAAUC,oBAAwD;IACpE,MAAM;IACN,QAAQC,CAAAA;QACJ,IAAI,CAACC,MAAM,OAAO,CAACD,MAAM,OAAO,KAAKA,AAAyB,MAAzBA,MAAM,OAAO,CAAC,MAAM,EACrD,OAAO;QAEX,MAAM,CAACE,OAAO,GAAGF,MAAM,OAAO;QAC9B,IAAI,AAA8B,YAA9B,OAAOE,OAAO,WAAW,EACzB,OAAO;QAEX,OAAOA,AAAqC,mBAArCA,OAAO,WAAW,CAAC,WAAW;IACzC;IACA,QAAQ,OAAO,EAAEC,MAAM,EAAEH,KAAK,EAAEI,OAAO,EAAE,GAC9BC,cAAcF,QAAQH,OAAOI;AAE5C;AAEAE,SAAS,QAAQ,CAACR"}
|
package/eventBridge/index.js
CHANGED
|
@@ -1,57 +1,42 @@
|
|
|
1
|
-
import { createHandler
|
|
1
|
+
import { createHandler } from "@webiny/handler";
|
|
2
2
|
import { registerDefaultPlugins } from "../plugins/index.js";
|
|
3
3
|
import { EventBridgeEventHandler } from "./plugins/EventBridgeEventHandler.js";
|
|
4
4
|
import { execute } from "../execute.js";
|
|
5
|
-
|
|
6
|
-
* We need a class, not an interface exported from types.
|
|
7
|
-
*/
|
|
8
|
-
// @ts-expect-error
|
|
9
|
-
import Reply from "fastify/lib/reply.js";
|
|
5
|
+
import lib_reply from "fastify/lib/reply.js";
|
|
10
6
|
import { createComposedHandler } from "../utils/composedHandler.js";
|
|
11
7
|
export * from "./plugins/EventBridgeEventHandler.js";
|
|
12
8
|
const url = "/webiny-eventBridge-event";
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
}
|
|
46
|
-
app.__webiny_raw_result = result;
|
|
47
|
-
return reply.send({});
|
|
48
|
-
});
|
|
49
|
-
return execute({
|
|
50
|
-
app,
|
|
51
|
-
url,
|
|
52
|
-
payload
|
|
53
|
-
});
|
|
54
|
-
};
|
|
55
|
-
};
|
|
9
|
+
const eventBridge_createHandler = (params)=>(payload, context)=>{
|
|
10
|
+
const app = createHandler({
|
|
11
|
+
...params,
|
|
12
|
+
options: {
|
|
13
|
+
logger: true === params.debug,
|
|
14
|
+
...params.options || {}
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
registerDefaultPlugins(app.webiny);
|
|
18
|
+
const plugins = app.webiny.plugins.byType(EventBridgeEventHandler.type).reverse();
|
|
19
|
+
if (0 === plugins.length) throw new Error("To run @webiny/handler-aws/eventBridge, you must have EventBridgeEventHandler set.");
|
|
20
|
+
const handler = createComposedHandler(plugins);
|
|
21
|
+
app.post(url, async (request, reply)=>{
|
|
22
|
+
const params = {
|
|
23
|
+
request,
|
|
24
|
+
reply,
|
|
25
|
+
context: app.webiny,
|
|
26
|
+
payload,
|
|
27
|
+
lambdaContext: context
|
|
28
|
+
};
|
|
29
|
+
const result = await handler(params);
|
|
30
|
+
if (result instanceof lib_reply) return result;
|
|
31
|
+
app.__webiny_raw_result = result;
|
|
32
|
+
return reply.send({});
|
|
33
|
+
});
|
|
34
|
+
return execute({
|
|
35
|
+
app,
|
|
36
|
+
url: url,
|
|
37
|
+
payload
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
export { eventBridge_createHandler as createHandler };
|
|
56
41
|
|
|
57
42
|
//# sourceMappingURL=index.js.map
|
package/eventBridge/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"eventBridge/index.js","sources":["../../src/eventBridge/index.ts"],"sourcesContent":["import { createHandler as createBaseHandler } from \"@webiny/handler\";\nimport { registerDefaultPlugins } from \"~/plugins/index.js\";\nimport type { EventBridgeEventHandlerCallableParams } from \"~/eventBridge/plugins/EventBridgeEventHandler.js\";\nimport { EventBridgeEventHandler } from \"~/eventBridge/plugins/EventBridgeEventHandler.js\";\nimport { execute } from \"~/execute.js\";\nimport type { HandlerFactoryParams } from \"~/types.js\";\nimport type {\n APIGatewayProxyResult,\n Context as LambdaContext,\n EventBridgeEvent\n} from \"@webiny/aws-sdk/types/index.js\";\n/**\n * We need a class, not an interface exported from types.\n */\n// @ts-expect-error\nimport Reply from \"fastify/lib/reply.js\";\nimport { createComposedHandler } from \"~/utils/composedHandler.js\";\n\nexport * from \"./plugins/EventBridgeEventHandler.js\";\n\nexport type HandlerParams = HandlerFactoryParams;\n\nexport interface HandlerCallable {\n (\n event: EventBridgeEvent<string, string>,\n context: LambdaContext\n ): Promise<APIGatewayProxyResult>;\n}\n\nconst url = \"/webiny-eventBridge-event\";\n\nexport const createHandler = (params: HandlerParams): HandlerCallable => {\n return (payload, context) => {\n const app = createBaseHandler({\n ...params,\n options: {\n logger: params.debug === true,\n ...(params.options || {})\n }\n });\n /**\n * We always must add our default plugins to the app.\n */\n registerDefaultPlugins(app.webiny);\n /**\n * There must be an event plugin for this handler to work.\n */\n const plugins = app.webiny.plugins\n .byType<EventBridgeEventHandler<string, string>>(EventBridgeEventHandler.type)\n .reverse();\n if (plugins.length === 0) {\n throw new Error(\n `To run @webiny/handler-aws/eventBridge, you must have EventBridgeEventHandler set.`\n );\n }\n\n const handler = createComposedHandler<\n EventBridgeEventHandler<string, string>,\n EventBridgeEventHandlerCallableParams<string, string, APIGatewayProxyResult>,\n APIGatewayProxyResult\n >(plugins);\n\n app.post(url, async (request, reply) => {\n const params: Omit<\n EventBridgeEventHandlerCallableParams<string, string, APIGatewayProxyResult>,\n \"next\"\n > = {\n request,\n reply,\n context: app.webiny,\n payload,\n lambdaContext: context\n };\n const result = await handler(\n params as unknown as EventBridgeEventHandlerCallableParams<\n string,\n string,\n APIGatewayProxyResult\n >\n );\n\n if (result instanceof Reply) {\n return result;\n }\n\n app.__webiny_raw_result = result;\n return reply.send({});\n });\n return execute({\n app,\n url,\n payload\n });\n };\n};\n"],"names":["url","createHandler","params","payload","context","app","createBaseHandler","registerDefaultPlugins","plugins","EventBridgeEventHandler","Error","handler","createComposedHandler","request","reply","result","Reply","execute"],"mappings":";;;;;;;AA6BA,MAAMA,MAAM;AAEL,MAAMC,4BAAgB,CAACC,SACnB,CAACC,SAASC;QACb,MAAMC,MAAMC,cAAkB;YAC1B,GAAGJ,MAAM;YACT,SAAS;gBACL,QAAQA,AAAiB,SAAjBA,OAAO,KAAK;gBACpB,GAAIA,OAAO,OAAO,IAAI,CAAC,CAAC;YAC5B;QACJ;QAIAK,uBAAuBF,IAAI,MAAM;QAIjC,MAAMG,UAAUH,IAAI,MAAM,CAAC,OAAO,CAC7B,MAAM,CAA0CI,wBAAwB,IAAI,EAC5E,OAAO;QACZ,IAAID,AAAmB,MAAnBA,QAAQ,MAAM,EACd,MAAM,IAAIE,MACN;QAIR,MAAMC,UAAUC,sBAIdJ;QAEFH,IAAI,IAAI,CAACL,KAAK,OAAOa,SAASC;YAC1B,MAAMZ,SAGF;gBACAW;gBACAC;gBACA,SAAST,IAAI,MAAM;gBACnBF;gBACA,eAAeC;YACnB;YACA,MAAMW,SAAS,MAAMJ,QACjBT;YAOJ,IAAIa,kBAAkBC,WAClB,OAAOD;YAGXV,IAAI,mBAAmB,GAAGU;YAC1B,OAAOD,MAAM,IAAI,CAAC,CAAC;QACvB;QACA,OAAOG,QAAQ;YACXZ;YACAL,KAAAA;YACAG;QACJ;IACJ"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { Plugin } from "@webiny/plugins/Plugin.js";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
2
|
+
class EventBridgeEventHandler extends Plugin {
|
|
3
|
+
static{
|
|
4
|
+
this.type = "handler.fastify.aws.eventBridge.eventHandler";
|
|
5
|
+
}
|
|
6
|
+
constructor(cb){
|
|
7
|
+
super();
|
|
8
|
+
this.cb = cb;
|
|
9
|
+
}
|
|
8
10
|
}
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
};
|
|
11
|
+
const createEventHandler = (cb)=>new EventBridgeEventHandler(cb);
|
|
12
|
+
export { EventBridgeEventHandler, createEventHandler };
|
|
12
13
|
|
|
13
14
|
//# sourceMappingURL=EventBridgeEventHandler.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"eventBridge/plugins/EventBridgeEventHandler.js","sources":["../../../src/eventBridge/plugins/EventBridgeEventHandler.ts"],"sourcesContent":["import type { Context as LambdaContext, EventBridgeEvent } from \"@webiny/aws-sdk/types/index.js\";\nimport { Plugin } from \"@webiny/plugins/Plugin.js\";\nimport type { Context, Reply, Request } from \"@webiny/handler/types.js\";\n\nexport interface EventBridgeEventHandlerCallableParams<\n DetailType extends string,\n Detail,\n Response = Reply\n> {\n request: Request;\n reply: Reply;\n context: Context;\n payload: EventBridgeEvent<DetailType, Detail>;\n lambdaContext: LambdaContext;\n next: () => Promise<Response>;\n}\nexport interface EventBridgeEventHandlerCallable<\n DetailType extends string,\n Detail,\n Response = Reply\n> {\n (\n params: EventBridgeEventHandlerCallableParams<DetailType, Detail, Response>\n ): Promise<Response>;\n}\n\nexport class EventBridgeEventHandler<\n DetailType extends string,\n Detail,\n Response = any\n> extends Plugin {\n public static override type = \"handler.fastify.aws.eventBridge.eventHandler\";\n\n public readonly cb: EventBridgeEventHandlerCallable<DetailType, Detail, Response>;\n\n public constructor(cb: EventBridgeEventHandlerCallable<DetailType, Detail, Response>) {\n super();\n this.cb = cb;\n }\n}\n\nexport const createEventHandler = <DetailType extends string, Detail, Response = any>(\n cb: EventBridgeEventHandlerCallable<DetailType, Detail, Response>\n) => {\n return new EventBridgeEventHandler<DetailType, Detail, Response>(cb);\n};\n"],"names":["EventBridgeEventHandler","Plugin","cb","createEventHandler"],"mappings":";AA0BO,MAAMA,gCAIHC;;aACiB,IAAI,GAAG;;IAI9B,YAAmBC,EAAiE,CAAE;QAClF,KAAK;QACL,IAAI,CAAC,EAAE,GAAGA;IACd;AACJ;AAEO,MAAMC,qBAAqB,CAC9BD,KAEO,IAAIF,wBAAsDE"}
|
package/eventBridge/register.js
CHANGED
|
@@ -2,17 +2,9 @@ import { registry } from "../registry.js";
|
|
|
2
2
|
import { createSourceHandler } from "../sourceHandler.js";
|
|
3
3
|
import { createHandler } from "./index.js";
|
|
4
4
|
const handler = createSourceHandler({
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
},
|
|
9
|
-
handle: async ({
|
|
10
|
-
params,
|
|
11
|
-
event,
|
|
12
|
-
context
|
|
13
|
-
}) => {
|
|
14
|
-
return createHandler(params)(event, context);
|
|
15
|
-
}
|
|
5
|
+
name: "handler-aws-event-bridge",
|
|
6
|
+
canUse: (event)=>!!event.source,
|
|
7
|
+
handle: async ({ params, event, context })=>createHandler(params)(event, context)
|
|
16
8
|
});
|
|
17
9
|
registry.register(handler);
|
|
18
10
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"eventBridge/register.js","sources":["../../src/eventBridge/register.ts"],"sourcesContent":["import type { EventBridgeEvent } from \"@webiny/aws-sdk/types/index.js\";\nimport { registry } from \"~/registry.js\";\nimport type { HandlerFactoryParams } from \"~/types.js\";\nimport { createSourceHandler } from \"~/sourceHandler.js\";\nimport { createHandler } from \"~/eventBridge/index.js\";\n\nexport interface HandlerParams extends HandlerFactoryParams {\n debug?: boolean;\n}\n\nconst handler = createSourceHandler<EventBridgeEvent<string, string>, HandlerParams>({\n name: \"handler-aws-event-bridge\",\n canUse: event => {\n return !!event.source;\n },\n handle: async ({ params, event, context }) => {\n return createHandler(params)(event, context);\n }\n});\n\nregistry.register(handler);\n"],"names":["handler","createSourceHandler","event","params","context","createHandler","registry"],"mappings":";;;AAUA,MAAMA,UAAUC,oBAAqE;IACjF,MAAM;IACN,QAAQC,CAAAA,QACG,CAAC,CAACA,MAAM,MAAM;IAEzB,QAAQ,OAAO,EAAEC,MAAM,EAAED,KAAK,EAAEE,OAAO,EAAE,GAC9BC,cAAcF,QAAQD,OAAOE;AAE5C;AAEAE,SAAS,QAAQ,CAACN"}
|
package/execute.js
CHANGED
|
@@ -1,66 +1,58 @@
|
|
|
1
1
|
import { Base64EncodeHeader } from "./types.js";
|
|
2
|
-
const createHandleResponse = (app, resolve) =>
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
isBase64Encoded
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
headers: result.headers,
|
|
27
|
-
isBase64Encoded
|
|
2
|
+
const createHandleResponse = (app, resolve)=>(err, result)=>{
|
|
3
|
+
if (err) return resolve({
|
|
4
|
+
statusCode: 500,
|
|
5
|
+
body: JSON.stringify(err),
|
|
6
|
+
headers: {}
|
|
7
|
+
});
|
|
8
|
+
if (app.__webiny_raw_result) return resolve(app.__webiny_raw_result);
|
|
9
|
+
if (!result) {
|
|
10
|
+
const response = {
|
|
11
|
+
statusCode: 200,
|
|
12
|
+
body: "",
|
|
13
|
+
headers: {},
|
|
14
|
+
isBase64Encoded: false
|
|
15
|
+
};
|
|
16
|
+
return resolve(response);
|
|
17
|
+
}
|
|
18
|
+
const isBase64Encoded = !!result.headers[Base64EncodeHeader.encoded] || !!result.headers[Base64EncodeHeader.binary];
|
|
19
|
+
const response = {
|
|
20
|
+
statusCode: result.statusCode,
|
|
21
|
+
body: isBase64Encoded ? result.rawPayload.toString("base64") : result.payload,
|
|
22
|
+
headers: result.headers,
|
|
23
|
+
isBase64Encoded
|
|
24
|
+
};
|
|
25
|
+
return resolve(response);
|
|
28
26
|
};
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
};
|
|
39
|
-
}
|
|
40
|
-
return defaults;
|
|
27
|
+
const getPayloadProperty = (payload, prop, defaults = {})=>{
|
|
28
|
+
if (payload && "object" == typeof payload) {
|
|
29
|
+
const value = payload[prop] ? payload[prop] : {};
|
|
30
|
+
return {
|
|
31
|
+
...defaults,
|
|
32
|
+
...value
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
return defaults;
|
|
41
36
|
};
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
headers,
|
|
61
|
-
cookies
|
|
62
|
-
}, createHandleResponse(app, resolve));
|
|
63
|
-
});
|
|
37
|
+
const execute = (params)=>{
|
|
38
|
+
const { app, url, payload } = params;
|
|
39
|
+
const query = getPayloadProperty(payload, "query", {});
|
|
40
|
+
const headers = getPayloadProperty(payload, "headers", {
|
|
41
|
+
["content-type"]: "application/json"
|
|
42
|
+
});
|
|
43
|
+
const cookies = getPayloadProperty(payload, "cookies", {});
|
|
44
|
+
return new Promise((resolve)=>{
|
|
45
|
+
app.inject({
|
|
46
|
+
method: "POST",
|
|
47
|
+
url,
|
|
48
|
+
payload: payload || {},
|
|
49
|
+
body: payload || {},
|
|
50
|
+
query,
|
|
51
|
+
headers,
|
|
52
|
+
cookies
|
|
53
|
+
}, createHandleResponse(app, resolve));
|
|
54
|
+
});
|
|
64
55
|
};
|
|
56
|
+
export { execute };
|
|
65
57
|
|
|
66
58
|
//# sourceMappingURL=execute.js.map
|