@geekmidas/constructs 0.0.7 → 0.0.10
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/dist/{AWSLambdaFunction-CANc3Qo2.d.mts → AWSLambdaFunction-D5V3YVqv.d.cts} +5 -5
- package/dist/{AWSLambdaFunction-DWIZYsCy.mjs → AWSLambdaFunction-D_V-ZQmS.mjs} +3 -3
- package/dist/{AWSLambdaFunction-DWIZYsCy.mjs.map → AWSLambdaFunction-D_V-ZQmS.mjs.map} +1 -1
- package/dist/{AWSLambdaFunction-qA5LqPsv.cjs → AWSLambdaFunction-DhUb-Vs6.cjs} +3 -3
- package/dist/{AWSLambdaFunction-qA5LqPsv.cjs.map → AWSLambdaFunction-DhUb-Vs6.cjs.map} +1 -1
- package/dist/{AWSLambdaFunction-CwagvPG3.d.cts → AWSLambdaFunction-DvZcnL8a.d.mts} +5 -5
- package/dist/{AWSLambdaSubscriberAdaptor-QKVxR6qh.d.cts → AWSLambdaSubscriberAdaptor-D6kjKjSf.d.mts} +4 -4
- package/dist/{AWSLambdaSubscriberAdaptor-C6JYIZxn.d.mts → AWSLambdaSubscriberAdaptor-J_pSz6pu.d.cts} +4 -4
- package/dist/{AmazonApiGatewayEndpointAdaptor-BrB3RfbI.d.mts → AmazonApiGatewayEndpointAdaptor-B7MKo8h3.d.mts} +3 -3
- package/dist/{AmazonApiGatewayEndpointAdaptor-BFhJ2Rpz.d.cts → AmazonApiGatewayEndpointAdaptor-BnNd8tCz.d.cts} +2 -2
- package/dist/{AmazonApiGatewayEndpointAdaptor-B8mozTcG.cjs → AmazonApiGatewayEndpointAdaptor-DHBF_5jn.cjs} +2 -2
- package/dist/{AmazonApiGatewayEndpointAdaptor-B8mozTcG.cjs.map → AmazonApiGatewayEndpointAdaptor-DHBF_5jn.cjs.map} +1 -1
- package/dist/{AmazonApiGatewayEndpointAdaptor-Bmz6Cy1e.mjs → AmazonApiGatewayEndpointAdaptor-DHcUetbw.mjs} +2 -2
- package/dist/{AmazonApiGatewayEndpointAdaptor-Bmz6Cy1e.mjs.map → AmazonApiGatewayEndpointAdaptor-DHcUetbw.mjs.map} +1 -1
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-Bd-o8ese.d.cts → AmazonApiGatewayV1EndpointAdaptor-BC-a2tt3.d.cts} +3 -3
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-D4eZ-fx5.cjs → AmazonApiGatewayV1EndpointAdaptor-CmUxFoPx.cjs} +2 -2
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-D4eZ-fx5.cjs.map → AmazonApiGatewayV1EndpointAdaptor-CmUxFoPx.cjs.map} +1 -1
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-24g3dLn5.mjs → AmazonApiGatewayV1EndpointAdaptor-CsV6zyvn.mjs} +2 -2
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-24g3dLn5.mjs.map → AmazonApiGatewayV1EndpointAdaptor-CsV6zyvn.mjs.map} +1 -1
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-BtNXt0-4.d.mts → AmazonApiGatewayV1EndpointAdaptor-gO9OxdZl.d.mts} +4 -4
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-DAJdtgek.d.mts → AmazonApiGatewayV2EndpointAdaptor-D1uz4wNg.d.mts} +4 -4
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-Cc40RThv.mjs → AmazonApiGatewayV2EndpointAdaptor-_bFcbEa-.mjs} +2 -2
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-Cc40RThv.mjs.map → AmazonApiGatewayV2EndpointAdaptor-_bFcbEa-.mjs.map} +1 -1
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-J6tACl-N.cjs → AmazonApiGatewayV2EndpointAdaptor-cZbaqiUi.cjs} +2 -2
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-J6tACl-N.cjs.map → AmazonApiGatewayV2EndpointAdaptor-cZbaqiUi.cjs.map} +1 -1
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-DX-Uci5w.d.cts → AmazonApiGatewayV2EndpointAdaptor-zNFUPxSY.d.cts} +3 -3
- package/dist/Authorizer-Bbk9ziuG.d.mts +29 -0
- package/dist/Authorizer-iXsSB600.d.cts +29 -0
- package/dist/{BaseFunctionBuilder-DtO4Nwxm.cjs → BaseFunctionBuilder-BmsbV0BU.cjs} +2 -2
- package/dist/{BaseFunctionBuilder-DtO4Nwxm.cjs.map → BaseFunctionBuilder-BmsbV0BU.cjs.map} +1 -1
- package/dist/{BaseFunctionBuilder-5QCHkchp.d.cts → BaseFunctionBuilder-C4ZJPkIZ.d.cts} +2 -2
- package/dist/{BaseFunctionBuilder-Dda7AiID.d.mts → BaseFunctionBuilder-CxBX0arJ.d.mts} +2 -2
- package/dist/{BaseFunctionBuilder-BPE9JBbT.mjs → BaseFunctionBuilder-DCUtCdVL.mjs} +2 -2
- package/dist/{BaseFunctionBuilder-BPE9JBbT.mjs.map → BaseFunctionBuilder-DCUtCdVL.mjs.map} +1 -1
- package/dist/{Construct-BbKCIPQm.mjs → Construct-C3hsQBy4.mjs} +10 -13
- package/dist/Construct-C3hsQBy4.mjs.map +1 -0
- package/dist/{Construct-BSEs6uwW.cjs → Construct-VEI7M3fs.cjs} +10 -13
- package/dist/Construct-VEI7M3fs.cjs.map +1 -0
- package/dist/{Construct-Bm-PSO2V.d.cts → Construct-ci5u8Xnu.d.cts} +4 -2
- package/dist/{Construct-DdyYENBD.d.mts → Construct-zhmcmIdY.d.mts} +4 -2
- package/dist/Construct.cjs +1 -1
- package/dist/Construct.d.cts +1 -1
- package/dist/Construct.d.mts +1 -1
- package/dist/Construct.mjs +1 -1
- package/dist/{Cron-BxMXmn4t.d.cts → Cron-ByNYsQDH.d.mts} +4 -4
- package/dist/{Cron-CmZ6esMM.cjs → Cron-Dfgr8F9d.cjs} +5 -5
- package/dist/Cron-Dfgr8F9d.cjs.map +1 -0
- package/dist/{Cron-NDBlJhb3.d.mts → Cron-DkPL-Fms.d.cts} +4 -4
- package/dist/{Cron-D6hnZLk7.mjs → Cron-wP6Ob48_.mjs} +5 -5
- package/dist/Cron-wP6Ob48_.mjs.map +1 -0
- package/dist/{CronBuilder-C6K5AbIO.d.cts → CronBuilder-BknVTWLE.d.mts} +6 -5
- package/dist/{CronBuilder-s5x8V8hH.d.mts → CronBuilder-BqTTozUi.d.cts} +6 -5
- package/dist/{CronBuilder-Dfv5JguE.mjs → CronBuilder-C27c5oqh.mjs} +10 -5
- package/dist/CronBuilder-C27c5oqh.mjs.map +1 -0
- package/dist/{CronBuilder-Di7QK8Rt.cjs → CronBuilder-W1ZqCJ7m.cjs} +10 -5
- package/dist/CronBuilder-W1ZqCJ7m.cjs.map +1 -0
- package/dist/{Endpoint-COGAflGh.cjs → Endpoint-BjpQmTek.cjs} +21 -12
- package/dist/Endpoint-BjpQmTek.cjs.map +1 -0
- package/dist/{Endpoint-C7jPJzAH.d.mts → Endpoint-C16whGI-.d.mts} +45 -13
- package/dist/{Endpoint-DLLZvqoh.mjs → Endpoint-C98BwZjA.mjs} +21 -12
- package/dist/Endpoint-C98BwZjA.mjs.map +1 -0
- package/dist/{Endpoint-XUMNAXYy.d.cts → Endpoint-zHPjZ35J.d.cts} +45 -13
- package/dist/{EndpointBuilder-t6fVEKBH.d.cts → EndpointBuilder-B5l7zQU1.d.cts} +18 -12
- package/dist/{EndpointBuilder-CFtWQhcv.d.mts → EndpointBuilder-BzqR0xvt.d.mts} +18 -12
- package/dist/{EndpointBuilder-oXO_ka1-.mjs → EndpointBuilder-CCUx4vep.mjs} +28 -5
- package/dist/EndpointBuilder-CCUx4vep.mjs.map +1 -0
- package/dist/{EndpointBuilder-FJktpPOu.cjs → EndpointBuilder-D2Zu8i9b.cjs} +28 -5
- package/dist/EndpointBuilder-D2Zu8i9b.cjs.map +1 -0
- package/dist/{EndpointFactory-Kk1tpifs.cjs → EndpointFactory-C4YhgXOc.cjs} +41 -10
- package/dist/EndpointFactory-C4YhgXOc.cjs.map +1 -0
- package/dist/{EndpointFactory-DBRGrXAy.d.mts → EndpointFactory-KkyIOE62.d.cts} +29 -21
- package/dist/{EndpointFactory-eG8bDhOh.mjs → EndpointFactory-RAb2zcw0.mjs} +41 -10
- package/dist/EndpointFactory-RAb2zcw0.mjs.map +1 -0
- package/dist/{EndpointFactory-DInjHvFR.d.cts → EndpointFactory-VnSAdwdv.d.mts} +29 -21
- package/dist/{Function-CbO2NZx-.cjs → Function-1Fh6Tdkg.cjs} +4 -5
- package/dist/Function-1Fh6Tdkg.cjs.map +1 -0
- package/dist/{Function-BP58p9Mp.d.cts → Function-BbLYIKLL.d.cts} +3 -4
- package/dist/{Function-C5mW-38v.mjs → Function-D-QEfH7k.mjs} +4 -5
- package/dist/Function-D-QEfH7k.mjs.map +1 -0
- package/dist/{Function-C98H68DW.d.mts → Function-DFRZZCC-.d.mts} +3 -4
- package/dist/{FunctionBuilder-CosgPmMl.mjs → FunctionBuilder-Bxyr1Pf9.mjs} +11 -5
- package/dist/FunctionBuilder-Bxyr1Pf9.mjs.map +1 -0
- package/dist/{FunctionBuilder-DuOeWCAl.cjs → FunctionBuilder-DcEFYgbn.cjs} +11 -5
- package/dist/FunctionBuilder-DcEFYgbn.cjs.map +1 -0
- package/dist/{FunctionBuilder-BS1KgxA_.d.cts → FunctionBuilder-DdGjpiFT.d.cts} +6 -4
- package/dist/{FunctionBuilder-DBwR7jg7.d.mts → FunctionBuilder-DuktGyZc.d.mts} +6 -4
- package/dist/{FunctionExecutionWrapper-XGrSAAPD.mjs → FunctionExecutionWrapper-BL6PE6Dv.mjs} +2 -2
- package/dist/{FunctionExecutionWrapper-XGrSAAPD.mjs.map → FunctionExecutionWrapper-BL6PE6Dv.mjs.map} +1 -1
- package/dist/{FunctionExecutionWrapper-B0V7V8YS.d.mts → FunctionExecutionWrapper-CRYi047B.d.cts} +4 -4
- package/dist/{FunctionExecutionWrapper-Bx-Dl-2a.d.cts → FunctionExecutionWrapper-DaR-dSLw.d.mts} +4 -4
- package/dist/{FunctionExecutionWrapper-CElXEjPe.cjs → FunctionExecutionWrapper-Ee-CE8Fz.cjs} +2 -2
- package/dist/{FunctionExecutionWrapper-CElXEjPe.cjs.map → FunctionExecutionWrapper-Ee-CE8Fz.cjs.map} +1 -1
- package/dist/{HonoEndpointAdaptor-BrbM9vxd.d.cts → HonoEndpointAdaptor-CY1mXTe6.d.mts} +7 -6
- package/dist/{HonoEndpointAdaptor-CxcYKdzT.d.mts → HonoEndpointAdaptor-CYvrXBe-.d.cts} +9 -8
- package/dist/{HonoEndpointAdaptor-BlT1rWHV.mjs → HonoEndpointAdaptor-CyVPl4w2.mjs} +33 -16
- package/dist/HonoEndpointAdaptor-CyVPl4w2.mjs.map +1 -0
- package/dist/{HonoEndpointAdaptor-Ds433Q8w.cjs → HonoEndpointAdaptor-DcvZdYzx.cjs} +20 -3
- package/dist/HonoEndpointAdaptor-DcvZdYzx.cjs.map +1 -0
- package/dist/{Subscriber-CSt7EOlT.cjs → Subscriber-BL30GpWp.cjs} +2 -2
- package/dist/{Subscriber-CSt7EOlT.cjs.map → Subscriber-BL30GpWp.cjs.map} +1 -1
- package/dist/{Subscriber-DkCDcTUL.mjs → Subscriber-CTczVFsF.mjs} +2 -2
- package/dist/{Subscriber-DkCDcTUL.mjs.map → Subscriber-CTczVFsF.mjs.map} +1 -1
- package/dist/{Subscriber-BoFm12i_.d.cts → Subscriber-Cy28j8MS.d.cts} +2 -2
- package/dist/{Subscriber-BxH6n8zQ.d.mts → Subscriber-g3IWM1_d.d.mts} +2 -2
- package/dist/{SubscriberBuilder-BpSDPzBz.d.mts → SubscriberBuilder-BzK8kc2a.d.cts} +3 -3
- package/dist/{SubscriberBuilder-Bn9Hyi28.mjs → SubscriberBuilder-CekL3BoP.mjs} +2 -2
- package/dist/{SubscriberBuilder-Bn9Hyi28.mjs.map → SubscriberBuilder-CekL3BoP.mjs.map} +1 -1
- package/dist/{SubscriberBuilder-RsiOmnwq.cjs → SubscriberBuilder-D1hojYLa.cjs} +2 -2
- package/dist/{SubscriberBuilder-RsiOmnwq.cjs.map → SubscriberBuilder-D1hojYLa.cjs.map} +1 -1
- package/dist/{SubscriberBuilder-DgljKtYu.d.cts → SubscriberBuilder-YjQ7qIpQ.d.mts} +3 -3
- package/dist/{TestEndpointAdaptor-Ct4I-gDo.mjs → TestEndpointAdaptor-B4z9G5Ap.mjs} +3 -3
- package/dist/{TestEndpointAdaptor-Ct4I-gDo.mjs.map → TestEndpointAdaptor-B4z9G5Ap.mjs.map} +1 -1
- package/dist/{TestEndpointAdaptor-FJUob2W_.cjs → TestEndpointAdaptor-C-ahwGW6.cjs} +3 -3
- package/dist/{TestEndpointAdaptor-FJUob2W_.cjs.map → TestEndpointAdaptor-C-ahwGW6.cjs.map} +1 -1
- package/dist/{TestEndpointAdaptor-vboVyJ0w.d.mts → TestEndpointAdaptor-DGWuai69.d.mts} +2 -2
- package/dist/{TestEndpointAdaptor-wwEaVHAt.d.cts → TestEndpointAdaptor-uXliWYjS.d.cts} +2 -2
- package/dist/adaptors/aws.cjs +11 -11
- package/dist/adaptors/aws.d.cts +14 -13
- package/dist/adaptors/aws.d.mts +14 -13
- package/dist/adaptors/aws.mjs +11 -11
- package/dist/adaptors/hono.cjs +8 -8
- package/dist/adaptors/hono.d.cts +8 -7
- package/dist/adaptors/hono.d.mts +8 -7
- package/dist/adaptors/hono.mjs +8 -8
- package/dist/adaptors/testing.cjs +7 -7
- package/dist/adaptors/testing.d.cts +8 -7
- package/dist/adaptors/testing.d.mts +8 -7
- package/dist/adaptors/testing.mjs +7 -7
- package/dist/crons/Cron.cjs +6 -6
- package/dist/crons/Cron.d.cts +6 -6
- package/dist/crons/Cron.d.mts +6 -6
- package/dist/crons/Cron.mjs +6 -6
- package/dist/crons/CronBuilder.cjs +7 -7
- package/dist/crons/CronBuilder.d.cts +7 -7
- package/dist/crons/CronBuilder.d.mts +7 -7
- package/dist/crons/CronBuilder.mjs +7 -7
- package/dist/crons/index.cjs +7 -7
- package/dist/crons/index.d.cts +11 -11
- package/dist/crons/index.d.mts +11 -11
- package/dist/crons/index.mjs +7 -7
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +7 -7
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +8 -7
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +8 -7
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +7 -7
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +8 -8
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +9 -8
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +9 -8
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +8 -8
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +8 -8
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +9 -8
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +9 -8
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +8 -8
- package/dist/endpoints/Authorizer.cjs +15 -0
- package/dist/endpoints/Authorizer.cjs.map +1 -0
- package/dist/endpoints/Authorizer.d.cts +2 -0
- package/dist/endpoints/Authorizer.d.mts +2 -0
- package/dist/endpoints/Authorizer.mjs +14 -0
- package/dist/endpoints/Authorizer.mjs.map +1 -0
- package/dist/endpoints/Endpoint.cjs +6 -6
- package/dist/endpoints/Endpoint.d.cts +7 -6
- package/dist/endpoints/Endpoint.d.mts +7 -6
- package/dist/endpoints/Endpoint.mjs +6 -6
- package/dist/endpoints/EndpointBuilder.cjs +7 -7
- package/dist/endpoints/EndpointBuilder.d.cts +8 -7
- package/dist/endpoints/EndpointBuilder.d.mts +8 -7
- package/dist/endpoints/EndpointBuilder.mjs +7 -7
- package/dist/endpoints/EndpointFactory.cjs +8 -8
- package/dist/endpoints/EndpointFactory.d.cts +9 -8
- package/dist/endpoints/EndpointFactory.d.mts +9 -8
- package/dist/endpoints/EndpointFactory.mjs +8 -8
- package/dist/endpoints/HonoEndpointAdaptor.cjs +8 -8
- package/dist/endpoints/HonoEndpointAdaptor.d.cts +8 -7
- package/dist/endpoints/HonoEndpointAdaptor.d.mts +8 -7
- package/dist/endpoints/HonoEndpointAdaptor.mjs +8 -8
- package/dist/endpoints/TestEndpointAdaptor.cjs +7 -7
- package/dist/endpoints/TestEndpointAdaptor.d.cts +8 -7
- package/dist/endpoints/TestEndpointAdaptor.d.mts +8 -7
- package/dist/endpoints/TestEndpointAdaptor.mjs +7 -7
- package/dist/endpoints/helpers.cjs +7 -7
- package/dist/endpoints/helpers.d.cts +7 -6
- package/dist/endpoints/helpers.d.mts +7 -6
- package/dist/endpoints/helpers.mjs +7 -7
- package/dist/endpoints/index.cjs +8 -8
- package/dist/endpoints/index.d.cts +11 -10
- package/dist/endpoints/index.d.mts +11 -10
- package/dist/endpoints/index.mjs +8 -8
- package/dist/functions/AWSLambdaFunction.cjs +6 -6
- package/dist/functions/AWSLambdaFunction.d.cts +4 -4
- package/dist/functions/AWSLambdaFunction.d.mts +4 -4
- package/dist/functions/AWSLambdaFunction.mjs +6 -6
- package/dist/functions/BaseFunctionBuilder.cjs +2 -2
- package/dist/functions/BaseFunctionBuilder.d.cts +2 -2
- package/dist/functions/BaseFunctionBuilder.d.mts +2 -2
- package/dist/functions/BaseFunctionBuilder.mjs +2 -2
- package/dist/functions/Function.cjs +2 -2
- package/dist/functions/Function.d.cts +2 -2
- package/dist/functions/Function.d.mts +2 -2
- package/dist/functions/Function.mjs +2 -2
- package/dist/functions/FunctionBuilder.cjs +4 -4
- package/dist/functions/FunctionBuilder.d.cts +4 -4
- package/dist/functions/FunctionBuilder.d.mts +4 -4
- package/dist/functions/FunctionBuilder.mjs +4 -4
- package/dist/functions/FunctionExecutionWrapper.cjs +5 -5
- package/dist/functions/FunctionExecutionWrapper.d.cts +3 -3
- package/dist/functions/FunctionExecutionWrapper.d.mts +3 -3
- package/dist/functions/FunctionExecutionWrapper.mjs +5 -5
- package/dist/functions/TestFunctionAdaptor.cjs +5 -5
- package/dist/functions/TestFunctionAdaptor.d.cts +2 -2
- package/dist/functions/TestFunctionAdaptor.d.mts +2 -2
- package/dist/functions/TestFunctionAdaptor.mjs +5 -5
- package/dist/functions/index.cjs +5 -5
- package/dist/functions/index.d.cts +5 -5
- package/dist/functions/index.d.mts +5 -5
- package/dist/functions/index.mjs +5 -5
- package/dist/{functions-DVDb5wEA.cjs → functions-BtgBiuC_.cjs} +2 -2
- package/dist/{functions-DVDb5wEA.cjs.map → functions-BtgBiuC_.cjs.map} +1 -1
- package/dist/functions-DD-00sWF.mjs +8 -0
- package/dist/{functions-mM-jcphA.mjs.map → functions-DD-00sWF.mjs.map} +1 -1
- package/dist/{helpers-CM0U-4Vk.mjs → helpers-DtPeOhUV.mjs} +2 -2
- package/dist/{helpers-CM0U-4Vk.mjs.map → helpers-DtPeOhUV.mjs.map} +1 -1
- package/dist/{helpers-go4jiRvV.cjs → helpers-QM_FSjPY.cjs} +2 -2
- package/dist/{helpers-go4jiRvV.cjs.map → helpers-QM_FSjPY.cjs.map} +1 -1
- package/dist/index-CcmV3PKF.d.cts +9 -0
- package/dist/index-DQt3pQtF.d.mts +9 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.cts +1 -1
- package/dist/index.d.mts +1 -1
- package/dist/index.mjs +1 -1
- package/dist/publisher.d.cts +1 -1
- package/dist/publisher.d.mts +1 -1
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +3 -3
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +3 -3
- package/dist/subscribers/Subscriber.cjs +2 -2
- package/dist/subscribers/Subscriber.d.cts +2 -2
- package/dist/subscribers/Subscriber.d.mts +2 -2
- package/dist/subscribers/Subscriber.mjs +2 -2
- package/dist/subscribers/SubscriberBuilder.cjs +3 -3
- package/dist/subscribers/SubscriberBuilder.d.cts +3 -3
- package/dist/subscribers/SubscriberBuilder.d.mts +3 -3
- package/dist/subscribers/SubscriberBuilder.mjs +3 -3
- package/dist/subscribers/index.cjs +3 -3
- package/dist/subscribers/index.d.cts +5 -5
- package/dist/subscribers/index.d.mts +5 -5
- package/dist/subscribers/index.mjs +3 -3
- package/package.json +6 -6
- package/src/Construct.ts +11 -24
- package/src/crons/Cron.ts +2 -0
- package/src/crons/CronBuilder.ts +8 -0
- package/src/crons/__tests__/CronBuilder.state-isolation.spec.ts +227 -0
- package/src/endpoints/Authorizer.ts +34 -0
- package/src/endpoints/Endpoint.ts +67 -14
- package/src/endpoints/EndpointBuilder.ts +79 -12
- package/src/endpoints/EndpointFactory.ts +106 -27
- package/src/endpoints/HonoEndpointAdaptor.ts +29 -0
- package/src/endpoints/__tests__/Endpoint.cookies.spec.ts +85 -0
- package/src/endpoints/__tests__/Endpoint.headers.spec.ts +187 -0
- package/src/endpoints/__tests__/Endpoint.manifest.spec.ts +176 -0
- package/src/endpoints/__tests__/EndpointFactory.authorizers.spec.ts +259 -0
- package/src/endpoints/__tests__/EndpointFactory.reference-audit.spec.ts +190 -0
- package/src/endpoints/__tests__/EndpointFactory.state-isolation.spec.ts +155 -0
- package/src/functions/Function.ts +12 -2
- package/src/functions/FunctionBuilder.ts +9 -0
- package/src/functions/__tests__/FunctionBuilder.state-isolation.spec.ts +160 -0
- package/dist/Construct-BSEs6uwW.cjs.map +0 -1
- package/dist/Construct-BbKCIPQm.mjs.map +0 -1
- package/dist/Cron-CmZ6esMM.cjs.map +0 -1
- package/dist/Cron-D6hnZLk7.mjs.map +0 -1
- package/dist/CronBuilder-Dfv5JguE.mjs.map +0 -1
- package/dist/CronBuilder-Di7QK8Rt.cjs.map +0 -1
- package/dist/Endpoint-COGAflGh.cjs.map +0 -1
- package/dist/Endpoint-DLLZvqoh.mjs.map +0 -1
- package/dist/EndpointBuilder-FJktpPOu.cjs.map +0 -1
- package/dist/EndpointBuilder-oXO_ka1-.mjs.map +0 -1
- package/dist/EndpointFactory-Kk1tpifs.cjs.map +0 -1
- package/dist/EndpointFactory-eG8bDhOh.mjs.map +0 -1
- package/dist/Function-C5mW-38v.mjs.map +0 -1
- package/dist/Function-CbO2NZx-.cjs.map +0 -1
- package/dist/FunctionBuilder-CosgPmMl.mjs.map +0 -1
- package/dist/FunctionBuilder-DuOeWCAl.cjs.map +0 -1
- package/dist/HonoEndpointAdaptor-BlT1rWHV.mjs.map +0 -1
- package/dist/HonoEndpointAdaptor-Ds433Q8w.cjs.map +0 -1
- package/dist/functions-mM-jcphA.mjs +0 -8
- package/dist/index-BGr5gFrX.d.cts +0 -9
- package/dist/index-YM4W9XUq.d.mts +0 -9
package/dist/index.mjs
CHANGED
package/dist/publisher.d.cts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Construct } from "./Construct-
|
|
1
|
+
import { Construct } from "./Construct-ci5u8Xnu.cjs";
|
|
2
2
|
import { EventPublisher, MappedEvent } from "@geekmidas/events";
|
|
3
3
|
import { Logger } from "@geekmidas/logger";
|
|
4
4
|
import { Service, ServiceDiscovery } from "@geekmidas/services";
|
package/dist/publisher.d.mts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Construct } from "./Construct-
|
|
1
|
+
import { Construct } from "./Construct-zhmcmIdY.mjs";
|
|
2
2
|
import { Service, ServiceDiscovery } from "@geekmidas/services";
|
|
3
3
|
import { EventPublisher, MappedEvent } from "@geekmidas/events";
|
|
4
4
|
import { Logger } from "@geekmidas/logger";
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import "../Subscriber-
|
|
3
|
-
import { AWSLambdaHandler, AWSLambdaSubscriber } from "../AWSLambdaSubscriberAdaptor-
|
|
1
|
+
import "../Construct-ci5u8Xnu.cjs";
|
|
2
|
+
import "../Subscriber-Cy28j8MS.cjs";
|
|
3
|
+
import { AWSLambdaHandler, AWSLambdaSubscriber } from "../AWSLambdaSubscriberAdaptor-J_pSz6pu.cjs";
|
|
4
4
|
export { AWSLambdaHandler, AWSLambdaSubscriber };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import "../Subscriber-
|
|
3
|
-
import { AWSLambdaHandler, AWSLambdaSubscriber } from "../AWSLambdaSubscriberAdaptor-
|
|
1
|
+
import "../Construct-zhmcmIdY.mjs";
|
|
2
|
+
import "../Subscriber-g3IWM1_d.mjs";
|
|
3
|
+
import { AWSLambdaHandler, AWSLambdaSubscriber } from "../AWSLambdaSubscriberAdaptor-D6kjKjSf.mjs";
|
|
4
4
|
export { AWSLambdaHandler, AWSLambdaSubscriber };
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import { Subscriber, SubscriberContext, SubscriberHandler } from "../Subscriber-
|
|
1
|
+
import "../Construct-ci5u8Xnu.cjs";
|
|
2
|
+
import { Subscriber, SubscriberContext, SubscriberHandler } from "../Subscriber-Cy28j8MS.cjs";
|
|
3
3
|
export { Subscriber, SubscriberContext, SubscriberHandler };
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import { Subscriber, SubscriberContext, SubscriberHandler } from "../Subscriber-
|
|
1
|
+
import "../Construct-zhmcmIdY.mjs";
|
|
2
|
+
import { Subscriber, SubscriberContext, SubscriberHandler } from "../Subscriber-g3IWM1_d.mjs";
|
|
3
3
|
export { Subscriber, SubscriberContext, SubscriberHandler };
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
require('../Construct-
|
|
2
|
-
require('../Subscriber-
|
|
3
|
-
const require_SubscriberBuilder = require('../SubscriberBuilder-
|
|
1
|
+
require('../Construct-VEI7M3fs.cjs');
|
|
2
|
+
require('../Subscriber-BL30GpWp.cjs');
|
|
3
|
+
const require_SubscriberBuilder = require('../SubscriberBuilder-D1hojYLa.cjs');
|
|
4
4
|
|
|
5
5
|
exports.SubscriberBuilder = require_SubscriberBuilder.SubscriberBuilder;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import "../Subscriber-
|
|
3
|
-
import { SubscriberBuilder } from "../SubscriberBuilder-
|
|
1
|
+
import "../Construct-ci5u8Xnu.cjs";
|
|
2
|
+
import "../Subscriber-Cy28j8MS.cjs";
|
|
3
|
+
import { SubscriberBuilder } from "../SubscriberBuilder-BzK8kc2a.cjs";
|
|
4
4
|
export { SubscriberBuilder };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import "../Subscriber-
|
|
3
|
-
import { SubscriberBuilder } from "../SubscriberBuilder-
|
|
1
|
+
import "../Construct-zhmcmIdY.mjs";
|
|
2
|
+
import "../Subscriber-g3IWM1_d.mjs";
|
|
3
|
+
import { SubscriberBuilder } from "../SubscriberBuilder-YjQ7qIpQ.mjs";
|
|
4
4
|
export { SubscriberBuilder };
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import "../Subscriber-
|
|
3
|
-
import { SubscriberBuilder } from "../SubscriberBuilder-
|
|
1
|
+
import "../Construct-C3hsQBy4.mjs";
|
|
2
|
+
import "../Subscriber-CTczVFsF.mjs";
|
|
3
|
+
import { SubscriberBuilder } from "../SubscriberBuilder-CekL3BoP.mjs";
|
|
4
4
|
|
|
5
5
|
export { SubscriberBuilder };
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
require('../Construct-
|
|
2
|
-
const require_Subscriber = require('../Subscriber-
|
|
3
|
-
const require_SubscriberBuilder = require('../SubscriberBuilder-
|
|
1
|
+
require('../Construct-VEI7M3fs.cjs');
|
|
2
|
+
const require_Subscriber = require('../Subscriber-BL30GpWp.cjs');
|
|
3
|
+
const require_SubscriberBuilder = require('../SubscriberBuilder-D1hojYLa.cjs');
|
|
4
4
|
|
|
5
5
|
//#region src/subscribers/index.ts
|
|
6
6
|
const s = new require_SubscriberBuilder.SubscriberBuilder();
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import { Subscriber } from "../Subscriber-
|
|
3
|
-
import { SubscriberBuilder } from "../SubscriberBuilder-
|
|
4
|
-
import * as
|
|
1
|
+
import "../Construct-ci5u8Xnu.cjs";
|
|
2
|
+
import { Subscriber } from "../Subscriber-Cy28j8MS.cjs";
|
|
3
|
+
import { SubscriberBuilder } from "../SubscriberBuilder-BzK8kc2a.cjs";
|
|
4
|
+
import * as _geekmidas_logger0 from "@geekmidas/logger";
|
|
5
5
|
|
|
6
6
|
//#region src/subscribers/index.d.ts
|
|
7
|
-
declare const s: SubscriberBuilder<[],
|
|
7
|
+
declare const s: SubscriberBuilder<[], _geekmidas_logger0.Logger, undefined, undefined, string, []>;
|
|
8
8
|
//#endregion
|
|
9
9
|
export { Subscriber, SubscriberBuilder, s };
|
|
10
10
|
//# sourceMappingURL=index.d.cts.map
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import { Subscriber } from "../Subscriber-
|
|
3
|
-
import { SubscriberBuilder } from "../SubscriberBuilder-
|
|
4
|
-
import * as
|
|
1
|
+
import "../Construct-zhmcmIdY.mjs";
|
|
2
|
+
import { Subscriber } from "../Subscriber-g3IWM1_d.mjs";
|
|
3
|
+
import { SubscriberBuilder } from "../SubscriberBuilder-YjQ7qIpQ.mjs";
|
|
4
|
+
import * as _geekmidas_logger1 from "@geekmidas/logger";
|
|
5
5
|
|
|
6
6
|
//#region src/subscribers/index.d.ts
|
|
7
|
-
declare const s: SubscriberBuilder<[],
|
|
7
|
+
declare const s: SubscriberBuilder<[], _geekmidas_logger1.Logger, undefined, undefined, string, []>;
|
|
8
8
|
//#endregion
|
|
9
9
|
export { Subscriber, SubscriberBuilder, s };
|
|
10
10
|
//# sourceMappingURL=index.d.mts.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import "../Construct-
|
|
2
|
-
import { Subscriber } from "../Subscriber-
|
|
3
|
-
import { SubscriberBuilder } from "../SubscriberBuilder-
|
|
1
|
+
import "../Construct-C3hsQBy4.mjs";
|
|
2
|
+
import { Subscriber } from "../Subscriber-CTczVFsF.mjs";
|
|
3
|
+
import { SubscriberBuilder } from "../SubscriberBuilder-CekL3BoP.mjs";
|
|
4
4
|
|
|
5
5
|
//#region src/subscribers/index.ts
|
|
6
6
|
const s = new SubscriberBuilder();
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@geekmidas/constructs",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.10",
|
|
4
4
|
"private": false,
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
@@ -66,12 +66,12 @@
|
|
|
66
66
|
"lodash.compact": "~3.0.1",
|
|
67
67
|
"openapi-types": "~12.1.3",
|
|
68
68
|
"fast-glob": "~3.3.3",
|
|
69
|
-
"@geekmidas/logger": "0.0.1",
|
|
70
|
-
"@geekmidas/events": "0.0.2",
|
|
71
69
|
"@geekmidas/schema": "0.0.2",
|
|
72
70
|
"@geekmidas/services": "0.0.1",
|
|
73
|
-
"@geekmidas/
|
|
71
|
+
"@geekmidas/logger": "0.0.1",
|
|
74
72
|
"@geekmidas/errors": "0.0.1",
|
|
73
|
+
"@geekmidas/cache": "0.0.7",
|
|
74
|
+
"@geekmidas/events": "0.0.2",
|
|
75
75
|
"@geekmidas/rate-limit": "0.1.0"
|
|
76
76
|
},
|
|
77
77
|
"devDependencies": {
|
|
@@ -81,13 +81,13 @@
|
|
|
81
81
|
"@types/lodash.uniqby": "~4.7.9",
|
|
82
82
|
"@types/lodash.compact": "~3.0.9",
|
|
83
83
|
"zod": "~4.1.12",
|
|
84
|
-
"@geekmidas/testkit": "0.0.
|
|
84
|
+
"@geekmidas/testkit": "0.0.17"
|
|
85
85
|
},
|
|
86
86
|
"peerDependencies": {
|
|
87
87
|
"@middy/core": ">=6.3.1",
|
|
88
88
|
"@types/aws-lambda": ">=8.10.92",
|
|
89
89
|
"hono": ">=4.8.2",
|
|
90
|
-
"@geekmidas/envkit": "~0.0.
|
|
90
|
+
"@geekmidas/envkit": "~0.0.8"
|
|
91
91
|
},
|
|
92
92
|
"scripts": {
|
|
93
93
|
"ts": "tsc --noEmit --skipLibCheck src/**/*.ts"
|
package/src/Construct.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SnifferEnvironmentParser } from '@geekmidas/envkit/sniffer';
|
|
2
2
|
import type { EventPublisher, MappedEvent } from '@geekmidas/events';
|
|
3
3
|
import type { Logger } from '@geekmidas/logger';
|
|
4
4
|
import type { Service } from '@geekmidas/services';
|
|
@@ -20,6 +20,8 @@ export abstract class Construct<
|
|
|
20
20
|
|
|
21
21
|
public readonly publisherService?: Service<TServiceName, T>,
|
|
22
22
|
public outputSchema?: OutSchema,
|
|
23
|
+
public readonly timeout?: number,
|
|
24
|
+
public readonly memorySize?: number,
|
|
23
25
|
) {}
|
|
24
26
|
|
|
25
27
|
/**
|
|
@@ -40,8 +42,7 @@ export abstract class Construct<
|
|
|
40
42
|
* ```
|
|
41
43
|
*/
|
|
42
44
|
async getEnvironment(): Promise<string[]> {
|
|
43
|
-
const
|
|
44
|
-
const sniffer = new EnvironmentParser({});
|
|
45
|
+
const sniffer = new SnifferEnvironmentParser();
|
|
45
46
|
const services: Service[] = compact([
|
|
46
47
|
...this.services,
|
|
47
48
|
this.publisherService,
|
|
@@ -51,34 +52,20 @@ export abstract class Construct<
|
|
|
51
52
|
// Run each service's register method with the sniffer to track env var access
|
|
52
53
|
for (const service of services) {
|
|
53
54
|
try {
|
|
54
|
-
const
|
|
55
|
+
const result = service.register(sniffer as any);
|
|
55
56
|
|
|
56
57
|
// Await if it's a Promise (async services)
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
? await Promise.resolve(config)
|
|
60
|
-
: config;
|
|
61
|
-
|
|
62
|
-
// If register returns a ConfigParser, collect its env vars
|
|
63
|
-
if (
|
|
64
|
-
resolvedConfig &&
|
|
65
|
-
typeof resolvedConfig === 'object' &&
|
|
66
|
-
'getEnvironmentVariables' in resolvedConfig &&
|
|
67
|
-
typeof resolvedConfig.getEnvironmentVariables === 'function'
|
|
68
|
-
) {
|
|
69
|
-
const vars = resolvedConfig.getEnvironmentVariables();
|
|
70
|
-
if (Array.isArray(vars)) {
|
|
71
|
-
vars.forEach((v: string) => envVars.add(v));
|
|
72
|
-
}
|
|
58
|
+
if (result && typeof result === 'object' && 'then' in result) {
|
|
59
|
+
await Promise.resolve(result);
|
|
73
60
|
}
|
|
74
|
-
} catch
|
|
75
|
-
// Service registration
|
|
76
|
-
// But env vars were already tracked during .create(), so we continue
|
|
61
|
+
} catch {
|
|
62
|
+
// Service registration may fail but env vars are still tracked
|
|
77
63
|
continue;
|
|
78
64
|
}
|
|
79
65
|
}
|
|
80
66
|
|
|
81
|
-
|
|
67
|
+
// Get tracked env vars directly from the sniffer
|
|
68
|
+
return sniffer.getEnvironmentVariables();
|
|
82
69
|
} catch (error) {
|
|
83
70
|
console.error(
|
|
84
71
|
'Error determining environment variables for construct:',
|
package/src/crons/Cron.ts
CHANGED
|
@@ -42,6 +42,7 @@ export class Cron<
|
|
|
42
42
|
logger?: TLogger,
|
|
43
43
|
publisherService?: Service<TEventPublisherServiceName, TEventPublisher>,
|
|
44
44
|
events: any[] = [],
|
|
45
|
+
memorySize?: number,
|
|
45
46
|
) {
|
|
46
47
|
super(
|
|
47
48
|
fn,
|
|
@@ -53,6 +54,7 @@ export class Cron<
|
|
|
53
54
|
logger,
|
|
54
55
|
publisherService,
|
|
55
56
|
events,
|
|
57
|
+
memorySize,
|
|
56
58
|
);
|
|
57
59
|
}
|
|
58
60
|
|
package/src/crons/CronBuilder.ts
CHANGED
|
@@ -28,10 +28,16 @@ export class CronBuilder<
|
|
|
28
28
|
TEventPublisherServiceName
|
|
29
29
|
> {
|
|
30
30
|
private _schedule?: ScheduleExpression;
|
|
31
|
+
|
|
31
32
|
constructor() {
|
|
32
33
|
super(ConstructType.Cron);
|
|
33
34
|
}
|
|
34
35
|
|
|
36
|
+
memorySize(memorySize: number): this {
|
|
37
|
+
this._memorySize = memorySize;
|
|
38
|
+
return this;
|
|
39
|
+
}
|
|
40
|
+
|
|
35
41
|
schedule(
|
|
36
42
|
_expression: ScheduleExpression,
|
|
37
43
|
): CronBuilder<
|
|
@@ -175,6 +181,7 @@ export class CronBuilder<
|
|
|
175
181
|
this._logger,
|
|
176
182
|
this._publisher,
|
|
177
183
|
this._events,
|
|
184
|
+
this._memorySize,
|
|
178
185
|
);
|
|
179
186
|
|
|
180
187
|
// Reset builder state after creating the cron to prevent pollution
|
|
@@ -186,6 +193,7 @@ export class CronBuilder<
|
|
|
186
193
|
this.inputSchema = undefined;
|
|
187
194
|
this.outputSchema = undefined;
|
|
188
195
|
this._timeout = undefined;
|
|
196
|
+
this._memorySize = undefined;
|
|
189
197
|
|
|
190
198
|
return cron;
|
|
191
199
|
}
|
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { ConsoleLogger } from '@geekmidas/logger/console';
|
|
3
|
+
import { CronBuilder } from '../CronBuilder';
|
|
4
|
+
import type { Service } from '@geekmidas/services';
|
|
5
|
+
|
|
6
|
+
const ServiceA = {
|
|
7
|
+
serviceName: 'a' as const,
|
|
8
|
+
async register() {
|
|
9
|
+
return { test: () => 'a' };
|
|
10
|
+
},
|
|
11
|
+
} satisfies Service<'a', any>;
|
|
12
|
+
|
|
13
|
+
const ServiceB = {
|
|
14
|
+
serviceName: 'b' as const,
|
|
15
|
+
async register() {
|
|
16
|
+
return { test: () => 'b' };
|
|
17
|
+
},
|
|
18
|
+
} satisfies Service<'b', any>;
|
|
19
|
+
|
|
20
|
+
describe('CronBuilder - State Isolation', () => {
|
|
21
|
+
describe('singleton instance state reset', () => {
|
|
22
|
+
it('should reset services after handle() is called', () => {
|
|
23
|
+
const c = new CronBuilder();
|
|
24
|
+
|
|
25
|
+
// First cron with ServiceA and ServiceB
|
|
26
|
+
const cron1 = c
|
|
27
|
+
.schedule('rate(5 minutes)')
|
|
28
|
+
.services([ServiceA, ServiceB])
|
|
29
|
+
.handle(async () => ({}));
|
|
30
|
+
|
|
31
|
+
// Second cron should not have any services from first
|
|
32
|
+
const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
|
|
33
|
+
|
|
34
|
+
expect(cron1.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
|
|
35
|
+
expect(cron2.services.map((s) => s.serviceName)).toEqual([]);
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it('should reset logger after handle() is called', () => {
|
|
39
|
+
const c = new CronBuilder();
|
|
40
|
+
const customLogger = new ConsoleLogger({ app: 'custom' });
|
|
41
|
+
|
|
42
|
+
// First cron with custom logger
|
|
43
|
+
const cron1 = c
|
|
44
|
+
.schedule('rate(5 minutes)')
|
|
45
|
+
.logger(customLogger)
|
|
46
|
+
.handle(async () => ({}));
|
|
47
|
+
|
|
48
|
+
// Second cron should have default logger (not the custom one)
|
|
49
|
+
const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
|
|
50
|
+
|
|
51
|
+
expect(cron1.logger).toBe(customLogger);
|
|
52
|
+
expect(cron2.logger).not.toBe(customLogger);
|
|
53
|
+
expect(cron2.logger).toBeInstanceOf(ConsoleLogger);
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
it('should reset schedule after handle() is called', () => {
|
|
57
|
+
const c = new CronBuilder();
|
|
58
|
+
|
|
59
|
+
// First cron with schedule
|
|
60
|
+
const cron1 = c.schedule('rate(5 minutes)').handle(async () => ({}));
|
|
61
|
+
|
|
62
|
+
// Second cron should not have schedule from first
|
|
63
|
+
const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
|
|
64
|
+
|
|
65
|
+
expect(cron1.schedule).toBe('rate(5 minutes)');
|
|
66
|
+
expect(cron2.schedule).toBe('rate(10 minutes)');
|
|
67
|
+
|
|
68
|
+
// Check internal state is reset
|
|
69
|
+
expect((c as any)._schedule).toBeUndefined();
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
it('should reset events after handle() is called', () => {
|
|
73
|
+
const c = new CronBuilder();
|
|
74
|
+
|
|
75
|
+
// Create first cron (events array should be empty initially)
|
|
76
|
+
const cron1 = c.schedule('rate(5 minutes)').handle(async () => ({}));
|
|
77
|
+
|
|
78
|
+
// Verify state was reset
|
|
79
|
+
expect((c as any)._events).toEqual([]);
|
|
80
|
+
expect((c as any)._services).toEqual([]);
|
|
81
|
+
expect((c as any)._schedule).toBeUndefined();
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
it('should reset input/output schemas after handle() is called', () => {
|
|
85
|
+
const c = new CronBuilder();
|
|
86
|
+
const inputSchema: any = { '~standard': { validate: () => ({}) } };
|
|
87
|
+
const outputSchema: any = { '~standard': { validate: () => ({}) } };
|
|
88
|
+
|
|
89
|
+
// First cron with schemas
|
|
90
|
+
const cron1 = c
|
|
91
|
+
.schedule('rate(5 minutes)')
|
|
92
|
+
.input(inputSchema)
|
|
93
|
+
.output(outputSchema)
|
|
94
|
+
.handle(async () => ({}));
|
|
95
|
+
|
|
96
|
+
// Second cron should not have schemas
|
|
97
|
+
const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
|
|
98
|
+
|
|
99
|
+
expect(cron1.input).toBe(inputSchema);
|
|
100
|
+
expect(cron1.outputSchema).toBe(outputSchema);
|
|
101
|
+
expect(cron2.input).toBeUndefined();
|
|
102
|
+
expect(cron2.outputSchema).toBeUndefined();
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it('should reset timeout after handle() is called', () => {
|
|
106
|
+
const c = new CronBuilder();
|
|
107
|
+
|
|
108
|
+
// First cron with custom timeout
|
|
109
|
+
const cron1 = c
|
|
110
|
+
.schedule('rate(5 minutes)')
|
|
111
|
+
.timeout(5000)
|
|
112
|
+
.handle(async () => ({}));
|
|
113
|
+
|
|
114
|
+
// Second cron should have default timeout (30000)
|
|
115
|
+
const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
|
|
116
|
+
|
|
117
|
+
expect(cron1.timeout).toBe(5000);
|
|
118
|
+
expect(cron2.timeout).toBe(30000); // Default timeout
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
describe('method chaining before handle()', () => {
|
|
123
|
+
it('should accumulate services when chaining', () => {
|
|
124
|
+
const c = new CronBuilder();
|
|
125
|
+
|
|
126
|
+
const cron = c
|
|
127
|
+
.schedule('rate(5 minutes)')
|
|
128
|
+
.services([ServiceA])
|
|
129
|
+
.services([ServiceB])
|
|
130
|
+
.handle(async () => ({}));
|
|
131
|
+
|
|
132
|
+
expect(cron.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
it('should not share references between different builder chains', () => {
|
|
136
|
+
const c = new CronBuilder();
|
|
137
|
+
|
|
138
|
+
// Start two separate chains
|
|
139
|
+
const builder1 = c.schedule('rate(5 minutes)').services([ServiceA]);
|
|
140
|
+
const builder2 = c.schedule('rate(10 minutes)').services([ServiceB]);
|
|
141
|
+
|
|
142
|
+
// They should be the same instance (singleton)
|
|
143
|
+
expect(builder1).toBe(builder2);
|
|
144
|
+
expect(builder1).toBe(c);
|
|
145
|
+
|
|
146
|
+
// But after handle, state is reset
|
|
147
|
+
const cron1 = builder1.handle(async () => ({}));
|
|
148
|
+
|
|
149
|
+
// Now builder2 should have reset state
|
|
150
|
+
expect((builder2 as any)._services).toEqual([]);
|
|
151
|
+
|
|
152
|
+
// Add services again
|
|
153
|
+
const cron2 = builder2
|
|
154
|
+
.schedule('rate(15 minutes)')
|
|
155
|
+
.services([ServiceB])
|
|
156
|
+
.handle(async () => ({}));
|
|
157
|
+
|
|
158
|
+
expect(cron1.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
|
|
159
|
+
expect(cron2.services.map((s) => s.serviceName)).toEqual(['b']);
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
describe('sequential cron creation', () => {
|
|
164
|
+
it('should create independent crons sequentially', () => {
|
|
165
|
+
const c = new CronBuilder();
|
|
166
|
+
|
|
167
|
+
const cron1 = c
|
|
168
|
+
.schedule('rate(5 minutes)')
|
|
169
|
+
.services([ServiceA, ServiceB])
|
|
170
|
+
.handle(async () => ({ result: 1 }));
|
|
171
|
+
|
|
172
|
+
const cron2 = c
|
|
173
|
+
.schedule('rate(10 minutes)')
|
|
174
|
+
.services([ServiceA])
|
|
175
|
+
.handle(async () => ({ result: 2 }));
|
|
176
|
+
|
|
177
|
+
const cron3 = c
|
|
178
|
+
.schedule('rate(15 minutes)')
|
|
179
|
+
.handle(async () => ({ result: 3 }));
|
|
180
|
+
|
|
181
|
+
expect(cron1.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
|
|
182
|
+
expect(cron1.schedule).toBe('rate(5 minutes)');
|
|
183
|
+
|
|
184
|
+
expect(cron2.services.map((s) => s.serviceName)).toEqual(['a']);
|
|
185
|
+
expect(cron2.schedule).toBe('rate(10 minutes)');
|
|
186
|
+
|
|
187
|
+
expect(cron3.services.map((s) => s.serviceName)).toEqual([]);
|
|
188
|
+
expect(cron3.schedule).toBe('rate(15 minutes)');
|
|
189
|
+
});
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
describe('publisher isolation', () => {
|
|
193
|
+
it('should reset publisher after handle() is called', () => {
|
|
194
|
+
const c = new CronBuilder();
|
|
195
|
+
const mockPublisher: any = {
|
|
196
|
+
serviceName: 'publisher',
|
|
197
|
+
async register() {
|
|
198
|
+
return { publish: () => {} };
|
|
199
|
+
},
|
|
200
|
+
};
|
|
201
|
+
|
|
202
|
+
const cron1 = c
|
|
203
|
+
.schedule('rate(5 minutes)')
|
|
204
|
+
.publisher(mockPublisher)
|
|
205
|
+
.handle(async () => ({}));
|
|
206
|
+
|
|
207
|
+
const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
|
|
208
|
+
|
|
209
|
+
expect((cron1 as any).publisherService).toBe(mockPublisher);
|
|
210
|
+
expect((cron2 as any).publisherService).toBeUndefined();
|
|
211
|
+
});
|
|
212
|
+
});
|
|
213
|
+
|
|
214
|
+
describe('cron expression types', () => {
|
|
215
|
+
it('should handle different schedule expression formats', () => {
|
|
216
|
+
const c = new CronBuilder();
|
|
217
|
+
|
|
218
|
+
const cron1 = c.schedule('rate(5 minutes)').handle(async () => ({}));
|
|
219
|
+
const cron2 = c.schedule('cron(0 12 * * ? *)').handle(async () => ({}));
|
|
220
|
+
const cron3 = c.schedule('rate(1 hour)').handle(async () => ({}));
|
|
221
|
+
|
|
222
|
+
expect(cron1.schedule).toBe('rate(5 minutes)');
|
|
223
|
+
expect(cron2.schedule).toBe('cron(0 12 * * ? *)');
|
|
224
|
+
expect(cron3.schedule).toBe('rate(1 hour)');
|
|
225
|
+
});
|
|
226
|
+
});
|
|
227
|
+
});
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Represents an authorizer configuration for endpoints
|
|
3
|
+
*/
|
|
4
|
+
export interface Authorizer {
|
|
5
|
+
/**
|
|
6
|
+
* Unique identifier for the authorizer
|
|
7
|
+
*/
|
|
8
|
+
name: string;
|
|
9
|
+
/**
|
|
10
|
+
* Type of authorizer (e.g., 'iam', 'jwt', 'custom')
|
|
11
|
+
*/
|
|
12
|
+
type?: string;
|
|
13
|
+
/**
|
|
14
|
+
* Description of what this authorizer does
|
|
15
|
+
*/
|
|
16
|
+
description?: string;
|
|
17
|
+
/**
|
|
18
|
+
* Additional metadata specific to the authorizer type
|
|
19
|
+
*/
|
|
20
|
+
metadata?: Record<string, any>;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Helper to create an authorizer configuration
|
|
25
|
+
*/
|
|
26
|
+
export function createAuthorizer(
|
|
27
|
+
name: string,
|
|
28
|
+
options?: Omit<Authorizer, 'name'>,
|
|
29
|
+
): Authorizer {
|
|
30
|
+
return {
|
|
31
|
+
name,
|
|
32
|
+
...options,
|
|
33
|
+
};
|
|
34
|
+
}
|