@geekmidas/constructs 0.2.4 → 0.3.1
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-gpqm7UBb.d.cts → AWSLambdaFunction-BdebRMUh.d.mts} +7 -5
- package/dist/AWSLambdaFunction-BdebRMUh.d.mts.map +1 -0
- package/dist/{AWSLambdaFunction-H65WfXLt.mjs → AWSLambdaFunction-C54a1doJ.mjs} +3 -3
- package/dist/AWSLambdaFunction-C54a1doJ.mjs.map +1 -0
- package/dist/{AWSLambdaFunction-D9RZhm0N.d.mts → AWSLambdaFunction-D0tEOTXQ.d.cts} +7 -5
- package/dist/AWSLambdaFunction-D0tEOTXQ.d.cts.map +1 -0
- package/dist/{AWSLambdaFunction-C-fuCLA3.cjs → AWSLambdaFunction-EPGY4s7i.cjs} +3 -3
- package/dist/AWSLambdaFunction-EPGY4s7i.cjs.map +1 -0
- package/dist/{AWSLambdaSubscriberAdaptor-CyFh7MN8.mjs → AWSLambdaSubscriberAdaptor-BLfO612H.mjs} +5 -3
- package/dist/{AWSLambdaSubscriberAdaptor-CyFh7MN8.mjs.map → AWSLambdaSubscriberAdaptor-BLfO612H.mjs.map} +1 -1
- package/dist/{AWSLambdaSubscriberAdaptor-Dum5bkw3.cjs → AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs} +5 -3
- package/dist/{AWSLambdaSubscriberAdaptor-Dum5bkw3.cjs.map → AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs.map} +1 -1
- package/dist/{AWSLambdaSubscriberAdaptor-C0aZBU64.d.mts → AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts} +4 -2
- package/dist/AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts.map +1 -0
- package/dist/{AWSLambdaSubscriberAdaptor-DT8icDRf.d.cts → AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts} +4 -2
- package/dist/AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts.map +1 -0
- package/dist/{AmazonApiGatewayEndpointAdaptor-pEWzF2uY.mjs → AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs} +2 -2
- package/dist/{AmazonApiGatewayEndpointAdaptor-pEWzF2uY.mjs.map → AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs.map} +1 -1
- package/dist/{AmazonApiGatewayEndpointAdaptor-CbJqLU6I.d.cts → AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts} +5 -3
- package/dist/AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts.map +1 -0
- package/dist/{AmazonApiGatewayEndpointAdaptor-Bk6ssx3K.cjs → AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs} +2 -2
- package/dist/{AmazonApiGatewayEndpointAdaptor-Bk6ssx3K.cjs.map → AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs.map} +1 -1
- package/dist/{AmazonApiGatewayEndpointAdaptor-DC3N7zY_.d.mts → AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts} +5 -3
- package/dist/AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts.map +1 -0
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-MJpRbIaQ.mjs → AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs} +3 -3
- package/dist/AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs.map +1 -0
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-uBp_4zLf.cjs → AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs} +3 -3
- package/dist/AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs.map +1 -0
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-BVxgQ-7J.d.mts → AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts} +8 -6
- package/dist/AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts.map +1 -0
- package/dist/{AmazonApiGatewayV1EndpointAdaptor-CVwJ5k16.d.cts → AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts} +8 -6
- package/dist/AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts.map +1 -0
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-I1W23Nvn.cjs → AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs} +3 -3
- package/dist/AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs.map +1 -0
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-1oBZdQH3.d.cts → AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts} +6 -4
- package/dist/AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts.map +1 -0
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-C3H8Hpv7.d.mts → AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts} +6 -4
- package/dist/AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts.map +1 -0
- package/dist/{AmazonApiGatewayV2EndpointAdaptor-ChO8BlDz.mjs → AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs} +3 -3
- package/dist/AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs.map +1 -0
- package/dist/{Authorizer-CpSUMTIs.d.cts → Authorizer-B-btowNd.d.cts} +2 -1
- package/dist/Authorizer-B-btowNd.d.cts.map +1 -0
- package/dist/{Authorizer-Cpx59w_q.d.mts → Authorizer-gWxYsGEp.d.mts} +2 -1
- package/dist/Authorizer-gWxYsGEp.d.mts.map +1 -0
- package/dist/{BaseFunctionBuilder-CoV7J45W.d.mts → BaseFunctionBuilder-BAtutR6q.d.cts} +5 -3
- package/dist/BaseFunctionBuilder-BAtutR6q.d.cts.map +1 -0
- package/dist/{BaseFunctionBuilder-B5gkW0Kt.mjs → BaseFunctionBuilder-Czi1Jwza.mjs} +2 -2
- package/dist/{BaseFunctionBuilder-B5gkW0Kt.mjs.map → BaseFunctionBuilder-Czi1Jwza.mjs.map} +1 -1
- package/dist/{BaseFunctionBuilder-DaQA0uKE.d.cts → BaseFunctionBuilder-DRY419e7.d.mts} +5 -3
- package/dist/BaseFunctionBuilder-DRY419e7.d.mts.map +1 -0
- package/dist/{BaseFunctionBuilder-C5Se7pdL.cjs → BaseFunctionBuilder-MYG3C9ug.cjs} +2 -2
- package/dist/{BaseFunctionBuilder-C5Se7pdL.cjs.map → BaseFunctionBuilder-MYG3C9ug.cjs.map} +1 -1
- package/dist/{Construct-BYSPikVm.cjs → Construct-Ba5cMxib.cjs} +2 -2
- package/dist/{Construct-BYSPikVm.cjs.map → Construct-Ba5cMxib.cjs.map} +1 -1
- package/dist/{Construct-Dkd8Kvc9.d.cts → Construct-C4rPE67v.d.cts} +8 -7
- package/dist/Construct-C4rPE67v.d.cts.map +1 -0
- package/dist/{Construct-LWeB1rSQ.mjs → Construct-DdyGHuag.mjs} +2 -2
- package/dist/{Construct-LWeB1rSQ.mjs.map → Construct-DdyGHuag.mjs.map} +1 -1
- package/dist/{Construct-jBKqb-Zi.d.mts → Construct-XrijZFFh.d.mts} +8 -7
- package/dist/Construct-XrijZFFh.d.mts.map +1 -0
- 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-Dy_HW2Vv.mjs → Cron-BxhGs5up.mjs} +3 -3
- package/dist/{Cron-Dy_HW2Vv.mjs.map → Cron-BxhGs5up.mjs.map} +1 -1
- package/dist/{Cron-Bi3QOge_.cjs → Cron-CGF4YAfM.cjs} +3 -3
- package/dist/{Cron-Bi3QOge_.cjs.map → Cron-CGF4YAfM.cjs.map} +1 -1
- package/dist/{Cron-7VPR2cNR.d.cts → Cron-bDLcTvV5.d.cts} +4 -4
- package/dist/Cron-bDLcTvV5.d.cts.map +1 -0
- package/dist/{Cron-JZkp_fHy.d.mts → Cron-cdjlSKNp.d.mts} +4 -4
- package/dist/Cron-cdjlSKNp.d.mts.map +1 -0
- package/dist/{CronBuilder-290th4zF.d.cts → CronBuilder-BC4m5-p1.d.mts} +7 -5
- package/dist/CronBuilder-BC4m5-p1.d.mts.map +1 -0
- package/dist/{CronBuilder-Dv_w7Yri.cjs → CronBuilder-CcxKRtVP.cjs} +4 -4
- package/dist/CronBuilder-CcxKRtVP.cjs.map +1 -0
- package/dist/{CronBuilder-BmFDO0Dm.d.mts → CronBuilder-DKVXyE0Q.d.cts} +7 -5
- package/dist/CronBuilder-DKVXyE0Q.d.cts.map +1 -0
- package/dist/{CronBuilder-Bl3A2Zp4.mjs → CronBuilder-d2jh-IB2.mjs} +4 -4
- package/dist/CronBuilder-d2jh-IB2.mjs.map +1 -0
- package/dist/{Endpoint-CC2RGjkl.d.cts → Endpoint-BPv9_-m_.d.cts} +6 -4
- package/dist/Endpoint-BPv9_-m_.d.cts.map +1 -0
- package/dist/{Endpoint-BJo9Hhwm.cjs → Endpoint-BVGZXFyV.cjs} +3 -3
- package/dist/{Endpoint-BJo9Hhwm.cjs.map → Endpoint-BVGZXFyV.cjs.map} +1 -1
- package/dist/{Endpoint-C5djXyae.d.mts → Endpoint-BdwG75G_.d.mts} +6 -4
- package/dist/Endpoint-BdwG75G_.d.mts.map +1 -0
- package/dist/{Endpoint-B70_KKhu.mjs → Endpoint-CuOEswxJ.mjs} +3 -3
- package/dist/{Endpoint-B70_KKhu.mjs.map → Endpoint-CuOEswxJ.mjs.map} +1 -1
- package/dist/{EndpointBuilder-CD8LkBda.d.mts → EndpointBuilder-B3az942t.d.mts} +7 -5
- package/dist/EndpointBuilder-B3az942t.d.mts.map +1 -0
- package/dist/{EndpointBuilder-DeswNQdG.cjs → EndpointBuilder-Cgj1P_ra.cjs} +4 -4
- package/dist/EndpointBuilder-Cgj1P_ra.cjs.map +1 -0
- package/dist/{EndpointBuilder-vXk6eIJk.d.cts → EndpointBuilder-DIy_m1bu.d.cts} +7 -5
- package/dist/EndpointBuilder-DIy_m1bu.d.cts.map +1 -0
- package/dist/{EndpointBuilder-FyyoFTJ5.mjs → EndpointBuilder-DnCB1h1j.mjs} +4 -4
- package/dist/EndpointBuilder-DnCB1h1j.mjs.map +1 -0
- package/dist/{EndpointFactory-jAkQxWRj.d.mts → EndpointFactory-C-0nE6Jg.d.mts} +6 -4
- package/dist/EndpointFactory-C-0nE6Jg.d.mts.map +1 -0
- package/dist/{EndpointFactory-eZc-XpNm.cjs → EndpointFactory-CYj6BYok.cjs} +2 -2
- package/dist/{EndpointFactory-eZc-XpNm.cjs.map → EndpointFactory-CYj6BYok.cjs.map} +1 -1
- package/dist/{EndpointFactory-CAneQs06.mjs → EndpointFactory-CbdxPCIH.mjs} +2 -2
- package/dist/{EndpointFactory-CAneQs06.mjs.map → EndpointFactory-CbdxPCIH.mjs.map} +1 -1
- package/dist/{EndpointFactory-D8I4NNCo.d.cts → EndpointFactory-CyPbm3AD.d.cts} +6 -4
- package/dist/EndpointFactory-CyPbm3AD.d.cts.map +1 -0
- package/dist/{Function-DfKsM5Kx.mjs → Function-BVHqIDp9.mjs} +2 -2
- package/dist/{Function-DfKsM5Kx.mjs.map → Function-BVHqIDp9.mjs.map} +1 -1
- package/dist/{Function-DHD1V9QW.d.cts → Function-Cf7f_kCz.d.cts} +5 -5
- package/dist/Function-Cf7f_kCz.d.cts.map +1 -0
- package/dist/{Function-DagDbeXo.cjs → Function-DDZb1525.cjs} +2 -2
- package/dist/{Function-DagDbeXo.cjs.map → Function-DDZb1525.cjs.map} +1 -1
- package/dist/{Function-Vh1t-Qjj.d.mts → Function-DN2G6OT5.d.mts} +5 -5
- package/dist/Function-DN2G6OT5.d.mts.map +1 -0
- package/dist/{FunctionBuilder-3jsoFffg.d.mts → FunctionBuilder-CJBzzXL3.d.cts} +7 -5
- package/dist/FunctionBuilder-CJBzzXL3.d.cts.map +1 -0
- package/dist/{FunctionBuilder-CVT7bG2o.mjs → FunctionBuilder-CrDYgfiI.mjs} +4 -4
- package/dist/FunctionBuilder-CrDYgfiI.mjs.map +1 -0
- package/dist/{FunctionBuilder-FV6r3I7X.d.cts → FunctionBuilder-Cxx8D2na.d.mts} +7 -5
- package/dist/FunctionBuilder-Cxx8D2na.d.mts.map +1 -0
- package/dist/{FunctionBuilder-DXvG_XD-.cjs → FunctionBuilder-DswJ-9sD.cjs} +4 -4
- package/dist/FunctionBuilder-DswJ-9sD.cjs.map +1 -0
- package/dist/{FunctionExecutionWrapper-DkNycmOh.cjs → FunctionExecutionWrapper-BYI2bGTL.cjs} +2 -2
- package/dist/{FunctionExecutionWrapper-DkNycmOh.cjs.map → FunctionExecutionWrapper-BYI2bGTL.cjs.map} +1 -1
- package/dist/{FunctionExecutionWrapper-Bubnr0zA.mjs → FunctionExecutionWrapper-CLDh7Z2_.mjs} +2 -2
- package/dist/{FunctionExecutionWrapper-Bubnr0zA.mjs.map → FunctionExecutionWrapper-CLDh7Z2_.mjs.map} +1 -1
- package/dist/{FunctionExecutionWrapper-CI3CaoCo.d.mts → FunctionExecutionWrapper-DF260Aaj.d.mts} +4 -2
- package/dist/FunctionExecutionWrapper-DF260Aaj.d.mts.map +1 -0
- package/dist/{FunctionExecutionWrapper-DYt3C8b9.d.cts → FunctionExecutionWrapper-Qy8bmgFR.d.cts} +4 -2
- package/dist/FunctionExecutionWrapper-Qy8bmgFR.d.cts.map +1 -0
- package/dist/{HonoEndpointAdaptor-BusUWu1w.d.cts → HonoEndpointAdaptor-Bqm6SEuP.d.cts} +8 -6
- package/dist/HonoEndpointAdaptor-Bqm6SEuP.d.cts.map +1 -0
- package/dist/{HonoEndpointAdaptor-DodwLM0-.cjs → HonoEndpointAdaptor-CQe2FqMR.cjs} +5 -6
- package/dist/{HonoEndpointAdaptor-DodwLM0-.cjs.map → HonoEndpointAdaptor-CQe2FqMR.cjs.map} +1 -1
- package/dist/{HonoEndpointAdaptor-g8xxh3tS.d.mts → HonoEndpointAdaptor-CRe-ij5f.d.mts} +8 -6
- package/dist/HonoEndpointAdaptor-CRe-ij5f.d.mts.map +1 -0
- package/dist/{HonoEndpointAdaptor-CcvXzoYV.mjs → HonoEndpointAdaptor-Ce-2HBxn.mjs} +5 -6
- package/dist/{HonoEndpointAdaptor-CcvXzoYV.mjs.map → HonoEndpointAdaptor-Ce-2HBxn.mjs.map} +1 -1
- package/dist/{Subscriber-DOt3svUC.cjs → Subscriber-BiHjVXtM.cjs} +2 -2
- package/dist/Subscriber-BiHjVXtM.cjs.map +1 -0
- package/dist/{Subscriber-kCHbH2fZ.mjs → Subscriber-BmPf9GFb.mjs} +2 -2
- package/dist/Subscriber-BmPf9GFb.mjs.map +1 -0
- package/dist/{Subscriber-DMSzvO_J.d.cts → Subscriber-COYMSevD.d.cts} +6 -6
- package/dist/Subscriber-COYMSevD.d.cts.map +1 -0
- package/dist/{Subscriber-aNr1qkxR.d.mts → Subscriber-ikctpU3I.d.mts} +6 -6
- package/dist/Subscriber-ikctpU3I.d.mts.map +1 -0
- package/dist/{SubscriberBuilder-Cj2u9k5Q.cjs → SubscriberBuilder-Cp1C-xtT.cjs} +2 -2
- package/dist/{SubscriberBuilder-Cj2u9k5Q.cjs.map → SubscriberBuilder-Cp1C-xtT.cjs.map} +1 -1
- package/dist/{SubscriberBuilder-DmxMU89X.mjs → SubscriberBuilder-DJPEeYDJ.mjs} +2 -2
- package/dist/{SubscriberBuilder-DmxMU89X.mjs.map → SubscriberBuilder-DJPEeYDJ.mjs.map} +1 -1
- package/dist/{SubscriberBuilder-BxJM3Hz_.d.cts → SubscriberBuilder-D_9zzllj.d.mts} +5 -3
- package/dist/SubscriberBuilder-D_9zzllj.d.mts.map +1 -0
- package/dist/{SubscriberBuilder-CWS4tdbp.d.mts → SubscriberBuilder-ivHAGIVi.d.cts} +5 -3
- package/dist/SubscriberBuilder-ivHAGIVi.d.cts.map +1 -0
- package/dist/{TestEndpointAdaptor-1pPixE6y.mjs → TestEndpointAdaptor-BXTofAKc.mjs} +17 -2
- package/dist/TestEndpointAdaptor-BXTofAKc.mjs.map +1 -0
- package/dist/{TestEndpointAdaptor-5-unBV8O.d.mts → TestEndpointAdaptor-C10xBI--.d.cts} +4 -4
- package/dist/TestEndpointAdaptor-C10xBI--.d.cts.map +1 -0
- package/dist/{TestEndpointAdaptor-wA-fmq4v.cjs → TestEndpointAdaptor-D9IwhIYg.cjs} +17 -2
- package/dist/TestEndpointAdaptor-D9IwhIYg.cjs.map +1 -0
- package/dist/{TestEndpointAdaptor-Bm0UjDtV.d.cts → TestEndpointAdaptor-DB7bREhS.d.mts} +4 -4
- package/dist/TestEndpointAdaptor-DB7bREhS.d.mts.map +1 -0
- package/dist/adaptors/aws.cjs +13 -13
- package/dist/adaptors/aws.d.cts +15 -15
- package/dist/adaptors/aws.d.mts +15 -15
- package/dist/adaptors/aws.mjs +13 -13
- package/dist/adaptors/hono.cjs +9 -9
- package/dist/adaptors/hono.d.cts +9 -9
- package/dist/adaptors/hono.d.mts +9 -9
- package/dist/adaptors/hono.mjs +9 -9
- package/dist/adaptors/testing.cjs +7 -7
- package/dist/adaptors/testing.d.cts +9 -9
- package/dist/adaptors/testing.d.mts +9 -9
- 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 +9 -7
- package/dist/crons/index.d.cts.map +1 -0
- package/dist/crons/index.d.mts +13 -11
- package/dist/crons/index.d.mts.map +1 -0
- package/dist/crons/index.mjs +7 -7
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +7 -7
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +9 -9
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +9 -9
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +7 -7
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +9 -9
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +10 -10
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +10 -10
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +9 -9
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +9 -9
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +10 -10
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +10 -10
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +9 -9
- package/dist/endpoints/Authorizer.d.cts +1 -1
- package/dist/endpoints/Authorizer.d.mts +1 -1
- package/dist/endpoints/Endpoint.cjs +6 -6
- package/dist/endpoints/Endpoint.d.cts +8 -8
- package/dist/endpoints/Endpoint.d.mts +8 -8
- package/dist/endpoints/Endpoint.mjs +6 -6
- package/dist/endpoints/EndpointBuilder.cjs +7 -7
- package/dist/endpoints/EndpointBuilder.d.cts +9 -9
- package/dist/endpoints/EndpointBuilder.d.mts +9 -9
- package/dist/endpoints/EndpointBuilder.mjs +7 -7
- package/dist/endpoints/EndpointFactory.cjs +8 -8
- package/dist/endpoints/EndpointFactory.d.cts +10 -10
- package/dist/endpoints/EndpointFactory.d.mts +10 -10
- package/dist/endpoints/EndpointFactory.mjs +8 -8
- package/dist/endpoints/HonoEndpointAdaptor.cjs +9 -9
- package/dist/endpoints/HonoEndpointAdaptor.d.cts +9 -9
- package/dist/endpoints/HonoEndpointAdaptor.d.mts +9 -9
- package/dist/endpoints/HonoEndpointAdaptor.mjs +9 -9
- package/dist/endpoints/TestEndpointAdaptor.cjs +7 -7
- package/dist/endpoints/TestEndpointAdaptor.d.cts +9 -9
- package/dist/endpoints/TestEndpointAdaptor.d.mts +9 -9
- package/dist/endpoints/TestEndpointAdaptor.mjs +7 -7
- package/dist/endpoints/audit.d.cts +8 -8
- package/dist/endpoints/audit.d.mts +8 -8
- package/dist/endpoints/helpers.cjs +7 -7
- package/dist/endpoints/helpers.d.cts +9 -8
- package/dist/endpoints/helpers.d.cts.map +1 -0
- package/dist/endpoints/helpers.d.mts +9 -8
- package/dist/endpoints/helpers.d.mts.map +1 -0
- package/dist/endpoints/helpers.mjs +7 -7
- package/dist/endpoints/index.cjs +8 -8
- package/dist/endpoints/index.d.cts +14 -12
- package/dist/endpoints/index.d.cts.map +1 -0
- package/dist/endpoints/index.d.mts +14 -12
- package/dist/endpoints/index.d.mts.map +1 -0
- package/dist/endpoints/index.mjs +8 -8
- package/dist/endpoints/parseHonoQuery.cjs +1 -1
- package/dist/endpoints/parseHonoQuery.d.cts +2 -0
- package/dist/endpoints/parseHonoQuery.d.cts.map +1 -0
- package/dist/endpoints/parseHonoQuery.d.mts +2 -0
- package/dist/endpoints/parseHonoQuery.d.mts.map +1 -0
- package/dist/endpoints/parseHonoQuery.mjs +1 -1
- package/dist/endpoints/parseQueryParams.cjs +1 -1
- package/dist/endpoints/parseQueryParams.d.cts +1 -0
- package/dist/endpoints/parseQueryParams.d.cts.map +1 -0
- package/dist/endpoints/parseQueryParams.d.mts +1 -0
- package/dist/endpoints/parseQueryParams.d.mts.map +1 -0
- package/dist/endpoints/parseQueryParams.mjs +1 -1
- package/dist/endpoints/processAudits.d.cts +10 -8
- package/dist/endpoints/processAudits.d.cts.map +1 -0
- package/dist/endpoints/processAudits.d.mts +10 -8
- package/dist/endpoints/processAudits.d.mts.map +1 -0
- package/dist/endpoints/rls.d.cts +8 -8
- package/dist/endpoints/rls.d.mts +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 +4 -4
- package/dist/functions/TestFunctionAdaptor.d.cts +4 -2
- package/dist/functions/TestFunctionAdaptor.d.cts.map +1 -0
- package/dist/functions/TestFunctionAdaptor.d.mts +4 -2
- package/dist/functions/TestFunctionAdaptor.d.mts.map +1 -0
- package/dist/functions/TestFunctionAdaptor.mjs +4 -4
- 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-C6EK1xL6.mjs +8 -0
- package/dist/{functions-JhRsNoAZ.mjs.map → functions-C6EK1xL6.mjs.map} +1 -1
- package/dist/{functions-FCb-wWFC.cjs → functions-fTid0RMK.cjs} +2 -2
- package/dist/{functions-FCb-wWFC.cjs.map → functions-fTid0RMK.cjs.map} +1 -1
- package/dist/{helpers-DxxSpLfw.cjs → helpers-BcP1tXAi.cjs} +2 -2
- package/dist/{helpers-DxxSpLfw.cjs.map → helpers-BcP1tXAi.cjs.map} +1 -1
- package/dist/{helpers-C3B2lVrM.mjs → helpers-ByRTDO_m.mjs} +2 -2
- package/dist/{helpers-C3B2lVrM.mjs.map → helpers-ByRTDO_m.mjs.map} +1 -1
- package/dist/{index-CFyaRrck.d.mts → index-BWzGIj06.d.mts} +4 -2
- package/dist/index-BWzGIj06.d.mts.map +1 -0
- package/dist/index-SI4V0XwK.d.cts +12 -0
- package/dist/index-SI4V0XwK.d.cts.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.cts +2 -2
- package/dist/index.d.mts +2 -2
- package/dist/index.mjs +1 -1
- package/dist/{parseHonoQuery-CT8Cvin-.cjs → parseHonoQuery-CZC5_97v.cjs} +3 -1
- package/dist/parseHonoQuery-CZC5_97v.cjs.map +1 -0
- package/dist/{parseHonoQuery-CwFKw2ua.mjs → parseHonoQuery-DDgIkTO4.mjs} +3 -1
- package/dist/parseHonoQuery-DDgIkTO4.mjs.map +1 -0
- package/dist/{parseQueryParams-CwvXXwkW.cjs → parseQueryParams-BSNkjmZ9.cjs} +3 -1
- package/dist/parseQueryParams-BSNkjmZ9.cjs.map +1 -0
- package/dist/{parseQueryParams-CHINupbZ.mjs → parseQueryParams-UMTRnRrW.mjs} +3 -1
- package/dist/parseQueryParams-UMTRnRrW.mjs.map +1 -0
- package/dist/publisher.d.cts +4 -2
- package/dist/publisher.d.cts.map +1 -0
- package/dist/publisher.d.mts +4 -2
- package/dist/publisher.d.mts.map +1 -0
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.cjs +1 -1
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +3 -3
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +3 -3
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.mjs +1 -1
- 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 +7 -5
- package/dist/subscribers/index.d.cts.map +1 -0
- package/dist/subscribers/index.d.mts +5 -3
- package/dist/subscribers/index.d.mts.map +1 -0
- package/dist/subscribers/index.mjs +3 -3
- package/dist/{types-Bp9ysFXd.d.cts → types-B5H3piDg.d.cts} +3 -1
- package/dist/types-B5H3piDg.d.cts.map +1 -0
- package/dist/{types-CScirkHt.d.mts → types-DdIlpxAd.d.mts} +3 -1
- package/dist/types-DdIlpxAd.d.mts.map +1 -0
- package/dist/types.d.cts +1 -1
- package/dist/types.d.mts +1 -1
- package/package.json +64 -13
- package/src/Construct.ts +3 -3
- package/src/__benchmarks__/endpoint.bench.ts +494 -0
- package/src/__benchmarks__/hono-server.bench.ts +249 -0
- package/src/crons/CronBuilder.ts +8 -8
- package/src/endpoints/AmazonApiGatewayV1EndpointAdaptor.ts +4 -4
- package/src/endpoints/AmazonApiGatewayV2EndpointAdaptor.ts +4 -4
- package/src/endpoints/EndpointBuilder.ts +4 -4
- package/src/endpoints/HonoEndpointAdaptor.ts +1 -2
- package/src/endpoints/TestEndpointAdaptor.ts +18 -0
- package/src/endpoints/parseHonoQuery.ts +2 -0
- package/src/endpoints/parseQueryParams.ts +2 -0
- package/src/functions/AWSLambdaFunction.ts +1 -1
- package/src/functions/FunctionBuilder.ts +5 -5
- package/src/subscribers/AWSLambdaSubscriberAdaptor.ts +8 -4
- package/src/subscribers/Subscriber.ts +5 -5
- package/tsconfig.json +9 -0
- package/dist/AWSLambdaFunction-C-fuCLA3.cjs.map +0 -1
- package/dist/AWSLambdaFunction-H65WfXLt.mjs.map +0 -1
- package/dist/AmazonApiGatewayV1EndpointAdaptor-MJpRbIaQ.mjs.map +0 -1
- package/dist/AmazonApiGatewayV1EndpointAdaptor-uBp_4zLf.cjs.map +0 -1
- package/dist/AmazonApiGatewayV2EndpointAdaptor-ChO8BlDz.mjs.map +0 -1
- package/dist/AmazonApiGatewayV2EndpointAdaptor-I1W23Nvn.cjs.map +0 -1
- package/dist/CronBuilder-Bl3A2Zp4.mjs.map +0 -1
- package/dist/CronBuilder-Dv_w7Yri.cjs.map +0 -1
- package/dist/EndpointBuilder-DeswNQdG.cjs.map +0 -1
- package/dist/EndpointBuilder-FyyoFTJ5.mjs.map +0 -1
- package/dist/FunctionBuilder-CVT7bG2o.mjs.map +0 -1
- package/dist/FunctionBuilder-DXvG_XD-.cjs.map +0 -1
- package/dist/Subscriber-DOt3svUC.cjs.map +0 -1
- package/dist/Subscriber-kCHbH2fZ.mjs.map +0 -1
- package/dist/TestEndpointAdaptor-1pPixE6y.mjs.map +0 -1
- package/dist/TestEndpointAdaptor-wA-fmq4v.cjs.map +0 -1
- package/dist/functions-JhRsNoAZ.mjs +0 -8
- package/dist/index-CqH4_Ieb.d.cts +0 -10
- package/dist/parseHonoQuery-CT8Cvin-.cjs.map +0 -1
- package/dist/parseHonoQuery-CwFKw2ua.mjs.map +0 -1
- package/dist/parseQueryParams-CHINupbZ.mjs.map +0 -1
- package/dist/parseQueryParams-CwvXXwkW.cjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HonoEndpointAdaptor-CcvXzoYV.mjs","names":["endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >","c: Context<any, string, {}>","data: unknown","schema?: T","serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>","app: Hono","serviceDiscovery: ServiceDiscovery<any, any>","logger","routes: string[]","envParser: EnvironmentParser<{}>","logger: TLogger","options?: HonoEndpointOptions","endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[]","db: TDatabase | undefined","metadata","output","result","validationError: any","e: any","docsPath: string","openApiOptions?: HonoEndpointOptions['openApiOptions']"],"sources":["../src/endpoints/HonoEndpointAdaptor.ts"],"sourcesContent":["import type { AuditStorage, AuditableAction } from '@geekmidas/audit';\nimport type { EnvironmentParser } from '@geekmidas/envkit';\nimport type { EventPublisher } from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport { checkRateLimit, getRateLimitHeaders } from '@geekmidas/rate-limit';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { type Context, Hono } from 'hono';\nimport { setCookie } from 'hono/cookie';\nimport { logger as honoLogger } from 'hono/logger';\nimport { timing } from 'hono/timing';\nimport { validator } from 'hono/validator';\nimport type { HttpMethod, LowerHttpMethod } from '../types';\nimport {\n Endpoint,\n type EndpointContext,\n type EndpointSchemas,\n ResponseBuilder,\n} from './Endpoint';\nimport { getEndpointsFromRoutes } from './helpers';\nimport { parseHonoQuery } from './parseHonoQuery';\n\nimport { withRlsContext } from '@geekmidas/db/rls';\nimport { wrapError } from '@geekmidas/errors';\nimport {\n type Service,\n ServiceDiscovery,\n type ServiceRecord,\n} from '@geekmidas/services';\nimport type { ContentfulStatusCode } from 'hono/utils/http-status';\nimport { publishConstructEvents } from '../publisher';\nimport type { MappedAudit } from './audit';\nimport {\n createAuditContext,\n executeWithAuditTransaction,\n} from './processAudits';\n\nexport interface HonoEndpointOptions {\n /**\n * Path where OpenAPI documentation will be served.\n * Set to false to disable docs route.\n * @default '/docs'\n */\n docsPath?: string | false;\n /**\n * OpenAPI schema options\n */\n openApiOptions?: {\n title?: string;\n version?: string;\n description?: string;\n };\n}\n\nexport class HonoEndpoint<\n TRoute extends string,\n TMethod extends HttpMethod,\n TInput extends EndpointSchemas = {},\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TSession = unknown,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n TAuditStorageServiceName extends string = string,\n TAuditAction extends AuditableAction<string, unknown> = AuditableAction<\n string,\n unknown\n >,\n TDatabase = undefined,\n TDatabaseServiceName extends string = string,\n> {\n constructor(\n private readonly endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >,\n ) {}\n\n static isDev = process.env.NODE_ENV === 'development';\n\n static async validate<T extends StandardSchemaV1>(\n c: Context<any, string, {}>,\n data: unknown,\n schema?: T,\n ) {\n if (!schema) {\n return undefined;\n }\n\n const parsed = await Endpoint.validate(schema, data);\n\n if (parsed.issues) {\n return c.json(parsed.issues, 422);\n }\n\n return parsed.value;\n }\n addRoute(\n serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,\n app: Hono,\n ): void {\n HonoEndpoint.addRoute(this.endpoint, serviceDiscovery, app);\n }\n\n static applyEventMiddleware(\n app: Hono,\n serviceDiscovery: ServiceDiscovery<any, any>,\n ) {\n app.use(async (c, next) => {\n await next();\n // @ts-ignore\n const endpoint = c.get('__endpoint') as Endpoint<\n any,\n any,\n any,\n any,\n any,\n any,\n any,\n any\n >;\n // @ts-ignore\n const response = c.get('__response');\n // @ts-ignore\n const logger = c.get('__logger') as Logger;\n\n if (Endpoint.isSuccessStatus(c.res.status) && endpoint) {\n // Process events (audits are handled in the handler with transaction support)\n await publishConstructEvents<any, any>(\n endpoint,\n response,\n serviceDiscovery,\n logger,\n );\n }\n });\n }\n\n static async fromRoutes<TLogger extends Logger, TServices extends Service[]>(\n routes: string[],\n envParser: EnvironmentParser<{}>,\n app = new Hono(),\n logger: TLogger,\n cwd = process.cwd(),\n options?: HonoEndpointOptions,\n ): Promise<Hono> {\n const endpoints = await getEndpointsFromRoutes<TServices>(routes, cwd);\n const serviceDiscovery = ServiceDiscovery.getInstance<\n ServiceRecord<TServices>,\n TLogger\n >(logger, envParser);\n\n HonoEndpoint.addRoutes(endpoints, serviceDiscovery, app, options);\n\n return app;\n }\n\n static addRoutes<\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n >(\n endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[],\n serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,\n app: Hono,\n options?: HonoEndpointOptions,\n ): void {\n // Add timing middleware (always enabled)\n app.use('*', timing());\n\n // Add logger middleware in development mode\n\n if (HonoEndpoint.isDev) {\n app.use('*', honoLogger());\n }\n\n // Add docs route if not disabled\n const docsPath =\n options?.docsPath !== false ? options?.docsPath || '/docs' : null;\n if (docsPath) {\n HonoEndpoint.addDocsRoute(\n endpoints,\n app,\n docsPath,\n options?.openApiOptions,\n );\n }\n\n // Sort endpoints to ensure static routes come before dynamic ones\n const sortedEndpoints = endpoints.sort((a, b) => {\n const aSegments = a.route.split('/');\n const bSegments = b.route.split('/');\n\n // Compare each segment\n for (let i = 0; i < Math.max(aSegments.length, bSegments.length); i++) {\n const aSegment = aSegments[i] || '';\n const bSegment = bSegments[i] || '';\n\n // If one is dynamic and the other is not, static comes first\n const aIsDynamic = aSegment.startsWith(':');\n const bIsDynamic = bSegment.startsWith(':');\n\n if (!aIsDynamic && bIsDynamic) return -1;\n if (aIsDynamic && !bIsDynamic) return 1;\n\n // If both are the same type, compare alphabetically\n if (aSegment !== bSegment) {\n return aSegment.localeCompare(bSegment);\n }\n }\n\n return 0;\n });\n HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);\n for (const endpoint of sortedEndpoints) {\n HonoEndpoint.addRoute(endpoint, serviceDiscovery, app);\n }\n }\n\n static addRoute<\n TRoute extends string,\n TMethod extends HttpMethod,\n TInput extends EndpointSchemas = {},\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TSession = unknown,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n TAuditStorageServiceName extends string = string,\n TAuditAction extends AuditableAction<string, unknown> = AuditableAction<\n string,\n unknown\n >,\n TDatabase = undefined,\n TDatabaseServiceName extends string = string,\n >(\n endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >,\n serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,\n app: Hono,\n ): void {\n const { route } = endpoint;\n const method = endpoint.method.toLowerCase() as LowerHttpMethod<TMethod>;\n\n app[method](\n route,\n validator('json', (value, c) =>\n HonoEndpoint.validate(c, value, endpoint.input?.body),\n ),\n validator('query', (_, c) => {\n const parsedQuery = parseHonoQuery(c);\n return HonoEndpoint.validate(c, parsedQuery, endpoint.input?.query);\n }),\n validator('param', (params, c) =>\n HonoEndpoint.validate(c, params, endpoint.input?.params),\n ),\n async (c) => {\n const logger = endpoint.logger.child({\n endpoint: endpoint.fullPath,\n route: endpoint.route,\n host: c.header('host'),\n method: endpoint.method,\n path: c.req.path,\n }) as TLogger;\n\n try {\n const headerValues = c.req.header();\n\n const header = Endpoint.createHeaders(headerValues);\n const cookie = Endpoint.createCookies(headerValues.cookie);\n\n const services = await serviceDiscovery.register(endpoint.services);\n\n // Resolve database service early so it's available for session extraction\n const rawDb = endpoint.databaseService\n ? await serviceDiscovery\n .register([endpoint.databaseService])\n .then(\n (s) =>\n s[endpoint.databaseService!.serviceName as keyof typeof s],\n )\n : undefined;\n\n const session = await endpoint.getSession({\n services,\n logger,\n header,\n cookie,\n ...(rawDb !== undefined && { db: rawDb }),\n } as any);\n\n const isAuthorized = await endpoint.authorize({\n header,\n cookie,\n services,\n logger,\n session,\n });\n\n if (!isAuthorized) {\n logger.warn('Unauthorized access attempt');\n return c.json({ error: 'Unauthorized' }, 401);\n }\n\n // Check rate limit if configured\n if (endpoint.rateLimit) {\n const rateLimitInfo = await checkRateLimit(endpoint.rateLimit, {\n header,\n services,\n logger,\n session,\n path: c.req.path,\n method: endpoint.method,\n });\n\n // Set rate limit headers\n const rateLimitHeaders = getRateLimitHeaders(\n rateLimitInfo,\n endpoint.rateLimit,\n );\n for (const [key, value] of Object.entries(rateLimitHeaders)) {\n if (value) {\n c.header(key, value);\n }\n }\n }\n\n // Create audit context if audit storage is configured\n const auditContext = await createAuditContext(\n endpoint,\n serviceDiscovery,\n logger,\n {\n session,\n header,\n cookie,\n services: services as Record<string, unknown>,\n },\n );\n\n // Warn if declarative audits are configured but no audit storage\n const audits = endpoint.audits as MappedAudit<\n TAuditAction,\n TOutSchema\n >[];\n if (!auditContext && audits?.length) {\n logger.warn('No auditor storage service available');\n }\n\n // Extract RLS context if configured and not bypassed\n const rlsActive =\n endpoint.rlsConfig && !endpoint.rlsBypass && rawDb !== undefined;\n const rlsContext = rlsActive\n ? await endpoint.rlsConfig!.extractor({\n services,\n session,\n header,\n cookie,\n logger,\n })\n : undefined;\n\n // Execute handler with automatic audit transaction support\n const result = await executeWithAuditTransaction(\n auditContext,\n async (auditor) => {\n // Use audit transaction as db only if the storage uses the same database service\n const sameDatabase =\n auditContext?.storage?.databaseServiceName &&\n auditContext.storage.databaseServiceName ===\n endpoint.databaseService?.serviceName;\n const baseDb = sameDatabase\n ? (auditor?.getTransaction?.() ?? rawDb)\n : rawDb;\n\n // Helper to execute handler with given db\n const executeHandler = async (db: TDatabase | undefined) => {\n const responseBuilder = new ResponseBuilder();\n const response = await endpoint.handler(\n {\n services,\n logger,\n body: c.req.valid('json'),\n query: c.req.valid('query'),\n params: c.req.valid('param'),\n session,\n header,\n cookie,\n auditor,\n db,\n } as unknown as EndpointContext<\n TInput,\n TServices,\n TLogger,\n TSession,\n TAuditAction,\n TDatabase,\n TAuditStorage\n >,\n responseBuilder,\n );\n\n // Check if response has metadata\n let data = response;\n let metadata = responseBuilder.getMetadata();\n\n if (Endpoint.hasMetadata(response)) {\n data = response.data;\n metadata = response.metadata;\n }\n\n const output = endpoint.outputSchema\n ? await endpoint.parseOutput(data)\n : undefined;\n\n return { output, metadata, responseBuilder };\n };\n\n // If RLS is active, wrap handler with RLS context\n if (rlsActive && rlsContext && baseDb) {\n return withRlsContext(\n baseDb as any,\n rlsContext,\n async (trx) => executeHandler(trx as TDatabase),\n { prefix: endpoint.rlsConfig!.prefix },\n );\n }\n\n return executeHandler(baseDb as TDatabase | undefined);\n },\n // Process declarative audits after handler (inside transaction)\n async (result, auditor) => {\n if (!audits?.length) return;\n\n for (const audit of audits) {\n if (audit.when && !audit.when(result.output as any)) {\n continue;\n }\n const payload = audit.payload(result.output as any);\n const entityId = audit.entityId?.(result.output as any);\n auditor.audit(audit.type as any, payload as any, {\n table: audit.table,\n entityId,\n });\n }\n },\n // Pass rawDb so storage can reuse existing transactions\n { db: rawDb },\n );\n\n const { output, metadata } = result;\n\n try {\n let status = endpoint.status as ContentfulStatusCode;\n\n // Apply response metadata\n if (metadata.status) {\n status = metadata.status as ContentfulStatusCode;\n }\n\n if (metadata.headers) {\n for (const [key, value] of Object.entries(metadata.headers)) {\n c.header(key, value);\n }\n }\n\n if (metadata.cookies) {\n for (const [name, { value, options }] of metadata.cookies) {\n setCookie(c, name, value, options);\n }\n }\n\n // @ts-ignore\n c.set('__response', output);\n // @ts-ignore\n c.set('__endpoint', endpoint);\n // @ts-ignore\n c.set('__logger', logger);\n // @ts-ignore\n c.set('__session', session);\n // @ts-ignore\n c.set('__services', services);\n\n if (HonoEndpoint.isDev) {\n logger.info({ status, body: output }, 'Outgoing response');\n }\n // @ts-ignore\n return c.json(output, status);\n } catch (validationError: any) {\n logger.error(validationError, 'Output validation failed');\n const error = wrapError(\n validationError,\n 422,\n 'Response validation failed',\n );\n if (HonoEndpoint.isDev) {\n logger.info(\n { status: error.statusCode, body: error },\n 'Outgoing response',\n );\n }\n return c.json(error, error.statusCode as ContentfulStatusCode);\n }\n } catch (e: any) {\n logger.error(e, 'Error processing endpoint request');\n const error = wrapError(e, 500, 'Internal Server Error');\n if (HonoEndpoint.isDev) {\n logger.info(\n { status: error.statusCode, body: error },\n 'Outgoing response',\n );\n }\n return c.json(error, error.statusCode as ContentfulStatusCode);\n }\n },\n );\n }\n\n static addDocsRoute<\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n >(\n endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[],\n app: Hono,\n docsPath: string,\n openApiOptions?: HonoEndpointOptions['openApiOptions'],\n ): void {\n app.get(docsPath, async (c) => {\n try {\n const openApiSchema = await Endpoint.buildOpenApiSchema(\n endpoints,\n openApiOptions,\n );\n\n return c.json(openApiSchema);\n } catch (error) {\n console.error('Error generating OpenAPI schema:', error);\n return c.json(\n { error: 'Failed to generate OpenAPI documentation' },\n 500,\n );\n }\n });\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"HonoEndpointAdaptor-Ce-2HBxn.mjs","names":["endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >","c: Context<any, string, {}>","data: unknown","schema?: T","serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>","app: Hono","serviceDiscovery: ServiceDiscovery<any, any>","logger","routes: string[]","envParser: EnvironmentParser<{}>","logger: TLogger","options?: HonoEndpointOptions","endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[]","db: TDatabase | undefined","metadata","output","result","validationError: any","e: any","docsPath: string","openApiOptions?: HonoEndpointOptions['openApiOptions']"],"sources":["../src/endpoints/HonoEndpointAdaptor.ts"],"sourcesContent":["import type { AuditStorage, AuditableAction } from '@geekmidas/audit';\nimport type { EnvironmentParser } from '@geekmidas/envkit';\nimport type { EventPublisher } from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport { checkRateLimit, getRateLimitHeaders } from '@geekmidas/rate-limit';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { type Context, Hono } from 'hono';\nimport { setCookie } from 'hono/cookie';\nimport { logger as honoLogger } from 'hono/logger';\nimport { timing } from 'hono/timing';\nimport { validator } from 'hono/validator';\nimport type { HttpMethod, LowerHttpMethod } from '../types';\nimport {\n Endpoint,\n type EndpointContext,\n type EndpointSchemas,\n ResponseBuilder,\n} from './Endpoint';\nimport { getEndpointsFromRoutes } from './helpers';\nimport { parseHonoQuery } from './parseHonoQuery';\n\nimport { withRlsContext } from '@geekmidas/db/rls';\nimport { wrapError } from '@geekmidas/errors';\nimport {\n type Service,\n ServiceDiscovery,\n type ServiceRecord,\n} from '@geekmidas/services';\nimport type { ContentfulStatusCode } from 'hono/utils/http-status';\nimport { publishConstructEvents } from '../publisher';\nimport type { MappedAudit } from './audit';\nimport {\n createAuditContext,\n executeWithAuditTransaction,\n} from './processAudits';\n\nexport interface HonoEndpointOptions {\n /**\n * Path where OpenAPI documentation will be served.\n * Set to false to disable docs route.\n * @default '/docs'\n */\n docsPath?: string | false;\n /**\n * OpenAPI schema options\n */\n openApiOptions?: {\n title?: string;\n version?: string;\n description?: string;\n };\n}\n\nexport class HonoEndpoint<\n TRoute extends string,\n TMethod extends HttpMethod,\n TInput extends EndpointSchemas = {},\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TSession = unknown,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n TAuditStorageServiceName extends string = string,\n TAuditAction extends AuditableAction<string, unknown> = AuditableAction<\n string,\n unknown\n >,\n TDatabase = undefined,\n TDatabaseServiceName extends string = string,\n> {\n constructor(\n private readonly endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >,\n ) {}\n\n static isDev = process.env.NODE_ENV === 'development';\n\n static async validate<T extends StandardSchemaV1>(\n c: Context<any, string, {}>,\n data: unknown,\n schema?: T,\n ) {\n if (!schema) {\n return undefined;\n }\n\n const parsed = await Endpoint.validate(schema, data);\n\n if (parsed.issues) {\n return c.json(parsed.issues, 422);\n }\n\n return parsed.value;\n }\n addRoute(\n serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,\n app: Hono,\n ): void {\n HonoEndpoint.addRoute(this.endpoint, serviceDiscovery, app);\n }\n\n static applyEventMiddleware(\n app: Hono,\n serviceDiscovery: ServiceDiscovery<any, any>,\n ) {\n app.use(async (c, next) => {\n await next();\n // @ts-ignore\n const endpoint = c.get('__endpoint') as Endpoint<\n any,\n any,\n any,\n any,\n any,\n any,\n any,\n any\n >;\n // @ts-ignore\n const response = c.get('__response');\n // @ts-ignore\n const logger = c.get('__logger') as Logger;\n\n if (Endpoint.isSuccessStatus(c.res.status) && endpoint) {\n // Process events (audits are handled in the handler with transaction support)\n await publishConstructEvents<any, any>(\n endpoint,\n response,\n serviceDiscovery,\n logger,\n );\n }\n });\n }\n\n static async fromRoutes<TLogger extends Logger, TServices extends Service[]>(\n routes: string[],\n envParser: EnvironmentParser<{}>,\n app = new Hono(),\n logger: TLogger,\n cwd = process.cwd(),\n options?: HonoEndpointOptions,\n ): Promise<Hono> {\n const endpoints = await getEndpointsFromRoutes<TServices>(routes, cwd);\n const serviceDiscovery = ServiceDiscovery.getInstance<\n ServiceRecord<TServices>,\n TLogger\n >(logger, envParser);\n\n HonoEndpoint.addRoutes(endpoints, serviceDiscovery, app, options);\n\n return app;\n }\n\n static addRoutes<\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n >(\n endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[],\n serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,\n app: Hono,\n options?: HonoEndpointOptions,\n ): void {\n // Add timing middleware (always enabled)\n app.use('*', timing());\n\n // Add logger middleware in development mode\n\n if (HonoEndpoint.isDev) {\n app.use('*', honoLogger());\n }\n\n // Add docs route if not disabled\n const docsPath =\n options?.docsPath !== false ? options?.docsPath || '/docs' : null;\n if (docsPath) {\n HonoEndpoint.addDocsRoute(\n endpoints,\n app,\n docsPath,\n options?.openApiOptions,\n );\n }\n\n // Sort endpoints to ensure static routes come before dynamic ones\n const sortedEndpoints = endpoints.sort((a, b) => {\n const aSegments = a.route.split('/');\n const bSegments = b.route.split('/');\n\n // Compare each segment\n for (let i = 0; i < Math.max(aSegments.length, bSegments.length); i++) {\n const aSegment = aSegments[i] || '';\n const bSegment = bSegments[i] || '';\n\n // If one is dynamic and the other is not, static comes first\n const aIsDynamic = aSegment.startsWith(':');\n const bIsDynamic = bSegment.startsWith(':');\n\n if (!aIsDynamic && bIsDynamic) return -1;\n if (aIsDynamic && !bIsDynamic) return 1;\n\n // If both are the same type, compare alphabetically\n if (aSegment !== bSegment) {\n return aSegment.localeCompare(bSegment);\n }\n }\n\n return 0;\n });\n HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);\n for (const endpoint of sortedEndpoints) {\n HonoEndpoint.addRoute(endpoint, serviceDiscovery, app);\n }\n }\n\n static addRoute<\n TRoute extends string,\n TMethod extends HttpMethod,\n TInput extends EndpointSchemas = {},\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TSession = unknown,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n TAuditStorageServiceName extends string = string,\n TAuditAction extends AuditableAction<string, unknown> = AuditableAction<\n string,\n unknown\n >,\n TDatabase = undefined,\n TDatabaseServiceName extends string = string,\n >(\n endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >,\n serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,\n app: Hono,\n ): void {\n const { route } = endpoint;\n const method = endpoint.method.toLowerCase() as LowerHttpMethod<TMethod>;\n\n app[method](\n route,\n validator('json', (value, c) =>\n HonoEndpoint.validate(c, value, endpoint.input?.body),\n ),\n validator('query', (_, c) => {\n const parsedQuery = parseHonoQuery(c);\n return HonoEndpoint.validate(c, parsedQuery, endpoint.input?.query);\n }),\n validator('param', (params, c) =>\n HonoEndpoint.validate(c, params, endpoint.input?.params),\n ),\n async (c) => {\n const logger = endpoint.logger.child({\n endpoint: endpoint.fullPath,\n route: endpoint.route,\n host: c.header('host'),\n method: endpoint.method,\n path: c.req.path,\n }) as TLogger;\n\n try {\n const headerValues = c.req.header();\n\n const header = Endpoint.createHeaders(headerValues);\n const cookie = Endpoint.createCookies(headerValues.cookie);\n\n const services = await serviceDiscovery.register(endpoint.services);\n\n // Resolve database service early so it's available for session extraction\n const rawDb = endpoint.databaseService\n ? await serviceDiscovery\n .register([endpoint.databaseService])\n .then(\n (s) =>\n s[endpoint.databaseService!.serviceName as keyof typeof s],\n )\n : undefined;\n\n const session = await endpoint.getSession({\n services,\n logger,\n header,\n cookie,\n ...(rawDb !== undefined && { db: rawDb }),\n } as any);\n\n const isAuthorized = await endpoint.authorize({\n header,\n cookie,\n services,\n logger,\n session,\n });\n\n if (!isAuthorized) {\n logger.warn('Unauthorized access attempt');\n return c.json({ error: 'Unauthorized' }, 401);\n }\n\n // Check rate limit if configured\n if (endpoint.rateLimit) {\n const rateLimitInfo = await checkRateLimit(endpoint.rateLimit, {\n header,\n services,\n logger,\n session,\n path: c.req.path,\n method: endpoint.method,\n });\n\n // Set rate limit headers\n const rateLimitHeaders = getRateLimitHeaders(\n rateLimitInfo,\n endpoint.rateLimit,\n );\n for (const [key, value] of Object.entries(rateLimitHeaders)) {\n if (value) {\n c.header(key, value);\n }\n }\n }\n\n // Create audit context if audit storage is configured\n const auditContext = await createAuditContext(\n endpoint,\n serviceDiscovery,\n logger,\n {\n session,\n header,\n cookie,\n services: services as Record<string, unknown>,\n },\n );\n\n // Warn if declarative audits are configured but no audit storage\n const audits = endpoint.audits as MappedAudit<\n TAuditAction,\n TOutSchema\n >[];\n if (!auditContext && audits?.length) {\n logger.warn('No auditor storage service available');\n }\n\n // Extract RLS context if configured and not bypassed\n const rlsActive =\n endpoint.rlsConfig && !endpoint.rlsBypass && rawDb !== undefined;\n const rlsContext = rlsActive\n ? await endpoint.rlsConfig!.extractor({\n services,\n session,\n header,\n cookie,\n logger,\n })\n : undefined;\n\n // Execute handler with automatic audit transaction support\n const result = await executeWithAuditTransaction(\n auditContext,\n async (auditor) => {\n // Use audit transaction as db only if the storage uses the same database service\n const sameDatabase =\n auditContext?.storage?.databaseServiceName &&\n auditContext.storage.databaseServiceName ===\n endpoint.databaseService?.serviceName;\n const baseDb = sameDatabase\n ? (auditor?.getTransaction?.() ?? rawDb)\n : rawDb;\n\n // Helper to execute handler with given db\n const executeHandler = async (db: TDatabase | undefined) => {\n const responseBuilder = new ResponseBuilder();\n const response = await endpoint.handler(\n {\n services,\n logger,\n body: c.req.valid('json'),\n query: c.req.valid('query'),\n params: c.req.valid('param'),\n session,\n header,\n cookie,\n auditor,\n db,\n } as unknown as EndpointContext<\n TInput,\n TServices,\n TLogger,\n TSession,\n TAuditAction,\n TDatabase,\n TAuditStorage\n >,\n responseBuilder,\n );\n\n // Check if response has metadata\n let data = response;\n let metadata = responseBuilder.getMetadata();\n\n if (Endpoint.hasMetadata(response)) {\n data = response.data;\n metadata = response.metadata;\n }\n\n const output = endpoint.outputSchema\n ? await endpoint.parseOutput(data)\n : undefined;\n\n return { output, metadata, responseBuilder };\n };\n\n // If RLS is active, wrap handler with RLS context\n if (rlsActive && rlsContext && baseDb) {\n return withRlsContext(\n baseDb as any,\n rlsContext,\n async (trx) => executeHandler(trx as TDatabase),\n { prefix: endpoint.rlsConfig!.prefix },\n );\n }\n\n return executeHandler(baseDb as TDatabase | undefined);\n },\n // Process declarative audits after handler (inside transaction)\n async (result, auditor) => {\n if (!audits?.length) return;\n\n for (const audit of audits) {\n if (audit.when && !audit.when(result.output as any)) {\n continue;\n }\n const payload = audit.payload(result.output as any);\n const entityId = audit.entityId?.(result.output as any);\n auditor.audit(audit.type as any, payload as any, {\n table: audit.table,\n entityId,\n });\n }\n },\n // Pass rawDb so storage can reuse existing transactions\n { db: rawDb },\n );\n\n const { output, metadata } = result;\n\n try {\n let status = endpoint.status as ContentfulStatusCode;\n\n // Apply response metadata\n if (metadata.status) {\n status = metadata.status as ContentfulStatusCode;\n }\n\n if (metadata.headers) {\n for (const [key, value] of Object.entries(metadata.headers)) {\n c.header(key, value);\n }\n }\n\n if (metadata.cookies) {\n for (const [name, { value, options }] of metadata.cookies) {\n setCookie(c, name, value, options);\n }\n }\n\n // @ts-ignore\n c.set('__response', output);\n // @ts-ignore\n c.set('__endpoint', endpoint);\n // @ts-ignore\n c.set('__logger', logger);\n // @ts-ignore\n c.set('__session', session);\n // @ts-ignore\n c.set('__services', services);\n\n if (HonoEndpoint.isDev) {\n logger.info({ status, body: output }, 'Outgoing response');\n }\n // @ts-ignore\n return c.json(output, status);\n } catch (validationError: any) {\n logger.error(validationError, 'Output validation failed');\n const error = wrapError(\n validationError,\n 422,\n 'Response validation failed',\n );\n if (HonoEndpoint.isDev) {\n logger.info(\n { status: error.statusCode, body: error },\n 'Outgoing response',\n );\n }\n return c.json(error, error.statusCode as ContentfulStatusCode);\n }\n } catch (e: any) {\n logger.error(e, 'Error processing endpoint request');\n const error = wrapError(e, 500, 'Internal Server Error');\n if (HonoEndpoint.isDev) {\n logger.info(\n { status: error.statusCode, body: error },\n 'Outgoing response',\n );\n }\n return c.json(error, error.statusCode as ContentfulStatusCode);\n }\n },\n );\n }\n\n static addDocsRoute<\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n >(\n endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[],\n app: Hono,\n docsPath: string,\n openApiOptions?: HonoEndpointOptions['openApiOptions'],\n ): void {\n app.get(docsPath, async (c) => {\n try {\n const openApiSchema = await Endpoint.buildOpenApiSchema(\n endpoints,\n openApiOptions,\n );\n\n return c.json(openApiSchema);\n } catch {\n return c.json(\n { error: 'Failed to generate OpenAPI documentation' },\n 500,\n );\n }\n });\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
const require_chunk = require('./chunk-CUT6urMc.cjs');
|
|
2
|
-
const require_Construct = require('./Construct-
|
|
2
|
+
const require_Construct = require('./Construct-Ba5cMxib.cjs');
|
|
3
3
|
const __geekmidas_logger_console = require_chunk.__toESM(require("@geekmidas/logger/console"));
|
|
4
4
|
|
|
5
5
|
//#region src/subscribers/Subscriber.ts
|
|
@@ -31,4 +31,4 @@ Object.defineProperty(exports, 'Subscriber', {
|
|
|
31
31
|
return Subscriber;
|
|
32
32
|
}
|
|
33
33
|
});
|
|
34
|
-
//# sourceMappingURL=Subscriber-
|
|
34
|
+
//# sourceMappingURL=Subscriber-BiHjVXtM.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Subscriber-BiHjVXtM.cjs","names":["ConsoleLogger","Construct","obj: any","ConstructType","handler: SubscriberHandler<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger,\n OutSchema\n >","timeout: number","_subscribedEvents?: TSubscribedEvents","outputSchema?: OutSchema","services: TServices","logger: TLogger","publisherService?: Service<\n TEventPublisherServiceName,\n TEventPublisher\n >"],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":["import type { Logger } from '@geekmidas/logger';\nimport { ConsoleLogger } from '@geekmidas/logger/console';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\n\nimport { Construct, ConstructType } from '../Construct';\n\nimport type {\n EventPublisher,\n ExtractPublisherMessage,\n} from '@geekmidas/events';\nimport type { InferStandardSchema } from '@geekmidas/schema';\nimport type { Service, ServiceRecord } from '@geekmidas/services';\n\nconst DEFAULT_LOGGER = new ConsoleLogger() as any;\n\n// Helper type to extract payload types for subscribed events\ntype ExtractEventPayloads<\n TPublisher extends EventPublisher<any> | undefined,\n TEventTypes extends any[],\n> = TPublisher extends EventPublisher<any>\n ? Extract<ExtractPublisherMessage<TPublisher>, { type: TEventTypes[number] }>\n : never;\n\nexport class Subscriber<\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n OutSchema extends StandardSchemaV1 | undefined = undefined,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TSubscribedEvents extends\n ExtractPublisherMessage<TEventPublisher>['type'][] = ExtractPublisherMessage<TEventPublisher>['type'][],\n> extends Construct<\n TLogger,\n TEventPublisherServiceName,\n TEventPublisher,\n OutSchema,\n TServices\n> {\n __IS_SUBSCRIBER__ = true;\n\n static isSubscriber(\n obj: any,\n ): obj is Subscriber<any, any, any, any, any, any> {\n return Boolean(\n obj &&\n obj.__IS_SUBSCRIBER__ === true &&\n obj.type === ConstructType.Subscriber,\n );\n }\n\n constructor(\n public readonly handler: SubscriberHandler<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger,\n OutSchema\n >,\n public override readonly timeout: number = 30000,\n protected _subscribedEvents?: TSubscribedEvents,\n public override readonly outputSchema?: OutSchema,\n public override readonly services: TServices = [] as unknown as TServices,\n public override readonly logger: TLogger = DEFAULT_LOGGER as TLogger,\n public override readonly publisherService?: Service<\n TEventPublisherServiceName,\n TEventPublisher\n >,\n ) {\n super(\n ConstructType.Subscriber,\n logger,\n services,\n [],\n publisherService,\n outputSchema,\n );\n }\n\n get subscribedEvents(): TSubscribedEvents | undefined {\n return this._subscribedEvents;\n }\n}\n\n// Handler type for subscribers that receives an array of events\nexport type SubscriberHandler<\n TEventPublisher extends EventPublisher<any> | undefined,\n TSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n OutSchema extends StandardSchemaV1 | undefined = undefined,\n> = (\n ctx: SubscriberContext<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger\n >,\n) => OutSchema extends StandardSchemaV1\n ? InferStandardSchema<OutSchema> | Promise<InferStandardSchema<OutSchema>>\n : any | Promise<any>;\n\n// Context type for subscriber handlers\nexport type SubscriberContext<\n TEventPublisher extends EventPublisher<any> | undefined,\n TSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n> = {\n events: ExtractEventPayloads<TEventPublisher, TSubscribedEvents>[];\n services: ServiceRecord<TServices>;\n logger: TLogger;\n};\n"],"mappings":";;;;;AAaA,MAAM,iBAAiB,IAAIA;AAU3B,IAAa,aAAb,cAQUC,4BAMR;CACA,oBAAoB;CAEpB,OAAO,aACLC,KACiD;AACjD,SAAO,QACL,OACE,IAAI,sBAAsB,QAC1B,IAAI,SAASC,gCAAc,WAC9B;CACF;CAED,YACkBC,SAOSC,UAAkB,KACjCC,mBACeC,cACAC,WAAsB,CAAE,GACxBC,SAAkB,gBAClBC,kBAIzB;AACA,QACEP,gCAAc,YACd,QACA,UACA,CAAE,GACF,kBACA,aACD;EAxBe;EAOS;EACf;EACe;EACA;EACA;EACA;CAa1B;CAED,IAAI,mBAAkD;AACpD,SAAO,KAAK;CACb;AACF"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Construct, ConstructType } from "./Construct-
|
|
1
|
+
import { Construct, ConstructType } from "./Construct-DdyGHuag.mjs";
|
|
2
2
|
import { ConsoleLogger } from "@geekmidas/logger/console";
|
|
3
3
|
|
|
4
4
|
//#region src/subscribers/Subscriber.ts
|
|
@@ -25,4 +25,4 @@ var Subscriber = class extends Construct {
|
|
|
25
25
|
|
|
26
26
|
//#endregion
|
|
27
27
|
export { Subscriber };
|
|
28
|
-
//# sourceMappingURL=Subscriber-
|
|
28
|
+
//# sourceMappingURL=Subscriber-BmPf9GFb.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Subscriber-BmPf9GFb.mjs","names":["DEFAULT_LOGGER","obj: any","handler: SubscriberHandler<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger,\n OutSchema\n >","timeout: number","_subscribedEvents?: TSubscribedEvents","outputSchema?: OutSchema","services: TServices","logger: TLogger","publisherService?: Service<\n TEventPublisherServiceName,\n TEventPublisher\n >"],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":["import type { Logger } from '@geekmidas/logger';\nimport { ConsoleLogger } from '@geekmidas/logger/console';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\n\nimport { Construct, ConstructType } from '../Construct';\n\nimport type {\n EventPublisher,\n ExtractPublisherMessage,\n} from '@geekmidas/events';\nimport type { InferStandardSchema } from '@geekmidas/schema';\nimport type { Service, ServiceRecord } from '@geekmidas/services';\n\nconst DEFAULT_LOGGER = new ConsoleLogger() as any;\n\n// Helper type to extract payload types for subscribed events\ntype ExtractEventPayloads<\n TPublisher extends EventPublisher<any> | undefined,\n TEventTypes extends any[],\n> = TPublisher extends EventPublisher<any>\n ? Extract<ExtractPublisherMessage<TPublisher>, { type: TEventTypes[number] }>\n : never;\n\nexport class Subscriber<\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n OutSchema extends StandardSchemaV1 | undefined = undefined,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TSubscribedEvents extends\n ExtractPublisherMessage<TEventPublisher>['type'][] = ExtractPublisherMessage<TEventPublisher>['type'][],\n> extends Construct<\n TLogger,\n TEventPublisherServiceName,\n TEventPublisher,\n OutSchema,\n TServices\n> {\n __IS_SUBSCRIBER__ = true;\n\n static isSubscriber(\n obj: any,\n ): obj is Subscriber<any, any, any, any, any, any> {\n return Boolean(\n obj &&\n obj.__IS_SUBSCRIBER__ === true &&\n obj.type === ConstructType.Subscriber,\n );\n }\n\n constructor(\n public readonly handler: SubscriberHandler<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger,\n OutSchema\n >,\n public override readonly timeout: number = 30000,\n protected _subscribedEvents?: TSubscribedEvents,\n public override readonly outputSchema?: OutSchema,\n public override readonly services: TServices = [] as unknown as TServices,\n public override readonly logger: TLogger = DEFAULT_LOGGER as TLogger,\n public override readonly publisherService?: Service<\n TEventPublisherServiceName,\n TEventPublisher\n >,\n ) {\n super(\n ConstructType.Subscriber,\n logger,\n services,\n [],\n publisherService,\n outputSchema,\n );\n }\n\n get subscribedEvents(): TSubscribedEvents | undefined {\n return this._subscribedEvents;\n }\n}\n\n// Handler type for subscribers that receives an array of events\nexport type SubscriberHandler<\n TEventPublisher extends EventPublisher<any> | undefined,\n TSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n OutSchema extends StandardSchemaV1 | undefined = undefined,\n> = (\n ctx: SubscriberContext<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger\n >,\n) => OutSchema extends StandardSchemaV1\n ? InferStandardSchema<OutSchema> | Promise<InferStandardSchema<OutSchema>>\n : any | Promise<any>;\n\n// Context type for subscriber handlers\nexport type SubscriberContext<\n TEventPublisher extends EventPublisher<any> | undefined,\n TSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n> = {\n events: ExtractEventPayloads<TEventPublisher, TSubscribedEvents>[];\n services: ServiceRecord<TServices>;\n logger: TLogger;\n};\n"],"mappings":";;;;AAaA,MAAMA,mBAAiB,IAAI;AAU3B,IAAa,aAAb,cAQU,UAMR;CACA,oBAAoB;CAEpB,OAAO,aACLC,KACiD;AACjD,SAAO,QACL,OACE,IAAI,sBAAsB,QAC1B,IAAI,SAAS,cAAc,WAC9B;CACF;CAED,YACkBC,SAOSC,UAAkB,KACjCC,mBACeC,cACAC,WAAsB,CAAE,GACxBC,SAAkBP,kBAClBQ,kBAIzB;AACA,QACE,cAAc,YACd,QACA,UACA,CAAE,GACF,kBACA,aACD;EAxBe;EAOS;EACf;EACe;EACA;EACA;EACA;CAa1B;CAED,IAAI,mBAAkD;AACpD,SAAO,KAAK;CACb;AACF"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Construct } from "./Construct-
|
|
1
|
+
import { Construct } from "./Construct-C4rPE67v.cjs";
|
|
2
2
|
import { EventPublisher, ExtractPublisherMessage } from "@geekmidas/events";
|
|
3
3
|
import { Logger } from "@geekmidas/logger";
|
|
4
4
|
import { Service, ServiceRecord } from "@geekmidas/services";
|
|
@@ -12,14 +12,14 @@ type ExtractEventPayloads<TPublisher extends EventPublisher<any> | undefined, TE
|
|
|
12
12
|
declare class Subscriber<TServices extends Service[] = [], TLogger extends Logger = Logger, OutSchema extends StandardSchemaV1 | undefined = undefined, TEventPublisher extends EventPublisher<any> | undefined = undefined, TEventPublisherServiceName extends string = string, TSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][] = ExtractPublisherMessage<TEventPublisher>['type'][]> extends Construct<TLogger, TEventPublisherServiceName, TEventPublisher, OutSchema, TServices> {
|
|
13
13
|
readonly handler: SubscriberHandler<TEventPublisher, TSubscribedEvents, TServices, TLogger, OutSchema>;
|
|
14
14
|
readonly timeout: number;
|
|
15
|
-
protected _subscribedEvents?: TSubscribedEvents;
|
|
16
|
-
readonly outputSchema?: OutSchema;
|
|
15
|
+
protected _subscribedEvents?: TSubscribedEvents | undefined;
|
|
16
|
+
readonly outputSchema?: OutSchema | undefined;
|
|
17
17
|
readonly services: TServices;
|
|
18
18
|
readonly logger: TLogger;
|
|
19
|
-
readonly publisherService?: Service<TEventPublisherServiceName, TEventPublisher
|
|
19
|
+
readonly publisherService?: Service<TEventPublisherServiceName, TEventPublisher> | undefined;
|
|
20
20
|
__IS_SUBSCRIBER__: boolean;
|
|
21
21
|
static isSubscriber(obj: any): obj is Subscriber<any, any, any, any, any, any>;
|
|
22
|
-
constructor(handler: SubscriberHandler<TEventPublisher, TSubscribedEvents, TServices, TLogger, OutSchema>, timeout?: number, _subscribedEvents?: TSubscribedEvents, outputSchema?: OutSchema, services?: TServices, logger?: TLogger, publisherService?: Service<TEventPublisherServiceName, TEventPublisher>);
|
|
22
|
+
constructor(handler: SubscriberHandler<TEventPublisher, TSubscribedEvents, TServices, TLogger, OutSchema>, timeout?: number, _subscribedEvents?: TSubscribedEvents | undefined, outputSchema?: OutSchema | undefined, services?: TServices, logger?: TLogger, publisherService?: Service<TEventPublisherServiceName, TEventPublisher> | undefined);
|
|
23
23
|
get subscribedEvents(): TSubscribedEvents | undefined;
|
|
24
24
|
}
|
|
25
25
|
type SubscriberHandler<TEventPublisher extends EventPublisher<any> | undefined, TSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][], TServices extends Service[] = [], TLogger extends Logger = Logger, OutSchema extends StandardSchemaV1 | undefined = undefined> = (ctx: SubscriberContext<TEventPublisher, TSubscribedEvents, TServices, TLogger>) => OutSchema extends StandardSchemaV1 ? InferStandardSchema<OutSchema> | Promise<InferStandardSchema<OutSchema>> : any | Promise<any>;
|
|
@@ -30,4 +30,4 @@ type SubscriberContext<TEventPublisher extends EventPublisher<any> | undefined,
|
|
|
30
30
|
};
|
|
31
31
|
//#endregion
|
|
32
32
|
export { Subscriber, SubscriberContext, SubscriberHandler };
|
|
33
|
-
//# sourceMappingURL=Subscriber-
|
|
33
|
+
//# sourceMappingURL=Subscriber-COYMSevD.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Subscriber-COYMSevD.d.cts","names":[],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Construct } from "./Construct-
|
|
1
|
+
import { Construct } from "./Construct-XrijZFFh.mjs";
|
|
2
2
|
import { Service, ServiceRecord } from "@geekmidas/services";
|
|
3
3
|
import { EventPublisher, ExtractPublisherMessage } from "@geekmidas/events";
|
|
4
4
|
import { Logger } from "@geekmidas/logger";
|
|
@@ -12,14 +12,14 @@ type ExtractEventPayloads<TPublisher extends EventPublisher<any> | undefined, TE
|
|
|
12
12
|
declare class Subscriber<TServices extends Service[] = [], TLogger extends Logger = Logger, OutSchema extends StandardSchemaV1 | undefined = undefined, TEventPublisher extends EventPublisher<any> | undefined = undefined, TEventPublisherServiceName extends string = string, TSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][] = ExtractPublisherMessage<TEventPublisher>['type'][]> extends Construct<TLogger, TEventPublisherServiceName, TEventPublisher, OutSchema, TServices> {
|
|
13
13
|
readonly handler: SubscriberHandler<TEventPublisher, TSubscribedEvents, TServices, TLogger, OutSchema>;
|
|
14
14
|
readonly timeout: number;
|
|
15
|
-
protected _subscribedEvents?: TSubscribedEvents;
|
|
16
|
-
readonly outputSchema?: OutSchema;
|
|
15
|
+
protected _subscribedEvents?: TSubscribedEvents | undefined;
|
|
16
|
+
readonly outputSchema?: OutSchema | undefined;
|
|
17
17
|
readonly services: TServices;
|
|
18
18
|
readonly logger: TLogger;
|
|
19
|
-
readonly publisherService?: Service<TEventPublisherServiceName, TEventPublisher
|
|
19
|
+
readonly publisherService?: Service<TEventPublisherServiceName, TEventPublisher> | undefined;
|
|
20
20
|
__IS_SUBSCRIBER__: boolean;
|
|
21
21
|
static isSubscriber(obj: any): obj is Subscriber<any, any, any, any, any, any>;
|
|
22
|
-
constructor(handler: SubscriberHandler<TEventPublisher, TSubscribedEvents, TServices, TLogger, OutSchema>, timeout?: number, _subscribedEvents?: TSubscribedEvents, outputSchema?: OutSchema, services?: TServices, logger?: TLogger, publisherService?: Service<TEventPublisherServiceName, TEventPublisher>);
|
|
22
|
+
constructor(handler: SubscriberHandler<TEventPublisher, TSubscribedEvents, TServices, TLogger, OutSchema>, timeout?: number, _subscribedEvents?: TSubscribedEvents | undefined, outputSchema?: OutSchema | undefined, services?: TServices, logger?: TLogger, publisherService?: Service<TEventPublisherServiceName, TEventPublisher> | undefined);
|
|
23
23
|
get subscribedEvents(): TSubscribedEvents | undefined;
|
|
24
24
|
}
|
|
25
25
|
type SubscriberHandler<TEventPublisher extends EventPublisher<any> | undefined, TSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][], TServices extends Service[] = [], TLogger extends Logger = Logger, OutSchema extends StandardSchemaV1 | undefined = undefined> = (ctx: SubscriberContext<TEventPublisher, TSubscribedEvents, TServices, TLogger>) => OutSchema extends StandardSchemaV1 ? InferStandardSchema<OutSchema> | Promise<InferStandardSchema<OutSchema>> : any | Promise<any>;
|
|
@@ -30,4 +30,4 @@ type SubscriberContext<TEventPublisher extends EventPublisher<any> | undefined,
|
|
|
30
30
|
};
|
|
31
31
|
//#endregion
|
|
32
32
|
export { Subscriber, SubscriberContext, SubscriberHandler };
|
|
33
|
-
//# sourceMappingURL=Subscriber-
|
|
33
|
+
//# sourceMappingURL=Subscriber-ikctpU3I.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Subscriber-ikctpU3I.d.mts","names":[],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":[],"mappings":";;;;;;;;KAgBK,wCACgB,8DAEjB,mBAAmB,sBACnB,QAAQ,wBAAwB;QAAqB;AATS,CAAA,CAAA,GAK7D,KAAA;AAAoB,cAOZ,UAPY,CAAA,kBAQL,OARK,EAAA,GAAA,EAAA,EAAA,gBASP,MATO,GASE,MATF,EAAA,kBAUL,gBAVK,GAAA,SAAA,GAAA,SAAA,EAAA,wBAWC,cAXD,CAAA,GAAA,CAAA,GAAA,SAAA,GAAA,SAAA,EAAA,mCAAA,MAAA,GAAA,MAAA,EAAA,0BAcrB,uBAdqB,CAcG,eAdH,CAAA,CAAA,MAAA,CAAA,EAAA,GAcgC,uBAdhC,CAcwD,eAdxD,CAAA,CAAA,MAAA,CAAA,EAAA,CAAA,SAef,SAfe,CAgBvB,OAhBuB,EAiBvB,0BAjBuB,EAkBvB,eAlBuB,EAmBvB,SAnBuB,EAoBvB,SApBuB,CAAA,CAAA;EAAA,SACJ,OAAA,EAkCQ,iBAlCR,CAmCf,eAnCe,EAoCf,iBApCe,EAqCf,SArCe,EAsCf,OAtCe,EAuCf,SAvCe,CAAA;EAAc,SAE/B,OAAA,EAAA,MAAA;EAAU,UAAS,iBAAA,CAAA,EAwCW,iBAxCX,GAAA,SAAA;EAAc,SACD,YAAA,CAAA,EAwCQ,SAxCR,GAAA,SAAA;EAAU,SAAlC,QAAA,EAyC2B,SAzC3B;EAAuB,SAAsB,MAAA,EA0CpB,OA1CoB;EAAW,SAAhE,gBAAA,CAAA,EA2C4C,OA3C5C,CA4CE,0BA5CF,EA6CE,eA7CF,CAAA,GAAA,SAAA;EAAO,iBAAA,EAAA,OAAA;EAGE,OAAA,YAAU,CAAA,GAAA,EAAA,GAAA,CAAA,EAAA,GAAA,IAmBX,UAnBW,CAAA,GAAA,EAAA,GAAA,EAAA,GAAA,EAAA,GAAA,EAAA,GAAA,EAAA,GAAA,CAAA;EAAA,WAAA,CAAA,OAAA,EA4BM,iBA5BN,CA6BjB,eA7BiB,EA8BjB,iBA9BiB,EA+BjB,SA/BiB,EAgCjB,OAhCiB,EAiCjB,SAjCiB,CAAA,EAAA,OAAA,CAAA,EAAA,MAAA,EAAA,iBAAA,CAAA,EAoCW,iBApCX,GAAA,SAAA,EAAA,YAAA,CAAA,EAqCqB,SArCrB,GAAA,SAAA,EAAA,QAAA,CAAA,EAsCgB,SAtChB,EAAA,MAAA,CAAA,EAuCc,OAvCd,EAAA,gBAAA,CAAA,EAwCyB,OAxCzB,CAyCjB,0BAzCiB,EA0CjB,eA1CiB,CAAA,GAAA,SAAA;EAAA,IACH,gBAAA,CAAA,CAAA,EAsDM,iBAtDN,GAAA,SAAA;;AACO,KA2Df,iBA3De,CAAA,wBA4DD,cA5DC,CAAA,GAAA,CAAA,GAAA,SAAA,EAAA,0BA6DC,uBA7DD,CA6DyB,eA7DzB,CAAA,CAAA,MAAA,CAAA,EAAA,EAAA,kBA8DP,OA9DO,EAAA,GAAA,EAAA,EAAA,gBA+DT,MA/DS,GA+DA,MA/DA,EAAA,kBAgEP,gBAhEO,GAAA,SAAA,GAAA,SAAA,CAAA,GAAA,CAAA,GAAA,EAkEpB,iBAlEoB,CAmEvB,eAnEuB,EAoEvB,iBApEuB,EAqEvB,SArEuB,EAsEvB,OAtEuB,CAAA,EAAA,GAwEtB,SAxEsB,SAwEJ,gBAxEI,GAyEvB,mBAzEuB,CAyEH,SAzEG,CAAA,GAyEU,OAzEV,CAyEkB,mBAzElB,CAyEsC,SAzEtC,CAAA,CAAA,GAAA,GAAA,GA0EjB,OA1EiB,CAAA,GAAA,CAAA;AACP,KA4ER,iBA5EQ,CAAA,wBA6EM,cA7EN,CAAA,GAAA,CAAA,GAAA,SAAA,EAAA,0BA8EQ,uBA9ER,CA8EgC,eA9EhC,CAAA,CAAA,MAAA,CAAA,EAAA,EAAA,kBA+EA,OA/EA,EAAA,GAAA,EAAA,EAAA,gBAgFF,MAhFE,GAgFO,MAhFP,CAAA,GAAA;EAAgB,MACV,EAiFhB,oBAjFgB,CAiFK,eAjFL,EAiFsB,iBAjFtB,CAAA,EAAA;EAAc,QAGZ,EA+EhB,aA/EgB,CA+EF,SA/EE,CAAA;EAAe,MAAvC,EAgFM,OAhFN;CAAuB"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
const require_chunk = require('./chunk-CUT6urMc.cjs');
|
|
2
|
-
const require_Subscriber = require('./Subscriber-
|
|
2
|
+
const require_Subscriber = require('./Subscriber-BiHjVXtM.cjs');
|
|
3
3
|
const __geekmidas_logger_console = require_chunk.__toESM(require("@geekmidas/logger/console"));
|
|
4
4
|
|
|
5
5
|
//#region src/subscribers/SubscriberBuilder.ts
|
|
@@ -57,4 +57,4 @@ Object.defineProperty(exports, 'SubscriberBuilder', {
|
|
|
57
57
|
return SubscriberBuilder;
|
|
58
58
|
}
|
|
59
59
|
});
|
|
60
|
-
//# sourceMappingURL=SubscriberBuilder-
|
|
60
|
+
//# sourceMappingURL=SubscriberBuilder-Cp1C-xtT.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SubscriberBuilder-
|
|
1
|
+
{"version":3,"file":"SubscriberBuilder-Cp1C-xtT.cjs","names":["DEFAULT_LOGGER","timeout: number","schema: T","services: T","logger: T","publisher: Service<TName, T>","event: TEvent","fn: SubscriberHandler<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger,\n OutSchema\n >","Subscriber"],"sources":["../src/subscribers/SubscriberBuilder.ts"],"sourcesContent":["import type {\n EventPublisher,\n ExtractPublisherMessage,\n} from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport { DEFAULT_LOGGER } from '@geekmidas/logger/console';\nimport type { Service } from '@geekmidas/services';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { Subscriber, type SubscriberHandler } from './Subscriber';\n\nexport class SubscriberBuilder<\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n OutSchema extends StandardSchemaV1 | undefined = undefined,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TSubscribedEvents extends any[] = [],\n> {\n private _subscribedEvents: TSubscribedEvents = [] as any;\n private _timeout?: number;\n private outputSchema?: OutSchema;\n private _services: TServices = [] as Service[] as TServices;\n private _logger: TLogger = DEFAULT_LOGGER;\n private _publisher?: Service<TEventPublisherServiceName, TEventPublisher>;\n\n constructor() {\n this._timeout = 30000; // Default timeout\n }\n\n timeout(timeout: number): this {\n this._timeout = timeout;\n return this;\n }\n\n output<T extends StandardSchemaV1>(\n schema: T,\n ): SubscriberBuilder<\n TServices,\n TLogger,\n T,\n TEventPublisher,\n TEventPublisherServiceName,\n TSubscribedEvents\n > {\n this.outputSchema = schema as unknown as OutSchema;\n return this as any;\n }\n\n services<T extends Service[]>(\n services: T,\n ): SubscriberBuilder<\n [...TServices, ...T],\n TLogger,\n OutSchema,\n TEventPublisher,\n TEventPublisherServiceName,\n TSubscribedEvents\n > {\n this._services = [...this._services, ...services] as any;\n return this as any;\n }\n\n logger<T extends Logger>(\n logger: T,\n ): SubscriberBuilder<\n TServices,\n T,\n OutSchema,\n TEventPublisher,\n TEventPublisherServiceName,\n TSubscribedEvents\n > {\n this._logger = logger as unknown as TLogger;\n return this as any;\n }\n\n publisher<T extends EventPublisher<any>, TName extends string>(\n publisher: Service<TName, T>,\n ): SubscriberBuilder<\n TServices,\n TLogger,\n OutSchema,\n T,\n TName,\n TSubscribedEvents\n > {\n this._publisher = publisher as any;\n return this as any;\n }\n\n subscribe<\n TEvent extends TEventPublisher extends EventPublisher<any>\n ?\n | ExtractPublisherMessage<TEventPublisher>['type']\n | ExtractPublisherMessage<TEventPublisher>['type'][]\n : never,\n >(\n event: TEvent,\n ): SubscriberBuilder<\n TServices,\n TLogger,\n OutSchema,\n TEventPublisher,\n TEventPublisherServiceName,\n TEvent extends any[]\n ? [...TSubscribedEvents, ...TEvent]\n : [...TSubscribedEvents, TEvent]\n > {\n const eventsToAdd = Array.isArray(event) ? event : [event];\n this._subscribedEvents = [...this._subscribedEvents, ...eventsToAdd] as any;\n return this as any;\n }\n\n handle(\n fn: SubscriberHandler<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger,\n OutSchema\n >,\n ): Subscriber<\n TServices,\n TLogger,\n OutSchema,\n TEventPublisher,\n TEventPublisherServiceName,\n TSubscribedEvents\n > {\n const subscriber = new Subscriber(\n fn,\n this._timeout,\n this._subscribedEvents,\n this.outputSchema,\n this._services,\n this._logger,\n this._publisher,\n );\n\n // Reset builder state after creating the subscriber to prevent pollution\n this._services = [] as Service[] as TServices;\n this._logger = DEFAULT_LOGGER;\n this._publisher = undefined;\n this._subscribedEvents = [] as any;\n this._timeout = 30000; // Reset to default\n this.outputSchema = undefined;\n\n return subscriber;\n }\n}\n"],"mappings":";;;;;AAUA,IAAa,oBAAb,MAOE;CACA,AAAQ,oBAAuC,CAAE;CACjD,AAAQ;CACR,AAAQ;CACR,AAAQ,YAAuB,CAAE;CACjC,AAAQ,UAAmBA;CAC3B,AAAQ;CAER,cAAc;AACZ,OAAK,WAAW;CACjB;CAED,QAAQC,SAAuB;AAC7B,OAAK,WAAW;AAChB,SAAO;CACR;CAED,OACEC,QAQA;AACA,OAAK,eAAe;AACpB,SAAO;CACR;CAED,SACEC,UAQA;AACA,OAAK,YAAY,CAAC,GAAG,KAAK,WAAW,GAAG,QAAS;AACjD,SAAO;CACR;CAED,OACEC,QAQA;AACA,OAAK,UAAU;AACf,SAAO;CACR;CAED,UACEC,WAQA;AACA,OAAK,aAAa;AAClB,SAAO;CACR;CAED,UAOEC,OAUA;EACA,MAAM,cAAc,MAAM,QAAQ,MAAM,GAAG,QAAQ,CAAC,KAAM;AAC1D,OAAK,oBAAoB,CAAC,GAAG,KAAK,mBAAmB,GAAG,WAAY;AACpE,SAAO;CACR;CAED,OACEC,IAcA;EACA,MAAM,aAAa,IAAIC,8BACrB,IACA,KAAK,UACL,KAAK,mBACL,KAAK,cACL,KAAK,WACL,KAAK,SACL,KAAK;AAIP,OAAK,YAAY,CAAE;AACnB,OAAK,UAAUR;AACf,OAAK;AACL,OAAK,oBAAoB,CAAE;AAC3B,OAAK,WAAW;AAChB,OAAK;AAEL,SAAO;CACR;AACF"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Subscriber } from "./Subscriber-
|
|
1
|
+
import { Subscriber } from "./Subscriber-BmPf9GFb.mjs";
|
|
2
2
|
import { DEFAULT_LOGGER } from "@geekmidas/logger/console";
|
|
3
3
|
|
|
4
4
|
//#region src/subscribers/SubscriberBuilder.ts
|
|
@@ -51,4 +51,4 @@ var SubscriberBuilder = class {
|
|
|
51
51
|
|
|
52
52
|
//#endregion
|
|
53
53
|
export { SubscriberBuilder };
|
|
54
|
-
//# sourceMappingURL=SubscriberBuilder-
|
|
54
|
+
//# sourceMappingURL=SubscriberBuilder-DJPEeYDJ.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SubscriberBuilder-
|
|
1
|
+
{"version":3,"file":"SubscriberBuilder-DJPEeYDJ.mjs","names":["timeout: number","schema: T","services: T","logger: T","publisher: Service<TName, T>","event: TEvent","fn: SubscriberHandler<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger,\n OutSchema\n >"],"sources":["../src/subscribers/SubscriberBuilder.ts"],"sourcesContent":["import type {\n EventPublisher,\n ExtractPublisherMessage,\n} from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport { DEFAULT_LOGGER } from '@geekmidas/logger/console';\nimport type { Service } from '@geekmidas/services';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { Subscriber, type SubscriberHandler } from './Subscriber';\n\nexport class SubscriberBuilder<\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n OutSchema extends StandardSchemaV1 | undefined = undefined,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TSubscribedEvents extends any[] = [],\n> {\n private _subscribedEvents: TSubscribedEvents = [] as any;\n private _timeout?: number;\n private outputSchema?: OutSchema;\n private _services: TServices = [] as Service[] as TServices;\n private _logger: TLogger = DEFAULT_LOGGER;\n private _publisher?: Service<TEventPublisherServiceName, TEventPublisher>;\n\n constructor() {\n this._timeout = 30000; // Default timeout\n }\n\n timeout(timeout: number): this {\n this._timeout = timeout;\n return this;\n }\n\n output<T extends StandardSchemaV1>(\n schema: T,\n ): SubscriberBuilder<\n TServices,\n TLogger,\n T,\n TEventPublisher,\n TEventPublisherServiceName,\n TSubscribedEvents\n > {\n this.outputSchema = schema as unknown as OutSchema;\n return this as any;\n }\n\n services<T extends Service[]>(\n services: T,\n ): SubscriberBuilder<\n [...TServices, ...T],\n TLogger,\n OutSchema,\n TEventPublisher,\n TEventPublisherServiceName,\n TSubscribedEvents\n > {\n this._services = [...this._services, ...services] as any;\n return this as any;\n }\n\n logger<T extends Logger>(\n logger: T,\n ): SubscriberBuilder<\n TServices,\n T,\n OutSchema,\n TEventPublisher,\n TEventPublisherServiceName,\n TSubscribedEvents\n > {\n this._logger = logger as unknown as TLogger;\n return this as any;\n }\n\n publisher<T extends EventPublisher<any>, TName extends string>(\n publisher: Service<TName, T>,\n ): SubscriberBuilder<\n TServices,\n TLogger,\n OutSchema,\n T,\n TName,\n TSubscribedEvents\n > {\n this._publisher = publisher as any;\n return this as any;\n }\n\n subscribe<\n TEvent extends TEventPublisher extends EventPublisher<any>\n ?\n | ExtractPublisherMessage<TEventPublisher>['type']\n | ExtractPublisherMessage<TEventPublisher>['type'][]\n : never,\n >(\n event: TEvent,\n ): SubscriberBuilder<\n TServices,\n TLogger,\n OutSchema,\n TEventPublisher,\n TEventPublisherServiceName,\n TEvent extends any[]\n ? [...TSubscribedEvents, ...TEvent]\n : [...TSubscribedEvents, TEvent]\n > {\n const eventsToAdd = Array.isArray(event) ? event : [event];\n this._subscribedEvents = [...this._subscribedEvents, ...eventsToAdd] as any;\n return this as any;\n }\n\n handle(\n fn: SubscriberHandler<\n TEventPublisher,\n TSubscribedEvents,\n TServices,\n TLogger,\n OutSchema\n >,\n ): Subscriber<\n TServices,\n TLogger,\n OutSchema,\n TEventPublisher,\n TEventPublisherServiceName,\n TSubscribedEvents\n > {\n const subscriber = new Subscriber(\n fn,\n this._timeout,\n this._subscribedEvents,\n this.outputSchema,\n this._services,\n this._logger,\n this._publisher,\n );\n\n // Reset builder state after creating the subscriber to prevent pollution\n this._services = [] as Service[] as TServices;\n this._logger = DEFAULT_LOGGER;\n this._publisher = undefined;\n this._subscribedEvents = [] as any;\n this._timeout = 30000; // Reset to default\n this.outputSchema = undefined;\n\n return subscriber;\n }\n}\n"],"mappings":";;;;AAUA,IAAa,oBAAb,MAOE;CACA,AAAQ,oBAAuC,CAAE;CACjD,AAAQ;CACR,AAAQ;CACR,AAAQ,YAAuB,CAAE;CACjC,AAAQ,UAAmB;CAC3B,AAAQ;CAER,cAAc;AACZ,OAAK,WAAW;CACjB;CAED,QAAQA,SAAuB;AAC7B,OAAK,WAAW;AAChB,SAAO;CACR;CAED,OACEC,QAQA;AACA,OAAK,eAAe;AACpB,SAAO;CACR;CAED,SACEC,UAQA;AACA,OAAK,YAAY,CAAC,GAAG,KAAK,WAAW,GAAG,QAAS;AACjD,SAAO;CACR;CAED,OACEC,QAQA;AACA,OAAK,UAAU;AACf,SAAO;CACR;CAED,UACEC,WAQA;AACA,OAAK,aAAa;AAClB,SAAO;CACR;CAED,UAOEC,OAUA;EACA,MAAM,cAAc,MAAM,QAAQ,MAAM,GAAG,QAAQ,CAAC,KAAM;AAC1D,OAAK,oBAAoB,CAAC,GAAG,KAAK,mBAAmB,GAAG,WAAY;AACpE,SAAO;CACR;CAED,OACEC,IAcA;EACA,MAAM,aAAa,IAAI,WACrB,IACA,KAAK,UACL,KAAK,mBACL,KAAK,cACL,KAAK,WACL,KAAK,SACL,KAAK;AAIP,OAAK,YAAY,CAAE;AACnB,OAAK,UAAU;AACf,OAAK;AACL,OAAK,oBAAoB,CAAE;AAC3B,OAAK,WAAW;AAChB,OAAK;AAEL,SAAO;CACR;AACF"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Subscriber, SubscriberHandler } from "./Subscriber-
|
|
1
|
+
import { Subscriber, SubscriberHandler } from "./Subscriber-ikctpU3I.mjs";
|
|
2
|
+
import { Service } from "@geekmidas/services";
|
|
2
3
|
import { EventPublisher, ExtractPublisherMessage } from "@geekmidas/events";
|
|
3
4
|
import { Logger } from "@geekmidas/logger";
|
|
4
|
-
import { Service } from "@geekmidas/services";
|
|
5
5
|
import { StandardSchemaV1 } from "@standard-schema/spec";
|
|
6
6
|
|
|
7
7
|
//#region src/subscribers/SubscriberBuilder.d.ts
|
|
@@ -21,6 +21,8 @@ declare class SubscriberBuilder<TServices extends Service[] = [], TLogger extend
|
|
|
21
21
|
subscribe<TEvent extends (TEventPublisher extends EventPublisher<any> ? ExtractPublisherMessage<TEventPublisher>['type'] | ExtractPublisherMessage<TEventPublisher>['type'][] : never)>(event: TEvent): SubscriberBuilder<TServices, TLogger, OutSchema, TEventPublisher, TEventPublisherServiceName, TEvent extends any[] ? [...TSubscribedEvents, ...TEvent] : [...TSubscribedEvents, TEvent]>;
|
|
22
22
|
handle(fn: SubscriberHandler<TEventPublisher, TSubscribedEvents, TServices, TLogger, OutSchema>): Subscriber<TServices, TLogger, OutSchema, TEventPublisher, TEventPublisherServiceName, TSubscribedEvents>;
|
|
23
23
|
}
|
|
24
|
+
//# sourceMappingURL=SubscriberBuilder.d.ts.map
|
|
25
|
+
|
|
24
26
|
//#endregion
|
|
25
27
|
export { SubscriberBuilder };
|
|
26
|
-
//# sourceMappingURL=SubscriberBuilder-
|
|
28
|
+
//# sourceMappingURL=SubscriberBuilder-D_9zzllj.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SubscriberBuilder-D_9zzllj.d.mts","names":[],"sources":["../src/subscribers/SubscriberBuilder.ts"],"sourcesContent":[],"mappings":";;;;;;;cAUa,oCACO,gCACF,SAAS,0BACP,kEACM;;EAJb,QAAA,QAAA;EAAiB,QAAA,YAAA;EAAA,QACV,SAAA;EAAO,QACT,OAAA;EAAM,QAAG,UAAA;EAAM,WACb,CAAA;EAAgB,OACV,CAAA,OAAA,EAAA,MAAA,CAAA,EAAA,IAAA;EAAc,MAoBrB,CAAA,UAAA,gBAAA,CAAA,CAAA,MAAA,EACP,CADO,CAAA,EAEd,iBAFc,CAGf,SAHe,EAIf,OAJe,EAKf,CALe,EAMf,eANe,EAOf,0BAPe,EAQf,iBARe,CAAA;EAAgB,QACvB,CAAA,UAaS,OAbT,EAAA,CAAA,CAAA,QAAA,EAcE,CAdF,CAAA,EAeP,iBAfO,CAAA,CAER,GAcI,SAdJ,EACA,GAakB,CAblB,CAAO,EAcP,OAbA,EAcA,SAdA,EAeA,eAfA,EAgBA,0BAhBA,EAiBA,iBAjBA,CAAA;EAAC,MACD,CAAA,UAsBe,MAtBf,CAAA,CAAA,MAAA,EAuBQ,CAvBR,CAAA,EAwBC,iBAxBD,CAyBA,SAzBA,EA0BA,CA1BA,EA2BA,SA3BA,EA4BA,eA5BA,EA6BA,0BA7BA,EA8BA,iBA9BA,CAAA;EAAe,SACf,CAAA,UAmCkB,cAnClB,CAAA,GAAA,CAAA,EAAA,cAAA,MAAA,CAAA,CAAA,SAAA,EAoCW,OApCX,CAoCmB,KApCnB,EAoC0B,CApC1B,CAAA,CAAA,EAqCC,iBArCD,CAsCA,SAtCA,EAuCA,OAvCA,EAwCA,SAxCA,EAyCA,CAzCA,EA0CA,KA1CA,EA2CA,iBA3CA,CAAA;EAA0B,SAC1B,CAAA,gBAiDe,eAjDf,SAiDuC,cAjDvC,CAAA,GAAA,CAAA,GAmDQ,uBAnDR,CAmDgC,eAnDhC,CAAA,CAAA,MAAA,CAAA,GAoDQ,uBApDR,CAoDgC,eApDhC,CAAA,CAAA,MAAA,CAAA,EAAA,GAAA,KAAA,EAAA,CAAA,KAAA,EAuDO,MAvDP,CAAA,EAwDC,iBAxDD,CAyDA,SAzDA,EA0DA,OA1DA,EA2DA,SA3DA,EA4DA,eA5DA,EA6DA,0BA7DA,EA8DA,MA9DA,SAAA,GAAA,EAAA,GAAA,CAAA,GA+DQ,iBA/DR,EAAA,GA+D8B,MA/D9B,CAAA,GAAA,CAAA,GAgEQ,iBAhER,EAgE2B,MAhE3B,CAAA,CAAA;EAAiB,MANhB,CAAA,EAAA,EA8EG,iBA9EH,CA+EC,eA/ED,EAgFC,iBAhFD,EAiFC,SAjFD,EAkFC,OAlFD,EAmFC,SAnFD,CAAA,CAAA,EAqFA,UArFA,CAsFD,SAtFC,EAuFD,OAvFC,EAwFD,SAxFC,EAyFD,eAzFC,EA0FD,0BA1FC,EA2FD,iBA3FC,CAAA"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Subscriber, SubscriberHandler } from "./Subscriber-
|
|
2
|
-
import { Service } from "@geekmidas/services";
|
|
1
|
+
import { Subscriber, SubscriberHandler } from "./Subscriber-COYMSevD.cjs";
|
|
3
2
|
import { EventPublisher, ExtractPublisherMessage } from "@geekmidas/events";
|
|
4
3
|
import { Logger } from "@geekmidas/logger";
|
|
4
|
+
import { Service } from "@geekmidas/services";
|
|
5
5
|
import { StandardSchemaV1 } from "@standard-schema/spec";
|
|
6
6
|
|
|
7
7
|
//#region src/subscribers/SubscriberBuilder.d.ts
|
|
@@ -21,6 +21,8 @@ declare class SubscriberBuilder<TServices extends Service[] = [], TLogger extend
|
|
|
21
21
|
subscribe<TEvent extends (TEventPublisher extends EventPublisher<any> ? ExtractPublisherMessage<TEventPublisher>['type'] | ExtractPublisherMessage<TEventPublisher>['type'][] : never)>(event: TEvent): SubscriberBuilder<TServices, TLogger, OutSchema, TEventPublisher, TEventPublisherServiceName, TEvent extends any[] ? [...TSubscribedEvents, ...TEvent] : [...TSubscribedEvents, TEvent]>;
|
|
22
22
|
handle(fn: SubscriberHandler<TEventPublisher, TSubscribedEvents, TServices, TLogger, OutSchema>): Subscriber<TServices, TLogger, OutSchema, TEventPublisher, TEventPublisherServiceName, TSubscribedEvents>;
|
|
23
23
|
}
|
|
24
|
+
//# sourceMappingURL=SubscriberBuilder.d.ts.map
|
|
25
|
+
|
|
24
26
|
//#endregion
|
|
25
27
|
export { SubscriberBuilder };
|
|
26
|
-
//# sourceMappingURL=SubscriberBuilder-
|
|
28
|
+
//# sourceMappingURL=SubscriberBuilder-ivHAGIVi.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SubscriberBuilder-ivHAGIVi.d.cts","names":[],"sources":["../src/subscribers/SubscriberBuilder.ts"],"sourcesContent":[],"mappings":";;;;;;;cAUa,oCACO,gCACF,SAAS,0BACP,kEACM;;EAJb,QAAA,QAAA;EAAiB,QAAA,YAAA;EAAA,QACV,SAAA;EAAO,QACT,OAAA;EAAM,QAAG,UAAA;EAAM,WACb,CAAA;EAAgB,OACV,CAAA,OAAA,EAAA,MAAA,CAAA,EAAA,IAAA;EAAc,MAoBrB,CAAA,UAAA,gBAAA,CAAA,CAAA,MAAA,EACP,CADO,CAAA,EAEd,iBAFc,CAGf,SAHe,EAIf,OAJe,EAKf,CALe,EAMf,eANe,EAOf,0BAPe,EAQf,iBARe,CAAA;EAAgB,QACvB,CAAA,UAaS,OAbT,EAAA,CAAA,CAAA,QAAA,EAcE,CAdF,CAAA,EAeP,iBAfO,CAAA,CAER,GAcI,SAdJ,EACA,GAakB,CAblB,CAAO,EAcP,OAbA,EAcA,SAdA,EAeA,eAfA,EAgBA,0BAhBA,EAiBA,iBAjBA,CAAA;EAAC,MACD,CAAA,UAsBe,MAtBf,CAAA,CAAA,MAAA,EAuBQ,CAvBR,CAAA,EAwBC,iBAxBD,CAyBA,SAzBA,EA0BA,CA1BA,EA2BA,SA3BA,EA4BA,eA5BA,EA6BA,0BA7BA,EA8BA,iBA9BA,CAAA;EAAe,SACf,CAAA,UAmCkB,cAnClB,CAAA,GAAA,CAAA,EAAA,cAAA,MAAA,CAAA,CAAA,SAAA,EAoCW,OApCX,CAoCmB,KApCnB,EAoC0B,CApC1B,CAAA,CAAA,EAqCC,iBArCD,CAsCA,SAtCA,EAuCA,OAvCA,EAwCA,SAxCA,EAyCA,CAzCA,EA0CA,KA1CA,EA2CA,iBA3CA,CAAA;EAA0B,SAC1B,CAAA,gBAiDe,eAjDf,SAiDuC,cAjDvC,CAAA,GAAA,CAAA,GAmDQ,uBAnDR,CAmDgC,eAnDhC,CAAA,CAAA,MAAA,CAAA,GAoDQ,uBApDR,CAoDgC,eApDhC,CAAA,CAAA,MAAA,CAAA,EAAA,GAAA,KAAA,EAAA,CAAA,KAAA,EAuDO,MAvDP,CAAA,EAwDC,iBAxDD,CAyDA,SAzDA,EA0DA,OA1DA,EA2DA,SA3DA,EA4DA,eA5DA,EA6DA,0BA7DA,EA8DA,MA9DA,SAAA,GAAA,EAAA,GAAA,CAAA,GA+DQ,iBA/DR,EAAA,GA+D8B,MA/D9B,CAAA,GAAA,CAAA,GAgEQ,iBAhER,EAgE2B,MAhE3B,CAAA,CAAA;EAAiB,MANhB,CAAA,EAAA,EA8EG,iBA9EH,CA+EC,eA/ED,EAgFC,iBAhFD,EAiFC,SAjFD,EAkFC,OAlFD,EAmFC,SAnFD,CAAA,CAAA,EAqFA,UArFA,CAsFD,SAtFC,EAuFD,OAvFC,EAwFD,SAxFC,EAyFD,eAzFC,EA0FD,0BA1FC,EA2FD,iBA3FC,CAAA"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { publishConstructEvents } from "./publisher-Bw4770Hi.mjs";
|
|
2
|
-
import { Endpoint, ResponseBuilder } from "./Endpoint-
|
|
2
|
+
import { Endpoint, ResponseBuilder } from "./Endpoint-CuOEswxJ.mjs";
|
|
3
3
|
import { executeWithAuditTransaction } from "./processAudits-Dj8UGqcW.mjs";
|
|
4
4
|
import { ServiceDiscovery } from "@geekmidas/services";
|
|
5
5
|
import { DefaultAuditor } from "@geekmidas/audit";
|
|
@@ -49,6 +49,21 @@ var TestEndpointAdaptor = class TestEndpointAdaptor {
|
|
|
49
49
|
cookie,
|
|
50
50
|
...rawDb !== void 0 && { db: rawDb }
|
|
51
51
|
});
|
|
52
|
+
const isAuthorized = await this.endpoint.authorize({
|
|
53
|
+
header,
|
|
54
|
+
cookie,
|
|
55
|
+
services: ctx.services,
|
|
56
|
+
logger,
|
|
57
|
+
session
|
|
58
|
+
});
|
|
59
|
+
if (!isAuthorized) {
|
|
60
|
+
logger.warn("Unauthorized access attempt");
|
|
61
|
+
return {
|
|
62
|
+
body: { error: "Unauthorized" },
|
|
63
|
+
status: 401,
|
|
64
|
+
headers: {}
|
|
65
|
+
};
|
|
66
|
+
}
|
|
52
67
|
const auditorStorage = ctx.auditorStorage;
|
|
53
68
|
let auditContext;
|
|
54
69
|
if (auditorStorage) {
|
|
@@ -145,4 +160,4 @@ var TestEndpointAdaptor = class TestEndpointAdaptor {
|
|
|
145
160
|
|
|
146
161
|
//#endregion
|
|
147
162
|
export { TestEndpointAdaptor };
|
|
148
|
-
//# sourceMappingURL=TestEndpointAdaptor-
|
|
163
|
+
//# sourceMappingURL=TestEndpointAdaptor-BXTofAKc.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestEndpointAdaptor-BXTofAKc.mjs","names":["name: string","value: string","options?: CookieOptions","endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >","serviceDiscovery: ServiceDiscovery<\n any,\n any\n >","ctx: TestRequestAdaptor<\n TInput,\n TServices,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TDatabase,\n TDatabaseServiceName\n >","auditContext: AuditExecutionContext<TAuditAction> | undefined","actor: AuditActor","metadata","output","result","headers: Record<string, string | string[]>","setCookieValues: string[]","cookie"],"sources":["../src/endpoints/TestEndpointAdaptor.ts"],"sourcesContent":["import type {\n AuditActor,\n AuditStorage,\n AuditableAction,\n} from '@geekmidas/audit';\nimport { DefaultAuditor } from '@geekmidas/audit';\nimport { EnvironmentParser } from '@geekmidas/envkit';\nimport type { EventPublisher } from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport type {\n InferComposableStandardSchema,\n InferStandardSchema,\n} from '@geekmidas/schema';\nimport {\n type Service,\n ServiceDiscovery,\n type ServiceRecord,\n} from '@geekmidas/services';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { publishConstructEvents } from '../publisher';\nimport type { HttpMethod } from '../types';\nimport {\n type CookieOptions,\n Endpoint,\n type EndpointSchemas,\n ResponseBuilder,\n} from './Endpoint';\nimport type { MappedAudit } from './audit';\nimport {\n type AuditExecutionContext,\n executeWithAuditTransaction,\n} from './processAudits';\n\nexport type TestHttpResponse<TBody = any> = {\n body: TBody;\n status: number;\n headers: Record<string, string | string[]>;\n};\n\n/**\n * Serializes a cookie into a Set-Cookie header string\n */\nfunction serializeCookie(\n name: string,\n value: string,\n options?: CookieOptions,\n): string {\n let cookieString = `${name}=${value}`;\n\n if (options) {\n if (options.maxAge !== undefined) {\n cookieString += `; Max-Age=${options.maxAge}`;\n }\n if (options.expires) {\n cookieString += `; Expires=${options.expires.toUTCString()}`;\n }\n if (options.domain) {\n cookieString += `; Domain=${options.domain}`;\n }\n if (options.path) {\n cookieString += `; Path=${options.path}`;\n }\n if (options.httpOnly) {\n cookieString += '; HttpOnly';\n }\n if (options.secure) {\n cookieString += '; Secure';\n }\n if (options.sameSite) {\n cookieString += `; SameSite=${options.sameSite}`;\n }\n }\n\n return cookieString;\n}\n\nexport class TestEndpointAdaptor<\n TRoute extends string,\n TMethod extends HttpMethod,\n TInput extends EndpointSchemas = {},\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TSession = unknown,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n TAuditStorageServiceName extends string = string,\n TAuditAction extends AuditableAction<string, unknown> = AuditableAction<\n string,\n unknown\n >,\n TDatabase = undefined,\n TDatabaseServiceName extends string = string,\n> {\n static getDefaultServiceDiscover<\n TRoute extends string,\n TMethod extends HttpMethod,\n TInput extends EndpointSchemas = {},\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TSession = unknown,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n TAuditStorageServiceName extends string = string,\n TAuditAction extends AuditableAction<string, unknown> = AuditableAction<\n string,\n unknown\n >,\n TDatabase = undefined,\n TDatabaseServiceName extends string = string,\n >(\n endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >,\n ) {\n return ServiceDiscovery.getInstance(\n endpoint.logger,\n new EnvironmentParser({}),\n );\n }\n constructor(\n private readonly endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >,\n private serviceDiscovery: ServiceDiscovery<\n any,\n any\n > = TestEndpointAdaptor.getDefaultServiceDiscover(endpoint),\n ) {}\n\n async fullRequest(\n ctx: TestRequestAdaptor<\n TInput,\n TServices,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TDatabase,\n TDatabaseServiceName\n >,\n ): Promise<TestHttpResponse<InferStandardSchema<TOutSchema>>> {\n const body = await this.endpoint.parseInput((ctx as any).body, 'body');\n const query = await this.endpoint.parseInput((ctx as any).query, 'query');\n const params = await this.endpoint.parseInput(\n (ctx as any).params,\n 'params',\n );\n\n const header = Endpoint.createHeaders(ctx.headers);\n const cookie = Endpoint.createCookies(ctx.headers.cookie);\n const logger = this.endpoint.logger.child({\n route: this.endpoint.route,\n host: ctx.headers.host,\n method: this.endpoint.method,\n }) as TLogger;\n\n // Get database from context for session extraction\n const rawDb = (ctx as any).database as TDatabase;\n\n const session = await this.endpoint.getSession({\n logger,\n services: ctx.services,\n header,\n cookie,\n ...(rawDb !== undefined && { db: rawDb }),\n } as any);\n\n // Check authorization\n const isAuthorized = await this.endpoint.authorize({\n header,\n cookie,\n services: ctx.services,\n logger,\n session,\n });\n\n if (!isAuthorized) {\n logger.warn('Unauthorized access attempt');\n return {\n body: { error: 'Unauthorized' } as any,\n status: 401,\n headers: {},\n };\n }\n\n // Create audit context if audit storage is provided\n // The auditorStorage instance is required when endpoint uses .auditor()\n const auditorStorage = (ctx as any).auditorStorage as TAuditStorage;\n let auditContext: AuditExecutionContext<TAuditAction> | undefined;\n\n if (auditorStorage) {\n // Extract actor if configured\n let actor: AuditActor = { id: 'system', type: 'system' };\n if (this.endpoint.actorExtractor) {\n try {\n actor = await this.endpoint.actorExtractor({\n services: ctx.services as any,\n session,\n header,\n cookie,\n logger,\n });\n } catch (error) {\n logger.error(error as Error, 'Failed to extract actor for audits');\n }\n }\n\n const auditor = new DefaultAuditor<TAuditAction>({\n actor,\n storage: auditorStorage as AuditStorage,\n metadata: {\n endpoint: this.endpoint.route,\n method: this.endpoint.method,\n },\n });\n\n auditContext = { auditor, storage: auditorStorage as AuditStorage };\n }\n\n // Warn if declarative audits are configured but no audit storage\n const audits = this.endpoint.audits as MappedAudit<\n TAuditAction,\n TOutSchema\n >[];\n if (!auditContext && audits?.length) {\n logger.warn('No auditor storage service available');\n }\n\n // Execute handler with automatic audit transaction support\n const result = await executeWithAuditTransaction(\n auditContext,\n async (auditor) => {\n // Use audit transaction as db if available (when storage has same database)\n // For testing, the tester controls whether to use transactional auditing\n const trx = auditor?.getTransaction?.();\n const db = trx ?? rawDb;\n\n const responseBuilder = new ResponseBuilder();\n const response = await this.endpoint.handler(\n {\n body,\n query,\n params,\n session,\n services: ctx.services,\n logger,\n header,\n cookie,\n auditor,\n db,\n } as any,\n responseBuilder,\n );\n\n // Check if response has metadata\n let data = response;\n let metadata = responseBuilder.getMetadata();\n\n if (Endpoint.hasMetadata(response)) {\n data = response.data;\n metadata = response.metadata;\n }\n\n const output = await this.endpoint.parseOutput(data);\n\n return { output, metadata, responseBuilder };\n },\n // Process declarative audits after handler (inside transaction)\n async (result, auditor) => {\n if (!audits?.length) return;\n\n for (const audit of audits) {\n if (audit.when && !audit.when(result.output as any)) {\n continue;\n }\n const payload = audit.payload(result.output as any);\n const entityId = audit.entityId?.(result.output as any);\n auditor.audit(audit.type as any, payload as any, {\n table: audit.table,\n entityId,\n });\n }\n },\n // Pass rawDb so storage can reuse existing transactions\n { db: rawDb },\n );\n\n const { output, metadata } = result;\n\n ctx.publisher && (await this.serviceDiscovery.register([ctx.publisher]));\n await publishConstructEvents(this.endpoint, output, this.serviceDiscovery);\n\n // Convert cookies to Set-Cookie headers\n const headers: Record<string, string | string[]> = {\n ...(metadata.headers || {}),\n };\n\n if (metadata.cookies && metadata.cookies.size > 0) {\n const setCookieValues: string[] = [];\n for (const [name, cookie] of metadata.cookies.entries()) {\n setCookieValues.push(\n serializeCookie(name, cookie.value, cookie.options),\n );\n }\n headers['set-cookie'] = setCookieValues;\n }\n\n // Return HTTP response format\n return {\n body: output,\n status: metadata.status || 200,\n headers,\n };\n }\n\n async request(\n ctx: TestRequestAdaptor<\n TInput,\n TServices,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TDatabase,\n TDatabaseServiceName\n >,\n ): Promise<InferStandardSchema<TOutSchema>> {\n const response = await this.fullRequest(ctx);\n return response.body;\n }\n}\n\n/**\n * Conditional audit storage requirement - required when TAuditStorage is configured\n */\ntype AuditStorageRequirement<\n TAuditStorage extends AuditStorage | undefined = undefined,\n> = TAuditStorage extends undefined\n ? {}\n : {\n /** Audit storage instance - required when endpoint uses .auditor() */\n auditorStorage: TAuditStorage;\n };\n\n/**\n * Conditional database requirement - required when TDatabase is configured\n */\ntype DatabaseRequirement<TDatabase = undefined> = TDatabase extends undefined\n ? {}\n : {\n /** Database instance - required when endpoint uses .database() */\n database: TDatabase;\n };\n\nexport type TestRequestAdaptor<\n TInput extends EndpointSchemas = {},\n TServices extends Service[] = [],\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n _TAuditStorageServiceName extends string = string,\n TDatabase = undefined,\n _TDatabaseServiceName extends string = string,\n> = {\n services: ServiceRecord<TServices>;\n headers: Record<string, string>;\n publisher?: Service<TEventPublisherServiceName, TEventPublisher>;\n} & InferComposableStandardSchema<TInput> &\n AuditStorageRequirement<TAuditStorage> &\n DatabaseRequirement<TDatabase>;\n"],"mappings":"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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { HttpMethod } from "./types-
|
|
2
|
-
import { Endpoint, EndpointSchemas } from "./Endpoint-
|
|
3
|
-
import { Service, ServiceDiscovery, ServiceRecord } from "@geekmidas/services";
|
|
1
|
+
import { HttpMethod } from "./types-B5H3piDg.cjs";
|
|
2
|
+
import { Endpoint, EndpointSchemas } from "./Endpoint-BPv9_-m_.cjs";
|
|
4
3
|
import { AuditStorage, AuditableAction } from "@geekmidas/audit";
|
|
5
4
|
import { EventPublisher } from "@geekmidas/events";
|
|
6
5
|
import { Logger } from "@geekmidas/logger";
|
|
6
|
+
import { Service, ServiceDiscovery, ServiceRecord } from "@geekmidas/services";
|
|
7
7
|
import { StandardSchemaV1 } from "@standard-schema/spec";
|
|
8
8
|
import { InferComposableStandardSchema, InferStandardSchema } from "@geekmidas/schema";
|
|
9
9
|
|
|
@@ -42,4 +42,4 @@ type TestRequestAdaptor<TInput extends EndpointSchemas = {}, TServices extends S
|
|
|
42
42
|
} & InferComposableStandardSchema<TInput> & AuditStorageRequirement<TAuditStorage> & DatabaseRequirement<TDatabase>;
|
|
43
43
|
//#endregion
|
|
44
44
|
export { TestEndpointAdaptor, TestHttpResponse, TestRequestAdaptor };
|
|
45
|
-
//# sourceMappingURL=TestEndpointAdaptor-
|
|
45
|
+
//# sourceMappingURL=TestEndpointAdaptor-C10xBI--.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestEndpointAdaptor-C10xBI--.d.cts","names":[],"sources":["../src/endpoints/TestEndpointAdaptor.ts"],"sourcesContent":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
const require_chunk = require('./chunk-CUT6urMc.cjs');
|
|
2
2
|
const require_publisher = require('./publisher-lFQleddL.cjs');
|
|
3
|
-
const require_Endpoint = require('./Endpoint-
|
|
3
|
+
const require_Endpoint = require('./Endpoint-BVGZXFyV.cjs');
|
|
4
4
|
const require_processAudits = require('./processAudits-CzHkPokQ.cjs');
|
|
5
5
|
const __geekmidas_services = require_chunk.__toESM(require("@geekmidas/services"));
|
|
6
6
|
const __geekmidas_audit = require_chunk.__toESM(require("@geekmidas/audit"));
|
|
@@ -50,6 +50,21 @@ var TestEndpointAdaptor = class TestEndpointAdaptor {
|
|
|
50
50
|
cookie,
|
|
51
51
|
...rawDb !== void 0 && { db: rawDb }
|
|
52
52
|
});
|
|
53
|
+
const isAuthorized = await this.endpoint.authorize({
|
|
54
|
+
header,
|
|
55
|
+
cookie,
|
|
56
|
+
services: ctx.services,
|
|
57
|
+
logger,
|
|
58
|
+
session
|
|
59
|
+
});
|
|
60
|
+
if (!isAuthorized) {
|
|
61
|
+
logger.warn("Unauthorized access attempt");
|
|
62
|
+
return {
|
|
63
|
+
body: { error: "Unauthorized" },
|
|
64
|
+
status: 401,
|
|
65
|
+
headers: {}
|
|
66
|
+
};
|
|
67
|
+
}
|
|
53
68
|
const auditorStorage = ctx.auditorStorage;
|
|
54
69
|
let auditContext;
|
|
55
70
|
if (auditorStorage) {
|
|
@@ -151,4 +166,4 @@ Object.defineProperty(exports, 'TestEndpointAdaptor', {
|
|
|
151
166
|
return TestEndpointAdaptor;
|
|
152
167
|
}
|
|
153
168
|
});
|
|
154
|
-
//# sourceMappingURL=TestEndpointAdaptor-
|
|
169
|
+
//# sourceMappingURL=TestEndpointAdaptor-D9IwhIYg.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestEndpointAdaptor-D9IwhIYg.cjs","names":["name: string","value: string","options?: CookieOptions","endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >","EnvironmentParser","serviceDiscovery: ServiceDiscovery<\n any,\n any\n >","ctx: TestRequestAdaptor<\n TInput,\n TServices,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TDatabase,\n TDatabaseServiceName\n >","auditContext: AuditExecutionContext<TAuditAction> | undefined","actor: AuditActor","DefaultAuditor","ResponseBuilder","metadata","output","result","headers: Record<string, string | string[]>","setCookieValues: string[]","cookie"],"sources":["../src/endpoints/TestEndpointAdaptor.ts"],"sourcesContent":["import type {\n AuditActor,\n AuditStorage,\n AuditableAction,\n} from '@geekmidas/audit';\nimport { DefaultAuditor } from '@geekmidas/audit';\nimport { EnvironmentParser } from '@geekmidas/envkit';\nimport type { EventPublisher } from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport type {\n InferComposableStandardSchema,\n InferStandardSchema,\n} from '@geekmidas/schema';\nimport {\n type Service,\n ServiceDiscovery,\n type ServiceRecord,\n} from '@geekmidas/services';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { publishConstructEvents } from '../publisher';\nimport type { HttpMethod } from '../types';\nimport {\n type CookieOptions,\n Endpoint,\n type EndpointSchemas,\n ResponseBuilder,\n} from './Endpoint';\nimport type { MappedAudit } from './audit';\nimport {\n type AuditExecutionContext,\n executeWithAuditTransaction,\n} from './processAudits';\n\nexport type TestHttpResponse<TBody = any> = {\n body: TBody;\n status: number;\n headers: Record<string, string | string[]>;\n};\n\n/**\n * Serializes a cookie into a Set-Cookie header string\n */\nfunction serializeCookie(\n name: string,\n value: string,\n options?: CookieOptions,\n): string {\n let cookieString = `${name}=${value}`;\n\n if (options) {\n if (options.maxAge !== undefined) {\n cookieString += `; Max-Age=${options.maxAge}`;\n }\n if (options.expires) {\n cookieString += `; Expires=${options.expires.toUTCString()}`;\n }\n if (options.domain) {\n cookieString += `; Domain=${options.domain}`;\n }\n if (options.path) {\n cookieString += `; Path=${options.path}`;\n }\n if (options.httpOnly) {\n cookieString += '; HttpOnly';\n }\n if (options.secure) {\n cookieString += '; Secure';\n }\n if (options.sameSite) {\n cookieString += `; SameSite=${options.sameSite}`;\n }\n }\n\n return cookieString;\n}\n\nexport class TestEndpointAdaptor<\n TRoute extends string,\n TMethod extends HttpMethod,\n TInput extends EndpointSchemas = {},\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TSession = unknown,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n TAuditStorageServiceName extends string = string,\n TAuditAction extends AuditableAction<string, unknown> = AuditableAction<\n string,\n unknown\n >,\n TDatabase = undefined,\n TDatabaseServiceName extends string = string,\n> {\n static getDefaultServiceDiscover<\n TRoute extends string,\n TMethod extends HttpMethod,\n TInput extends EndpointSchemas = {},\n TOutSchema extends StandardSchemaV1 | undefined = undefined,\n TServices extends Service[] = [],\n TLogger extends Logger = Logger,\n TSession = unknown,\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n TAuditStorageServiceName extends string = string,\n TAuditAction extends AuditableAction<string, unknown> = AuditableAction<\n string,\n unknown\n >,\n TDatabase = undefined,\n TDatabaseServiceName extends string = string,\n >(\n endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >,\n ) {\n return ServiceDiscovery.getInstance(\n endpoint.logger,\n new EnvironmentParser({}),\n );\n }\n constructor(\n private readonly endpoint: Endpoint<\n TRoute,\n TMethod,\n TInput,\n TOutSchema,\n TServices,\n TLogger,\n TSession,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TAuditAction,\n TDatabase,\n TDatabaseServiceName\n >,\n private serviceDiscovery: ServiceDiscovery<\n any,\n any\n > = TestEndpointAdaptor.getDefaultServiceDiscover(endpoint),\n ) {}\n\n async fullRequest(\n ctx: TestRequestAdaptor<\n TInput,\n TServices,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TDatabase,\n TDatabaseServiceName\n >,\n ): Promise<TestHttpResponse<InferStandardSchema<TOutSchema>>> {\n const body = await this.endpoint.parseInput((ctx as any).body, 'body');\n const query = await this.endpoint.parseInput((ctx as any).query, 'query');\n const params = await this.endpoint.parseInput(\n (ctx as any).params,\n 'params',\n );\n\n const header = Endpoint.createHeaders(ctx.headers);\n const cookie = Endpoint.createCookies(ctx.headers.cookie);\n const logger = this.endpoint.logger.child({\n route: this.endpoint.route,\n host: ctx.headers.host,\n method: this.endpoint.method,\n }) as TLogger;\n\n // Get database from context for session extraction\n const rawDb = (ctx as any).database as TDatabase;\n\n const session = await this.endpoint.getSession({\n logger,\n services: ctx.services,\n header,\n cookie,\n ...(rawDb !== undefined && { db: rawDb }),\n } as any);\n\n // Check authorization\n const isAuthorized = await this.endpoint.authorize({\n header,\n cookie,\n services: ctx.services,\n logger,\n session,\n });\n\n if (!isAuthorized) {\n logger.warn('Unauthorized access attempt');\n return {\n body: { error: 'Unauthorized' } as any,\n status: 401,\n headers: {},\n };\n }\n\n // Create audit context if audit storage is provided\n // The auditorStorage instance is required when endpoint uses .auditor()\n const auditorStorage = (ctx as any).auditorStorage as TAuditStorage;\n let auditContext: AuditExecutionContext<TAuditAction> | undefined;\n\n if (auditorStorage) {\n // Extract actor if configured\n let actor: AuditActor = { id: 'system', type: 'system' };\n if (this.endpoint.actorExtractor) {\n try {\n actor = await this.endpoint.actorExtractor({\n services: ctx.services as any,\n session,\n header,\n cookie,\n logger,\n });\n } catch (error) {\n logger.error(error as Error, 'Failed to extract actor for audits');\n }\n }\n\n const auditor = new DefaultAuditor<TAuditAction>({\n actor,\n storage: auditorStorage as AuditStorage,\n metadata: {\n endpoint: this.endpoint.route,\n method: this.endpoint.method,\n },\n });\n\n auditContext = { auditor, storage: auditorStorage as AuditStorage };\n }\n\n // Warn if declarative audits are configured but no audit storage\n const audits = this.endpoint.audits as MappedAudit<\n TAuditAction,\n TOutSchema\n >[];\n if (!auditContext && audits?.length) {\n logger.warn('No auditor storage service available');\n }\n\n // Execute handler with automatic audit transaction support\n const result = await executeWithAuditTransaction(\n auditContext,\n async (auditor) => {\n // Use audit transaction as db if available (when storage has same database)\n // For testing, the tester controls whether to use transactional auditing\n const trx = auditor?.getTransaction?.();\n const db = trx ?? rawDb;\n\n const responseBuilder = new ResponseBuilder();\n const response = await this.endpoint.handler(\n {\n body,\n query,\n params,\n session,\n services: ctx.services,\n logger,\n header,\n cookie,\n auditor,\n db,\n } as any,\n responseBuilder,\n );\n\n // Check if response has metadata\n let data = response;\n let metadata = responseBuilder.getMetadata();\n\n if (Endpoint.hasMetadata(response)) {\n data = response.data;\n metadata = response.metadata;\n }\n\n const output = await this.endpoint.parseOutput(data);\n\n return { output, metadata, responseBuilder };\n },\n // Process declarative audits after handler (inside transaction)\n async (result, auditor) => {\n if (!audits?.length) return;\n\n for (const audit of audits) {\n if (audit.when && !audit.when(result.output as any)) {\n continue;\n }\n const payload = audit.payload(result.output as any);\n const entityId = audit.entityId?.(result.output as any);\n auditor.audit(audit.type as any, payload as any, {\n table: audit.table,\n entityId,\n });\n }\n },\n // Pass rawDb so storage can reuse existing transactions\n { db: rawDb },\n );\n\n const { output, metadata } = result;\n\n ctx.publisher && (await this.serviceDiscovery.register([ctx.publisher]));\n await publishConstructEvents(this.endpoint, output, this.serviceDiscovery);\n\n // Convert cookies to Set-Cookie headers\n const headers: Record<string, string | string[]> = {\n ...(metadata.headers || {}),\n };\n\n if (metadata.cookies && metadata.cookies.size > 0) {\n const setCookieValues: string[] = [];\n for (const [name, cookie] of metadata.cookies.entries()) {\n setCookieValues.push(\n serializeCookie(name, cookie.value, cookie.options),\n );\n }\n headers['set-cookie'] = setCookieValues;\n }\n\n // Return HTTP response format\n return {\n body: output,\n status: metadata.status || 200,\n headers,\n };\n }\n\n async request(\n ctx: TestRequestAdaptor<\n TInput,\n TServices,\n TEventPublisher,\n TEventPublisherServiceName,\n TAuditStorage,\n TAuditStorageServiceName,\n TDatabase,\n TDatabaseServiceName\n >,\n ): Promise<InferStandardSchema<TOutSchema>> {\n const response = await this.fullRequest(ctx);\n return response.body;\n }\n}\n\n/**\n * Conditional audit storage requirement - required when TAuditStorage is configured\n */\ntype AuditStorageRequirement<\n TAuditStorage extends AuditStorage | undefined = undefined,\n> = TAuditStorage extends undefined\n ? {}\n : {\n /** Audit storage instance - required when endpoint uses .auditor() */\n auditorStorage: TAuditStorage;\n };\n\n/**\n * Conditional database requirement - required when TDatabase is configured\n */\ntype DatabaseRequirement<TDatabase = undefined> = TDatabase extends undefined\n ? {}\n : {\n /** Database instance - required when endpoint uses .database() */\n database: TDatabase;\n };\n\nexport type TestRequestAdaptor<\n TInput extends EndpointSchemas = {},\n TServices extends Service[] = [],\n TEventPublisher extends EventPublisher<any> | undefined = undefined,\n TEventPublisherServiceName extends string = string,\n TAuditStorage extends AuditStorage | undefined = undefined,\n _TAuditStorageServiceName extends string = string,\n TDatabase = undefined,\n _TDatabaseServiceName extends string = string,\n> = {\n services: ServiceRecord<TServices>;\n headers: Record<string, string>;\n publisher?: Service<TEventPublisherServiceName, TEventPublisher>;\n} & InferComposableStandardSchema<TInput> &\n AuditStorageRequirement<TAuditStorage> &\n DatabaseRequirement<TDatabase>;\n"],"mappings":"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"}
|