@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,572 +1,645 @@
1
- import type { AuditStorage, AuditableAction } from '@geekmidas/audit';
1
+ import type { AuditableAction, AuditStorage } from '@geekmidas/audit';
2
+ import { withRlsContext } from '@geekmidas/db/rls';
2
3
  import type { EnvironmentParser } from '@geekmidas/envkit';
4
+ import { wrapError } from '@geekmidas/errors';
3
5
  import type { EventPublisher } from '@geekmidas/events';
4
6
  import type { Logger } from '@geekmidas/logger';
5
7
  import { checkRateLimit, getRateLimitHeaders } from '@geekmidas/rate-limit';
8
+ import {
9
+ runWithRequestContext,
10
+ type Service,
11
+ ServiceDiscovery,
12
+ type ServiceRecord,
13
+ } from '@geekmidas/services';
6
14
  import type { StandardSchemaV1 } from '@standard-schema/spec';
7
15
  import { type Context, Hono } from 'hono';
8
16
  import { setCookie } from 'hono/cookie';
9
17
  import { logger as honoLogger } from 'hono/logger';
10
18
  import { timing } from 'hono/timing';
19
+ import type { ContentfulStatusCode } from 'hono/utils/http-status';
11
20
  import { validator } from 'hono/validator';
21
+ import { publishConstructEvents } from '../publisher';
12
22
  import type { HttpMethod, LowerHttpMethod } from '../types';
23
+ import type { MappedAudit } from './audit';
13
24
  import {
14
- Endpoint,
15
- type EndpointContext,
16
- type EndpointSchemas,
17
- ResponseBuilder,
25
+ Endpoint,
26
+ type EndpointContext,
27
+ type EndpointSchemas,
28
+ ResponseBuilder,
18
29
  } from './Endpoint';
19
30
  import { getEndpointsFromRoutes } from './helpers';
31
+ import { createHonoCookies, createHonoHeaders } from './lazyAccessors';
20
32
  import { parseHonoQuery } from './parseHonoQuery';
21
-
22
- import { withRlsContext } from '@geekmidas/db/rls';
23
- import { wrapError } from '@geekmidas/errors';
24
33
  import {
25
- type Service,
26
- ServiceDiscovery,
27
- type ServiceRecord,
28
- } from '@geekmidas/services';
29
- import type { ContentfulStatusCode } from 'hono/utils/http-status';
30
- import { publishConstructEvents } from '../publisher';
31
- import type { MappedAudit } from './audit';
32
- import {
33
- createAuditContext,
34
- executeWithAuditTransaction,
34
+ createAuditContext,
35
+ executeWithAuditTransaction,
35
36
  } from './processAudits';
36
37
 
37
38
  export interface HonoEndpointOptions {
38
- /**
39
- * Path where OpenAPI documentation will be served.
40
- * Set to false to disable docs route.
41
- * @default '/docs'
42
- */
43
- docsPath?: string | false;
44
- /**
45
- * OpenAPI schema options
46
- */
47
- openApiOptions?: {
48
- title?: string;
49
- version?: string;
50
- description?: string;
51
- };
39
+ /**
40
+ * Path where OpenAPI documentation will be served.
41
+ * Set to false to disable docs route.
42
+ * @default '/docs'
43
+ */
44
+ docsPath?: string | false;
45
+ /**
46
+ * OpenAPI schema options
47
+ */
48
+ openApiOptions?: {
49
+ title?: string;
50
+ version?: string;
51
+ description?: string;
52
+ };
53
+ }
54
+
55
+ /**
56
+ * Feature flags for an endpoint, analyzed once at route registration time.
57
+ * This avoids per-request feature detection overhead.
58
+ */
59
+ interface EndpointFeatures {
60
+ hasServices: boolean;
61
+ hasDatabase: boolean;
62
+ hasBodyValidation: boolean;
63
+ hasQueryValidation: boolean;
64
+ hasParamValidation: boolean;
65
+ hasAudits: boolean;
66
+ hasEvents: boolean;
67
+ hasRateLimit: boolean;
68
+ hasRls: boolean;
69
+ }
70
+
71
+ /**
72
+ * Analyze endpoint features at registration time (not per-request)
73
+ */
74
+ function analyzeEndpointFeatures(
75
+ endpoint: Endpoint<
76
+ any,
77
+ any,
78
+ any,
79
+ any,
80
+ any,
81
+ any,
82
+ any,
83
+ any,
84
+ any,
85
+ any,
86
+ any,
87
+ any,
88
+ any,
89
+ any
90
+ >,
91
+ ): EndpointFeatures {
92
+ return {
93
+ hasServices: endpoint.services.length > 0,
94
+ hasDatabase: !!endpoint.databaseService,
95
+ hasBodyValidation: !!endpoint.input?.body,
96
+ hasQueryValidation: !!endpoint.input?.query,
97
+ hasParamValidation: !!endpoint.input?.params,
98
+ // Audit context needed if declarative audits OR auditor storage service configured (for manual audits)
99
+ hasAudits:
100
+ (endpoint.audits?.length ?? 0) > 0 || !!endpoint.auditorStorageService,
101
+ hasEvents: (endpoint.events?.length ?? 0) > 0,
102
+ hasRateLimit: !!endpoint.rateLimit,
103
+ hasRls: !!endpoint.rlsConfig && !endpoint.rlsBypass,
104
+ };
52
105
  }
53
106
 
54
107
  export class HonoEndpoint<
55
- TRoute extends string,
56
- TMethod extends HttpMethod,
57
- TInput extends EndpointSchemas = {},
58
- TOutSchema extends StandardSchemaV1 | undefined = undefined,
59
- TServices extends Service[] = [],
60
- TLogger extends Logger = Logger,
61
- TSession = unknown,
62
- TEventPublisher extends EventPublisher<any> | undefined = undefined,
63
- TEventPublisherServiceName extends string = string,
64
- TAuditStorage extends AuditStorage | undefined = undefined,
65
- TAuditStorageServiceName extends string = string,
66
- TAuditAction extends AuditableAction<string, unknown> = AuditableAction<
67
- string,
68
- unknown
69
- >,
70
- TDatabase = undefined,
71
- TDatabaseServiceName extends string = string,
108
+ TRoute extends string,
109
+ TMethod extends HttpMethod,
110
+ TInput extends EndpointSchemas = {},
111
+ TOutSchema extends StandardSchemaV1 | undefined = undefined,
112
+ TServices extends Service[] = [],
113
+ TLogger extends Logger = Logger,
114
+ TSession = unknown,
115
+ TEventPublisher extends EventPublisher<any> | undefined = undefined,
116
+ TEventPublisherServiceName extends string = string,
117
+ TAuditStorage extends AuditStorage | undefined = undefined,
118
+ TAuditStorageServiceName extends string = string,
119
+ TAuditAction extends AuditableAction<string, unknown> = AuditableAction<
120
+ string,
121
+ unknown
122
+ >,
123
+ TDatabase = undefined,
124
+ TDatabaseServiceName extends string = string,
72
125
  > {
73
- constructor(
74
- private readonly endpoint: Endpoint<
75
- TRoute,
76
- TMethod,
77
- TInput,
78
- TOutSchema,
79
- TServices,
80
- TLogger,
81
- TSession,
82
- TEventPublisher,
83
- TEventPublisherServiceName,
84
- TAuditStorage,
85
- TAuditStorageServiceName,
86
- TAuditAction,
87
- TDatabase,
88
- TDatabaseServiceName
89
- >,
90
- ) {}
91
-
92
- static isDev = process.env.NODE_ENV === 'development';
93
-
94
- static async validate<T extends StandardSchemaV1>(
95
- c: Context<any, string, {}>,
96
- data: unknown,
97
- schema?: T,
98
- ) {
99
- if (!schema) {
100
- return undefined;
101
- }
102
-
103
- const parsed = await Endpoint.validate(schema, data);
104
-
105
- if (parsed.issues) {
106
- return c.json(parsed.issues, 422);
107
- }
108
-
109
- return parsed.value;
110
- }
111
- addRoute(
112
- serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,
113
- app: Hono,
114
- ): void {
115
- HonoEndpoint.addRoute(this.endpoint, serviceDiscovery, app);
116
- }
117
-
118
- static applyEventMiddleware(
119
- app: Hono,
120
- serviceDiscovery: ServiceDiscovery<any, any>,
121
- ) {
122
- app.use(async (c, next) => {
123
- await next();
124
- // @ts-ignore
125
- const endpoint = c.get('__endpoint') as Endpoint<
126
- any,
127
- any,
128
- any,
129
- any,
130
- any,
131
- any,
132
- any,
133
- any
134
- >;
135
- // @ts-ignore
136
- const response = c.get('__response');
137
- // @ts-ignore
138
- const logger = c.get('__logger') as Logger;
139
-
140
- if (Endpoint.isSuccessStatus(c.res.status) && endpoint) {
141
- // Process events (audits are handled in the handler with transaction support)
142
- await publishConstructEvents<any, any>(
143
- endpoint,
144
- response,
145
- serviceDiscovery,
146
- logger,
147
- );
148
- }
149
- });
150
- }
151
-
152
- static async fromRoutes<TLogger extends Logger, TServices extends Service[]>(
153
- routes: string[],
154
- envParser: EnvironmentParser<{}>,
155
- app = new Hono(),
156
- logger: TLogger,
157
- cwd = process.cwd(),
158
- options?: HonoEndpointOptions,
159
- ): Promise<Hono> {
160
- const endpoints = await getEndpointsFromRoutes<TServices>(routes, cwd);
161
- const serviceDiscovery = ServiceDiscovery.getInstance<
162
- ServiceRecord<TServices>,
163
- TLogger
164
- >(logger, envParser);
165
-
166
- HonoEndpoint.addRoutes(endpoints, serviceDiscovery, app, options);
167
-
168
- return app;
169
- }
170
-
171
- static addRoutes<
172
- TServices extends Service[] = [],
173
- TLogger extends Logger = Logger,
174
- >(
175
- endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[],
176
- serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,
177
- app: Hono,
178
- options?: HonoEndpointOptions,
179
- ): void {
180
- // Add timing middleware (always enabled)
181
- app.use('*', timing());
182
-
183
- // Add logger middleware in development mode
184
-
185
- if (HonoEndpoint.isDev) {
186
- app.use('*', honoLogger());
187
- }
188
-
189
- // Add docs route if not disabled
190
- const docsPath =
191
- options?.docsPath !== false ? options?.docsPath || '/docs' : null;
192
- if (docsPath) {
193
- HonoEndpoint.addDocsRoute(
194
- endpoints,
195
- app,
196
- docsPath,
197
- options?.openApiOptions,
198
- );
199
- }
200
-
201
- // Sort endpoints to ensure static routes come before dynamic ones
202
- const sortedEndpoints = endpoints.sort((a, b) => {
203
- const aSegments = a.route.split('/');
204
- const bSegments = b.route.split('/');
205
-
206
- // Compare each segment
207
- for (let i = 0; i < Math.max(aSegments.length, bSegments.length); i++) {
208
- const aSegment = aSegments[i] || '';
209
- const bSegment = bSegments[i] || '';
210
-
211
- // If one is dynamic and the other is not, static comes first
212
- const aIsDynamic = aSegment.startsWith(':');
213
- const bIsDynamic = bSegment.startsWith(':');
214
-
215
- if (!aIsDynamic && bIsDynamic) return -1;
216
- if (aIsDynamic && !bIsDynamic) return 1;
217
-
218
- // If both are the same type, compare alphabetically
219
- if (aSegment !== bSegment) {
220
- return aSegment.localeCompare(bSegment);
221
- }
222
- }
223
-
224
- return 0;
225
- });
226
- HonoEndpoint.applyEventMiddleware(app, serviceDiscovery);
227
- for (const endpoint of sortedEndpoints) {
228
- HonoEndpoint.addRoute(endpoint, serviceDiscovery, app);
229
- }
230
- }
231
-
232
- static addRoute<
233
- TRoute extends string,
234
- TMethod extends HttpMethod,
235
- TInput extends EndpointSchemas = {},
236
- TOutSchema extends StandardSchemaV1 | undefined = undefined,
237
- TServices extends Service[] = [],
238
- TLogger extends Logger = Logger,
239
- TSession = unknown,
240
- TEventPublisher extends EventPublisher<any> | undefined = undefined,
241
- TEventPublisherServiceName extends string = string,
242
- TAuditStorage extends AuditStorage | undefined = undefined,
243
- TAuditStorageServiceName extends string = string,
244
- TAuditAction extends AuditableAction<string, unknown> = AuditableAction<
245
- string,
246
- unknown
247
- >,
248
- TDatabase = undefined,
249
- TDatabaseServiceName extends string = string,
250
- >(
251
- endpoint: Endpoint<
252
- TRoute,
253
- TMethod,
254
- TInput,
255
- TOutSchema,
256
- TServices,
257
- TLogger,
258
- TSession,
259
- TEventPublisher,
260
- TEventPublisherServiceName,
261
- TAuditStorage,
262
- TAuditStorageServiceName,
263
- TAuditAction,
264
- TDatabase,
265
- TDatabaseServiceName
266
- >,
267
- serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,
268
- app: Hono,
269
- ): void {
270
- const { route } = endpoint;
271
- const method = endpoint.method.toLowerCase() as LowerHttpMethod<TMethod>;
272
-
273
- app[method](
274
- route,
275
- validator('json', (value, c) =>
276
- HonoEndpoint.validate(c, value, endpoint.input?.body),
277
- ),
278
- validator('query', (_, c) => {
279
- const parsedQuery = parseHonoQuery(c);
280
- return HonoEndpoint.validate(c, parsedQuery, endpoint.input?.query);
281
- }),
282
- validator('param', (params, c) =>
283
- HonoEndpoint.validate(c, params, endpoint.input?.params),
284
- ),
285
- async (c) => {
286
- const logger = endpoint.logger.child({
287
- endpoint: endpoint.fullPath,
288
- route: endpoint.route,
289
- host: c.header('host'),
290
- method: endpoint.method,
291
- path: c.req.path,
292
- }) as TLogger;
293
-
294
- try {
295
- const headerValues = c.req.header();
296
-
297
- const header = Endpoint.createHeaders(headerValues);
298
- const cookie = Endpoint.createCookies(headerValues.cookie);
299
-
300
- const services = await serviceDiscovery.register(endpoint.services);
301
-
302
- // Resolve database service early so it's available for session extraction
303
- const rawDb = endpoint.databaseService
304
- ? await serviceDiscovery
305
- .register([endpoint.databaseService])
306
- .then(
307
- (s) =>
308
- s[endpoint.databaseService!.serviceName as keyof typeof s],
309
- )
310
- : undefined;
311
-
312
- const session = await endpoint.getSession({
313
- services,
314
- logger,
315
- header,
316
- cookie,
317
- ...(rawDb !== undefined && { db: rawDb }),
318
- } as any);
319
-
320
- const isAuthorized = await endpoint.authorize({
321
- header,
322
- cookie,
323
- services,
324
- logger,
325
- session,
326
- });
327
-
328
- if (!isAuthorized) {
329
- logger.warn('Unauthorized access attempt');
330
- return c.json({ error: 'Unauthorized' }, 401);
331
- }
332
-
333
- // Check rate limit if configured
334
- if (endpoint.rateLimit) {
335
- const rateLimitInfo = await checkRateLimit(endpoint.rateLimit, {
336
- header,
337
- services,
338
- logger,
339
- session,
340
- path: c.req.path,
341
- method: endpoint.method,
342
- });
343
-
344
- // Set rate limit headers
345
- const rateLimitHeaders = getRateLimitHeaders(
346
- rateLimitInfo,
347
- endpoint.rateLimit,
348
- );
349
- for (const [key, value] of Object.entries(rateLimitHeaders)) {
350
- if (value) {
351
- c.header(key, value);
352
- }
353
- }
354
- }
355
-
356
- // Create audit context if audit storage is configured
357
- const auditContext = await createAuditContext(
358
- endpoint,
359
- serviceDiscovery,
360
- logger,
361
- {
362
- session,
363
- header,
364
- cookie,
365
- services: services as Record<string, unknown>,
366
- },
367
- );
368
-
369
- // Warn if declarative audits are configured but no audit storage
370
- const audits = endpoint.audits as MappedAudit<
371
- TAuditAction,
372
- TOutSchema
373
- >[];
374
- if (!auditContext && audits?.length) {
375
- logger.warn('No auditor storage service available');
376
- }
377
-
378
- // Extract RLS context if configured and not bypassed
379
- const rlsActive =
380
- endpoint.rlsConfig && !endpoint.rlsBypass && rawDb !== undefined;
381
- const rlsContext = rlsActive
382
- ? await endpoint.rlsConfig!.extractor({
383
- services,
384
- session,
385
- header,
386
- cookie,
387
- logger,
388
- })
389
- : undefined;
390
-
391
- // Execute handler with automatic audit transaction support
392
- const result = await executeWithAuditTransaction(
393
- auditContext,
394
- async (auditor) => {
395
- // Use audit transaction as db only if the storage uses the same database service
396
- const sameDatabase =
397
- auditContext?.storage?.databaseServiceName &&
398
- auditContext.storage.databaseServiceName ===
399
- endpoint.databaseService?.serviceName;
400
- const baseDb = sameDatabase
401
- ? (auditor?.getTransaction?.() ?? rawDb)
402
- : rawDb;
403
-
404
- // Helper to execute handler with given db
405
- const executeHandler = async (db: TDatabase | undefined) => {
406
- const responseBuilder = new ResponseBuilder();
407
- const response = await endpoint.handler(
408
- {
409
- services,
410
- logger,
411
- body: c.req.valid('json'),
412
- query: c.req.valid('query'),
413
- params: c.req.valid('param'),
414
- session,
415
- header,
416
- cookie,
417
- auditor,
418
- db,
419
- } as unknown as EndpointContext<
420
- TInput,
421
- TServices,
422
- TLogger,
423
- TSession,
424
- TAuditAction,
425
- TDatabase,
426
- TAuditStorage
427
- >,
428
- responseBuilder,
429
- );
430
-
431
- // Check if response has metadata
432
- let data = response;
433
- let metadata = responseBuilder.getMetadata();
434
-
435
- if (Endpoint.hasMetadata(response)) {
436
- data = response.data;
437
- metadata = response.metadata;
438
- }
439
-
440
- const output = endpoint.outputSchema
441
- ? await endpoint.parseOutput(data)
442
- : undefined;
443
-
444
- return { output, metadata, responseBuilder };
445
- };
446
-
447
- // If RLS is active, wrap handler with RLS context
448
- if (rlsActive && rlsContext && baseDb) {
449
- return withRlsContext(
450
- baseDb as any,
451
- rlsContext,
452
- async (trx) => executeHandler(trx as TDatabase),
453
- { prefix: endpoint.rlsConfig!.prefix },
454
- );
455
- }
456
-
457
- return executeHandler(baseDb as TDatabase | undefined);
458
- },
459
- // Process declarative audits after handler (inside transaction)
460
- async (result, auditor) => {
461
- if (!audits?.length) return;
462
-
463
- for (const audit of audits) {
464
- if (audit.when && !audit.when(result.output as any)) {
465
- continue;
466
- }
467
- const payload = audit.payload(result.output as any);
468
- const entityId = audit.entityId?.(result.output as any);
469
- auditor.audit(audit.type as any, payload as any, {
470
- table: audit.table,
471
- entityId,
472
- });
473
- }
474
- },
475
- // Pass rawDb so storage can reuse existing transactions
476
- { db: rawDb },
477
- );
478
-
479
- const { output, metadata } = result;
480
-
481
- try {
482
- let status = endpoint.status as ContentfulStatusCode;
483
-
484
- // Apply response metadata
485
- if (metadata.status) {
486
- status = metadata.status as ContentfulStatusCode;
487
- }
488
-
489
- if (metadata.headers) {
490
- for (const [key, value] of Object.entries(metadata.headers)) {
491
- c.header(key, value);
492
- }
493
- }
494
-
495
- if (metadata.cookies) {
496
- for (const [name, { value, options }] of metadata.cookies) {
497
- setCookie(c, name, value, options);
498
- }
499
- }
500
-
501
- // @ts-ignore
502
- c.set('__response', output);
503
- // @ts-ignore
504
- c.set('__endpoint', endpoint);
505
- // @ts-ignore
506
- c.set('__logger', logger);
507
- // @ts-ignore
508
- c.set('__session', session);
509
- // @ts-ignore
510
- c.set('__services', services);
511
-
512
- if (HonoEndpoint.isDev) {
513
- logger.info({ status, body: output }, 'Outgoing response');
514
- }
515
- // @ts-ignore
516
- return c.json(output, status);
517
- } catch (validationError: any) {
518
- logger.error(validationError, 'Output validation failed');
519
- const error = wrapError(
520
- validationError,
521
- 422,
522
- 'Response validation failed',
523
- );
524
- if (HonoEndpoint.isDev) {
525
- logger.info(
526
- { status: error.statusCode, body: error },
527
- 'Outgoing response',
528
- );
529
- }
530
- return c.json(error, error.statusCode as ContentfulStatusCode);
531
- }
532
- } catch (e: any) {
533
- logger.error(e, 'Error processing endpoint request');
534
- const error = wrapError(e, 500, 'Internal Server Error');
535
- if (HonoEndpoint.isDev) {
536
- logger.info(
537
- { status: error.statusCode, body: error },
538
- 'Outgoing response',
539
- );
540
- }
541
- return c.json(error, error.statusCode as ContentfulStatusCode);
542
- }
543
- },
544
- );
545
- }
546
-
547
- static addDocsRoute<
548
- TServices extends Service[] = [],
549
- TLogger extends Logger = Logger,
550
- >(
551
- endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[],
552
- app: Hono,
553
- docsPath: string,
554
- openApiOptions?: HonoEndpointOptions['openApiOptions'],
555
- ): void {
556
- app.get(docsPath, async (c) => {
557
- try {
558
- const openApiSchema = await Endpoint.buildOpenApiSchema(
559
- endpoints,
560
- openApiOptions,
561
- );
562
-
563
- return c.json(openApiSchema);
564
- } catch {
565
- return c.json(
566
- { error: 'Failed to generate OpenAPI documentation' },
567
- 500,
568
- );
569
- }
570
- });
571
- }
126
+ constructor(
127
+ private readonly endpoint: Endpoint<
128
+ TRoute,
129
+ TMethod,
130
+ TInput,
131
+ TOutSchema,
132
+ TServices,
133
+ TLogger,
134
+ TSession,
135
+ TEventPublisher,
136
+ TEventPublisherServiceName,
137
+ TAuditStorage,
138
+ TAuditStorageServiceName,
139
+ TAuditAction,
140
+ TDatabase,
141
+ TDatabaseServiceName
142
+ >,
143
+ ) {}
144
+
145
+ static isDev = process.env.NODE_ENV === 'development';
146
+
147
+ static async validate<T extends StandardSchemaV1>(
148
+ c: Context<any, string, {}>,
149
+ data: unknown,
150
+ schema?: T,
151
+ ) {
152
+ if (!schema) {
153
+ return undefined;
154
+ }
155
+
156
+ const parsed = await Endpoint.validate(schema, data);
157
+
158
+ if (parsed.issues) {
159
+ return c.json(parsed.issues, 422);
160
+ }
161
+
162
+ return parsed.value;
163
+ }
164
+ addRoute(
165
+ serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,
166
+ app: Hono,
167
+ ): void {
168
+ HonoEndpoint.addRoute(this.endpoint, serviceDiscovery, app);
169
+ }
170
+
171
+ /**
172
+ * @deprecated Global event middleware is no longer used.
173
+ * Events are now published per-route only for endpoints that have events configured.
174
+ * This method is kept for backward compatibility but does nothing.
175
+ */
176
+ static applyEventMiddleware(
177
+ _app: Hono,
178
+ _serviceDiscovery: ServiceDiscovery<any, any>,
179
+ ) {
180
+ // No-op: Event publishing is now handled per-route in addRoute
181
+ // This avoids running middleware on every request including 404s
182
+ }
183
+
184
+ static async fromRoutes<TLogger extends Logger, TServices extends Service[]>(
185
+ routes: string[],
186
+ envParser: EnvironmentParser<{}>,
187
+ app = new Hono(),
188
+ _logger: TLogger,
189
+ cwd = process.cwd(),
190
+ options?: HonoEndpointOptions,
191
+ ): Promise<Hono> {
192
+ const endpoints = await getEndpointsFromRoutes<TServices>(routes, cwd);
193
+ const serviceDiscovery =
194
+ ServiceDiscovery.getInstance<ServiceRecord<TServices>>(envParser);
195
+
196
+ HonoEndpoint.addRoutes(endpoints, serviceDiscovery, app, options);
197
+
198
+ return app;
199
+ }
200
+
201
+ static addRoutes<
202
+ TServices extends Service[] = [],
203
+ TLogger extends Logger = Logger,
204
+ >(
205
+ endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[],
206
+ serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,
207
+ app: Hono,
208
+ options?: HonoEndpointOptions,
209
+ ): void {
210
+ // Add timing middleware (always enabled)
211
+ app.use('*', timing());
212
+
213
+ // Add logger middleware in development mode
214
+
215
+ if (HonoEndpoint.isDev) {
216
+ app.use('*', honoLogger());
217
+ }
218
+
219
+ // Add docs route if not disabled
220
+ const docsPath =
221
+ options?.docsPath !== false ? options?.docsPath || '/docs' : null;
222
+ if (docsPath) {
223
+ HonoEndpoint.addDocsRoute(
224
+ endpoints,
225
+ app,
226
+ docsPath,
227
+ options?.openApiOptions,
228
+ );
229
+ }
230
+
231
+ // Sort endpoints to ensure static routes come before dynamic ones
232
+ const sortedEndpoints = endpoints.sort((a, b) => {
233
+ const aSegments = a.route.split('/');
234
+ const bSegments = b.route.split('/');
235
+
236
+ // Compare each segment
237
+ for (let i = 0; i < Math.max(aSegments.length, bSegments.length); i++) {
238
+ const aSegment = aSegments[i] || '';
239
+ const bSegment = bSegments[i] || '';
240
+
241
+ // If one is dynamic and the other is not, static comes first
242
+ const aIsDynamic = aSegment.startsWith(':');
243
+ const bIsDynamic = bSegment.startsWith(':');
244
+
245
+ if (!aIsDynamic && bIsDynamic) return -1;
246
+ if (aIsDynamic && !bIsDynamic) return 1;
247
+
248
+ // If both are the same type, compare alphabetically
249
+ if (aSegment !== bSegment) {
250
+ return aSegment.localeCompare(bSegment);
251
+ }
252
+ }
253
+
254
+ return 0;
255
+ });
256
+
257
+ // Note: Global event middleware removed for performance
258
+ // Events are now published per-route only for endpoints with events configured
259
+ for (const endpoint of sortedEndpoints) {
260
+ HonoEndpoint.addRoute(endpoint, serviceDiscovery, app);
261
+ }
262
+ }
263
+
264
+ static addRoute<
265
+ TRoute extends string,
266
+ TMethod extends HttpMethod,
267
+ TInput extends EndpointSchemas = {},
268
+ TOutSchema extends StandardSchemaV1 | undefined = undefined,
269
+ TServices extends Service[] = [],
270
+ TLogger extends Logger = Logger,
271
+ TSession = unknown,
272
+ TEventPublisher extends EventPublisher<any> | undefined = undefined,
273
+ TEventPublisherServiceName extends string = string,
274
+ TAuditStorage extends AuditStorage | undefined = undefined,
275
+ TAuditStorageServiceName extends string = string,
276
+ TAuditAction extends AuditableAction<string, unknown> = AuditableAction<
277
+ string,
278
+ unknown
279
+ >,
280
+ TDatabase = undefined,
281
+ TDatabaseServiceName extends string = string,
282
+ >(
283
+ endpoint: Endpoint<
284
+ TRoute,
285
+ TMethod,
286
+ TInput,
287
+ TOutSchema,
288
+ TServices,
289
+ TLogger,
290
+ TSession,
291
+ TEventPublisher,
292
+ TEventPublisherServiceName,
293
+ TAuditStorage,
294
+ TAuditStorageServiceName,
295
+ TAuditAction,
296
+ TDatabase,
297
+ TDatabaseServiceName
298
+ >,
299
+ serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>, TLogger>,
300
+ app: Hono,
301
+ ): void {
302
+ const { route } = endpoint;
303
+ const method = endpoint.method.toLowerCase() as LowerHttpMethod<TMethod>;
304
+
305
+ // Analyze endpoint features once at registration time (not per-request)
306
+ const features = analyzeEndpointFeatures(endpoint);
307
+
308
+ // Build validators array - only add validators for schemas that exist
309
+ const validators: any[] = [];
310
+
311
+ if (features.hasBodyValidation) {
312
+ validators.push(
313
+ validator('json', (value, c) =>
314
+ HonoEndpoint.validate(c, value, endpoint.input?.body),
315
+ ),
316
+ );
317
+ }
318
+
319
+ if (features.hasQueryValidation) {
320
+ validators.push(
321
+ validator('query', (_, c) => {
322
+ const parsedQuery = parseHonoQuery(c);
323
+ return HonoEndpoint.validate(c, parsedQuery, endpoint.input?.query);
324
+ }),
325
+ );
326
+ }
327
+
328
+ if (features.hasParamValidation) {
329
+ validators.push(
330
+ validator('param', (params, c) =>
331
+ HonoEndpoint.validate(c, params, endpoint.input?.params),
332
+ ),
333
+ );
334
+ }
335
+
336
+ // Main handler
337
+ const handler = async (c: Context) => {
338
+ // Request context setup
339
+ const startTime = Date.now();
340
+ const requestId = c.req.header('X-Request-ID') ?? crypto.randomUUID();
341
+
342
+ const logger = endpoint.logger.child({
343
+ requestId,
344
+ endpoint: endpoint.fullPath,
345
+ route: endpoint.route,
346
+ host: c.req.header('host'),
347
+ method: endpoint.method,
348
+ path: c.req.path,
349
+ }) as TLogger;
350
+
351
+ // Set response header
352
+ c.header('X-Request-ID', requestId);
353
+
354
+ // Wrap entire handler in request context for services to access
355
+ return runWithRequestContext(
356
+ { logger, requestId, startTime },
357
+ async () => {
358
+ try {
359
+ // Lazy accessors - no upfront parsing, use native Hono methods
360
+ const header = createHonoHeaders(c);
361
+ const cookie = createHonoCookies(c);
362
+
363
+ // Only register services if endpoint has any
364
+ const services = features.hasServices
365
+ ? await serviceDiscovery.register(endpoint.services)
366
+ : ({} as ServiceRecord<TServices>);
367
+
368
+ // Resolve database service only if configured
369
+ const rawDb = features.hasDatabase
370
+ ? await serviceDiscovery
371
+ .register([endpoint.databaseService!])
372
+ .then(
373
+ (s) =>
374
+ s[
375
+ endpoint.databaseService?.serviceName as keyof typeof s
376
+ ],
377
+ )
378
+ : undefined;
379
+
380
+ // Extract session (defaults to empty object)
381
+ const session = await endpoint.getSession({
382
+ services,
383
+ logger,
384
+ header,
385
+ cookie,
386
+ ...(rawDb !== undefined && { db: rawDb }),
387
+ } as any);
388
+
389
+ // Check authorization (defaults to true)
390
+ const isAuthorized = await endpoint.authorize({
391
+ header,
392
+ cookie,
393
+ services,
394
+ logger,
395
+ session,
396
+ });
397
+
398
+ if (!isAuthorized) {
399
+ logger.warn('Unauthorized access attempt');
400
+ return c.json({ error: 'Unauthorized' }, 401);
401
+ }
402
+
403
+ // Check rate limit only if configured
404
+ if (features.hasRateLimit) {
405
+ const rateLimitInfo = await checkRateLimit(endpoint.rateLimit!, {
406
+ header,
407
+ services,
408
+ logger,
409
+ session,
410
+ path: c.req.path,
411
+ method: endpoint.method,
412
+ });
413
+
414
+ const rateLimitHeaders = getRateLimitHeaders(
415
+ rateLimitInfo,
416
+ endpoint.rateLimit!,
417
+ );
418
+ for (const [key, value] of Object.entries(rateLimitHeaders)) {
419
+ if (value) {
420
+ c.header(key, value);
421
+ }
422
+ }
423
+ }
424
+
425
+ // Create audit context only if audits are configured
426
+ const auditContext = features.hasAudits
427
+ ? await createAuditContext(
428
+ endpoint as any,
429
+ serviceDiscovery,
430
+ logger,
431
+ {
432
+ session,
433
+ header,
434
+ cookie,
435
+ services: services as Record<string, unknown>,
436
+ },
437
+ )
438
+ : undefined;
439
+
440
+ const audits = features.hasAudits
441
+ ? (endpoint.audits as MappedAudit<TAuditAction, TOutSchema>[])
442
+ : [];
443
+
444
+ // Warn if declarative audits are configured but no audit storage
445
+ if (features.hasAudits && !auditContext) {
446
+ logger.warn('No auditor storage service available');
447
+ }
448
+
449
+ // Extract RLS context only if configured and not bypassed
450
+ const rlsContext =
451
+ features.hasRls && rawDb !== undefined
452
+ ? await endpoint.rlsConfig?.extractor({
453
+ services,
454
+ session: session as TSession,
455
+ header,
456
+ cookie,
457
+ logger,
458
+ })
459
+ : undefined;
460
+
461
+ // Execute handler with automatic audit transaction support
462
+ const result = await executeWithAuditTransaction(
463
+ auditContext,
464
+ async (auditor) => {
465
+ const sameDatabase =
466
+ auditContext?.storage?.databaseServiceName &&
467
+ auditContext.storage.databaseServiceName ===
468
+ endpoint.databaseService?.serviceName;
469
+ const baseDb = sameDatabase
470
+ ? (auditor?.getTransaction?.() ?? rawDb)
471
+ : rawDb;
472
+
473
+ const executeHandler = async (db: TDatabase | undefined) => {
474
+ const responseBuilder = new ResponseBuilder();
475
+ const response = await endpoint.handler(
476
+ {
477
+ services,
478
+ logger,
479
+ body: features.hasBodyValidation
480
+ ? (c.req.valid as any)('json')
481
+ : undefined,
482
+ query: features.hasQueryValidation
483
+ ? (c.req.valid as any)('query')
484
+ : undefined,
485
+ params: features.hasParamValidation
486
+ ? (c.req.valid as any)('param')
487
+ : undefined,
488
+ session,
489
+ header,
490
+ cookie,
491
+ auditor,
492
+ db,
493
+ } as unknown as EndpointContext<
494
+ TInput,
495
+ TServices,
496
+ TLogger,
497
+ TSession,
498
+ TAuditAction,
499
+ TDatabase,
500
+ TAuditStorage
501
+ >,
502
+ responseBuilder,
503
+ );
504
+
505
+ let data = response;
506
+ let metadata = responseBuilder.getMetadata();
507
+
508
+ if (Endpoint.hasMetadata(response)) {
509
+ data = response.data;
510
+ metadata = response.metadata;
511
+ }
512
+
513
+ const output = endpoint.outputSchema
514
+ ? await endpoint.parseOutput(data)
515
+ : undefined;
516
+
517
+ return { output, metadata, responseBuilder };
518
+ };
519
+
520
+ if (features.hasRls && rlsContext && baseDb) {
521
+ return withRlsContext(
522
+ baseDb as any,
523
+ rlsContext,
524
+ async (trx) => executeHandler(trx as TDatabase),
525
+ { prefix: endpoint.rlsConfig?.prefix },
526
+ );
527
+ }
528
+
529
+ return executeHandler(baseDb as TDatabase | undefined);
530
+ },
531
+ async (result, auditor) => {
532
+ if (!audits?.length) return;
533
+
534
+ for (const audit of audits) {
535
+ if (audit.when && !audit.when(result.output as any)) {
536
+ continue;
537
+ }
538
+ const payload = audit.payload(result.output as any);
539
+ const entityId = audit.entityId?.(result.output as any);
540
+ auditor.audit(audit.type as any, payload as any, {
541
+ table: audit.table,
542
+ entityId,
543
+ });
544
+ }
545
+ },
546
+ { db: rawDb },
547
+ );
548
+
549
+ const { output, metadata } = result;
550
+
551
+ try {
552
+ let status = endpoint.status as ContentfulStatusCode;
553
+
554
+ if (metadata.status) {
555
+ status = metadata.status as ContentfulStatusCode;
556
+ }
557
+
558
+ if (metadata.headers) {
559
+ for (const [key, value] of Object.entries(metadata.headers)) {
560
+ c.header(key, value);
561
+ }
562
+ }
563
+
564
+ if (metadata.cookies) {
565
+ for (const [name, { value, options }] of metadata.cookies) {
566
+ setCookie(c, name, value, options);
567
+ }
568
+ }
569
+
570
+ // Only publish events if configured (no global middleware overhead)
571
+ if (features.hasEvents && Endpoint.isSuccessStatus(status)) {
572
+ await publishConstructEvents<any, any>(
573
+ endpoint as any,
574
+ output,
575
+ serviceDiscovery,
576
+ logger,
577
+ );
578
+ }
579
+
580
+ if (HonoEndpoint.isDev) {
581
+ logger.info({ status, body: output }, 'Outgoing response');
582
+ }
583
+
584
+ // @ts-expect-error
585
+ return c.json(output, status);
586
+ } catch (validationError: any) {
587
+ logger.error(validationError, 'Output validation failed');
588
+ const error = wrapError(
589
+ validationError,
590
+ 422,
591
+ 'Response validation failed',
592
+ );
593
+ if (HonoEndpoint.isDev) {
594
+ logger.info(
595
+ { status: error.statusCode, body: error },
596
+ 'Outgoing response',
597
+ );
598
+ }
599
+ return c.json(error, error.statusCode as ContentfulStatusCode);
600
+ }
601
+ } catch (e: any) {
602
+ logger.error(e, 'Error processing endpoint request');
603
+ const error = wrapError(e, 500, 'Internal Server Error');
604
+ if (HonoEndpoint.isDev) {
605
+ logger.info(
606
+ { status: error.statusCode, body: error },
607
+ 'Outgoing response',
608
+ );
609
+ }
610
+ return c.json(error, error.statusCode as ContentfulStatusCode);
611
+ }
612
+ },
613
+ );
614
+ };
615
+
616
+ // Register route with conditional validators
617
+ app[method](route, ...validators, handler);
618
+ }
619
+
620
+ static addDocsRoute<
621
+ TServices extends Service[] = [],
622
+ TLogger extends Logger = Logger,
623
+ >(
624
+ endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[],
625
+ app: Hono,
626
+ docsPath: string,
627
+ openApiOptions?: HonoEndpointOptions['openApiOptions'],
628
+ ): void {
629
+ app.get(docsPath, async (c) => {
630
+ try {
631
+ const openApiSchema = await Endpoint.buildOpenApiSchema(
632
+ endpoints,
633
+ openApiOptions,
634
+ );
635
+
636
+ return c.json(openApiSchema);
637
+ } catch {
638
+ return c.json(
639
+ { error: 'Failed to generate OpenAPI documentation' },
640
+ 500,
641
+ );
642
+ }
643
+ });
644
+ }
572
645
  }