@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
@@ -10,449 +10,449 @@ import { Function } from '../Function';
10
10
 
11
11
  // Mock services
12
12
  class TestService implements Service<'TestService', TestService> {
13
- serviceName = 'TestService' as const;
14
- static serviceName = 'TestService';
13
+ serviceName = 'TestService' as const;
14
+ static serviceName = 'TestService';
15
15
 
16
- async register() {
17
- return this;
18
- }
16
+ async register() {
17
+ return this;
18
+ }
19
19
 
20
- getValue() {
21
- return 'test-value';
22
- }
20
+ getValue() {
21
+ return 'test-value';
22
+ }
23
23
  }
24
24
 
25
25
  // Mock event publisher
26
26
  type TestEvent = PublishableMessage<'test.event', { data: string }>;
27
27
 
28
28
  class TestPublisher implements EventPublisher<TestEvent> {
29
- publishedEvents: TestEvent[] = [];
29
+ publishedEvents: TestEvent[] = [];
30
30
 
31
- async publish(events: TestEvent[]): Promise<void> {
32
- this.publishedEvents.push(...events);
33
- }
31
+ async publish(events: TestEvent[]): Promise<void> {
32
+ this.publishedEvents.push(...events);
33
+ }
34
34
  }
35
35
 
36
36
  class TestPublisherService
37
- implements Service<'TestPublisherService', TestPublisher>
37
+ implements Service<'TestPublisherService', TestPublisher>
38
38
  {
39
- serviceName = 'TestPublisherService' as const;
40
- static serviceName = 'TestPublisherService';
41
- publisher = new TestPublisher();
39
+ serviceName = 'TestPublisherService' as const;
40
+ static serviceName = 'TestPublisherService';
41
+ publisher = new TestPublisher();
42
42
 
43
- async register() {
44
- return this.publisher;
45
- }
43
+ async register() {
44
+ return this.publisher;
45
+ }
46
46
  }
47
47
 
48
48
  // Mock Lambda context
49
49
  const createMockContext = (): Context => ({
50
- functionName: 'test-function',
51
- functionVersion: '1',
52
- invokedFunctionArn: 'arn:aws:lambda:region:account:function:test-function',
53
- memoryLimitInMB: '128',
54
- awsRequestId: 'test-request-id',
55
- logGroupName: '/aws/lambda/test-function',
56
- logStreamName: '2023/01/01/[$LATEST]test-stream',
57
- getRemainingTimeInMillis: () => 30000,
58
- done: vi.fn(),
59
- fail: vi.fn(),
60
- succeed: vi.fn(),
61
- callbackWaitsForEmptyEventLoop: true,
50
+ functionName: 'test-function',
51
+ functionVersion: '1',
52
+ invokedFunctionArn: 'arn:aws:lambda:region:account:function:test-function',
53
+ memoryLimitInMB: '128',
54
+ awsRequestId: 'test-request-id',
55
+ logGroupName: '/aws/lambda/test-function',
56
+ logStreamName: '2023/01/01/[$LATEST]test-stream',
57
+ getRemainingTimeInMillis: () => 30000,
58
+ done: vi.fn(),
59
+ fail: vi.fn(),
60
+ succeed: vi.fn(),
61
+ callbackWaitsForEmptyEventLoop: true,
62
62
  });
63
63
 
64
64
  describe('AWSLambdaFunction', () => {
65
- let envParser: EnvironmentParser<{}>;
66
- let logger: ConsoleLogger;
67
-
68
- beforeEach(() => {
69
- envParser = new EnvironmentParser({});
70
- logger = new ConsoleLogger();
71
- vi.clearAllMocks();
72
- });
73
-
74
- describe('basic function execution', () => {
75
- it('should execute a simple function without input/output schemas', async () => {
76
- const fn = new Function(async ({ input }) => {
77
- return { message: `Hello ` };
78
- });
79
-
80
- const adaptor = new AWSLambdaFunction(envParser, fn);
81
- const handler = adaptor.handler;
82
-
83
- const result = await handler(
84
- { name: 'World' },
85
- createMockContext(),
86
- vi.fn(),
87
- );
88
-
89
- expect(result).toBeUndefined();
90
- });
91
-
92
- it('should execute a function with input schema validation', async () => {
93
- const inputSchema = { name: z.string() };
94
- const outputSchema = z.object({ message: z.string() });
95
- const handler = vi.fn(async ({ input }) => ({
96
- message: `Hello ${input.name}`,
97
- }));
98
-
99
- const fn = new Function(
100
- handler,
101
- undefined,
102
- undefined,
103
- inputSchema,
104
- outputSchema,
105
- [],
106
- logger,
107
- );
108
-
109
- const adaptor = new AWSLambdaFunction(envParser, fn);
110
- const lambdaHandler = adaptor.handler;
111
-
112
- const result = await lambdaHandler(
113
- { name: 'TypeScript' },
114
- createMockContext(),
115
- vi.fn(),
116
- );
117
-
118
- expect(result).toEqual({ message: 'Hello TypeScript' });
119
- expect(handler).toHaveBeenCalledWith(
120
- expect.objectContaining({
121
- input: { name: 'TypeScript' },
122
- }),
123
- );
124
- });
125
-
126
- it('should fail with invalid input', async () => {
127
- const inputSchema = { age: z.number() };
128
- const fn = new Function(
129
- async () => ({ success: true }),
130
- undefined,
131
- undefined,
132
- inputSchema,
133
- undefined,
134
- [],
135
- logger,
136
- );
137
-
138
- const adaptor = new AWSLambdaFunction(envParser, fn);
139
- const handler = adaptor.handler;
140
-
141
- await expect(
142
- handler({ age: 'not a number' }, createMockContext(), vi.fn()),
143
- ).rejects.toThrow();
144
- });
145
-
146
- it('should validate output schema', async () => {
147
- const outputSchema = z.object({
148
- id: z.string(),
149
- timestamp: z.number(),
150
- });
151
-
152
- const fn = new Function(
153
- async () => ({
154
- id: '123',
155
- timestamp: Date.now(),
156
- }),
157
- undefined,
158
- undefined,
159
- undefined,
160
- outputSchema,
161
- [],
162
- logger,
163
- );
164
-
165
- const adaptor = new AWSLambdaFunction(envParser, fn);
166
- const handler = adaptor.handler;
167
-
168
- const result = await handler({}, createMockContext(), vi.fn());
169
-
170
- expect(result).toMatchObject({
171
- id: '123',
172
- timestamp: expect.any(Number),
173
- });
174
- });
175
-
176
- it('should fail with invalid output', async () => {
177
- const outputSchema = z.object({
178
- id: z.string(),
179
- });
180
-
181
- const fn = new Function(
182
- // @ts-ignore
183
- async () => ({
184
- id: 123, // Invalid type, should be string
185
- }),
186
- undefined,
187
- undefined,
188
- undefined,
189
- outputSchema,
190
- [],
191
- logger,
192
- );
193
-
194
- const adaptor = new AWSLambdaFunction(envParser, fn);
195
- const handler = adaptor.handler;
196
-
197
- await expect(handler({}, createMockContext(), vi.fn())).rejects.toThrow();
198
- });
199
- });
200
-
201
- describe('services', () => {
202
- it('should inject services into function context', async () => {
203
- const service = new TestService();
204
- const handler = vi.fn(async ({ services }) => ({
205
- value: services.TestService.getValue(),
206
- }));
207
-
208
- const schema = z.object({ value: z.string() });
209
- const fn = new Function(
210
- handler,
211
- undefined,
212
- undefined,
213
- undefined,
214
- schema,
215
- [service],
216
- logger,
217
- );
218
-
219
- const adaptor = new AWSLambdaFunction(envParser, fn);
220
- const lambdaHandler = adaptor.handler;
221
-
222
- const result = await lambdaHandler({}, createMockContext(), vi.fn());
223
-
224
- expect(result).toEqual({ value: 'test-value' });
225
- expect(handler).toHaveBeenCalledWith(
226
- expect.objectContaining({
227
- services: expect.objectContaining({
228
- TestService: expect.any(TestService),
229
- }),
230
- }),
231
- );
232
- });
233
- });
234
-
235
- describe('logging', () => {
236
- it('should create child logger with Lambda context', async () => {
237
- const mockLogger = {
238
- child: vi.fn().mockReturnThis(),
239
- info: vi.fn(),
240
- error: vi.fn(),
241
- warn: vi.fn(),
242
- debug: vi.fn(),
243
- };
244
-
245
- const fn = new Function(
246
- async ({ logger }) => {
247
- logger.info('Function executed');
248
- return { success: true };
249
- },
250
- undefined,
251
- undefined,
252
- undefined,
253
- undefined,
254
- [],
255
- mockLogger as any,
256
- );
257
-
258
- const adaptor = new AWSLambdaFunction(envParser, fn);
259
- const handler = adaptor.handler;
260
-
261
- const context = createMockContext();
262
- await handler({}, context, vi.fn());
263
-
264
- expect(mockLogger.child).toHaveBeenCalledWith({
265
- fn: {
266
- name: 'test-function',
267
- version: '1',
268
- memory: '128',
269
- },
270
- req: {
271
- id: 'test-request-id',
272
- },
273
- });
274
- expect(mockLogger.info).toHaveBeenCalledWith('Function executed');
275
- });
276
- });
277
-
278
- describe('error handling', () => {
279
- it('should wrap and log errors', async () => {
280
- const mockLogger = {
281
- child: vi.fn().mockReturnThis(),
282
- error: vi.fn(),
283
- info: vi.fn(),
284
- warn: vi.fn(),
285
- debug: vi.fn(),
286
- };
287
-
288
- const fn = new Function(
289
- async () => {
290
- throw new Error('Function failed');
291
- },
292
- undefined,
293
- undefined,
294
- undefined,
295
- undefined,
296
- [],
297
- mockLogger as any,
298
- );
299
-
300
- const adaptor = new AWSLambdaFunction(envParser, fn);
301
- const handler = adaptor.handler;
302
-
303
- await expect(handler({}, createMockContext(), vi.fn())).rejects.toThrow();
304
-
305
- expect(mockLogger.error).toHaveBeenCalledWith(
306
- expect.any(Error),
307
- 'Error processing function',
308
- );
309
- });
310
- });
311
-
312
- describe('events', () => {
313
- it('should publish events after successful execution', async () => {
314
- const publisherService = new TestPublisherService();
315
-
316
- const fn = new Function(
317
- async () => ({ id: '123' }),
318
- undefined,
319
- undefined,
320
- undefined,
321
- z.object({ id: z.string() }),
322
- [],
323
- logger,
324
- publisherService,
325
- [
326
- {
327
- type: 'test.event',
328
- payload: (response) => ({ data: response.id }),
329
- },
330
- ],
331
- );
332
-
333
- const adaptor = new AWSLambdaFunction(envParser, fn);
334
- const handler = adaptor.handler;
335
-
336
- await handler({}, createMockContext(), vi.fn());
337
-
338
- expect(publisherService.publisher.publishedEvents).toHaveLength(1);
339
- expect(publisherService.publisher.publishedEvents[0]).toEqual({
340
- type: 'test.event',
341
- payload: { data: '123' },
342
- });
343
- });
344
-
345
- it('should conditionally publish events based on when clause', async () => {
346
- const publisherService = new TestPublisherService();
347
-
348
- const fn = new Function(
349
- async () => ({ success: false }),
350
- undefined,
351
- undefined,
352
- undefined,
353
- z.object({ success: z.boolean() }),
354
- [],
355
- logger,
356
- publisherService,
357
- [
358
- {
359
- type: 'test.event',
360
- payload: () => ({ data: 'test' }),
361
- when: (response) => response.success === true,
362
- },
363
- ],
364
- );
365
-
366
- const adaptor = new AWSLambdaFunction(envParser, fn);
367
- const handler = adaptor.handler;
368
-
369
- await handler({}, createMockContext(), vi.fn());
370
-
371
- expect(publisherService.publisher.publishedEvents).toHaveLength(0);
372
- });
373
- });
374
-
375
- // Skipping timeout tests for now as middleware order needs to be adjusted
376
-
377
- describe('database', () => {
378
- // Mock database service
379
- class MockDatabase {
380
- async query(sql: string) {
381
- return [{ id: '1', name: 'Test User' }];
382
- }
383
- }
384
-
385
- class DatabaseService implements Service<'database', MockDatabase> {
386
- serviceName = 'database' as const;
387
- db = new MockDatabase();
388
-
389
- async register() {
390
- return this.db;
391
- }
392
- }
393
-
394
- it('should inject database into function context', async () => {
395
- const databaseService = new DatabaseService();
396
- const handler = vi.fn(async ({ db }) => {
397
- const result = await db.query('SELECT * FROM users');
398
- return { users: result };
399
- });
400
-
401
- const outputSchema = z.object({
402
- users: z.array(z.object({ id: z.string(), name: z.string() })),
403
- });
404
-
405
- const fn = new Function(
406
- handler,
407
- undefined,
408
- undefined,
409
- undefined,
410
- outputSchema,
411
- [],
412
- logger,
413
- undefined,
414
- [],
415
- undefined,
416
- undefined,
417
- databaseService,
418
- );
419
-
420
- const adaptor = new AWSLambdaFunction(envParser, fn);
421
- const lambdaHandler = adaptor.handler;
422
-
423
- const result = await lambdaHandler({}, createMockContext(), vi.fn());
424
-
425
- expect(result).toEqual({ users: [{ id: '1', name: 'Test User' }] });
426
- expect(handler).toHaveBeenCalledWith(
427
- expect.objectContaining({
428
- db: expect.any(MockDatabase),
429
- }),
430
- );
431
- });
432
-
433
- it('should have db as undefined when no database service is configured', async () => {
434
- const handler = vi.fn(async ({ db }) => {
435
- return { hasDb: db !== undefined };
436
- });
437
-
438
- const outputSchema = z.object({ hasDb: z.boolean() });
439
-
440
- const fn = new Function(
441
- handler,
442
- undefined,
443
- undefined,
444
- undefined,
445
- outputSchema,
446
- [],
447
- logger,
448
- );
449
-
450
- const adaptor = new AWSLambdaFunction(envParser, fn);
451
- const lambdaHandler = adaptor.handler;
452
-
453
- const result = await lambdaHandler({}, createMockContext(), vi.fn());
454
-
455
- expect(result).toEqual({ hasDb: false });
456
- });
457
- });
65
+ let envParser: EnvironmentParser<{}>;
66
+ let logger: ConsoleLogger;
67
+
68
+ beforeEach(() => {
69
+ envParser = new EnvironmentParser({});
70
+ logger = new ConsoleLogger();
71
+ vi.clearAllMocks();
72
+ });
73
+
74
+ describe('basic function execution', () => {
75
+ it('should execute a simple function without input/output schemas', async () => {
76
+ const fn = new Function(async ({ input }) => {
77
+ return { message: `Hello ` };
78
+ });
79
+
80
+ const adaptor = new AWSLambdaFunction(envParser, fn);
81
+ const handler = adaptor.handler;
82
+
83
+ const result = await handler(
84
+ { name: 'World' },
85
+ createMockContext(),
86
+ vi.fn(),
87
+ );
88
+
89
+ expect(result).toBeUndefined();
90
+ });
91
+
92
+ it('should execute a function with input schema validation', async () => {
93
+ const inputSchema = { name: z.string() };
94
+ const outputSchema = z.object({ message: z.string() });
95
+ const handler = vi.fn(async ({ input }) => ({
96
+ message: `Hello ${input.name}`,
97
+ }));
98
+
99
+ const fn = new Function(
100
+ handler,
101
+ undefined,
102
+ undefined,
103
+ inputSchema,
104
+ outputSchema,
105
+ [],
106
+ logger,
107
+ );
108
+
109
+ const adaptor = new AWSLambdaFunction(envParser, fn);
110
+ const lambdaHandler = adaptor.handler;
111
+
112
+ const result = await lambdaHandler(
113
+ { name: 'TypeScript' },
114
+ createMockContext(),
115
+ vi.fn(),
116
+ );
117
+
118
+ expect(result).toEqual({ message: 'Hello TypeScript' });
119
+ expect(handler).toHaveBeenCalledWith(
120
+ expect.objectContaining({
121
+ input: { name: 'TypeScript' },
122
+ }),
123
+ );
124
+ });
125
+
126
+ it('should fail with invalid input', async () => {
127
+ const inputSchema = { age: z.number() };
128
+ const fn = new Function(
129
+ async () => ({ success: true }),
130
+ undefined,
131
+ undefined,
132
+ inputSchema,
133
+ undefined,
134
+ [],
135
+ logger,
136
+ );
137
+
138
+ const adaptor = new AWSLambdaFunction(envParser, fn);
139
+ const handler = adaptor.handler;
140
+
141
+ await expect(
142
+ handler({ age: 'not a number' }, createMockContext(), vi.fn()),
143
+ ).rejects.toThrow();
144
+ });
145
+
146
+ it('should validate output schema', async () => {
147
+ const outputSchema = z.object({
148
+ id: z.string(),
149
+ timestamp: z.number(),
150
+ });
151
+
152
+ const fn = new Function(
153
+ async () => ({
154
+ id: '123',
155
+ timestamp: Date.now(),
156
+ }),
157
+ undefined,
158
+ undefined,
159
+ undefined,
160
+ outputSchema,
161
+ [],
162
+ logger,
163
+ );
164
+
165
+ const adaptor = new AWSLambdaFunction(envParser, fn);
166
+ const handler = adaptor.handler;
167
+
168
+ const result = await handler({}, createMockContext(), vi.fn());
169
+
170
+ expect(result).toMatchObject({
171
+ id: '123',
172
+ timestamp: expect.any(Number),
173
+ });
174
+ });
175
+
176
+ it('should fail with invalid output', async () => {
177
+ const outputSchema = z.object({
178
+ id: z.string(),
179
+ });
180
+
181
+ const fn = new Function(
182
+ // @ts-expect-error
183
+ async () => ({
184
+ id: 123, // Invalid type, should be string
185
+ }),
186
+ undefined,
187
+ undefined,
188
+ undefined,
189
+ outputSchema,
190
+ [],
191
+ logger,
192
+ );
193
+
194
+ const adaptor = new AWSLambdaFunction(envParser, fn);
195
+ const handler = adaptor.handler;
196
+
197
+ await expect(handler({}, createMockContext(), vi.fn())).rejects.toThrow();
198
+ });
199
+ });
200
+
201
+ describe('services', () => {
202
+ it('should inject services into function context', async () => {
203
+ const service = new TestService();
204
+ const handler = vi.fn(async ({ services }) => ({
205
+ value: services.TestService.getValue(),
206
+ }));
207
+
208
+ const schema = z.object({ value: z.string() });
209
+ const fn = new Function(
210
+ handler,
211
+ undefined,
212
+ undefined,
213
+ undefined,
214
+ schema,
215
+ [service],
216
+ logger,
217
+ );
218
+
219
+ const adaptor = new AWSLambdaFunction(envParser, fn);
220
+ const lambdaHandler = adaptor.handler;
221
+
222
+ const result = await lambdaHandler({}, createMockContext(), vi.fn());
223
+
224
+ expect(result).toEqual({ value: 'test-value' });
225
+ expect(handler).toHaveBeenCalledWith(
226
+ expect.objectContaining({
227
+ services: expect.objectContaining({
228
+ TestService: expect.any(TestService),
229
+ }),
230
+ }),
231
+ );
232
+ });
233
+ });
234
+
235
+ describe('logging', () => {
236
+ it('should create child logger with Lambda context', async () => {
237
+ const mockLogger = {
238
+ child: vi.fn().mockReturnThis(),
239
+ info: vi.fn(),
240
+ error: vi.fn(),
241
+ warn: vi.fn(),
242
+ debug: vi.fn(),
243
+ };
244
+
245
+ const fn = new Function(
246
+ async ({ logger }) => {
247
+ logger.info('Function executed');
248
+ return { success: true };
249
+ },
250
+ undefined,
251
+ undefined,
252
+ undefined,
253
+ undefined,
254
+ [],
255
+ mockLogger as any,
256
+ );
257
+
258
+ const adaptor = new AWSLambdaFunction(envParser, fn);
259
+ const handler = adaptor.handler;
260
+
261
+ const context = createMockContext();
262
+ await handler({}, context, vi.fn());
263
+
264
+ expect(mockLogger.child).toHaveBeenCalledWith({
265
+ fn: {
266
+ name: 'test-function',
267
+ version: '1',
268
+ memory: '128',
269
+ },
270
+ req: {
271
+ id: 'test-request-id',
272
+ },
273
+ });
274
+ expect(mockLogger.info).toHaveBeenCalledWith('Function executed');
275
+ });
276
+ });
277
+
278
+ describe('error handling', () => {
279
+ it('should wrap and log errors', async () => {
280
+ const mockLogger = {
281
+ child: vi.fn().mockReturnThis(),
282
+ error: vi.fn(),
283
+ info: vi.fn(),
284
+ warn: vi.fn(),
285
+ debug: vi.fn(),
286
+ };
287
+
288
+ const fn = new Function(
289
+ async () => {
290
+ throw new Error('Function failed');
291
+ },
292
+ undefined,
293
+ undefined,
294
+ undefined,
295
+ undefined,
296
+ [],
297
+ mockLogger as any,
298
+ );
299
+
300
+ const adaptor = new AWSLambdaFunction(envParser, fn);
301
+ const handler = adaptor.handler;
302
+
303
+ await expect(handler({}, createMockContext(), vi.fn())).rejects.toThrow();
304
+
305
+ expect(mockLogger.error).toHaveBeenCalledWith(
306
+ expect.any(Error),
307
+ 'Error processing function',
308
+ );
309
+ });
310
+ });
311
+
312
+ describe('events', () => {
313
+ it('should publish events after successful execution', async () => {
314
+ const publisherService = new TestPublisherService();
315
+
316
+ const fn = new Function(
317
+ async () => ({ id: '123' }),
318
+ undefined,
319
+ undefined,
320
+ undefined,
321
+ z.object({ id: z.string() }),
322
+ [],
323
+ logger,
324
+ publisherService,
325
+ [
326
+ {
327
+ type: 'test.event',
328
+ payload: (response) => ({ data: response.id }),
329
+ },
330
+ ],
331
+ );
332
+
333
+ const adaptor = new AWSLambdaFunction(envParser, fn);
334
+ const handler = adaptor.handler;
335
+
336
+ await handler({}, createMockContext(), vi.fn());
337
+
338
+ expect(publisherService.publisher.publishedEvents).toHaveLength(1);
339
+ expect(publisherService.publisher.publishedEvents[0]).toEqual({
340
+ type: 'test.event',
341
+ payload: { data: '123' },
342
+ });
343
+ });
344
+
345
+ it('should conditionally publish events based on when clause', async () => {
346
+ const publisherService = new TestPublisherService();
347
+
348
+ const fn = new Function(
349
+ async () => ({ success: false }),
350
+ undefined,
351
+ undefined,
352
+ undefined,
353
+ z.object({ success: z.boolean() }),
354
+ [],
355
+ logger,
356
+ publisherService,
357
+ [
358
+ {
359
+ type: 'test.event',
360
+ payload: () => ({ data: 'test' }),
361
+ when: (response) => response.success === true,
362
+ },
363
+ ],
364
+ );
365
+
366
+ const adaptor = new AWSLambdaFunction(envParser, fn);
367
+ const handler = adaptor.handler;
368
+
369
+ await handler({}, createMockContext(), vi.fn());
370
+
371
+ expect(publisherService.publisher.publishedEvents).toHaveLength(0);
372
+ });
373
+ });
374
+
375
+ // Skipping timeout tests for now as middleware order needs to be adjusted
376
+
377
+ describe('database', () => {
378
+ // Mock database service
379
+ class MockDatabase {
380
+ async query(_sql: string) {
381
+ return [{ id: '1', name: 'Test User' }];
382
+ }
383
+ }
384
+
385
+ class DatabaseService implements Service<'database', MockDatabase> {
386
+ serviceName = 'database' as const;
387
+ db = new MockDatabase();
388
+
389
+ async register() {
390
+ return this.db;
391
+ }
392
+ }
393
+
394
+ it('should inject database into function context', async () => {
395
+ const databaseService = new DatabaseService();
396
+ const handler = vi.fn(async ({ db }) => {
397
+ const result = await db.query('SELECT * FROM users');
398
+ return { users: result };
399
+ });
400
+
401
+ const outputSchema = z.object({
402
+ users: z.array(z.object({ id: z.string(), name: z.string() })),
403
+ });
404
+
405
+ const fn = new Function(
406
+ handler,
407
+ undefined,
408
+ undefined,
409
+ undefined,
410
+ outputSchema,
411
+ [],
412
+ logger,
413
+ undefined,
414
+ [],
415
+ undefined,
416
+ undefined,
417
+ databaseService,
418
+ );
419
+
420
+ const adaptor = new AWSLambdaFunction(envParser, fn);
421
+ const lambdaHandler = adaptor.handler;
422
+
423
+ const result = await lambdaHandler({}, createMockContext(), vi.fn());
424
+
425
+ expect(result).toEqual({ users: [{ id: '1', name: 'Test User' }] });
426
+ expect(handler).toHaveBeenCalledWith(
427
+ expect.objectContaining({
428
+ db: expect.any(MockDatabase),
429
+ }),
430
+ );
431
+ });
432
+
433
+ it('should have db as undefined when no database service is configured', async () => {
434
+ const handler = vi.fn(async ({ db }) => {
435
+ return { hasDb: db !== undefined };
436
+ });
437
+
438
+ const outputSchema = z.object({ hasDb: z.boolean() });
439
+
440
+ const fn = new Function(
441
+ handler,
442
+ undefined,
443
+ undefined,
444
+ undefined,
445
+ outputSchema,
446
+ [],
447
+ logger,
448
+ );
449
+
450
+ const adaptor = new AWSLambdaFunction(envParser, fn);
451
+ const lambdaHandler = adaptor.handler;
452
+
453
+ const result = await lambdaHandler({}, createMockContext(), vi.fn());
454
+
455
+ expect(result).toEqual({ hasDb: false });
456
+ });
457
+ });
458
458
  });