@geekmidas/constructs 0.0.12 → 0.0.13
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/README.md +448 -0
- package/dist/AWSLambdaFunction-B-Oxr8qt.d.cts +30 -0
- package/dist/{AWSLambdaFunction-DMxScuaw.cjs → AWSLambdaFunction-C-fuCLA3.cjs} +28 -5
- package/dist/AWSLambdaFunction-C-fuCLA3.cjs.map +1 -0
- package/dist/AWSLambdaFunction-CAm9r5ZX.d.mts +30 -0
- package/dist/{AWSLambdaFunction-cL8A169J.mjs → AWSLambdaFunction-H65WfXLt.mjs} +28 -5
- package/dist/AWSLambdaFunction-H65WfXLt.mjs.map +1 -0
- package/dist/{AmazonApiGatewayEndpointAdaptor-eDQgPNLH.d.mts → AmazonApiGatewayEndpointAdaptor-4hPy5vty.d.mts} +4 -4
- package/dist/{AmazonApiGatewayEndpointAdaptor-CIEhW1TQ.mjs → AmazonApiGatewayEndpointAdaptor-C6Jk5HSy.mjs} +6 -2
- package/dist/AmazonApiGatewayEndpointAdaptor-C6Jk5HSy.mjs.map +1 -0
- package/dist/{AmazonApiGatewayEndpointAdaptor-H8YvtfQm.cjs → AmazonApiGatewayEndpointAdaptor-CI9L7Ucn.cjs} +6 -2
- package/dist/AmazonApiGatewayEndpointAdaptor-CI9L7Ucn.cjs.map +1 -0
- package/dist/{AmazonApiGatewayEndpointAdaptor-CwItKPz2.d.cts → AmazonApiGatewayEndpointAdaptor-ro0RMLzr.d.cts} +4 -4
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-B36zXLJ7.mjs → AmazonApiGatewayV1EndpointAdaptor-BMy8DdNJ.mjs} +2 -2
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-B36zXLJ7.mjs.map → AmazonApiGatewayV1EndpointAdaptor-BMy8DdNJ.mjs.map} +1 -1
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-DaCvUL6y.d.cts → AmazonApiGatewayV1EndpointAdaptor-BWJWKqQT.d.cts} +3 -3
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-0n71d3gq.cjs → AmazonApiGatewayV1EndpointAdaptor-DYL1bCBS.cjs} +2 -2
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-0n71d3gq.cjs.map → AmazonApiGatewayV1EndpointAdaptor-DYL1bCBS.cjs.map} +1 -1
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-CnGVpA38.d.mts → AmazonApiGatewayV1EndpointAdaptor-hyR-WwyP.d.mts} +3 -3
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-CE3wZEb8.mjs → AmazonApiGatewayV2EndpointAdaptor-BU5wQMOe.mjs} +2 -2
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-CE3wZEb8.mjs.map → AmazonApiGatewayV2EndpointAdaptor-BU5wQMOe.mjs.map} +1 -1
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-DtU3Cb8F.cjs → AmazonApiGatewayV2EndpointAdaptor-CPLCMeaN.cjs} +2 -2
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-DtU3Cb8F.cjs.map → AmazonApiGatewayV2EndpointAdaptor-CPLCMeaN.cjs.map} +1 -1
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-DA1PH0nc.d.cts → AmazonApiGatewayV2EndpointAdaptor-D1Irdggp.d.cts} +3 -3
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-BELz2ijs.d.mts → AmazonApiGatewayV2EndpointAdaptor-DX3SuI5S.d.mts} +3 -3
- package/dist/{Authorizer-BRCVPz_O.d.mts → Authorizer-BTmly8ps.d.cts} +1 -1
- package/dist/{Authorizer-DG54w1m2.d.cts → Authorizer-pmPvIVgv.d.mts} +1 -1
- package/dist/{BaseFunctionBuilder-CT7p10K1.mjs → BaseFunctionBuilder-B5gkW0Kt.mjs} +10 -1
- package/dist/BaseFunctionBuilder-B5gkW0Kt.mjs.map +1 -0
- package/dist/{BaseFunctionBuilder-B8rT07QR.cjs → BaseFunctionBuilder-C5Se7pdL.cjs} +10 -1
- package/dist/BaseFunctionBuilder-C5Se7pdL.cjs.map +1 -0
- package/dist/{BaseFunctionBuilder-DilipY1y.d.mts → BaseFunctionBuilder-CbDnPZpD.d.mts} +10 -4
- package/dist/{BaseFunctionBuilder-Cf0op65o.d.cts → BaseFunctionBuilder-DUZMbEr3.d.cts} +10 -4
- package/dist/{Cron-Bnd-2pgE.cjs → Cron-Bi3QOge_.cjs} +4 -4
- package/dist/Cron-Bi3QOge_.cjs.map +1 -0
- package/dist/{Cron-6lOgKqSA.d.cts → Cron-COdfP0Jd.d.cts} +4 -4
- package/dist/{Cron-BH_07atD.d.mts → Cron-D8cn_ahj.d.mts} +4 -4
- package/dist/{Cron-DNRjf2cp.mjs → Cron-Dy_HW2Vv.mjs} +4 -4
- package/dist/Cron-Dy_HW2Vv.mjs.map +1 -0
- package/dist/{CronBuilder-DdR2TuQa.mjs → CronBuilder-Bl3A2Zp4.mjs} +13 -4
- package/dist/CronBuilder-Bl3A2Zp4.mjs.map +1 -0
- package/dist/{CronBuilder-5oK2AL2n.d.cts → CronBuilder-DntF6H3A.d.cts} +17 -12
- package/dist/{CronBuilder-D2b4zY4l.d.mts → CronBuilder-DoMnSs_0.d.mts} +17 -12
- package/dist/{CronBuilder-dtw4ZyH6.cjs → CronBuilder-Dv_w7Yri.cjs} +13 -4
- package/dist/CronBuilder-Dv_w7Yri.cjs.map +1 -0
- package/dist/{Endpoint-DuZlyjd4.d.mts → Endpoint-Bbs_sFvg.d.mts} +49 -20
- package/dist/{Endpoint-Cs-MsYlY.d.cts → Endpoint-Bu8Phz6y.d.cts} +49 -20
- package/dist/{Endpoint-B9PryZES.cjs → Endpoint-DDpF7NO1.cjs} +11 -6
- package/dist/Endpoint-DDpF7NO1.cjs.map +1 -0
- package/dist/{Endpoint-B69TqESg.mjs → Endpoint-S6Yh2_PN.mjs} +11 -6
- package/dist/Endpoint-S6Yh2_PN.mjs.map +1 -0
- package/dist/{EndpointBuilder-C-PHInEW.d.cts → EndpointBuilder-CPxmF_w7.d.cts} +30 -13
- package/dist/{EndpointBuilder-BrB-K1jO.d.mts → EndpointBuilder-Csfyfjd7.d.mts} +30 -13
- package/dist/{EndpointBuilder-DofwCnWJ.cjs → EndpointBuilder-DpGmObMb.cjs} +25 -4
- package/dist/EndpointBuilder-DpGmObMb.cjs.map +1 -0
- package/dist/{EndpointBuilder-DnVL-EU_.mjs → EndpointBuilder-aE2E6WTx.mjs} +25 -4
- package/dist/EndpointBuilder-aE2E6WTx.mjs.map +1 -0
- package/dist/{EndpointFactory-6zNpVSYp.d.mts → EndpointFactory-Bf9JSWzI.d.cts} +12 -12
- package/dist/{EndpointFactory-Ba9mx9MU.cjs → EndpointFactory-BfH6mjJ3.cjs} +2 -2
- package/dist/EndpointFactory-BfH6mjJ3.cjs.map +1 -0
- package/dist/{EndpointFactory-e5WYVR6t.d.cts → EndpointFactory-Cgk1R0oO.d.mts} +12 -12
- package/dist/{EndpointFactory-pPaIGFHV.mjs → EndpointFactory-D4leYk1N.mjs} +2 -2
- package/dist/EndpointFactory-D4leYk1N.mjs.map +1 -0
- package/dist/{Function-CO-s2pB8.cjs → Function-DagDbeXo.cjs} +3 -2
- package/dist/Function-DagDbeXo.cjs.map +1 -0
- package/dist/{Function-COnc-tWM.mjs → Function-DfKsM5Kx.mjs} +3 -2
- package/dist/Function-DfKsM5Kx.mjs.map +1 -0
- package/dist/{Function-G3JPHMaY.d.mts → Function-V9M9UVHp.d.mts} +24 -7
- package/dist/{Function-6EWabl_X.d.cts → Function-VI1TB3Mh.d.cts} +24 -7
- package/dist/{FunctionBuilder-CMhLQ4dt.mjs → FunctionBuilder-CVT7bG2o.mjs} +20 -4
- package/dist/FunctionBuilder-CVT7bG2o.mjs.map +1 -0
- package/dist/{FunctionBuilder-B3fpp3hA.d.cts → FunctionBuilder-CjVEFTYC.d.cts} +22 -12
- package/dist/{FunctionBuilder-ByaB_LQ4.d.mts → FunctionBuilder-D1ofSeMd.d.mts} +22 -12
- package/dist/{FunctionBuilder-_hMwZUof.cjs → FunctionBuilder-DXvG_XD-.cjs} +20 -4
- package/dist/FunctionBuilder-DXvG_XD-.cjs.map +1 -0
- package/dist/FunctionExecutionWrapper-Bubnr0zA.mjs +101 -0
- package/dist/FunctionExecutionWrapper-Bubnr0zA.mjs.map +1 -0
- package/dist/FunctionExecutionWrapper-CwtwYozd.d.cts +48 -0
- package/dist/FunctionExecutionWrapper-DkNycmOh.cjs +107 -0
- package/dist/FunctionExecutionWrapper-DkNycmOh.cjs.map +1 -0
- package/dist/FunctionExecutionWrapper-rhbIYT0Q.d.mts +48 -0
- package/dist/{HonoEndpointAdaptor-DSHl8ZCY.d.cts → HonoEndpointAdaptor-B34kNobH.d.cts} +7 -7
- package/dist/{HonoEndpointAdaptor-BElil8O5.d.mts → HonoEndpointAdaptor-BDpi32mH.d.mts} +7 -7
- package/dist/{HonoEndpointAdaptor-Cw2if5cG.cjs → HonoEndpointAdaptor-CfLRHHFw.cjs} +8 -4
- package/dist/HonoEndpointAdaptor-CfLRHHFw.cjs.map +1 -0
- package/dist/{HonoEndpointAdaptor-DAfnTFVS.mjs → HonoEndpointAdaptor-DuyE06nH.mjs} +8 -4
- package/dist/HonoEndpointAdaptor-DuyE06nH.mjs.map +1 -0
- package/dist/{Subscriber-D-FPWts6.cjs → Subscriber-Bdh8rMSL.cjs} +1 -1
- package/dist/{Subscriber-D-FPWts6.cjs.map → Subscriber-Bdh8rMSL.cjs.map} +1 -1
- package/dist/{Subscriber-CGb8LjZa.mjs → Subscriber-CJOWwaw1.mjs} +1 -1
- package/dist/{Subscriber-CGb8LjZa.mjs.map → Subscriber-CJOWwaw1.mjs.map} +1 -1
- package/dist/{SubscriberBuilder-BcAspHv9.mjs → SubscriberBuilder-BWQmiYd8.mjs} +2 -2
- package/dist/{SubscriberBuilder-BcAspHv9.mjs.map → SubscriberBuilder-BWQmiYd8.mjs.map} +1 -1
- package/dist/{SubscriberBuilder-BfE2cL1q.cjs → SubscriberBuilder-DieD_60p.cjs} +2 -2
- package/dist/{SubscriberBuilder-BfE2cL1q.cjs.map → SubscriberBuilder-DieD_60p.cjs.map} +1 -1
- package/dist/{TestEndpointAdaptor-DubQOJk_.mjs → TestEndpointAdaptor-BEyZa0Yg.mjs} +7 -3
- package/dist/TestEndpointAdaptor-BEyZa0Yg.mjs.map +1 -0
- package/dist/{TestEndpointAdaptor-Bn1WRFph.cjs → TestEndpointAdaptor-C8425RJ0.cjs} +7 -3
- package/dist/TestEndpointAdaptor-C8425RJ0.cjs.map +1 -0
- package/dist/{TestEndpointAdaptor-o-xtSyQ3.d.cts → TestEndpointAdaptor-H5To8PH7.d.cts} +2 -2
- package/dist/{TestEndpointAdaptor-DnlAA_rm.d.mts → TestEndpointAdaptor-jxn68ayg.d.mts} +2 -2
- package/dist/adaptors/aws.cjs +10 -10
- package/dist/adaptors/aws.d.cts +11 -11
- package/dist/adaptors/aws.d.mts +11 -11
- package/dist/adaptors/aws.mjs +10 -10
- package/dist/adaptors/hono.cjs +7 -7
- package/dist/adaptors/hono.d.cts +7 -7
- package/dist/adaptors/hono.d.mts +7 -7
- package/dist/adaptors/hono.mjs +7 -7
- package/dist/adaptors/testing.cjs +6 -6
- package/dist/adaptors/testing.d.cts +7 -7
- package/dist/adaptors/testing.d.mts +7 -7
- package/dist/adaptors/testing.mjs +6 -6
- package/dist/crons/Cron.cjs +5 -5
- package/dist/crons/Cron.d.cts +5 -5
- package/dist/crons/Cron.d.mts +5 -5
- package/dist/crons/Cron.mjs +5 -5
- package/dist/crons/CronBuilder.cjs +6 -6
- package/dist/crons/CronBuilder.d.cts +6 -6
- package/dist/crons/CronBuilder.d.mts +6 -6
- package/dist/crons/CronBuilder.mjs +6 -6
- package/dist/crons/index.cjs +6 -6
- package/dist/crons/index.d.cts +10 -10
- package/dist/crons/index.d.mts +10 -10
- package/dist/crons/index.mjs +6 -6
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +6 -6
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +7 -7
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +7 -7
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +6 -6
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +7 -7
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +8 -8
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +8 -8
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +7 -7
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +7 -7
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +8 -8
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +8 -8
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +7 -7
- package/dist/endpoints/Authorizer.d.cts +1 -1
- package/dist/endpoints/Authorizer.d.mts +1 -1
- package/dist/endpoints/Endpoint.cjs +5 -5
- package/dist/endpoints/Endpoint.d.cts +6 -6
- package/dist/endpoints/Endpoint.d.mts +6 -6
- package/dist/endpoints/Endpoint.mjs +5 -5
- package/dist/endpoints/EndpointBuilder.cjs +6 -6
- package/dist/endpoints/EndpointBuilder.d.cts +7 -7
- package/dist/endpoints/EndpointBuilder.d.mts +7 -7
- package/dist/endpoints/EndpointBuilder.mjs +6 -6
- package/dist/endpoints/EndpointFactory.cjs +7 -7
- package/dist/endpoints/EndpointFactory.d.cts +8 -8
- package/dist/endpoints/EndpointFactory.d.mts +8 -8
- package/dist/endpoints/EndpointFactory.mjs +7 -7
- package/dist/endpoints/HonoEndpointAdaptor.cjs +7 -7
- package/dist/endpoints/HonoEndpointAdaptor.d.cts +7 -7
- package/dist/endpoints/HonoEndpointAdaptor.d.mts +7 -7
- package/dist/endpoints/HonoEndpointAdaptor.mjs +7 -7
- package/dist/endpoints/TestEndpointAdaptor.cjs +6 -6
- package/dist/endpoints/TestEndpointAdaptor.d.cts +7 -7
- package/dist/endpoints/TestEndpointAdaptor.d.mts +7 -7
- package/dist/endpoints/TestEndpointAdaptor.mjs +6 -6
- package/dist/endpoints/audit.d.cts +6 -6
- package/dist/endpoints/audit.d.mts +6 -6
- package/dist/endpoints/helpers.cjs +6 -6
- package/dist/endpoints/helpers.d.cts +6 -6
- package/dist/endpoints/helpers.d.mts +6 -6
- package/dist/endpoints/helpers.mjs +6 -6
- package/dist/endpoints/index.cjs +7 -7
- package/dist/endpoints/index.d.cts +10 -10
- package/dist/endpoints/index.d.mts +10 -10
- package/dist/endpoints/index.mjs +7 -7
- package/dist/endpoints/processAudits.d.cts +7 -7
- package/dist/endpoints/processAudits.d.mts +7 -7
- package/dist/functions/AWSLambdaFunction.cjs +5 -5
- package/dist/functions/AWSLambdaFunction.d.cts +3 -3
- package/dist/functions/AWSLambdaFunction.d.mts +3 -3
- package/dist/functions/AWSLambdaFunction.mjs +5 -5
- package/dist/functions/BaseFunctionBuilder.cjs +1 -1
- package/dist/functions/BaseFunctionBuilder.d.cts +1 -1
- package/dist/functions/BaseFunctionBuilder.d.mts +1 -1
- package/dist/functions/BaseFunctionBuilder.mjs +1 -1
- package/dist/functions/Function.cjs +1 -1
- package/dist/functions/Function.d.cts +1 -1
- package/dist/functions/Function.d.mts +1 -1
- package/dist/functions/Function.mjs +1 -1
- package/dist/functions/FunctionBuilder.cjs +3 -3
- package/dist/functions/FunctionBuilder.d.cts +3 -3
- package/dist/functions/FunctionBuilder.d.mts +3 -3
- package/dist/functions/FunctionBuilder.mjs +3 -3
- package/dist/functions/FunctionExecutionWrapper.cjs +4 -4
- package/dist/functions/FunctionExecutionWrapper.d.cts +2 -2
- package/dist/functions/FunctionExecutionWrapper.d.mts +2 -2
- package/dist/functions/FunctionExecutionWrapper.mjs +4 -4
- package/dist/functions/TestFunctionAdaptor.cjs +37 -4
- package/dist/functions/TestFunctionAdaptor.cjs.map +1 -1
- package/dist/functions/TestFunctionAdaptor.d.cts +9 -6
- package/dist/functions/TestFunctionAdaptor.d.mts +9 -6
- package/dist/functions/TestFunctionAdaptor.mjs +37 -4
- package/dist/functions/TestFunctionAdaptor.mjs.map +1 -1
- package/dist/functions/index.cjs +4 -4
- package/dist/functions/index.d.cts +4 -4
- package/dist/functions/index.d.mts +4 -4
- package/dist/functions/index.mjs +4 -4
- package/dist/{functions-D03lqK-r.cjs → functions-FCb-wWFC.cjs} +2 -2
- package/dist/{functions-D03lqK-r.cjs.map → functions-FCb-wWFC.cjs.map} +1 -1
- package/dist/functions-JhRsNoAZ.mjs +8 -0
- package/dist/{functions-BYqZAob8.mjs.map → functions-JhRsNoAZ.mjs.map} +1 -1
- package/dist/{helpers-BPDogwac.mjs → helpers-2CLKTnRm.mjs} +2 -2
- package/dist/{helpers-BPDogwac.mjs.map → helpers-2CLKTnRm.mjs.map} +1 -1
- package/dist/{helpers-BApRyhly.cjs → helpers-Khuhi_Qx.cjs} +2 -2
- package/dist/{helpers-BApRyhly.cjs.map → helpers-Khuhi_Qx.cjs.map} +1 -1
- package/dist/index-Bomy7R9z.d.mts +10 -0
- package/dist/index-DRYfZHb3.d.cts +10 -0
- package/dist/processAudits-BFokHhCO.cjs.map +1 -1
- package/dist/processAudits-DfcB-X-4.mjs.map +1 -1
- package/dist/publisher-Bw4770Hi.mjs.map +1 -1
- package/dist/publisher-lFQleddL.cjs.map +1 -1
- package/dist/publisher.d.cts +2 -1
- package/dist/publisher.d.mts +2 -1
- package/dist/subscribers/Subscriber.cjs +1 -1
- package/dist/subscribers/Subscriber.mjs +1 -1
- package/dist/subscribers/SubscriberBuilder.cjs +2 -2
- package/dist/subscribers/SubscriberBuilder.mjs +2 -2
- package/dist/subscribers/index.cjs +2 -2
- package/dist/subscribers/index.d.cts +2 -2
- package/dist/subscribers/index.d.mts +2 -2
- package/dist/subscribers/index.mjs +2 -2
- package/package.json +6 -6
- package/src/crons/Cron.ts +12 -3
- package/src/crons/CronBuilder.ts +85 -13
- package/src/crons/__tests__/CronBuilder.state-isolation.spec.ts +2 -2
- package/src/endpoints/AmazonApiGatewayEndpointAdaptor.ts +29 -6
- package/src/endpoints/Endpoint.ts +156 -40
- package/src/endpoints/EndpointBuilder.ts +123 -17
- package/src/endpoints/EndpointFactory.ts +5 -1
- package/src/endpoints/HonoEndpointAdaptor.ts +35 -5
- package/src/endpoints/TestEndpointAdaptor.ts +22 -2
- package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.spec.ts +1 -1
- package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.audits.spec.ts +2 -2
- package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.events.spec.ts +9 -9
- package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.kysely-audit.integration.spec.ts +79 -40
- package/src/endpoints/__tests__/Endpoint.cookies.spec.ts +3 -1
- package/src/endpoints/__tests__/Endpoint.manifest.spec.ts +1 -1
- package/src/endpoints/__tests__/EndpointBuilder.audit.spec.ts +35 -11
- package/src/endpoints/__tests__/EndpointFactory.authorizers.spec.ts +51 -14
- package/src/endpoints/__tests__/EndpointFactory.reference-audit.spec.ts +8 -8
- package/src/endpoints/__tests__/EndpointFactory.state-isolation.spec.ts +11 -11
- package/src/endpoints/__tests__/HonoEndpointAdaptor.audit-transactions.spec.ts +44 -26
- package/src/endpoints/__tests__/HonoEndpointAdaptor.audits.spec.ts +10 -10
- package/src/endpoints/__tests__/HonoEndpointAdaptor.events.spec.ts +8 -8
- package/src/endpoints/__tests__/HonoEndpointAdaptor.kysely-audit.integration.spec.ts +446 -61
- package/src/endpoints/__tests__/HonoEndpointAdaptor.openapi.spec.ts +4 -4
- package/src/endpoints/audit.ts +1 -1
- package/src/endpoints/processAudits.ts +32 -23
- package/src/functions/AWSLambdaFunction.ts +125 -12
- package/src/functions/BaseFunctionBuilder.ts +51 -3
- package/src/functions/Function.ts +73 -9
- package/src/functions/FunctionBuilder.ts +153 -17
- package/src/functions/FunctionExecutionWrapper.ts +133 -2
- package/src/functions/TestFunctionAdaptor.ts +94 -8
- package/src/functions/__tests__/AWSLambdaFunctionAdaptor.spec.ts +82 -0
- package/src/functions/__tests__/Function.audits.spec.ts +393 -0
- package/src/functions/__tests__/Function.spec.ts +76 -0
- package/src/functions/__tests__/FunctionBuilder.state-isolation.spec.ts +11 -5
- package/src/publisher.ts +12 -1
- package/dist/AWSLambdaFunction-DMxScuaw.cjs.map +0 -1
- package/dist/AWSLambdaFunction-DSB2oaFG.d.mts +0 -27
- package/dist/AWSLambdaFunction-cL8A169J.mjs.map +0 -1
- package/dist/AWSLambdaFunction-t6q2o8EL.d.cts +0 -27
- package/dist/AmazonApiGatewayEndpointAdaptor-CIEhW1TQ.mjs.map +0 -1
- package/dist/AmazonApiGatewayEndpointAdaptor-H8YvtfQm.cjs.map +0 -1
- package/dist/BaseFunctionBuilder-B8rT07QR.cjs.map +0 -1
- package/dist/BaseFunctionBuilder-CT7p10K1.mjs.map +0 -1
- package/dist/Cron-Bnd-2pgE.cjs.map +0 -1
- package/dist/Cron-DNRjf2cp.mjs.map +0 -1
- package/dist/CronBuilder-DdR2TuQa.mjs.map +0 -1
- package/dist/CronBuilder-dtw4ZyH6.cjs.map +0 -1
- package/dist/Endpoint-B69TqESg.mjs.map +0 -1
- package/dist/Endpoint-B9PryZES.cjs.map +0 -1
- package/dist/EndpointBuilder-DnVL-EU_.mjs.map +0 -1
- package/dist/EndpointBuilder-DofwCnWJ.cjs.map +0 -1
- package/dist/EndpointFactory-Ba9mx9MU.cjs.map +0 -1
- package/dist/EndpointFactory-pPaIGFHV.mjs.map +0 -1
- package/dist/Function-CO-s2pB8.cjs.map +0 -1
- package/dist/Function-COnc-tWM.mjs.map +0 -1
- package/dist/FunctionBuilder-CMhLQ4dt.mjs.map +0 -1
- package/dist/FunctionBuilder-_hMwZUof.cjs.map +0 -1
- package/dist/FunctionExecutionWrapper-Ci-ookJG.d.cts +0 -24
- package/dist/FunctionExecutionWrapper-DHFMLrOl.d.mts +0 -24
- package/dist/FunctionExecutionWrapper-i9v5L3Av.mjs +0 -36
- package/dist/FunctionExecutionWrapper-i9v5L3Av.mjs.map +0 -1
- package/dist/FunctionExecutionWrapper-sxJNTpuc.cjs +0 -42
- package/dist/FunctionExecutionWrapper-sxJNTpuc.cjs.map +0 -1
- package/dist/HonoEndpointAdaptor-Cw2if5cG.cjs.map +0 -1
- package/dist/HonoEndpointAdaptor-DAfnTFVS.mjs.map +0 -1
- package/dist/TestEndpointAdaptor-Bn1WRFph.cjs.map +0 -1
- package/dist/TestEndpointAdaptor-DubQOJk_.mjs.map +0 -1
- package/dist/functions-BYqZAob8.mjs +0 -8
- package/dist/index-CUg_hSq-.d.cts +0 -9
- package/dist/index-D-a7e2gv.d.mts +0 -9
|
@@ -0,0 +1,393 @@
|
|
|
1
|
+
import type {
|
|
2
|
+
AuditRecord,
|
|
3
|
+
AuditStorage,
|
|
4
|
+
AuditableAction,
|
|
5
|
+
} from '@geekmidas/audit';
|
|
6
|
+
import { EnvironmentParser } from '@geekmidas/envkit';
|
|
7
|
+
import { ConsoleLogger } from '@geekmidas/logger/console';
|
|
8
|
+
|
|
9
|
+
import { beforeEach, describe, expect, it, vi } from 'vitest';
|
|
10
|
+
import { z } from 'zod/v4';
|
|
11
|
+
|
|
12
|
+
import { AWSLambdaFunction } from '../AWSLambdaFunction';
|
|
13
|
+
import { FunctionBuilder } from '../FunctionBuilder';
|
|
14
|
+
import { TestFunctionAdaptor } from '../TestFunctionAdaptor';
|
|
15
|
+
|
|
16
|
+
// Define audit action types for type-safety
|
|
17
|
+
type UserAuditActions =
|
|
18
|
+
| AuditableAction<'user.processed', { userId: string; status: string }>
|
|
19
|
+
| AuditableAction<'user.failed', { userId: string; reason: string }>;
|
|
20
|
+
|
|
21
|
+
// Mock audit storage
|
|
22
|
+
class MockAuditStorage implements AuditStorage {
|
|
23
|
+
storedRecords: AuditRecord[] = [];
|
|
24
|
+
|
|
25
|
+
async write(records: AuditRecord[]): Promise<void> {
|
|
26
|
+
this.storedRecords.push(...records);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
getDatabase() {
|
|
30
|
+
return undefined;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// Audit storage service - use unique names to avoid ServiceDiscovery caching
|
|
35
|
+
let serviceCounter = 0;
|
|
36
|
+
const createAuditStorageService = <T extends string>(
|
|
37
|
+
storage: MockAuditStorage,
|
|
38
|
+
name?: T,
|
|
39
|
+
) => ({
|
|
40
|
+
serviceName: (name ?? `auditStorage-${++serviceCounter}`) as T extends string
|
|
41
|
+
? T
|
|
42
|
+
: `auditStorage-${number}`,
|
|
43
|
+
async register() {
|
|
44
|
+
return storage;
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
describe('Function Audits', () => {
|
|
49
|
+
let logger: ConsoleLogger;
|
|
50
|
+
let envParser: EnvironmentParser<{}>;
|
|
51
|
+
|
|
52
|
+
beforeEach(() => {
|
|
53
|
+
logger = new ConsoleLogger();
|
|
54
|
+
envParser = new EnvironmentParser({});
|
|
55
|
+
vi.clearAllMocks();
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
describe('FunctionBuilder with auditor', () => {
|
|
59
|
+
it('should configure auditor storage service', () => {
|
|
60
|
+
const auditStorage = new MockAuditStorage();
|
|
61
|
+
const auditStorageService = createAuditStorageService(auditStorage);
|
|
62
|
+
|
|
63
|
+
const fn = new FunctionBuilder()
|
|
64
|
+
.auditor(auditStorageService)
|
|
65
|
+
.output(z.object({ result: z.string() }))
|
|
66
|
+
.handle(async () => {
|
|
67
|
+
return { result: 'success' };
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
expect(fn.auditorStorageService).toBe(auditStorageService);
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
it('should provide type-safe auditor via actions()', () => {
|
|
74
|
+
const auditStorage = new MockAuditStorage();
|
|
75
|
+
const auditStorageService = createAuditStorageService(auditStorage);
|
|
76
|
+
|
|
77
|
+
const fn = new FunctionBuilder()
|
|
78
|
+
.auditor(auditStorageService)
|
|
79
|
+
.actions<UserAuditActions>()
|
|
80
|
+
.output(z.object({ result: z.string() }))
|
|
81
|
+
.handle(async ({ auditor }) => {
|
|
82
|
+
// auditor should be typed with UserAuditActions
|
|
83
|
+
if (auditor) {
|
|
84
|
+
auditor.audit('user.processed', {
|
|
85
|
+
userId: '123',
|
|
86
|
+
status: 'active',
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
return { result: 'success' };
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
expect(fn.auditorStorageService).toBe(auditStorageService);
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
describe('TestFunctionAdaptor with auditor', () => {
|
|
97
|
+
it('should inject auditor and flush audits', async () => {
|
|
98
|
+
const auditStorage = new MockAuditStorage();
|
|
99
|
+
const auditStorageService = createAuditStorageService(auditStorage);
|
|
100
|
+
|
|
101
|
+
const fn = new FunctionBuilder()
|
|
102
|
+
.auditor(auditStorageService)
|
|
103
|
+
.actions<UserAuditActions>()
|
|
104
|
+
.input({ userId: z.string() })
|
|
105
|
+
.output(z.object({ processed: z.boolean() }))
|
|
106
|
+
.handle(async ({ input, auditor }) => {
|
|
107
|
+
if (auditor) {
|
|
108
|
+
auditor.audit('user.processed', {
|
|
109
|
+
userId: input.userId,
|
|
110
|
+
status: 'completed',
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
return { processed: true };
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
const adaptor = new TestFunctionAdaptor(fn);
|
|
117
|
+
const result = await adaptor.invoke({
|
|
118
|
+
input: { userId: 'user-123' },
|
|
119
|
+
services: {},
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
expect(result).toEqual({ processed: true });
|
|
123
|
+
expect(auditStorage.storedRecords).toHaveLength(1);
|
|
124
|
+
expect(auditStorage.storedRecords[0]).toMatchObject({
|
|
125
|
+
type: 'user.processed',
|
|
126
|
+
payload: { userId: 'user-123', status: 'completed' },
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
|
|
130
|
+
it('should work without auditor when not configured', async () => {
|
|
131
|
+
const fn = new FunctionBuilder()
|
|
132
|
+
.input({ value: z.number() })
|
|
133
|
+
.output(z.object({ doubled: z.number() }))
|
|
134
|
+
.handle(async (ctx) => {
|
|
135
|
+
// auditor should be undefined when not configured
|
|
136
|
+
// Use type assertion since it's not in the type when not configured
|
|
137
|
+
expect((ctx as any).auditor).toBeUndefined();
|
|
138
|
+
return { doubled: ctx.input.value * 2 };
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
const adaptor = new TestFunctionAdaptor(fn);
|
|
142
|
+
const result = await adaptor.invoke({
|
|
143
|
+
input: { value: 5 },
|
|
144
|
+
services: {},
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
expect(result).toEqual({ doubled: 10 });
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
it('should allow injecting custom auditor', async () => {
|
|
151
|
+
const customAuditStorage = new MockAuditStorage();
|
|
152
|
+
const auditStorageService = createAuditStorageService(customAuditStorage);
|
|
153
|
+
|
|
154
|
+
const fn = new FunctionBuilder()
|
|
155
|
+
.auditor(auditStorageService)
|
|
156
|
+
.actions<UserAuditActions>()
|
|
157
|
+
.input({ trigger: z.string() })
|
|
158
|
+
.output(z.object({ success: z.boolean() }))
|
|
159
|
+
.handle(async ({ auditor }) => {
|
|
160
|
+
if (auditor) {
|
|
161
|
+
auditor.audit('user.processed', {
|
|
162
|
+
userId: 'custom',
|
|
163
|
+
status: 'custom-audit',
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
return { success: true };
|
|
167
|
+
});
|
|
168
|
+
|
|
169
|
+
// Create a custom auditor with different storage
|
|
170
|
+
const testStorage = new MockAuditStorage();
|
|
171
|
+
const { DefaultAuditor } = await import('@geekmidas/audit');
|
|
172
|
+
const customAuditor = new DefaultAuditor<UserAuditActions>({
|
|
173
|
+
actor: { id: 'test', type: 'test' },
|
|
174
|
+
storage: testStorage,
|
|
175
|
+
metadata: { test: true },
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
const adaptor = new TestFunctionAdaptor(fn);
|
|
179
|
+
const result = await adaptor.invoke({
|
|
180
|
+
input: { trigger: 'test' },
|
|
181
|
+
services: {},
|
|
182
|
+
auditor: customAuditor,
|
|
183
|
+
});
|
|
184
|
+
|
|
185
|
+
expect(result).toEqual({ success: true });
|
|
186
|
+
// Custom auditor's storage should have the records
|
|
187
|
+
expect(testStorage.storedRecords).toHaveLength(1);
|
|
188
|
+
// Default storage should be empty
|
|
189
|
+
expect(customAuditStorage.storedRecords).toHaveLength(0);
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
it('should record multiple audits in single invocation', async () => {
|
|
193
|
+
const auditStorage = new MockAuditStorage();
|
|
194
|
+
const auditStorageService = createAuditStorageService(auditStorage);
|
|
195
|
+
|
|
196
|
+
const fn = new FunctionBuilder()
|
|
197
|
+
.auditor(auditStorageService)
|
|
198
|
+
.actions<UserAuditActions>()
|
|
199
|
+
.input({ userIds: z.array(z.string()) })
|
|
200
|
+
.output(z.object({ processed: z.number() }))
|
|
201
|
+
.handle(async ({ input, auditor }) => {
|
|
202
|
+
for (const userId of input.userIds) {
|
|
203
|
+
if (auditor) {
|
|
204
|
+
auditor.audit('user.processed', {
|
|
205
|
+
userId,
|
|
206
|
+
status: 'batch-processed',
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
return { processed: input.userIds.length };
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
const adaptor = new TestFunctionAdaptor(fn);
|
|
214
|
+
const result = await adaptor.invoke({
|
|
215
|
+
input: { userIds: ['user-1', 'user-2', 'user-3'] },
|
|
216
|
+
services: {},
|
|
217
|
+
});
|
|
218
|
+
|
|
219
|
+
expect(result).toEqual({ processed: 3 });
|
|
220
|
+
expect(auditStorage.storedRecords).toHaveLength(3);
|
|
221
|
+
expect(auditStorage.storedRecords.map((r) => r.payload)).toEqual([
|
|
222
|
+
{ userId: 'user-1', status: 'batch-processed' },
|
|
223
|
+
{ userId: 'user-2', status: 'batch-processed' },
|
|
224
|
+
{ userId: 'user-3', status: 'batch-processed' },
|
|
225
|
+
]);
|
|
226
|
+
});
|
|
227
|
+
});
|
|
228
|
+
|
|
229
|
+
describe('AWSLambdaFunction with auditor', () => {
|
|
230
|
+
const createMockLambdaContext = () => ({
|
|
231
|
+
functionName: 'test-function',
|
|
232
|
+
functionVersion: '1',
|
|
233
|
+
invokedFunctionArn: 'arn:aws:lambda:region:account:function:test',
|
|
234
|
+
memoryLimitInMB: '128',
|
|
235
|
+
awsRequestId: 'test-request-id',
|
|
236
|
+
logGroupName: '/aws/lambda/test',
|
|
237
|
+
logStreamName: '2023/01/01/[$LATEST]test',
|
|
238
|
+
getRemainingTimeInMillis: () => 30000,
|
|
239
|
+
done: vi.fn(),
|
|
240
|
+
fail: vi.fn(),
|
|
241
|
+
succeed: vi.fn(),
|
|
242
|
+
callbackWaitsForEmptyEventLoop: true,
|
|
243
|
+
});
|
|
244
|
+
|
|
245
|
+
it('should inject auditor in Lambda handler', async () => {
|
|
246
|
+
const auditStorage = new MockAuditStorage();
|
|
247
|
+
const auditStorageService = createAuditStorageService(auditStorage);
|
|
248
|
+
|
|
249
|
+
const fn = new FunctionBuilder()
|
|
250
|
+
.logger(logger)
|
|
251
|
+
.auditor(auditStorageService)
|
|
252
|
+
.actions<UserAuditActions>()
|
|
253
|
+
.input({ action: z.string() })
|
|
254
|
+
.output(z.object({ completed: z.boolean() }))
|
|
255
|
+
.handle(async ({ input, auditor }) => {
|
|
256
|
+
if (auditor) {
|
|
257
|
+
auditor.audit('user.processed', {
|
|
258
|
+
userId: 'lambda-user',
|
|
259
|
+
status: input.action,
|
|
260
|
+
});
|
|
261
|
+
}
|
|
262
|
+
return { completed: true };
|
|
263
|
+
});
|
|
264
|
+
|
|
265
|
+
const adaptor = new AWSLambdaFunction(envParser, fn);
|
|
266
|
+
const handler = adaptor.handler;
|
|
267
|
+
|
|
268
|
+
const result = await handler(
|
|
269
|
+
{ action: 'lambda-action' },
|
|
270
|
+
createMockLambdaContext(),
|
|
271
|
+
vi.fn(),
|
|
272
|
+
);
|
|
273
|
+
|
|
274
|
+
expect(result).toEqual({ completed: true });
|
|
275
|
+
expect(auditStorage.storedRecords).toHaveLength(1);
|
|
276
|
+
expect(auditStorage.storedRecords[0]).toMatchObject({
|
|
277
|
+
type: 'user.processed',
|
|
278
|
+
payload: { userId: 'lambda-user', status: 'lambda-action' },
|
|
279
|
+
});
|
|
280
|
+
});
|
|
281
|
+
|
|
282
|
+
it('should work without auditor when not configured', async () => {
|
|
283
|
+
const fn = new FunctionBuilder()
|
|
284
|
+
.logger(logger)
|
|
285
|
+
.input({ value: z.number() })
|
|
286
|
+
.output(z.object({ result: z.number() }))
|
|
287
|
+
.handle(async (ctx) => {
|
|
288
|
+
// Use type assertion since auditor is not in type when not configured
|
|
289
|
+
expect((ctx as any).auditor).toBeUndefined();
|
|
290
|
+
return { result: ctx.input.value + 1 };
|
|
291
|
+
});
|
|
292
|
+
|
|
293
|
+
const adaptor = new AWSLambdaFunction(envParser, fn);
|
|
294
|
+
const handler = adaptor.handler;
|
|
295
|
+
|
|
296
|
+
const result = await handler(
|
|
297
|
+
{ value: 10 },
|
|
298
|
+
createMockLambdaContext(),
|
|
299
|
+
vi.fn(),
|
|
300
|
+
);
|
|
301
|
+
|
|
302
|
+
expect(result).toEqual({ result: 11 });
|
|
303
|
+
});
|
|
304
|
+
|
|
305
|
+
it('should flush audits after successful execution', async () => {
|
|
306
|
+
const auditStorage = new MockAuditStorage();
|
|
307
|
+
const auditStorageService = createAuditStorageService(auditStorage);
|
|
308
|
+
|
|
309
|
+
const fn = new FunctionBuilder()
|
|
310
|
+
.logger(logger)
|
|
311
|
+
.auditor(auditStorageService)
|
|
312
|
+
.actions<UserAuditActions>()
|
|
313
|
+
.output(z.object({ status: z.string() }))
|
|
314
|
+
.handle(async ({ auditor }) => {
|
|
315
|
+
if (auditor) {
|
|
316
|
+
auditor.audit('user.processed', {
|
|
317
|
+
userId: 'flush-test',
|
|
318
|
+
status: 'pending',
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
return { status: 'ok' };
|
|
322
|
+
});
|
|
323
|
+
|
|
324
|
+
const adaptor = new AWSLambdaFunction(envParser, fn);
|
|
325
|
+
const handler = adaptor.handler;
|
|
326
|
+
|
|
327
|
+
await handler({}, createMockLambdaContext(), vi.fn());
|
|
328
|
+
|
|
329
|
+
// Records should be flushed
|
|
330
|
+
expect(auditStorage.storedRecords).toHaveLength(1);
|
|
331
|
+
});
|
|
332
|
+
|
|
333
|
+
it('should not flush audits if none were recorded', async () => {
|
|
334
|
+
const auditStorage = new MockAuditStorage();
|
|
335
|
+
const writeSpy = vi.spyOn(auditStorage, 'write');
|
|
336
|
+
const auditStorageService = createAuditStorageService(auditStorage);
|
|
337
|
+
|
|
338
|
+
const fn = new FunctionBuilder()
|
|
339
|
+
.logger(logger)
|
|
340
|
+
.auditor(auditStorageService)
|
|
341
|
+
.actions<UserAuditActions>()
|
|
342
|
+
.output(z.object({ status: z.string() }))
|
|
343
|
+
.handle(async () => {
|
|
344
|
+
// Don't record any audits
|
|
345
|
+
return { status: 'no-audits' };
|
|
346
|
+
});
|
|
347
|
+
|
|
348
|
+
const adaptor = new AWSLambdaFunction(envParser, fn);
|
|
349
|
+
const handler = adaptor.handler;
|
|
350
|
+
|
|
351
|
+
await handler({}, createMockLambdaContext(), vi.fn());
|
|
352
|
+
|
|
353
|
+
// write should not be called
|
|
354
|
+
expect(writeSpy).not.toHaveBeenCalled();
|
|
355
|
+
});
|
|
356
|
+
});
|
|
357
|
+
|
|
358
|
+
describe('Auditor with entity tracking', () => {
|
|
359
|
+
it('should record audits with entityId and table', async () => {
|
|
360
|
+
const auditStorage = new MockAuditStorage();
|
|
361
|
+
const auditStorageService = createAuditStorageService(auditStorage);
|
|
362
|
+
|
|
363
|
+
const fn = new FunctionBuilder()
|
|
364
|
+
.auditor(auditStorageService)
|
|
365
|
+
.actions<UserAuditActions>()
|
|
366
|
+
.input({ userId: z.string() })
|
|
367
|
+
.output(z.object({ success: z.boolean() }))
|
|
368
|
+
.handle(async ({ input, auditor }) => {
|
|
369
|
+
if (auditor) {
|
|
370
|
+
auditor.audit(
|
|
371
|
+
'user.processed',
|
|
372
|
+
{ userId: input.userId, status: 'active' },
|
|
373
|
+
{ entityId: input.userId, table: 'users' },
|
|
374
|
+
);
|
|
375
|
+
}
|
|
376
|
+
return { success: true };
|
|
377
|
+
});
|
|
378
|
+
|
|
379
|
+
const adaptor = new TestFunctionAdaptor(fn);
|
|
380
|
+
await adaptor.invoke({
|
|
381
|
+
input: { userId: 'entity-123' },
|
|
382
|
+
services: {},
|
|
383
|
+
});
|
|
384
|
+
|
|
385
|
+
expect(auditStorage.storedRecords).toHaveLength(1);
|
|
386
|
+
expect(auditStorage.storedRecords[0]).toMatchObject({
|
|
387
|
+
type: 'user.processed',
|
|
388
|
+
entityId: 'entity-123',
|
|
389
|
+
table: 'users',
|
|
390
|
+
});
|
|
391
|
+
});
|
|
392
|
+
});
|
|
393
|
+
});
|
|
@@ -305,6 +305,82 @@ describe('Function', () => {
|
|
|
305
305
|
// _timeout is protected, so we just verify the builder chain works
|
|
306
306
|
expect(finalBuilder).toBeInstanceOf(FunctionBuilder);
|
|
307
307
|
});
|
|
308
|
+
|
|
309
|
+
it('should set database service', () => {
|
|
310
|
+
const builder = new FunctionBuilder();
|
|
311
|
+
|
|
312
|
+
class MockDatabase {
|
|
313
|
+
async query(sql: string) {
|
|
314
|
+
return [];
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
|
|
318
|
+
const databaseService = {
|
|
319
|
+
serviceName: 'database' as const,
|
|
320
|
+
async register() {
|
|
321
|
+
return new MockDatabase();
|
|
322
|
+
},
|
|
323
|
+
};
|
|
324
|
+
|
|
325
|
+
const newBuilder = builder.database(databaseService);
|
|
326
|
+
expect(newBuilder['_databaseService']).toBe(databaseService);
|
|
327
|
+
});
|
|
328
|
+
|
|
329
|
+
it('should chain database with other methods', () => {
|
|
330
|
+
const builder = new FunctionBuilder();
|
|
331
|
+
const service = new TestService();
|
|
332
|
+
const logger = new ConsoleLogger();
|
|
333
|
+
|
|
334
|
+
class MockDatabase {
|
|
335
|
+
async query(sql: string) {
|
|
336
|
+
return [];
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
const databaseService = {
|
|
341
|
+
serviceName: 'database' as const,
|
|
342
|
+
async register() {
|
|
343
|
+
return new MockDatabase();
|
|
344
|
+
},
|
|
345
|
+
};
|
|
346
|
+
|
|
347
|
+
const finalBuilder = builder
|
|
348
|
+
.services([service])
|
|
349
|
+
.logger(logger)
|
|
350
|
+
.database(databaseService)
|
|
351
|
+
.output(z.object({ result: z.string() }));
|
|
352
|
+
|
|
353
|
+
expect(finalBuilder._services.length).toBe(1);
|
|
354
|
+
expect(finalBuilder['_databaseService']).toBe(databaseService);
|
|
355
|
+
expect(finalBuilder).toBeInstanceOf(FunctionBuilder);
|
|
356
|
+
});
|
|
357
|
+
|
|
358
|
+
it('should create function with database service', () => {
|
|
359
|
+
const builder = new FunctionBuilder();
|
|
360
|
+
|
|
361
|
+
class MockDatabase {
|
|
362
|
+
async query(sql: string) {
|
|
363
|
+
return [];
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
const databaseService = {
|
|
368
|
+
serviceName: 'database' as const,
|
|
369
|
+
async register() {
|
|
370
|
+
return new MockDatabase();
|
|
371
|
+
},
|
|
372
|
+
};
|
|
373
|
+
|
|
374
|
+
const fn = builder
|
|
375
|
+
.database(databaseService)
|
|
376
|
+
.output(z.object({ result: z.string() }))
|
|
377
|
+
.handle(async ({ db }) => {
|
|
378
|
+
// db should be available
|
|
379
|
+
return { result: 'success' };
|
|
380
|
+
});
|
|
381
|
+
|
|
382
|
+
expect(fn.databaseService).toBe(databaseService);
|
|
383
|
+
});
|
|
308
384
|
});
|
|
309
385
|
});
|
|
310
386
|
|
|
@@ -43,7 +43,7 @@ describe('FunctionBuilder - State Isolation', () => {
|
|
|
43
43
|
const fn2 = f.handle(async () => ({}));
|
|
44
44
|
|
|
45
45
|
expect(fn1.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
|
|
46
|
-
expect(fn2.services
|
|
46
|
+
expect(fn2.services).toEqual([]);
|
|
47
47
|
});
|
|
48
48
|
|
|
49
49
|
it('should reset logger after handle() is called', () => {
|
|
@@ -67,7 +67,8 @@ describe('FunctionBuilder - State Isolation', () => {
|
|
|
67
67
|
// Create first function (events array should be empty initially)
|
|
68
68
|
const fn1 = f.handle(async () => ({}));
|
|
69
69
|
|
|
70
|
-
// Verify state was reset
|
|
70
|
+
// Verify function was created and state was reset
|
|
71
|
+
expect(fn1).toBeDefined();
|
|
71
72
|
expect((f as any)._events).toEqual([]);
|
|
72
73
|
expect((f as any)._services).toEqual([]);
|
|
73
74
|
});
|
|
@@ -78,7 +79,10 @@ describe('FunctionBuilder - State Isolation', () => {
|
|
|
78
79
|
const outputSchema: any = { '~standard': { validate: () => ({}) } };
|
|
79
80
|
|
|
80
81
|
// First function with schemas
|
|
81
|
-
const fn1 = f
|
|
82
|
+
const fn1 = f
|
|
83
|
+
.input(inputSchema)
|
|
84
|
+
.output(outputSchema)
|
|
85
|
+
.handle(async () => ({}));
|
|
82
86
|
|
|
83
87
|
// Second function should not have schemas
|
|
84
88
|
const fn2 = f.handle(async () => ({}));
|
|
@@ -144,13 +148,15 @@ describe('FunctionBuilder - State Isolation', () => {
|
|
|
144
148
|
it('should create independent functions sequentially', () => {
|
|
145
149
|
const f = new FunctionBuilder();
|
|
146
150
|
|
|
147
|
-
const fn1 = f
|
|
151
|
+
const fn1 = f
|
|
152
|
+
.services([ServiceA, ServiceB])
|
|
153
|
+
.handle(async () => ({ result: 1 }));
|
|
148
154
|
const fn2 = f.services([ServiceA]).handle(async () => ({ result: 2 }));
|
|
149
155
|
const fn3 = f.handle(async () => ({ result: 3 }));
|
|
150
156
|
|
|
151
157
|
expect(fn1.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
|
|
152
158
|
expect(fn2.services.map((s) => s.serviceName)).toEqual(['a']);
|
|
153
|
-
expect(fn3.services
|
|
159
|
+
expect(fn3.services).toEqual([]);
|
|
154
160
|
});
|
|
155
161
|
});
|
|
156
162
|
|
package/src/publisher.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import type { AuditStorage } from '@geekmidas/audit';
|
|
1
2
|
import type { Logger } from '@geekmidas/logger';
|
|
2
3
|
import type { StandardSchemaV1 } from '@standard-schema/spec';
|
|
3
4
|
|
|
@@ -67,8 +68,18 @@ export async function publishConstructEvents<
|
|
|
67
68
|
OutSchema extends StandardSchemaV1 | undefined = undefined,
|
|
68
69
|
TServiceName extends string = string,
|
|
69
70
|
TServices extends Service[] = [],
|
|
71
|
+
TAuditStorageServiceName extends string = string,
|
|
72
|
+
TAuditStorage extends AuditStorage | undefined = undefined,
|
|
70
73
|
>(
|
|
71
|
-
construct: Construct<
|
|
74
|
+
construct: Construct<
|
|
75
|
+
Logger,
|
|
76
|
+
TServiceName,
|
|
77
|
+
T,
|
|
78
|
+
OutSchema,
|
|
79
|
+
TServices,
|
|
80
|
+
TAuditStorageServiceName,
|
|
81
|
+
TAuditStorage
|
|
82
|
+
>,
|
|
72
83
|
response: InferStandardSchema<OutSchema>,
|
|
73
84
|
serviceDiscovery: ServiceDiscovery<any, any>,
|
|
74
85
|
logger: Logger = construct.logger,
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AWSLambdaFunction-DMxScuaw.cjs","names":["FunctionExecutionWrapper","envParser: EnvironmentParser<{}>","fn: Function<\n TInput,\n TServices,\n TLogger,\n TOutSchema,\n FunctionHandler<TInput, TServices, TLogger, TOutSchema>,\n TEventPublisher,\n TEventPublisherServiceName\n >","event: FunctionEvent<TEvent, TInput, TServices, TLogger>"],"sources":["../src/functions/AWSLambdaFunction.ts"],"sourcesContent":["import type { EnvironmentParser } from '@geekmidas/envkit';\nimport middy, { type MiddlewareObj } from '@middy/core';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport type { Context, Handler } from 'aws-lambda';\nimport type { Function, FunctionHandler } from './Function';\nimport { FunctionBuilder } from './FunctionBuilder';\n\nimport { wrapError } from '@geekmidas/errors';\nimport type { EventPublisher } from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport type {\n ComposableStandardSchema,\n InferComposableStandardSchema,\n InferStandardSchema,\n} from '@geekmidas/schema';\nimport type { Service, ServiceRecord } from '@geekmidas/services';\nimport { FunctionExecutionWrapper } from './FunctionExecutionWrapper';\n\nexport type AWSLambdaHandler<TEvent = any, TResult = any> = Handler<\n TEvent,\n TResult\n>;\n\ntype FunctionEvent<\n TEvent,\n TInput extends ComposableStandardSchema | undefined,\n TServices extends Service[],\n TLogger extends Logger,\n> = TEvent & {\n parsedInput: InferComposableStandardSchema<TInput>;\n services: ServiceRecord<TServices>;\n logger: TLogger;\n};\n\ntype Middleware<\n TEvent,\n TInput extends ComposableStandardSchema | undefined,\n TServices extends Service[],\n TLogger extends Logger,\n TOutSchema extends StandardSchemaV1 | undefined,\n> = MiddlewareObj<\n FunctionEvent<TEvent, TInput, TServices, TLogger>,\n InferComposableStandardSchema<TOutSchema>,\n Error,\n Context\n>;\n\nexport class AWSLambdaFunction<\n TInput extends ComposableStandardSchema | undefined = undefined,\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n> extends FunctionExecutionWrapper<\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TEventPublisher,\n TEventPublisherServiceName\n> {\n constructor(\n envParser: EnvironmentParser<{}>,\n readonly fn: Function<\n TInput,\n TServices,\n TLogger,\n TOutSchema,\n FunctionHandler<TInput, TServices, TLogger, TOutSchema>,\n TEventPublisher,\n TEventPublisherServiceName\n >,\n ) {\n super(envParser, fn);\n }\n\n private error<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n onError: (req) => {\n const logger = req.event?.logger || this.fn.logger;\n logger.error(req.error || {}, 'Error processing function');\n\n // Re-throw the wrapped error to let Lambda handle it\n throw wrapError(req.error);\n },\n };\n }\n\n private baseInput<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n before: (req) => {},\n };\n }\n\n private input<\n TEvent extends { input: InferComposableStandardSchema<TInput> },\n >(): Middleware<TEvent, TInput, TServices, TLogger, TOutSchema> {\n return {\n before: async (req) => {\n try {\n // Parse input if schema is provided\n if (this.fn.input) {\n const parsedInput =\n await FunctionBuilder.parseComposableStandardSchema(\n req.event,\n this.fn.input,\n );\n\n req.event.parsedInput =\n parsedInput as InferComposableStandardSchema<TInput>;\n } else {\n // If no schema, pass the event as-is\n req.event.parsedInput = req.event as any;\n }\n } catch (error) {\n this.logger.error(\n { error, event: req.event },\n 'Failed to parse input',\n );\n throw error;\n }\n },\n };\n }\n\n private loggerMiddleware<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n before: (req) => {\n this._logger = this.fn.logger.child({\n fn: {\n name: req.context.functionName,\n version: req.context.functionVersion,\n memory: req.context.memoryLimitInMB,\n },\n req: {\n id: req.context.awsRequestId,\n },\n }) as TLogger;\n\n req.event.logger = this._logger;\n },\n };\n }\n\n private services<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n before: async (req) => {\n req.event.services = await this.getServices();\n },\n };\n }\n\n private events<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n after: async (req) => {\n const response = (req.response ||\n undefined) as InferStandardSchema<TOutSchema>;\n await this.publishEvents(response);\n },\n };\n }\n\n private async _handler<TEvent>(\n event: FunctionEvent<TEvent, TInput, TServices, TLogger>,\n ) {\n // Execute the function with the parsed context\n const result = await this.fn['fn']({\n input: event.parsedInput,\n services: event.services,\n logger: event.logger,\n });\n\n // Parse output if schema is provided\n const output = await this.fn.parseOutput(result);\n\n return output;\n }\n\n get handler(): AWSLambdaHandler {\n const handler = this._handler.bind(this);\n\n // Apply middleware in order\n return middy(handler)\n .use(this.loggerMiddleware())\n .use(this.baseInput())\n .use(this.error())\n .use(this.services())\n .use(this.input())\n .use(this.events()) as unknown as AWSLambdaHandler;\n }\n}\n"],"mappings":";;;;;;;AA+CA,IAAa,oBAAb,cAOUA,0DAOR;CACA,YACEC,WACSC,IAST;AACA,QAAM,WAAW,GAAG;EAVX;CAWV;CAED,AAAQ,QAMN;AACA,SAAO,EACL,SAAS,CAAC,QAAQ;GAChB,MAAM,SAAS,IAAI,OAAO,UAAU,KAAK,GAAG;AAC5C,UAAO,MAAM,IAAI,SAAS,CAAE,GAAE,4BAA4B;AAG1D,SAAM,kCAAU,IAAI,MAAM;EAC3B,EACF;CACF;CAED,AAAQ,YAMN;AACA,SAAO,EACL,QAAQ,CAAC,QAAQ,CAAE,EACpB;CACF;CAED,AAAQ,QAEwD;AAC9D,SAAO,EACL,QAAQ,OAAO,QAAQ;AACrB,OAAI;AAEF,QAAI,KAAK,GAAG,OAAO;KACjB,MAAM,cACJ,MAAM,wCAAgB,8BACpB,IAAI,OACJ,KAAK,GAAG,MACT;AAEH,SAAI,MAAM,cACR;IACH,MAEC,KAAI,MAAM,cAAc,IAAI;GAE/B,SAAQ,OAAO;AACd,SAAK,OAAO,MACV;KAAE;KAAO,OAAO,IAAI;IAAO,GAC3B,wBACD;AACD,UAAM;GACP;EACF,EACF;CACF;CAED,AAAQ,mBAMN;AACA,SAAO,EACL,QAAQ,CAAC,QAAQ;AACf,QAAK,UAAU,KAAK,GAAG,OAAO,MAAM;IAClC,IAAI;KACF,MAAM,IAAI,QAAQ;KAClB,SAAS,IAAI,QAAQ;KACrB,QAAQ,IAAI,QAAQ;IACrB;IACD,KAAK,EACH,IAAI,IAAI,QAAQ,aACjB;GACF,EAAC;AAEF,OAAI,MAAM,SAAS,KAAK;EACzB,EACF;CACF;CAED,AAAQ,WAMN;AACA,SAAO,EACL,QAAQ,OAAO,QAAQ;AACrB,OAAI,MAAM,WAAW,MAAM,KAAK,aAAa;EAC9C,EACF;CACF;CAED,AAAQ,SAMN;AACA,SAAO,EACL,OAAO,OAAO,QAAQ;GACpB,MAAM,WAAY,IAAI;AAEtB,SAAM,KAAK,cAAc,SAAS;EACnC,EACF;CACF;CAED,MAAc,SACZC,OACA;EAEA,MAAM,SAAS,MAAM,KAAK,GAAG,MAAM;GACjC,OAAO,MAAM;GACb,UAAU,MAAM;GAChB,QAAQ,MAAM;EACf,EAAC;EAGF,MAAM,SAAS,MAAM,KAAK,GAAG,YAAY,OAAO;AAEhD,SAAO;CACR;CAED,IAAI,UAA4B;EAC9B,MAAM,UAAU,KAAK,SAAS,KAAK,KAAK;AAGxC,SAAO,0BAAM,QAAQ,CAClB,IAAI,KAAK,kBAAkB,CAAC,CAC5B,IAAI,KAAK,WAAW,CAAC,CACrB,IAAI,KAAK,OAAO,CAAC,CACjB,IAAI,KAAK,UAAU,CAAC,CACpB,IAAI,KAAK,OAAO,CAAC,CACjB,IAAI,KAAK,QAAQ,CAAC;CACtB;AACF"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { Function, FunctionHandler } from "./Function-G3JPHMaY.mjs";
|
|
2
|
-
import { FunctionExecutionWrapper } from "./FunctionExecutionWrapper-DHFMLrOl.mjs";
|
|
3
|
-
import { Service } from "@geekmidas/services";
|
|
4
|
-
import { EnvironmentParser } from "@geekmidas/envkit";
|
|
5
|
-
import { EventPublisher } from "@geekmidas/events";
|
|
6
|
-
import { Logger } from "@geekmidas/logger";
|
|
7
|
-
import { StandardSchemaV1 } from "@standard-schema/spec";
|
|
8
|
-
import { ComposableStandardSchema } from "@geekmidas/schema";
|
|
9
|
-
import { Handler } from "aws-lambda";
|
|
10
|
-
|
|
11
|
-
//#region src/functions/AWSLambdaFunction.d.ts
|
|
12
|
-
type AWSLambdaHandler<TEvent = any, TResult = any> = Handler<TEvent, TResult>;
|
|
13
|
-
declare class AWSLambdaFunction<TInput extends ComposableStandardSchema | undefined = undefined, TOutSchema extends StandardSchemaV1 | undefined = undefined, TServices extends Service[] = [], TLogger extends Logger = Logger, TEventPublisher extends EventPublisher<any> | undefined = undefined, TEventPublisherServiceName extends string = string> extends FunctionExecutionWrapper<TInput, TOutSchema, TServices, TLogger, TEventPublisher, TEventPublisherServiceName> {
|
|
14
|
-
readonly fn: Function<TInput, TServices, TLogger, TOutSchema, FunctionHandler<TInput, TServices, TLogger, TOutSchema>, TEventPublisher, TEventPublisherServiceName>;
|
|
15
|
-
constructor(envParser: EnvironmentParser<{}>, fn: Function<TInput, TServices, TLogger, TOutSchema, FunctionHandler<TInput, TServices, TLogger, TOutSchema>, TEventPublisher, TEventPublisherServiceName>);
|
|
16
|
-
private error;
|
|
17
|
-
private baseInput;
|
|
18
|
-
private input;
|
|
19
|
-
private loggerMiddleware;
|
|
20
|
-
private services;
|
|
21
|
-
private events;
|
|
22
|
-
private _handler;
|
|
23
|
-
get handler(): AWSLambdaHandler;
|
|
24
|
-
}
|
|
25
|
-
//#endregion
|
|
26
|
-
export { AWSLambdaFunction, AWSLambdaHandler };
|
|
27
|
-
//# sourceMappingURL=AWSLambdaFunction-DSB2oaFG.d.mts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AWSLambdaFunction-cL8A169J.mjs","names":["envParser: EnvironmentParser<{}>","fn: Function<\n TInput,\n TServices,\n TLogger,\n TOutSchema,\n FunctionHandler<TInput, TServices, TLogger, TOutSchema>,\n TEventPublisher,\n TEventPublisherServiceName\n >","event: FunctionEvent<TEvent, TInput, TServices, TLogger>"],"sources":["../src/functions/AWSLambdaFunction.ts"],"sourcesContent":["import type { EnvironmentParser } from '@geekmidas/envkit';\nimport middy, { type MiddlewareObj } from '@middy/core';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport type { Context, Handler } from 'aws-lambda';\nimport type { Function, FunctionHandler } from './Function';\nimport { FunctionBuilder } from './FunctionBuilder';\n\nimport { wrapError } from '@geekmidas/errors';\nimport type { EventPublisher } from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport type {\n ComposableStandardSchema,\n InferComposableStandardSchema,\n InferStandardSchema,\n} from '@geekmidas/schema';\nimport type { Service, ServiceRecord } from '@geekmidas/services';\nimport { FunctionExecutionWrapper } from './FunctionExecutionWrapper';\n\nexport type AWSLambdaHandler<TEvent = any, TResult = any> = Handler<\n TEvent,\n TResult\n>;\n\ntype FunctionEvent<\n TEvent,\n TInput extends ComposableStandardSchema | undefined,\n TServices extends Service[],\n TLogger extends Logger,\n> = TEvent & {\n parsedInput: InferComposableStandardSchema<TInput>;\n services: ServiceRecord<TServices>;\n logger: TLogger;\n};\n\ntype Middleware<\n TEvent,\n TInput extends ComposableStandardSchema | undefined,\n TServices extends Service[],\n TLogger extends Logger,\n TOutSchema extends StandardSchemaV1 | undefined,\n> = MiddlewareObj<\n FunctionEvent<TEvent, TInput, TServices, TLogger>,\n InferComposableStandardSchema<TOutSchema>,\n Error,\n Context\n>;\n\nexport class AWSLambdaFunction<\n TInput extends ComposableStandardSchema | undefined = undefined,\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n> extends FunctionExecutionWrapper<\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TEventPublisher,\n TEventPublisherServiceName\n> {\n constructor(\n envParser: EnvironmentParser<{}>,\n readonly fn: Function<\n TInput,\n TServices,\n TLogger,\n TOutSchema,\n FunctionHandler<TInput, TServices, TLogger, TOutSchema>,\n TEventPublisher,\n TEventPublisherServiceName\n >,\n ) {\n super(envParser, fn);\n }\n\n private error<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n onError: (req) => {\n const logger = req.event?.logger || this.fn.logger;\n logger.error(req.error || {}, 'Error processing function');\n\n // Re-throw the wrapped error to let Lambda handle it\n throw wrapError(req.error);\n },\n };\n }\n\n private baseInput<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n before: (req) => {},\n };\n }\n\n private input<\n TEvent extends { input: InferComposableStandardSchema<TInput> },\n >(): Middleware<TEvent, TInput, TServices, TLogger, TOutSchema> {\n return {\n before: async (req) => {\n try {\n // Parse input if schema is provided\n if (this.fn.input) {\n const parsedInput =\n await FunctionBuilder.parseComposableStandardSchema(\n req.event,\n this.fn.input,\n );\n\n req.event.parsedInput =\n parsedInput as InferComposableStandardSchema<TInput>;\n } else {\n // If no schema, pass the event as-is\n req.event.parsedInput = req.event as any;\n }\n } catch (error) {\n this.logger.error(\n { error, event: req.event },\n 'Failed to parse input',\n );\n throw error;\n }\n },\n };\n }\n\n private loggerMiddleware<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n before: (req) => {\n this._logger = this.fn.logger.child({\n fn: {\n name: req.context.functionName,\n version: req.context.functionVersion,\n memory: req.context.memoryLimitInMB,\n },\n req: {\n id: req.context.awsRequestId,\n },\n }) as TLogger;\n\n req.event.logger = this._logger;\n },\n };\n }\n\n private services<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n before: async (req) => {\n req.event.services = await this.getServices();\n },\n };\n }\n\n private events<TEvent>(): Middleware<\n TEvent,\n TInput,\n TServices,\n TLogger,\n TOutSchema\n > {\n return {\n after: async (req) => {\n const response = (req.response ||\n undefined) as InferStandardSchema<TOutSchema>;\n await this.publishEvents(response);\n },\n };\n }\n\n private async _handler<TEvent>(\n event: FunctionEvent<TEvent, TInput, TServices, TLogger>,\n ) {\n // Execute the function with the parsed context\n const result = await this.fn['fn']({\n input: event.parsedInput,\n services: event.services,\n logger: event.logger,\n });\n\n // Parse output if schema is provided\n const output = await this.fn.parseOutput(result);\n\n return output;\n }\n\n get handler(): AWSLambdaHandler {\n const handler = this._handler.bind(this);\n\n // Apply middleware in order\n return middy(handler)\n .use(this.loggerMiddleware())\n .use(this.baseInput())\n .use(this.error())\n .use(this.services())\n .use(this.input())\n .use(this.events()) as unknown as AWSLambdaHandler;\n }\n}\n"],"mappings":";;;;;;AA+CA,IAAa,oBAAb,cAOU,yBAOR;CACA,YACEA,WACSC,IAST;AACA,QAAM,WAAW,GAAG;EAVX;CAWV;CAED,AAAQ,QAMN;AACA,SAAO,EACL,SAAS,CAAC,QAAQ;GAChB,MAAM,SAAS,IAAI,OAAO,UAAU,KAAK,GAAG;AAC5C,UAAO,MAAM,IAAI,SAAS,CAAE,GAAE,4BAA4B;AAG1D,SAAM,UAAU,IAAI,MAAM;EAC3B,EACF;CACF;CAED,AAAQ,YAMN;AACA,SAAO,EACL,QAAQ,CAAC,QAAQ,CAAE,EACpB;CACF;CAED,AAAQ,QAEwD;AAC9D,SAAO,EACL,QAAQ,OAAO,QAAQ;AACrB,OAAI;AAEF,QAAI,KAAK,GAAG,OAAO;KACjB,MAAM,cACJ,MAAM,gBAAgB,8BACpB,IAAI,OACJ,KAAK,GAAG,MACT;AAEH,SAAI,MAAM,cACR;IACH,MAEC,KAAI,MAAM,cAAc,IAAI;GAE/B,SAAQ,OAAO;AACd,SAAK,OAAO,MACV;KAAE;KAAO,OAAO,IAAI;IAAO,GAC3B,wBACD;AACD,UAAM;GACP;EACF,EACF;CACF;CAED,AAAQ,mBAMN;AACA,SAAO,EACL,QAAQ,CAAC,QAAQ;AACf,QAAK,UAAU,KAAK,GAAG,OAAO,MAAM;IAClC,IAAI;KACF,MAAM,IAAI,QAAQ;KAClB,SAAS,IAAI,QAAQ;KACrB,QAAQ,IAAI,QAAQ;IACrB;IACD,KAAK,EACH,IAAI,IAAI,QAAQ,aACjB;GACF,EAAC;AAEF,OAAI,MAAM,SAAS,KAAK;EACzB,EACF;CACF;CAED,AAAQ,WAMN;AACA,SAAO,EACL,QAAQ,OAAO,QAAQ;AACrB,OAAI,MAAM,WAAW,MAAM,KAAK,aAAa;EAC9C,EACF;CACF;CAED,AAAQ,SAMN;AACA,SAAO,EACL,OAAO,OAAO,QAAQ;GACpB,MAAM,WAAY,IAAI;AAEtB,SAAM,KAAK,cAAc,SAAS;EACnC,EACF;CACF;CAED,MAAc,SACZC,OACA;EAEA,MAAM,SAAS,MAAM,KAAK,GAAG,MAAM;GACjC,OAAO,MAAM;GACb,UAAU,MAAM;GAChB,QAAQ,MAAM;EACf,EAAC;EAGF,MAAM,SAAS,MAAM,KAAK,GAAG,YAAY,OAAO;AAEhD,SAAO;CACR;CAED,IAAI,UAA4B;EAC9B,MAAM,UAAU,KAAK,SAAS,KAAK,KAAK;AAGxC,SAAO,MAAM,QAAQ,CAClB,IAAI,KAAK,kBAAkB,CAAC,CAC5B,IAAI,KAAK,WAAW,CAAC,CACrB,IAAI,KAAK,OAAO,CAAC,CACjB,IAAI,KAAK,UAAU,CAAC,CACpB,IAAI,KAAK,OAAO,CAAC,CACjB,IAAI,KAAK,QAAQ,CAAC;CACtB;AACF"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { Function, FunctionHandler } from "./Function-6EWabl_X.cjs";
|
|
2
|
-
import { FunctionExecutionWrapper } from "./FunctionExecutionWrapper-Ci-ookJG.cjs";
|
|
3
|
-
import { EventPublisher } from "@geekmidas/events";
|
|
4
|
-
import { Logger } from "@geekmidas/logger";
|
|
5
|
-
import { Service } from "@geekmidas/services";
|
|
6
|
-
import { StandardSchemaV1 } from "@standard-schema/spec";
|
|
7
|
-
import { ComposableStandardSchema } from "@geekmidas/schema";
|
|
8
|
-
import { EnvironmentParser } from "@geekmidas/envkit";
|
|
9
|
-
import { Handler } from "aws-lambda";
|
|
10
|
-
|
|
11
|
-
//#region src/functions/AWSLambdaFunction.d.ts
|
|
12
|
-
type AWSLambdaHandler<TEvent = any, TResult = any> = Handler<TEvent, TResult>;
|
|
13
|
-
declare class AWSLambdaFunction<TInput extends ComposableStandardSchema | undefined = undefined, TOutSchema extends StandardSchemaV1 | undefined = undefined, TServices extends Service[] = [], TLogger extends Logger = Logger, TEventPublisher extends EventPublisher<any> | undefined = undefined, TEventPublisherServiceName extends string = string> extends FunctionExecutionWrapper<TInput, TOutSchema, TServices, TLogger, TEventPublisher, TEventPublisherServiceName> {
|
|
14
|
-
readonly fn: Function<TInput, TServices, TLogger, TOutSchema, FunctionHandler<TInput, TServices, TLogger, TOutSchema>, TEventPublisher, TEventPublisherServiceName>;
|
|
15
|
-
constructor(envParser: EnvironmentParser<{}>, fn: Function<TInput, TServices, TLogger, TOutSchema, FunctionHandler<TInput, TServices, TLogger, TOutSchema>, TEventPublisher, TEventPublisherServiceName>);
|
|
16
|
-
private error;
|
|
17
|
-
private baseInput;
|
|
18
|
-
private input;
|
|
19
|
-
private loggerMiddleware;
|
|
20
|
-
private services;
|
|
21
|
-
private events;
|
|
22
|
-
private _handler;
|
|
23
|
-
get handler(): AWSLambdaHandler;
|
|
24
|
-
}
|
|
25
|
-
//#endregion
|
|
26
|
-
export { AWSLambdaFunction, AWSLambdaHandler };
|
|
27
|
-
//# sourceMappingURL=AWSLambdaFunction-t6q2o8EL.d.cts.map
|