@geekmidas/constructs 0.3.2 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (550) hide show
  1. package/dist/{AWSLambdaFunction-EPGY4s7i.cjs → AWSLambdaFunction-Ba1DcsW2.cjs} +6 -6
  2. package/dist/AWSLambdaFunction-Ba1DcsW2.cjs.map +1 -0
  3. package/dist/{AWSLambdaFunction-BdebRMUh.d.mts → AWSLambdaFunction-CKe73Qr0.d.cts} +6 -6
  4. package/dist/AWSLambdaFunction-CKe73Qr0.d.cts.map +1 -0
  5. package/dist/{AWSLambdaFunction-D0tEOTXQ.d.cts → AWSLambdaFunction-CuG3HNZx.d.mts} +6 -6
  6. package/dist/AWSLambdaFunction-CuG3HNZx.d.mts.map +1 -0
  7. package/dist/{AWSLambdaFunction-C54a1doJ.mjs → AWSLambdaFunction-DnMm4xvz.mjs} +6 -6
  8. package/dist/AWSLambdaFunction-DnMm4xvz.mjs.map +1 -0
  9. package/dist/{AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts → AWSLambdaSubscriberAdaptor-B4HH-WuQ.d.mts} +4 -4
  10. package/dist/AWSLambdaSubscriberAdaptor-B4HH-WuQ.d.mts.map +1 -0
  11. package/dist/{AWSLambdaSubscriberAdaptor-BLfO612H.mjs → AWSLambdaSubscriberAdaptor-BD3FwGUb.mjs} +3 -3
  12. package/dist/AWSLambdaSubscriberAdaptor-BD3FwGUb.mjs.map +1 -0
  13. package/dist/{AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts → AWSLambdaSubscriberAdaptor-BEqQ96VJ.d.cts} +4 -4
  14. package/dist/AWSLambdaSubscriberAdaptor-BEqQ96VJ.d.cts.map +1 -0
  15. package/dist/{AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs → AWSLambdaSubscriberAdaptor-DQDnt1Xk.cjs} +3 -3
  16. package/dist/AWSLambdaSubscriberAdaptor-DQDnt1Xk.cjs.map +1 -0
  17. package/dist/{AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs → AmazonApiGatewayEndpointAdaptor-Bvy-Hgjf.mjs} +56 -14
  18. package/dist/AmazonApiGatewayEndpointAdaptor-Bvy-Hgjf.mjs.map +1 -0
  19. package/dist/{AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs → AmazonApiGatewayEndpointAdaptor-Cpxluhfg.cjs} +55 -13
  20. package/dist/AmazonApiGatewayEndpointAdaptor-Cpxluhfg.cjs.map +1 -0
  21. package/dist/{AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts → AmazonApiGatewayEndpointAdaptor-DTgdZ8I1.d.mts} +52 -6
  22. package/dist/AmazonApiGatewayEndpointAdaptor-DTgdZ8I1.d.mts.map +1 -0
  23. package/dist/{AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts → AmazonApiGatewayEndpointAdaptor-DsWnO6x9.d.cts} +51 -5
  24. package/dist/AmazonApiGatewayEndpointAdaptor-DsWnO6x9.d.cts.map +1 -0
  25. package/dist/{AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts → AmazonApiGatewayV1EndpointAdaptor-7ELXUBFK.d.cts} +4 -4
  26. package/dist/AmazonApiGatewayV1EndpointAdaptor-7ELXUBFK.d.cts.map +1 -0
  27. package/dist/{AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs → AmazonApiGatewayV1EndpointAdaptor-B8vIYYNh.cjs} +4 -4
  28. package/dist/AmazonApiGatewayV1EndpointAdaptor-B8vIYYNh.cjs.map +1 -0
  29. package/dist/{AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs → AmazonApiGatewayV1EndpointAdaptor-ByXGIju8.mjs} +4 -4
  30. package/dist/AmazonApiGatewayV1EndpointAdaptor-ByXGIju8.mjs.map +1 -0
  31. package/dist/{AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts → AmazonApiGatewayV1EndpointAdaptor-RWRmFPrN.d.mts} +5 -5
  32. package/dist/AmazonApiGatewayV1EndpointAdaptor-RWRmFPrN.d.mts.map +1 -0
  33. package/dist/{AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs → AmazonApiGatewayV2EndpointAdaptor-DIetspUm.cjs} +4 -4
  34. package/dist/AmazonApiGatewayV2EndpointAdaptor-DIetspUm.cjs.map +1 -0
  35. package/dist/{AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs → AmazonApiGatewayV2EndpointAdaptor-DWemCZvl.mjs} +4 -4
  36. package/dist/AmazonApiGatewayV2EndpointAdaptor-DWemCZvl.mjs.map +1 -0
  37. package/dist/{AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts → AmazonApiGatewayV2EndpointAdaptor-D_uMTmuJ.d.cts} +4 -6
  38. package/dist/AmazonApiGatewayV2EndpointAdaptor-D_uMTmuJ.d.cts.map +1 -0
  39. package/dist/{AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts → AmazonApiGatewayV2EndpointAdaptor-wnOMDv6o.d.mts} +5 -7
  40. package/dist/AmazonApiGatewayV2EndpointAdaptor-wnOMDv6o.d.mts.map +1 -0
  41. package/dist/{Authorizer-C0ge_tc8.cjs → Authorizer-BXxBee2P.cjs} +1 -1
  42. package/dist/Authorizer-BXxBee2P.cjs.map +1 -0
  43. package/dist/{Authorizer-r9U3y_ms.mjs → Authorizer-BgjU8-z6.mjs} +1 -1
  44. package/dist/Authorizer-BgjU8-z6.mjs.map +1 -0
  45. package/dist/{Authorizer-gWxYsGEp.d.mts → Authorizer-DCcYOx3h.d.mts} +1 -1
  46. package/dist/Authorizer-DCcYOx3h.d.mts.map +1 -0
  47. package/dist/{Authorizer-B-btowNd.d.cts → Authorizer-DWtwC8we.d.cts} +1 -1
  48. package/dist/Authorizer-DWtwC8we.d.cts.map +1 -0
  49. package/dist/{BaseFunctionBuilder-Czi1Jwza.mjs → BaseFunctionBuilder-0qlenb9z.mjs} +2 -2
  50. package/dist/BaseFunctionBuilder-0qlenb9z.mjs.map +1 -0
  51. package/dist/BaseFunctionBuilder-BAtutR6q.d.cts.map +1 -1
  52. package/dist/{BaseFunctionBuilder-DRY419e7.d.mts → BaseFunctionBuilder-CDfDWWAQ.d.mts} +2 -2
  53. package/dist/BaseFunctionBuilder-CDfDWWAQ.d.mts.map +1 -0
  54. package/dist/{BaseFunctionBuilder-MYG3C9ug.cjs → BaseFunctionBuilder-D7o93EGv.cjs} +2 -2
  55. package/dist/BaseFunctionBuilder-D7o93EGv.cjs.map +1 -0
  56. package/dist/{Construct-Ba5cMxib.cjs → Construct-BlnyYtJC.cjs} +31 -2
  57. package/dist/Construct-BlnyYtJC.cjs.map +1 -0
  58. package/dist/Construct-C4rPE67v.d.cts.map +1 -1
  59. package/dist/{Construct-DdyGHuag.mjs → Construct-D5dCvxZ3.mjs} +31 -2
  60. package/dist/Construct-D5dCvxZ3.mjs.map +1 -0
  61. package/dist/{Construct-XrijZFFh.d.mts → Construct-dZiwVo0q.d.mts} +1 -1
  62. package/dist/Construct-dZiwVo0q.d.mts.map +1 -0
  63. package/dist/Construct.cjs +1 -1
  64. package/dist/Construct.d.mts +1 -1
  65. package/dist/Construct.mjs +1 -1
  66. package/dist/{Cron-bDLcTvV5.d.cts → Cron-B6FnTu7k.d.cts} +2 -2
  67. package/dist/Cron-B6FnTu7k.d.cts.map +1 -0
  68. package/dist/{Cron-CGF4YAfM.cjs → Cron-BAPQetlC.cjs} +3 -3
  69. package/dist/Cron-BAPQetlC.cjs.map +1 -0
  70. package/dist/{Cron-BxhGs5up.mjs → Cron-CAk_ddH8.mjs} +3 -3
  71. package/dist/Cron-CAk_ddH8.mjs.map +1 -0
  72. package/dist/{Cron-cdjlSKNp.d.mts → Cron-D3bEljxQ.d.mts} +2 -2
  73. package/dist/Cron-D3bEljxQ.d.mts.map +1 -0
  74. package/dist/{CronBuilder-DKVXyE0Q.d.cts → CronBuilder-CA8euP0z.d.cts} +4 -4
  75. package/dist/CronBuilder-CA8euP0z.d.cts.map +1 -0
  76. package/dist/{CronBuilder-BC4m5-p1.d.mts → CronBuilder-DvdiKzhq.d.mts} +4 -4
  77. package/dist/CronBuilder-DvdiKzhq.d.mts.map +1 -0
  78. package/dist/{CronBuilder-CcxKRtVP.cjs → CronBuilder-DxXA5ymv.cjs} +4 -4
  79. package/dist/CronBuilder-DxXA5ymv.cjs.map +1 -0
  80. package/dist/{CronBuilder-d2jh-IB2.mjs → CronBuilder-e8TaHPYm.mjs} +4 -4
  81. package/dist/CronBuilder-e8TaHPYm.mjs.map +1 -0
  82. package/dist/{Endpoint-BPv9_-m_.d.cts → Endpoint-BOlbY5iq.d.cts} +3 -3
  83. package/dist/Endpoint-BOlbY5iq.d.cts.map +1 -0
  84. package/dist/{Endpoint-CuOEswxJ.mjs → Endpoint-BbdNmtlM.mjs} +6 -6
  85. package/dist/Endpoint-BbdNmtlM.mjs.map +1 -0
  86. package/dist/{Endpoint-BdwG75G_.d.mts → Endpoint-Dlv7nxgj.d.mts} +4 -4
  87. package/dist/Endpoint-Dlv7nxgj.d.mts.map +1 -0
  88. package/dist/{Endpoint-BVGZXFyV.cjs → Endpoint-DxvnlfXg.cjs} +6 -6
  89. package/dist/Endpoint-DxvnlfXg.cjs.map +1 -0
  90. package/dist/{EndpointBuilder-Cgj1P_ra.cjs → EndpointBuilder-40Iz5CjY.cjs} +6 -6
  91. package/dist/EndpointBuilder-40Iz5CjY.cjs.map +1 -0
  92. package/dist/{EndpointBuilder-DnCB1h1j.mjs → EndpointBuilder-BaVvhW9m.mjs} +6 -6
  93. package/dist/EndpointBuilder-BaVvhW9m.mjs.map +1 -0
  94. package/dist/{EndpointBuilder-DIy_m1bu.d.cts → EndpointBuilder-CFfWWjUa.d.cts} +3 -3
  95. package/dist/EndpointBuilder-CFfWWjUa.d.cts.map +1 -0
  96. package/dist/{EndpointBuilder-B3az942t.d.mts → EndpointBuilder-T_K2NLWw.d.mts} +5 -5
  97. package/dist/EndpointBuilder-T_K2NLWw.d.mts.map +1 -0
  98. package/dist/{EndpointFactory-CyPbm3AD.d.cts → EndpointFactory-ChzBVEM9.d.cts} +4 -4
  99. package/dist/EndpointFactory-ChzBVEM9.d.cts.map +1 -0
  100. package/dist/{EndpointFactory-CbdxPCIH.mjs → EndpointFactory-DfNjSgVG.mjs} +7 -7
  101. package/dist/EndpointFactory-DfNjSgVG.mjs.map +1 -0
  102. package/dist/{EndpointFactory-C-0nE6Jg.d.mts → EndpointFactory-GAL_tuPf.d.mts} +4 -4
  103. package/dist/EndpointFactory-GAL_tuPf.d.mts.map +1 -0
  104. package/dist/{EndpointFactory-CYj6BYok.cjs → EndpointFactory-r6jxPvQ8.cjs} +7 -7
  105. package/dist/EndpointFactory-r6jxPvQ8.cjs.map +1 -0
  106. package/dist/{Function-BVHqIDp9.mjs → Function-D8tBamM3.mjs} +3 -3
  107. package/dist/Function-D8tBamM3.mjs.map +1 -0
  108. package/dist/{Function-DN2G6OT5.d.mts → Function-DBmU3uGI.d.mts} +3 -3
  109. package/dist/Function-DBmU3uGI.d.mts.map +1 -0
  110. package/dist/{Function-Cf7f_kCz.d.cts → Function-PNW4HdNE.d.cts} +2 -2
  111. package/dist/Function-PNW4HdNE.d.cts.map +1 -0
  112. package/dist/{Function-DDZb1525.cjs → Function-iLKrUXuw.cjs} +3 -3
  113. package/dist/Function-iLKrUXuw.cjs.map +1 -0
  114. package/dist/{FunctionBuilder-DswJ-9sD.cjs → FunctionBuilder-BEpPgeho.cjs} +4 -4
  115. package/dist/FunctionBuilder-BEpPgeho.cjs.map +1 -0
  116. package/dist/{FunctionBuilder-Cxx8D2na.d.mts → FunctionBuilder-Bv4H2I1a.d.mts} +4 -4
  117. package/dist/FunctionBuilder-Bv4H2I1a.d.mts.map +1 -0
  118. package/dist/{FunctionBuilder-CrDYgfiI.mjs → FunctionBuilder-BwNF99AB.mjs} +4 -4
  119. package/dist/FunctionBuilder-BwNF99AB.mjs.map +1 -0
  120. package/dist/{FunctionBuilder-CJBzzXL3.d.cts → FunctionBuilder-DCqXIHaq.d.cts} +2 -2
  121. package/dist/FunctionBuilder-DCqXIHaq.d.cts.map +1 -0
  122. package/dist/{FunctionExecutionWrapper-CLDh7Z2_.mjs → FunctionExecutionWrapper-B__HE_B-.mjs} +3 -3
  123. package/dist/FunctionExecutionWrapper-B__HE_B-.mjs.map +1 -0
  124. package/dist/{FunctionExecutionWrapper-DF260Aaj.d.mts → FunctionExecutionWrapper-BclgIztn.d.cts} +5 -5
  125. package/dist/FunctionExecutionWrapper-BclgIztn.d.cts.map +1 -0
  126. package/dist/{FunctionExecutionWrapper-BYI2bGTL.cjs → FunctionExecutionWrapper-BjF6t9Hb.cjs} +3 -3
  127. package/dist/FunctionExecutionWrapper-BjF6t9Hb.cjs.map +1 -0
  128. package/dist/{FunctionExecutionWrapper-Qy8bmgFR.d.cts → FunctionExecutionWrapper-Dq21c6vt.d.mts} +5 -5
  129. package/dist/FunctionExecutionWrapper-Dq21c6vt.d.mts.map +1 -0
  130. package/dist/HonoEndpointAdaptor-C_ym_Sbr.mjs +251 -0
  131. package/dist/HonoEndpointAdaptor-C_ym_Sbr.mjs.map +1 -0
  132. package/dist/HonoEndpointAdaptor-DiQH0eTb.cjs +257 -0
  133. package/dist/HonoEndpointAdaptor-DiQH0eTb.cjs.map +1 -0
  134. package/dist/{HonoEndpointAdaptor-YcRHYALH.d.cts → HonoEndpointAdaptor-Dkkemmbo.d.cts} +10 -5
  135. package/dist/HonoEndpointAdaptor-Dkkemmbo.d.cts.map +1 -0
  136. package/dist/{HonoEndpointAdaptor-BaPlUhz0.d.mts → HonoEndpointAdaptor-HukjdF6M.d.mts} +11 -6
  137. package/dist/HonoEndpointAdaptor-HukjdF6M.d.mts.map +1 -0
  138. package/dist/{Subscriber-COYMSevD.d.cts → Subscriber--zUjZDR6.d.cts} +1 -1
  139. package/dist/Subscriber--zUjZDR6.d.cts.map +1 -0
  140. package/dist/{Subscriber-ikctpU3I.d.mts → Subscriber-0Ac7cXID.d.mts} +2 -2
  141. package/dist/Subscriber-0Ac7cXID.d.mts.map +1 -0
  142. package/dist/{Subscriber-BmPf9GFb.mjs → Subscriber-BgZ8T-O2.mjs} +2 -2
  143. package/dist/Subscriber-BgZ8T-O2.mjs.map +1 -0
  144. package/dist/{Subscriber-BiHjVXtM.cjs → Subscriber-CoFmHMIM.cjs} +2 -2
  145. package/dist/Subscriber-CoFmHMIM.cjs.map +1 -0
  146. package/dist/{SubscriberBuilder-D_9zzllj.d.mts → SubscriberBuilder-D8cmUHee.d.mts} +2 -2
  147. package/dist/SubscriberBuilder-D8cmUHee.d.mts.map +1 -0
  148. package/dist/{SubscriberBuilder-DJPEeYDJ.mjs → SubscriberBuilder-DWXWZBPo.mjs} +2 -2
  149. package/dist/SubscriberBuilder-DWXWZBPo.mjs.map +1 -0
  150. package/dist/{SubscriberBuilder-ivHAGIVi.d.cts → SubscriberBuilder-DciTqb-7.d.cts} +2 -2
  151. package/dist/SubscriberBuilder-DciTqb-7.d.cts.map +1 -0
  152. package/dist/{SubscriberBuilder-Cp1C-xtT.cjs → SubscriberBuilder-JlxhyqGp.cjs} +2 -2
  153. package/dist/SubscriberBuilder-JlxhyqGp.cjs.map +1 -0
  154. package/dist/{TestEndpointAdaptor-DB7bREhS.d.mts → TestEndpointAdaptor-Boijwbmz.d.mts} +4 -4
  155. package/dist/TestEndpointAdaptor-Boijwbmz.d.mts.map +1 -0
  156. package/dist/{TestEndpointAdaptor-C10xBI--.d.cts → TestEndpointAdaptor-DdwpRyNh.d.cts} +3 -3
  157. package/dist/TestEndpointAdaptor-DdwpRyNh.d.cts.map +1 -0
  158. package/dist/TestEndpointAdaptor-Dk75ExxE.cjs +176 -0
  159. package/dist/TestEndpointAdaptor-Dk75ExxE.cjs.map +1 -0
  160. package/dist/TestEndpointAdaptor-OiA2JLDp.mjs +170 -0
  161. package/dist/TestEndpointAdaptor-OiA2JLDp.mjs.map +1 -0
  162. package/dist/adaptors/aws.cjs +12 -12
  163. package/dist/adaptors/aws.d.cts +13 -12
  164. package/dist/adaptors/aws.d.mts +16 -15
  165. package/dist/adaptors/aws.mjs +12 -12
  166. package/dist/adaptors/hono.cjs +10 -9
  167. package/dist/adaptors/hono.d.cts +6 -6
  168. package/dist/adaptors/hono.d.mts +9 -9
  169. package/dist/adaptors/hono.mjs +10 -9
  170. package/dist/adaptors/testing.cjs +8 -7
  171. package/dist/adaptors/testing.d.cts +6 -6
  172. package/dist/adaptors/testing.d.mts +9 -9
  173. package/dist/adaptors/testing.mjs +8 -7
  174. package/dist/crons/Cron.cjs +6 -6
  175. package/dist/crons/Cron.d.cts +4 -4
  176. package/dist/crons/Cron.d.mts +6 -6
  177. package/dist/crons/Cron.mjs +6 -6
  178. package/dist/crons/CronBuilder.cjs +7 -7
  179. package/dist/crons/CronBuilder.d.cts +5 -5
  180. package/dist/crons/CronBuilder.d.mts +7 -7
  181. package/dist/crons/CronBuilder.mjs +7 -7
  182. package/dist/crons/index.cjs +7 -7
  183. package/dist/crons/index.cjs.map +1 -1
  184. package/dist/crons/index.d.cts +9 -9
  185. package/dist/crons/index.d.mts +7 -7
  186. package/dist/crons/index.mjs +7 -7
  187. package/dist/crons/index.mjs.map +1 -1
  188. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +7 -7
  189. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +8 -7
  190. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +11 -10
  191. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +7 -7
  192. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +8 -8
  193. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +8 -7
  194. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +11 -10
  195. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +8 -8
  196. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +8 -8
  197. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +9 -8
  198. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +12 -11
  199. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +8 -8
  200. package/dist/endpoints/Authorizer.cjs +1 -1
  201. package/dist/endpoints/Authorizer.d.cts +1 -1
  202. package/dist/endpoints/Authorizer.d.mts +1 -1
  203. package/dist/endpoints/Authorizer.mjs +1 -1
  204. package/dist/endpoints/Endpoint.cjs +6 -6
  205. package/dist/endpoints/Endpoint.d.cts +5 -5
  206. package/dist/endpoints/Endpoint.d.mts +8 -8
  207. package/dist/endpoints/Endpoint.mjs +6 -6
  208. package/dist/endpoints/EndpointBuilder.cjs +9 -9
  209. package/dist/endpoints/EndpointBuilder.d.cts +6 -6
  210. package/dist/endpoints/EndpointBuilder.d.mts +9 -9
  211. package/dist/endpoints/EndpointBuilder.mjs +9 -9
  212. package/dist/endpoints/EndpointFactory.cjs +10 -10
  213. package/dist/endpoints/EndpointFactory.d.cts +7 -7
  214. package/dist/endpoints/EndpointFactory.d.mts +10 -10
  215. package/dist/endpoints/EndpointFactory.mjs +10 -10
  216. package/dist/endpoints/HonoEndpointAdaptor.cjs +10 -9
  217. package/dist/endpoints/HonoEndpointAdaptor.d.cts +6 -6
  218. package/dist/endpoints/HonoEndpointAdaptor.d.mts +9 -9
  219. package/dist/endpoints/HonoEndpointAdaptor.mjs +10 -9
  220. package/dist/endpoints/TestEndpointAdaptor.cjs +8 -7
  221. package/dist/endpoints/TestEndpointAdaptor.d.cts +6 -6
  222. package/dist/endpoints/TestEndpointAdaptor.d.mts +9 -9
  223. package/dist/endpoints/TestEndpointAdaptor.mjs +8 -7
  224. package/dist/endpoints/audit.d.cts +5 -5
  225. package/dist/endpoints/audit.d.mts +8 -8
  226. package/dist/endpoints/helpers.cjs +7 -7
  227. package/dist/endpoints/helpers.d.cts +5 -5
  228. package/dist/endpoints/helpers.d.cts.map +1 -1
  229. package/dist/endpoints/helpers.d.mts +8 -8
  230. package/dist/endpoints/helpers.d.mts.map +1 -1
  231. package/dist/endpoints/helpers.mjs +7 -7
  232. package/dist/endpoints/index.cjs +20 -10
  233. package/dist/endpoints/index.cjs.map +1 -1
  234. package/dist/endpoints/index.d.cts +12 -10
  235. package/dist/endpoints/index.d.cts.map +1 -1
  236. package/dist/endpoints/index.d.mts +15 -13
  237. package/dist/endpoints/index.d.mts.map +1 -1
  238. package/dist/endpoints/index.mjs +13 -11
  239. package/dist/endpoints/index.mjs.map +1 -1
  240. package/dist/endpoints/lazyAccessors.cjs +10 -0
  241. package/dist/endpoints/lazyAccessors.d.cts +10 -0
  242. package/dist/endpoints/lazyAccessors.d.mts +10 -0
  243. package/dist/endpoints/lazyAccessors.mjs +3 -0
  244. package/dist/endpoints/parseHonoQuery.cjs +1 -1
  245. package/dist/endpoints/parseHonoQuery.mjs +1 -1
  246. package/dist/endpoints/parseQueryParams.d.cts.map +1 -1
  247. package/dist/endpoints/parseQueryParams.d.mts.map +1 -1
  248. package/dist/endpoints/processAudits.d.cts +5 -5
  249. package/dist/endpoints/processAudits.d.cts.map +1 -1
  250. package/dist/endpoints/processAudits.d.mts +8 -8
  251. package/dist/endpoints/processAudits.d.mts.map +1 -1
  252. package/dist/endpoints/rls.cjs +1 -1
  253. package/dist/endpoints/rls.d.cts +5 -5
  254. package/dist/endpoints/rls.d.mts +8 -8
  255. package/dist/endpoints/rls.mjs +1 -1
  256. package/dist/functions/AWSLambdaFunction.cjs +6 -6
  257. package/dist/functions/AWSLambdaFunction.d.cts +3 -3
  258. package/dist/functions/AWSLambdaFunction.d.mts +4 -4
  259. package/dist/functions/AWSLambdaFunction.mjs +6 -6
  260. package/dist/functions/BaseFunctionBuilder.cjs +2 -2
  261. package/dist/functions/BaseFunctionBuilder.d.mts +2 -2
  262. package/dist/functions/BaseFunctionBuilder.mjs +2 -2
  263. package/dist/functions/Function.cjs +2 -2
  264. package/dist/functions/Function.d.cts +1 -1
  265. package/dist/functions/Function.d.mts +2 -2
  266. package/dist/functions/Function.mjs +2 -2
  267. package/dist/functions/FunctionBuilder.cjs +4 -4
  268. package/dist/functions/FunctionBuilder.d.cts +2 -2
  269. package/dist/functions/FunctionBuilder.d.mts +4 -4
  270. package/dist/functions/FunctionBuilder.mjs +4 -4
  271. package/dist/functions/FunctionExecutionWrapper.cjs +5 -5
  272. package/dist/functions/FunctionExecutionWrapper.d.cts +2 -2
  273. package/dist/functions/FunctionExecutionWrapper.d.mts +3 -3
  274. package/dist/functions/FunctionExecutionWrapper.mjs +5 -5
  275. package/dist/functions/TestFunctionAdaptor.cjs +7 -7
  276. package/dist/functions/TestFunctionAdaptor.cjs.map +1 -1
  277. package/dist/functions/TestFunctionAdaptor.d.cts +2 -2
  278. package/dist/functions/TestFunctionAdaptor.d.cts.map +1 -1
  279. package/dist/functions/TestFunctionAdaptor.d.mts +3 -3
  280. package/dist/functions/TestFunctionAdaptor.d.mts.map +1 -1
  281. package/dist/functions/TestFunctionAdaptor.mjs +7 -7
  282. package/dist/functions/TestFunctionAdaptor.mjs.map +1 -1
  283. package/dist/functions/index.cjs +5 -5
  284. package/dist/functions/index.d.cts +3 -3
  285. package/dist/functions/index.d.mts +5 -5
  286. package/dist/functions/index.mjs +5 -5
  287. package/dist/{functions-fTid0RMK.cjs → functions-BkKXVeHm.cjs} +2 -2
  288. package/dist/functions-BkKXVeHm.cjs.map +1 -0
  289. package/dist/functions-C3A1vMRW.mjs +8 -0
  290. package/dist/functions-C3A1vMRW.mjs.map +1 -0
  291. package/dist/{helpers-BcP1tXAi.cjs → helpers-BelEzV4U.cjs} +2 -2
  292. package/dist/helpers-BelEzV4U.cjs.map +1 -0
  293. package/dist/{helpers-ByRTDO_m.mjs → helpers-DgsMFMUV.mjs} +2 -2
  294. package/dist/helpers-DgsMFMUV.mjs.map +1 -0
  295. package/dist/{index-BWzGIj06.d.mts → index-CgAQHr3f.d.mts} +2 -2
  296. package/dist/index-CgAQHr3f.d.mts.map +1 -0
  297. package/dist/index-D0fp_IK1.d.cts +12 -0
  298. package/dist/index-D0fp_IK1.d.cts.map +1 -0
  299. package/dist/index.cjs +1 -1
  300. package/dist/index.d.cts +2 -1
  301. package/dist/index.d.mts +4 -3
  302. package/dist/index.mjs +1 -1
  303. package/dist/lazyAccessors-B-Jgkg2o.mjs +175 -0
  304. package/dist/lazyAccessors-B-Jgkg2o.mjs.map +1 -0
  305. package/dist/lazyAccessors-B2ILzU-j.d.mts +49 -0
  306. package/dist/lazyAccessors-B2ILzU-j.d.mts.map +1 -0
  307. package/dist/lazyAccessors-B8Hhras9.cjs +223 -0
  308. package/dist/lazyAccessors-B8Hhras9.cjs.map +1 -0
  309. package/dist/lazyAccessors-Bcpi06ed.d.cts +49 -0
  310. package/dist/lazyAccessors-Bcpi06ed.d.cts.map +1 -0
  311. package/dist/{parseHonoQuery-CZC5_97v.cjs → parseHonoQuery-D4MhxTRc.cjs} +1 -1
  312. package/dist/parseHonoQuery-D4MhxTRc.cjs.map +1 -0
  313. package/dist/{parseHonoQuery-DDgIkTO4.mjs → parseHonoQuery-DpK3sGPc.mjs} +1 -1
  314. package/dist/parseHonoQuery-DpK3sGPc.mjs.map +1 -0
  315. package/dist/parseQueryParams-BSNkjmZ9.cjs.map +1 -1
  316. package/dist/parseQueryParams-UMTRnRrW.mjs.map +1 -1
  317. package/dist/processAudits-CzHkPokQ.cjs.map +1 -1
  318. package/dist/processAudits-Dj8UGqcW.mjs.map +1 -1
  319. package/dist/publisher-Bw4770Hi.mjs.map +1 -1
  320. package/dist/publisher-C4BhHB5I.d.cts +16 -0
  321. package/dist/publisher-C4BhHB5I.d.cts.map +1 -0
  322. package/dist/publisher-NE-GnXL8.d.mts +16 -0
  323. package/dist/publisher-NE-GnXL8.d.mts.map +1 -0
  324. package/dist/publisher-lFQleddL.cjs.map +1 -1
  325. package/dist/publisher.d.cts +3 -16
  326. package/dist/publisher.d.mts +3 -16
  327. package/dist/{rls-CmJ7bRsz.cjs → rls-BrywnrQb.cjs} +1 -1
  328. package/dist/{rls-CmJ7bRsz.cjs.map → rls-BrywnrQb.cjs.map} +1 -1
  329. package/dist/{rls-Bf3FRwto.mjs → rls-C0cWOnk4.mjs} +1 -1
  330. package/dist/{rls-Bf3FRwto.mjs.map → rls-C0cWOnk4.mjs.map} +1 -1
  331. package/dist/subscribers/AWSLambdaSubscriberAdaptor.cjs +1 -1
  332. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +2 -2
  333. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +3 -3
  334. package/dist/subscribers/AWSLambdaSubscriberAdaptor.mjs +1 -1
  335. package/dist/subscribers/Subscriber.cjs +2 -2
  336. package/dist/subscribers/Subscriber.d.cts +1 -1
  337. package/dist/subscribers/Subscriber.d.mts +2 -2
  338. package/dist/subscribers/Subscriber.mjs +2 -2
  339. package/dist/subscribers/SubscriberBuilder.cjs +3 -3
  340. package/dist/subscribers/SubscriberBuilder.d.cts +2 -2
  341. package/dist/subscribers/SubscriberBuilder.d.mts +3 -3
  342. package/dist/subscribers/SubscriberBuilder.mjs +3 -3
  343. package/dist/subscribers/index.cjs +3 -3
  344. package/dist/subscribers/index.cjs.map +1 -1
  345. package/dist/subscribers/index.d.cts +4 -4
  346. package/dist/subscribers/index.d.cts.map +1 -1
  347. package/dist/subscribers/index.d.mts +3 -3
  348. package/dist/subscribers/index.d.mts.map +1 -1
  349. package/dist/subscribers/index.mjs +3 -3
  350. package/dist/subscribers/index.mjs.map +1 -1
  351. package/dist/telemetry-BTaiRqPo.d.cts +95 -0
  352. package/dist/telemetry-BTaiRqPo.d.cts.map +1 -0
  353. package/dist/telemetry-yAHf5yDs.d.mts +95 -0
  354. package/dist/telemetry-yAHf5yDs.d.mts.map +1 -0
  355. package/dist/telemetry.cjs +0 -0
  356. package/dist/telemetry.d.cts +2 -0
  357. package/dist/telemetry.d.mts +2 -0
  358. package/dist/telemetry.mjs +0 -0
  359. package/dist/types-B5H3piDg.d.cts.map +1 -1
  360. package/dist/{types-DdIlpxAd.d.mts → types-Dw-iLd3Y.d.mts} +1 -1
  361. package/dist/types-Dw-iLd3Y.d.mts.map +1 -0
  362. package/dist/types.d.mts +1 -1
  363. package/package.json +18 -18
  364. package/src/Construct.ts +117 -86
  365. package/src/__benchmarks__/build-time-optimization.bench.ts +274 -0
  366. package/src/__benchmarks__/endpoint.bench.ts +375 -375
  367. package/src/__benchmarks__/fixtures.ts +241 -0
  368. package/src/__benchmarks__/hono-adaptor.bench.ts +533 -0
  369. package/src/__benchmarks__/hono-server.bench.ts +206 -206
  370. package/src/__benchmarks__/response-builder.bench.ts +428 -0
  371. package/src/__benchmarks__/strategies/strategy-a-lazy-services.ts +319 -0
  372. package/src/__benchmarks__/strategies/strategy-c-middleware.ts +530 -0
  373. package/src/__benchmarks__/strategies/strategy-d-opt-in-events.ts +567 -0
  374. package/src/__tests__/Construct.environment.spec.ts +349 -350
  375. package/src/__tests__/publisher.setting.spec.ts +496 -499
  376. package/src/__tests__/publisher.spec.ts +440 -442
  377. package/src/crons/Cron.ts +117 -117
  378. package/src/crons/CronBuilder.ts +237 -238
  379. package/src/crons/__tests__/Cron.spec.ts +448 -448
  380. package/src/crons/__tests__/CronBuilder.state-isolation.spec.ts +214 -214
  381. package/src/crons/index.ts +4 -4
  382. package/src/endpoints/AmazonApiGatewayEndpointAdaptor.ts +571 -463
  383. package/src/endpoints/AmazonApiGatewayV1EndpointAdaptor.ts +86 -86
  384. package/src/endpoints/AmazonApiGatewayV2EndpointAdaptor.ts +85 -81
  385. package/src/endpoints/Authorizer.ts +100 -100
  386. package/src/endpoints/Endpoint.ts +921 -937
  387. package/src/endpoints/EndpointBuilder.ts +703 -703
  388. package/src/endpoints/EndpointFactory.ts +1054 -1056
  389. package/src/endpoints/HonoEndpointAdaptor.ts +621 -548
  390. package/src/endpoints/TestEndpointAdaptor.ts +372 -353
  391. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.audits.spec.ts +499 -0
  392. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.events.spec.ts +541 -542
  393. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.spec.ts +1172 -1174
  394. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.audits.spec.ts +599 -599
  395. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.events.spec.ts +710 -710
  396. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.factory-publisher.spec.ts +280 -280
  397. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.kysely-audit.integration.spec.ts +924 -730
  398. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.rls.spec.ts +307 -0
  399. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.spec.ts +408 -408
  400. package/src/endpoints/__tests__/Authorizer.spec.ts +286 -0
  401. package/src/endpoints/__tests__/Endpoint.cookies.spec.ts +162 -162
  402. package/src/endpoints/__tests__/Endpoint.headers.spec.ts +182 -182
  403. package/src/endpoints/__tests__/Endpoint.manifest.spec.ts +158 -159
  404. package/src/endpoints/__tests__/Endpoint.spec.ts +819 -822
  405. package/src/endpoints/__tests__/EndpointBuilder.audit.spec.ts +427 -427
  406. package/src/endpoints/__tests__/EndpointBuilder.spec.ts +478 -478
  407. package/src/endpoints/__tests__/EndpointFactory.authorizers.spec.ts +426 -426
  408. package/src/endpoints/__tests__/EndpointFactory.database-auditor.spec.ts +501 -501
  409. package/src/endpoints/__tests__/EndpointFactory.reference-audit.spec.ts +177 -177
  410. package/src/endpoints/__tests__/EndpointFactory.spec.ts +471 -471
  411. package/src/endpoints/__tests__/EndpointFactory.state-isolation.spec.ts +143 -143
  412. package/src/endpoints/__tests__/HonoEndpointAdaptor.audit-transactions.spec.ts +663 -663
  413. package/src/endpoints/__tests__/HonoEndpointAdaptor.audits.spec.ts +608 -608
  414. package/src/endpoints/__tests__/HonoEndpointAdaptor.events.spec.ts +561 -561
  415. package/src/endpoints/__tests__/HonoEndpointAdaptor.kysely-audit.integration.spec.ts +1036 -1036
  416. package/src/endpoints/__tests__/HonoEndpointAdaptor.openapi.spec.ts +278 -278
  417. package/src/endpoints/__tests__/HonoEndpointAdaptor.spec.ts +1093 -1093
  418. package/src/endpoints/__tests__/ResponseBuilder.spec.ts +230 -230
  419. package/src/endpoints/__tests__/TestEndpointAdaptor.audits.spec.ts +569 -569
  420. package/src/endpoints/__tests__/TestEndpointAdaptor.spec.ts +841 -841
  421. package/src/endpoints/__tests__/endpoint-types.test.ts +68 -68
  422. package/src/endpoints/__tests__/helpers.spec.ts +37 -0
  423. package/src/endpoints/__tests__/lazyAccessors.spec.ts +330 -0
  424. package/src/endpoints/__tests__/processAudits.spec.ts +631 -0
  425. package/src/endpoints/audit.ts +51 -51
  426. package/src/endpoints/helpers.ts +34 -35
  427. package/src/endpoints/index.ts +33 -23
  428. package/src/endpoints/lazyAccessors.ts +241 -0
  429. package/src/endpoints/parseHonoQuery.ts +41 -41
  430. package/src/endpoints/parseQueryParams.ts +36 -36
  431. package/src/endpoints/processAudits.ts +269 -269
  432. package/src/endpoints/rls.ts +16 -16
  433. package/src/functions/AWSLambdaFunction.ts +294 -295
  434. package/src/functions/BaseFunctionBuilder.ts +185 -185
  435. package/src/functions/Function.ts +190 -190
  436. package/src/functions/FunctionBuilder.ts +353 -353
  437. package/src/functions/FunctionExecutionWrapper.ts +199 -200
  438. package/src/functions/TestFunctionAdaptor.ts +191 -191
  439. package/src/functions/__tests__/AWSLambdaFunctionAdaptor.spec.ts +424 -424
  440. package/src/functions/__tests__/Function.audits.spec.ts +364 -364
  441. package/src/functions/__tests__/Function.spec.ts +453 -454
  442. package/src/functions/__tests__/FunctionBuilder.state-isolation.spec.ts +179 -179
  443. package/src/functions/__tests__/TestFunctionAdaptor.spec.ts +369 -369
  444. package/src/functions/index.ts +6 -4
  445. package/src/index.ts +13 -9
  446. package/src/publisher.ts +71 -72
  447. package/src/subscribers/AWSLambdaSubscriberAdaptor.ts +244 -248
  448. package/src/subscribers/Subscriber.ts +82 -84
  449. package/src/subscribers/SubscriberBuilder.ts +129 -129
  450. package/src/subscribers/__tests__/AWSLambdaSubscriberAdaptor.spec.ts +589 -589
  451. package/src/subscribers/__tests__/Subscriber.spec.ts +402 -404
  452. package/src/subscribers/index.ts +1 -0
  453. package/src/telemetry.ts +103 -0
  454. package/src/types.ts +7 -7
  455. package/test.ts +58 -59
  456. package/dist/AWSLambdaFunction-BdebRMUh.d.mts.map +0 -1
  457. package/dist/AWSLambdaFunction-C54a1doJ.mjs.map +0 -1
  458. package/dist/AWSLambdaFunction-D0tEOTXQ.d.cts.map +0 -1
  459. package/dist/AWSLambdaFunction-EPGY4s7i.cjs.map +0 -1
  460. package/dist/AWSLambdaSubscriberAdaptor-BLfO612H.mjs.map +0 -1
  461. package/dist/AWSLambdaSubscriberAdaptor-BNcYYZ-P.cjs.map +0 -1
  462. package/dist/AWSLambdaSubscriberAdaptor-DrFAvHOp.d.mts.map +0 -1
  463. package/dist/AWSLambdaSubscriberAdaptor-Dx-Ks1Jp.d.cts.map +0 -1
  464. package/dist/AmazonApiGatewayEndpointAdaptor-BT9JXihC.mjs.map +0 -1
  465. package/dist/AmazonApiGatewayEndpointAdaptor-DLqnYQ4E.d.cts.map +0 -1
  466. package/dist/AmazonApiGatewayEndpointAdaptor-DNFvvdmW.cjs.map +0 -1
  467. package/dist/AmazonApiGatewayEndpointAdaptor-qlKXuZxy.d.mts.map +0 -1
  468. package/dist/AmazonApiGatewayV1EndpointAdaptor-CShQI8Gk.mjs.map +0 -1
  469. package/dist/AmazonApiGatewayV1EndpointAdaptor-Ccl8B8kG.cjs.map +0 -1
  470. package/dist/AmazonApiGatewayV1EndpointAdaptor-DyUaJIhB.d.cts.map +0 -1
  471. package/dist/AmazonApiGatewayV1EndpointAdaptor-MRUxs3Xi.d.mts.map +0 -1
  472. package/dist/AmazonApiGatewayV2EndpointAdaptor-D8-0Aab4.cjs.map +0 -1
  473. package/dist/AmazonApiGatewayV2EndpointAdaptor-M1-w0U5R.d.cts.map +0 -1
  474. package/dist/AmazonApiGatewayV2EndpointAdaptor-fuLM6M9k.d.mts.map +0 -1
  475. package/dist/AmazonApiGatewayV2EndpointAdaptor-lCRzGE4q.mjs.map +0 -1
  476. package/dist/Authorizer-B-btowNd.d.cts.map +0 -1
  477. package/dist/Authorizer-C0ge_tc8.cjs.map +0 -1
  478. package/dist/Authorizer-gWxYsGEp.d.mts.map +0 -1
  479. package/dist/Authorizer-r9U3y_ms.mjs.map +0 -1
  480. package/dist/BaseFunctionBuilder-Czi1Jwza.mjs.map +0 -1
  481. package/dist/BaseFunctionBuilder-DRY419e7.d.mts.map +0 -1
  482. package/dist/BaseFunctionBuilder-MYG3C9ug.cjs.map +0 -1
  483. package/dist/Construct-Ba5cMxib.cjs.map +0 -1
  484. package/dist/Construct-DdyGHuag.mjs.map +0 -1
  485. package/dist/Construct-XrijZFFh.d.mts.map +0 -1
  486. package/dist/Cron-BxhGs5up.mjs.map +0 -1
  487. package/dist/Cron-CGF4YAfM.cjs.map +0 -1
  488. package/dist/Cron-bDLcTvV5.d.cts.map +0 -1
  489. package/dist/Cron-cdjlSKNp.d.mts.map +0 -1
  490. package/dist/CronBuilder-BC4m5-p1.d.mts.map +0 -1
  491. package/dist/CronBuilder-CcxKRtVP.cjs.map +0 -1
  492. package/dist/CronBuilder-DKVXyE0Q.d.cts.map +0 -1
  493. package/dist/CronBuilder-d2jh-IB2.mjs.map +0 -1
  494. package/dist/Endpoint-BPv9_-m_.d.cts.map +0 -1
  495. package/dist/Endpoint-BVGZXFyV.cjs.map +0 -1
  496. package/dist/Endpoint-BdwG75G_.d.mts.map +0 -1
  497. package/dist/Endpoint-CuOEswxJ.mjs.map +0 -1
  498. package/dist/EndpointBuilder-B3az942t.d.mts.map +0 -1
  499. package/dist/EndpointBuilder-Cgj1P_ra.cjs.map +0 -1
  500. package/dist/EndpointBuilder-DIy_m1bu.d.cts.map +0 -1
  501. package/dist/EndpointBuilder-DnCB1h1j.mjs.map +0 -1
  502. package/dist/EndpointFactory-C-0nE6Jg.d.mts.map +0 -1
  503. package/dist/EndpointFactory-CYj6BYok.cjs.map +0 -1
  504. package/dist/EndpointFactory-CbdxPCIH.mjs.map +0 -1
  505. package/dist/EndpointFactory-CyPbm3AD.d.cts.map +0 -1
  506. package/dist/Function-BVHqIDp9.mjs.map +0 -1
  507. package/dist/Function-Cf7f_kCz.d.cts.map +0 -1
  508. package/dist/Function-DDZb1525.cjs.map +0 -1
  509. package/dist/Function-DN2G6OT5.d.mts.map +0 -1
  510. package/dist/FunctionBuilder-CJBzzXL3.d.cts.map +0 -1
  511. package/dist/FunctionBuilder-CrDYgfiI.mjs.map +0 -1
  512. package/dist/FunctionBuilder-Cxx8D2na.d.mts.map +0 -1
  513. package/dist/FunctionBuilder-DswJ-9sD.cjs.map +0 -1
  514. package/dist/FunctionExecutionWrapper-BYI2bGTL.cjs.map +0 -1
  515. package/dist/FunctionExecutionWrapper-CLDh7Z2_.mjs.map +0 -1
  516. package/dist/FunctionExecutionWrapper-DF260Aaj.d.mts.map +0 -1
  517. package/dist/FunctionExecutionWrapper-Qy8bmgFR.d.cts.map +0 -1
  518. package/dist/HonoEndpointAdaptor-BaPlUhz0.d.mts.map +0 -1
  519. package/dist/HonoEndpointAdaptor-CQe2FqMR.cjs +0 -234
  520. package/dist/HonoEndpointAdaptor-CQe2FqMR.cjs.map +0 -1
  521. package/dist/HonoEndpointAdaptor-Ce-2HBxn.mjs +0 -228
  522. package/dist/HonoEndpointAdaptor-Ce-2HBxn.mjs.map +0 -1
  523. package/dist/HonoEndpointAdaptor-YcRHYALH.d.cts.map +0 -1
  524. package/dist/Subscriber-BiHjVXtM.cjs.map +0 -1
  525. package/dist/Subscriber-BmPf9GFb.mjs.map +0 -1
  526. package/dist/Subscriber-COYMSevD.d.cts.map +0 -1
  527. package/dist/Subscriber-ikctpU3I.d.mts.map +0 -1
  528. package/dist/SubscriberBuilder-Cp1C-xtT.cjs.map +0 -1
  529. package/dist/SubscriberBuilder-DJPEeYDJ.mjs.map +0 -1
  530. package/dist/SubscriberBuilder-D_9zzllj.d.mts.map +0 -1
  531. package/dist/SubscriberBuilder-ivHAGIVi.d.cts.map +0 -1
  532. package/dist/TestEndpointAdaptor-C10xBI--.d.cts.map +0 -1
  533. package/dist/TestEndpointAdaptor-DB7bREhS.d.mts.map +0 -1
  534. package/dist/TestEndpointAdaptor-DJgik2Wj.mjs +0 -160
  535. package/dist/TestEndpointAdaptor-DJgik2Wj.mjs.map +0 -1
  536. package/dist/TestEndpointAdaptor-ZbtQiuHE.cjs +0 -166
  537. package/dist/TestEndpointAdaptor-ZbtQiuHE.cjs.map +0 -1
  538. package/dist/functions-C6EK1xL6.mjs +0 -8
  539. package/dist/functions-C6EK1xL6.mjs.map +0 -1
  540. package/dist/functions-fTid0RMK.cjs.map +0 -1
  541. package/dist/helpers-BcP1tXAi.cjs.map +0 -1
  542. package/dist/helpers-ByRTDO_m.mjs.map +0 -1
  543. package/dist/index-BWzGIj06.d.mts.map +0 -1
  544. package/dist/index-DmFozqLd.d.cts +0 -12
  545. package/dist/index-DmFozqLd.d.cts.map +0 -1
  546. package/dist/parseHonoQuery-CZC5_97v.cjs.map +0 -1
  547. package/dist/parseHonoQuery-DDgIkTO4.mjs.map +0 -1
  548. package/dist/publisher.d.cts.map +0 -1
  549. package/dist/publisher.d.mts.map +0 -1
  550. package/dist/types-DdIlpxAd.d.mts.map +0 -1
@@ -7,845 +7,845 @@ import { e } from '../EndpointFactory';
7
7
  import { TestEndpointAdaptor } from '../TestEndpointAdaptor';
8
8
 
9
9
  describe('TestEndpointAdaptor', () => {
10
- const mockServices = {};
11
- const logger = new ConsoleLogger();
12
-
13
- describe('request', () => {
14
- it('should handle simple endpoint without schemas', async () => {
15
- const endpoint = e
16
- .get('/test')
17
- .output(z.object({ message: z.string() }))
18
- .handle(() => ({ message: 'Hello World' }));
19
-
20
- const adapter = new TestEndpointAdaptor(endpoint);
21
-
22
- const result = await adapter.request({
23
- services: mockServices,
24
- headers: { host: 'example.com' },
25
- });
26
-
27
- expect(result).toEqual({ message: 'Hello World' });
28
- });
29
-
30
- it('should handle endpoint with body schema', async () => {
31
- const endpoint = e
32
- .post('/users')
33
- .body(z.object({ name: z.string(), email: z.string().email() }))
34
- .output(z.object({ id: z.string(), name: z.string() }))
35
- .handle(async ({ body }) => ({
36
- id: 'user-123',
37
- name: body.name,
38
- }));
39
-
40
- const adapter = new TestEndpointAdaptor(endpoint);
41
-
42
- const result = await adapter.request({
43
- body: { name: 'John Doe', email: 'john@example.com' },
44
- services: mockServices,
45
- headers: { host: 'example.com', 'content-type': 'application/json' },
46
- });
47
-
48
- expect(result).toEqual({ id: 'user-123', name: 'John Doe' });
49
- });
50
-
51
- it('should handle endpoint with params schema', async () => {
52
- const endpoint = e
53
- .get('/users/:id')
54
- .params(z.object({ id: z.string() }))
55
- .output(z.object({ id: z.string(), found: z.boolean() }))
56
- .handle(async ({ params }) => ({
57
- id: params.id,
58
- found: true,
59
- }));
60
-
61
- const adapter = new TestEndpointAdaptor(endpoint);
62
-
63
- const result = await adapter.request({
64
- params: { id: 'user-456' },
65
- services: mockServices,
66
- headers: { host: 'example.com' },
67
- });
68
-
69
- expect(result).toEqual({ id: 'user-456', found: true });
70
- });
71
-
72
- it('should handle endpoint with query schema', async () => {
73
- const endpoint = e
74
- .get('/search')
75
- .query(z.object({ q: z.string(), page: z.coerce.number().default(1) }))
76
- .output(z.object({ query: z.string(), page: z.number() }))
77
- .handle(async ({ query }) => ({
78
- query: query.q,
79
- page: query.page,
80
- }));
81
-
82
- const adapter = new TestEndpointAdaptor(endpoint);
83
-
84
- const result = await adapter.request({
85
- query: { q: 'test search', page: 2 },
86
- services: mockServices,
87
- headers: { host: 'example.com' },
88
- });
89
-
90
- expect(result).toEqual({ query: 'test search', page: 2 });
91
- });
92
-
93
- it('should handle endpoint with all schemas', async () => {
94
- const endpoint = e
95
- .put('/users/:id')
96
- .params(z.object({ id: z.string() }))
97
- .body(z.object({ name: z.string(), email: z.string().email() }))
98
- .query(z.object({ notify: z.coerce.boolean().default(false) }))
99
- .output(
100
- z.object({
101
- id: z.string(),
102
- updated: z.boolean(),
103
- notified: z.boolean(),
104
- }),
105
- )
106
- .handle(async ({ params, body, query }) => ({
107
- id: params.id,
108
- updated: true,
109
- notified: query.notify,
110
- }));
111
-
112
- const adapter = new TestEndpointAdaptor(endpoint);
113
-
114
- const result = await adapter.request({
115
- body: { name: 'Jane Doe', email: 'jane@example.com' },
116
- query: { notify: true },
117
- params: { id: 'user-789' },
118
- services: mockServices,
119
- headers: { host: 'example.com' },
120
- });
121
-
122
- expect(result).toEqual({
123
- id: 'user-789',
124
- updated: true,
125
- notified: true,
126
- });
127
- });
128
-
129
- it('should throw validation error for invalid body', async () => {
130
- const endpoint = e
131
- .post('/users')
132
- .body(z.object({ name: z.string(), age: z.number().min(18) }))
133
- .handle(async ({ body }) => ({ id: '123' }));
134
-
135
- const adapter = new TestEndpointAdaptor(endpoint);
136
-
137
- await expect(
138
- adapter.request({
139
- body: { name: 'John', age: 15 },
140
- services: mockServices,
141
- headers: { host: 'example.com' },
142
- }),
143
- ).rejects.toThrow(UnprocessableEntityError);
144
- });
145
-
146
- it('should handle headers correctly', async () => {
147
- const endpoint = e
148
- .get('/headers')
149
- .output(z.object({ auth: z.string().optional(), host: z.string() }))
150
- .handle(async ({ header }) => ({
151
- auth: header('authorization'),
152
- host: header('host') || 'unknown',
153
- }));
154
-
155
- const adapter = new TestEndpointAdaptor(endpoint);
156
-
157
- const result = await adapter.request({
158
- services: mockServices,
159
- headers: {
160
- host: 'api.example.com',
161
- authorization: 'Bearer token123',
162
- 'Content-Type': 'application/json',
163
- },
164
- });
165
-
166
- expect(result).toEqual({
167
- auth: 'Bearer token123',
168
- host: 'api.example.com',
169
- });
170
- });
171
-
172
- it('should handle session correctly', async () => {
173
- const endpoint = e
174
- .get('/profile')
175
- .output(z.object({ userId: z.string() }))
176
- .handle(async ({ session }) => ({
177
- userId: (session as any).userId,
178
- }));
179
-
180
- // Mock getSession
181
- endpoint.getSession = vi.fn().mockResolvedValue({ userId: 'user-123' });
182
-
183
- const adapter = new TestEndpointAdaptor(endpoint);
184
-
185
- const result = await adapter.request({
186
- services: mockServices,
187
- headers: { host: 'example.com' },
188
- });
189
-
190
- expect(result).toEqual({ userId: 'user-123' });
191
- expect(endpoint.getSession).toHaveBeenCalledWith({
192
- logger: expect.any(ConsoleLogger),
193
- services: mockServices,
194
- header: expect.any(Function),
195
- cookie: expect.any(Function),
196
- });
197
- });
198
-
199
- it('should validate output schema', async () => {
200
- const endpoint = e
201
- .get('/invalid')
202
- .output(z.object({ id: z.string(), count: z.number() }))
203
- .handle(() => ({ id: '123', count: 'not-a-number' as any }));
204
-
205
- const adapter = new TestEndpointAdaptor(endpoint);
206
-
207
- await expect(
208
- adapter.request({
209
- services: mockServices,
210
- headers: { host: 'example.com' },
211
- }),
212
- ).rejects.toThrow(UnprocessableEntityError);
213
- });
214
-
215
- it('should handle case-insensitive headers', async () => {
216
- const endpoint = e
217
- .get('/headers-case')
218
- .output(z.object({ contentType: z.string().optional() }))
219
- .handle(async ({ header }) => ({
220
- contentType: header('CONTENT-TYPE'),
221
- }));
222
-
223
- const adapter = new TestEndpointAdaptor(endpoint);
224
-
225
- const result = await adapter.request({
226
- services: mockServices,
227
- headers: {
228
- host: 'example.com',
229
- 'content-type': 'application/json',
230
- },
231
- });
232
-
233
- expect(result).toEqual({
234
- contentType: 'application/json',
235
- });
236
- });
237
-
238
- it('should read cookies from request', async () => {
239
- const endpoint = e
240
- .get('/cookies')
241
- .output(
242
- z.object({
243
- session: z.string().optional(),
244
- theme: z.string().optional(),
245
- }),
246
- )
247
- .handle(async ({ cookie }) => ({
248
- session: cookie('session'),
249
- theme: cookie('theme'),
250
- }));
251
-
252
- const adapter = new TestEndpointAdaptor(endpoint);
253
-
254
- const result = await adapter.request({
255
- services: mockServices,
256
- headers: {
257
- host: 'example.com',
258
- cookie: 'session=abc123; theme=dark',
259
- },
260
- });
261
-
262
- expect(result).toEqual({
263
- session: 'abc123',
264
- theme: 'dark',
265
- });
266
- });
267
-
268
- it('should handle missing cookies gracefully', async () => {
269
- const endpoint = e
270
- .get('/cookies-optional')
271
- .output(
272
- z.object({
273
- session: z.string().optional(),
274
- }),
275
- )
276
- .handle(async ({ cookie }) => ({
277
- session: cookie('session') || 'default',
278
- }));
279
-
280
- const adapter = new TestEndpointAdaptor(endpoint);
281
-
282
- const result = await adapter.request({
283
- services: mockServices,
284
- headers: {
285
- host: 'example.com',
286
- },
287
- });
288
-
289
- expect(result).toEqual({
290
- session: 'default',
291
- });
292
- });
293
-
294
- it('should handle URL encoded cookie values', async () => {
295
- const endpoint = e
296
- .get('/cookies-encoded')
297
- .output(z.object({ user: z.string() }))
298
- .handle(async ({ cookie }) => ({
299
- user: cookie('user') || 'unknown',
300
- }));
301
-
302
- const adapter = new TestEndpointAdaptor(endpoint);
303
-
304
- const result = await adapter.request({
305
- services: mockServices,
306
- headers: {
307
- host: 'example.com',
308
- cookie: 'user=John%20Doe',
309
- },
310
- });
311
-
312
- expect(result).toEqual({
313
- user: 'John Doe',
314
- });
315
- });
316
-
317
- it('should use cookies in session extraction', async () => {
318
- const endpoint = e
319
- .get('/profile')
320
- .output(z.object({ userId: z.string() }))
321
- .handle(async ({ session }) => ({
322
- userId: (session as any).userId,
323
- }));
324
-
325
- // Mock getSession that uses cookies
326
- endpoint.getSession = vi.fn().mockImplementation(({ cookie }) => {
327
- const sessionId = cookie('session');
328
- if (sessionId === 'valid-session') {
329
- return { userId: 'user-123' };
330
- }
331
- return null;
332
- });
333
-
334
- const adapter = new TestEndpointAdaptor(endpoint);
335
-
336
- const result = await adapter.request({
337
- services: mockServices,
338
- headers: {
339
- host: 'example.com',
340
- cookie: 'session=valid-session',
341
- },
342
- });
343
-
344
- expect(result).toEqual({ userId: 'user-123' });
345
- expect(endpoint.getSession).toHaveBeenCalledWith({
346
- logger: expect.any(ConsoleLogger),
347
- services: mockServices,
348
- header: expect.any(Function),
349
- cookie: expect.any(Function),
350
- });
351
- });
352
-
353
- it('should handle multiple cookies with same name (uses last)', async () => {
354
- const endpoint = e
355
- .get('/duplicate-cookies')
356
- .output(z.object({ value: z.string() }))
357
- .handle(async ({ cookie }) => ({
358
- value: cookie('test') || 'none',
359
- }));
360
-
361
- const adapter = new TestEndpointAdaptor(endpoint);
362
-
363
- const result = await adapter.request({
364
- services: mockServices,
365
- headers: {
366
- host: 'example.com',
367
- cookie: 'test=first; test=second',
368
- },
369
- });
370
-
371
- // When duplicates exist, Map uses the last occurrence
372
- expect(result).toEqual({
373
- value: 'second',
374
- });
375
- });
376
- });
377
-
378
- describe('response handling', () => {
379
- it('should set response cookies', async () => {
380
- const endpoint = e
381
- .post('/auth/login')
382
- .body(z.object({ email: z.string(), password: z.string() }))
383
- .output(z.object({ id: z.string(), email: z.string() }))
384
- .handle(async ({ body }, response) => {
385
- return response
386
- .cookie('session', 'abc123', {
387
- httpOnly: true,
388
- secure: true,
389
- sameSite: 'strict',
390
- maxAge: 3600,
391
- })
392
- .send({ id: 'user-1', email: body.email });
393
- });
394
-
395
- const adapter = new TestEndpointAdaptor(endpoint);
396
- const result = await adapter.fullRequest({
397
- body: { email: 'test@example.com', password: 'pass123' },
398
- services: mockServices,
399
- headers: { host: 'example.com' },
400
- });
401
-
402
- expect(result.body).toEqual({
403
- id: 'user-1',
404
- email: 'test@example.com',
405
- });
406
- expect(result.headers['set-cookie']).toEqual([
407
- 'session=abc123; Max-Age=3600; HttpOnly; Secure; SameSite=strict',
408
- ]);
409
- });
410
-
411
- it('should set custom response headers', async () => {
412
- const endpoint = e
413
- .post('/users')
414
- .body(z.object({ name: z.string() }))
415
- .output(z.object({ id: z.string(), name: z.string() }))
416
- .handle(async ({ body }, response) => {
417
- const user = { id: 'user-123', name: body.name };
418
- return response
419
- .header('Location', `/users/${user.id}`)
420
- .header('X-User-Id', user.id)
421
- .send(user);
422
- });
423
-
424
- const adapter = new TestEndpointAdaptor(endpoint);
425
- const result = await adapter.fullRequest({
426
- body: { name: 'John Doe' },
427
- services: mockServices,
428
- headers: { host: 'example.com' },
429
- });
430
-
431
- expect(result.body).toEqual({
432
- id: 'user-123',
433
- name: 'John Doe',
434
- });
435
- expect(result.headers).toEqual({
436
- Location: '/users/user-123',
437
- 'X-User-Id': 'user-123',
438
- });
439
- });
440
-
441
- it('should set custom status code', async () => {
442
- const endpoint = e
443
- .post('/resources')
444
- .body(z.object({ name: z.string() }))
445
- .output(z.object({ id: z.string() }))
446
- .handle(async (ctx, response) => {
447
- return response.status(SuccessStatus.Created).send({ id: '123' });
448
- });
449
-
450
- const adapter = new TestEndpointAdaptor(endpoint);
451
- const result = await adapter.fullRequest({
452
- body: { name: 'Resource' },
453
- services: mockServices,
454
- headers: { host: 'example.com' },
455
- });
456
-
457
- expect(result.status).toBe(201);
458
- });
459
-
460
- it('should delete cookies', async () => {
461
- const endpoint = e
462
- .post('/auth/logout')
463
- .output(z.object({ success: z.boolean() }))
464
- .handle(async (ctx, response) => {
465
- return response
466
- .deleteCookie('session', { path: '/' })
467
- .send({ success: true });
468
- });
469
-
470
- const adapter = new TestEndpointAdaptor(endpoint);
471
- const result = await adapter.fullRequest({
472
- services: mockServices,
473
- headers: { host: 'example.com' },
474
- });
475
-
476
- expect(result.body.success).toBe(true);
477
- const setCookieHeader = result.headers['set-cookie'] as string[];
478
- expect(setCookieHeader).toHaveLength(1);
479
- expect(setCookieHeader[0]).toContain('session=');
480
- expect(setCookieHeader[0]).toContain('Max-Age=0');
481
- expect(setCookieHeader[0]).toContain('Path=/');
482
- });
483
-
484
- it('should combine cookies, headers, and status', async () => {
485
- const endpoint = e
486
- .post('/complete')
487
- .body(z.object({ data: z.string() }))
488
- .output(z.object({ id: z.string(), result: z.string() }))
489
- .handle(async ({ body }, response) => {
490
- return response
491
- .status(SuccessStatus.Created)
492
- .header('Location', '/complete/123')
493
- .header('X-Request-Id', 'req-456')
494
- .cookie('tracking', 'track-789')
495
- .cookie('preference', 'dark', { maxAge: 86400 })
496
- .send({ id: '123', result: body.data });
497
- });
498
-
499
- const adapter = new TestEndpointAdaptor(endpoint);
500
- const result = await adapter.fullRequest({
501
- body: { data: 'test' },
502
- services: mockServices,
503
- headers: { host: 'example.com' },
504
- });
505
-
506
- expect(result.body).toEqual({
507
- id: '123',
508
- result: 'test',
509
- });
510
- expect(result.status).toBe(201);
511
- expect(result.headers).toEqual({
512
- Location: '/complete/123',
513
- 'X-Request-Id': 'req-456',
514
- 'set-cookie': ['tracking=track-789', 'preference=dark; Max-Age=86400'],
515
- });
516
- });
517
-
518
- it('should return simple response without metadata when not using response builder', async () => {
519
- const endpoint = e
520
- .get('/simple')
521
- .output(z.object({ message: z.string() }))
522
- .handle(async () => {
523
- // Not using response builder, just returning data
524
- return { message: 'Hello' };
525
- });
526
-
527
- const adapter = new TestEndpointAdaptor(endpoint);
528
- const result = await adapter.request({
529
- services: mockServices,
530
- headers: { host: 'example.com' },
531
- });
532
-
533
- // Should return just the data, not wrapped in metadata
534
- expect(result).toEqual({ message: 'Hello' });
535
- expect(result).not.toHaveProperty('metadata');
536
- });
537
-
538
- it('should combine request cookies and response cookies', async () => {
539
- const endpoint = e
540
- .get('/preferences')
541
- .output(z.object({ theme: z.string(), updated: z.boolean() }))
542
- .handle(async ({ cookie }, response) => {
543
- const currentTheme = cookie('theme') || 'light';
544
- const newTheme = currentTheme === 'light' ? 'dark' : 'light';
545
-
546
- return response
547
- .cookie('theme', newTheme, { maxAge: 86400 })
548
- .send({ theme: newTheme, updated: true });
549
- });
550
-
551
- const adapter = new TestEndpointAdaptor(endpoint);
552
- const result = await adapter.fullRequest({
553
- services: mockServices,
554
- headers: {
555
- host: 'example.com',
556
- cookie: 'theme=light',
557
- },
558
- });
559
-
560
- expect(result.body).toEqual({
561
- theme: 'dark',
562
- updated: true,
563
- });
564
- expect(result.headers['set-cookie']).toEqual([
565
- 'theme=dark; Max-Age=86400',
566
- ]);
567
- });
568
- });
569
-
570
- describe('fullRequest', () => {
571
- it('should return full HTTP response with body, status, and headers', async () => {
572
- const endpoint = e
573
- .get('/test')
574
- .output(z.object({ message: z.string() }))
575
- .handle(() => ({ message: 'Hello World' }));
576
-
577
- const adapter = new TestEndpointAdaptor(endpoint);
578
-
579
- const result = await adapter.fullRequest({
580
- services: mockServices,
581
- headers: { host: 'example.com' },
582
- });
583
-
584
- expect(result).toEqual({
585
- body: { message: 'Hello World' },
586
- status: 200,
587
- headers: {},
588
- });
589
- });
590
-
591
- it('should return custom status code in HTTP response', async () => {
592
- const endpoint = e
593
- .post('/resources')
594
- .body(z.object({ name: z.string() }))
595
- .output(z.object({ id: z.string() }))
596
- .handle(async (ctx, response) => {
597
- return response.status(SuccessStatus.Created).send({ id: '123' });
598
- });
599
-
600
- const adapter = new TestEndpointAdaptor(endpoint);
601
- const result = await adapter.fullRequest({
602
- body: { name: 'Resource' },
603
- services: mockServices,
604
- headers: { host: 'example.com' },
605
- });
606
-
607
- expect(result.status).toBe(201);
608
- expect(result.body).toEqual({ id: '123' });
609
- });
610
-
611
- it('should include custom headers in HTTP response', async () => {
612
- const endpoint = e
613
- .post('/users')
614
- .body(z.object({ name: z.string() }))
615
- .output(z.object({ id: z.string(), name: z.string() }))
616
- .handle(async ({ body }, response) => {
617
- const user = { id: 'user-123', name: body.name };
618
- return response
619
- .header('Location', `/users/${user.id}`)
620
- .header('X-User-Id', user.id)
621
- .send(user);
622
- });
623
-
624
- const adapter = new TestEndpointAdaptor(endpoint);
625
- const result = await adapter.fullRequest({
626
- body: { name: 'John Doe' },
627
- services: mockServices,
628
- headers: { host: 'example.com' },
629
- });
630
-
631
- expect(result.body).toEqual({
632
- id: 'user-123',
633
- name: 'John Doe',
634
- });
635
- expect(result.headers).toEqual({
636
- Location: '/users/user-123',
637
- 'X-User-Id': 'user-123',
638
- });
639
- });
640
-
641
- it('should convert cookies to Set-Cookie headers', async () => {
642
- const endpoint = e
643
- .post('/auth/login')
644
- .body(z.object({ email: z.string(), password: z.string() }))
645
- .output(z.object({ id: z.string(), email: z.string() }))
646
- .handle(async ({ body }, response) => {
647
- return response
648
- .cookie('session', 'abc123', {
649
- httpOnly: true,
650
- secure: true,
651
- sameSite: 'strict',
652
- maxAge: 3600,
653
- })
654
- .send({ id: 'user-1', email: body.email });
655
- });
656
-
657
- const adapter = new TestEndpointAdaptor(endpoint);
658
- const result = await adapter.fullRequest({
659
- body: { email: 'test@example.com', password: 'pass123' },
660
- services: mockServices,
661
- headers: { host: 'example.com' },
662
- });
663
-
664
- expect(result.body).toEqual({
665
- id: 'user-1',
666
- email: 'test@example.com',
667
- });
668
- expect(result.headers['set-cookie']).toEqual([
669
- 'session=abc123; Max-Age=3600; HttpOnly; Secure; SameSite=strict',
670
- ]);
671
- });
672
-
673
- it('should handle multiple cookies as array of Set-Cookie headers', async () => {
674
- const endpoint = e
675
- .post('/complete')
676
- .body(z.object({ data: z.string() }))
677
- .output(z.object({ id: z.string(), result: z.string() }))
678
- .handle(async ({ body }, response) => {
679
- return response
680
- .cookie('tracking', 'track-789')
681
- .cookie('preference', 'dark', { maxAge: 86400, path: '/' })
682
- .send({ id: '123', result: body.data });
683
- });
684
-
685
- const adapter = new TestEndpointAdaptor(endpoint);
686
- const result = await adapter.fullRequest({
687
- body: { data: 'test' },
688
- services: mockServices,
689
- headers: { host: 'example.com' },
690
- });
691
-
692
- expect(result.headers['set-cookie']).toEqual([
693
- 'tracking=track-789',
694
- 'preference=dark; Max-Age=86400; Path=/',
695
- ]);
696
- });
697
-
698
- it('should serialize all cookie options correctly', async () => {
699
- const expires = new Date('2025-12-31T23:59:59Z');
700
- const endpoint = e
701
- .get('/cookies-full')
702
- .output(z.object({ success: z.boolean() }))
703
- .handle(async (ctx, response) => {
704
- return response
705
- .cookie('full-cookie', 'value123', {
706
- domain: 'example.com',
707
- path: '/api',
708
- expires: expires,
709
- maxAge: 7200,
710
- httpOnly: true,
711
- secure: true,
712
- sameSite: 'lax',
713
- })
714
- .send({ success: true });
715
- });
716
-
717
- const adapter = new TestEndpointAdaptor(endpoint);
718
- const result = await adapter.fullRequest({
719
- services: mockServices,
720
- headers: { host: 'example.com' },
721
- });
722
-
723
- expect(result.headers['set-cookie']).toEqual([
724
- `full-cookie=value123; Max-Age=7200; Expires=${expires.toUTCString()}; Domain=example.com; Path=/api; HttpOnly; Secure; SameSite=lax`,
725
- ]);
726
- });
727
-
728
- it('should handle cookie deletion in Set-Cookie header', async () => {
729
- const endpoint = e
730
- .post('/auth/logout')
731
- .output(z.object({ success: z.boolean() }))
732
- .handle(async (ctx, response) => {
733
- return response
734
- .deleteCookie('session', { path: '/' })
735
- .send({ success: true });
736
- });
737
-
738
- const adapter = new TestEndpointAdaptor(endpoint);
739
- const result = await adapter.fullRequest({
740
- services: mockServices,
741
- headers: { host: 'example.com' },
742
- });
743
-
744
- expect(result.body.success).toBe(true);
745
- const setCookieHeader = result.headers['set-cookie'] as string[];
746
- expect(setCookieHeader).toHaveLength(1);
747
- expect(setCookieHeader[0]).toContain('session=');
748
- expect(setCookieHeader[0]).toContain('Max-Age=0');
749
- expect(setCookieHeader[0]).toContain('Path=/');
750
- expect(setCookieHeader[0]).toContain('Expires=');
751
- });
752
-
753
- it('should combine headers and cookies in HTTP response', async () => {
754
- const endpoint = e
755
- .post('/complete')
756
- .body(z.object({ data: z.string() }))
757
- .output(z.object({ id: z.string(), result: z.string() }))
758
- .handle(async ({ body }, response) => {
759
- return response
760
- .status(SuccessStatus.Created)
761
- .header('Location', '/complete/123')
762
- .header('X-Request-Id', 'req-456')
763
- .cookie('tracking', 'track-789')
764
- .cookie('preference', 'dark', { maxAge: 86400 })
765
- .send({ id: '123', result: body.data });
766
- });
767
-
768
- const adapter = new TestEndpointAdaptor(endpoint);
769
- const result = await adapter.fullRequest({
770
- body: { data: 'test' },
771
- services: mockServices,
772
- headers: { host: 'example.com' },
773
- });
774
-
775
- expect(result).toEqual({
776
- body: { id: '123', result: 'test' },
777
- status: 201,
778
- headers: {
779
- Location: '/complete/123',
780
- 'X-Request-Id': 'req-456',
781
- 'set-cookie': [
782
- 'tracking=track-789',
783
- 'preference=dark; Max-Age=86400',
784
- ],
785
- },
786
- });
787
- });
788
-
789
- it('should handle empty response metadata', async () => {
790
- const endpoint = e
791
- .get('/simple')
792
- .output(z.object({ message: z.string() }))
793
- .handle(async () => ({ message: 'Hello' }));
794
-
795
- const adapter = new TestEndpointAdaptor(endpoint);
796
- const result = await adapter.fullRequest({
797
- services: mockServices,
798
- headers: { host: 'example.com' },
799
- });
800
-
801
- expect(result).toEqual({
802
- body: { message: 'Hello' },
803
- status: 200,
804
- headers: {},
805
- });
806
- });
807
- });
808
-
809
- describe('request method delegation', () => {
810
- it('should return only body from fullRequest', async () => {
811
- const endpoint = e
812
- .post('/users')
813
- .body(z.object({ name: z.string() }))
814
- .output(z.object({ id: z.string(), name: z.string() }))
815
- .handle(async ({ body }, response) => {
816
- return response
817
- .status(SuccessStatus.Created)
818
- .header('Location', '/users/123')
819
- .cookie('session', 'abc')
820
- .send({ id: '123', name: body.name });
821
- });
822
-
823
- const adapter = new TestEndpointAdaptor(endpoint);
824
-
825
- // Call request (should only return body)
826
- const simpleResult = await adapter.request({
827
- body: { name: 'John' },
828
- services: mockServices,
829
- headers: { host: 'example.com' },
830
- });
831
-
832
- // Call fullRequest (should return full HTTP response)
833
- const fullResult = await adapter.fullRequest({
834
- body: { name: 'John' },
835
- services: mockServices,
836
- headers: { host: 'example.com' },
837
- });
838
-
839
- // request should only return the body
840
- expect(simpleResult).toEqual({ id: '123', name: 'John' });
841
- expect(simpleResult).not.toHaveProperty('status');
842
- expect(simpleResult).not.toHaveProperty('headers');
843
-
844
- // fullRequest should return complete HTTP response
845
- expect(fullResult.body).toEqual({ id: '123', name: 'John' });
846
- expect(fullResult.status).toBe(201);
847
- expect(fullResult.headers).toHaveProperty('Location');
848
- expect(fullResult.headers).toHaveProperty('set-cookie');
849
- });
850
- });
10
+ const mockServices = {};
11
+ const _logger = new ConsoleLogger();
12
+
13
+ describe('request', () => {
14
+ it('should handle simple endpoint without schemas', async () => {
15
+ const endpoint = e
16
+ .get('/test')
17
+ .output(z.object({ message: z.string() }))
18
+ .handle(() => ({ message: 'Hello World' }));
19
+
20
+ const adapter = new TestEndpointAdaptor(endpoint);
21
+
22
+ const result = await adapter.request({
23
+ services: mockServices,
24
+ headers: { host: 'example.com' },
25
+ });
26
+
27
+ expect(result).toEqual({ message: 'Hello World' });
28
+ });
29
+
30
+ it('should handle endpoint with body schema', async () => {
31
+ const endpoint = e
32
+ .post('/users')
33
+ .body(z.object({ name: z.string(), email: z.string().email() }))
34
+ .output(z.object({ id: z.string(), name: z.string() }))
35
+ .handle(async ({ body }) => ({
36
+ id: 'user-123',
37
+ name: body.name,
38
+ }));
39
+
40
+ const adapter = new TestEndpointAdaptor(endpoint);
41
+
42
+ const result = await adapter.request({
43
+ body: { name: 'John Doe', email: 'john@example.com' },
44
+ services: mockServices,
45
+ headers: { host: 'example.com', 'content-type': 'application/json' },
46
+ });
47
+
48
+ expect(result).toEqual({ id: 'user-123', name: 'John Doe' });
49
+ });
50
+
51
+ it('should handle endpoint with params schema', async () => {
52
+ const endpoint = e
53
+ .get('/users/:id')
54
+ .params(z.object({ id: z.string() }))
55
+ .output(z.object({ id: z.string(), found: z.boolean() }))
56
+ .handle(async ({ params }) => ({
57
+ id: params.id,
58
+ found: true,
59
+ }));
60
+
61
+ const adapter = new TestEndpointAdaptor(endpoint);
62
+
63
+ const result = await adapter.request({
64
+ params: { id: 'user-456' },
65
+ services: mockServices,
66
+ headers: { host: 'example.com' },
67
+ });
68
+
69
+ expect(result).toEqual({ id: 'user-456', found: true });
70
+ });
71
+
72
+ it('should handle endpoint with query schema', async () => {
73
+ const endpoint = e
74
+ .get('/search')
75
+ .query(z.object({ q: z.string(), page: z.coerce.number().default(1) }))
76
+ .output(z.object({ query: z.string(), page: z.number() }))
77
+ .handle(async ({ query }) => ({
78
+ query: query.q,
79
+ page: query.page,
80
+ }));
81
+
82
+ const adapter = new TestEndpointAdaptor(endpoint);
83
+
84
+ const result = await adapter.request({
85
+ query: { q: 'test search', page: 2 },
86
+ services: mockServices,
87
+ headers: { host: 'example.com' },
88
+ });
89
+
90
+ expect(result).toEqual({ query: 'test search', page: 2 });
91
+ });
92
+
93
+ it('should handle endpoint with all schemas', async () => {
94
+ const endpoint = e
95
+ .put('/users/:id')
96
+ .params(z.object({ id: z.string() }))
97
+ .body(z.object({ name: z.string(), email: z.string().email() }))
98
+ .query(z.object({ notify: z.coerce.boolean().default(false) }))
99
+ .output(
100
+ z.object({
101
+ id: z.string(),
102
+ updated: z.boolean(),
103
+ notified: z.boolean(),
104
+ }),
105
+ )
106
+ .handle(async ({ params, body, query }) => ({
107
+ id: params.id,
108
+ updated: true,
109
+ notified: query.notify,
110
+ }));
111
+
112
+ const adapter = new TestEndpointAdaptor(endpoint);
113
+
114
+ const result = await adapter.request({
115
+ body: { name: 'Jane Doe', email: 'jane@example.com' },
116
+ query: { notify: true },
117
+ params: { id: 'user-789' },
118
+ services: mockServices,
119
+ headers: { host: 'example.com' },
120
+ });
121
+
122
+ expect(result).toEqual({
123
+ id: 'user-789',
124
+ updated: true,
125
+ notified: true,
126
+ });
127
+ });
128
+
129
+ it('should throw validation error for invalid body', async () => {
130
+ const endpoint = e
131
+ .post('/users')
132
+ .body(z.object({ name: z.string(), age: z.number().min(18) }))
133
+ .handle(async ({ body }) => ({ id: '123' }));
134
+
135
+ const adapter = new TestEndpointAdaptor(endpoint);
136
+
137
+ await expect(
138
+ adapter.request({
139
+ body: { name: 'John', age: 15 },
140
+ services: mockServices,
141
+ headers: { host: 'example.com' },
142
+ }),
143
+ ).rejects.toThrow(UnprocessableEntityError);
144
+ });
145
+
146
+ it('should handle headers correctly', async () => {
147
+ const endpoint = e
148
+ .get('/headers')
149
+ .output(z.object({ auth: z.string().optional(), host: z.string() }))
150
+ .handle(async ({ header }) => ({
151
+ auth: header('authorization'),
152
+ host: header('host') || 'unknown',
153
+ }));
154
+
155
+ const adapter = new TestEndpointAdaptor(endpoint);
156
+
157
+ const result = await adapter.request({
158
+ services: mockServices,
159
+ headers: {
160
+ host: 'api.example.com',
161
+ authorization: 'Bearer token123',
162
+ 'Content-Type': 'application/json',
163
+ },
164
+ });
165
+
166
+ expect(result).toEqual({
167
+ auth: 'Bearer token123',
168
+ host: 'api.example.com',
169
+ });
170
+ });
171
+
172
+ it('should handle session correctly', async () => {
173
+ const endpoint = e
174
+ .get('/profile')
175
+ .output(z.object({ userId: z.string() }))
176
+ .handle(async ({ session }) => ({
177
+ userId: (session as any).userId,
178
+ }));
179
+
180
+ // Mock getSession
181
+ endpoint.getSession = vi.fn().mockResolvedValue({ userId: 'user-123' });
182
+
183
+ const adapter = new TestEndpointAdaptor(endpoint);
184
+
185
+ const result = await adapter.request({
186
+ services: mockServices,
187
+ headers: { host: 'example.com' },
188
+ });
189
+
190
+ expect(result).toEqual({ userId: 'user-123' });
191
+ expect(endpoint.getSession).toHaveBeenCalledWith({
192
+ logger: expect.any(ConsoleLogger),
193
+ services: mockServices,
194
+ header: expect.any(Function),
195
+ cookie: expect.any(Function),
196
+ });
197
+ });
198
+
199
+ it('should validate output schema', async () => {
200
+ const endpoint = e
201
+ .get('/invalid')
202
+ .output(z.object({ id: z.string(), count: z.number() }))
203
+ .handle(() => ({ id: '123', count: 'not-a-number' as any }));
204
+
205
+ const adapter = new TestEndpointAdaptor(endpoint);
206
+
207
+ await expect(
208
+ adapter.request({
209
+ services: mockServices,
210
+ headers: { host: 'example.com' },
211
+ }),
212
+ ).rejects.toThrow(UnprocessableEntityError);
213
+ });
214
+
215
+ it('should handle case-insensitive headers', async () => {
216
+ const endpoint = e
217
+ .get('/headers-case')
218
+ .output(z.object({ contentType: z.string().optional() }))
219
+ .handle(async ({ header }) => ({
220
+ contentType: header('CONTENT-TYPE'),
221
+ }));
222
+
223
+ const adapter = new TestEndpointAdaptor(endpoint);
224
+
225
+ const result = await adapter.request({
226
+ services: mockServices,
227
+ headers: {
228
+ host: 'example.com',
229
+ 'content-type': 'application/json',
230
+ },
231
+ });
232
+
233
+ expect(result).toEqual({
234
+ contentType: 'application/json',
235
+ });
236
+ });
237
+
238
+ it('should read cookies from request', async () => {
239
+ const endpoint = e
240
+ .get('/cookies')
241
+ .output(
242
+ z.object({
243
+ session: z.string().optional(),
244
+ theme: z.string().optional(),
245
+ }),
246
+ )
247
+ .handle(async ({ cookie }) => ({
248
+ session: cookie('session'),
249
+ theme: cookie('theme'),
250
+ }));
251
+
252
+ const adapter = new TestEndpointAdaptor(endpoint);
253
+
254
+ const result = await adapter.request({
255
+ services: mockServices,
256
+ headers: {
257
+ host: 'example.com',
258
+ cookie: 'session=abc123; theme=dark',
259
+ },
260
+ });
261
+
262
+ expect(result).toEqual({
263
+ session: 'abc123',
264
+ theme: 'dark',
265
+ });
266
+ });
267
+
268
+ it('should handle missing cookies gracefully', async () => {
269
+ const endpoint = e
270
+ .get('/cookies-optional')
271
+ .output(
272
+ z.object({
273
+ session: z.string().optional(),
274
+ }),
275
+ )
276
+ .handle(async ({ cookie }) => ({
277
+ session: cookie('session') || 'default',
278
+ }));
279
+
280
+ const adapter = new TestEndpointAdaptor(endpoint);
281
+
282
+ const result = await adapter.request({
283
+ services: mockServices,
284
+ headers: {
285
+ host: 'example.com',
286
+ },
287
+ });
288
+
289
+ expect(result).toEqual({
290
+ session: 'default',
291
+ });
292
+ });
293
+
294
+ it('should handle URL encoded cookie values', async () => {
295
+ const endpoint = e
296
+ .get('/cookies-encoded')
297
+ .output(z.object({ user: z.string() }))
298
+ .handle(async ({ cookie }) => ({
299
+ user: cookie('user') || 'unknown',
300
+ }));
301
+
302
+ const adapter = new TestEndpointAdaptor(endpoint);
303
+
304
+ const result = await adapter.request({
305
+ services: mockServices,
306
+ headers: {
307
+ host: 'example.com',
308
+ cookie: 'user=John%20Doe',
309
+ },
310
+ });
311
+
312
+ expect(result).toEqual({
313
+ user: 'John Doe',
314
+ });
315
+ });
316
+
317
+ it('should use cookies in session extraction', async () => {
318
+ const endpoint = e
319
+ .get('/profile')
320
+ .output(z.object({ userId: z.string() }))
321
+ .handle(async ({ session }) => ({
322
+ userId: (session as any).userId,
323
+ }));
324
+
325
+ // Mock getSession that uses cookies
326
+ endpoint.getSession = vi.fn().mockImplementation(({ cookie }) => {
327
+ const sessionId = cookie('session');
328
+ if (sessionId === 'valid-session') {
329
+ return { userId: 'user-123' };
330
+ }
331
+ return null;
332
+ });
333
+
334
+ const adapter = new TestEndpointAdaptor(endpoint);
335
+
336
+ const result = await adapter.request({
337
+ services: mockServices,
338
+ headers: {
339
+ host: 'example.com',
340
+ cookie: 'session=valid-session',
341
+ },
342
+ });
343
+
344
+ expect(result).toEqual({ userId: 'user-123' });
345
+ expect(endpoint.getSession).toHaveBeenCalledWith({
346
+ logger: expect.any(ConsoleLogger),
347
+ services: mockServices,
348
+ header: expect.any(Function),
349
+ cookie: expect.any(Function),
350
+ });
351
+ });
352
+
353
+ it('should handle multiple cookies with same name (uses last)', async () => {
354
+ const endpoint = e
355
+ .get('/duplicate-cookies')
356
+ .output(z.object({ value: z.string() }))
357
+ .handle(async ({ cookie }) => ({
358
+ value: cookie('test') || 'none',
359
+ }));
360
+
361
+ const adapter = new TestEndpointAdaptor(endpoint);
362
+
363
+ const result = await adapter.request({
364
+ services: mockServices,
365
+ headers: {
366
+ host: 'example.com',
367
+ cookie: 'test=first; test=second',
368
+ },
369
+ });
370
+
371
+ // When duplicates exist, Map uses the last occurrence
372
+ expect(result).toEqual({
373
+ value: 'second',
374
+ });
375
+ });
376
+ });
377
+
378
+ describe('response handling', () => {
379
+ it('should set response cookies', async () => {
380
+ const endpoint = e
381
+ .post('/auth/login')
382
+ .body(z.object({ email: z.string(), password: z.string() }))
383
+ .output(z.object({ id: z.string(), email: z.string() }))
384
+ .handle(async ({ body }, response) => {
385
+ return response
386
+ .cookie('session', 'abc123', {
387
+ httpOnly: true,
388
+ secure: true,
389
+ sameSite: 'strict',
390
+ maxAge: 3600,
391
+ })
392
+ .send({ id: 'user-1', email: body.email });
393
+ });
394
+
395
+ const adapter = new TestEndpointAdaptor(endpoint);
396
+ const result = await adapter.fullRequest({
397
+ body: { email: 'test@example.com', password: 'pass123' },
398
+ services: mockServices,
399
+ headers: { host: 'example.com' },
400
+ });
401
+
402
+ expect(result.body).toEqual({
403
+ id: 'user-1',
404
+ email: 'test@example.com',
405
+ });
406
+ expect(result.headers['set-cookie']).toEqual([
407
+ 'session=abc123; Max-Age=3600; HttpOnly; Secure; SameSite=strict',
408
+ ]);
409
+ });
410
+
411
+ it('should set custom response headers', async () => {
412
+ const endpoint = e
413
+ .post('/users')
414
+ .body(z.object({ name: z.string() }))
415
+ .output(z.object({ id: z.string(), name: z.string() }))
416
+ .handle(async ({ body }, response) => {
417
+ const user = { id: 'user-123', name: body.name };
418
+ return response
419
+ .header('Location', `/users/${user.id}`)
420
+ .header('X-User-Id', user.id)
421
+ .send(user);
422
+ });
423
+
424
+ const adapter = new TestEndpointAdaptor(endpoint);
425
+ const result = await adapter.fullRequest({
426
+ body: { name: 'John Doe' },
427
+ services: mockServices,
428
+ headers: { host: 'example.com' },
429
+ });
430
+
431
+ expect(result.body).toEqual({
432
+ id: 'user-123',
433
+ name: 'John Doe',
434
+ });
435
+ expect(result.headers).toEqual({
436
+ Location: '/users/user-123',
437
+ 'X-User-Id': 'user-123',
438
+ });
439
+ });
440
+
441
+ it('should set custom status code', async () => {
442
+ const endpoint = e
443
+ .post('/resources')
444
+ .body(z.object({ name: z.string() }))
445
+ .output(z.object({ id: z.string() }))
446
+ .handle(async (_ctx, response) => {
447
+ return response.status(SuccessStatus.Created).send({ id: '123' });
448
+ });
449
+
450
+ const adapter = new TestEndpointAdaptor(endpoint);
451
+ const result = await adapter.fullRequest({
452
+ body: { name: 'Resource' },
453
+ services: mockServices,
454
+ headers: { host: 'example.com' },
455
+ });
456
+
457
+ expect(result.status).toBe(201);
458
+ });
459
+
460
+ it('should delete cookies', async () => {
461
+ const endpoint = e
462
+ .post('/auth/logout')
463
+ .output(z.object({ success: z.boolean() }))
464
+ .handle(async (_ctx, response) => {
465
+ return response
466
+ .deleteCookie('session', { path: '/' })
467
+ .send({ success: true });
468
+ });
469
+
470
+ const adapter = new TestEndpointAdaptor(endpoint);
471
+ const result = await adapter.fullRequest({
472
+ services: mockServices,
473
+ headers: { host: 'example.com' },
474
+ });
475
+
476
+ expect(result.body.success).toBe(true);
477
+ const setCookieHeader = result.headers['set-cookie'] as string[];
478
+ expect(setCookieHeader).toHaveLength(1);
479
+ expect(setCookieHeader[0]).toContain('session=');
480
+ expect(setCookieHeader[0]).toContain('Max-Age=0');
481
+ expect(setCookieHeader[0]).toContain('Path=/');
482
+ });
483
+
484
+ it('should combine cookies, headers, and status', async () => {
485
+ const endpoint = e
486
+ .post('/complete')
487
+ .body(z.object({ data: z.string() }))
488
+ .output(z.object({ id: z.string(), result: z.string() }))
489
+ .handle(async ({ body }, response) => {
490
+ return response
491
+ .status(SuccessStatus.Created)
492
+ .header('Location', '/complete/123')
493
+ .header('X-Request-Id', 'req-456')
494
+ .cookie('tracking', 'track-789')
495
+ .cookie('preference', 'dark', { maxAge: 86400 })
496
+ .send({ id: '123', result: body.data });
497
+ });
498
+
499
+ const adapter = new TestEndpointAdaptor(endpoint);
500
+ const result = await adapter.fullRequest({
501
+ body: { data: 'test' },
502
+ services: mockServices,
503
+ headers: { host: 'example.com' },
504
+ });
505
+
506
+ expect(result.body).toEqual({
507
+ id: '123',
508
+ result: 'test',
509
+ });
510
+ expect(result.status).toBe(201);
511
+ expect(result.headers).toEqual({
512
+ Location: '/complete/123',
513
+ 'X-Request-Id': 'req-456',
514
+ 'set-cookie': ['tracking=track-789', 'preference=dark; Max-Age=86400'],
515
+ });
516
+ });
517
+
518
+ it('should return simple response without metadata when not using response builder', async () => {
519
+ const endpoint = e
520
+ .get('/simple')
521
+ .output(z.object({ message: z.string() }))
522
+ .handle(async () => {
523
+ // Not using response builder, just returning data
524
+ return { message: 'Hello' };
525
+ });
526
+
527
+ const adapter = new TestEndpointAdaptor(endpoint);
528
+ const result = await adapter.request({
529
+ services: mockServices,
530
+ headers: { host: 'example.com' },
531
+ });
532
+
533
+ // Should return just the data, not wrapped in metadata
534
+ expect(result).toEqual({ message: 'Hello' });
535
+ expect(result).not.toHaveProperty('metadata');
536
+ });
537
+
538
+ it('should combine request cookies and response cookies', async () => {
539
+ const endpoint = e
540
+ .get('/preferences')
541
+ .output(z.object({ theme: z.string(), updated: z.boolean() }))
542
+ .handle(async ({ cookie }, response) => {
543
+ const currentTheme = cookie('theme') || 'light';
544
+ const newTheme = currentTheme === 'light' ? 'dark' : 'light';
545
+
546
+ return response
547
+ .cookie('theme', newTheme, { maxAge: 86400 })
548
+ .send({ theme: newTheme, updated: true });
549
+ });
550
+
551
+ const adapter = new TestEndpointAdaptor(endpoint);
552
+ const result = await adapter.fullRequest({
553
+ services: mockServices,
554
+ headers: {
555
+ host: 'example.com',
556
+ cookie: 'theme=light',
557
+ },
558
+ });
559
+
560
+ expect(result.body).toEqual({
561
+ theme: 'dark',
562
+ updated: true,
563
+ });
564
+ expect(result.headers['set-cookie']).toEqual([
565
+ 'theme=dark; Max-Age=86400',
566
+ ]);
567
+ });
568
+ });
569
+
570
+ describe('fullRequest', () => {
571
+ it('should return full HTTP response with body, status, and headers', async () => {
572
+ const endpoint = e
573
+ .get('/test')
574
+ .output(z.object({ message: z.string() }))
575
+ .handle(() => ({ message: 'Hello World' }));
576
+
577
+ const adapter = new TestEndpointAdaptor(endpoint);
578
+
579
+ const result = await adapter.fullRequest({
580
+ services: mockServices,
581
+ headers: { host: 'example.com' },
582
+ });
583
+
584
+ expect(result).toEqual({
585
+ body: { message: 'Hello World' },
586
+ status: 200,
587
+ headers: {},
588
+ });
589
+ });
590
+
591
+ it('should return custom status code in HTTP response', async () => {
592
+ const endpoint = e
593
+ .post('/resources')
594
+ .body(z.object({ name: z.string() }))
595
+ .output(z.object({ id: z.string() }))
596
+ .handle(async (_ctx, response) => {
597
+ return response.status(SuccessStatus.Created).send({ id: '123' });
598
+ });
599
+
600
+ const adapter = new TestEndpointAdaptor(endpoint);
601
+ const result = await adapter.fullRequest({
602
+ body: { name: 'Resource' },
603
+ services: mockServices,
604
+ headers: { host: 'example.com' },
605
+ });
606
+
607
+ expect(result.status).toBe(201);
608
+ expect(result.body).toEqual({ id: '123' });
609
+ });
610
+
611
+ it('should include custom headers in HTTP response', async () => {
612
+ const endpoint = e
613
+ .post('/users')
614
+ .body(z.object({ name: z.string() }))
615
+ .output(z.object({ id: z.string(), name: z.string() }))
616
+ .handle(async ({ body }, response) => {
617
+ const user = { id: 'user-123', name: body.name };
618
+ return response
619
+ .header('Location', `/users/${user.id}`)
620
+ .header('X-User-Id', user.id)
621
+ .send(user);
622
+ });
623
+
624
+ const adapter = new TestEndpointAdaptor(endpoint);
625
+ const result = await adapter.fullRequest({
626
+ body: { name: 'John Doe' },
627
+ services: mockServices,
628
+ headers: { host: 'example.com' },
629
+ });
630
+
631
+ expect(result.body).toEqual({
632
+ id: 'user-123',
633
+ name: 'John Doe',
634
+ });
635
+ expect(result.headers).toEqual({
636
+ Location: '/users/user-123',
637
+ 'X-User-Id': 'user-123',
638
+ });
639
+ });
640
+
641
+ it('should convert cookies to Set-Cookie headers', async () => {
642
+ const endpoint = e
643
+ .post('/auth/login')
644
+ .body(z.object({ email: z.string(), password: z.string() }))
645
+ .output(z.object({ id: z.string(), email: z.string() }))
646
+ .handle(async ({ body }, response) => {
647
+ return response
648
+ .cookie('session', 'abc123', {
649
+ httpOnly: true,
650
+ secure: true,
651
+ sameSite: 'strict',
652
+ maxAge: 3600,
653
+ })
654
+ .send({ id: 'user-1', email: body.email });
655
+ });
656
+
657
+ const adapter = new TestEndpointAdaptor(endpoint);
658
+ const result = await adapter.fullRequest({
659
+ body: { email: 'test@example.com', password: 'pass123' },
660
+ services: mockServices,
661
+ headers: { host: 'example.com' },
662
+ });
663
+
664
+ expect(result.body).toEqual({
665
+ id: 'user-1',
666
+ email: 'test@example.com',
667
+ });
668
+ expect(result.headers['set-cookie']).toEqual([
669
+ 'session=abc123; Max-Age=3600; HttpOnly; Secure; SameSite=strict',
670
+ ]);
671
+ });
672
+
673
+ it('should handle multiple cookies as array of Set-Cookie headers', async () => {
674
+ const endpoint = e
675
+ .post('/complete')
676
+ .body(z.object({ data: z.string() }))
677
+ .output(z.object({ id: z.string(), result: z.string() }))
678
+ .handle(async ({ body }, response) => {
679
+ return response
680
+ .cookie('tracking', 'track-789')
681
+ .cookie('preference', 'dark', { maxAge: 86400, path: '/' })
682
+ .send({ id: '123', result: body.data });
683
+ });
684
+
685
+ const adapter = new TestEndpointAdaptor(endpoint);
686
+ const result = await adapter.fullRequest({
687
+ body: { data: 'test' },
688
+ services: mockServices,
689
+ headers: { host: 'example.com' },
690
+ });
691
+
692
+ expect(result.headers['set-cookie']).toEqual([
693
+ 'tracking=track-789',
694
+ 'preference=dark; Max-Age=86400; Path=/',
695
+ ]);
696
+ });
697
+
698
+ it('should serialize all cookie options correctly', async () => {
699
+ const expires = new Date('2025-12-31T23:59:59Z');
700
+ const endpoint = e
701
+ .get('/cookies-full')
702
+ .output(z.object({ success: z.boolean() }))
703
+ .handle(async (_ctx, response) => {
704
+ return response
705
+ .cookie('full-cookie', 'value123', {
706
+ domain: 'example.com',
707
+ path: '/api',
708
+ expires: expires,
709
+ maxAge: 7200,
710
+ httpOnly: true,
711
+ secure: true,
712
+ sameSite: 'lax',
713
+ })
714
+ .send({ success: true });
715
+ });
716
+
717
+ const adapter = new TestEndpointAdaptor(endpoint);
718
+ const result = await adapter.fullRequest({
719
+ services: mockServices,
720
+ headers: { host: 'example.com' },
721
+ });
722
+
723
+ expect(result.headers['set-cookie']).toEqual([
724
+ `full-cookie=value123; Max-Age=7200; Expires=${expires.toUTCString()}; Domain=example.com; Path=/api; HttpOnly; Secure; SameSite=lax`,
725
+ ]);
726
+ });
727
+
728
+ it('should handle cookie deletion in Set-Cookie header', async () => {
729
+ const endpoint = e
730
+ .post('/auth/logout')
731
+ .output(z.object({ success: z.boolean() }))
732
+ .handle(async (_ctx, response) => {
733
+ return response
734
+ .deleteCookie('session', { path: '/' })
735
+ .send({ success: true });
736
+ });
737
+
738
+ const adapter = new TestEndpointAdaptor(endpoint);
739
+ const result = await adapter.fullRequest({
740
+ services: mockServices,
741
+ headers: { host: 'example.com' },
742
+ });
743
+
744
+ expect(result.body.success).toBe(true);
745
+ const setCookieHeader = result.headers['set-cookie'] as string[];
746
+ expect(setCookieHeader).toHaveLength(1);
747
+ expect(setCookieHeader[0]).toContain('session=');
748
+ expect(setCookieHeader[0]).toContain('Max-Age=0');
749
+ expect(setCookieHeader[0]).toContain('Path=/');
750
+ expect(setCookieHeader[0]).toContain('Expires=');
751
+ });
752
+
753
+ it('should combine headers and cookies in HTTP response', async () => {
754
+ const endpoint = e
755
+ .post('/complete')
756
+ .body(z.object({ data: z.string() }))
757
+ .output(z.object({ id: z.string(), result: z.string() }))
758
+ .handle(async ({ body }, response) => {
759
+ return response
760
+ .status(SuccessStatus.Created)
761
+ .header('Location', '/complete/123')
762
+ .header('X-Request-Id', 'req-456')
763
+ .cookie('tracking', 'track-789')
764
+ .cookie('preference', 'dark', { maxAge: 86400 })
765
+ .send({ id: '123', result: body.data });
766
+ });
767
+
768
+ const adapter = new TestEndpointAdaptor(endpoint);
769
+ const result = await adapter.fullRequest({
770
+ body: { data: 'test' },
771
+ services: mockServices,
772
+ headers: { host: 'example.com' },
773
+ });
774
+
775
+ expect(result).toEqual({
776
+ body: { id: '123', result: 'test' },
777
+ status: 201,
778
+ headers: {
779
+ Location: '/complete/123',
780
+ 'X-Request-Id': 'req-456',
781
+ 'set-cookie': [
782
+ 'tracking=track-789',
783
+ 'preference=dark; Max-Age=86400',
784
+ ],
785
+ },
786
+ });
787
+ });
788
+
789
+ it('should handle empty response metadata', async () => {
790
+ const endpoint = e
791
+ .get('/simple')
792
+ .output(z.object({ message: z.string() }))
793
+ .handle(async () => ({ message: 'Hello' }));
794
+
795
+ const adapter = new TestEndpointAdaptor(endpoint);
796
+ const result = await adapter.fullRequest({
797
+ services: mockServices,
798
+ headers: { host: 'example.com' },
799
+ });
800
+
801
+ expect(result).toEqual({
802
+ body: { message: 'Hello' },
803
+ status: 200,
804
+ headers: {},
805
+ });
806
+ });
807
+ });
808
+
809
+ describe('request method delegation', () => {
810
+ it('should return only body from fullRequest', async () => {
811
+ const endpoint = e
812
+ .post('/users')
813
+ .body(z.object({ name: z.string() }))
814
+ .output(z.object({ id: z.string(), name: z.string() }))
815
+ .handle(async ({ body }, response) => {
816
+ return response
817
+ .status(SuccessStatus.Created)
818
+ .header('Location', '/users/123')
819
+ .cookie('session', 'abc')
820
+ .send({ id: '123', name: body.name });
821
+ });
822
+
823
+ const adapter = new TestEndpointAdaptor(endpoint);
824
+
825
+ // Call request (should only return body)
826
+ const simpleResult = await adapter.request({
827
+ body: { name: 'John' },
828
+ services: mockServices,
829
+ headers: { host: 'example.com' },
830
+ });
831
+
832
+ // Call fullRequest (should return full HTTP response)
833
+ const fullResult = await adapter.fullRequest({
834
+ body: { name: 'John' },
835
+ services: mockServices,
836
+ headers: { host: 'example.com' },
837
+ });
838
+
839
+ // request should only return the body
840
+ expect(simpleResult).toEqual({ id: '123', name: 'John' });
841
+ expect(simpleResult).not.toHaveProperty('status');
842
+ expect(simpleResult).not.toHaveProperty('headers');
843
+
844
+ // fullRequest should return complete HTTP response
845
+ expect(fullResult.body).toEqual({ id: '123', name: 'John' });
846
+ expect(fullResult.status).toBe(201);
847
+ expect(fullResult.headers).toHaveProperty('Location');
848
+ expect(fullResult.headers).toHaveProperty('set-cookie');
849
+ });
850
+ });
851
851
  });