@geekmidas/constructs 0.3.2 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (550) hide show
  1. package/dist/{AWSLambdaFunction-EPGY4s7i.cjs → AWSLambdaFunction-Ba1DcsW2.cjs} +6 -6
  2. package/dist/AWSLambdaFunction-Ba1DcsW2.cjs.map +1 -0
  3. package/dist/{AWSLambdaFunction-BdebRMUh.d.mts → AWSLambdaFunction-CKe73Qr0.d.cts} +6 -6
  4. package/dist/AWSLambdaFunction-CKe73Qr0.d.cts.map +1 -0
  5. package/dist/{AWSLambdaFunction-D0tEOTXQ.d.cts → AWSLambdaFunction-CuG3HNZx.d.mts} +6 -6
  6. package/dist/AWSLambdaFunction-CuG3HNZx.d.mts.map +1 -0
  7. package/dist/{AWSLambdaFunction-C54a1doJ.mjs → AWSLambdaFunction-DnMm4xvz.mjs} +6 -6
  8. package/dist/AWSLambdaFunction-DnMm4xvz.mjs.map +1 -0
  9. package/dist/{AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts → AWSLambdaSubscriberAdaptor-B4HH-WuQ.d.mts} +4 -4
  10. package/dist/AWSLambdaSubscriberAdaptor-B4HH-WuQ.d.mts.map +1 -0
  11. package/dist/{AWSLambdaSubscriberAdaptor-BLfO612H.mjs → AWSLambdaSubscriberAdaptor-BD3FwGUb.mjs} +3 -3
  12. package/dist/AWSLambdaSubscriberAdaptor-BD3FwGUb.mjs.map +1 -0
  13. package/dist/{AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts → AWSLambdaSubscriberAdaptor-BEqQ96VJ.d.cts} +4 -4
  14. package/dist/AWSLambdaSubscriberAdaptor-BEqQ96VJ.d.cts.map +1 -0
  15. package/dist/{AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs → AWSLambdaSubscriberAdaptor-DQDnt1Xk.cjs} +3 -3
  16. package/dist/AWSLambdaSubscriberAdaptor-DQDnt1Xk.cjs.map +1 -0
  17. package/dist/{AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs → AmazonApiGatewayEndpointAdaptor-Bvy-Hgjf.mjs} +56 -14
  18. package/dist/AmazonApiGatewayEndpointAdaptor-Bvy-Hgjf.mjs.map +1 -0
  19. package/dist/{AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs → AmazonApiGatewayEndpointAdaptor-Cpxluhfg.cjs} +55 -13
  20. package/dist/AmazonApiGatewayEndpointAdaptor-Cpxluhfg.cjs.map +1 -0
  21. package/dist/{AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts → AmazonApiGatewayEndpointAdaptor-DTgdZ8I1.d.mts} +52 -6
  22. package/dist/AmazonApiGatewayEndpointAdaptor-DTgdZ8I1.d.mts.map +1 -0
  23. package/dist/{AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts → AmazonApiGatewayEndpointAdaptor-DsWnO6x9.d.cts} +51 -5
  24. package/dist/AmazonApiGatewayEndpointAdaptor-DsWnO6x9.d.cts.map +1 -0
  25. package/dist/{AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts → AmazonApiGatewayV1EndpointAdaptor-7ELXUBFK.d.cts} +4 -4
  26. package/dist/AmazonApiGatewayV1EndpointAdaptor-7ELXUBFK.d.cts.map +1 -0
  27. package/dist/{AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs → AmazonApiGatewayV1EndpointAdaptor-B8vIYYNh.cjs} +4 -4
  28. package/dist/AmazonApiGatewayV1EndpointAdaptor-B8vIYYNh.cjs.map +1 -0
  29. package/dist/{AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs → AmazonApiGatewayV1EndpointAdaptor-ByXGIju8.mjs} +4 -4
  30. package/dist/AmazonApiGatewayV1EndpointAdaptor-ByXGIju8.mjs.map +1 -0
  31. package/dist/{AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts → AmazonApiGatewayV1EndpointAdaptor-RWRmFPrN.d.mts} +5 -5
  32. package/dist/AmazonApiGatewayV1EndpointAdaptor-RWRmFPrN.d.mts.map +1 -0
  33. package/dist/{AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs → AmazonApiGatewayV2EndpointAdaptor-DIetspUm.cjs} +4 -4
  34. package/dist/AmazonApiGatewayV2EndpointAdaptor-DIetspUm.cjs.map +1 -0
  35. package/dist/{AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs → AmazonApiGatewayV2EndpointAdaptor-DWemCZvl.mjs} +4 -4
  36. package/dist/AmazonApiGatewayV2EndpointAdaptor-DWemCZvl.mjs.map +1 -0
  37. package/dist/{AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts → AmazonApiGatewayV2EndpointAdaptor-D_uMTmuJ.d.cts} +4 -6
  38. package/dist/AmazonApiGatewayV2EndpointAdaptor-D_uMTmuJ.d.cts.map +1 -0
  39. package/dist/{AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts → AmazonApiGatewayV2EndpointAdaptor-wnOMDv6o.d.mts} +5 -7
  40. package/dist/AmazonApiGatewayV2EndpointAdaptor-wnOMDv6o.d.mts.map +1 -0
  41. package/dist/{Authorizer-C0ge_tc8.cjs → Authorizer-BXxBee2P.cjs} +1 -1
  42. package/dist/Authorizer-BXxBee2P.cjs.map +1 -0
  43. package/dist/{Authorizer-r9U3y_ms.mjs → Authorizer-BgjU8-z6.mjs} +1 -1
  44. package/dist/Authorizer-BgjU8-z6.mjs.map +1 -0
  45. package/dist/{Authorizer-gWxYsGEp.d.mts → Authorizer-DCcYOx3h.d.mts} +1 -1
  46. package/dist/Authorizer-DCcYOx3h.d.mts.map +1 -0
  47. package/dist/{Authorizer-B-btowNd.d.cts → Authorizer-DWtwC8we.d.cts} +1 -1
  48. package/dist/Authorizer-DWtwC8we.d.cts.map +1 -0
  49. package/dist/{BaseFunctionBuilder-Czi1Jwza.mjs → BaseFunctionBuilder-0qlenb9z.mjs} +2 -2
  50. package/dist/BaseFunctionBuilder-0qlenb9z.mjs.map +1 -0
  51. package/dist/BaseFunctionBuilder-BAtutR6q.d.cts.map +1 -1
  52. package/dist/{BaseFunctionBuilder-DRY419e7.d.mts → BaseFunctionBuilder-CDfDWWAQ.d.mts} +2 -2
  53. package/dist/BaseFunctionBuilder-CDfDWWAQ.d.mts.map +1 -0
  54. package/dist/{BaseFunctionBuilder-MYG3C9ug.cjs → BaseFunctionBuilder-D7o93EGv.cjs} +2 -2
  55. package/dist/BaseFunctionBuilder-D7o93EGv.cjs.map +1 -0
  56. package/dist/{Construct-Ba5cMxib.cjs → Construct-BlnyYtJC.cjs} +31 -2
  57. package/dist/Construct-BlnyYtJC.cjs.map +1 -0
  58. package/dist/Construct-C4rPE67v.d.cts.map +1 -1
  59. package/dist/{Construct-DdyGHuag.mjs → Construct-D5dCvxZ3.mjs} +31 -2
  60. package/dist/Construct-D5dCvxZ3.mjs.map +1 -0
  61. package/dist/{Construct-XrijZFFh.d.mts → Construct-dZiwVo0q.d.mts} +1 -1
  62. package/dist/Construct-dZiwVo0q.d.mts.map +1 -0
  63. package/dist/Construct.cjs +1 -1
  64. package/dist/Construct.d.mts +1 -1
  65. package/dist/Construct.mjs +1 -1
  66. package/dist/{Cron-bDLcTvV5.d.cts → Cron-B6FnTu7k.d.cts} +2 -2
  67. package/dist/Cron-B6FnTu7k.d.cts.map +1 -0
  68. package/dist/{Cron-CGF4YAfM.cjs → Cron-BAPQetlC.cjs} +3 -3
  69. package/dist/Cron-BAPQetlC.cjs.map +1 -0
  70. package/dist/{Cron-BxhGs5up.mjs → Cron-CAk_ddH8.mjs} +3 -3
  71. package/dist/Cron-CAk_ddH8.mjs.map +1 -0
  72. package/dist/{Cron-cdjlSKNp.d.mts → Cron-D3bEljxQ.d.mts} +2 -2
  73. package/dist/Cron-D3bEljxQ.d.mts.map +1 -0
  74. package/dist/{CronBuilder-DKVXyE0Q.d.cts → CronBuilder-CA8euP0z.d.cts} +4 -4
  75. package/dist/CronBuilder-CA8euP0z.d.cts.map +1 -0
  76. package/dist/{CronBuilder-BC4m5-p1.d.mts → CronBuilder-DvdiKzhq.d.mts} +4 -4
  77. package/dist/CronBuilder-DvdiKzhq.d.mts.map +1 -0
  78. package/dist/{CronBuilder-CcxKRtVP.cjs → CronBuilder-DxXA5ymv.cjs} +4 -4
  79. package/dist/CronBuilder-DxXA5ymv.cjs.map +1 -0
  80. package/dist/{CronBuilder-d2jh-IB2.mjs → CronBuilder-e8TaHPYm.mjs} +4 -4
  81. package/dist/CronBuilder-e8TaHPYm.mjs.map +1 -0
  82. package/dist/{Endpoint-BPv9_-m_.d.cts → Endpoint-BOlbY5iq.d.cts} +3 -3
  83. package/dist/Endpoint-BOlbY5iq.d.cts.map +1 -0
  84. package/dist/{Endpoint-CuOEswxJ.mjs → Endpoint-BbdNmtlM.mjs} +6 -6
  85. package/dist/Endpoint-BbdNmtlM.mjs.map +1 -0
  86. package/dist/{Endpoint-BdwG75G_.d.mts → Endpoint-Dlv7nxgj.d.mts} +4 -4
  87. package/dist/Endpoint-Dlv7nxgj.d.mts.map +1 -0
  88. package/dist/{Endpoint-BVGZXFyV.cjs → Endpoint-DxvnlfXg.cjs} +6 -6
  89. package/dist/Endpoint-DxvnlfXg.cjs.map +1 -0
  90. package/dist/{EndpointBuilder-Cgj1P_ra.cjs → EndpointBuilder-40Iz5CjY.cjs} +6 -6
  91. package/dist/EndpointBuilder-40Iz5CjY.cjs.map +1 -0
  92. package/dist/{EndpointBuilder-DnCB1h1j.mjs → EndpointBuilder-BaVvhW9m.mjs} +6 -6
  93. package/dist/EndpointBuilder-BaVvhW9m.mjs.map +1 -0
  94. package/dist/{EndpointBuilder-DIy_m1bu.d.cts → EndpointBuilder-CFfWWjUa.d.cts} +3 -3
  95. package/dist/EndpointBuilder-CFfWWjUa.d.cts.map +1 -0
  96. package/dist/{EndpointBuilder-B3az942t.d.mts → EndpointBuilder-T_K2NLWw.d.mts} +5 -5
  97. package/dist/EndpointBuilder-T_K2NLWw.d.mts.map +1 -0
  98. package/dist/{EndpointFactory-CyPbm3AD.d.cts → EndpointFactory-ChzBVEM9.d.cts} +4 -4
  99. package/dist/EndpointFactory-ChzBVEM9.d.cts.map +1 -0
  100. package/dist/{EndpointFactory-CbdxPCIH.mjs → EndpointFactory-DfNjSgVG.mjs} +7 -7
  101. package/dist/EndpointFactory-DfNjSgVG.mjs.map +1 -0
  102. package/dist/{EndpointFactory-C-0nE6Jg.d.mts → EndpointFactory-GAL_tuPf.d.mts} +4 -4
  103. package/dist/EndpointFactory-GAL_tuPf.d.mts.map +1 -0
  104. package/dist/{EndpointFactory-CYj6BYok.cjs → EndpointFactory-r6jxPvQ8.cjs} +7 -7
  105. package/dist/EndpointFactory-r6jxPvQ8.cjs.map +1 -0
  106. package/dist/{Function-BVHqIDp9.mjs → Function-D8tBamM3.mjs} +3 -3
  107. package/dist/Function-D8tBamM3.mjs.map +1 -0
  108. package/dist/{Function-DN2G6OT5.d.mts → Function-DBmU3uGI.d.mts} +3 -3
  109. package/dist/Function-DBmU3uGI.d.mts.map +1 -0
  110. package/dist/{Function-Cf7f_kCz.d.cts → Function-PNW4HdNE.d.cts} +2 -2
  111. package/dist/Function-PNW4HdNE.d.cts.map +1 -0
  112. package/dist/{Function-DDZb1525.cjs → Function-iLKrUXuw.cjs} +3 -3
  113. package/dist/Function-iLKrUXuw.cjs.map +1 -0
  114. package/dist/{FunctionBuilder-DswJ-9sD.cjs → FunctionBuilder-BEpPgeho.cjs} +4 -4
  115. package/dist/FunctionBuilder-BEpPgeho.cjs.map +1 -0
  116. package/dist/{FunctionBuilder-Cxx8D2na.d.mts → FunctionBuilder-Bv4H2I1a.d.mts} +4 -4
  117. package/dist/FunctionBuilder-Bv4H2I1a.d.mts.map +1 -0
  118. package/dist/{FunctionBuilder-CrDYgfiI.mjs → FunctionBuilder-BwNF99AB.mjs} +4 -4
  119. package/dist/FunctionBuilder-BwNF99AB.mjs.map +1 -0
  120. package/dist/{FunctionBuilder-CJBzzXL3.d.cts → FunctionBuilder-DCqXIHaq.d.cts} +2 -2
  121. package/dist/FunctionBuilder-DCqXIHaq.d.cts.map +1 -0
  122. package/dist/{FunctionExecutionWrapper-CLDh7Z2_.mjs → FunctionExecutionWrapper-B__HE_B-.mjs} +3 -3
  123. package/dist/FunctionExecutionWrapper-B__HE_B-.mjs.map +1 -0
  124. package/dist/{FunctionExecutionWrapper-DF260Aaj.d.mts → FunctionExecutionWrapper-BclgIztn.d.cts} +5 -5
  125. package/dist/FunctionExecutionWrapper-BclgIztn.d.cts.map +1 -0
  126. package/dist/{FunctionExecutionWrapper-BYI2bGTL.cjs → FunctionExecutionWrapper-BjF6t9Hb.cjs} +3 -3
  127. package/dist/FunctionExecutionWrapper-BjF6t9Hb.cjs.map +1 -0
  128. package/dist/{FunctionExecutionWrapper-Qy8bmgFR.d.cts → FunctionExecutionWrapper-Dq21c6vt.d.mts} +5 -5
  129. package/dist/FunctionExecutionWrapper-Dq21c6vt.d.mts.map +1 -0
  130. package/dist/HonoEndpointAdaptor-C_ym_Sbr.mjs +251 -0
  131. package/dist/HonoEndpointAdaptor-C_ym_Sbr.mjs.map +1 -0
  132. package/dist/HonoEndpointAdaptor-DiQH0eTb.cjs +257 -0
  133. package/dist/HonoEndpointAdaptor-DiQH0eTb.cjs.map +1 -0
  134. package/dist/{HonoEndpointAdaptor-YcRHYALH.d.cts → HonoEndpointAdaptor-Dkkemmbo.d.cts} +10 -5
  135. package/dist/HonoEndpointAdaptor-Dkkemmbo.d.cts.map +1 -0
  136. package/dist/{HonoEndpointAdaptor-BaPlUhz0.d.mts → HonoEndpointAdaptor-HukjdF6M.d.mts} +11 -6
  137. package/dist/HonoEndpointAdaptor-HukjdF6M.d.mts.map +1 -0
  138. package/dist/{Subscriber-COYMSevD.d.cts → Subscriber--zUjZDR6.d.cts} +1 -1
  139. package/dist/Subscriber--zUjZDR6.d.cts.map +1 -0
  140. package/dist/{Subscriber-ikctpU3I.d.mts → Subscriber-0Ac7cXID.d.mts} +2 -2
  141. package/dist/Subscriber-0Ac7cXID.d.mts.map +1 -0
  142. package/dist/{Subscriber-BmPf9GFb.mjs → Subscriber-BgZ8T-O2.mjs} +2 -2
  143. package/dist/Subscriber-BgZ8T-O2.mjs.map +1 -0
  144. package/dist/{Subscriber-BiHjVXtM.cjs → Subscriber-CoFmHMIM.cjs} +2 -2
  145. package/dist/Subscriber-CoFmHMIM.cjs.map +1 -0
  146. package/dist/{SubscriberBuilder-D_9zzllj.d.mts → SubscriberBuilder-D8cmUHee.d.mts} +2 -2
  147. package/dist/SubscriberBuilder-D8cmUHee.d.mts.map +1 -0
  148. package/dist/{SubscriberBuilder-DJPEeYDJ.mjs → SubscriberBuilder-DWXWZBPo.mjs} +2 -2
  149. package/dist/SubscriberBuilder-DWXWZBPo.mjs.map +1 -0
  150. package/dist/{SubscriberBuilder-ivHAGIVi.d.cts → SubscriberBuilder-DciTqb-7.d.cts} +2 -2
  151. package/dist/SubscriberBuilder-DciTqb-7.d.cts.map +1 -0
  152. package/dist/{SubscriberBuilder-Cp1C-xtT.cjs → SubscriberBuilder-JlxhyqGp.cjs} +2 -2
  153. package/dist/SubscriberBuilder-JlxhyqGp.cjs.map +1 -0
  154. package/dist/{TestEndpointAdaptor-DB7bREhS.d.mts → TestEndpointAdaptor-Boijwbmz.d.mts} +4 -4
  155. package/dist/TestEndpointAdaptor-Boijwbmz.d.mts.map +1 -0
  156. package/dist/{TestEndpointAdaptor-C10xBI--.d.cts → TestEndpointAdaptor-DdwpRyNh.d.cts} +3 -3
  157. package/dist/TestEndpointAdaptor-DdwpRyNh.d.cts.map +1 -0
  158. package/dist/TestEndpointAdaptor-Dk75ExxE.cjs +176 -0
  159. package/dist/TestEndpointAdaptor-Dk75ExxE.cjs.map +1 -0
  160. package/dist/TestEndpointAdaptor-OiA2JLDp.mjs +170 -0
  161. package/dist/TestEndpointAdaptor-OiA2JLDp.mjs.map +1 -0
  162. package/dist/adaptors/aws.cjs +12 -12
  163. package/dist/adaptors/aws.d.cts +13 -12
  164. package/dist/adaptors/aws.d.mts +16 -15
  165. package/dist/adaptors/aws.mjs +12 -12
  166. package/dist/adaptors/hono.cjs +10 -9
  167. package/dist/adaptors/hono.d.cts +6 -6
  168. package/dist/adaptors/hono.d.mts +9 -9
  169. package/dist/adaptors/hono.mjs +10 -9
  170. package/dist/adaptors/testing.cjs +8 -7
  171. package/dist/adaptors/testing.d.cts +6 -6
  172. package/dist/adaptors/testing.d.mts +9 -9
  173. package/dist/adaptors/testing.mjs +8 -7
  174. package/dist/crons/Cron.cjs +6 -6
  175. package/dist/crons/Cron.d.cts +4 -4
  176. package/dist/crons/Cron.d.mts +6 -6
  177. package/dist/crons/Cron.mjs +6 -6
  178. package/dist/crons/CronBuilder.cjs +7 -7
  179. package/dist/crons/CronBuilder.d.cts +5 -5
  180. package/dist/crons/CronBuilder.d.mts +7 -7
  181. package/dist/crons/CronBuilder.mjs +7 -7
  182. package/dist/crons/index.cjs +7 -7
  183. package/dist/crons/index.cjs.map +1 -1
  184. package/dist/crons/index.d.cts +9 -9
  185. package/dist/crons/index.d.mts +7 -7
  186. package/dist/crons/index.mjs +7 -7
  187. package/dist/crons/index.mjs.map +1 -1
  188. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +7 -7
  189. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +8 -7
  190. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +11 -10
  191. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +7 -7
  192. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +8 -8
  193. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +8 -7
  194. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +11 -10
  195. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +8 -8
  196. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +8 -8
  197. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +9 -8
  198. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +12 -11
  199. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +8 -8
  200. package/dist/endpoints/Authorizer.cjs +1 -1
  201. package/dist/endpoints/Authorizer.d.cts +1 -1
  202. package/dist/endpoints/Authorizer.d.mts +1 -1
  203. package/dist/endpoints/Authorizer.mjs +1 -1
  204. package/dist/endpoints/Endpoint.cjs +6 -6
  205. package/dist/endpoints/Endpoint.d.cts +5 -5
  206. package/dist/endpoints/Endpoint.d.mts +8 -8
  207. package/dist/endpoints/Endpoint.mjs +6 -6
  208. package/dist/endpoints/EndpointBuilder.cjs +9 -9
  209. package/dist/endpoints/EndpointBuilder.d.cts +6 -6
  210. package/dist/endpoints/EndpointBuilder.d.mts +9 -9
  211. package/dist/endpoints/EndpointBuilder.mjs +9 -9
  212. package/dist/endpoints/EndpointFactory.cjs +10 -10
  213. package/dist/endpoints/EndpointFactory.d.cts +7 -7
  214. package/dist/endpoints/EndpointFactory.d.mts +10 -10
  215. package/dist/endpoints/EndpointFactory.mjs +10 -10
  216. package/dist/endpoints/HonoEndpointAdaptor.cjs +10 -9
  217. package/dist/endpoints/HonoEndpointAdaptor.d.cts +6 -6
  218. package/dist/endpoints/HonoEndpointAdaptor.d.mts +9 -9
  219. package/dist/endpoints/HonoEndpointAdaptor.mjs +10 -9
  220. package/dist/endpoints/TestEndpointAdaptor.cjs +8 -7
  221. package/dist/endpoints/TestEndpointAdaptor.d.cts +6 -6
  222. package/dist/endpoints/TestEndpointAdaptor.d.mts +9 -9
  223. package/dist/endpoints/TestEndpointAdaptor.mjs +8 -7
  224. package/dist/endpoints/audit.d.cts +5 -5
  225. package/dist/endpoints/audit.d.mts +8 -8
  226. package/dist/endpoints/helpers.cjs +7 -7
  227. package/dist/endpoints/helpers.d.cts +5 -5
  228. package/dist/endpoints/helpers.d.cts.map +1 -1
  229. package/dist/endpoints/helpers.d.mts +8 -8
  230. package/dist/endpoints/helpers.d.mts.map +1 -1
  231. package/dist/endpoints/helpers.mjs +7 -7
  232. package/dist/endpoints/index.cjs +20 -10
  233. package/dist/endpoints/index.cjs.map +1 -1
  234. package/dist/endpoints/index.d.cts +12 -10
  235. package/dist/endpoints/index.d.cts.map +1 -1
  236. package/dist/endpoints/index.d.mts +15 -13
  237. package/dist/endpoints/index.d.mts.map +1 -1
  238. package/dist/endpoints/index.mjs +13 -11
  239. package/dist/endpoints/index.mjs.map +1 -1
  240. package/dist/endpoints/lazyAccessors.cjs +10 -0
  241. package/dist/endpoints/lazyAccessors.d.cts +10 -0
  242. package/dist/endpoints/lazyAccessors.d.mts +10 -0
  243. package/dist/endpoints/lazyAccessors.mjs +3 -0
  244. package/dist/endpoints/parseHonoQuery.cjs +1 -1
  245. package/dist/endpoints/parseHonoQuery.mjs +1 -1
  246. package/dist/endpoints/parseQueryParams.d.cts.map +1 -1
  247. package/dist/endpoints/parseQueryParams.d.mts.map +1 -1
  248. package/dist/endpoints/processAudits.d.cts +5 -5
  249. package/dist/endpoints/processAudits.d.cts.map +1 -1
  250. package/dist/endpoints/processAudits.d.mts +8 -8
  251. package/dist/endpoints/processAudits.d.mts.map +1 -1
  252. package/dist/endpoints/rls.cjs +1 -1
  253. package/dist/endpoints/rls.d.cts +5 -5
  254. package/dist/endpoints/rls.d.mts +8 -8
  255. package/dist/endpoints/rls.mjs +1 -1
  256. package/dist/functions/AWSLambdaFunction.cjs +6 -6
  257. package/dist/functions/AWSLambdaFunction.d.cts +3 -3
  258. package/dist/functions/AWSLambdaFunction.d.mts +4 -4
  259. package/dist/functions/AWSLambdaFunction.mjs +6 -6
  260. package/dist/functions/BaseFunctionBuilder.cjs +2 -2
  261. package/dist/functions/BaseFunctionBuilder.d.mts +2 -2
  262. package/dist/functions/BaseFunctionBuilder.mjs +2 -2
  263. package/dist/functions/Function.cjs +2 -2
  264. package/dist/functions/Function.d.cts +1 -1
  265. package/dist/functions/Function.d.mts +2 -2
  266. package/dist/functions/Function.mjs +2 -2
  267. package/dist/functions/FunctionBuilder.cjs +4 -4
  268. package/dist/functions/FunctionBuilder.d.cts +2 -2
  269. package/dist/functions/FunctionBuilder.d.mts +4 -4
  270. package/dist/functions/FunctionBuilder.mjs +4 -4
  271. package/dist/functions/FunctionExecutionWrapper.cjs +5 -5
  272. package/dist/functions/FunctionExecutionWrapper.d.cts +2 -2
  273. package/dist/functions/FunctionExecutionWrapper.d.mts +3 -3
  274. package/dist/functions/FunctionExecutionWrapper.mjs +5 -5
  275. package/dist/functions/TestFunctionAdaptor.cjs +7 -7
  276. package/dist/functions/TestFunctionAdaptor.cjs.map +1 -1
  277. package/dist/functions/TestFunctionAdaptor.d.cts +2 -2
  278. package/dist/functions/TestFunctionAdaptor.d.cts.map +1 -1
  279. package/dist/functions/TestFunctionAdaptor.d.mts +3 -3
  280. package/dist/functions/TestFunctionAdaptor.d.mts.map +1 -1
  281. package/dist/functions/TestFunctionAdaptor.mjs +7 -7
  282. package/dist/functions/TestFunctionAdaptor.mjs.map +1 -1
  283. package/dist/functions/index.cjs +5 -5
  284. package/dist/functions/index.d.cts +3 -3
  285. package/dist/functions/index.d.mts +5 -5
  286. package/dist/functions/index.mjs +5 -5
  287. package/dist/{functions-fTid0RMK.cjs → functions-BkKXVeHm.cjs} +2 -2
  288. package/dist/functions-BkKXVeHm.cjs.map +1 -0
  289. package/dist/functions-C3A1vMRW.mjs +8 -0
  290. package/dist/functions-C3A1vMRW.mjs.map +1 -0
  291. package/dist/{helpers-BcP1tXAi.cjs → helpers-BelEzV4U.cjs} +2 -2
  292. package/dist/helpers-BelEzV4U.cjs.map +1 -0
  293. package/dist/{helpers-ByRTDO_m.mjs → helpers-DgsMFMUV.mjs} +2 -2
  294. package/dist/helpers-DgsMFMUV.mjs.map +1 -0
  295. package/dist/{index-BWzGIj06.d.mts → index-CgAQHr3f.d.mts} +2 -2
  296. package/dist/index-CgAQHr3f.d.mts.map +1 -0
  297. package/dist/index-D0fp_IK1.d.cts +12 -0
  298. package/dist/index-D0fp_IK1.d.cts.map +1 -0
  299. package/dist/index.cjs +1 -1
  300. package/dist/index.d.cts +2 -1
  301. package/dist/index.d.mts +4 -3
  302. package/dist/index.mjs +1 -1
  303. package/dist/lazyAccessors-B-Jgkg2o.mjs +175 -0
  304. package/dist/lazyAccessors-B-Jgkg2o.mjs.map +1 -0
  305. package/dist/lazyAccessors-B2ILzU-j.d.mts +49 -0
  306. package/dist/lazyAccessors-B2ILzU-j.d.mts.map +1 -0
  307. package/dist/lazyAccessors-B8Hhras9.cjs +223 -0
  308. package/dist/lazyAccessors-B8Hhras9.cjs.map +1 -0
  309. package/dist/lazyAccessors-Bcpi06ed.d.cts +49 -0
  310. package/dist/lazyAccessors-Bcpi06ed.d.cts.map +1 -0
  311. package/dist/{parseHonoQuery-CZC5_97v.cjs → parseHonoQuery-D4MhxTRc.cjs} +1 -1
  312. package/dist/parseHonoQuery-D4MhxTRc.cjs.map +1 -0
  313. package/dist/{parseHonoQuery-DDgIkTO4.mjs → parseHonoQuery-DpK3sGPc.mjs} +1 -1
  314. package/dist/parseHonoQuery-DpK3sGPc.mjs.map +1 -0
  315. package/dist/parseQueryParams-BSNkjmZ9.cjs.map +1 -1
  316. package/dist/parseQueryParams-UMTRnRrW.mjs.map +1 -1
  317. package/dist/processAudits-CzHkPokQ.cjs.map +1 -1
  318. package/dist/processAudits-Dj8UGqcW.mjs.map +1 -1
  319. package/dist/publisher-Bw4770Hi.mjs.map +1 -1
  320. package/dist/publisher-C4BhHB5I.d.cts +16 -0
  321. package/dist/publisher-C4BhHB5I.d.cts.map +1 -0
  322. package/dist/publisher-NE-GnXL8.d.mts +16 -0
  323. package/dist/publisher-NE-GnXL8.d.mts.map +1 -0
  324. package/dist/publisher-lFQleddL.cjs.map +1 -1
  325. package/dist/publisher.d.cts +3 -16
  326. package/dist/publisher.d.mts +3 -16
  327. package/dist/{rls-CmJ7bRsz.cjs → rls-BrywnrQb.cjs} +1 -1
  328. package/dist/{rls-CmJ7bRsz.cjs.map → rls-BrywnrQb.cjs.map} +1 -1
  329. package/dist/{rls-Bf3FRwto.mjs → rls-C0cWOnk4.mjs} +1 -1
  330. package/dist/{rls-Bf3FRwto.mjs.map → rls-C0cWOnk4.mjs.map} +1 -1
  331. package/dist/subscribers/AWSLambdaSubscriberAdaptor.cjs +1 -1
  332. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +2 -2
  333. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +3 -3
  334. package/dist/subscribers/AWSLambdaSubscriberAdaptor.mjs +1 -1
  335. package/dist/subscribers/Subscriber.cjs +2 -2
  336. package/dist/subscribers/Subscriber.d.cts +1 -1
  337. package/dist/subscribers/Subscriber.d.mts +2 -2
  338. package/dist/subscribers/Subscriber.mjs +2 -2
  339. package/dist/subscribers/SubscriberBuilder.cjs +3 -3
  340. package/dist/subscribers/SubscriberBuilder.d.cts +2 -2
  341. package/dist/subscribers/SubscriberBuilder.d.mts +3 -3
  342. package/dist/subscribers/SubscriberBuilder.mjs +3 -3
  343. package/dist/subscribers/index.cjs +3 -3
  344. package/dist/subscribers/index.cjs.map +1 -1
  345. package/dist/subscribers/index.d.cts +4 -4
  346. package/dist/subscribers/index.d.cts.map +1 -1
  347. package/dist/subscribers/index.d.mts +3 -3
  348. package/dist/subscribers/index.d.mts.map +1 -1
  349. package/dist/subscribers/index.mjs +3 -3
  350. package/dist/subscribers/index.mjs.map +1 -1
  351. package/dist/telemetry-BTaiRqPo.d.cts +95 -0
  352. package/dist/telemetry-BTaiRqPo.d.cts.map +1 -0
  353. package/dist/telemetry-yAHf5yDs.d.mts +95 -0
  354. package/dist/telemetry-yAHf5yDs.d.mts.map +1 -0
  355. package/dist/telemetry.cjs +0 -0
  356. package/dist/telemetry.d.cts +2 -0
  357. package/dist/telemetry.d.mts +2 -0
  358. package/dist/telemetry.mjs +0 -0
  359. package/dist/types-B5H3piDg.d.cts.map +1 -1
  360. package/dist/{types-DdIlpxAd.d.mts → types-Dw-iLd3Y.d.mts} +1 -1
  361. package/dist/types-Dw-iLd3Y.d.mts.map +1 -0
  362. package/dist/types.d.mts +1 -1
  363. package/package.json +18 -18
  364. package/src/Construct.ts +117 -86
  365. package/src/__benchmarks__/build-time-optimization.bench.ts +274 -0
  366. package/src/__benchmarks__/endpoint.bench.ts +375 -375
  367. package/src/__benchmarks__/fixtures.ts +241 -0
  368. package/src/__benchmarks__/hono-adaptor.bench.ts +533 -0
  369. package/src/__benchmarks__/hono-server.bench.ts +206 -206
  370. package/src/__benchmarks__/response-builder.bench.ts +428 -0
  371. package/src/__benchmarks__/strategies/strategy-a-lazy-services.ts +319 -0
  372. package/src/__benchmarks__/strategies/strategy-c-middleware.ts +530 -0
  373. package/src/__benchmarks__/strategies/strategy-d-opt-in-events.ts +567 -0
  374. package/src/__tests__/Construct.environment.spec.ts +349 -350
  375. package/src/__tests__/publisher.setting.spec.ts +496 -499
  376. package/src/__tests__/publisher.spec.ts +440 -442
  377. package/src/crons/Cron.ts +117 -117
  378. package/src/crons/CronBuilder.ts +237 -238
  379. package/src/crons/__tests__/Cron.spec.ts +448 -448
  380. package/src/crons/__tests__/CronBuilder.state-isolation.spec.ts +214 -214
  381. package/src/crons/index.ts +4 -4
  382. package/src/endpoints/AmazonApiGatewayEndpointAdaptor.ts +571 -463
  383. package/src/endpoints/AmazonApiGatewayV1EndpointAdaptor.ts +86 -86
  384. package/src/endpoints/AmazonApiGatewayV2EndpointAdaptor.ts +85 -81
  385. package/src/endpoints/Authorizer.ts +100 -100
  386. package/src/endpoints/Endpoint.ts +921 -937
  387. package/src/endpoints/EndpointBuilder.ts +703 -703
  388. package/src/endpoints/EndpointFactory.ts +1054 -1056
  389. package/src/endpoints/HonoEndpointAdaptor.ts +621 -548
  390. package/src/endpoints/TestEndpointAdaptor.ts +372 -353
  391. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.audits.spec.ts +499 -0
  392. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.events.spec.ts +541 -542
  393. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.spec.ts +1172 -1174
  394. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.audits.spec.ts +599 -599
  395. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.events.spec.ts +710 -710
  396. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.factory-publisher.spec.ts +280 -280
  397. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.kysely-audit.integration.spec.ts +924 -730
  398. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.rls.spec.ts +307 -0
  399. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.spec.ts +408 -408
  400. package/src/endpoints/__tests__/Authorizer.spec.ts +286 -0
  401. package/src/endpoints/__tests__/Endpoint.cookies.spec.ts +162 -162
  402. package/src/endpoints/__tests__/Endpoint.headers.spec.ts +182 -182
  403. package/src/endpoints/__tests__/Endpoint.manifest.spec.ts +158 -159
  404. package/src/endpoints/__tests__/Endpoint.spec.ts +819 -822
  405. package/src/endpoints/__tests__/EndpointBuilder.audit.spec.ts +427 -427
  406. package/src/endpoints/__tests__/EndpointBuilder.spec.ts +478 -478
  407. package/src/endpoints/__tests__/EndpointFactory.authorizers.spec.ts +426 -426
  408. package/src/endpoints/__tests__/EndpointFactory.database-auditor.spec.ts +501 -501
  409. package/src/endpoints/__tests__/EndpointFactory.reference-audit.spec.ts +177 -177
  410. package/src/endpoints/__tests__/EndpointFactory.spec.ts +471 -471
  411. package/src/endpoints/__tests__/EndpointFactory.state-isolation.spec.ts +143 -143
  412. package/src/endpoints/__tests__/HonoEndpointAdaptor.audit-transactions.spec.ts +663 -663
  413. package/src/endpoints/__tests__/HonoEndpointAdaptor.audits.spec.ts +608 -608
  414. package/src/endpoints/__tests__/HonoEndpointAdaptor.events.spec.ts +561 -561
  415. package/src/endpoints/__tests__/HonoEndpointAdaptor.kysely-audit.integration.spec.ts +1036 -1036
  416. package/src/endpoints/__tests__/HonoEndpointAdaptor.openapi.spec.ts +278 -278
  417. package/src/endpoints/__tests__/HonoEndpointAdaptor.spec.ts +1093 -1093
  418. package/src/endpoints/__tests__/ResponseBuilder.spec.ts +230 -230
  419. package/src/endpoints/__tests__/TestEndpointAdaptor.audits.spec.ts +569 -569
  420. package/src/endpoints/__tests__/TestEndpointAdaptor.spec.ts +841 -841
  421. package/src/endpoints/__tests__/endpoint-types.test.ts +68 -68
  422. package/src/endpoints/__tests__/helpers.spec.ts +37 -0
  423. package/src/endpoints/__tests__/lazyAccessors.spec.ts +330 -0
  424. package/src/endpoints/__tests__/processAudits.spec.ts +631 -0
  425. package/src/endpoints/audit.ts +51 -51
  426. package/src/endpoints/helpers.ts +34 -35
  427. package/src/endpoints/index.ts +33 -23
  428. package/src/endpoints/lazyAccessors.ts +241 -0
  429. package/src/endpoints/parseHonoQuery.ts +41 -41
  430. package/src/endpoints/parseQueryParams.ts +36 -36
  431. package/src/endpoints/processAudits.ts +269 -269
  432. package/src/endpoints/rls.ts +16 -16
  433. package/src/functions/AWSLambdaFunction.ts +294 -295
  434. package/src/functions/BaseFunctionBuilder.ts +185 -185
  435. package/src/functions/Function.ts +190 -190
  436. package/src/functions/FunctionBuilder.ts +353 -353
  437. package/src/functions/FunctionExecutionWrapper.ts +199 -200
  438. package/src/functions/TestFunctionAdaptor.ts +191 -191
  439. package/src/functions/__tests__/AWSLambdaFunctionAdaptor.spec.ts +424 -424
  440. package/src/functions/__tests__/Function.audits.spec.ts +364 -364
  441. package/src/functions/__tests__/Function.spec.ts +453 -454
  442. package/src/functions/__tests__/FunctionBuilder.state-isolation.spec.ts +179 -179
  443. package/src/functions/__tests__/TestFunctionAdaptor.spec.ts +369 -369
  444. package/src/functions/index.ts +6 -4
  445. package/src/index.ts +13 -9
  446. package/src/publisher.ts +71 -72
  447. package/src/subscribers/AWSLambdaSubscriberAdaptor.ts +244 -248
  448. package/src/subscribers/Subscriber.ts +82 -84
  449. package/src/subscribers/SubscriberBuilder.ts +129 -129
  450. package/src/subscribers/__tests__/AWSLambdaSubscriberAdaptor.spec.ts +589 -589
  451. package/src/subscribers/__tests__/Subscriber.spec.ts +402 -404
  452. package/src/subscribers/index.ts +1 -0
  453. package/src/telemetry.ts +103 -0
  454. package/src/types.ts +7 -7
  455. package/test.ts +58 -59
  456. package/dist/AWSLambdaFunction-BdebRMUh.d.mts.map +0 -1
  457. package/dist/AWSLambdaFunction-C54a1doJ.mjs.map +0 -1
  458. package/dist/AWSLambdaFunction-D0tEOTXQ.d.cts.map +0 -1
  459. package/dist/AWSLambdaFunction-EPGY4s7i.cjs.map +0 -1
  460. package/dist/AWSLambdaSubscriberAdaptor-BLfO612H.mjs.map +0 -1
  461. package/dist/AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs.map +0 -1
  462. package/dist/AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts.map +0 -1
  463. package/dist/AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts.map +0 -1
  464. package/dist/AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs.map +0 -1
  465. package/dist/AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts.map +0 -1
  466. package/dist/AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs.map +0 -1
  467. package/dist/AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts.map +0 -1
  468. package/dist/AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs.map +0 -1
  469. package/dist/AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs.map +0 -1
  470. package/dist/AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts.map +0 -1
  471. package/dist/AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts.map +0 -1
  472. package/dist/AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs.map +0 -1
  473. package/dist/AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts.map +0 -1
  474. package/dist/AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts.map +0 -1
  475. package/dist/AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs.map +0 -1
  476. package/dist/Authorizer-B-btowNd.d.cts.map +0 -1
  477. package/dist/Authorizer-C0ge_tc8.cjs.map +0 -1
  478. package/dist/Authorizer-gWxYsGEp.d.mts.map +0 -1
  479. package/dist/Authorizer-r9U3y_ms.mjs.map +0 -1
  480. package/dist/BaseFunctionBuilder-Czi1Jwza.mjs.map +0 -1
  481. package/dist/BaseFunctionBuilder-DRY419e7.d.mts.map +0 -1
  482. package/dist/BaseFunctionBuilder-MYG3C9ug.cjs.map +0 -1
  483. package/dist/Construct-Ba5cMxib.cjs.map +0 -1
  484. package/dist/Construct-DdyGHuag.mjs.map +0 -1
  485. package/dist/Construct-XrijZFFh.d.mts.map +0 -1
  486. package/dist/Cron-BxhGs5up.mjs.map +0 -1
  487. package/dist/Cron-CGF4YAfM.cjs.map +0 -1
  488. package/dist/Cron-bDLcTvV5.d.cts.map +0 -1
  489. package/dist/Cron-cdjlSKNp.d.mts.map +0 -1
  490. package/dist/CronBuilder-BC4m5-p1.d.mts.map +0 -1
  491. package/dist/CronBuilder-CcxKRtVP.cjs.map +0 -1
  492. package/dist/CronBuilder-DKVXyE0Q.d.cts.map +0 -1
  493. package/dist/CronBuilder-d2jh-IB2.mjs.map +0 -1
  494. package/dist/Endpoint-BPv9_-m_.d.cts.map +0 -1
  495. package/dist/Endpoint-BVGZXFyV.cjs.map +0 -1
  496. package/dist/Endpoint-BdwG75G_.d.mts.map +0 -1
  497. package/dist/Endpoint-CuOEswxJ.mjs.map +0 -1
  498. package/dist/EndpointBuilder-B3az942t.d.mts.map +0 -1
  499. package/dist/EndpointBuilder-Cgj1P_ra.cjs.map +0 -1
  500. package/dist/EndpointBuilder-DIy_m1bu.d.cts.map +0 -1
  501. package/dist/EndpointBuilder-DnCB1h1j.mjs.map +0 -1
  502. package/dist/EndpointFactory-C-0nE6Jg.d.mts.map +0 -1
  503. package/dist/EndpointFactory-CYj6BYok.cjs.map +0 -1
  504. package/dist/EndpointFactory-CbdxPCIH.mjs.map +0 -1
  505. package/dist/EndpointFactory-CyPbm3AD.d.cts.map +0 -1
  506. package/dist/Function-BVHqIDp9.mjs.map +0 -1
  507. package/dist/Function-Cf7f_kCz.d.cts.map +0 -1
  508. package/dist/Function-DDZb1525.cjs.map +0 -1
  509. package/dist/Function-DN2G6OT5.d.mts.map +0 -1
  510. package/dist/FunctionBuilder-CJBzzXL3.d.cts.map +0 -1
  511. package/dist/FunctionBuilder-CrDYgfiI.mjs.map +0 -1
  512. package/dist/FunctionBuilder-Cxx8D2na.d.mts.map +0 -1
  513. package/dist/FunctionBuilder-DswJ-9sD.cjs.map +0 -1
  514. package/dist/FunctionExecutionWrapper-BYI2bGTL.cjs.map +0 -1
  515. package/dist/FunctionExecutionWrapper-CLDh7Z2_.mjs.map +0 -1
  516. package/dist/FunctionExecutionWrapper-DF260Aaj.d.mts.map +0 -1
  517. package/dist/FunctionExecutionWrapper-Qy8bmgFR.d.cts.map +0 -1
  518. package/dist/HonoEndpointAdaptor-BaPlUhz0.d.mts.map +0 -1
  519. package/dist/HonoEndpointAdaptor-CQe2FqMR.cjs +0 -234
  520. package/dist/HonoEndpointAdaptor-CQe2FqMR.cjs.map +0 -1
  521. package/dist/HonoEndpointAdaptor-Ce-2HBxn.mjs +0 -228
  522. package/dist/HonoEndpointAdaptor-Ce-2HBxn.mjs.map +0 -1
  523. package/dist/HonoEndpointAdaptor-YcRHYALH.d.cts.map +0 -1
  524. package/dist/Subscriber-BiHjVXtM.cjs.map +0 -1
  525. package/dist/Subscriber-BmPf9GFb.mjs.map +0 -1
  526. package/dist/Subscriber-COYMSevD.d.cts.map +0 -1
  527. package/dist/Subscriber-ikctpU3I.d.mts.map +0 -1
  528. package/dist/SubscriberBuilder-Cp1C-xtT.cjs.map +0 -1
  529. package/dist/SubscriberBuilder-DJPEeYDJ.mjs.map +0 -1
  530. package/dist/SubscriberBuilder-D_9zzllj.d.mts.map +0 -1
  531. package/dist/SubscriberBuilder-ivHAGIVi.d.cts.map +0 -1
  532. package/dist/TestEndpointAdaptor-C10xBI--.d.cts.map +0 -1
  533. package/dist/TestEndpointAdaptor-DB7bREhS.d.mts.map +0 -1
  534. package/dist/TestEndpointAdaptor-DJgik2Wj.mjs +0 -160
  535. package/dist/TestEndpointAdaptor-DJgik2Wj.mjs.map +0 -1
  536. package/dist/TestEndpointAdaptor-ZbtQiuHE.cjs +0 -166
  537. package/dist/TestEndpointAdaptor-ZbtQiuHE.cjs.map +0 -1
  538. package/dist/functions-C6EK1xL6.mjs +0 -8
  539. package/dist/functions-C6EK1xL6.mjs.map +0 -1
  540. package/dist/functions-fTid0RMK.cjs.map +0 -1
  541. package/dist/helpers-BcP1tXAi.cjs.map +0 -1
  542. package/dist/helpers-ByRTDO_m.mjs.map +0 -1
  543. package/dist/index-BWzGIj06.d.mts.map +0 -1
  544. package/dist/index-DmFozqLd.d.cts +0 -12
  545. package/dist/index-DmFozqLd.d.cts.map +0 -1
  546. package/dist/parseHonoQuery-CZC5_97v.cjs.map +0 -1
  547. package/dist/parseHonoQuery-DDgIkTO4.mjs.map +0 -1
  548. package/dist/publisher.d.cts.map +0 -1
  549. package/dist/publisher.d.mts.map +0 -1
  550. package/dist/types-DdIlpxAd.d.mts.map +0 -1
@@ -1,7 +1,7 @@
1
1
  import type {
2
- AuditRecord,
3
- AuditStorage,
4
- AuditableAction,
2
+ AuditableAction,
3
+ AuditRecord,
4
+ AuditStorage,
5
5
  } from '@geekmidas/audit';
6
6
  import { EnvironmentParser } from '@geekmidas/envkit';
7
7
  import type { Logger } from '@geekmidas/logger';
@@ -10,26 +10,26 @@ import { ServiceDiscovery } from '@geekmidas/services';
10
10
  import { Hono } from 'hono';
11
11
  import { beforeEach, describe, expect, it, vi } from 'vitest';
12
12
  import { z } from 'zod';
13
+ import type { MappedAudit } from '../audit';
13
14
  import { Endpoint, type EndpointContext } from '../Endpoint';
14
15
  import { HonoEndpoint } from '../HonoEndpointAdaptor';
15
- import type { MappedAudit } from '../audit';
16
16
 
17
17
  /**
18
18
  * Mock transaction that simulates Kysely Transaction behavior.
19
19
  */
20
20
  class MockTransaction {
21
- isTransaction = true as const;
21
+ isTransaction = true as const;
22
22
 
23
- constructor(private db: MockDatabase) {}
23
+ constructor(private db: MockDatabase) {}
24
24
 
25
- insert(table: string, data: unknown) {
26
- this.db.pendingOperations.push({ type: `insert:${table}`, data });
27
- }
25
+ insert(table: string, data: unknown) {
26
+ this.db.pendingOperations.push({ type: `insert:${table}`, data });
27
+ }
28
28
 
29
- // Required by Kysely interface - nested transactions just return self
30
- transaction() {
31
- return this.db.transaction();
32
- }
29
+ // Required by Kysely interface - nested transactions just return self
30
+ transaction() {
31
+ return this.db.transaction();
32
+ }
33
33
  }
34
34
 
35
35
  /**
@@ -37,50 +37,50 @@ class MockTransaction {
37
37
  * Tracks all operations and can simulate rollbacks.
38
38
  */
39
39
  class MockDatabase {
40
- pendingOperations: Array<{ type: string; data: unknown }> = [];
41
- committedOperations: Array<{ type: string; data: unknown }> = [];
42
- isTransaction = false as const;
43
- shouldFailOnCommit = false;
44
-
45
- // Simulates db.transaction() returning a builder
46
- transaction() {
47
- const self = this;
48
- return {
49
- setIsolationLevel(_level: string) {
50
- return this;
51
- },
52
- async execute<T>(cb: (trx: MockTransaction) => Promise<T>): Promise<T> {
53
- const trx = new MockTransaction(self);
54
-
55
- try {
56
- const result = await cb(trx);
57
-
58
- if (self.shouldFailOnCommit) {
59
- throw new Error('Simulated commit failure');
60
- }
61
-
62
- // Commit: move pending operations to committed
63
- self.committedOperations.push(...self.pendingOperations);
64
- self.pendingOperations = [];
65
- return result;
66
- } catch (error) {
67
- // Rollback: discard pending operations
68
- self.pendingOperations = [];
69
- throw error;
70
- }
71
- },
72
- };
73
- }
74
-
75
- insert(table: string, data: unknown) {
76
- this.pendingOperations.push({ type: `insert:${table}`, data });
77
- }
78
-
79
- reset() {
80
- this.pendingOperations = [];
81
- this.committedOperations = [];
82
- this.shouldFailOnCommit = false;
83
- }
40
+ pendingOperations: Array<{ type: string; data: unknown }> = [];
41
+ committedOperations: Array<{ type: string; data: unknown }> = [];
42
+ isTransaction = false as const;
43
+ shouldFailOnCommit = false;
44
+
45
+ // Simulates db.transaction() returning a builder
46
+ transaction() {
47
+ const self = this;
48
+ return {
49
+ setIsolationLevel(_level: string) {
50
+ return this;
51
+ },
52
+ async execute<T>(cb: (trx: MockTransaction) => Promise<T>): Promise<T> {
53
+ const trx = new MockTransaction(self);
54
+
55
+ try {
56
+ const result = await cb(trx);
57
+
58
+ if (self.shouldFailOnCommit) {
59
+ throw new Error('Simulated commit failure');
60
+ }
61
+
62
+ // Commit: move pending operations to committed
63
+ self.committedOperations.push(...self.pendingOperations);
64
+ self.pendingOperations = [];
65
+ return result;
66
+ } catch (error) {
67
+ // Rollback: discard pending operations
68
+ self.pendingOperations = [];
69
+ throw error;
70
+ }
71
+ },
72
+ };
73
+ }
74
+
75
+ insert(table: string, data: unknown) {
76
+ this.pendingOperations.push({ type: `insert:${table}`, data });
77
+ }
78
+
79
+ reset() {
80
+ this.pendingOperations = [];
81
+ this.committedOperations = [];
82
+ this.shouldFailOnCommit = false;
83
+ }
84
84
  }
85
85
 
86
86
  /**
@@ -88,616 +88,616 @@ class MockDatabase {
88
88
  * Can be configured to fail on write to test rollback behavior.
89
89
  */
90
90
  class TransactionalAuditStorage implements AuditStorage {
91
- records: AuditRecord[] = [];
92
- shouldFailOnWrite = false;
93
- writeAttempts = 0;
94
-
95
- constructor(private db: MockDatabase) {}
96
-
97
- async write(records: AuditRecord[], trx?: unknown): Promise<void> {
98
- this.writeAttempts++;
99
-
100
- if (this.shouldFailOnWrite) {
101
- throw new Error('Simulated audit write failure');
102
- }
103
-
104
- // If we have a transaction, use it
105
- if (trx) {
106
- const mockTrx = trx as MockTransaction;
107
- for (const record of records) {
108
- mockTrx.insert('audit_logs', record);
109
- }
110
- }
111
-
112
- this.records.push(...records);
113
- }
114
-
115
- async query(): Promise<AuditRecord[]> {
116
- return this.records;
117
- }
118
-
119
- getDatabase(): MockDatabase {
120
- return this.db;
121
- }
122
-
123
- reset() {
124
- this.records = [];
125
- this.shouldFailOnWrite = false;
126
- this.writeAttempts = 0;
127
- }
91
+ records: AuditRecord[] = [];
92
+ shouldFailOnWrite = false;
93
+ writeAttempts = 0;
94
+
95
+ constructor(private db: MockDatabase) {}
96
+
97
+ async write(records: AuditRecord[], trx?: unknown): Promise<void> {
98
+ this.writeAttempts++;
99
+
100
+ if (this.shouldFailOnWrite) {
101
+ throw new Error('Simulated audit write failure');
102
+ }
103
+
104
+ // If we have a transaction, use it
105
+ if (trx) {
106
+ const mockTrx = trx as MockTransaction;
107
+ for (const record of records) {
108
+ mockTrx.insert('audit_logs', record);
109
+ }
110
+ }
111
+
112
+ this.records.push(...records);
113
+ }
114
+
115
+ async query(): Promise<AuditRecord[]> {
116
+ return this.records;
117
+ }
118
+
119
+ getDatabase(): MockDatabase {
120
+ return this.db;
121
+ }
122
+
123
+ reset() {
124
+ this.records = [];
125
+ this.shouldFailOnWrite = false;
126
+ this.writeAttempts = 0;
127
+ }
128
128
  }
129
129
 
130
130
  // Test audit action types
131
131
  type TestAuditAction =
132
- | AuditableAction<'user.created', { userId: string; email: string }>
133
- | AuditableAction<'user.updated', { userId: string; changes: string[] }>;
132
+ | AuditableAction<'user.created', { userId: string; email: string }>
133
+ | AuditableAction<'user.updated', { userId: string; changes: string[] }>;
134
134
 
135
135
  describe('HonoEndpoint Audit Transactions', () => {
136
- let mockDb: MockDatabase;
137
- let auditStorage: TransactionalAuditStorage;
138
- let mockLogger: Logger;
139
-
140
- const createMockLogger = (): Logger => ({
141
- debug: vi.fn(),
142
- info: vi.fn(),
143
- warn: vi.fn(),
144
- error: vi.fn(),
145
- fatal: vi.fn(),
146
- trace: vi.fn(),
147
- child: vi.fn(function (this: Logger) {
148
- return this;
149
- }),
150
- });
151
-
152
- const createServiceDiscovery = (logger: Logger) => {
153
- const envParser = new EnvironmentParser({});
154
- ServiceDiscovery.reset();
155
- return ServiceDiscovery.getInstance(logger, envParser);
156
- };
157
-
158
- beforeEach(() => {
159
- mockDb = new MockDatabase();
160
- auditStorage = new TransactionalAuditStorage(mockDb);
161
- mockLogger = createMockLogger();
162
- });
163
-
164
- describe('successful transactions', () => {
165
- it('should commit both handler operations and audits on success', async () => {
166
- const serviceDiscovery = createServiceDiscovery(mockLogger);
167
-
168
- const auditStorageService: Service<
169
- 'auditStorage',
170
- TransactionalAuditStorage
171
- > = {
172
- serviceName: 'auditStorage' as const,
173
- register: vi.fn().mockResolvedValue(auditStorage),
174
- };
175
-
176
- const outputSchema = z.object({ id: z.string(), email: z.string() });
177
-
178
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
179
- {
180
- type: 'user.created',
181
- payload: (response) => ({
182
- userId: response.id,
183
- email: response.email,
184
- }),
185
- },
186
- ];
187
-
188
- const endpoint = new Endpoint({
189
- route: '/users',
190
- method: 'POST',
191
- fn: async () => {
192
- // Simulate handler database operation
193
- mockDb.insert('users', { id: '123', email: 'test@example.com' });
194
- return { id: '123', email: 'test@example.com' };
195
- },
196
- input: undefined,
197
- output: outputSchema,
198
- services: [],
199
- logger: mockLogger,
200
- timeout: undefined,
201
- memorySize: undefined,
202
- status: 201,
203
- getSession: undefined,
204
- authorize: undefined,
205
- description: undefined,
206
- events: [],
207
- publisherService: undefined,
208
- auditorStorageService: auditStorageService,
209
- audits,
210
- });
211
-
212
- const adaptor = new HonoEndpoint(endpoint);
213
- const app = new Hono();
214
- HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
215
- adaptor.addRoute(serviceDiscovery, app);
216
-
217
- const response = await app.request('/users', {
218
- method: 'POST',
219
- body: JSON.stringify({}),
220
- headers: { 'Content-Type': 'application/json' },
221
- });
222
-
223
- expect(response.status).toBe(201);
224
-
225
- // Both handler operations and audits should be committed
226
- expect(auditStorage.records).toHaveLength(1);
227
- expect(auditStorage.records[0].type).toBe('user.created');
228
- });
229
- });
230
-
231
- describe('handler failure rollback', () => {
232
- it('should not write audits when handler throws an error', async () => {
233
- const serviceDiscovery = createServiceDiscovery(mockLogger);
234
-
235
- const auditStorageService: Service<
236
- 'auditStorage',
237
- TransactionalAuditStorage
238
- > = {
239
- serviceName: 'auditStorage' as const,
240
- register: vi.fn().mockResolvedValue(auditStorage),
241
- };
242
-
243
- const outputSchema = z.object({ id: z.string(), email: z.string() });
244
-
245
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
246
- {
247
- type: 'user.created',
248
- payload: (response) => ({
249
- userId: response.id,
250
- email: response.email,
251
- }),
252
- },
253
- ];
254
-
255
- const endpoint = new Endpoint({
256
- route: '/users',
257
- method: 'POST',
258
- fn: async () => {
259
- // Simulate handler database operation before failure
260
- mockDb.insert('users', { id: '123', email: 'test@example.com' });
261
- throw new Error('Handler failed after database operation');
262
- },
263
- input: undefined,
264
- output: outputSchema,
265
- services: [],
266
- logger: mockLogger,
267
- timeout: undefined,
268
- memorySize: undefined,
269
- status: 201,
270
- getSession: undefined,
271
- authorize: undefined,
272
- description: undefined,
273
- events: [],
274
- publisherService: undefined,
275
- auditorStorageService: auditStorageService,
276
- audits,
277
- });
278
-
279
- const adaptor = new HonoEndpoint(endpoint);
280
- const app = new Hono();
281
- HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
282
- adaptor.addRoute(serviceDiscovery, app);
283
-
284
- const response = await app.request('/users', {
285
- method: 'POST',
286
- body: JSON.stringify({}),
287
- headers: { 'Content-Type': 'application/json' },
288
- });
289
-
290
- // Handler error should result in 500
291
- expect(response.status).toBe(500);
292
-
293
- // No audits should be written when handler fails
294
- expect(auditStorage.records).toHaveLength(0);
295
-
296
- // Database operations should not be committed (rolled back)
297
- expect(mockDb.committedOperations).toHaveLength(0);
298
- });
299
-
300
- it('should not write audits when handler validation fails', async () => {
301
- const serviceDiscovery = createServiceDiscovery(mockLogger);
302
-
303
- const auditStorageService: Service<
304
- 'auditStorage',
305
- TransactionalAuditStorage
306
- > = {
307
- serviceName: 'auditStorage' as const,
308
- register: vi.fn().mockResolvedValue(auditStorage),
309
- };
310
-
311
- const outputSchema = z.object({
312
- id: z.string().min(10), // Will fail validation
313
- email: z.string().email(),
314
- });
315
-
316
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
317
- {
318
- type: 'user.created',
319
- payload: (response) => ({
320
- userId: response.id,
321
- email: response.email,
322
- }),
323
- },
324
- ];
325
-
326
- const endpoint = new Endpoint({
327
- route: '/users',
328
- method: 'POST',
329
- fn: async () => {
330
- mockDb.insert('users', { id: '123', email: 'test@example.com' });
331
- // Return value that fails output validation (id too short)
332
- return { id: '123', email: 'test@example.com' };
333
- },
334
- input: undefined,
335
- output: outputSchema,
336
- services: [],
337
- logger: mockLogger,
338
- timeout: undefined,
339
- memorySize: undefined,
340
- status: 201,
341
- getSession: undefined,
342
- authorize: undefined,
343
- description: undefined,
344
- events: [],
345
- publisherService: undefined,
346
- auditorStorageService: auditStorageService,
347
- audits,
348
- });
349
-
350
- const adaptor = new HonoEndpoint(endpoint);
351
- const app = new Hono();
352
- HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
353
- adaptor.addRoute(serviceDiscovery, app);
354
-
355
- const response = await app.request('/users', {
356
- method: 'POST',
357
- body: JSON.stringify({}),
358
- headers: { 'Content-Type': 'application/json' },
359
- });
360
-
361
- // Output validation error should result in 422
362
- expect(response.status).toBe(422);
363
-
364
- // No audits should be written when output validation fails
365
- expect(auditStorage.records).toHaveLength(0);
366
- });
367
- });
368
-
369
- describe('audit failure rollback', () => {
370
- it('should rollback handler operations when audit write fails', async () => {
371
- const serviceDiscovery = createServiceDiscovery(mockLogger);
372
-
373
- // Configure audit storage to fail
374
- auditStorage.shouldFailOnWrite = true;
375
-
376
- const auditStorageService: Service<
377
- 'auditStorage',
378
- TransactionalAuditStorage
379
- > = {
380
- serviceName: 'auditStorage' as const,
381
- register: vi.fn().mockResolvedValue(auditStorage),
382
- };
383
-
384
- const outputSchema = z.object({ id: z.string(), email: z.string() });
385
-
386
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
387
- {
388
- type: 'user.created',
389
- payload: (response) => ({
390
- userId: response.id,
391
- email: response.email,
392
- }),
393
- },
394
- ];
395
-
396
- const endpoint = new Endpoint({
397
- route: '/users',
398
- method: 'POST',
399
- fn: async () => {
400
- // This operation should be rolled back when audit fails
401
- mockDb.insert('users', { id: '123', email: 'test@example.com' });
402
- return { id: '123', email: 'test@example.com' };
403
- },
404
- input: undefined,
405
- output: outputSchema,
406
- services: [],
407
- logger: mockLogger,
408
- timeout: undefined,
409
- memorySize: undefined,
410
- status: 201,
411
- getSession: undefined,
412
- authorize: undefined,
413
- description: undefined,
414
- events: [],
415
- publisherService: undefined,
416
- auditorStorageService: auditStorageService,
417
- audits,
418
- });
419
-
420
- const adaptor = new HonoEndpoint(endpoint);
421
- const app = new Hono();
422
- HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
423
- adaptor.addRoute(serviceDiscovery, app);
424
-
425
- const response = await app.request('/users', {
426
- method: 'POST',
427
- body: JSON.stringify({}),
428
- headers: { 'Content-Type': 'application/json' },
429
- });
430
-
431
- // Audit failure should result in error response
432
- expect(response.status).toBe(500);
433
-
434
- // Audit write should have been attempted
435
- expect(auditStorage.writeAttempts).toBe(1);
436
-
437
- // No audits should be persisted
438
- expect(auditStorage.records).toHaveLength(0);
439
-
440
- // Handler database operations should not be committed (rolled back)
441
- expect(mockDb.committedOperations).toHaveLength(0);
442
- });
443
- });
444
-
445
- describe('manual audits in handler', () => {
446
- it('should include manual audits from handler in transaction', async () => {
447
- const serviceDiscovery = createServiceDiscovery(mockLogger);
448
-
449
- const registerFn = vi.fn().mockResolvedValue(auditStorage);
450
- const auditStorageService: Service<
451
- 'auditStorage',
452
- TransactionalAuditStorage
453
- > = {
454
- serviceName: 'auditStorage' as const,
455
- register: registerFn,
456
- };
457
-
458
- const outputSchema = z.object({ id: z.string(), email: z.string() });
459
-
460
- // No declarative audits - we'll use manual audits in the handler
461
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [];
462
-
463
- let auditorWasAvailable = false;
464
- let receivedCtxKeys: string[] = [];
465
-
466
- const endpoint = new Endpoint({
467
- route: '/users',
468
- method: 'POST',
469
- fn: async (
470
- ctx: EndpointContext<
471
- undefined,
472
- [],
473
- Logger,
474
- unknown,
475
- TestAuditAction,
476
- undefined,
477
- TransactionalAuditStorage
478
- >,
479
- ) => {
480
- receivedCtxKeys = Object.keys(ctx);
481
- mockDb.insert('users', { id: '123', email: 'test@example.com' });
482
-
483
- // Manual audit via auditor in context - auditor is guaranteed to exist
484
- auditorWasAvailable = true;
485
- ctx.auditor.audit('user.created', {
486
- userId: '123',
487
- email: 'test@example.com',
488
- });
489
-
490
- return { id: '123', email: 'test@example.com' };
491
- },
492
- input: undefined,
493
- output: outputSchema,
494
- services: [],
495
- logger: mockLogger,
496
- timeout: undefined,
497
- memorySize: undefined,
498
- status: 201,
499
- getSession: undefined,
500
- authorize: undefined,
501
- description: undefined,
502
- events: [],
503
- publisherService: undefined,
504
- auditorStorageService: auditStorageService,
505
- audits,
506
- });
507
-
508
- // Verify endpoint has auditorStorageService
509
- expect(endpoint.auditorStorageService).toBe(auditStorageService);
510
-
511
- const adaptor = new HonoEndpoint(endpoint);
512
- const app = new Hono();
513
- HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
514
- adaptor.addRoute(serviceDiscovery, app);
515
-
516
- const response = await app.request('/users', {
517
- method: 'POST',
518
- body: JSON.stringify({}),
519
- headers: { 'Content-Type': 'application/json' },
520
- });
521
-
522
- expect(response.status).toBe(201);
523
-
524
- // Verify service was registered
525
- expect(registerFn).toHaveBeenCalled();
526
-
527
- // Verify auditor key is in context
528
- expect(receivedCtxKeys).toContain('auditor');
529
-
530
- // Verify auditor was available in handler
531
- expect(auditorWasAvailable).toBe(true);
532
-
533
- // Manual audit should be written
534
- expect(auditStorage.records).toHaveLength(1);
535
- expect(auditStorage.records[0].type).toBe('user.created');
536
- expect(auditStorage.records[0].payload).toEqual({
537
- userId: '123',
538
- email: 'test@example.com',
539
- });
540
- });
541
-
542
- it('should rollback manual audits when handler fails after audit call', async () => {
543
- const serviceDiscovery = createServiceDiscovery(mockLogger);
544
-
545
- const auditStorageService: Service<
546
- 'auditStorage',
547
- TransactionalAuditStorage
548
- > = {
549
- serviceName: 'auditStorage' as const,
550
- register: vi.fn().mockResolvedValue(auditStorage),
551
- };
552
-
553
- const outputSchema = z.object({ id: z.string(), email: z.string() });
554
-
555
- const endpoint = new Endpoint({
556
- route: '/users',
557
- method: 'POST',
558
- fn: async (
559
- ctx: EndpointContext<
560
- undefined,
561
- [],
562
- Logger,
563
- unknown,
564
- TestAuditAction,
565
- undefined,
566
- TransactionalAuditStorage
567
- >,
568
- ) => {
569
- mockDb.insert('users', { id: '123', email: 'test@example.com' });
570
-
571
- // Manual audit before failure - auditor is guaranteed to exist
572
- ctx.auditor.audit('user.created', {
573
- userId: '123',
574
- email: 'test@example.com',
575
- });
576
-
577
- // Fail after audit was recorded (but not yet flushed)
578
- throw new Error('Handler failed after recording audit');
579
- },
580
- input: undefined,
581
- output: outputSchema,
582
- services: [],
583
- logger: mockLogger,
584
- timeout: undefined,
585
- memorySize: undefined,
586
- status: 201,
587
- getSession: undefined,
588
- authorize: undefined,
589
- description: undefined,
590
- events: [],
591
- publisherService: undefined,
592
- auditorStorageService: auditStorageService,
593
- audits: [],
594
- });
595
-
596
- const adaptor = new HonoEndpoint(endpoint);
597
- const app = new Hono();
598
- HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
599
- adaptor.addRoute(serviceDiscovery, app);
600
-
601
- const response = await app.request('/users', {
602
- method: 'POST',
603
- body: JSON.stringify({}),
604
- headers: { 'Content-Type': 'application/json' },
605
- });
606
-
607
- expect(response.status).toBe(500);
608
-
609
- // Manual audit should NOT be written because handler failed
610
- expect(auditStorage.records).toHaveLength(0);
611
-
612
- // Database operations should be rolled back
613
- expect(mockDb.committedOperations).toHaveLength(0);
614
- });
615
- });
616
-
617
- describe('combined declarative and manual audits', () => {
618
- it('should process both declarative and manual audits in same transaction', async () => {
619
- const serviceDiscovery = createServiceDiscovery(mockLogger);
620
-
621
- const auditStorageService: Service<
622
- 'auditStorage',
623
- TransactionalAuditStorage
624
- > = {
625
- serviceName: 'auditStorage' as const,
626
- register: vi.fn().mockResolvedValue(auditStorage),
627
- };
628
-
629
- const outputSchema = z.object({ id: z.string(), email: z.string() });
630
-
631
- // Declarative audit
632
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
633
- {
634
- type: 'user.created',
635
- payload: (response) => ({
636
- userId: response.id,
637
- email: response.email,
638
- }),
639
- },
640
- ];
641
-
642
- const endpoint = new Endpoint({
643
- route: '/users',
644
- method: 'POST',
645
- fn: async (
646
- ctx: EndpointContext<
647
- undefined,
648
- [],
649
- Logger,
650
- unknown,
651
- TestAuditAction,
652
- undefined,
653
- TransactionalAuditStorage
654
- >,
655
- ) => {
656
- mockDb.insert('users', { id: '123', email: 'test@example.com' });
657
-
658
- // Also add a manual audit - auditor is guaranteed to exist
659
- ctx.auditor.audit('user.updated', {
660
- userId: '123',
661
- changes: ['email_verified'],
662
- });
663
-
664
- return { id: '123', email: 'test@example.com' };
665
- },
666
- input: undefined,
667
- output: outputSchema,
668
- services: [],
669
- logger: mockLogger,
670
- timeout: undefined,
671
- memorySize: undefined,
672
- status: 201,
673
- getSession: undefined,
674
- authorize: undefined,
675
- description: undefined,
676
- events: [],
677
- publisherService: undefined,
678
- auditorStorageService: auditStorageService,
679
- audits,
680
- });
681
-
682
- const adaptor = new HonoEndpoint(endpoint);
683
- const app = new Hono();
684
- HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
685
- adaptor.addRoute(serviceDiscovery, app);
686
-
687
- const response = await app.request('/users', {
688
- method: 'POST',
689
- body: JSON.stringify({}),
690
- headers: { 'Content-Type': 'application/json' },
691
- });
692
-
693
- expect(response.status).toBe(201);
694
-
695
- // Both manual and declarative audits should be written
696
- expect(auditStorage.records).toHaveLength(2);
697
-
698
- const auditTypes = auditStorage.records.map((r) => r.type);
699
- expect(auditTypes).toContain('user.created'); // declarative
700
- expect(auditTypes).toContain('user.updated'); // manual
701
- });
702
- });
136
+ let mockDb: MockDatabase;
137
+ let auditStorage: TransactionalAuditStorage;
138
+ let mockLogger: Logger;
139
+
140
+ const createMockLogger = (): Logger => ({
141
+ debug: vi.fn(),
142
+ info: vi.fn(),
143
+ warn: vi.fn(),
144
+ error: vi.fn(),
145
+ fatal: vi.fn(),
146
+ trace: vi.fn(),
147
+ child: vi.fn(function (this: Logger) {
148
+ return this;
149
+ }),
150
+ });
151
+
152
+ const createServiceDiscovery = () => {
153
+ const envParser = new EnvironmentParser({});
154
+ ServiceDiscovery.reset();
155
+ return ServiceDiscovery.getInstance(envParser);
156
+ };
157
+
158
+ beforeEach(() => {
159
+ mockDb = new MockDatabase();
160
+ auditStorage = new TransactionalAuditStorage(mockDb);
161
+ mockLogger = createMockLogger();
162
+ });
163
+
164
+ describe('successful transactions', () => {
165
+ it('should commit both handler operations and audits on success', async () => {
166
+ const serviceDiscovery = createServiceDiscovery();
167
+
168
+ const auditStorageService: Service<
169
+ 'auditStorage',
170
+ TransactionalAuditStorage
171
+ > = {
172
+ serviceName: 'auditStorage' as const,
173
+ register: vi.fn().mockResolvedValue(auditStorage),
174
+ };
175
+
176
+ const outputSchema = z.object({ id: z.string(), email: z.string() });
177
+
178
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
179
+ {
180
+ type: 'user.created',
181
+ payload: (response) => ({
182
+ userId: response.id,
183
+ email: response.email,
184
+ }),
185
+ },
186
+ ];
187
+
188
+ const endpoint = new Endpoint({
189
+ route: '/users',
190
+ method: 'POST',
191
+ fn: async () => {
192
+ // Simulate handler database operation
193
+ mockDb.insert('users', { id: '123', email: 'test@example.com' });
194
+ return { id: '123', email: 'test@example.com' };
195
+ },
196
+ input: undefined,
197
+ output: outputSchema,
198
+ services: [],
199
+ logger: mockLogger,
200
+ timeout: undefined,
201
+ memorySize: undefined,
202
+ status: 201,
203
+ getSession: undefined,
204
+ authorize: undefined,
205
+ description: undefined,
206
+ events: [],
207
+ publisherService: undefined,
208
+ auditorStorageService: auditStorageService,
209
+ audits,
210
+ });
211
+
212
+ const adaptor = new HonoEndpoint(endpoint);
213
+ const app = new Hono();
214
+ HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
215
+ adaptor.addRoute(serviceDiscovery, app);
216
+
217
+ const response = await app.request('/users', {
218
+ method: 'POST',
219
+ body: JSON.stringify({}),
220
+ headers: { 'Content-Type': 'application/json' },
221
+ });
222
+
223
+ expect(response.status).toBe(201);
224
+
225
+ // Both handler operations and audits should be committed
226
+ expect(auditStorage.records).toHaveLength(1);
227
+ expect(auditStorage.records[0].type).toBe('user.created');
228
+ });
229
+ });
230
+
231
+ describe('handler failure rollback', () => {
232
+ it('should not write audits when handler throws an error', async () => {
233
+ const serviceDiscovery = createServiceDiscovery();
234
+
235
+ const auditStorageService: Service<
236
+ 'auditStorage',
237
+ TransactionalAuditStorage
238
+ > = {
239
+ serviceName: 'auditStorage' as const,
240
+ register: vi.fn().mockResolvedValue(auditStorage),
241
+ };
242
+
243
+ const outputSchema = z.object({ id: z.string(), email: z.string() });
244
+
245
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
246
+ {
247
+ type: 'user.created',
248
+ payload: (response) => ({
249
+ userId: response.id,
250
+ email: response.email,
251
+ }),
252
+ },
253
+ ];
254
+
255
+ const endpoint = new Endpoint({
256
+ route: '/users',
257
+ method: 'POST',
258
+ fn: async () => {
259
+ // Simulate handler database operation before failure
260
+ mockDb.insert('users', { id: '123', email: 'test@example.com' });
261
+ throw new Error('Handler failed after database operation');
262
+ },
263
+ input: undefined,
264
+ output: outputSchema,
265
+ services: [],
266
+ logger: mockLogger,
267
+ timeout: undefined,
268
+ memorySize: undefined,
269
+ status: 201,
270
+ getSession: undefined,
271
+ authorize: undefined,
272
+ description: undefined,
273
+ events: [],
274
+ publisherService: undefined,
275
+ auditorStorageService: auditStorageService,
276
+ audits,
277
+ });
278
+
279
+ const adaptor = new HonoEndpoint(endpoint);
280
+ const app = new Hono();
281
+ HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
282
+ adaptor.addRoute(serviceDiscovery, app);
283
+
284
+ const response = await app.request('/users', {
285
+ method: 'POST',
286
+ body: JSON.stringify({}),
287
+ headers: { 'Content-Type': 'application/json' },
288
+ });
289
+
290
+ // Handler error should result in 500
291
+ expect(response.status).toBe(500);
292
+
293
+ // No audits should be written when handler fails
294
+ expect(auditStorage.records).toHaveLength(0);
295
+
296
+ // Database operations should not be committed (rolled back)
297
+ expect(mockDb.committedOperations).toHaveLength(0);
298
+ });
299
+
300
+ it('should not write audits when handler validation fails', async () => {
301
+ const serviceDiscovery = createServiceDiscovery();
302
+
303
+ const auditStorageService: Service<
304
+ 'auditStorage',
305
+ TransactionalAuditStorage
306
+ > = {
307
+ serviceName: 'auditStorage' as const,
308
+ register: vi.fn().mockResolvedValue(auditStorage),
309
+ };
310
+
311
+ const outputSchema = z.object({
312
+ id: z.string().min(10), // Will fail validation
313
+ email: z.string().email(),
314
+ });
315
+
316
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
317
+ {
318
+ type: 'user.created',
319
+ payload: (response) => ({
320
+ userId: response.id,
321
+ email: response.email,
322
+ }),
323
+ },
324
+ ];
325
+
326
+ const endpoint = new Endpoint({
327
+ route: '/users',
328
+ method: 'POST',
329
+ fn: async () => {
330
+ mockDb.insert('users', { id: '123', email: 'test@example.com' });
331
+ // Return value that fails output validation (id too short)
332
+ return { id: '123', email: 'test@example.com' };
333
+ },
334
+ input: undefined,
335
+ output: outputSchema,
336
+ services: [],
337
+ logger: mockLogger,
338
+ timeout: undefined,
339
+ memorySize: undefined,
340
+ status: 201,
341
+ getSession: undefined,
342
+ authorize: undefined,
343
+ description: undefined,
344
+ events: [],
345
+ publisherService: undefined,
346
+ auditorStorageService: auditStorageService,
347
+ audits,
348
+ });
349
+
350
+ const adaptor = new HonoEndpoint(endpoint);
351
+ const app = new Hono();
352
+ HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
353
+ adaptor.addRoute(serviceDiscovery, app);
354
+
355
+ const response = await app.request('/users', {
356
+ method: 'POST',
357
+ body: JSON.stringify({}),
358
+ headers: { 'Content-Type': 'application/json' },
359
+ });
360
+
361
+ // Output validation error should result in 422
362
+ expect(response.status).toBe(422);
363
+
364
+ // No audits should be written when output validation fails
365
+ expect(auditStorage.records).toHaveLength(0);
366
+ });
367
+ });
368
+
369
+ describe('audit failure rollback', () => {
370
+ it('should rollback handler operations when audit write fails', async () => {
371
+ const serviceDiscovery = createServiceDiscovery();
372
+
373
+ // Configure audit storage to fail
374
+ auditStorage.shouldFailOnWrite = true;
375
+
376
+ const auditStorageService: Service<
377
+ 'auditStorage',
378
+ TransactionalAuditStorage
379
+ > = {
380
+ serviceName: 'auditStorage' as const,
381
+ register: vi.fn().mockResolvedValue(auditStorage),
382
+ };
383
+
384
+ const outputSchema = z.object({ id: z.string(), email: z.string() });
385
+
386
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
387
+ {
388
+ type: 'user.created',
389
+ payload: (response) => ({
390
+ userId: response.id,
391
+ email: response.email,
392
+ }),
393
+ },
394
+ ];
395
+
396
+ const endpoint = new Endpoint({
397
+ route: '/users',
398
+ method: 'POST',
399
+ fn: async () => {
400
+ // This operation should be rolled back when audit fails
401
+ mockDb.insert('users', { id: '123', email: 'test@example.com' });
402
+ return { id: '123', email: 'test@example.com' };
403
+ },
404
+ input: undefined,
405
+ output: outputSchema,
406
+ services: [],
407
+ logger: mockLogger,
408
+ timeout: undefined,
409
+ memorySize: undefined,
410
+ status: 201,
411
+ getSession: undefined,
412
+ authorize: undefined,
413
+ description: undefined,
414
+ events: [],
415
+ publisherService: undefined,
416
+ auditorStorageService: auditStorageService,
417
+ audits,
418
+ });
419
+
420
+ const adaptor = new HonoEndpoint(endpoint);
421
+ const app = new Hono();
422
+ HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
423
+ adaptor.addRoute(serviceDiscovery, app);
424
+
425
+ const response = await app.request('/users', {
426
+ method: 'POST',
427
+ body: JSON.stringify({}),
428
+ headers: { 'Content-Type': 'application/json' },
429
+ });
430
+
431
+ // Audit failure should result in error response
432
+ expect(response.status).toBe(500);
433
+
434
+ // Audit write should have been attempted
435
+ expect(auditStorage.writeAttempts).toBe(1);
436
+
437
+ // No audits should be persisted
438
+ expect(auditStorage.records).toHaveLength(0);
439
+
440
+ // Handler database operations should not be committed (rolled back)
441
+ expect(mockDb.committedOperations).toHaveLength(0);
442
+ });
443
+ });
444
+
445
+ describe('manual audits in handler', () => {
446
+ it('should include manual audits from handler in transaction', async () => {
447
+ const serviceDiscovery = createServiceDiscovery();
448
+
449
+ const registerFn = vi.fn().mockResolvedValue(auditStorage);
450
+ const auditStorageService: Service<
451
+ 'auditStorage',
452
+ TransactionalAuditStorage
453
+ > = {
454
+ serviceName: 'auditStorage' as const,
455
+ register: registerFn,
456
+ };
457
+
458
+ const outputSchema = z.object({ id: z.string(), email: z.string() });
459
+
460
+ // No declarative audits - we'll use manual audits in the handler
461
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [];
462
+
463
+ let auditorWasAvailable = false;
464
+ let receivedCtxKeys: string[] = [];
465
+
466
+ const endpoint = new Endpoint({
467
+ route: '/users',
468
+ method: 'POST',
469
+ fn: async (
470
+ ctx: EndpointContext<
471
+ undefined,
472
+ [],
473
+ Logger,
474
+ unknown,
475
+ TestAuditAction,
476
+ undefined,
477
+ TransactionalAuditStorage
478
+ >,
479
+ ) => {
480
+ receivedCtxKeys = Object.keys(ctx);
481
+ mockDb.insert('users', { id: '123', email: 'test@example.com' });
482
+
483
+ // Manual audit via auditor in context - auditor is guaranteed to exist
484
+ auditorWasAvailable = true;
485
+ ctx.auditor.audit('user.created', {
486
+ userId: '123',
487
+ email: 'test@example.com',
488
+ });
489
+
490
+ return { id: '123', email: 'test@example.com' };
491
+ },
492
+ input: undefined,
493
+ output: outputSchema,
494
+ services: [],
495
+ logger: mockLogger,
496
+ timeout: undefined,
497
+ memorySize: undefined,
498
+ status: 201,
499
+ getSession: undefined,
500
+ authorize: undefined,
501
+ description: undefined,
502
+ events: [],
503
+ publisherService: undefined,
504
+ auditorStorageService: auditStorageService,
505
+ audits,
506
+ });
507
+
508
+ // Verify endpoint has auditorStorageService
509
+ expect(endpoint.auditorStorageService).toBe(auditStorageService);
510
+
511
+ const adaptor = new HonoEndpoint(endpoint);
512
+ const app = new Hono();
513
+ HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
514
+ adaptor.addRoute(serviceDiscovery, app);
515
+
516
+ const response = await app.request('/users', {
517
+ method: 'POST',
518
+ body: JSON.stringify({}),
519
+ headers: { 'Content-Type': 'application/json' },
520
+ });
521
+
522
+ expect(response.status).toBe(201);
523
+
524
+ // Verify service was registered
525
+ expect(registerFn).toHaveBeenCalled();
526
+
527
+ // Verify auditor key is in context
528
+ expect(receivedCtxKeys).toContain('auditor');
529
+
530
+ // Verify auditor was available in handler
531
+ expect(auditorWasAvailable).toBe(true);
532
+
533
+ // Manual audit should be written
534
+ expect(auditStorage.records).toHaveLength(1);
535
+ expect(auditStorage.records[0].type).toBe('user.created');
536
+ expect(auditStorage.records[0].payload).toEqual({
537
+ userId: '123',
538
+ email: 'test@example.com',
539
+ });
540
+ });
541
+
542
+ it('should rollback manual audits when handler fails after audit call', async () => {
543
+ const serviceDiscovery = createServiceDiscovery();
544
+
545
+ const auditStorageService: Service<
546
+ 'auditStorage',
547
+ TransactionalAuditStorage
548
+ > = {
549
+ serviceName: 'auditStorage' as const,
550
+ register: vi.fn().mockResolvedValue(auditStorage),
551
+ };
552
+
553
+ const outputSchema = z.object({ id: z.string(), email: z.string() });
554
+
555
+ const endpoint = new Endpoint({
556
+ route: '/users',
557
+ method: 'POST',
558
+ fn: async (
559
+ ctx: EndpointContext<
560
+ undefined,
561
+ [],
562
+ Logger,
563
+ unknown,
564
+ TestAuditAction,
565
+ undefined,
566
+ TransactionalAuditStorage
567
+ >,
568
+ ) => {
569
+ mockDb.insert('users', { id: '123', email: 'test@example.com' });
570
+
571
+ // Manual audit before failure - auditor is guaranteed to exist
572
+ ctx.auditor.audit('user.created', {
573
+ userId: '123',
574
+ email: 'test@example.com',
575
+ });
576
+
577
+ // Fail after audit was recorded (but not yet flushed)
578
+ throw new Error('Handler failed after recording audit');
579
+ },
580
+ input: undefined,
581
+ output: outputSchema,
582
+ services: [],
583
+ logger: mockLogger,
584
+ timeout: undefined,
585
+ memorySize: undefined,
586
+ status: 201,
587
+ getSession: undefined,
588
+ authorize: undefined,
589
+ description: undefined,
590
+ events: [],
591
+ publisherService: undefined,
592
+ auditorStorageService: auditStorageService,
593
+ audits: [],
594
+ });
595
+
596
+ const adaptor = new HonoEndpoint(endpoint);
597
+ const app = new Hono();
598
+ HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
599
+ adaptor.addRoute(serviceDiscovery, app);
600
+
601
+ const response = await app.request('/users', {
602
+ method: 'POST',
603
+ body: JSON.stringify({}),
604
+ headers: { 'Content-Type': 'application/json' },
605
+ });
606
+
607
+ expect(response.status).toBe(500);
608
+
609
+ // Manual audit should NOT be written because handler failed
610
+ expect(auditStorage.records).toHaveLength(0);
611
+
612
+ // Database operations should be rolled back
613
+ expect(mockDb.committedOperations).toHaveLength(0);
614
+ });
615
+ });
616
+
617
+ describe('combined declarative and manual audits', () => {
618
+ it('should process both declarative and manual audits in same transaction', async () => {
619
+ const serviceDiscovery = createServiceDiscovery();
620
+
621
+ const auditStorageService: Service<
622
+ 'auditStorage',
623
+ TransactionalAuditStorage
624
+ > = {
625
+ serviceName: 'auditStorage' as const,
626
+ register: vi.fn().mockResolvedValue(auditStorage),
627
+ };
628
+
629
+ const outputSchema = z.object({ id: z.string(), email: z.string() });
630
+
631
+ // Declarative audit
632
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
633
+ {
634
+ type: 'user.created',
635
+ payload: (response) => ({
636
+ userId: response.id,
637
+ email: response.email,
638
+ }),
639
+ },
640
+ ];
641
+
642
+ const endpoint = new Endpoint({
643
+ route: '/users',
644
+ method: 'POST',
645
+ fn: async (
646
+ ctx: EndpointContext<
647
+ undefined,
648
+ [],
649
+ Logger,
650
+ unknown,
651
+ TestAuditAction,
652
+ undefined,
653
+ TransactionalAuditStorage
654
+ >,
655
+ ) => {
656
+ mockDb.insert('users', { id: '123', email: 'test@example.com' });
657
+
658
+ // Also add a manual audit - auditor is guaranteed to exist
659
+ ctx.auditor.audit('user.updated', {
660
+ userId: '123',
661
+ changes: ['email_verified'],
662
+ });
663
+
664
+ return { id: '123', email: 'test@example.com' };
665
+ },
666
+ input: undefined,
667
+ output: outputSchema,
668
+ services: [],
669
+ logger: mockLogger,
670
+ timeout: undefined,
671
+ memorySize: undefined,
672
+ status: 201,
673
+ getSession: undefined,
674
+ authorize: undefined,
675
+ description: undefined,
676
+ events: [],
677
+ publisherService: undefined,
678
+ auditorStorageService: auditStorageService,
679
+ audits,
680
+ });
681
+
682
+ const adaptor = new HonoEndpoint(endpoint);
683
+ const app = new Hono();
684
+ HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
685
+ adaptor.addRoute(serviceDiscovery, app);
686
+
687
+ const response = await app.request('/users', {
688
+ method: 'POST',
689
+ body: JSON.stringify({}),
690
+ headers: { 'Content-Type': 'application/json' },
691
+ });
692
+
693
+ expect(response.status).toBe(201);
694
+
695
+ // Both manual and declarative audits should be written
696
+ expect(auditStorage.records).toHaveLength(2);
697
+
698
+ const auditTypes = auditStorage.records.map((r) => r.type);
699
+ expect(auditTypes).toContain('user.created'); // declarative
700
+ expect(auditTypes).toContain('user.updated'); // manual
701
+ });
702
+ });
703
703
  });