@geekmidas/constructs 0.3.2 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (557) hide show
  1. package/dist/{AWSLambdaFunction-C54a1doJ.mjs → AWSLambdaFunction-BMTaCrG9.mjs} +6 -6
  2. package/dist/AWSLambdaFunction-BMTaCrG9.mjs.map +1 -0
  3. package/dist/{AWSLambdaFunction-BdebRMUh.d.mts → AWSLambdaFunction-BfLF5vNa.d.cts} +6 -6
  4. package/dist/AWSLambdaFunction-BfLF5vNa.d.cts.map +1 -0
  5. package/dist/{AWSLambdaFunction-EPGY4s7i.cjs → AWSLambdaFunction-C1gRqLO7.cjs} +6 -6
  6. package/dist/AWSLambdaFunction-C1gRqLO7.cjs.map +1 -0
  7. package/dist/{AWSLambdaFunction-D0tEOTXQ.d.cts → AWSLambdaFunction-K94K8JU2.d.mts} +6 -6
  8. package/dist/AWSLambdaFunction-K94K8JU2.d.mts.map +1 -0
  9. package/dist/{AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts → AWSLambdaSubscriberAdaptor-B2Gk3fgx.d.cts} +2 -2
  10. package/dist/AWSLambdaSubscriberAdaptor-B2Gk3fgx.d.cts.map +1 -0
  11. package/dist/{AWSLambdaSubscriberAdaptor-BLfO612H.mjs → AWSLambdaSubscriberAdaptor-BD3FwGUb.mjs} +3 -3
  12. package/dist/AWSLambdaSubscriberAdaptor-BD3FwGUb.mjs.map +1 -0
  13. package/dist/{AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs → AWSLambdaSubscriberAdaptor-DQDnt1Xk.cjs} +3 -3
  14. package/dist/AWSLambdaSubscriberAdaptor-DQDnt1Xk.cjs.map +1 -0
  15. package/dist/{AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts → AWSLambdaSubscriberAdaptor-QuMFwltJ.d.mts} +2 -2
  16. package/dist/AWSLambdaSubscriberAdaptor-QuMFwltJ.d.mts.map +1 -0
  17. package/dist/{AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs → AmazonApiGatewayEndpointAdaptor-B4gLJ2dx.mjs} +56 -14
  18. package/dist/AmazonApiGatewayEndpointAdaptor-B4gLJ2dx.mjs.map +1 -0
  19. package/dist/{AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts → AmazonApiGatewayEndpointAdaptor-C987ZCsM.d.cts} +51 -5
  20. package/dist/AmazonApiGatewayEndpointAdaptor-C987ZCsM.d.cts.map +1 -0
  21. package/dist/{AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs → AmazonApiGatewayEndpointAdaptor-CwRKMRr_.cjs} +55 -13
  22. package/dist/AmazonApiGatewayEndpointAdaptor-CwRKMRr_.cjs.map +1 -0
  23. package/dist/{AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts → AmazonApiGatewayEndpointAdaptor-DpPfO6Vj.d.mts} +52 -6
  24. package/dist/AmazonApiGatewayEndpointAdaptor-DpPfO6Vj.d.mts.map +1 -0
  25. package/dist/{AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs → AmazonApiGatewayV1EndpointAdaptor-BeZMu5DZ.cjs} +4 -4
  26. package/dist/AmazonApiGatewayV1EndpointAdaptor-BeZMu5DZ.cjs.map +1 -0
  27. package/dist/{AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts → AmazonApiGatewayV1EndpointAdaptor-DI_5kdqw.d.mts} +5 -5
  28. package/dist/AmazonApiGatewayV1EndpointAdaptor-DI_5kdqw.d.mts.map +1 -0
  29. package/dist/{AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts → AmazonApiGatewayV1EndpointAdaptor-DkGMOpoB.d.cts} +4 -4
  30. package/dist/AmazonApiGatewayV1EndpointAdaptor-DkGMOpoB.d.cts.map +1 -0
  31. package/dist/{AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs → AmazonApiGatewayV1EndpointAdaptor-VccB6FKp.mjs} +4 -4
  32. package/dist/AmazonApiGatewayV1EndpointAdaptor-VccB6FKp.mjs.map +1 -0
  33. package/dist/{AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts → AmazonApiGatewayV2EndpointAdaptor-BtBnMJS_.d.cts} +4 -6
  34. package/dist/AmazonApiGatewayV2EndpointAdaptor-BtBnMJS_.d.cts.map +1 -0
  35. package/dist/{AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs → AmazonApiGatewayV2EndpointAdaptor-BwsL9Gia.cjs} +4 -4
  36. package/dist/AmazonApiGatewayV2EndpointAdaptor-BwsL9Gia.cjs.map +1 -0
  37. package/dist/{AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs → AmazonApiGatewayV2EndpointAdaptor-CljxmUfz.mjs} +4 -4
  38. package/dist/AmazonApiGatewayV2EndpointAdaptor-CljxmUfz.mjs.map +1 -0
  39. package/dist/{AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts → AmazonApiGatewayV2EndpointAdaptor-DnCoqlvw.d.mts} +5 -7
  40. package/dist/AmazonApiGatewayV2EndpointAdaptor-DnCoqlvw.d.mts.map +1 -0
  41. package/dist/{Authorizer-C0ge_tc8.cjs → Authorizer-BXxBee2P.cjs} +1 -1
  42. package/dist/Authorizer-BXxBee2P.cjs.map +1 -0
  43. package/dist/{Authorizer-r9U3y_ms.mjs → Authorizer-BgjU8-z6.mjs} +1 -1
  44. package/dist/Authorizer-BgjU8-z6.mjs.map +1 -0
  45. package/dist/{Authorizer-gWxYsGEp.d.mts → Authorizer-DCcYOx3h.d.mts} +1 -1
  46. package/dist/Authorizer-DCcYOx3h.d.mts.map +1 -0
  47. package/dist/{Authorizer-B-btowNd.d.cts → Authorizer-DWtwC8we.d.cts} +1 -1
  48. package/dist/Authorizer-DWtwC8we.d.cts.map +1 -0
  49. package/dist/{BaseFunctionBuilder-BAtutR6q.d.cts → BaseFunctionBuilder-BqZCqIeU.d.mts} +3 -3
  50. package/dist/BaseFunctionBuilder-BqZCqIeU.d.mts.map +1 -0
  51. package/dist/{BaseFunctionBuilder-DRY419e7.d.mts → BaseFunctionBuilder-CcK691ni.d.cts} +3 -3
  52. package/dist/BaseFunctionBuilder-CcK691ni.d.cts.map +1 -0
  53. package/dist/{BaseFunctionBuilder-Czi1Jwza.mjs → BaseFunctionBuilder-Dsqe6pnn.mjs} +2 -2
  54. package/dist/BaseFunctionBuilder-Dsqe6pnn.mjs.map +1 -0
  55. package/dist/{BaseFunctionBuilder-MYG3C9ug.cjs → BaseFunctionBuilder-Z0XwrKB5.cjs} +2 -2
  56. package/dist/BaseFunctionBuilder-Z0XwrKB5.cjs.map +1 -0
  57. package/dist/Construct-BNDLJJfD.mjs +150 -0
  58. package/dist/Construct-BNDLJJfD.mjs.map +1 -0
  59. package/dist/{Construct-Ba5cMxib.cjs → Construct-CPrCF8NK.cjs} +93 -9
  60. package/dist/Construct-CPrCF8NK.cjs.map +1 -0
  61. package/dist/{Construct-C4rPE67v.d.cts → Construct-Dl0l2d8d.d.cts} +30 -4
  62. package/dist/Construct-Dl0l2d8d.d.cts.map +1 -0
  63. package/dist/{Construct-XrijZFFh.d.mts → Construct-E8QPyHh4.d.mts} +30 -4
  64. package/dist/Construct-E8QPyHh4.d.mts.map +1 -0
  65. package/dist/Construct.cjs +4 -2
  66. package/dist/Construct.d.cts +2 -2
  67. package/dist/Construct.d.mts +2 -2
  68. package/dist/Construct.mjs +2 -2
  69. package/dist/{Cron-CGF4YAfM.cjs → Cron-BmPNTLla.cjs} +3 -3
  70. package/dist/Cron-BmPNTLla.cjs.map +1 -0
  71. package/dist/{Cron-BxhGs5up.mjs → Cron-BpJONaFv.mjs} +3 -3
  72. package/dist/Cron-BpJONaFv.mjs.map +1 -0
  73. package/dist/{Cron-bDLcTvV5.d.cts → Cron-CnmLLh3E.d.mts} +3 -3
  74. package/dist/Cron-CnmLLh3E.d.mts.map +1 -0
  75. package/dist/{Cron-cdjlSKNp.d.mts → Cron-DufAeHry.d.cts} +3 -3
  76. package/dist/Cron-DufAeHry.d.cts.map +1 -0
  77. package/dist/{CronBuilder-d2jh-IB2.mjs → CronBuilder-02HSIHJr.mjs} +4 -4
  78. package/dist/CronBuilder-02HSIHJr.mjs.map +1 -0
  79. package/dist/{CronBuilder-CcxKRtVP.cjs → CronBuilder-DC2zUS8a.cjs} +4 -4
  80. package/dist/CronBuilder-DC2zUS8a.cjs.map +1 -0
  81. package/dist/{CronBuilder-BC4m5-p1.d.mts → CronBuilder-anUSbMxb.d.mts} +4 -4
  82. package/dist/CronBuilder-anUSbMxb.d.mts.map +1 -0
  83. package/dist/{CronBuilder-DKVXyE0Q.d.cts → CronBuilder-fyqf_X8n.d.cts} +4 -4
  84. package/dist/CronBuilder-fyqf_X8n.d.cts.map +1 -0
  85. package/dist/{Endpoint-BVGZXFyV.cjs → Endpoint-BCWVbi8l.cjs} +6 -6
  86. package/dist/Endpoint-BCWVbi8l.cjs.map +1 -0
  87. package/dist/{Endpoint-BPv9_-m_.d.cts → Endpoint-BlcHiGNx.d.cts} +3 -3
  88. package/dist/Endpoint-BlcHiGNx.d.cts.map +1 -0
  89. package/dist/{Endpoint-BdwG75G_.d.mts → Endpoint-DEHuy46S.d.mts} +4 -4
  90. package/dist/Endpoint-DEHuy46S.d.mts.map +1 -0
  91. package/dist/{Endpoint-CuOEswxJ.mjs → Endpoint-ygxv2Ia6.mjs} +6 -6
  92. package/dist/Endpoint-ygxv2Ia6.mjs.map +1 -0
  93. package/dist/{EndpointBuilder-DIy_m1bu.d.cts → EndpointBuilder-DPLAUHqg.d.cts} +4 -4
  94. package/dist/EndpointBuilder-DPLAUHqg.d.cts.map +1 -0
  95. package/dist/{EndpointBuilder-B3az942t.d.mts → EndpointBuilder-DaeCeneF.d.mts} +5 -5
  96. package/dist/EndpointBuilder-DaeCeneF.d.mts.map +1 -0
  97. package/dist/{EndpointBuilder-Cgj1P_ra.cjs → EndpointBuilder-J5D67Y6a.cjs} +6 -6
  98. package/dist/EndpointBuilder-J5D67Y6a.cjs.map +1 -0
  99. package/dist/{EndpointBuilder-DnCB1h1j.mjs → EndpointBuilder-tn4zqoyw.mjs} +6 -6
  100. package/dist/EndpointBuilder-tn4zqoyw.mjs.map +1 -0
  101. package/dist/{EndpointFactory-CbdxPCIH.mjs → EndpointFactory-CIUZTTAF.mjs} +7 -7
  102. package/dist/EndpointFactory-CIUZTTAF.mjs.map +1 -0
  103. package/dist/{EndpointFactory-CyPbm3AD.d.cts → EndpointFactory-CiKcb5PX.d.cts} +4 -4
  104. package/dist/EndpointFactory-CiKcb5PX.d.cts.map +1 -0
  105. package/dist/{EndpointFactory-C-0nE6Jg.d.mts → EndpointFactory-DufM0t2z.d.mts} +4 -4
  106. package/dist/EndpointFactory-DufM0t2z.d.mts.map +1 -0
  107. package/dist/{EndpointFactory-CYj6BYok.cjs → EndpointFactory-d5uwWFkK.cjs} +7 -7
  108. package/dist/EndpointFactory-d5uwWFkK.cjs.map +1 -0
  109. package/dist/{Function-DDZb1525.cjs → Function-2qWSZqYB.cjs} +3 -3
  110. package/dist/Function-2qWSZqYB.cjs.map +1 -0
  111. package/dist/{Function-Cf7f_kCz.d.cts → Function-CbEohg13.d.cts} +3 -3
  112. package/dist/Function-CbEohg13.d.cts.map +1 -0
  113. package/dist/{Function-BVHqIDp9.mjs → Function-CdF1HmFu.mjs} +3 -3
  114. package/dist/Function-CdF1HmFu.mjs.map +1 -0
  115. package/dist/{Function-DN2G6OT5.d.mts → Function-EjIOLxlh.d.mts} +3 -3
  116. package/dist/Function-EjIOLxlh.d.mts.map +1 -0
  117. package/dist/{FunctionBuilder-DswJ-9sD.cjs → FunctionBuilder-B-pbgm09.cjs} +4 -4
  118. package/dist/FunctionBuilder-B-pbgm09.cjs.map +1 -0
  119. package/dist/{FunctionBuilder-CJBzzXL3.d.cts → FunctionBuilder-CX3ooNdq.d.cts} +4 -4
  120. package/dist/FunctionBuilder-CX3ooNdq.d.cts.map +1 -0
  121. package/dist/{FunctionBuilder-Cxx8D2na.d.mts → FunctionBuilder-D11ytDyy.d.mts} +4 -4
  122. package/dist/FunctionBuilder-D11ytDyy.d.mts.map +1 -0
  123. package/dist/{FunctionBuilder-CrDYgfiI.mjs → FunctionBuilder-DaWVthAJ.mjs} +4 -4
  124. package/dist/FunctionBuilder-DaWVthAJ.mjs.map +1 -0
  125. package/dist/{FunctionExecutionWrapper-DF260Aaj.d.mts → FunctionExecutionWrapper-BJcRjH9Z.d.cts} +5 -5
  126. package/dist/FunctionExecutionWrapper-BJcRjH9Z.d.cts.map +1 -0
  127. package/dist/{FunctionExecutionWrapper-BYI2bGTL.cjs → FunctionExecutionWrapper-C6ChBNHs.cjs} +3 -3
  128. package/dist/FunctionExecutionWrapper-C6ChBNHs.cjs.map +1 -0
  129. package/dist/{FunctionExecutionWrapper-Qy8bmgFR.d.cts → FunctionExecutionWrapper-D3RNjGIR.d.mts} +5 -5
  130. package/dist/FunctionExecutionWrapper-D3RNjGIR.d.mts.map +1 -0
  131. package/dist/{FunctionExecutionWrapper-CLDh7Z2_.mjs → FunctionExecutionWrapper-Dj3pmXaN.mjs} +3 -3
  132. package/dist/FunctionExecutionWrapper-Dj3pmXaN.mjs.map +1 -0
  133. package/dist/{HonoEndpointAdaptor-BaPlUhz0.d.mts → HonoEndpointAdaptor-CKP6nrG2.d.mts} +11 -6
  134. package/dist/HonoEndpointAdaptor-CKP6nrG2.d.mts.map +1 -0
  135. package/dist/HonoEndpointAdaptor-Cc8Rnp9G.mjs +251 -0
  136. package/dist/HonoEndpointAdaptor-Cc8Rnp9G.mjs.map +1 -0
  137. package/dist/{HonoEndpointAdaptor-YcRHYALH.d.cts → HonoEndpointAdaptor-hrrvyfw9.d.cts} +10 -5
  138. package/dist/HonoEndpointAdaptor-hrrvyfw9.d.cts.map +1 -0
  139. package/dist/HonoEndpointAdaptor-xGnDZa3a.cjs +257 -0
  140. package/dist/HonoEndpointAdaptor-xGnDZa3a.cjs.map +1 -0
  141. package/dist/{Subscriber-COYMSevD.d.cts → Subscriber-BBcIOkhW.d.cts} +2 -2
  142. package/dist/Subscriber-BBcIOkhW.d.cts.map +1 -0
  143. package/dist/{Subscriber-ikctpU3I.d.mts → Subscriber-BpTAXvbM.d.mts} +2 -2
  144. package/dist/Subscriber-BpTAXvbM.d.mts.map +1 -0
  145. package/dist/{Subscriber-BiHjVXtM.cjs → Subscriber-CL4iYm01.cjs} +2 -2
  146. package/dist/Subscriber-CL4iYm01.cjs.map +1 -0
  147. package/dist/{Subscriber-BmPf9GFb.mjs → Subscriber-CZ8Smwd2.mjs} +2 -2
  148. package/dist/Subscriber-CZ8Smwd2.mjs.map +1 -0
  149. package/dist/{SubscriberBuilder-DJPEeYDJ.mjs → SubscriberBuilder-CxQg3TTm.mjs} +2 -2
  150. package/dist/SubscriberBuilder-CxQg3TTm.mjs.map +1 -0
  151. package/dist/{SubscriberBuilder-Cp1C-xtT.cjs → SubscriberBuilder-D0OS3hd7.cjs} +2 -2
  152. package/dist/SubscriberBuilder-D0OS3hd7.cjs.map +1 -0
  153. package/dist/{SubscriberBuilder-D_9zzllj.d.mts → SubscriberBuilder-D7IgufwB.d.cts} +3 -3
  154. package/dist/SubscriberBuilder-D7IgufwB.d.cts.map +1 -0
  155. package/dist/{SubscriberBuilder-ivHAGIVi.d.cts → SubscriberBuilder-DOFBbWLt.d.mts} +3 -3
  156. package/dist/SubscriberBuilder-DOFBbWLt.d.mts.map +1 -0
  157. package/dist/{TestEndpointAdaptor-DB7bREhS.d.mts → TestEndpointAdaptor-BnJusjf7.d.mts} +4 -4
  158. package/dist/TestEndpointAdaptor-BnJusjf7.d.mts.map +1 -0
  159. package/dist/TestEndpointAdaptor-CPL8ru6q.mjs +170 -0
  160. package/dist/TestEndpointAdaptor-CPL8ru6q.mjs.map +1 -0
  161. package/dist/TestEndpointAdaptor-Ca4K26_d.cjs +176 -0
  162. package/dist/TestEndpointAdaptor-Ca4K26_d.cjs.map +1 -0
  163. package/dist/{TestEndpointAdaptor-C10xBI--.d.cts → TestEndpointAdaptor-EPPTjntv.d.cts} +3 -3
  164. package/dist/TestEndpointAdaptor-EPPTjntv.d.cts.map +1 -0
  165. package/dist/adaptors/aws.cjs +12 -12
  166. package/dist/adaptors/aws.d.cts +15 -14
  167. package/dist/adaptors/aws.d.mts +16 -15
  168. package/dist/adaptors/aws.mjs +12 -12
  169. package/dist/adaptors/hono.cjs +10 -9
  170. package/dist/adaptors/hono.d.cts +8 -8
  171. package/dist/adaptors/hono.d.mts +9 -9
  172. package/dist/adaptors/hono.mjs +10 -9
  173. package/dist/adaptors/testing.cjs +8 -7
  174. package/dist/adaptors/testing.d.cts +8 -8
  175. package/dist/adaptors/testing.d.mts +9 -9
  176. package/dist/adaptors/testing.mjs +8 -7
  177. package/dist/crons/Cron.cjs +6 -6
  178. package/dist/crons/Cron.d.cts +6 -6
  179. package/dist/crons/Cron.d.mts +6 -6
  180. package/dist/crons/Cron.mjs +6 -6
  181. package/dist/crons/CronBuilder.cjs +7 -7
  182. package/dist/crons/CronBuilder.d.cts +7 -7
  183. package/dist/crons/CronBuilder.d.mts +7 -7
  184. package/dist/crons/CronBuilder.mjs +7 -7
  185. package/dist/crons/index.cjs +7 -7
  186. package/dist/crons/index.cjs.map +1 -1
  187. package/dist/crons/index.d.cts +11 -11
  188. package/dist/crons/index.d.mts +7 -7
  189. package/dist/crons/index.mjs +7 -7
  190. package/dist/crons/index.mjs.map +1 -1
  191. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +7 -7
  192. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +10 -9
  193. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +11 -10
  194. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +7 -7
  195. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +8 -8
  196. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +10 -9
  197. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +11 -10
  198. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +8 -8
  199. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +8 -8
  200. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +11 -10
  201. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +12 -11
  202. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +8 -8
  203. package/dist/endpoints/Authorizer.cjs +1 -1
  204. package/dist/endpoints/Authorizer.d.cts +1 -1
  205. package/dist/endpoints/Authorizer.d.mts +1 -1
  206. package/dist/endpoints/Authorizer.mjs +1 -1
  207. package/dist/endpoints/Endpoint.cjs +6 -6
  208. package/dist/endpoints/Endpoint.d.cts +7 -7
  209. package/dist/endpoints/Endpoint.d.mts +8 -8
  210. package/dist/endpoints/Endpoint.mjs +6 -6
  211. package/dist/endpoints/EndpointBuilder.cjs +9 -9
  212. package/dist/endpoints/EndpointBuilder.d.cts +8 -8
  213. package/dist/endpoints/EndpointBuilder.d.mts +9 -9
  214. package/dist/endpoints/EndpointBuilder.mjs +9 -9
  215. package/dist/endpoints/EndpointFactory.cjs +10 -10
  216. package/dist/endpoints/EndpointFactory.d.cts +9 -9
  217. package/dist/endpoints/EndpointFactory.d.mts +10 -10
  218. package/dist/endpoints/EndpointFactory.mjs +10 -10
  219. package/dist/endpoints/HonoEndpointAdaptor.cjs +10 -9
  220. package/dist/endpoints/HonoEndpointAdaptor.d.cts +8 -8
  221. package/dist/endpoints/HonoEndpointAdaptor.d.mts +9 -9
  222. package/dist/endpoints/HonoEndpointAdaptor.mjs +10 -9
  223. package/dist/endpoints/TestEndpointAdaptor.cjs +8 -7
  224. package/dist/endpoints/TestEndpointAdaptor.d.cts +8 -8
  225. package/dist/endpoints/TestEndpointAdaptor.d.mts +9 -9
  226. package/dist/endpoints/TestEndpointAdaptor.mjs +8 -7
  227. package/dist/endpoints/audit.d.cts +7 -7
  228. package/dist/endpoints/audit.d.mts +8 -8
  229. package/dist/endpoints/helpers.cjs +7 -7
  230. package/dist/endpoints/helpers.d.cts +7 -7
  231. package/dist/endpoints/helpers.d.cts.map +1 -1
  232. package/dist/endpoints/helpers.d.mts +8 -8
  233. package/dist/endpoints/helpers.d.mts.map +1 -1
  234. package/dist/endpoints/helpers.mjs +7 -7
  235. package/dist/endpoints/index.cjs +20 -10
  236. package/dist/endpoints/index.cjs.map +1 -1
  237. package/dist/endpoints/index.d.cts +14 -12
  238. package/dist/endpoints/index.d.cts.map +1 -1
  239. package/dist/endpoints/index.d.mts +15 -13
  240. package/dist/endpoints/index.d.mts.map +1 -1
  241. package/dist/endpoints/index.mjs +13 -11
  242. package/dist/endpoints/index.mjs.map +1 -1
  243. package/dist/endpoints/lazyAccessors.cjs +10 -0
  244. package/dist/endpoints/lazyAccessors.d.cts +10 -0
  245. package/dist/endpoints/lazyAccessors.d.mts +10 -0
  246. package/dist/endpoints/lazyAccessors.mjs +3 -0
  247. package/dist/endpoints/parseHonoQuery.cjs +1 -1
  248. package/dist/endpoints/parseHonoQuery.mjs +1 -1
  249. package/dist/endpoints/parseQueryParams.d.cts.map +1 -1
  250. package/dist/endpoints/parseQueryParams.d.mts.map +1 -1
  251. package/dist/endpoints/processAudits.d.cts +7 -7
  252. package/dist/endpoints/processAudits.d.cts.map +1 -1
  253. package/dist/endpoints/processAudits.d.mts +8 -8
  254. package/dist/endpoints/processAudits.d.mts.map +1 -1
  255. package/dist/endpoints/rls.cjs +1 -1
  256. package/dist/endpoints/rls.d.cts +7 -7
  257. package/dist/endpoints/rls.d.mts +8 -8
  258. package/dist/endpoints/rls.mjs +1 -1
  259. package/dist/functions/AWSLambdaFunction.cjs +6 -6
  260. package/dist/functions/AWSLambdaFunction.d.cts +4 -4
  261. package/dist/functions/AWSLambdaFunction.d.mts +4 -4
  262. package/dist/functions/AWSLambdaFunction.mjs +6 -6
  263. package/dist/functions/BaseFunctionBuilder.cjs +2 -2
  264. package/dist/functions/BaseFunctionBuilder.d.cts +2 -2
  265. package/dist/functions/BaseFunctionBuilder.d.mts +2 -2
  266. package/dist/functions/BaseFunctionBuilder.mjs +2 -2
  267. package/dist/functions/Function.cjs +2 -2
  268. package/dist/functions/Function.d.cts +2 -2
  269. package/dist/functions/Function.d.mts +2 -2
  270. package/dist/functions/Function.mjs +2 -2
  271. package/dist/functions/FunctionBuilder.cjs +4 -4
  272. package/dist/functions/FunctionBuilder.d.cts +4 -4
  273. package/dist/functions/FunctionBuilder.d.mts +4 -4
  274. package/dist/functions/FunctionBuilder.mjs +4 -4
  275. package/dist/functions/FunctionExecutionWrapper.cjs +5 -5
  276. package/dist/functions/FunctionExecutionWrapper.d.cts +3 -3
  277. package/dist/functions/FunctionExecutionWrapper.d.mts +3 -3
  278. package/dist/functions/FunctionExecutionWrapper.mjs +5 -5
  279. package/dist/functions/TestFunctionAdaptor.cjs +7 -7
  280. package/dist/functions/TestFunctionAdaptor.cjs.map +1 -1
  281. package/dist/functions/TestFunctionAdaptor.d.cts +3 -3
  282. package/dist/functions/TestFunctionAdaptor.d.cts.map +1 -1
  283. package/dist/functions/TestFunctionAdaptor.d.mts +3 -3
  284. package/dist/functions/TestFunctionAdaptor.d.mts.map +1 -1
  285. package/dist/functions/TestFunctionAdaptor.mjs +7 -7
  286. package/dist/functions/TestFunctionAdaptor.mjs.map +1 -1
  287. package/dist/functions/index.cjs +5 -5
  288. package/dist/functions/index.d.cts +5 -5
  289. package/dist/functions/index.d.mts +5 -5
  290. package/dist/functions/index.mjs +5 -5
  291. package/dist/{functions-fTid0RMK.cjs → functions-CUEv5NC3.cjs} +2 -2
  292. package/dist/functions-CUEv5NC3.cjs.map +1 -0
  293. package/dist/functions-DOYBrb7n.mjs +8 -0
  294. package/dist/functions-DOYBrb7n.mjs.map +1 -0
  295. package/dist/{helpers-ByRTDO_m.mjs → helpers-Dl1eszfi.mjs} +2 -2
  296. package/dist/helpers-Dl1eszfi.mjs.map +1 -0
  297. package/dist/{helpers-BcP1tXAi.cjs → helpers-QMdfdnvU.cjs} +2 -2
  298. package/dist/helpers-QMdfdnvU.cjs.map +1 -0
  299. package/dist/{index-BWzGIj06.d.mts → index-BrGtMlpJ.d.cts} +2 -2
  300. package/dist/index-BrGtMlpJ.d.cts.map +1 -0
  301. package/dist/index-Dn4py3Db.d.mts +12 -0
  302. package/dist/index-Dn4py3Db.d.mts.map +1 -0
  303. package/dist/index.cjs +4 -2
  304. package/dist/index.d.cts +3 -2
  305. package/dist/index.d.mts +4 -3
  306. package/dist/index.mjs +2 -2
  307. package/dist/lazyAccessors-B-Jgkg2o.mjs +175 -0
  308. package/dist/lazyAccessors-B-Jgkg2o.mjs.map +1 -0
  309. package/dist/lazyAccessors-B8Hhras9.cjs +223 -0
  310. package/dist/lazyAccessors-B8Hhras9.cjs.map +1 -0
  311. package/dist/lazyAccessors-BFAj2-S4.d.mts +49 -0
  312. package/dist/lazyAccessors-BFAj2-S4.d.mts.map +1 -0
  313. package/dist/lazyAccessors-knaNZuTN.d.cts +49 -0
  314. package/dist/lazyAccessors-knaNZuTN.d.cts.map +1 -0
  315. package/dist/{parseHonoQuery-CZC5_97v.cjs → parseHonoQuery-D4MhxTRc.cjs} +1 -1
  316. package/dist/parseHonoQuery-D4MhxTRc.cjs.map +1 -0
  317. package/dist/{parseHonoQuery-DDgIkTO4.mjs → parseHonoQuery-DpK3sGPc.mjs} +1 -1
  318. package/dist/parseHonoQuery-DpK3sGPc.mjs.map +1 -0
  319. package/dist/parseQueryParams-BSNkjmZ9.cjs.map +1 -1
  320. package/dist/parseQueryParams-UMTRnRrW.mjs.map +1 -1
  321. package/dist/processAudits-CzHkPokQ.cjs.map +1 -1
  322. package/dist/processAudits-Dj8UGqcW.mjs.map +1 -1
  323. package/dist/publisher-BXG9YiRi.d.mts +16 -0
  324. package/dist/publisher-BXG9YiRi.d.mts.map +1 -0
  325. package/dist/publisher-Bw4770Hi.mjs.map +1 -1
  326. package/dist/publisher-D9ngDXg3.d.cts +16 -0
  327. package/dist/publisher-D9ngDXg3.d.cts.map +1 -0
  328. package/dist/publisher-lFQleddL.cjs.map +1 -1
  329. package/dist/publisher.d.cts +3 -16
  330. package/dist/publisher.d.mts +3 -16
  331. package/dist/{rls-CmJ7bRsz.cjs → rls-BrywnrQb.cjs} +1 -1
  332. package/dist/{rls-CmJ7bRsz.cjs.map → rls-BrywnrQb.cjs.map} +1 -1
  333. package/dist/{rls-Bf3FRwto.mjs → rls-C0cWOnk4.mjs} +1 -1
  334. package/dist/{rls-Bf3FRwto.mjs.map → rls-C0cWOnk4.mjs.map} +1 -1
  335. package/dist/subscribers/AWSLambdaSubscriberAdaptor.cjs +1 -1
  336. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +3 -3
  337. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +3 -3
  338. package/dist/subscribers/AWSLambdaSubscriberAdaptor.mjs +1 -1
  339. package/dist/subscribers/Subscriber.cjs +2 -2
  340. package/dist/subscribers/Subscriber.d.cts +2 -2
  341. package/dist/subscribers/Subscriber.d.mts +2 -2
  342. package/dist/subscribers/Subscriber.mjs +2 -2
  343. package/dist/subscribers/SubscriberBuilder.cjs +3 -3
  344. package/dist/subscribers/SubscriberBuilder.d.cts +3 -3
  345. package/dist/subscribers/SubscriberBuilder.d.mts +3 -3
  346. package/dist/subscribers/SubscriberBuilder.mjs +3 -3
  347. package/dist/subscribers/index.cjs +3 -3
  348. package/dist/subscribers/index.cjs.map +1 -1
  349. package/dist/subscribers/index.d.cts +5 -5
  350. package/dist/subscribers/index.d.cts.map +1 -1
  351. package/dist/subscribers/index.d.mts +5 -5
  352. package/dist/subscribers/index.d.mts.map +1 -1
  353. package/dist/subscribers/index.mjs +3 -3
  354. package/dist/subscribers/index.mjs.map +1 -1
  355. package/dist/telemetry-BTaiRqPo.d.cts +95 -0
  356. package/dist/telemetry-BTaiRqPo.d.cts.map +1 -0
  357. package/dist/telemetry-yAHf5yDs.d.mts +95 -0
  358. package/dist/telemetry-yAHf5yDs.d.mts.map +1 -0
  359. package/dist/telemetry.cjs +0 -0
  360. package/dist/telemetry.d.cts +2 -0
  361. package/dist/telemetry.d.mts +2 -0
  362. package/dist/telemetry.mjs +0 -0
  363. package/dist/types-B5H3piDg.d.cts.map +1 -1
  364. package/dist/{types-DdIlpxAd.d.mts → types-Dw-iLd3Y.d.mts} +1 -1
  365. package/dist/types-Dw-iLd3Y.d.mts.map +1 -0
  366. package/dist/types.d.mts +1 -1
  367. package/package.json +19 -18
  368. package/src/Construct.ts +189 -94
  369. package/src/__benchmarks__/build-time-optimization.bench.ts +274 -0
  370. package/src/__benchmarks__/endpoint.bench.ts +375 -375
  371. package/src/__benchmarks__/fixtures.ts +241 -0
  372. package/src/__benchmarks__/hono-adaptor.bench.ts +533 -0
  373. package/src/__benchmarks__/hono-server.bench.ts +206 -206
  374. package/src/__benchmarks__/response-builder.bench.ts +428 -0
  375. package/src/__benchmarks__/strategies/strategy-a-lazy-services.ts +319 -0
  376. package/src/__benchmarks__/strategies/strategy-c-middleware.ts +530 -0
  377. package/src/__benchmarks__/strategies/strategy-d-opt-in-events.ts +567 -0
  378. package/src/__tests__/Construct.environment.spec.ts +572 -351
  379. package/src/__tests__/publisher.setting.spec.ts +496 -499
  380. package/src/__tests__/publisher.spec.ts +440 -442
  381. package/src/crons/Cron.ts +117 -117
  382. package/src/crons/CronBuilder.ts +237 -238
  383. package/src/crons/__tests__/Cron.spec.ts +448 -448
  384. package/src/crons/__tests__/CronBuilder.state-isolation.spec.ts +214 -214
  385. package/src/crons/index.ts +4 -4
  386. package/src/endpoints/AmazonApiGatewayEndpointAdaptor.ts +571 -463
  387. package/src/endpoints/AmazonApiGatewayV1EndpointAdaptor.ts +86 -86
  388. package/src/endpoints/AmazonApiGatewayV2EndpointAdaptor.ts +85 -81
  389. package/src/endpoints/Authorizer.ts +100 -100
  390. package/src/endpoints/Endpoint.ts +921 -937
  391. package/src/endpoints/EndpointBuilder.ts +703 -703
  392. package/src/endpoints/EndpointFactory.ts +1054 -1056
  393. package/src/endpoints/HonoEndpointAdaptor.ts +621 -548
  394. package/src/endpoints/TestEndpointAdaptor.ts +372 -353
  395. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.audits.spec.ts +499 -0
  396. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.events.spec.ts +541 -542
  397. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.spec.ts +1172 -1174
  398. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.audits.spec.ts +599 -599
  399. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.events.spec.ts +710 -710
  400. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.factory-publisher.spec.ts +280 -280
  401. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.kysely-audit.integration.spec.ts +924 -730
  402. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.rls.spec.ts +307 -0
  403. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.spec.ts +408 -408
  404. package/src/endpoints/__tests__/Authorizer.spec.ts +286 -0
  405. package/src/endpoints/__tests__/Endpoint.cookies.spec.ts +162 -162
  406. package/src/endpoints/__tests__/Endpoint.headers.spec.ts +182 -182
  407. package/src/endpoints/__tests__/Endpoint.manifest.spec.ts +158 -159
  408. package/src/endpoints/__tests__/Endpoint.spec.ts +819 -822
  409. package/src/endpoints/__tests__/EndpointBuilder.audit.spec.ts +427 -427
  410. package/src/endpoints/__tests__/EndpointBuilder.spec.ts +478 -478
  411. package/src/endpoints/__tests__/EndpointFactory.authorizers.spec.ts +426 -426
  412. package/src/endpoints/__tests__/EndpointFactory.database-auditor.spec.ts +501 -501
  413. package/src/endpoints/__tests__/EndpointFactory.reference-audit.spec.ts +177 -177
  414. package/src/endpoints/__tests__/EndpointFactory.spec.ts +471 -471
  415. package/src/endpoints/__tests__/EndpointFactory.state-isolation.spec.ts +143 -143
  416. package/src/endpoints/__tests__/HonoEndpointAdaptor.audit-transactions.spec.ts +663 -663
  417. package/src/endpoints/__tests__/HonoEndpointAdaptor.audits.spec.ts +608 -608
  418. package/src/endpoints/__tests__/HonoEndpointAdaptor.events.spec.ts +561 -561
  419. package/src/endpoints/__tests__/HonoEndpointAdaptor.kysely-audit.integration.spec.ts +1036 -1036
  420. package/src/endpoints/__tests__/HonoEndpointAdaptor.openapi.spec.ts +278 -278
  421. package/src/endpoints/__tests__/HonoEndpointAdaptor.spec.ts +1093 -1093
  422. package/src/endpoints/__tests__/ResponseBuilder.spec.ts +230 -230
  423. package/src/endpoints/__tests__/TestEndpointAdaptor.audits.spec.ts +569 -569
  424. package/src/endpoints/__tests__/TestEndpointAdaptor.spec.ts +841 -841
  425. package/src/endpoints/__tests__/endpoint-types.test.ts +68 -68
  426. package/src/endpoints/__tests__/helpers.spec.ts +37 -0
  427. package/src/endpoints/__tests__/lazyAccessors.spec.ts +330 -0
  428. package/src/endpoints/__tests__/processAudits.spec.ts +631 -0
  429. package/src/endpoints/audit.ts +51 -51
  430. package/src/endpoints/helpers.ts +34 -35
  431. package/src/endpoints/index.ts +33 -23
  432. package/src/endpoints/lazyAccessors.ts +241 -0
  433. package/src/endpoints/parseHonoQuery.ts +41 -41
  434. package/src/endpoints/parseQueryParams.ts +36 -36
  435. package/src/endpoints/processAudits.ts +269 -269
  436. package/src/endpoints/rls.ts +16 -16
  437. package/src/functions/AWSLambdaFunction.ts +294 -295
  438. package/src/functions/BaseFunctionBuilder.ts +185 -185
  439. package/src/functions/Function.ts +190 -190
  440. package/src/functions/FunctionBuilder.ts +353 -353
  441. package/src/functions/FunctionExecutionWrapper.ts +199 -200
  442. package/src/functions/TestFunctionAdaptor.ts +191 -191
  443. package/src/functions/__tests__/AWSLambdaFunctionAdaptor.spec.ts +424 -424
  444. package/src/functions/__tests__/Function.audits.spec.ts +364 -364
  445. package/src/functions/__tests__/Function.spec.ts +453 -454
  446. package/src/functions/__tests__/FunctionBuilder.state-isolation.spec.ts +179 -179
  447. package/src/functions/__tests__/TestFunctionAdaptor.spec.ts +369 -369
  448. package/src/functions/index.ts +6 -4
  449. package/src/index.ts +18 -9
  450. package/src/publisher.ts +71 -72
  451. package/src/subscribers/AWSLambdaSubscriberAdaptor.ts +244 -248
  452. package/src/subscribers/Subscriber.ts +82 -84
  453. package/src/subscribers/SubscriberBuilder.ts +129 -129
  454. package/src/subscribers/__tests__/AWSLambdaSubscriberAdaptor.spec.ts +589 -589
  455. package/src/subscribers/__tests__/Subscriber.spec.ts +402 -404
  456. package/src/subscribers/index.ts +1 -0
  457. package/src/telemetry.ts +103 -0
  458. package/src/types.ts +7 -7
  459. package/test.ts +58 -59
  460. package/dist/AWSLambdaFunction-BdebRMUh.d.mts.map +0 -1
  461. package/dist/AWSLambdaFunction-C54a1doJ.mjs.map +0 -1
  462. package/dist/AWSLambdaFunction-D0tEOTXQ.d.cts.map +0 -1
  463. package/dist/AWSLambdaFunction-EPGY4s7i.cjs.map +0 -1
  464. package/dist/AWSLambdaSubscriberAdaptor-BLfO612H.mjs.map +0 -1
  465. package/dist/AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs.map +0 -1
  466. package/dist/AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts.map +0 -1
  467. package/dist/AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts.map +0 -1
  468. package/dist/AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs.map +0 -1
  469. package/dist/AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts.map +0 -1
  470. package/dist/AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs.map +0 -1
  471. package/dist/AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts.map +0 -1
  472. package/dist/AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs.map +0 -1
  473. package/dist/AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs.map +0 -1
  474. package/dist/AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts.map +0 -1
  475. package/dist/AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts.map +0 -1
  476. package/dist/AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs.map +0 -1
  477. package/dist/AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts.map +0 -1
  478. package/dist/AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts.map +0 -1
  479. package/dist/AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs.map +0 -1
  480. package/dist/Authorizer-B-btowNd.d.cts.map +0 -1
  481. package/dist/Authorizer-C0ge_tc8.cjs.map +0 -1
  482. package/dist/Authorizer-gWxYsGEp.d.mts.map +0 -1
  483. package/dist/Authorizer-r9U3y_ms.mjs.map +0 -1
  484. package/dist/BaseFunctionBuilder-BAtutR6q.d.cts.map +0 -1
  485. package/dist/BaseFunctionBuilder-Czi1Jwza.mjs.map +0 -1
  486. package/dist/BaseFunctionBuilder-DRY419e7.d.mts.map +0 -1
  487. package/dist/BaseFunctionBuilder-MYG3C9ug.cjs.map +0 -1
  488. package/dist/Construct-Ba5cMxib.cjs.map +0 -1
  489. package/dist/Construct-C4rPE67v.d.cts.map +0 -1
  490. package/dist/Construct-DdyGHuag.mjs +0 -78
  491. package/dist/Construct-DdyGHuag.mjs.map +0 -1
  492. package/dist/Construct-XrijZFFh.d.mts.map +0 -1
  493. package/dist/Cron-BxhGs5up.mjs.map +0 -1
  494. package/dist/Cron-CGF4YAfM.cjs.map +0 -1
  495. package/dist/Cron-bDLcTvV5.d.cts.map +0 -1
  496. package/dist/Cron-cdjlSKNp.d.mts.map +0 -1
  497. package/dist/CronBuilder-BC4m5-p1.d.mts.map +0 -1
  498. package/dist/CronBuilder-CcxKRtVP.cjs.map +0 -1
  499. package/dist/CronBuilder-DKVXyE0Q.d.cts.map +0 -1
  500. package/dist/CronBuilder-d2jh-IB2.mjs.map +0 -1
  501. package/dist/Endpoint-BPv9_-m_.d.cts.map +0 -1
  502. package/dist/Endpoint-BVGZXFyV.cjs.map +0 -1
  503. package/dist/Endpoint-BdwG75G_.d.mts.map +0 -1
  504. package/dist/Endpoint-CuOEswxJ.mjs.map +0 -1
  505. package/dist/EndpointBuilder-B3az942t.d.mts.map +0 -1
  506. package/dist/EndpointBuilder-Cgj1P_ra.cjs.map +0 -1
  507. package/dist/EndpointBuilder-DIy_m1bu.d.cts.map +0 -1
  508. package/dist/EndpointBuilder-DnCB1h1j.mjs.map +0 -1
  509. package/dist/EndpointFactory-C-0nE6Jg.d.mts.map +0 -1
  510. package/dist/EndpointFactory-CYj6BYok.cjs.map +0 -1
  511. package/dist/EndpointFactory-CbdxPCIH.mjs.map +0 -1
  512. package/dist/EndpointFactory-CyPbm3AD.d.cts.map +0 -1
  513. package/dist/Function-BVHqIDp9.mjs.map +0 -1
  514. package/dist/Function-Cf7f_kCz.d.cts.map +0 -1
  515. package/dist/Function-DDZb1525.cjs.map +0 -1
  516. package/dist/Function-DN2G6OT5.d.mts.map +0 -1
  517. package/dist/FunctionBuilder-CJBzzXL3.d.cts.map +0 -1
  518. package/dist/FunctionBuilder-CrDYgfiI.mjs.map +0 -1
  519. package/dist/FunctionBuilder-Cxx8D2na.d.mts.map +0 -1
  520. package/dist/FunctionBuilder-DswJ-9sD.cjs.map +0 -1
  521. package/dist/FunctionExecutionWrapper-BYI2bGTL.cjs.map +0 -1
  522. package/dist/FunctionExecutionWrapper-CLDh7Z2_.mjs.map +0 -1
  523. package/dist/FunctionExecutionWrapper-DF260Aaj.d.mts.map +0 -1
  524. package/dist/FunctionExecutionWrapper-Qy8bmgFR.d.cts.map +0 -1
  525. package/dist/HonoEndpointAdaptor-BaPlUhz0.d.mts.map +0 -1
  526. package/dist/HonoEndpointAdaptor-CQe2FqMR.cjs +0 -234
  527. package/dist/HonoEndpointAdaptor-CQe2FqMR.cjs.map +0 -1
  528. package/dist/HonoEndpointAdaptor-Ce-2HBxn.mjs +0 -228
  529. package/dist/HonoEndpointAdaptor-Ce-2HBxn.mjs.map +0 -1
  530. package/dist/HonoEndpointAdaptor-YcRHYALH.d.cts.map +0 -1
  531. package/dist/Subscriber-BiHjVXtM.cjs.map +0 -1
  532. package/dist/Subscriber-BmPf9GFb.mjs.map +0 -1
  533. package/dist/Subscriber-COYMSevD.d.cts.map +0 -1
  534. package/dist/Subscriber-ikctpU3I.d.mts.map +0 -1
  535. package/dist/SubscriberBuilder-Cp1C-xtT.cjs.map +0 -1
  536. package/dist/SubscriberBuilder-DJPEeYDJ.mjs.map +0 -1
  537. package/dist/SubscriberBuilder-D_9zzllj.d.mts.map +0 -1
  538. package/dist/SubscriberBuilder-ivHAGIVi.d.cts.map +0 -1
  539. package/dist/TestEndpointAdaptor-C10xBI--.d.cts.map +0 -1
  540. package/dist/TestEndpointAdaptor-DB7bREhS.d.mts.map +0 -1
  541. package/dist/TestEndpointAdaptor-DJgik2Wj.mjs +0 -160
  542. package/dist/TestEndpointAdaptor-DJgik2Wj.mjs.map +0 -1
  543. package/dist/TestEndpointAdaptor-ZbtQiuHE.cjs +0 -166
  544. package/dist/TestEndpointAdaptor-ZbtQiuHE.cjs.map +0 -1
  545. package/dist/functions-C6EK1xL6.mjs +0 -8
  546. package/dist/functions-C6EK1xL6.mjs.map +0 -1
  547. package/dist/functions-fTid0RMK.cjs.map +0 -1
  548. package/dist/helpers-BcP1tXAi.cjs.map +0 -1
  549. package/dist/helpers-ByRTDO_m.mjs.map +0 -1
  550. package/dist/index-BWzGIj06.d.mts.map +0 -1
  551. package/dist/index-DmFozqLd.d.cts +0 -12
  552. package/dist/index-DmFozqLd.d.cts.map +0 -1
  553. package/dist/parseHonoQuery-CZC5_97v.cjs.map +0 -1
  554. package/dist/parseHonoQuery-DDgIkTO4.mjs.map +0 -1
  555. package/dist/publisher.d.cts.map +0 -1
  556. package/dist/publisher.d.mts.map +0 -1
  557. package/dist/types-DdIlpxAd.d.mts.map +0 -1
@@ -1,7 +1,7 @@
1
1
  import type { AuditableAction } from '@geekmidas/audit';
2
2
  import {
3
- type AuditLogTable,
4
- KyselyAuditStorage,
3
+ type AuditLogTable,
4
+ KyselyAuditStorage,
5
5
  } from '@geekmidas/audit/kysely';
6
6
  import { EnvironmentParser } from '@geekmidas/envkit';
7
7
  import type { Logger } from '@geekmidas/logger';
@@ -9,749 +9,943 @@ import type { Service } from '@geekmidas/services';
9
9
  import { ServiceDiscovery } from '@geekmidas/services';
10
10
  import { createMockContext, createMockV2Event } from '@geekmidas/testkit/aws';
11
11
  import {
12
- CamelCasePlugin,
13
- type Generated,
14
- Kysely,
15
- PostgresDialect,
16
- sql,
12
+ CamelCasePlugin,
13
+ type Generated,
14
+ Kysely,
15
+ PostgresDialect,
16
+ sql,
17
17
  } from 'kysely';
18
18
  import pg from 'pg';
19
19
  import {
20
- afterAll,
21
- afterEach,
22
- beforeAll,
23
- beforeEach,
24
- describe,
25
- expect,
26
- it,
27
- vi,
20
+ afterAll,
21
+ afterEach,
22
+ beforeAll,
23
+ beforeEach,
24
+ describe,
25
+ expect,
26
+ it,
27
+ vi,
28
28
  } from 'vitest';
29
29
  import { z } from 'zod';
30
30
  import { TEST_DATABASE_CONFIG } from '../../../../testkit/test/globalSetup';
31
31
  import { AmazonApiGatewayV2Endpoint } from '../AmazonApiGatewayV2EndpointAdaptor';
32
- import { Endpoint, type EndpointContext } from '../Endpoint';
33
32
  import type { MappedAudit } from '../audit';
33
+ import { Endpoint, type EndpointContext } from '../Endpoint';
34
34
 
35
35
  // Database schema - use different table names to avoid conflicts with HonoEndpoint tests
36
36
  interface TestDatabase {
37
- awsAuditLogs: AuditLogTable;
38
- awsUsers: {
39
- id: Generated<number>;
40
- name: string;
41
- email: string;
42
- };
37
+ awsAuditLogs: AuditLogTable;
38
+ awsUsers: {
39
+ id: Generated<number>;
40
+ name: string;
41
+ email: string;
42
+ };
43
43
  }
44
44
 
45
45
  // Audit action types
46
46
  type TestAuditAction =
47
- | AuditableAction<'user.created', { userId: number; email: string }>
48
- | AuditableAction<'user.updated', { userId: number; changes: string[] }>
49
- | AuditableAction<'user.deleted', { userId: number }>;
47
+ | AuditableAction<'user.created', { userId: number; email: string }>
48
+ | AuditableAction<'user.updated', { userId: number; changes: string[] }>
49
+ | AuditableAction<'user.deleted', { userId: number }>;
50
50
 
51
51
  describe('AmazonApiGatewayV2Endpoint Kysely Audit Integration', () => {
52
- let db: Kysely<TestDatabase>;
53
- let auditStorage: KyselyAuditStorage<TestDatabase>;
54
- let mockLogger: Logger;
55
- let envParser: EnvironmentParser<{}>;
56
-
57
- const createMockLogger = (): Logger => ({
58
- debug: vi.fn(),
59
- info: vi.fn(),
60
- warn: vi.fn(),
61
- error: vi.fn(),
62
- fatal: vi.fn(),
63
- trace: vi.fn(),
64
- child: vi.fn(function (this: Logger) {
65
- return this;
66
- }),
67
- });
68
-
69
- beforeAll(async () => {
70
- db = new Kysely<TestDatabase>({
71
- dialect: new PostgresDialect({
72
- pool: new pg.Pool({
73
- ...TEST_DATABASE_CONFIG,
74
- database: 'postgres',
75
- }),
76
- }),
77
- plugins: [new CamelCasePlugin()],
78
- });
79
-
80
- // Create audit_logs table
81
- await db.schema
82
- .createTable('awsAuditLogs')
83
- .ifNotExists()
84
- .addColumn('id', 'varchar(32)', (col) => col.primaryKey())
85
- .addColumn('type', 'varchar', (col) => col.notNull())
86
- .addColumn('operation', 'varchar', (col) => col.notNull())
87
- .addColumn('table', 'varchar')
88
- .addColumn('entityId', 'varchar')
89
- .addColumn('oldValues', 'jsonb')
90
- .addColumn('newValues', 'jsonb')
91
- .addColumn('payload', 'jsonb')
92
- .addColumn('timestamp', 'timestamp', (col) =>
93
- col.defaultTo(sql`now()`).notNull(),
94
- )
95
- .addColumn('actorId', 'varchar')
96
- .addColumn('actorType', 'varchar')
97
- .addColumn('actorData', 'jsonb')
98
- .addColumn('metadata', 'jsonb')
99
- .execute();
100
-
101
- // Create users table
102
- await db.schema
103
- .createTable('awsUsers')
104
- .ifNotExists()
105
- .addColumn('id', 'serial', (col) => col.primaryKey())
106
- .addColumn('name', 'varchar', (col) => col.notNull())
107
- .addColumn('email', 'varchar', (col) => col.notNull().unique())
108
- .execute();
109
-
110
- auditStorage = new KyselyAuditStorage({
111
- db,
112
- tableName: 'awsAuditLogs',
113
- });
114
- });
115
-
116
- beforeEach(() => {
117
- mockLogger = createMockLogger();
118
- envParser = new EnvironmentParser({});
119
- ServiceDiscovery.reset();
120
- });
121
-
122
- afterEach(async () => {
123
- await db.deleteFrom('awsAuditLogs').execute();
124
- await db.deleteFrom('awsUsers').execute();
125
- });
126
-
127
- afterAll(async () => {
128
- await db.schema.dropTable('awsAuditLogs').ifExists().execute();
129
- await db.schema.dropTable('awsUsers').ifExists().execute();
130
- await db.destroy();
131
- });
132
-
133
- describe('declarative audits with real database', () => {
134
- it('should write declarative audit to database on successful request', async () => {
135
- const auditStorageService: Service<
136
- 'auditStorage',
137
- KyselyAuditStorage<TestDatabase>
138
- > = {
139
- serviceName: 'auditStorage' as const,
140
- register: vi.fn().mockResolvedValue(auditStorage),
141
- };
142
-
143
- const outputSchema = z.object({ id: z.number(), email: z.string() });
144
-
145
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
146
- {
147
- type: 'user.created',
148
- payload: (response) => ({
149
- userId: response.id,
150
- email: response.email,
151
- }),
152
- },
153
- ];
154
-
155
- const endpoint = new Endpoint({
156
- route: '/users',
157
- method: 'POST',
158
- fn: async () => {
159
- return { id: 1, email: 'test@example.com' };
160
- },
161
- input: undefined,
162
- output: outputSchema,
163
- services: [],
164
- logger: mockLogger,
165
- timeout: undefined,
166
- memorySize: undefined,
167
- status: 201,
168
- getSession: undefined,
169
- authorize: undefined,
170
- description: undefined,
171
- events: [],
172
- publisherService: undefined,
173
- auditorStorageService: auditStorageService,
174
- audits,
175
- });
176
-
177
- const adapter = new AmazonApiGatewayV2Endpoint(
178
- envParser,
179
- endpoint as any,
180
- );
181
- const handler = adapter.handler;
182
-
183
- const event = createMockV2Event({
184
- requestContext: {
185
- ...createMockV2Event().requestContext,
186
- http: {
187
- method: 'POST',
188
- path: '/users',
189
- protocol: 'HTTP/1.1',
190
- sourceIp: '192.168.1.1',
191
- userAgent: 'test-agent',
192
- },
193
- },
194
- body: JSON.stringify({}),
195
- });
196
- const context = createMockContext();
197
- const response = await handler(event, context);
198
-
199
- expect(response.statusCode).toBe(201);
200
-
201
- // Verify audit was written to the real database
202
- const auditsInDb = await db
203
- .selectFrom('awsAuditLogs')
204
- .selectAll()
205
- .execute();
206
-
207
- expect(auditsInDb).toHaveLength(1);
208
- expect(auditsInDb[0].type).toBe('user.created');
209
- expect(auditsInDb[0].payload).toEqual({
210
- userId: 1,
211
- email: 'test@example.com',
212
- });
213
- });
214
-
215
- it('should not write audit when handler fails', async () => {
216
- const auditStorageService: Service<
217
- 'auditStorage',
218
- KyselyAuditStorage<TestDatabase>
219
- > = {
220
- serviceName: 'auditStorage' as const,
221
- register: vi.fn().mockResolvedValue(auditStorage),
222
- };
223
-
224
- const outputSchema = z.object({ id: z.number(), email: z.string() });
225
-
226
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
227
- {
228
- type: 'user.created',
229
- payload: (response) => ({
230
- userId: response.id,
231
- email: response.email,
232
- }),
233
- },
234
- ];
235
-
236
- const endpoint = new Endpoint({
237
- route: '/users',
238
- method: 'POST',
239
- fn: async () => {
240
- throw new Error('Handler failed');
241
- },
242
- input: undefined,
243
- output: outputSchema,
244
- services: [],
245
- logger: mockLogger,
246
- timeout: undefined,
247
- memorySize: undefined,
248
- status: 201,
249
- getSession: undefined,
250
- authorize: undefined,
251
- description: undefined,
252
- events: [],
253
- publisherService: undefined,
254
- auditorStorageService: auditStorageService,
255
- audits,
256
- });
257
-
258
- const adapter = new AmazonApiGatewayV2Endpoint(
259
- envParser,
260
- endpoint as any,
261
- );
262
- const handler = adapter.handler;
263
-
264
- const event = createMockV2Event({
265
- requestContext: {
266
- ...createMockV2Event().requestContext,
267
- http: {
268
- method: 'POST',
269
- path: '/users',
270
- protocol: 'HTTP/1.1',
271
- sourceIp: '192.168.1.1',
272
- userAgent: 'test-agent',
273
- },
274
- },
275
- body: JSON.stringify({}),
276
- });
277
- const context = createMockContext();
278
- const response = await handler(event, context);
279
-
280
- expect(response.statusCode).toBe(500);
281
-
282
- // Verify no audit was written
283
- const auditsInDb = await db
284
- .selectFrom('awsAuditLogs')
285
- .selectAll()
286
- .execute();
287
-
288
- expect(auditsInDb).toHaveLength(0);
289
- });
290
- });
291
-
292
- describe('manual audits with real database', () => {
293
- it('should write manual audits from handler to database', async () => {
294
- const auditStorageService: Service<
295
- 'auditStorage',
296
- KyselyAuditStorage<TestDatabase>
297
- > = {
298
- serviceName: 'auditStorage' as const,
299
- register: vi.fn().mockResolvedValue(auditStorage),
300
- };
301
-
302
- const outputSchema = z.object({ id: z.number(), email: z.string() });
303
-
304
- const endpoint = new Endpoint({
305
- route: '/users',
306
- method: 'POST',
307
- fn: async (
308
- ctx: EndpointContext<
309
- undefined,
310
- [],
311
- Logger,
312
- unknown,
313
- TestAuditAction,
314
- undefined,
315
- KyselyAuditStorage<TestDatabase>
316
- >,
317
- ) => {
318
- // Manual audit in handler - auditor is guaranteed to exist when TAuditStorage is configured
319
- ctx.auditor.audit('user.created', {
320
- userId: 42,
321
- email: 'manual@example.com',
322
- });
323
-
324
- return { id: 42, email: 'manual@example.com' };
325
- },
326
- input: undefined,
327
- output: outputSchema,
328
- services: [],
329
- logger: mockLogger,
330
- timeout: undefined,
331
- memorySize: undefined,
332
- status: 201,
333
- getSession: undefined,
334
- authorize: undefined,
335
- description: undefined,
336
- events: [],
337
- publisherService: undefined,
338
- auditorStorageService: auditStorageService,
339
- audits: [],
340
- });
341
-
342
- const adapter = new AmazonApiGatewayV2Endpoint(
343
- envParser,
344
- endpoint as any,
345
- );
346
- const handler = adapter.handler;
347
-
348
- const event = createMockV2Event({
349
- requestContext: {
350
- ...createMockV2Event().requestContext,
351
- http: {
352
- method: 'POST',
353
- path: '/users',
354
- protocol: 'HTTP/1.1',
355
- sourceIp: '192.168.1.1',
356
- userAgent: 'test-agent',
357
- },
358
- },
359
- body: JSON.stringify({}),
360
- });
361
- const context = createMockContext();
362
- const response = await handler(event, context);
363
-
364
- expect(response.statusCode).toBe(201);
365
-
366
- // Verify manual audit was written
367
- const auditsInDb = await db
368
- .selectFrom('awsAuditLogs')
369
- .selectAll()
370
- .execute();
371
-
372
- expect(auditsInDb).toHaveLength(1);
373
- expect(auditsInDb[0].type).toBe('user.created');
374
- expect(auditsInDb[0].payload).toEqual({
375
- userId: 42,
376
- email: 'manual@example.com',
377
- });
378
- });
379
-
380
- it('should not write manual audit when handler fails after audit call', async () => {
381
- const auditStorageService: Service<
382
- 'auditStorage',
383
- KyselyAuditStorage<TestDatabase>
384
- > = {
385
- serviceName: 'auditStorage' as const,
386
- register: vi.fn().mockResolvedValue(auditStorage),
387
- };
388
-
389
- const outputSchema = z.object({ id: z.number(), email: z.string() });
390
-
391
- const endpoint = new Endpoint({
392
- route: '/users',
393
- method: 'POST',
394
- fn: async (
395
- ctx: EndpointContext<
396
- undefined,
397
- [],
398
- Logger,
399
- unknown,
400
- TestAuditAction,
401
- undefined,
402
- KyselyAuditStorage<TestDatabase>
403
- >,
404
- ) => {
405
- // Manual audit before failure - auditor is guaranteed to exist
406
- ctx.auditor.audit('user.created', {
407
- userId: 99,
408
- email: 'shouldnotexist@example.com',
409
- });
410
-
411
- // Fail after audit
412
- throw new Error('Handler failed after audit');
413
- },
414
- input: undefined,
415
- output: outputSchema,
416
- services: [],
417
- logger: mockLogger,
418
- timeout: undefined,
419
- memorySize: undefined,
420
- status: 201,
421
- getSession: undefined,
422
- authorize: undefined,
423
- description: undefined,
424
- events: [],
425
- publisherService: undefined,
426
- auditorStorageService: auditStorageService,
427
- audits: [],
428
- });
429
-
430
- const adapter = new AmazonApiGatewayV2Endpoint(
431
- envParser,
432
- endpoint as any,
433
- );
434
- const handler = adapter.handler;
435
-
436
- const event = createMockV2Event({
437
- requestContext: {
438
- ...createMockV2Event().requestContext,
439
- http: {
440
- method: 'POST',
441
- path: '/users',
442
- protocol: 'HTTP/1.1',
443
- sourceIp: '192.168.1.1',
444
- userAgent: 'test-agent',
445
- },
446
- },
447
- body: JSON.stringify({}),
448
- });
449
- const context = createMockContext();
450
- const response = await handler(event, context);
451
-
452
- expect(response.statusCode).toBe(500);
453
-
454
- // Verify no audit was written (transaction rolled back)
455
- const auditsInDb = await db
456
- .selectFrom('awsAuditLogs')
457
- .selectAll()
458
- .execute();
459
-
460
- expect(auditsInDb).toHaveLength(0);
461
- });
462
- });
463
-
464
- describe('transactional consistency with real database', () => {
465
- it('should commit both user insert and audit on success', async () => {
466
- const databaseService: Service<'database', Kysely<TestDatabase>> = {
467
- serviceName: 'database' as const,
468
- register: vi.fn().mockResolvedValue(db),
469
- };
470
-
471
- const auditStorageService: Service<
472
- 'auditStorage',
473
- KyselyAuditStorage<TestDatabase>
474
- > = {
475
- serviceName: 'auditStorage' as const,
476
- register: vi.fn().mockResolvedValue(auditStorage),
477
- };
478
-
479
- const outputSchema = z.object({ id: z.number(), email: z.string() });
480
-
481
- const endpoint = new Endpoint({
482
- route: '/users',
483
- method: 'POST',
484
- fn: async (
485
- ctx: EndpointContext<
486
- undefined,
487
- [typeof databaseService],
488
- Logger,
489
- unknown,
490
- TestAuditAction,
491
- undefined,
492
- KyselyAuditStorage<TestDatabase>
493
- >,
494
- ) => {
495
- const database = ctx.services.database;
496
-
497
- // Insert user
498
- const user = await database
499
- .insertInto('awsUsers')
500
- .values({ name: 'Success User', email: 'success@example.com' })
501
- .returningAll()
502
- .executeTakeFirstOrThrow();
503
-
504
- // Record audit - auditor is guaranteed to exist
505
- ctx.auditor.audit('user.created', {
506
- userId: user.id,
507
- email: user.email,
508
- });
509
-
510
- return { id: user.id, email: user.email };
511
- },
512
- input: undefined,
513
- output: outputSchema,
514
- services: [databaseService],
515
- logger: mockLogger,
516
- timeout: undefined,
517
- memorySize: undefined,
518
- status: 201,
519
- getSession: undefined,
520
- authorize: undefined,
521
- description: undefined,
522
- events: [],
523
- publisherService: undefined,
524
- auditorStorageService: auditStorageService,
525
- audits: [],
526
- });
527
-
528
- const adapter = new AmazonApiGatewayV2Endpoint(
529
- envParser,
530
- endpoint as any,
531
- );
532
- const handler = adapter.handler;
533
-
534
- const event = createMockV2Event({
535
- requestContext: {
536
- ...createMockV2Event().requestContext,
537
- http: {
538
- method: 'POST',
539
- path: '/users',
540
- protocol: 'HTTP/1.1',
541
- sourceIp: '192.168.1.1',
542
- userAgent: 'test-agent',
543
- },
544
- },
545
- body: JSON.stringify({}),
546
- });
547
- const context = createMockContext();
548
- const response = await handler(event, context);
549
-
550
- expect(response.statusCode).toBe(201);
551
-
552
- // Verify user was created
553
- const usersInDb = await db.selectFrom('awsUsers').selectAll().execute();
554
- expect(usersInDb).toHaveLength(1);
555
- expect(usersInDb[0].email).toBe('success@example.com');
556
-
557
- // Verify audit was written
558
- const auditsInDb = await db
559
- .selectFrom('awsAuditLogs')
560
- .selectAll()
561
- .execute();
562
- expect(auditsInDb).toHaveLength(1);
563
- expect(auditsInDb[0].type).toBe('user.created');
564
- expect(auditsInDb[0].payload).toEqual({
565
- userId: usersInDb[0].id,
566
- email: 'success@example.com',
567
- });
568
- });
569
-
570
- it('should handle combined declarative and manual audits', async () => {
571
- const auditStorageService: Service<
572
- 'auditStorage',
573
- KyselyAuditStorage<TestDatabase>
574
- > = {
575
- serviceName: 'auditStorage' as const,
576
- register: vi.fn().mockResolvedValue(auditStorage),
577
- };
578
-
579
- const outputSchema = z.object({ id: z.number(), email: z.string() });
580
-
581
- // Declarative audit
582
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
583
- {
584
- type: 'user.created',
585
- payload: (response) => ({
586
- userId: response.id,
587
- email: response.email,
588
- }),
589
- },
590
- ];
591
-
592
- const endpoint = new Endpoint({
593
- route: '/users',
594
- method: 'POST',
595
- fn: async (
596
- ctx: EndpointContext<
597
- undefined,
598
- [],
599
- Logger,
600
- unknown,
601
- TestAuditAction,
602
- undefined,
603
- KyselyAuditStorage<TestDatabase>
604
- >,
605
- ) => {
606
- // Manual audit - auditor is guaranteed to exist
607
- ctx.auditor.audit('user.updated', {
608
- userId: 100,
609
- changes: ['verified'],
610
- });
611
-
612
- return { id: 100, email: 'combined@example.com' };
613
- },
614
- input: undefined,
615
- output: outputSchema,
616
- services: [],
617
- logger: mockLogger,
618
- timeout: undefined,
619
- memorySize: undefined,
620
- status: 201,
621
- getSession: undefined,
622
- authorize: undefined,
623
- description: undefined,
624
- events: [],
625
- publisherService: undefined,
626
- auditorStorageService: auditStorageService,
627
- audits,
628
- });
629
-
630
- const adapter = new AmazonApiGatewayV2Endpoint(
631
- envParser,
632
- endpoint as any,
633
- );
634
- const handler = adapter.handler;
635
-
636
- const event = createMockV2Event({
637
- requestContext: {
638
- ...createMockV2Event().requestContext,
639
- http: {
640
- method: 'POST',
641
- path: '/users',
642
- protocol: 'HTTP/1.1',
643
- sourceIp: '192.168.1.1',
644
- userAgent: 'test-agent',
645
- },
646
- },
647
- body: JSON.stringify({}),
648
- });
649
- const context = createMockContext();
650
- const response = await handler(event, context);
651
-
652
- expect(response.statusCode).toBe(201);
653
-
654
- // Verify both audits were written
655
- const auditsInDb = await db
656
- .selectFrom('awsAuditLogs')
657
- .selectAll()
658
- .execute();
659
-
660
- expect(auditsInDb).toHaveLength(2);
661
-
662
- const auditTypes = auditsInDb.map((a) => a.type).sort();
663
- expect(auditTypes).toEqual(['user.created', 'user.updated']);
664
- });
665
- });
666
-
667
- describe('actor extraction with real database', () => {
668
- it('should include actor information in audit records', async () => {
669
- const auditStorageService: Service<
670
- 'auditStorage',
671
- KyselyAuditStorage<TestDatabase>
672
- > = {
673
- serviceName: 'auditStorage' as const,
674
- register: vi.fn().mockResolvedValue(auditStorage),
675
- };
676
-
677
- const outputSchema = z.object({ id: z.number(), email: z.string() });
678
-
679
- const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
680
- {
681
- type: 'user.created',
682
- payload: (response) => ({
683
- userId: response.id,
684
- email: response.email,
685
- }),
686
- },
687
- ];
688
-
689
- const endpoint = new Endpoint({
690
- route: '/users',
691
- method: 'POST',
692
- fn: async () => {
693
- return { id: 1, email: 'actor-test@example.com' };
694
- },
695
- input: undefined,
696
- output: outputSchema,
697
- services: [],
698
- logger: mockLogger,
699
- timeout: undefined,
700
- memorySize: undefined,
701
- status: 201,
702
- getSession: undefined,
703
- authorize: undefined,
704
- description: undefined,
705
- events: [],
706
- publisherService: undefined,
707
- auditorStorageService: auditStorageService,
708
- audits,
709
- actorExtractor: async ({ header }) => {
710
- const userId = header('x-user-id');
711
- return {
712
- id: userId ?? 'anonymous',
713
- type: userId ? 'user' : 'anonymous',
714
- };
715
- },
716
- });
717
-
718
- const adapter = new AmazonApiGatewayV2Endpoint(
719
- envParser,
720
- endpoint as any,
721
- );
722
- const handler = adapter.handler;
723
-
724
- const event = createMockV2Event({
725
- requestContext: {
726
- ...createMockV2Event().requestContext,
727
- http: {
728
- method: 'POST',
729
- path: '/users',
730
- protocol: 'HTTP/1.1',
731
- sourceIp: '192.168.1.1',
732
- userAgent: 'test-agent',
733
- },
734
- },
735
- headers: {
736
- 'content-type': 'application/json',
737
- 'x-user-id': 'user-123',
738
- },
739
- body: JSON.stringify({}),
740
- });
741
- const context = createMockContext();
742
- const response = await handler(event, context);
743
-
744
- expect(response.statusCode).toBe(201);
745
-
746
- // Verify actor was included in audit
747
- const auditsInDb = await db
748
- .selectFrom('awsAuditLogs')
749
- .selectAll()
750
- .execute();
751
-
752
- expect(auditsInDb).toHaveLength(1);
753
- expect(auditsInDb[0].actorId).toBe('user-123');
754
- expect(auditsInDb[0].actorType).toBe('user');
755
- });
756
- });
52
+ let db: Kysely<TestDatabase>;
53
+ let auditStorage: KyselyAuditStorage<TestDatabase>;
54
+ let mockLogger: Logger;
55
+ let envParser: EnvironmentParser<{}>;
56
+
57
+ const createMockLogger = (): Logger => ({
58
+ debug: vi.fn(),
59
+ info: vi.fn(),
60
+ warn: vi.fn(),
61
+ error: vi.fn(),
62
+ fatal: vi.fn(),
63
+ trace: vi.fn(),
64
+ child: vi.fn(function (this: Logger) {
65
+ return this;
66
+ }),
67
+ });
68
+
69
+ beforeAll(async () => {
70
+ db = new Kysely<TestDatabase>({
71
+ dialect: new PostgresDialect({
72
+ pool: new pg.Pool({
73
+ ...TEST_DATABASE_CONFIG,
74
+ database: 'postgres',
75
+ }),
76
+ }),
77
+ plugins: [new CamelCasePlugin()],
78
+ });
79
+
80
+ // Create audit_logs table
81
+ await db.schema
82
+ .createTable('awsAuditLogs')
83
+ .ifNotExists()
84
+ .addColumn('id', 'varchar(32)', (col) => col.primaryKey())
85
+ .addColumn('type', 'varchar', (col) => col.notNull())
86
+ .addColumn('operation', 'varchar', (col) => col.notNull())
87
+ .addColumn('table', 'varchar')
88
+ .addColumn('entityId', 'varchar')
89
+ .addColumn('oldValues', 'jsonb')
90
+ .addColumn('newValues', 'jsonb')
91
+ .addColumn('payload', 'jsonb')
92
+ .addColumn('timestamp', 'timestamp', (col) =>
93
+ col.defaultTo(sql`now()`).notNull(),
94
+ )
95
+ .addColumn('actorId', 'varchar')
96
+ .addColumn('actorType', 'varchar')
97
+ .addColumn('actorData', 'jsonb')
98
+ .addColumn('metadata', 'jsonb')
99
+ .execute();
100
+
101
+ // Create users table
102
+ await db.schema
103
+ .createTable('awsUsers')
104
+ .ifNotExists()
105
+ .addColumn('id', 'serial', (col) => col.primaryKey())
106
+ .addColumn('name', 'varchar', (col) => col.notNull())
107
+ .addColumn('email', 'varchar', (col) => col.notNull().unique())
108
+ .execute();
109
+
110
+ auditStorage = new KyselyAuditStorage({
111
+ db,
112
+ tableName: 'awsAuditLogs',
113
+ });
114
+ });
115
+
116
+ beforeEach(() => {
117
+ mockLogger = createMockLogger();
118
+ envParser = new EnvironmentParser({});
119
+ ServiceDiscovery.reset();
120
+ });
121
+
122
+ afterEach(async () => {
123
+ await db.deleteFrom('awsAuditLogs').execute();
124
+ await db.deleteFrom('awsUsers').execute();
125
+ });
126
+
127
+ afterAll(async () => {
128
+ await db.schema.dropTable('awsAuditLogs').ifExists().execute();
129
+ await db.schema.dropTable('awsUsers').ifExists().execute();
130
+ await db.destroy();
131
+ });
132
+
133
+ describe('declarative audits with real database', () => {
134
+ it('should write declarative audit to database on successful request', async () => {
135
+ const auditStorageService: Service<
136
+ 'auditStorage',
137
+ KyselyAuditStorage<TestDatabase>
138
+ > = {
139
+ serviceName: 'auditStorage' as const,
140
+ register: vi.fn().mockResolvedValue(auditStorage),
141
+ };
142
+
143
+ const outputSchema = z.object({ id: z.number(), email: z.string() });
144
+
145
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
146
+ {
147
+ type: 'user.created',
148
+ payload: (response) => ({
149
+ userId: response.id,
150
+ email: response.email,
151
+ }),
152
+ },
153
+ ];
154
+
155
+ const endpoint = new Endpoint({
156
+ route: '/users',
157
+ method: 'POST',
158
+ fn: async () => {
159
+ return { id: 1, email: 'test@example.com' };
160
+ },
161
+ input: undefined,
162
+ output: outputSchema,
163
+ services: [],
164
+ logger: mockLogger,
165
+ timeout: undefined,
166
+ memorySize: undefined,
167
+ status: 201,
168
+ getSession: undefined,
169
+ authorize: undefined,
170
+ description: undefined,
171
+ events: [],
172
+ publisherService: undefined,
173
+ auditorStorageService: auditStorageService,
174
+ audits,
175
+ });
176
+
177
+ const adapter = new AmazonApiGatewayV2Endpoint(
178
+ envParser,
179
+ endpoint as any,
180
+ );
181
+ const handler = adapter.handler;
182
+
183
+ const event = createMockV2Event({
184
+ requestContext: {
185
+ ...createMockV2Event().requestContext,
186
+ http: {
187
+ method: 'POST',
188
+ path: '/users',
189
+ protocol: 'HTTP/1.1',
190
+ sourceIp: '192.168.1.1',
191
+ userAgent: 'test-agent',
192
+ },
193
+ },
194
+ body: JSON.stringify({}),
195
+ });
196
+ const context = createMockContext();
197
+ const response = await handler(event, context);
198
+
199
+ expect(response.statusCode).toBe(201);
200
+
201
+ // Verify audit was written to the real database
202
+ const auditsInDb = await db
203
+ .selectFrom('awsAuditLogs')
204
+ .selectAll()
205
+ .execute();
206
+
207
+ expect(auditsInDb).toHaveLength(1);
208
+ expect(auditsInDb[0].type).toBe('user.created');
209
+ expect(auditsInDb[0].payload).toEqual({
210
+ userId: 1,
211
+ email: 'test@example.com',
212
+ });
213
+ });
214
+
215
+ it('should not write audit when handler fails', async () => {
216
+ const auditStorageService: Service<
217
+ 'auditStorage',
218
+ KyselyAuditStorage<TestDatabase>
219
+ > = {
220
+ serviceName: 'auditStorage' as const,
221
+ register: vi.fn().mockResolvedValue(auditStorage),
222
+ };
223
+
224
+ const outputSchema = z.object({ id: z.number(), email: z.string() });
225
+
226
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
227
+ {
228
+ type: 'user.created',
229
+ payload: (response) => ({
230
+ userId: response.id,
231
+ email: response.email,
232
+ }),
233
+ },
234
+ ];
235
+
236
+ const endpoint = new Endpoint({
237
+ route: '/users',
238
+ method: 'POST',
239
+ fn: async () => {
240
+ throw new Error('Handler failed');
241
+ },
242
+ input: undefined,
243
+ output: outputSchema,
244
+ services: [],
245
+ logger: mockLogger,
246
+ timeout: undefined,
247
+ memorySize: undefined,
248
+ status: 201,
249
+ getSession: undefined,
250
+ authorize: undefined,
251
+ description: undefined,
252
+ events: [],
253
+ publisherService: undefined,
254
+ auditorStorageService: auditStorageService,
255
+ audits,
256
+ });
257
+
258
+ const adapter = new AmazonApiGatewayV2Endpoint(
259
+ envParser,
260
+ endpoint as any,
261
+ );
262
+ const handler = adapter.handler;
263
+
264
+ const event = createMockV2Event({
265
+ requestContext: {
266
+ ...createMockV2Event().requestContext,
267
+ http: {
268
+ method: 'POST',
269
+ path: '/users',
270
+ protocol: 'HTTP/1.1',
271
+ sourceIp: '192.168.1.1',
272
+ userAgent: 'test-agent',
273
+ },
274
+ },
275
+ body: JSON.stringify({}),
276
+ });
277
+ const context = createMockContext();
278
+ const response = await handler(event, context);
279
+
280
+ expect(response.statusCode).toBe(500);
281
+
282
+ // Verify no audit was written
283
+ const auditsInDb = await db
284
+ .selectFrom('awsAuditLogs')
285
+ .selectAll()
286
+ .execute();
287
+
288
+ expect(auditsInDb).toHaveLength(0);
289
+ });
290
+ });
291
+
292
+ describe('manual audits with real database', () => {
293
+ it('should write manual audits from handler to database', async () => {
294
+ const auditStorageService: Service<
295
+ 'auditStorage',
296
+ KyselyAuditStorage<TestDatabase>
297
+ > = {
298
+ serviceName: 'auditStorage' as const,
299
+ register: vi.fn().mockResolvedValue(auditStorage),
300
+ };
301
+
302
+ const outputSchema = z.object({ id: z.number(), email: z.string() });
303
+
304
+ const endpoint = new Endpoint({
305
+ route: '/users',
306
+ method: 'POST',
307
+ fn: async (
308
+ ctx: EndpointContext<
309
+ undefined,
310
+ [],
311
+ Logger,
312
+ unknown,
313
+ TestAuditAction,
314
+ undefined,
315
+ KyselyAuditStorage<TestDatabase>
316
+ >,
317
+ ) => {
318
+ // Manual audit in handler - auditor is guaranteed to exist when TAuditStorage is configured
319
+ ctx.auditor.audit('user.created', {
320
+ userId: 42,
321
+ email: 'manual@example.com',
322
+ });
323
+
324
+ return { id: 42, email: 'manual@example.com' };
325
+ },
326
+ input: undefined,
327
+ output: outputSchema,
328
+ services: [],
329
+ logger: mockLogger,
330
+ timeout: undefined,
331
+ memorySize: undefined,
332
+ status: 201,
333
+ getSession: undefined,
334
+ authorize: undefined,
335
+ description: undefined,
336
+ events: [],
337
+ publisherService: undefined,
338
+ auditorStorageService: auditStorageService,
339
+ audits: [],
340
+ });
341
+
342
+ const adapter = new AmazonApiGatewayV2Endpoint(
343
+ envParser,
344
+ endpoint as any,
345
+ );
346
+ const handler = adapter.handler;
347
+
348
+ const event = createMockV2Event({
349
+ requestContext: {
350
+ ...createMockV2Event().requestContext,
351
+ http: {
352
+ method: 'POST',
353
+ path: '/users',
354
+ protocol: 'HTTP/1.1',
355
+ sourceIp: '192.168.1.1',
356
+ userAgent: 'test-agent',
357
+ },
358
+ },
359
+ body: JSON.stringify({}),
360
+ });
361
+ const context = createMockContext();
362
+ const response = await handler(event, context);
363
+
364
+ expect(response.statusCode).toBe(201);
365
+
366
+ // Verify manual audit was written
367
+ const auditsInDb = await db
368
+ .selectFrom('awsAuditLogs')
369
+ .selectAll()
370
+ .execute();
371
+
372
+ expect(auditsInDb).toHaveLength(1);
373
+ expect(auditsInDb[0].type).toBe('user.created');
374
+ expect(auditsInDb[0].payload).toEqual({
375
+ userId: 42,
376
+ email: 'manual@example.com',
377
+ });
378
+ });
379
+
380
+ it('should not write manual audit when handler fails after audit call', async () => {
381
+ const auditStorageService: Service<
382
+ 'auditStorage',
383
+ KyselyAuditStorage<TestDatabase>
384
+ > = {
385
+ serviceName: 'auditStorage' as const,
386
+ register: vi.fn().mockResolvedValue(auditStorage),
387
+ };
388
+
389
+ const outputSchema = z.object({ id: z.number(), email: z.string() });
390
+
391
+ const endpoint = new Endpoint({
392
+ route: '/users',
393
+ method: 'POST',
394
+ fn: async (
395
+ ctx: EndpointContext<
396
+ undefined,
397
+ [],
398
+ Logger,
399
+ unknown,
400
+ TestAuditAction,
401
+ undefined,
402
+ KyselyAuditStorage<TestDatabase>
403
+ >,
404
+ ) => {
405
+ // Manual audit before failure - auditor is guaranteed to exist
406
+ ctx.auditor.audit('user.created', {
407
+ userId: 99,
408
+ email: 'shouldnotexist@example.com',
409
+ });
410
+
411
+ // Fail after audit
412
+ throw new Error('Handler failed after audit');
413
+ },
414
+ input: undefined,
415
+ output: outputSchema,
416
+ services: [],
417
+ logger: mockLogger,
418
+ timeout: undefined,
419
+ memorySize: undefined,
420
+ status: 201,
421
+ getSession: undefined,
422
+ authorize: undefined,
423
+ description: undefined,
424
+ events: [],
425
+ publisherService: undefined,
426
+ auditorStorageService: auditStorageService,
427
+ audits: [],
428
+ });
429
+
430
+ const adapter = new AmazonApiGatewayV2Endpoint(
431
+ envParser,
432
+ endpoint as any,
433
+ );
434
+ const handler = adapter.handler;
435
+
436
+ const event = createMockV2Event({
437
+ requestContext: {
438
+ ...createMockV2Event().requestContext,
439
+ http: {
440
+ method: 'POST',
441
+ path: '/users',
442
+ protocol: 'HTTP/1.1',
443
+ sourceIp: '192.168.1.1',
444
+ userAgent: 'test-agent',
445
+ },
446
+ },
447
+ body: JSON.stringify({}),
448
+ });
449
+ const context = createMockContext();
450
+ const response = await handler(event, context);
451
+
452
+ expect(response.statusCode).toBe(500);
453
+
454
+ // Verify no audit was written (transaction rolled back)
455
+ const auditsInDb = await db
456
+ .selectFrom('awsAuditLogs')
457
+ .selectAll()
458
+ .execute();
459
+
460
+ expect(auditsInDb).toHaveLength(0);
461
+ });
462
+ });
463
+
464
+ describe('transactional consistency with real database', () => {
465
+ it('should commit both user insert and audit on success', async () => {
466
+ const databaseService: Service<'database', Kysely<TestDatabase>> = {
467
+ serviceName: 'database' as const,
468
+ register: vi.fn().mockResolvedValue(db),
469
+ };
470
+
471
+ const auditStorageService: Service<
472
+ 'auditStorage',
473
+ KyselyAuditStorage<TestDatabase>
474
+ > = {
475
+ serviceName: 'auditStorage' as const,
476
+ register: vi.fn().mockResolvedValue(auditStorage),
477
+ };
478
+
479
+ const outputSchema = z.object({ id: z.number(), email: z.string() });
480
+
481
+ const endpoint = new Endpoint({
482
+ route: '/users',
483
+ method: 'POST',
484
+ fn: async (
485
+ ctx: EndpointContext<
486
+ undefined,
487
+ [typeof databaseService],
488
+ Logger,
489
+ unknown,
490
+ TestAuditAction,
491
+ undefined,
492
+ KyselyAuditStorage<TestDatabase>
493
+ >,
494
+ ) => {
495
+ const database = ctx.services.database;
496
+
497
+ // Insert user
498
+ const user = await database
499
+ .insertInto('awsUsers')
500
+ .values({ name: 'Success User', email: 'success@example.com' })
501
+ .returningAll()
502
+ .executeTakeFirstOrThrow();
503
+
504
+ // Record audit - auditor is guaranteed to exist
505
+ ctx.auditor.audit('user.created', {
506
+ userId: user.id,
507
+ email: user.email,
508
+ });
509
+
510
+ return { id: user.id, email: user.email };
511
+ },
512
+ input: undefined,
513
+ output: outputSchema,
514
+ services: [databaseService],
515
+ logger: mockLogger,
516
+ timeout: undefined,
517
+ memorySize: undefined,
518
+ status: 201,
519
+ getSession: undefined,
520
+ authorize: undefined,
521
+ description: undefined,
522
+ events: [],
523
+ publisherService: undefined,
524
+ auditorStorageService: auditStorageService,
525
+ audits: [],
526
+ });
527
+
528
+ const adapter = new AmazonApiGatewayV2Endpoint(
529
+ envParser,
530
+ endpoint as any,
531
+ );
532
+ const handler = adapter.handler;
533
+
534
+ const event = createMockV2Event({
535
+ requestContext: {
536
+ ...createMockV2Event().requestContext,
537
+ http: {
538
+ method: 'POST',
539
+ path: '/users',
540
+ protocol: 'HTTP/1.1',
541
+ sourceIp: '192.168.1.1',
542
+ userAgent: 'test-agent',
543
+ },
544
+ },
545
+ body: JSON.stringify({}),
546
+ });
547
+ const context = createMockContext();
548
+ const response = await handler(event, context);
549
+
550
+ expect(response.statusCode).toBe(201);
551
+
552
+ // Verify user was created
553
+ const usersInDb = await db.selectFrom('awsUsers').selectAll().execute();
554
+ expect(usersInDb).toHaveLength(1);
555
+ expect(usersInDb[0].email).toBe('success@example.com');
556
+
557
+ // Verify audit was written
558
+ const auditsInDb = await db
559
+ .selectFrom('awsAuditLogs')
560
+ .selectAll()
561
+ .execute();
562
+ expect(auditsInDb).toHaveLength(1);
563
+ expect(auditsInDb[0].type).toBe('user.created');
564
+ expect(auditsInDb[0].payload).toEqual({
565
+ userId: usersInDb[0].id,
566
+ email: 'success@example.com',
567
+ });
568
+ });
569
+
570
+ it('should handle combined declarative and manual audits', async () => {
571
+ const auditStorageService: Service<
572
+ 'auditStorage',
573
+ KyselyAuditStorage<TestDatabase>
574
+ > = {
575
+ serviceName: 'auditStorage' as const,
576
+ register: vi.fn().mockResolvedValue(auditStorage),
577
+ };
578
+
579
+ const outputSchema = z.object({ id: z.number(), email: z.string() });
580
+
581
+ // Declarative audit
582
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
583
+ {
584
+ type: 'user.created',
585
+ payload: (response) => ({
586
+ userId: response.id,
587
+ email: response.email,
588
+ }),
589
+ },
590
+ ];
591
+
592
+ const endpoint = new Endpoint({
593
+ route: '/users',
594
+ method: 'POST',
595
+ fn: async (
596
+ ctx: EndpointContext<
597
+ undefined,
598
+ [],
599
+ Logger,
600
+ unknown,
601
+ TestAuditAction,
602
+ undefined,
603
+ KyselyAuditStorage<TestDatabase>
604
+ >,
605
+ ) => {
606
+ // Manual audit - auditor is guaranteed to exist
607
+ ctx.auditor.audit('user.updated', {
608
+ userId: 100,
609
+ changes: ['verified'],
610
+ });
611
+
612
+ return { id: 100, email: 'combined@example.com' };
613
+ },
614
+ input: undefined,
615
+ output: outputSchema,
616
+ services: [],
617
+ logger: mockLogger,
618
+ timeout: undefined,
619
+ memorySize: undefined,
620
+ status: 201,
621
+ getSession: undefined,
622
+ authorize: undefined,
623
+ description: undefined,
624
+ events: [],
625
+ publisherService: undefined,
626
+ auditorStorageService: auditStorageService,
627
+ audits,
628
+ });
629
+
630
+ const adapter = new AmazonApiGatewayV2Endpoint(
631
+ envParser,
632
+ endpoint as any,
633
+ );
634
+ const handler = adapter.handler;
635
+
636
+ const event = createMockV2Event({
637
+ requestContext: {
638
+ ...createMockV2Event().requestContext,
639
+ http: {
640
+ method: 'POST',
641
+ path: '/users',
642
+ protocol: 'HTTP/1.1',
643
+ sourceIp: '192.168.1.1',
644
+ userAgent: 'test-agent',
645
+ },
646
+ },
647
+ body: JSON.stringify({}),
648
+ });
649
+ const context = createMockContext();
650
+ const response = await handler(event, context);
651
+
652
+ expect(response.statusCode).toBe(201);
653
+
654
+ // Verify both audits were written
655
+ const auditsInDb = await db
656
+ .selectFrom('awsAuditLogs')
657
+ .selectAll()
658
+ .execute();
659
+
660
+ expect(auditsInDb).toHaveLength(2);
661
+
662
+ const auditTypes = auditsInDb.map((a) => a.type).sort();
663
+ expect(auditTypes).toEqual(['user.created', 'user.updated']);
664
+ });
665
+ });
666
+
667
+ describe('actor extraction with real database', () => {
668
+ it('should include actor information in audit records', async () => {
669
+ const auditStorageService: Service<
670
+ 'auditStorage',
671
+ KyselyAuditStorage<TestDatabase>
672
+ > = {
673
+ serviceName: 'auditStorage' as const,
674
+ register: vi.fn().mockResolvedValue(auditStorage),
675
+ };
676
+
677
+ const outputSchema = z.object({ id: z.number(), email: z.string() });
678
+
679
+ const audits: MappedAudit<TestAuditAction, typeof outputSchema>[] = [
680
+ {
681
+ type: 'user.created',
682
+ payload: (response) => ({
683
+ userId: response.id,
684
+ email: response.email,
685
+ }),
686
+ },
687
+ ];
688
+
689
+ const endpoint = new Endpoint({
690
+ route: '/users',
691
+ method: 'POST',
692
+ fn: async () => {
693
+ return { id: 1, email: 'actor-test@example.com' };
694
+ },
695
+ input: undefined,
696
+ output: outputSchema,
697
+ services: [],
698
+ logger: mockLogger,
699
+ timeout: undefined,
700
+ memorySize: undefined,
701
+ status: 201,
702
+ getSession: undefined,
703
+ authorize: undefined,
704
+ description: undefined,
705
+ events: [],
706
+ publisherService: undefined,
707
+ auditorStorageService: auditStorageService,
708
+ audits,
709
+ actorExtractor: async ({ header }) => {
710
+ const userId = header('x-user-id');
711
+ return {
712
+ id: userId ?? 'anonymous',
713
+ type: userId ? 'user' : 'anonymous',
714
+ };
715
+ },
716
+ });
717
+
718
+ const adapter = new AmazonApiGatewayV2Endpoint(
719
+ envParser,
720
+ endpoint as any,
721
+ );
722
+ const handler = adapter.handler;
723
+
724
+ const event = createMockV2Event({
725
+ requestContext: {
726
+ ...createMockV2Event().requestContext,
727
+ http: {
728
+ method: 'POST',
729
+ path: '/users',
730
+ protocol: 'HTTP/1.1',
731
+ sourceIp: '192.168.1.1',
732
+ userAgent: 'test-agent',
733
+ },
734
+ },
735
+ headers: {
736
+ 'content-type': 'application/json',
737
+ 'x-user-id': 'user-123',
738
+ },
739
+ body: JSON.stringify({}),
740
+ });
741
+ const context = createMockContext();
742
+ const response = await handler(event, context);
743
+
744
+ expect(response.statusCode).toBe(201);
745
+
746
+ // Verify actor was included in audit
747
+ const auditsInDb = await db
748
+ .selectFrom('awsAuditLogs')
749
+ .selectAll()
750
+ .execute();
751
+
752
+ expect(auditsInDb).toHaveLength(1);
753
+ expect(auditsInDb[0].actorId).toBe('user-123');
754
+ expect(auditsInDb[0].actorType).toBe('user');
755
+ });
756
+ });
757
+
758
+ describe('RLS context with real database', () => {
759
+ it('should set RLS context variables in transaction', async () => {
760
+ const databaseService: Service<'database', Kysely<TestDatabase>> = {
761
+ serviceName: 'database' as const,
762
+ register: vi.fn().mockResolvedValue(db),
763
+ };
764
+
765
+ type TestSession = { userId: string; tenantId: string };
766
+
767
+ const outputSchema = z.object({
768
+ userId: z.string(),
769
+ tenantId: z.string(),
770
+ });
771
+
772
+ const endpoint = new Endpoint({
773
+ route: '/rls-test',
774
+ method: 'GET',
775
+ fn: async (ctx) => {
776
+ // Query the session variables to verify they were set
777
+ const userIdResult = await sql<{ value: string }>`
778
+ SELECT current_setting('app.user_id', true) as value
779
+ `.execute(ctx.db);
780
+
781
+ const tenantIdResult = await sql<{ value: string }>`
782
+ SELECT current_setting('app.tenant_id', true) as value
783
+ `.execute(ctx.db);
784
+
785
+ return {
786
+ userId: userIdResult.rows[0]?.value ?? 'not-set',
787
+ tenantId: tenantIdResult.rows[0]?.value ?? 'not-set',
788
+ };
789
+ },
790
+ input: undefined,
791
+ output: outputSchema,
792
+ services: [databaseService],
793
+ logger: mockLogger,
794
+ timeout: undefined,
795
+ memorySize: undefined,
796
+ status: 200,
797
+ getSession: async () => ({
798
+ userId: 'test-user-123',
799
+ tenantId: 'test-tenant-456',
800
+ }),
801
+ authorize: undefined,
802
+ description: undefined,
803
+ databaseService,
804
+ rlsConfig: {
805
+ extractor: async ({ session }) => ({
806
+ user_id: session.userId,
807
+ tenant_id: session.tenantId,
808
+ }),
809
+ prefix: 'app',
810
+ },
811
+ rlsBypass: false,
812
+ });
813
+
814
+ const adapter = new AmazonApiGatewayV2Endpoint(
815
+ envParser,
816
+ endpoint as any,
817
+ );
818
+ const handler = adapter.handler;
819
+
820
+ const event = createMockV2Event();
821
+ const context = createMockContext();
822
+ const response = await handler(event, context);
823
+
824
+ expect(response.statusCode).toBe(200);
825
+
826
+ const body = JSON.parse(response.body!);
827
+ expect(body.userId).toBe('test-user-123');
828
+ expect(body.tenantId).toBe('test-tenant-456');
829
+ });
830
+
831
+ it('should bypass RLS when rlsBypass is true', async () => {
832
+ const databaseService: Service<'database', Kysely<TestDatabase>> = {
833
+ serviceName: 'database' as const,
834
+ register: vi.fn().mockResolvedValue(db),
835
+ };
836
+
837
+ type TestSession = { userId: string };
838
+
839
+ const outputSchema = z.object({ userId: z.string() });
840
+
841
+ const endpoint = new Endpoint({
842
+ route: '/admin/rls-bypass',
843
+ method: 'GET',
844
+ fn: async (ctx) => {
845
+ // Query the session variable - should not be set when bypassed
846
+ const userIdResult = await sql<{ value: string | null }>`
847
+ SELECT current_setting('app.user_id', true) as value
848
+ `.execute(ctx.db);
849
+
850
+ // current_setting returns empty string when not set
851
+ return {
852
+ userId: userIdResult.rows[0]?.value || 'not-set',
853
+ };
854
+ },
855
+ input: undefined,
856
+ output: outputSchema,
857
+ services: [databaseService],
858
+ logger: mockLogger,
859
+ timeout: undefined,
860
+ memorySize: undefined,
861
+ status: 200,
862
+ getSession: async () => ({ userId: 'admin-user' }),
863
+ authorize: undefined,
864
+ description: undefined,
865
+ databaseService,
866
+ rlsConfig: {
867
+ extractor: async ({ session }) => ({
868
+ user_id: session.userId,
869
+ }),
870
+ prefix: 'app',
871
+ },
872
+ rlsBypass: true, // Bypass RLS
873
+ });
874
+
875
+ const adapter = new AmazonApiGatewayV2Endpoint(
876
+ envParser,
877
+ endpoint as any,
878
+ );
879
+ const handler = adapter.handler;
880
+
881
+ const event = createMockV2Event();
882
+ const context = createMockContext();
883
+ const response = await handler(event, context);
884
+
885
+ expect(response.statusCode).toBe(200);
886
+
887
+ const body = JSON.parse(response.body!);
888
+ // When bypassed, the RLS context should not be set (returns 'not-set')
889
+ expect(body.userId).toBe('not-set');
890
+ });
891
+
892
+ it('should use custom prefix for RLS context variables', async () => {
893
+ const databaseService: Service<'database', Kysely<TestDatabase>> = {
894
+ serviceName: 'database' as const,
895
+ register: vi.fn().mockResolvedValue(db),
896
+ };
897
+
898
+ type TestSession = { userId: string };
899
+
900
+ const outputSchema = z.object({ userId: z.string() });
901
+
902
+ const endpoint = new Endpoint({
903
+ route: '/custom-prefix',
904
+ method: 'GET',
905
+ fn: async (ctx) => {
906
+ // Query the session variable with custom prefix
907
+ const userIdResult = await sql<{ value: string }>`
908
+ SELECT current_setting('myapp.user_id', true) as value
909
+ `.execute(ctx.db);
910
+
911
+ return {
912
+ userId: userIdResult.rows[0]?.value ?? 'not-set',
913
+ };
914
+ },
915
+ input: undefined,
916
+ output: outputSchema,
917
+ services: [databaseService],
918
+ logger: mockLogger,
919
+ timeout: undefined,
920
+ memorySize: undefined,
921
+ status: 200,
922
+ getSession: async () => ({ userId: 'custom-user' }),
923
+ authorize: undefined,
924
+ description: undefined,
925
+ databaseService,
926
+ rlsConfig: {
927
+ extractor: async ({ session }) => ({
928
+ user_id: session.userId,
929
+ }),
930
+ prefix: 'myapp', // Custom prefix
931
+ },
932
+ rlsBypass: false,
933
+ });
934
+
935
+ const adapter = new AmazonApiGatewayV2Endpoint(
936
+ envParser,
937
+ endpoint as any,
938
+ );
939
+ const handler = adapter.handler;
940
+
941
+ const event = createMockV2Event();
942
+ const context = createMockContext();
943
+ const response = await handler(event, context);
944
+
945
+ expect(response.statusCode).toBe(200);
946
+
947
+ const body = JSON.parse(response.body!);
948
+ expect(body.userId).toBe('custom-user');
949
+ });
950
+ });
757
951
  });