@geekmidas/constructs 0.0.12 → 0.0.14

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