@geekmidas/constructs 0.3.2 → 0.6.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 (557) hide show
  1. package/dist/{AWSLambdaFunction-C54a1doJ.mjs → AWSLambdaFunction-BMTaCrG9.mjs} +6 -6
  2. package/dist/AWSLambdaFunction-BMTaCrG9.mjs.map +1 -0
  3. package/dist/{AWSLambdaFunction-BdebRMUh.d.mts → AWSLambdaFunction-BfLF5vNa.d.cts} +6 -6
  4. package/dist/AWSLambdaFunction-BfLF5vNa.d.cts.map +1 -0
  5. package/dist/{AWSLambdaFunction-EPGY4s7i.cjs → AWSLambdaFunction-C1gRqLO7.cjs} +6 -6
  6. package/dist/AWSLambdaFunction-C1gRqLO7.cjs.map +1 -0
  7. package/dist/{AWSLambdaFunction-D0tEOTXQ.d.cts → AWSLambdaFunction-K94K8JU2.d.mts} +6 -6
  8. package/dist/AWSLambdaFunction-K94K8JU2.d.mts.map +1 -0
  9. package/dist/{AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts → AWSLambdaSubscriberAdaptor-B2Gk3fgx.d.cts} +2 -2
  10. package/dist/AWSLambdaSubscriberAdaptor-B2Gk3fgx.d.cts.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-BNcYYZ-P.cjs → AWSLambdaSubscriberAdaptor-DQDnt1Xk.cjs} +3 -3
  14. package/dist/AWSLambdaSubscriberAdaptor-DQDnt1Xk.cjs.map +1 -0
  15. package/dist/{AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts → AWSLambdaSubscriberAdaptor-QuMFwltJ.d.mts} +2 -2
  16. package/dist/AWSLambdaSubscriberAdaptor-QuMFwltJ.d.mts.map +1 -0
  17. package/dist/{AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs → AmazonApiGatewayEndpointAdaptor-B4gLJ2dx.mjs} +56 -14
  18. package/dist/AmazonApiGatewayEndpointAdaptor-B4gLJ2dx.mjs.map +1 -0
  19. package/dist/{AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts → AmazonApiGatewayEndpointAdaptor-C987ZCsM.d.cts} +51 -5
  20. package/dist/AmazonApiGatewayEndpointAdaptor-C987ZCsM.d.cts.map +1 -0
  21. package/dist/{AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs → AmazonApiGatewayEndpointAdaptor-CwRKMRr_.cjs} +55 -13
  22. package/dist/AmazonApiGatewayEndpointAdaptor-CwRKMRr_.cjs.map +1 -0
  23. package/dist/{AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts → AmazonApiGatewayEndpointAdaptor-DpPfO6Vj.d.mts} +52 -6
  24. package/dist/AmazonApiGatewayEndpointAdaptor-DpPfO6Vj.d.mts.map +1 -0
  25. package/dist/{AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs → AmazonApiGatewayV1EndpointAdaptor-BeZMu5DZ.cjs} +4 -4
  26. package/dist/AmazonApiGatewayV1EndpointAdaptor-BeZMu5DZ.cjs.map +1 -0
  27. package/dist/{AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts → AmazonApiGatewayV1EndpointAdaptor-DI_5kdqw.d.mts} +5 -5
  28. package/dist/AmazonApiGatewayV1EndpointAdaptor-DI_5kdqw.d.mts.map +1 -0
  29. package/dist/{AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts → AmazonApiGatewayV1EndpointAdaptor-DkGMOpoB.d.cts} +4 -4
  30. package/dist/AmazonApiGatewayV1EndpointAdaptor-DkGMOpoB.d.cts.map +1 -0
  31. package/dist/{AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs → AmazonApiGatewayV1EndpointAdaptor-VccB6FKp.mjs} +4 -4
  32. package/dist/AmazonApiGatewayV1EndpointAdaptor-VccB6FKp.mjs.map +1 -0
  33. package/dist/{AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts → AmazonApiGatewayV2EndpointAdaptor-BtBnMJS_.d.cts} +4 -6
  34. package/dist/AmazonApiGatewayV2EndpointAdaptor-BtBnMJS_.d.cts.map +1 -0
  35. package/dist/{AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs → AmazonApiGatewayV2EndpointAdaptor-BwsL9Gia.cjs} +4 -4
  36. package/dist/AmazonApiGatewayV2EndpointAdaptor-BwsL9Gia.cjs.map +1 -0
  37. package/dist/{AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs → AmazonApiGatewayV2EndpointAdaptor-CljxmUfz.mjs} +4 -4
  38. package/dist/AmazonApiGatewayV2EndpointAdaptor-CljxmUfz.mjs.map +1 -0
  39. package/dist/{AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts → AmazonApiGatewayV2EndpointAdaptor-DnCoqlvw.d.mts} +5 -7
  40. package/dist/AmazonApiGatewayV2EndpointAdaptor-DnCoqlvw.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-BAtutR6q.d.cts → BaseFunctionBuilder-BqZCqIeU.d.mts} +3 -3
  50. package/dist/BaseFunctionBuilder-BqZCqIeU.d.mts.map +1 -0
  51. package/dist/{BaseFunctionBuilder-DRY419e7.d.mts → BaseFunctionBuilder-CcK691ni.d.cts} +3 -3
  52. package/dist/BaseFunctionBuilder-CcK691ni.d.cts.map +1 -0
  53. package/dist/{BaseFunctionBuilder-Czi1Jwza.mjs → BaseFunctionBuilder-Dsqe6pnn.mjs} +2 -2
  54. package/dist/BaseFunctionBuilder-Dsqe6pnn.mjs.map +1 -0
  55. package/dist/{BaseFunctionBuilder-MYG3C9ug.cjs → BaseFunctionBuilder-Z0XwrKB5.cjs} +2 -2
  56. package/dist/BaseFunctionBuilder-Z0XwrKB5.cjs.map +1 -0
  57. package/dist/Construct-BNDLJJfD.mjs +150 -0
  58. package/dist/Construct-BNDLJJfD.mjs.map +1 -0
  59. package/dist/{Construct-Ba5cMxib.cjs → Construct-CPrCF8NK.cjs} +93 -9
  60. package/dist/Construct-CPrCF8NK.cjs.map +1 -0
  61. package/dist/{Construct-C4rPE67v.d.cts → Construct-Dl0l2d8d.d.cts} +30 -4
  62. package/dist/Construct-Dl0l2d8d.d.cts.map +1 -0
  63. package/dist/{Construct-XrijZFFh.d.mts → Construct-E8QPyHh4.d.mts} +30 -4
  64. package/dist/Construct-E8QPyHh4.d.mts.map +1 -0
  65. package/dist/Construct.cjs +4 -2
  66. package/dist/Construct.d.cts +2 -2
  67. package/dist/Construct.d.mts +2 -2
  68. package/dist/Construct.mjs +2 -2
  69. package/dist/{Cron-CGF4YAfM.cjs → Cron-BmPNTLla.cjs} +3 -3
  70. package/dist/Cron-BmPNTLla.cjs.map +1 -0
  71. package/dist/{Cron-BxhGs5up.mjs → Cron-BpJONaFv.mjs} +3 -3
  72. package/dist/Cron-BpJONaFv.mjs.map +1 -0
  73. package/dist/{Cron-bDLcTvV5.d.cts → Cron-CnmLLh3E.d.mts} +3 -3
  74. package/dist/Cron-CnmLLh3E.d.mts.map +1 -0
  75. package/dist/{Cron-cdjlSKNp.d.mts → Cron-DufAeHry.d.cts} +3 -3
  76. package/dist/Cron-DufAeHry.d.cts.map +1 -0
  77. package/dist/{CronBuilder-d2jh-IB2.mjs → CronBuilder-02HSIHJr.mjs} +4 -4
  78. package/dist/CronBuilder-02HSIHJr.mjs.map +1 -0
  79. package/dist/{CronBuilder-CcxKRtVP.cjs → CronBuilder-DC2zUS8a.cjs} +4 -4
  80. package/dist/CronBuilder-DC2zUS8a.cjs.map +1 -0
  81. package/dist/{CronBuilder-BC4m5-p1.d.mts → CronBuilder-anUSbMxb.d.mts} +4 -4
  82. package/dist/CronBuilder-anUSbMxb.d.mts.map +1 -0
  83. package/dist/{CronBuilder-DKVXyE0Q.d.cts → CronBuilder-fyqf_X8n.d.cts} +4 -4
  84. package/dist/CronBuilder-fyqf_X8n.d.cts.map +1 -0
  85. package/dist/{Endpoint-BVGZXFyV.cjs → Endpoint-BCWVbi8l.cjs} +6 -6
  86. package/dist/Endpoint-BCWVbi8l.cjs.map +1 -0
  87. package/dist/{Endpoint-BPv9_-m_.d.cts → Endpoint-BlcHiGNx.d.cts} +3 -3
  88. package/dist/Endpoint-BlcHiGNx.d.cts.map +1 -0
  89. package/dist/{Endpoint-BdwG75G_.d.mts → Endpoint-DEHuy46S.d.mts} +4 -4
  90. package/dist/Endpoint-DEHuy46S.d.mts.map +1 -0
  91. package/dist/{Endpoint-CuOEswxJ.mjs → Endpoint-ygxv2Ia6.mjs} +6 -6
  92. package/dist/Endpoint-ygxv2Ia6.mjs.map +1 -0
  93. package/dist/{EndpointBuilder-DIy_m1bu.d.cts → EndpointBuilder-DPLAUHqg.d.cts} +4 -4
  94. package/dist/EndpointBuilder-DPLAUHqg.d.cts.map +1 -0
  95. package/dist/{EndpointBuilder-B3az942t.d.mts → EndpointBuilder-DaeCeneF.d.mts} +5 -5
  96. package/dist/EndpointBuilder-DaeCeneF.d.mts.map +1 -0
  97. package/dist/{EndpointBuilder-Cgj1P_ra.cjs → EndpointBuilder-J5D67Y6a.cjs} +6 -6
  98. package/dist/EndpointBuilder-J5D67Y6a.cjs.map +1 -0
  99. package/dist/{EndpointBuilder-DnCB1h1j.mjs → EndpointBuilder-tn4zqoyw.mjs} +6 -6
  100. package/dist/EndpointBuilder-tn4zqoyw.mjs.map +1 -0
  101. package/dist/{EndpointFactory-CbdxPCIH.mjs → EndpointFactory-CIUZTTAF.mjs} +7 -7
  102. package/dist/EndpointFactory-CIUZTTAF.mjs.map +1 -0
  103. package/dist/{EndpointFactory-CyPbm3AD.d.cts → EndpointFactory-CiKcb5PX.d.cts} +4 -4
  104. package/dist/EndpointFactory-CiKcb5PX.d.cts.map +1 -0
  105. package/dist/{EndpointFactory-C-0nE6Jg.d.mts → EndpointFactory-DufM0t2z.d.mts} +4 -4
  106. package/dist/EndpointFactory-DufM0t2z.d.mts.map +1 -0
  107. package/dist/{EndpointFactory-CYj6BYok.cjs → EndpointFactory-d5uwWFkK.cjs} +7 -7
  108. package/dist/EndpointFactory-d5uwWFkK.cjs.map +1 -0
  109. package/dist/{Function-DDZb1525.cjs → Function-2qWSZqYB.cjs} +3 -3
  110. package/dist/Function-2qWSZqYB.cjs.map +1 -0
  111. package/dist/{Function-Cf7f_kCz.d.cts → Function-CbEohg13.d.cts} +3 -3
  112. package/dist/Function-CbEohg13.d.cts.map +1 -0
  113. package/dist/{Function-BVHqIDp9.mjs → Function-CdF1HmFu.mjs} +3 -3
  114. package/dist/Function-CdF1HmFu.mjs.map +1 -0
  115. package/dist/{Function-DN2G6OT5.d.mts → Function-EjIOLxlh.d.mts} +3 -3
  116. package/dist/Function-EjIOLxlh.d.mts.map +1 -0
  117. package/dist/{FunctionBuilder-DswJ-9sD.cjs → FunctionBuilder-B-pbgm09.cjs} +4 -4
  118. package/dist/FunctionBuilder-B-pbgm09.cjs.map +1 -0
  119. package/dist/{FunctionBuilder-CJBzzXL3.d.cts → FunctionBuilder-CX3ooNdq.d.cts} +4 -4
  120. package/dist/FunctionBuilder-CX3ooNdq.d.cts.map +1 -0
  121. package/dist/{FunctionBuilder-Cxx8D2na.d.mts → FunctionBuilder-D11ytDyy.d.mts} +4 -4
  122. package/dist/FunctionBuilder-D11ytDyy.d.mts.map +1 -0
  123. package/dist/{FunctionBuilder-CrDYgfiI.mjs → FunctionBuilder-DaWVthAJ.mjs} +4 -4
  124. package/dist/FunctionBuilder-DaWVthAJ.mjs.map +1 -0
  125. package/dist/{FunctionExecutionWrapper-DF260Aaj.d.mts → FunctionExecutionWrapper-BJcRjH9Z.d.cts} +5 -5
  126. package/dist/FunctionExecutionWrapper-BJcRjH9Z.d.cts.map +1 -0
  127. package/dist/{FunctionExecutionWrapper-BYI2bGTL.cjs → FunctionExecutionWrapper-C6ChBNHs.cjs} +3 -3
  128. package/dist/FunctionExecutionWrapper-C6ChBNHs.cjs.map +1 -0
  129. package/dist/{FunctionExecutionWrapper-Qy8bmgFR.d.cts → FunctionExecutionWrapper-D3RNjGIR.d.mts} +5 -5
  130. package/dist/FunctionExecutionWrapper-D3RNjGIR.d.mts.map +1 -0
  131. package/dist/{FunctionExecutionWrapper-CLDh7Z2_.mjs → FunctionExecutionWrapper-Dj3pmXaN.mjs} +3 -3
  132. package/dist/FunctionExecutionWrapper-Dj3pmXaN.mjs.map +1 -0
  133. package/dist/{HonoEndpointAdaptor-BaPlUhz0.d.mts → HonoEndpointAdaptor-CKP6nrG2.d.mts} +11 -6
  134. package/dist/HonoEndpointAdaptor-CKP6nrG2.d.mts.map +1 -0
  135. package/dist/HonoEndpointAdaptor-Cc8Rnp9G.mjs +251 -0
  136. package/dist/HonoEndpointAdaptor-Cc8Rnp9G.mjs.map +1 -0
  137. package/dist/{HonoEndpointAdaptor-YcRHYALH.d.cts → HonoEndpointAdaptor-hrrvyfw9.d.cts} +10 -5
  138. package/dist/HonoEndpointAdaptor-hrrvyfw9.d.cts.map +1 -0
  139. package/dist/HonoEndpointAdaptor-xGnDZa3a.cjs +257 -0
  140. package/dist/HonoEndpointAdaptor-xGnDZa3a.cjs.map +1 -0
  141. package/dist/{Subscriber-COYMSevD.d.cts → Subscriber-BBcIOkhW.d.cts} +2 -2
  142. package/dist/Subscriber-BBcIOkhW.d.cts.map +1 -0
  143. package/dist/{Subscriber-ikctpU3I.d.mts → Subscriber-BpTAXvbM.d.mts} +2 -2
  144. package/dist/Subscriber-BpTAXvbM.d.mts.map +1 -0
  145. package/dist/{Subscriber-BiHjVXtM.cjs → Subscriber-CL4iYm01.cjs} +2 -2
  146. package/dist/Subscriber-CL4iYm01.cjs.map +1 -0
  147. package/dist/{Subscriber-BmPf9GFb.mjs → Subscriber-CZ8Smwd2.mjs} +2 -2
  148. package/dist/Subscriber-CZ8Smwd2.mjs.map +1 -0
  149. package/dist/{SubscriberBuilder-DJPEeYDJ.mjs → SubscriberBuilder-CxQg3TTm.mjs} +2 -2
  150. package/dist/SubscriberBuilder-CxQg3TTm.mjs.map +1 -0
  151. package/dist/{SubscriberBuilder-Cp1C-xtT.cjs → SubscriberBuilder-D0OS3hd7.cjs} +2 -2
  152. package/dist/SubscriberBuilder-D0OS3hd7.cjs.map +1 -0
  153. package/dist/{SubscriberBuilder-D_9zzllj.d.mts → SubscriberBuilder-D7IgufwB.d.cts} +3 -3
  154. package/dist/SubscriberBuilder-D7IgufwB.d.cts.map +1 -0
  155. package/dist/{SubscriberBuilder-ivHAGIVi.d.cts → SubscriberBuilder-DOFBbWLt.d.mts} +3 -3
  156. package/dist/SubscriberBuilder-DOFBbWLt.d.mts.map +1 -0
  157. package/dist/{TestEndpointAdaptor-DB7bREhS.d.mts → TestEndpointAdaptor-BnJusjf7.d.mts} +4 -4
  158. package/dist/TestEndpointAdaptor-BnJusjf7.d.mts.map +1 -0
  159. package/dist/TestEndpointAdaptor-CPL8ru6q.mjs +170 -0
  160. package/dist/TestEndpointAdaptor-CPL8ru6q.mjs.map +1 -0
  161. package/dist/TestEndpointAdaptor-Ca4K26_d.cjs +176 -0
  162. package/dist/TestEndpointAdaptor-Ca4K26_d.cjs.map +1 -0
  163. package/dist/{TestEndpointAdaptor-C10xBI--.d.cts → TestEndpointAdaptor-EPPTjntv.d.cts} +3 -3
  164. package/dist/TestEndpointAdaptor-EPPTjntv.d.cts.map +1 -0
  165. package/dist/adaptors/aws.cjs +12 -12
  166. package/dist/adaptors/aws.d.cts +15 -14
  167. package/dist/adaptors/aws.d.mts +16 -15
  168. package/dist/adaptors/aws.mjs +12 -12
  169. package/dist/adaptors/hono.cjs +10 -9
  170. package/dist/adaptors/hono.d.cts +8 -8
  171. package/dist/adaptors/hono.d.mts +9 -9
  172. package/dist/adaptors/hono.mjs +10 -9
  173. package/dist/adaptors/testing.cjs +8 -7
  174. package/dist/adaptors/testing.d.cts +8 -8
  175. package/dist/adaptors/testing.d.mts +9 -9
  176. package/dist/adaptors/testing.mjs +8 -7
  177. package/dist/crons/Cron.cjs +6 -6
  178. package/dist/crons/Cron.d.cts +6 -6
  179. package/dist/crons/Cron.d.mts +6 -6
  180. package/dist/crons/Cron.mjs +6 -6
  181. package/dist/crons/CronBuilder.cjs +7 -7
  182. package/dist/crons/CronBuilder.d.cts +7 -7
  183. package/dist/crons/CronBuilder.d.mts +7 -7
  184. package/dist/crons/CronBuilder.mjs +7 -7
  185. package/dist/crons/index.cjs +7 -7
  186. package/dist/crons/index.cjs.map +1 -1
  187. package/dist/crons/index.d.cts +11 -11
  188. package/dist/crons/index.d.mts +7 -7
  189. package/dist/crons/index.mjs +7 -7
  190. package/dist/crons/index.mjs.map +1 -1
  191. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +7 -7
  192. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +10 -9
  193. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +11 -10
  194. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +7 -7
  195. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +8 -8
  196. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +10 -9
  197. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +11 -10
  198. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +8 -8
  199. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +8 -8
  200. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +11 -10
  201. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +12 -11
  202. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +8 -8
  203. package/dist/endpoints/Authorizer.cjs +1 -1
  204. package/dist/endpoints/Authorizer.d.cts +1 -1
  205. package/dist/endpoints/Authorizer.d.mts +1 -1
  206. package/dist/endpoints/Authorizer.mjs +1 -1
  207. package/dist/endpoints/Endpoint.cjs +6 -6
  208. package/dist/endpoints/Endpoint.d.cts +7 -7
  209. package/dist/endpoints/Endpoint.d.mts +8 -8
  210. package/dist/endpoints/Endpoint.mjs +6 -6
  211. package/dist/endpoints/EndpointBuilder.cjs +9 -9
  212. package/dist/endpoints/EndpointBuilder.d.cts +8 -8
  213. package/dist/endpoints/EndpointBuilder.d.mts +9 -9
  214. package/dist/endpoints/EndpointBuilder.mjs +9 -9
  215. package/dist/endpoints/EndpointFactory.cjs +10 -10
  216. package/dist/endpoints/EndpointFactory.d.cts +9 -9
  217. package/dist/endpoints/EndpointFactory.d.mts +10 -10
  218. package/dist/endpoints/EndpointFactory.mjs +10 -10
  219. package/dist/endpoints/HonoEndpointAdaptor.cjs +10 -9
  220. package/dist/endpoints/HonoEndpointAdaptor.d.cts +8 -8
  221. package/dist/endpoints/HonoEndpointAdaptor.d.mts +9 -9
  222. package/dist/endpoints/HonoEndpointAdaptor.mjs +10 -9
  223. package/dist/endpoints/TestEndpointAdaptor.cjs +8 -7
  224. package/dist/endpoints/TestEndpointAdaptor.d.cts +8 -8
  225. package/dist/endpoints/TestEndpointAdaptor.d.mts +9 -9
  226. package/dist/endpoints/TestEndpointAdaptor.mjs +8 -7
  227. package/dist/endpoints/audit.d.cts +7 -7
  228. package/dist/endpoints/audit.d.mts +8 -8
  229. package/dist/endpoints/helpers.cjs +7 -7
  230. package/dist/endpoints/helpers.d.cts +7 -7
  231. package/dist/endpoints/helpers.d.cts.map +1 -1
  232. package/dist/endpoints/helpers.d.mts +8 -8
  233. package/dist/endpoints/helpers.d.mts.map +1 -1
  234. package/dist/endpoints/helpers.mjs +7 -7
  235. package/dist/endpoints/index.cjs +20 -10
  236. package/dist/endpoints/index.cjs.map +1 -1
  237. package/dist/endpoints/index.d.cts +14 -12
  238. package/dist/endpoints/index.d.cts.map +1 -1
  239. package/dist/endpoints/index.d.mts +15 -13
  240. package/dist/endpoints/index.d.mts.map +1 -1
  241. package/dist/endpoints/index.mjs +13 -11
  242. package/dist/endpoints/index.mjs.map +1 -1
  243. package/dist/endpoints/lazyAccessors.cjs +10 -0
  244. package/dist/endpoints/lazyAccessors.d.cts +10 -0
  245. package/dist/endpoints/lazyAccessors.d.mts +10 -0
  246. package/dist/endpoints/lazyAccessors.mjs +3 -0
  247. package/dist/endpoints/parseHonoQuery.cjs +1 -1
  248. package/dist/endpoints/parseHonoQuery.mjs +1 -1
  249. package/dist/endpoints/parseQueryParams.d.cts.map +1 -1
  250. package/dist/endpoints/parseQueryParams.d.mts.map +1 -1
  251. package/dist/endpoints/processAudits.d.cts +7 -7
  252. package/dist/endpoints/processAudits.d.cts.map +1 -1
  253. package/dist/endpoints/processAudits.d.mts +8 -8
  254. package/dist/endpoints/processAudits.d.mts.map +1 -1
  255. package/dist/endpoints/rls.cjs +1 -1
  256. package/dist/endpoints/rls.d.cts +7 -7
  257. package/dist/endpoints/rls.d.mts +8 -8
  258. package/dist/endpoints/rls.mjs +1 -1
  259. package/dist/functions/AWSLambdaFunction.cjs +6 -6
  260. package/dist/functions/AWSLambdaFunction.d.cts +4 -4
  261. package/dist/functions/AWSLambdaFunction.d.mts +4 -4
  262. package/dist/functions/AWSLambdaFunction.mjs +6 -6
  263. package/dist/functions/BaseFunctionBuilder.cjs +2 -2
  264. package/dist/functions/BaseFunctionBuilder.d.cts +2 -2
  265. package/dist/functions/BaseFunctionBuilder.d.mts +2 -2
  266. package/dist/functions/BaseFunctionBuilder.mjs +2 -2
  267. package/dist/functions/Function.cjs +2 -2
  268. package/dist/functions/Function.d.cts +2 -2
  269. package/dist/functions/Function.d.mts +2 -2
  270. package/dist/functions/Function.mjs +2 -2
  271. package/dist/functions/FunctionBuilder.cjs +4 -4
  272. package/dist/functions/FunctionBuilder.d.cts +4 -4
  273. package/dist/functions/FunctionBuilder.d.mts +4 -4
  274. package/dist/functions/FunctionBuilder.mjs +4 -4
  275. package/dist/functions/FunctionExecutionWrapper.cjs +5 -5
  276. package/dist/functions/FunctionExecutionWrapper.d.cts +3 -3
  277. package/dist/functions/FunctionExecutionWrapper.d.mts +3 -3
  278. package/dist/functions/FunctionExecutionWrapper.mjs +5 -5
  279. package/dist/functions/TestFunctionAdaptor.cjs +7 -7
  280. package/dist/functions/TestFunctionAdaptor.cjs.map +1 -1
  281. package/dist/functions/TestFunctionAdaptor.d.cts +3 -3
  282. package/dist/functions/TestFunctionAdaptor.d.cts.map +1 -1
  283. package/dist/functions/TestFunctionAdaptor.d.mts +3 -3
  284. package/dist/functions/TestFunctionAdaptor.d.mts.map +1 -1
  285. package/dist/functions/TestFunctionAdaptor.mjs +7 -7
  286. package/dist/functions/TestFunctionAdaptor.mjs.map +1 -1
  287. package/dist/functions/index.cjs +5 -5
  288. package/dist/functions/index.d.cts +5 -5
  289. package/dist/functions/index.d.mts +5 -5
  290. package/dist/functions/index.mjs +5 -5
  291. package/dist/{functions-fTid0RMK.cjs → functions-CUEv5NC3.cjs} +2 -2
  292. package/dist/functions-CUEv5NC3.cjs.map +1 -0
  293. package/dist/functions-DOYBrb7n.mjs +8 -0
  294. package/dist/functions-DOYBrb7n.mjs.map +1 -0
  295. package/dist/{helpers-ByRTDO_m.mjs → helpers-Dl1eszfi.mjs} +2 -2
  296. package/dist/helpers-Dl1eszfi.mjs.map +1 -0
  297. package/dist/{helpers-BcP1tXAi.cjs → helpers-QMdfdnvU.cjs} +2 -2
  298. package/dist/helpers-QMdfdnvU.cjs.map +1 -0
  299. package/dist/{index-BWzGIj06.d.mts → index-BrGtMlpJ.d.cts} +2 -2
  300. package/dist/index-BrGtMlpJ.d.cts.map +1 -0
  301. package/dist/index-Dn4py3Db.d.mts +12 -0
  302. package/dist/index-Dn4py3Db.d.mts.map +1 -0
  303. package/dist/index.cjs +4 -2
  304. package/dist/index.d.cts +3 -2
  305. package/dist/index.d.mts +4 -3
  306. package/dist/index.mjs +2 -2
  307. package/dist/lazyAccessors-B-Jgkg2o.mjs +175 -0
  308. package/dist/lazyAccessors-B-Jgkg2o.mjs.map +1 -0
  309. package/dist/lazyAccessors-B8Hhras9.cjs +223 -0
  310. package/dist/lazyAccessors-B8Hhras9.cjs.map +1 -0
  311. package/dist/lazyAccessors-BFAj2-S4.d.mts +49 -0
  312. package/dist/lazyAccessors-BFAj2-S4.d.mts.map +1 -0
  313. package/dist/lazyAccessors-knaNZuTN.d.cts +49 -0
  314. package/dist/lazyAccessors-knaNZuTN.d.cts.map +1 -0
  315. package/dist/{parseHonoQuery-CZC5_97v.cjs → parseHonoQuery-D4MhxTRc.cjs} +1 -1
  316. package/dist/parseHonoQuery-D4MhxTRc.cjs.map +1 -0
  317. package/dist/{parseHonoQuery-DDgIkTO4.mjs → parseHonoQuery-DpK3sGPc.mjs} +1 -1
  318. package/dist/parseHonoQuery-DpK3sGPc.mjs.map +1 -0
  319. package/dist/parseQueryParams-BSNkjmZ9.cjs.map +1 -1
  320. package/dist/parseQueryParams-UMTRnRrW.mjs.map +1 -1
  321. package/dist/processAudits-CzHkPokQ.cjs.map +1 -1
  322. package/dist/processAudits-Dj8UGqcW.mjs.map +1 -1
  323. package/dist/publisher-BXG9YiRi.d.mts +16 -0
  324. package/dist/publisher-BXG9YiRi.d.mts.map +1 -0
  325. package/dist/publisher-Bw4770Hi.mjs.map +1 -1
  326. package/dist/publisher-D9ngDXg3.d.cts +16 -0
  327. package/dist/publisher-D9ngDXg3.d.cts.map +1 -0
  328. package/dist/publisher-lFQleddL.cjs.map +1 -1
  329. package/dist/publisher.d.cts +3 -16
  330. package/dist/publisher.d.mts +3 -16
  331. package/dist/{rls-CmJ7bRsz.cjs → rls-BrywnrQb.cjs} +1 -1
  332. package/dist/{rls-CmJ7bRsz.cjs.map → rls-BrywnrQb.cjs.map} +1 -1
  333. package/dist/{rls-Bf3FRwto.mjs → rls-C0cWOnk4.mjs} +1 -1
  334. package/dist/{rls-Bf3FRwto.mjs.map → rls-C0cWOnk4.mjs.map} +1 -1
  335. package/dist/subscribers/AWSLambdaSubscriberAdaptor.cjs +1 -1
  336. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +3 -3
  337. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +3 -3
  338. package/dist/subscribers/AWSLambdaSubscriberAdaptor.mjs +1 -1
  339. package/dist/subscribers/Subscriber.cjs +2 -2
  340. package/dist/subscribers/Subscriber.d.cts +2 -2
  341. package/dist/subscribers/Subscriber.d.mts +2 -2
  342. package/dist/subscribers/Subscriber.mjs +2 -2
  343. package/dist/subscribers/SubscriberBuilder.cjs +3 -3
  344. package/dist/subscribers/SubscriberBuilder.d.cts +3 -3
  345. package/dist/subscribers/SubscriberBuilder.d.mts +3 -3
  346. package/dist/subscribers/SubscriberBuilder.mjs +3 -3
  347. package/dist/subscribers/index.cjs +3 -3
  348. package/dist/subscribers/index.cjs.map +1 -1
  349. package/dist/subscribers/index.d.cts +5 -5
  350. package/dist/subscribers/index.d.cts.map +1 -1
  351. package/dist/subscribers/index.d.mts +5 -5
  352. package/dist/subscribers/index.d.mts.map +1 -1
  353. package/dist/subscribers/index.mjs +3 -3
  354. package/dist/subscribers/index.mjs.map +1 -1
  355. package/dist/telemetry-BTaiRqPo.d.cts +95 -0
  356. package/dist/telemetry-BTaiRqPo.d.cts.map +1 -0
  357. package/dist/telemetry-yAHf5yDs.d.mts +95 -0
  358. package/dist/telemetry-yAHf5yDs.d.mts.map +1 -0
  359. package/dist/telemetry.cjs +0 -0
  360. package/dist/telemetry.d.cts +2 -0
  361. package/dist/telemetry.d.mts +2 -0
  362. package/dist/telemetry.mjs +0 -0
  363. package/dist/types-B5H3piDg.d.cts.map +1 -1
  364. package/dist/{types-DdIlpxAd.d.mts → types-Dw-iLd3Y.d.mts} +1 -1
  365. package/dist/types-Dw-iLd3Y.d.mts.map +1 -0
  366. package/dist/types.d.mts +1 -1
  367. package/package.json +19 -18
  368. package/src/Construct.ts +189 -94
  369. package/src/__benchmarks__/build-time-optimization.bench.ts +274 -0
  370. package/src/__benchmarks__/endpoint.bench.ts +375 -375
  371. package/src/__benchmarks__/fixtures.ts +241 -0
  372. package/src/__benchmarks__/hono-adaptor.bench.ts +533 -0
  373. package/src/__benchmarks__/hono-server.bench.ts +206 -206
  374. package/src/__benchmarks__/response-builder.bench.ts +428 -0
  375. package/src/__benchmarks__/strategies/strategy-a-lazy-services.ts +319 -0
  376. package/src/__benchmarks__/strategies/strategy-c-middleware.ts +530 -0
  377. package/src/__benchmarks__/strategies/strategy-d-opt-in-events.ts +567 -0
  378. package/src/__tests__/Construct.environment.spec.ts +572 -351
  379. package/src/__tests__/publisher.setting.spec.ts +496 -499
  380. package/src/__tests__/publisher.spec.ts +440 -442
  381. package/src/crons/Cron.ts +117 -117
  382. package/src/crons/CronBuilder.ts +237 -238
  383. package/src/crons/__tests__/Cron.spec.ts +448 -448
  384. package/src/crons/__tests__/CronBuilder.state-isolation.spec.ts +214 -214
  385. package/src/crons/index.ts +4 -4
  386. package/src/endpoints/AmazonApiGatewayEndpointAdaptor.ts +571 -463
  387. package/src/endpoints/AmazonApiGatewayV1EndpointAdaptor.ts +86 -86
  388. package/src/endpoints/AmazonApiGatewayV2EndpointAdaptor.ts +85 -81
  389. package/src/endpoints/Authorizer.ts +100 -100
  390. package/src/endpoints/Endpoint.ts +921 -937
  391. package/src/endpoints/EndpointBuilder.ts +703 -703
  392. package/src/endpoints/EndpointFactory.ts +1054 -1056
  393. package/src/endpoints/HonoEndpointAdaptor.ts +621 -548
  394. package/src/endpoints/TestEndpointAdaptor.ts +372 -353
  395. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.audits.spec.ts +499 -0
  396. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.events.spec.ts +541 -542
  397. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.spec.ts +1172 -1174
  398. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.audits.spec.ts +599 -599
  399. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.events.spec.ts +710 -710
  400. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.factory-publisher.spec.ts +280 -280
  401. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.kysely-audit.integration.spec.ts +924 -730
  402. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.rls.spec.ts +307 -0
  403. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.spec.ts +408 -408
  404. package/src/endpoints/__tests__/Authorizer.spec.ts +286 -0
  405. package/src/endpoints/__tests__/Endpoint.cookies.spec.ts +162 -162
  406. package/src/endpoints/__tests__/Endpoint.headers.spec.ts +182 -182
  407. package/src/endpoints/__tests__/Endpoint.manifest.spec.ts +158 -159
  408. package/src/endpoints/__tests__/Endpoint.spec.ts +819 -822
  409. package/src/endpoints/__tests__/EndpointBuilder.audit.spec.ts +427 -427
  410. package/src/endpoints/__tests__/EndpointBuilder.spec.ts +478 -478
  411. package/src/endpoints/__tests__/EndpointFactory.authorizers.spec.ts +426 -426
  412. package/src/endpoints/__tests__/EndpointFactory.database-auditor.spec.ts +501 -501
  413. package/src/endpoints/__tests__/EndpointFactory.reference-audit.spec.ts +177 -177
  414. package/src/endpoints/__tests__/EndpointFactory.spec.ts +471 -471
  415. package/src/endpoints/__tests__/EndpointFactory.state-isolation.spec.ts +143 -143
  416. package/src/endpoints/__tests__/HonoEndpointAdaptor.audit-transactions.spec.ts +663 -663
  417. package/src/endpoints/__tests__/HonoEndpointAdaptor.audits.spec.ts +608 -608
  418. package/src/endpoints/__tests__/HonoEndpointAdaptor.events.spec.ts +561 -561
  419. package/src/endpoints/__tests__/HonoEndpointAdaptor.kysely-audit.integration.spec.ts +1036 -1036
  420. package/src/endpoints/__tests__/HonoEndpointAdaptor.openapi.spec.ts +278 -278
  421. package/src/endpoints/__tests__/HonoEndpointAdaptor.spec.ts +1093 -1093
  422. package/src/endpoints/__tests__/ResponseBuilder.spec.ts +230 -230
  423. package/src/endpoints/__tests__/TestEndpointAdaptor.audits.spec.ts +569 -569
  424. package/src/endpoints/__tests__/TestEndpointAdaptor.spec.ts +841 -841
  425. package/src/endpoints/__tests__/endpoint-types.test.ts +68 -68
  426. package/src/endpoints/__tests__/helpers.spec.ts +37 -0
  427. package/src/endpoints/__tests__/lazyAccessors.spec.ts +330 -0
  428. package/src/endpoints/__tests__/processAudits.spec.ts +631 -0
  429. package/src/endpoints/audit.ts +51 -51
  430. package/src/endpoints/helpers.ts +34 -35
  431. package/src/endpoints/index.ts +33 -23
  432. package/src/endpoints/lazyAccessors.ts +241 -0
  433. package/src/endpoints/parseHonoQuery.ts +41 -41
  434. package/src/endpoints/parseQueryParams.ts +36 -36
  435. package/src/endpoints/processAudits.ts +269 -269
  436. package/src/endpoints/rls.ts +16 -16
  437. package/src/functions/AWSLambdaFunction.ts +294 -295
  438. package/src/functions/BaseFunctionBuilder.ts +185 -185
  439. package/src/functions/Function.ts +190 -190
  440. package/src/functions/FunctionBuilder.ts +353 -353
  441. package/src/functions/FunctionExecutionWrapper.ts +199 -200
  442. package/src/functions/TestFunctionAdaptor.ts +191 -191
  443. package/src/functions/__tests__/AWSLambdaFunctionAdaptor.spec.ts +424 -424
  444. package/src/functions/__tests__/Function.audits.spec.ts +364 -364
  445. package/src/functions/__tests__/Function.spec.ts +453 -454
  446. package/src/functions/__tests__/FunctionBuilder.state-isolation.spec.ts +179 -179
  447. package/src/functions/__tests__/TestFunctionAdaptor.spec.ts +369 -369
  448. package/src/functions/index.ts +6 -4
  449. package/src/index.ts +18 -9
  450. package/src/publisher.ts +71 -72
  451. package/src/subscribers/AWSLambdaSubscriberAdaptor.ts +244 -248
  452. package/src/subscribers/Subscriber.ts +82 -84
  453. package/src/subscribers/SubscriberBuilder.ts +129 -129
  454. package/src/subscribers/__tests__/AWSLambdaSubscriberAdaptor.spec.ts +589 -589
  455. package/src/subscribers/__tests__/Subscriber.spec.ts +402 -404
  456. package/src/subscribers/index.ts +1 -0
  457. package/src/telemetry.ts +103 -0
  458. package/src/types.ts +7 -7
  459. package/test.ts +58 -59
  460. package/dist/AWSLambdaFunction-BdebRMUh.d.mts.map +0 -1
  461. package/dist/AWSLambdaFunction-C54a1doJ.mjs.map +0 -1
  462. package/dist/AWSLambdaFunction-D0tEOTXQ.d.cts.map +0 -1
  463. package/dist/AWSLambdaFunction-EPGY4s7i.cjs.map +0 -1
  464. package/dist/AWSLambdaSubscriberAdaptor-BLfO612H.mjs.map +0 -1
  465. package/dist/AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs.map +0 -1
  466. package/dist/AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts.map +0 -1
  467. package/dist/AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts.map +0 -1
  468. package/dist/AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs.map +0 -1
  469. package/dist/AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts.map +0 -1
  470. package/dist/AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs.map +0 -1
  471. package/dist/AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts.map +0 -1
  472. package/dist/AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs.map +0 -1
  473. package/dist/AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs.map +0 -1
  474. package/dist/AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts.map +0 -1
  475. package/dist/AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts.map +0 -1
  476. package/dist/AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs.map +0 -1
  477. package/dist/AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts.map +0 -1
  478. package/dist/AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts.map +0 -1
  479. package/dist/AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs.map +0 -1
  480. package/dist/Authorizer-B-btowNd.d.cts.map +0 -1
  481. package/dist/Authorizer-C0ge_tc8.cjs.map +0 -1
  482. package/dist/Authorizer-gWxYsGEp.d.mts.map +0 -1
  483. package/dist/Authorizer-r9U3y_ms.mjs.map +0 -1
  484. package/dist/BaseFunctionBuilder-BAtutR6q.d.cts.map +0 -1
  485. package/dist/BaseFunctionBuilder-Czi1Jwza.mjs.map +0 -1
  486. package/dist/BaseFunctionBuilder-DRY419e7.d.mts.map +0 -1
  487. package/dist/BaseFunctionBuilder-MYG3C9ug.cjs.map +0 -1
  488. package/dist/Construct-Ba5cMxib.cjs.map +0 -1
  489. package/dist/Construct-C4rPE67v.d.cts.map +0 -1
  490. package/dist/Construct-DdyGHuag.mjs +0 -78
  491. package/dist/Construct-DdyGHuag.mjs.map +0 -1
  492. package/dist/Construct-XrijZFFh.d.mts.map +0 -1
  493. package/dist/Cron-BxhGs5up.mjs.map +0 -1
  494. package/dist/Cron-CGF4YAfM.cjs.map +0 -1
  495. package/dist/Cron-bDLcTvV5.d.cts.map +0 -1
  496. package/dist/Cron-cdjlSKNp.d.mts.map +0 -1
  497. package/dist/CronBuilder-BC4m5-p1.d.mts.map +0 -1
  498. package/dist/CronBuilder-CcxKRtVP.cjs.map +0 -1
  499. package/dist/CronBuilder-DKVXyE0Q.d.cts.map +0 -1
  500. package/dist/CronBuilder-d2jh-IB2.mjs.map +0 -1
  501. package/dist/Endpoint-BPv9_-m_.d.cts.map +0 -1
  502. package/dist/Endpoint-BVGZXFyV.cjs.map +0 -1
  503. package/dist/Endpoint-BdwG75G_.d.mts.map +0 -1
  504. package/dist/Endpoint-CuOEswxJ.mjs.map +0 -1
  505. package/dist/EndpointBuilder-B3az942t.d.mts.map +0 -1
  506. package/dist/EndpointBuilder-Cgj1P_ra.cjs.map +0 -1
  507. package/dist/EndpointBuilder-DIy_m1bu.d.cts.map +0 -1
  508. package/dist/EndpointBuilder-DnCB1h1j.mjs.map +0 -1
  509. package/dist/EndpointFactory-C-0nE6Jg.d.mts.map +0 -1
  510. package/dist/EndpointFactory-CYj6BYok.cjs.map +0 -1
  511. package/dist/EndpointFactory-CbdxPCIH.mjs.map +0 -1
  512. package/dist/EndpointFactory-CyPbm3AD.d.cts.map +0 -1
  513. package/dist/Function-BVHqIDp9.mjs.map +0 -1
  514. package/dist/Function-Cf7f_kCz.d.cts.map +0 -1
  515. package/dist/Function-DDZb1525.cjs.map +0 -1
  516. package/dist/Function-DN2G6OT5.d.mts.map +0 -1
  517. package/dist/FunctionBuilder-CJBzzXL3.d.cts.map +0 -1
  518. package/dist/FunctionBuilder-CrDYgfiI.mjs.map +0 -1
  519. package/dist/FunctionBuilder-Cxx8D2na.d.mts.map +0 -1
  520. package/dist/FunctionBuilder-DswJ-9sD.cjs.map +0 -1
  521. package/dist/FunctionExecutionWrapper-BYI2bGTL.cjs.map +0 -1
  522. package/dist/FunctionExecutionWrapper-CLDh7Z2_.mjs.map +0 -1
  523. package/dist/FunctionExecutionWrapper-DF260Aaj.d.mts.map +0 -1
  524. package/dist/FunctionExecutionWrapper-Qy8bmgFR.d.cts.map +0 -1
  525. package/dist/HonoEndpointAdaptor-BaPlUhz0.d.mts.map +0 -1
  526. package/dist/HonoEndpointAdaptor-CQe2FqMR.cjs +0 -234
  527. package/dist/HonoEndpointAdaptor-CQe2FqMR.cjs.map +0 -1
  528. package/dist/HonoEndpointAdaptor-Ce-2HBxn.mjs +0 -228
  529. package/dist/HonoEndpointAdaptor-Ce-2HBxn.mjs.map +0 -1
  530. package/dist/HonoEndpointAdaptor-YcRHYALH.d.cts.map +0 -1
  531. package/dist/Subscriber-BiHjVXtM.cjs.map +0 -1
  532. package/dist/Subscriber-BmPf9GFb.mjs.map +0 -1
  533. package/dist/Subscriber-COYMSevD.d.cts.map +0 -1
  534. package/dist/Subscriber-ikctpU3I.d.mts.map +0 -1
  535. package/dist/SubscriberBuilder-Cp1C-xtT.cjs.map +0 -1
  536. package/dist/SubscriberBuilder-DJPEeYDJ.mjs.map +0 -1
  537. package/dist/SubscriberBuilder-D_9zzllj.d.mts.map +0 -1
  538. package/dist/SubscriberBuilder-ivHAGIVi.d.cts.map +0 -1
  539. package/dist/TestEndpointAdaptor-C10xBI--.d.cts.map +0 -1
  540. package/dist/TestEndpointAdaptor-DB7bREhS.d.mts.map +0 -1
  541. package/dist/TestEndpointAdaptor-DJgik2Wj.mjs +0 -160
  542. package/dist/TestEndpointAdaptor-DJgik2Wj.mjs.map +0 -1
  543. package/dist/TestEndpointAdaptor-ZbtQiuHE.cjs +0 -166
  544. package/dist/TestEndpointAdaptor-ZbtQiuHE.cjs.map +0 -1
  545. package/dist/functions-C6EK1xL6.mjs +0 -8
  546. package/dist/functions-C6EK1xL6.mjs.map +0 -1
  547. package/dist/functions-fTid0RMK.cjs.map +0 -1
  548. package/dist/helpers-BcP1tXAi.cjs.map +0 -1
  549. package/dist/helpers-ByRTDO_m.mjs.map +0 -1
  550. package/dist/index-BWzGIj06.d.mts.map +0 -1
  551. package/dist/index-DmFozqLd.d.cts +0 -12
  552. package/dist/index-DmFozqLd.d.cts.map +0 -1
  553. package/dist/parseHonoQuery-CZC5_97v.cjs.map +0 -1
  554. package/dist/parseHonoQuery-DDgIkTO4.mjs.map +0 -1
  555. package/dist/publisher.d.cts.map +0 -1
  556. package/dist/publisher.d.mts.map +0 -1
  557. 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
  });