@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
@@ -6,826 +6,823 @@ import { z } from 'zod/v4';
6
6
  import { Endpoint } from '../Endpoint';
7
7
 
8
8
  describe('Endpoint', () => {
9
- describe('toOpenApi3Route', () => {
10
- it('should generate basic OpenAPI spec for GET endpoint', async () => {
11
- const endpoint = new Endpoint({
12
- route: '/users',
13
- method: 'GET',
14
- authorize: undefined,
15
- description: 'Get all users',
16
- fn: async () => [],
17
- input: undefined,
18
- status: undefined,
19
- getSession: undefined,
20
- output: undefined,
21
- services: [],
22
- logger: {} as any,
23
- timeout: undefined,
24
- memorySize: undefined,
25
- });
26
-
27
- const spec = await endpoint.toOpenApi3Route();
28
-
29
- expect(spec).toEqual({
30
- '/users': {
31
- get: {
32
- description: 'Get all users',
33
- responses: {
34
- '200': {
35
- description: 'Successful response',
36
- },
37
- },
38
- },
39
- },
40
- });
41
- });
42
-
43
- it('should include response schema when output is defined', async () => {
44
- const outputSchema = z.object({
45
- id: z.string(),
46
- name: z.string(),
47
- });
48
-
49
- const endpoint = new Endpoint({
50
- route: '/users/:id',
51
- method: 'GET',
52
- description: 'Get user by ID',
53
- fn: async () => ({ id: '1', name: 'John' }),
54
- input: undefined,
55
- output: outputSchema,
56
- authorize: undefined,
57
- services: [],
58
- status: undefined,
59
- getSession: undefined,
60
- logger: {} as any,
61
- timeout: undefined,
62
- memorySize: undefined,
63
- });
64
-
65
- const spec = await endpoint.toOpenApi3Route();
66
- const doc = spec['/users/{id}'];
67
- expect(doc.get.responses?.['200']).toHaveProperty('content');
68
- expect(
69
- (doc.get.responses?.['200'] as any).content['application/json'].schema,
70
- ).toMatchObject({
71
- type: 'object',
72
- properties: {
73
- id: { type: 'string' },
74
- name: { type: 'string' },
75
- },
76
- required: ['id', 'name'],
77
- });
78
- });
79
-
80
- it('should include request body for POST endpoint', async () => {
81
- const bodySchema = z.object({
82
- name: z.string(),
83
- email: z.string().email(),
84
- });
85
-
86
- const endpoint = new Endpoint({
87
- route: '/users',
88
- method: 'POST',
89
- authorize: undefined,
90
- description: 'Create a new user',
91
- fn: async (ctx) => ({ id: '1', ...(ctx as any).body }),
92
- input: {
93
- body: bodySchema,
94
- },
95
- output: undefined,
96
- status: undefined,
97
- getSession: undefined,
98
- services: [],
99
- logger: {} as any,
100
- timeout: undefined,
101
- memorySize: undefined,
102
- });
103
-
104
- const spec = await endpoint.toOpenApi3Route();
105
-
106
- expect(spec['/users']!.post).toHaveProperty('requestBody');
107
- expect((spec['/users']!.post! as any).requestBody).toMatchObject({
108
- required: true,
109
- content: {
110
- 'application/json': {
111
- schema: {
112
- type: 'object',
113
- properties: {
114
- name: { type: 'string' },
115
- email: { type: 'string', format: 'email' },
116
- },
117
- required: ['name', 'email'],
118
- },
119
- },
120
- },
121
- });
122
- });
123
-
124
- it('should include path parameters at route level', async () => {
125
- const paramsSchema = z.object({
126
- id: z.string(),
127
- subId: z.string().optional(),
128
- });
129
-
130
- const endpoint = new Endpoint({
131
- route: '/users/:id/items/:subId',
132
- method: 'GET',
133
- status: undefined,
134
- authorize: undefined,
135
- getSession: undefined,
136
- description: 'Get user item',
137
- fn: async (ctx) => ({
138
- userId: (ctx as any).params.id,
139
- itemId: (ctx as any).params.subId,
140
- }),
141
- input: {
142
- params: paramsSchema,
143
- },
144
- output: undefined,
145
- services: [],
146
- logger: {} as any,
147
- timeout: undefined,
148
- memorySize: undefined,
149
- });
150
-
151
- const spec = await endpoint.toOpenApi3Route();
152
-
153
- const doc = spec['/users/{id}/items/{subId}'];
154
-
155
- // Path parameters should be at route level, not method level
156
- expect(doc).toHaveProperty('parameters');
157
- const parameters = doc.parameters;
158
-
159
- expect(parameters).toHaveLength(2);
160
- expect(parameters).toContainEqual({
161
- name: 'id',
162
- in: 'path',
163
- required: true,
164
- schema: { type: 'string' },
165
- });
166
- expect(parameters).toContainEqual({
167
- name: 'subId',
168
- in: 'path',
169
- required: false,
170
- schema: { type: 'string' },
171
- });
172
-
173
- // Method should not have path parameters
174
- expect(doc.get.parameters).toBeUndefined();
175
- });
176
-
177
- it('should include query parameters', async () => {
178
- const searchSchema = z.object({
179
- page: z.number().optional(),
180
- limit: z.number().optional(),
181
- sort: z.enum(['asc', 'desc']),
182
- });
183
-
184
- const endpoint = new Endpoint({
185
- route: '/users',
186
- method: 'GET',
187
- authorize: undefined,
188
- description: 'List users with pagination',
189
- fn: async (ctx) => [],
190
- input: {
191
- query: searchSchema,
192
- },
193
- output: undefined,
194
- services: [],
195
- logger: {} as any,
196
- timeout: undefined,
197
- memorySize: undefined,
198
- status: undefined,
199
- getSession: undefined,
200
- });
201
-
202
- const spec = await endpoint.toOpenApi3Route();
203
-
204
- expect(spec['/users']!.get).toHaveProperty('parameters');
205
- const parameters = (spec['/users']!.get! as any).parameters;
206
-
207
- expect(parameters).toHaveLength(3);
208
- expect(parameters).toContainEqual({
209
- name: 'page',
210
- in: 'query',
211
- required: false,
212
- schema: { type: 'number' },
213
- });
214
- expect(parameters).toContainEqual({
215
- name: 'limit',
216
- in: 'query',
217
- required: false,
218
- schema: { type: 'number' },
219
- });
220
- expect(parameters).toContainEqual({
221
- name: 'sort',
222
- in: 'query',
223
- required: true,
224
- schema: { type: 'string', enum: ['asc', 'desc'] },
225
- });
226
- });
227
-
228
- it('should handle PUT endpoint with body and params', async () => {
229
- const bodySchema = z.object({
230
- name: z.string(),
231
- email: z.string().email(),
232
- });
233
- const paramsSchema = z.object({
234
- id: z.string(),
235
- });
236
- const outputSchema = z.object({
237
- id: z.string(),
238
- name: z.string(),
239
- email: z.string(),
240
- updatedAt: z.string(),
241
- });
242
-
243
- const endpoint = new Endpoint({
244
- route: '/users/:id',
245
- method: 'PUT',
246
- description: 'Update user',
247
- status: undefined,
248
- getSession: undefined,
249
- authorize: undefined,
250
- fn: async (ctx) => ({
251
- id: (ctx as any).params.id,
252
- ...(ctx as any).body,
253
- updatedAt: new Date().toISOString(),
254
- }),
255
- input: {
256
- body: bodySchema,
257
- params: paramsSchema,
258
- },
259
- output: outputSchema,
260
- services: [],
261
- logger: {} as any,
262
- timeout: undefined,
263
- memorySize: undefined,
264
- });
265
-
266
- const spec = await endpoint.toOpenApi3Route();
267
- const doc = spec['/users/{id}'];
268
-
269
- // Check request body
270
- expect(doc.put).toHaveProperty('requestBody');
271
- expect(
272
- (doc.put as any).requestBody.content['application/json'].schema,
273
- ).toMatchObject({
274
- type: 'object',
275
- properties: {
276
- name: { type: 'string' },
277
- email: { type: 'string', format: 'email' },
278
- },
279
- });
280
-
281
- // Check path parameters at route level
282
- expect(doc).toHaveProperty('parameters');
283
- expect(doc.parameters).toHaveLength(1);
284
- expect(doc.parameters?.[0]).toEqual({
285
- name: 'id',
286
- in: 'path',
287
- required: true,
288
- schema: { type: 'string' },
289
- });
290
-
291
- // Method should not have path parameters
292
- expect((doc.put as any).parameters).toBeUndefined();
293
-
294
- // Check response
295
- expect(
296
- (doc.put.responses?.['200'] as any).content['application/json'].schema,
297
- ).toMatchObject({
298
- type: 'object',
299
- properties: {
300
- id: { type: 'string' },
301
- name: { type: 'string' },
302
- email: { type: 'string' },
303
- updatedAt: { type: 'string' },
304
- },
305
- });
306
- });
307
-
308
- it('should handle endpoint without any schemas', async () => {
309
- const endpoint = new Endpoint({
310
- route: '/health',
311
- method: 'GET',
312
- authorize: undefined,
313
- fn: async () => ({ status: 'ok' }),
314
- status: undefined,
315
- getSession: undefined,
316
- input: undefined,
317
- output: undefined,
318
- services: [],
319
- logger: {} as any,
320
- timeout: undefined,
321
- memorySize: undefined,
322
- description: undefined,
323
- });
324
-
325
- const spec = await endpoint.toOpenApi3Route();
326
-
327
- expect(spec).toEqual({
328
- '/health': {
329
- get: {
330
- responses: {
331
- '200': {
332
- description: 'Successful response',
333
- },
334
- },
335
- },
336
- },
337
- });
338
- });
339
-
340
- it('should not include body for GET endpoint even if provided', async () => {
341
- const bodySchema = z.object({ invalid: z.string() });
342
-
343
- const endpoint = new Endpoint({
344
- route: '/users',
345
- method: 'GET',
346
- status: undefined,
347
- getSession: undefined,
348
- authorize: undefined,
349
- output: z.object({
350
- users: z.array(z.object({ id: z.string(), name: z.string() })),
351
- }),
352
- fn: async ({}) => ({
353
- users: [],
354
- }),
355
- input: {
356
- body: bodySchema,
357
- },
358
- services: [],
359
- logger: {} as any,
360
- timeout: undefined,
361
- memorySize: undefined,
362
- description: undefined,
363
- });
364
-
365
- const spec = await endpoint.toOpenApi3Route();
366
-
367
- expect(spec['/users']!.get).not.toHaveProperty('requestBody');
368
- });
369
-
370
- it('should correctly separate path and query parameters', async () => {
371
- const paramsSchema = z.object({
372
- userId: z.string(),
373
- itemId: z.string(),
374
- });
375
- const querySchema = z.object({
376
- limit: z.number().optional(),
377
- offset: z.number().optional(),
378
- filter: z.string(),
379
- });
380
-
381
- const endpoint = new Endpoint({
382
- route: '/users/:userId/items/:itemId',
383
- method: 'GET',
384
- description: 'Get user item with pagination',
385
- fn: async () => ({}),
386
- input: {
387
- params: paramsSchema,
388
- query: querySchema,
389
- },
390
- output: undefined,
391
- services: [],
392
- logger: {} as any,
393
- timeout: undefined,
394
- memorySize: undefined,
395
- status: undefined,
396
- getSession: undefined,
397
- authorize: undefined,
398
- });
399
-
400
- const spec = await endpoint.toOpenApi3Route();
401
- const doc = spec['/users/{userId}/items/{itemId}'];
402
-
403
- // Path parameters should be at route level
404
- expect(doc.parameters).toBeDefined();
405
- expect(doc.parameters).toHaveLength(2);
406
- expect(doc.parameters).toContainEqual({
407
- name: 'userId',
408
- in: 'path',
409
- required: true,
410
- schema: { type: 'string' },
411
- });
412
- expect(doc.parameters).toContainEqual({
413
- name: 'itemId',
414
- in: 'path',
415
- required: true,
416
- schema: { type: 'string' },
417
- });
418
-
419
- // Query parameters should be at method level
420
- expect(doc.get.parameters).toBeDefined();
421
- expect(doc.get.parameters).toHaveLength(3);
422
- expect(doc.get.parameters).toContainEqual({
423
- name: 'limit',
424
- in: 'query',
425
- required: false,
426
- schema: { type: 'number' },
427
- });
428
- expect(doc.get.parameters).toContainEqual({
429
- name: 'offset',
430
- in: 'query',
431
- required: false,
432
- schema: { type: 'number' },
433
- });
434
- expect(doc.get.parameters).toContainEqual({
435
- name: 'filter',
436
- in: 'query',
437
- required: true,
438
- schema: { type: 'string' },
439
- });
440
- });
441
- });
442
-
443
- describe('authorize property', () => {
444
- const mockLogger: Logger = {
445
- debug: vi.fn(),
446
- info: vi.fn(),
447
- warn: vi.fn(),
448
- error: vi.fn(),
449
- fatal: vi.fn(),
450
- trace: vi.fn(),
451
- child: vi.fn(() => mockLogger),
452
- };
453
-
454
- const services = ServiceDiscovery.getInstance(
455
- mockLogger,
456
- new EnvironmentParser({}),
457
- );
458
-
459
- it('should have default authorize function that returns true', async () => {
460
- const endpoint = new Endpoint({
461
- route: '/test',
462
- method: 'GET',
463
- fn: async () => ({ success: true }),
464
- input: undefined,
465
- output: undefined,
466
- services: [],
467
- authorize: undefined,
468
- logger: mockLogger,
469
- timeout: undefined,
470
- memorySize: undefined,
471
- status: undefined,
472
- getSession: undefined,
473
- description: undefined,
474
- });
475
-
476
- const result = await endpoint.authorize({
477
- header: vi.fn(),
478
- services,
479
- logger: mockLogger,
480
- session: {},
481
- cookie: vi.fn(),
482
- });
483
-
484
- expect(result).toBe(true);
485
- });
486
-
487
- it('should allow custom authorize function', async () => {
488
- const endpoint = new Endpoint({
489
- route: '/test',
490
- method: 'GET',
491
- fn: async () => ({ success: true }),
492
- input: undefined,
493
- output: undefined,
494
- services: [],
495
- logger: mockLogger,
496
- authorize: undefined,
497
- timeout: undefined,
498
- memorySize: undefined,
499
- status: undefined,
500
- getSession: undefined,
501
- description: undefined,
502
- });
503
-
504
- const customAuthFn = vi.fn().mockResolvedValue(false);
505
- endpoint.authorize = customAuthFn;
506
-
507
- const mockContext = {
508
- header: vi.fn(),
509
- services,
510
- logger: mockLogger,
511
- session: {},
512
- cookie: vi.fn(),
513
- };
514
-
515
- const result = await endpoint.authorize(mockContext);
516
-
517
- expect(result).toBe(false);
518
- expect(customAuthFn).toHaveBeenCalledWith(mockContext);
519
- });
520
-
521
- it('should support synchronous authorize function', () => {
522
- const endpoint = new Endpoint({
523
- route: '/test',
524
- method: 'GET',
525
- fn: async () => ({ success: true }),
526
- input: undefined,
527
- output: undefined,
528
- services: [],
529
- logger: mockLogger,
530
- timeout: undefined,
531
- memorySize: undefined,
532
- authorize: undefined,
533
- status: undefined,
534
- getSession: undefined,
535
- description: undefined,
536
- });
537
-
538
- const syncAuthFn = vi.fn().mockReturnValue(true);
539
- endpoint.authorize = syncAuthFn;
540
-
541
- const mockContext = {
542
- header: vi.fn(),
543
- services,
544
- logger: mockLogger,
545
- session: {},
546
- cookie: vi.fn(),
547
- };
548
-
549
- const result = endpoint.authorize(mockContext);
550
-
551
- expect(result).toBe(true);
552
- expect(syncAuthFn).toHaveBeenCalledWith(mockContext);
553
- });
554
-
555
- it('should receive header function in context', async () => {
556
- const endpoint = new Endpoint({
557
- route: '/test',
558
- method: 'GET',
559
- fn: async () => ({ success: true }),
560
- input: undefined,
561
- output: undefined,
562
- services: [],
563
- authorize: undefined,
564
- logger: mockLogger,
565
- timeout: undefined,
566
- memorySize: undefined,
567
- status: undefined,
568
- getSession: undefined,
569
- description: undefined,
570
- });
571
-
572
- const headerFn = vi.fn().mockReturnValue('Bearer token123');
573
-
574
- endpoint.authorize = ({ header }) => {
575
- return header('authorization') === 'Bearer token123';
576
- };
577
-
578
- const result = await endpoint.authorize({
579
- header: headerFn,
580
- services,
581
- logger: mockLogger,
582
- session: {},
583
- cookie: vi.fn(),
584
- });
585
-
586
- expect(result).toBe(true);
587
- expect(headerFn).toHaveBeenCalledWith('authorization');
588
- });
589
-
590
- it('should receive services in context', async () => {
591
- const TestService = {
592
- serviceName: 'TestService' as const,
593
- register() {
594
- return {
595
- validateUser(id: string) {
596
- return id === 'valid';
597
- },
598
- };
599
- },
600
- };
601
-
602
- await services.register([TestService]);
603
- const endpoint = new Endpoint({
604
- route: '/test',
605
- method: 'GET',
606
- fn: async () => ({ success: true }),
607
- input: undefined,
608
- output: undefined,
609
- services: [TestService],
610
- logger: mockLogger,
611
- timeout: undefined,
612
- memorySize: undefined,
613
- status: undefined,
614
- authorize: async ({ services }) => {
615
- return services.TestService.validateUser('valid');
616
- },
617
- getSession: undefined,
618
- description: undefined,
619
- });
620
-
621
- const result = await endpoint.authorize({
622
- header: vi.fn(),
623
- services: { TestService: TestService.register() },
624
- logger: mockLogger,
625
- session: {},
626
- cookie: vi.fn(),
627
- });
628
-
629
- expect(result).toBe(true);
630
- });
631
-
632
- it('should receive logger in context', async () => {
633
- const endpoint = new Endpoint({
634
- route: '/test',
635
- method: 'GET',
636
- fn: async () => ({ success: true }),
637
- input: undefined,
638
- output: undefined,
639
- authorize: undefined,
640
- services: [],
641
- logger: mockLogger,
642
- timeout: undefined,
643
- memorySize: undefined,
644
- status: undefined,
645
- getSession: undefined,
646
- description: undefined,
647
- });
648
-
649
- const loggerSpy = vi.fn();
650
- const testLogger = {
651
- ...mockLogger,
652
- info: loggerSpy,
653
- };
654
-
655
- endpoint.authorize = ({ logger }) => {
656
- logger.info('Authorization check');
657
- return true;
658
- };
659
-
660
- const result = await endpoint.authorize({
661
- header: vi.fn(),
662
- services,
663
- logger: testLogger,
664
- cookie: vi.fn(),
665
- session: {},
666
- });
667
-
668
- expect(result).toBe(true);
669
- expect(loggerSpy).toHaveBeenCalledWith('Authorization check');
670
- });
671
-
672
- it('should receive session in context', async () => {
673
- const endpoint = new Endpoint({
674
- route: '/test',
675
- method: 'GET',
676
- fn: async () => ({ success: true }),
677
- input: undefined,
678
- output: undefined,
679
- authorize: undefined,
680
- services: [],
681
- logger: mockLogger,
682
- timeout: undefined,
683
- memorySize: undefined,
684
- status: undefined,
685
- getSession: () => ({ role: 'admin' }),
686
- description: undefined,
687
- });
688
-
689
- const mockSession = { userId: 'user123', role: 'admin' };
690
-
691
- endpoint.authorize = ({ session }) => {
692
- return session.role === 'admin';
693
- };
694
-
695
- const result = await endpoint.authorize({
696
- header: vi.fn(),
697
- services,
698
- logger: mockLogger,
699
- session: mockSession,
700
- cookie: vi.fn(),
701
- });
702
-
703
- expect(result).toBe(true);
704
- });
705
-
706
- it('should handle authorize function that throws error', async () => {
707
- const endpoint = new Endpoint({
708
- route: '/test',
709
- method: 'GET',
710
- fn: async () => ({ success: true }),
711
- input: undefined,
712
- output: undefined,
713
- services: [],
714
- authorize: async () => {
715
- throw new Error('Authorization failed');
716
- },
717
-
718
- logger: mockLogger,
719
- timeout: undefined,
720
- memorySize: undefined,
721
- status: undefined,
722
- getSession: undefined,
723
- description: undefined,
724
- });
725
-
726
- await expect(() =>
727
- endpoint.authorize({
728
- header: vi.fn(),
729
- services,
730
- logger: mockLogger,
731
- session: {},
732
- cookie: vi.fn(),
733
- }),
734
- ).rejects.toThrow('Authorization failed');
735
- });
736
-
737
- it('should handle async authorize function that throws error', async () => {
738
- const endpoint = new Endpoint({
739
- route: '/test',
740
- method: 'GET',
741
- fn: async () => ({ success: true }),
742
- input: undefined,
743
- output: undefined,
744
- services: [],
745
- logger: mockLogger,
746
- timeout: undefined,
747
- memorySize: undefined,
748
- authorize: undefined,
749
- status: undefined,
750
- getSession: undefined,
751
- description: undefined,
752
- });
753
-
754
- endpoint.authorize = async () => {
755
- throw new Error('Async authorization failed');
756
- };
757
-
758
- await expect(
759
- endpoint.authorize({
760
- header: vi.fn(),
761
- services,
762
- logger: mockLogger,
763
- session: {},
764
- cookie: vi.fn(),
765
- }),
766
- ).rejects.toThrow('Async authorization failed');
767
- });
768
-
769
- it('should work with complex authorization logic', async () => {
770
- const endpoint = new Endpoint({
771
- route: '/admin/users',
772
- method: 'GET',
773
- authorize: undefined,
774
- fn: async () => ({ users: [] }),
775
- input: undefined,
776
- output: undefined,
777
- services: [],
778
- logger: mockLogger,
779
- timeout: undefined,
780
- memorySize: undefined,
781
- status: undefined,
782
- getSession: undefined,
783
- description: undefined,
784
- });
785
-
786
- endpoint.authorize = async ({ header, session }) => {
787
- // Simulate complex authorization logic
788
- const token = header('authorization');
789
- if (!token) return false;
790
-
791
- const user = session as any;
792
- if (!user?.role) return false;
793
-
794
- return user.role === 'admin' || user.role === 'superuser';
795
- };
796
-
797
- // Test with admin role
798
- const adminResult = await endpoint.authorize({
799
- header: vi.fn().mockReturnValue('Bearer admin-token'),
800
- services,
801
- logger: mockLogger,
802
- cookie: vi.fn(),
803
- session: { userId: 'admin1', role: 'admin' },
804
- });
805
-
806
- expect(adminResult).toBe(true);
807
-
808
- // Test with user role
809
- const userResult = await endpoint.authorize({
810
- header: vi.fn().mockReturnValue('Bearer user-token'),
811
- services,
812
- cookie: vi.fn(),
813
- logger: mockLogger,
814
- session: { userId: 'user1', role: 'user' },
815
- });
816
-
817
- expect(userResult).toBe(false);
818
-
819
- // Test with no token
820
- const noTokenResult = await endpoint.authorize({
821
- header: vi.fn().mockReturnValue(undefined),
822
- services,
823
- logger: mockLogger,
824
- session: { userId: 'user1', role: 'admin' },
825
- cookie: vi.fn(),
826
- });
827
-
828
- expect(noTokenResult).toBe(false);
829
- });
830
- });
9
+ describe('toOpenApi3Route', () => {
10
+ it('should generate basic OpenAPI spec for GET endpoint', async () => {
11
+ const endpoint = new Endpoint({
12
+ route: '/users',
13
+ method: 'GET',
14
+ authorize: undefined,
15
+ description: 'Get all users',
16
+ fn: async () => [],
17
+ input: undefined,
18
+ status: undefined,
19
+ getSession: undefined,
20
+ output: undefined,
21
+ services: [],
22
+ logger: {} as any,
23
+ timeout: undefined,
24
+ memorySize: undefined,
25
+ });
26
+
27
+ const spec = await endpoint.toOpenApi3Route();
28
+
29
+ expect(spec).toEqual({
30
+ '/users': {
31
+ get: {
32
+ description: 'Get all users',
33
+ responses: {
34
+ '200': {
35
+ description: 'Successful response',
36
+ },
37
+ },
38
+ },
39
+ },
40
+ });
41
+ });
42
+
43
+ it('should include response schema when output is defined', async () => {
44
+ const outputSchema = z.object({
45
+ id: z.string(),
46
+ name: z.string(),
47
+ });
48
+
49
+ const endpoint = new Endpoint({
50
+ route: '/users/:id',
51
+ method: 'GET',
52
+ description: 'Get user by ID',
53
+ fn: async () => ({ id: '1', name: 'John' }),
54
+ input: undefined,
55
+ output: outputSchema,
56
+ authorize: undefined,
57
+ services: [],
58
+ status: undefined,
59
+ getSession: undefined,
60
+ logger: {} as any,
61
+ timeout: undefined,
62
+ memorySize: undefined,
63
+ });
64
+
65
+ const spec = await endpoint.toOpenApi3Route();
66
+ const doc = spec['/users/{id}'];
67
+ expect(doc.get.responses?.['200']).toHaveProperty('content');
68
+ expect(
69
+ (doc.get.responses?.['200'] as any).content['application/json'].schema,
70
+ ).toMatchObject({
71
+ type: 'object',
72
+ properties: {
73
+ id: { type: 'string' },
74
+ name: { type: 'string' },
75
+ },
76
+ required: ['id', 'name'],
77
+ });
78
+ });
79
+
80
+ it('should include request body for POST endpoint', async () => {
81
+ const bodySchema = z.object({
82
+ name: z.string(),
83
+ email: z.string().email(),
84
+ });
85
+
86
+ const endpoint = new Endpoint({
87
+ route: '/users',
88
+ method: 'POST',
89
+ authorize: undefined,
90
+ description: 'Create a new user',
91
+ fn: async (ctx) => ({ id: '1', ...(ctx as any).body }),
92
+ input: {
93
+ body: bodySchema,
94
+ },
95
+ output: undefined,
96
+ status: undefined,
97
+ getSession: undefined,
98
+ services: [],
99
+ logger: {} as any,
100
+ timeout: undefined,
101
+ memorySize: undefined,
102
+ });
103
+
104
+ const spec = await endpoint.toOpenApi3Route();
105
+
106
+ expect(spec['/users']?.post).toHaveProperty('requestBody');
107
+ expect((spec['/users']?.post! as any).requestBody).toMatchObject({
108
+ required: true,
109
+ content: {
110
+ 'application/json': {
111
+ schema: {
112
+ type: 'object',
113
+ properties: {
114
+ name: { type: 'string' },
115
+ email: { type: 'string', format: 'email' },
116
+ },
117
+ required: ['name', 'email'],
118
+ },
119
+ },
120
+ },
121
+ });
122
+ });
123
+
124
+ it('should include path parameters at route level', async () => {
125
+ const paramsSchema = z.object({
126
+ id: z.string(),
127
+ subId: z.string().optional(),
128
+ });
129
+
130
+ const endpoint = new Endpoint({
131
+ route: '/users/:id/items/:subId',
132
+ method: 'GET',
133
+ status: undefined,
134
+ authorize: undefined,
135
+ getSession: undefined,
136
+ description: 'Get user item',
137
+ fn: async (ctx) => ({
138
+ userId: (ctx as any).params.id,
139
+ itemId: (ctx as any).params.subId,
140
+ }),
141
+ input: {
142
+ params: paramsSchema,
143
+ },
144
+ output: undefined,
145
+ services: [],
146
+ logger: {} as any,
147
+ timeout: undefined,
148
+ memorySize: undefined,
149
+ });
150
+
151
+ const spec = await endpoint.toOpenApi3Route();
152
+
153
+ const doc = spec['/users/{id}/items/{subId}'];
154
+
155
+ // Path parameters should be at route level, not method level
156
+ expect(doc).toHaveProperty('parameters');
157
+ const parameters = doc.parameters;
158
+
159
+ expect(parameters).toHaveLength(2);
160
+ expect(parameters).toContainEqual({
161
+ name: 'id',
162
+ in: 'path',
163
+ required: true,
164
+ schema: { type: 'string' },
165
+ });
166
+ expect(parameters).toContainEqual({
167
+ name: 'subId',
168
+ in: 'path',
169
+ required: false,
170
+ schema: { type: 'string' },
171
+ });
172
+
173
+ // Method should not have path parameters
174
+ expect(doc.get.parameters).toBeUndefined();
175
+ });
176
+
177
+ it('should include query parameters', async () => {
178
+ const searchSchema = z.object({
179
+ page: z.number().optional(),
180
+ limit: z.number().optional(),
181
+ sort: z.enum(['asc', 'desc']),
182
+ });
183
+
184
+ const endpoint = new Endpoint({
185
+ route: '/users',
186
+ method: 'GET',
187
+ authorize: undefined,
188
+ description: 'List users with pagination',
189
+ fn: async (_ctx) => [],
190
+ input: {
191
+ query: searchSchema,
192
+ },
193
+ output: undefined,
194
+ services: [],
195
+ logger: {} as any,
196
+ timeout: undefined,
197
+ memorySize: undefined,
198
+ status: undefined,
199
+ getSession: undefined,
200
+ });
201
+
202
+ const spec = await endpoint.toOpenApi3Route();
203
+
204
+ expect(spec['/users']?.get).toHaveProperty('parameters');
205
+ const parameters = (spec['/users']?.get! as any).parameters;
206
+
207
+ expect(parameters).toHaveLength(3);
208
+ expect(parameters).toContainEqual({
209
+ name: 'page',
210
+ in: 'query',
211
+ required: false,
212
+ schema: { type: 'number' },
213
+ });
214
+ expect(parameters).toContainEqual({
215
+ name: 'limit',
216
+ in: 'query',
217
+ required: false,
218
+ schema: { type: 'number' },
219
+ });
220
+ expect(parameters).toContainEqual({
221
+ name: 'sort',
222
+ in: 'query',
223
+ required: true,
224
+ schema: { type: 'string', enum: ['asc', 'desc'] },
225
+ });
226
+ });
227
+
228
+ it('should handle PUT endpoint with body and params', async () => {
229
+ const bodySchema = z.object({
230
+ name: z.string(),
231
+ email: z.string().email(),
232
+ });
233
+ const paramsSchema = z.object({
234
+ id: z.string(),
235
+ });
236
+ const outputSchema = z.object({
237
+ id: z.string(),
238
+ name: z.string(),
239
+ email: z.string(),
240
+ updatedAt: z.string(),
241
+ });
242
+
243
+ const endpoint = new Endpoint({
244
+ route: '/users/:id',
245
+ method: 'PUT',
246
+ description: 'Update user',
247
+ status: undefined,
248
+ getSession: undefined,
249
+ authorize: undefined,
250
+ fn: async (ctx) => ({
251
+ id: (ctx as any).params.id,
252
+ ...(ctx as any).body,
253
+ updatedAt: new Date().toISOString(),
254
+ }),
255
+ input: {
256
+ body: bodySchema,
257
+ params: paramsSchema,
258
+ },
259
+ output: outputSchema,
260
+ services: [],
261
+ logger: {} as any,
262
+ timeout: undefined,
263
+ memorySize: undefined,
264
+ });
265
+
266
+ const spec = await endpoint.toOpenApi3Route();
267
+ const doc = spec['/users/{id}'];
268
+
269
+ // Check request body
270
+ expect(doc.put).toHaveProperty('requestBody');
271
+ expect(
272
+ (doc.put as any).requestBody.content['application/json'].schema,
273
+ ).toMatchObject({
274
+ type: 'object',
275
+ properties: {
276
+ name: { type: 'string' },
277
+ email: { type: 'string', format: 'email' },
278
+ },
279
+ });
280
+
281
+ // Check path parameters at route level
282
+ expect(doc).toHaveProperty('parameters');
283
+ expect(doc.parameters).toHaveLength(1);
284
+ expect(doc.parameters?.[0]).toEqual({
285
+ name: 'id',
286
+ in: 'path',
287
+ required: true,
288
+ schema: { type: 'string' },
289
+ });
290
+
291
+ // Method should not have path parameters
292
+ expect((doc.put as any).parameters).toBeUndefined();
293
+
294
+ // Check response
295
+ expect(
296
+ (doc.put.responses?.['200'] as any).content['application/json'].schema,
297
+ ).toMatchObject({
298
+ type: 'object',
299
+ properties: {
300
+ id: { type: 'string' },
301
+ name: { type: 'string' },
302
+ email: { type: 'string' },
303
+ updatedAt: { type: 'string' },
304
+ },
305
+ });
306
+ });
307
+
308
+ it('should handle endpoint without any schemas', async () => {
309
+ const endpoint = new Endpoint({
310
+ route: '/health',
311
+ method: 'GET',
312
+ authorize: undefined,
313
+ fn: async () => ({ status: 'ok' }),
314
+ status: undefined,
315
+ getSession: undefined,
316
+ input: undefined,
317
+ output: undefined,
318
+ services: [],
319
+ logger: {} as any,
320
+ timeout: undefined,
321
+ memorySize: undefined,
322
+ description: undefined,
323
+ });
324
+
325
+ const spec = await endpoint.toOpenApi3Route();
326
+
327
+ expect(spec).toEqual({
328
+ '/health': {
329
+ get: {
330
+ responses: {
331
+ '200': {
332
+ description: 'Successful response',
333
+ },
334
+ },
335
+ },
336
+ },
337
+ });
338
+ });
339
+
340
+ it('should not include body for GET endpoint even if provided', async () => {
341
+ const bodySchema = z.object({ invalid: z.string() });
342
+
343
+ const endpoint = new Endpoint({
344
+ route: '/users',
345
+ method: 'GET',
346
+ status: undefined,
347
+ getSession: undefined,
348
+ authorize: undefined,
349
+ output: z.object({
350
+ users: z.array(z.object({ id: z.string(), name: z.string() })),
351
+ }),
352
+ fn: async () => ({
353
+ users: [],
354
+ }),
355
+ input: {
356
+ body: bodySchema,
357
+ },
358
+ services: [],
359
+ logger: {} as any,
360
+ timeout: undefined,
361
+ memorySize: undefined,
362
+ description: undefined,
363
+ });
364
+
365
+ const spec = await endpoint.toOpenApi3Route();
366
+
367
+ expect(spec['/users']?.get).not.toHaveProperty('requestBody');
368
+ });
369
+
370
+ it('should correctly separate path and query parameters', async () => {
371
+ const paramsSchema = z.object({
372
+ userId: z.string(),
373
+ itemId: z.string(),
374
+ });
375
+ const querySchema = z.object({
376
+ limit: z.number().optional(),
377
+ offset: z.number().optional(),
378
+ filter: z.string(),
379
+ });
380
+
381
+ const endpoint = new Endpoint({
382
+ route: '/users/:userId/items/:itemId',
383
+ method: 'GET',
384
+ description: 'Get user item with pagination',
385
+ fn: async () => ({}),
386
+ input: {
387
+ params: paramsSchema,
388
+ query: querySchema,
389
+ },
390
+ output: undefined,
391
+ services: [],
392
+ logger: {} as any,
393
+ timeout: undefined,
394
+ memorySize: undefined,
395
+ status: undefined,
396
+ getSession: undefined,
397
+ authorize: undefined,
398
+ });
399
+
400
+ const spec = await endpoint.toOpenApi3Route();
401
+ const doc = spec['/users/{userId}/items/{itemId}'];
402
+
403
+ // Path parameters should be at route level
404
+ expect(doc.parameters).toBeDefined();
405
+ expect(doc.parameters).toHaveLength(2);
406
+ expect(doc.parameters).toContainEqual({
407
+ name: 'userId',
408
+ in: 'path',
409
+ required: true,
410
+ schema: { type: 'string' },
411
+ });
412
+ expect(doc.parameters).toContainEqual({
413
+ name: 'itemId',
414
+ in: 'path',
415
+ required: true,
416
+ schema: { type: 'string' },
417
+ });
418
+
419
+ // Query parameters should be at method level
420
+ expect(doc.get.parameters).toBeDefined();
421
+ expect(doc.get.parameters).toHaveLength(3);
422
+ expect(doc.get.parameters).toContainEqual({
423
+ name: 'limit',
424
+ in: 'query',
425
+ required: false,
426
+ schema: { type: 'number' },
427
+ });
428
+ expect(doc.get.parameters).toContainEqual({
429
+ name: 'offset',
430
+ in: 'query',
431
+ required: false,
432
+ schema: { type: 'number' },
433
+ });
434
+ expect(doc.get.parameters).toContainEqual({
435
+ name: 'filter',
436
+ in: 'query',
437
+ required: true,
438
+ schema: { type: 'string' },
439
+ });
440
+ });
441
+ });
442
+
443
+ describe('authorize property', () => {
444
+ const mockLogger: Logger = {
445
+ debug: vi.fn(),
446
+ info: vi.fn(),
447
+ warn: vi.fn(),
448
+ error: vi.fn(),
449
+ fatal: vi.fn(),
450
+ trace: vi.fn(),
451
+ child: vi.fn(() => mockLogger),
452
+ };
453
+
454
+ const services = ServiceDiscovery.getInstance(new EnvironmentParser({}));
455
+
456
+ it('should have default authorize function that returns true', async () => {
457
+ const endpoint = new Endpoint({
458
+ route: '/test',
459
+ method: 'GET',
460
+ fn: async () => ({ success: true }),
461
+ input: undefined,
462
+ output: undefined,
463
+ services: [],
464
+ authorize: undefined,
465
+ logger: mockLogger,
466
+ timeout: undefined,
467
+ memorySize: undefined,
468
+ status: undefined,
469
+ getSession: undefined,
470
+ description: undefined,
471
+ });
472
+
473
+ const result = await endpoint.authorize({
474
+ header: vi.fn(),
475
+ services,
476
+ logger: mockLogger,
477
+ session: {},
478
+ cookie: vi.fn(),
479
+ });
480
+
481
+ expect(result).toBe(true);
482
+ });
483
+
484
+ it('should allow custom authorize function', async () => {
485
+ const endpoint = new Endpoint({
486
+ route: '/test',
487
+ method: 'GET',
488
+ fn: async () => ({ success: true }),
489
+ input: undefined,
490
+ output: undefined,
491
+ services: [],
492
+ logger: mockLogger,
493
+ authorize: undefined,
494
+ timeout: undefined,
495
+ memorySize: undefined,
496
+ status: undefined,
497
+ getSession: undefined,
498
+ description: undefined,
499
+ });
500
+
501
+ const customAuthFn = vi.fn().mockResolvedValue(false);
502
+ endpoint.authorize = customAuthFn;
503
+
504
+ const mockContext = {
505
+ header: vi.fn(),
506
+ services,
507
+ logger: mockLogger,
508
+ session: {},
509
+ cookie: vi.fn(),
510
+ };
511
+
512
+ const result = await endpoint.authorize(mockContext);
513
+
514
+ expect(result).toBe(false);
515
+ expect(customAuthFn).toHaveBeenCalledWith(mockContext);
516
+ });
517
+
518
+ it('should support synchronous authorize function', () => {
519
+ const endpoint = new Endpoint({
520
+ route: '/test',
521
+ method: 'GET',
522
+ fn: async () => ({ success: true }),
523
+ input: undefined,
524
+ output: undefined,
525
+ services: [],
526
+ logger: mockLogger,
527
+ timeout: undefined,
528
+ memorySize: undefined,
529
+ authorize: undefined,
530
+ status: undefined,
531
+ getSession: undefined,
532
+ description: undefined,
533
+ });
534
+
535
+ const syncAuthFn = vi.fn().mockReturnValue(true);
536
+ endpoint.authorize = syncAuthFn;
537
+
538
+ const mockContext = {
539
+ header: vi.fn(),
540
+ services,
541
+ logger: mockLogger,
542
+ session: {},
543
+ cookie: vi.fn(),
544
+ };
545
+
546
+ const result = endpoint.authorize(mockContext);
547
+
548
+ expect(result).toBe(true);
549
+ expect(syncAuthFn).toHaveBeenCalledWith(mockContext);
550
+ });
551
+
552
+ it('should receive header function in context', async () => {
553
+ const endpoint = new Endpoint({
554
+ route: '/test',
555
+ method: 'GET',
556
+ fn: async () => ({ success: true }),
557
+ input: undefined,
558
+ output: undefined,
559
+ services: [],
560
+ authorize: undefined,
561
+ logger: mockLogger,
562
+ timeout: undefined,
563
+ memorySize: undefined,
564
+ status: undefined,
565
+ getSession: undefined,
566
+ description: undefined,
567
+ });
568
+
569
+ const headerFn = vi.fn().mockReturnValue('Bearer token123');
570
+
571
+ endpoint.authorize = ({ header }) => {
572
+ return header('authorization') === 'Bearer token123';
573
+ };
574
+
575
+ const result = await endpoint.authorize({
576
+ header: headerFn,
577
+ services,
578
+ logger: mockLogger,
579
+ session: {},
580
+ cookie: vi.fn(),
581
+ });
582
+
583
+ expect(result).toBe(true);
584
+ expect(headerFn).toHaveBeenCalledWith('authorization');
585
+ });
586
+
587
+ it('should receive services in context', async () => {
588
+ const TestService = {
589
+ serviceName: 'TestService' as const,
590
+ register() {
591
+ return {
592
+ validateUser(id: string) {
593
+ return id === 'valid';
594
+ },
595
+ };
596
+ },
597
+ };
598
+
599
+ await services.register([TestService]);
600
+ const endpoint = new Endpoint({
601
+ route: '/test',
602
+ method: 'GET',
603
+ fn: async () => ({ success: true }),
604
+ input: undefined,
605
+ output: undefined,
606
+ services: [TestService],
607
+ logger: mockLogger,
608
+ timeout: undefined,
609
+ memorySize: undefined,
610
+ status: undefined,
611
+ authorize: async ({ services }) => {
612
+ return services.TestService.validateUser('valid');
613
+ },
614
+ getSession: undefined,
615
+ description: undefined,
616
+ });
617
+
618
+ const result = await endpoint.authorize({
619
+ header: vi.fn(),
620
+ services: { TestService: TestService.register() },
621
+ logger: mockLogger,
622
+ session: {},
623
+ cookie: vi.fn(),
624
+ });
625
+
626
+ expect(result).toBe(true);
627
+ });
628
+
629
+ it('should receive logger in context', async () => {
630
+ const endpoint = new Endpoint({
631
+ route: '/test',
632
+ method: 'GET',
633
+ fn: async () => ({ success: true }),
634
+ input: undefined,
635
+ output: undefined,
636
+ authorize: undefined,
637
+ services: [],
638
+ logger: mockLogger,
639
+ timeout: undefined,
640
+ memorySize: undefined,
641
+ status: undefined,
642
+ getSession: undefined,
643
+ description: undefined,
644
+ });
645
+
646
+ const loggerSpy = vi.fn();
647
+ const testLogger = {
648
+ ...mockLogger,
649
+ info: loggerSpy,
650
+ };
651
+
652
+ endpoint.authorize = ({ logger }) => {
653
+ logger.info('Authorization check');
654
+ return true;
655
+ };
656
+
657
+ const result = await endpoint.authorize({
658
+ header: vi.fn(),
659
+ services,
660
+ logger: testLogger,
661
+ cookie: vi.fn(),
662
+ session: {},
663
+ });
664
+
665
+ expect(result).toBe(true);
666
+ expect(loggerSpy).toHaveBeenCalledWith('Authorization check');
667
+ });
668
+
669
+ it('should receive session in context', async () => {
670
+ const endpoint = new Endpoint({
671
+ route: '/test',
672
+ method: 'GET',
673
+ fn: async () => ({ success: true }),
674
+ input: undefined,
675
+ output: undefined,
676
+ authorize: undefined,
677
+ services: [],
678
+ logger: mockLogger,
679
+ timeout: undefined,
680
+ memorySize: undefined,
681
+ status: undefined,
682
+ getSession: () => ({ role: 'admin' }),
683
+ description: undefined,
684
+ });
685
+
686
+ const mockSession = { userId: 'user123', role: 'admin' };
687
+
688
+ endpoint.authorize = ({ session }) => {
689
+ return session.role === 'admin';
690
+ };
691
+
692
+ const result = await endpoint.authorize({
693
+ header: vi.fn(),
694
+ services,
695
+ logger: mockLogger,
696
+ session: mockSession,
697
+ cookie: vi.fn(),
698
+ });
699
+
700
+ expect(result).toBe(true);
701
+ });
702
+
703
+ it('should handle authorize function that throws error', async () => {
704
+ const endpoint = new Endpoint({
705
+ route: '/test',
706
+ method: 'GET',
707
+ fn: async () => ({ success: true }),
708
+ input: undefined,
709
+ output: undefined,
710
+ services: [],
711
+ authorize: async () => {
712
+ throw new Error('Authorization failed');
713
+ },
714
+
715
+ logger: mockLogger,
716
+ timeout: undefined,
717
+ memorySize: undefined,
718
+ status: undefined,
719
+ getSession: undefined,
720
+ description: undefined,
721
+ });
722
+
723
+ await expect(() =>
724
+ endpoint.authorize({
725
+ header: vi.fn(),
726
+ services,
727
+ logger: mockLogger,
728
+ session: {},
729
+ cookie: vi.fn(),
730
+ }),
731
+ ).rejects.toThrow('Authorization failed');
732
+ });
733
+
734
+ it('should handle async authorize function that throws error', async () => {
735
+ const endpoint = new Endpoint({
736
+ route: '/test',
737
+ method: 'GET',
738
+ fn: async () => ({ success: true }),
739
+ input: undefined,
740
+ output: undefined,
741
+ services: [],
742
+ logger: mockLogger,
743
+ timeout: undefined,
744
+ memorySize: undefined,
745
+ authorize: undefined,
746
+ status: undefined,
747
+ getSession: undefined,
748
+ description: undefined,
749
+ });
750
+
751
+ endpoint.authorize = async () => {
752
+ throw new Error('Async authorization failed');
753
+ };
754
+
755
+ await expect(
756
+ endpoint.authorize({
757
+ header: vi.fn(),
758
+ services,
759
+ logger: mockLogger,
760
+ session: {},
761
+ cookie: vi.fn(),
762
+ }),
763
+ ).rejects.toThrow('Async authorization failed');
764
+ });
765
+
766
+ it('should work with complex authorization logic', async () => {
767
+ const endpoint = new Endpoint({
768
+ route: '/admin/users',
769
+ method: 'GET',
770
+ authorize: undefined,
771
+ fn: async () => ({ users: [] }),
772
+ input: undefined,
773
+ output: undefined,
774
+ services: [],
775
+ logger: mockLogger,
776
+ timeout: undefined,
777
+ memorySize: undefined,
778
+ status: undefined,
779
+ getSession: undefined,
780
+ description: undefined,
781
+ });
782
+
783
+ endpoint.authorize = async ({ header, session }) => {
784
+ // Simulate complex authorization logic
785
+ const token = header('authorization');
786
+ if (!token) return false;
787
+
788
+ const user = session as any;
789
+ if (!user?.role) return false;
790
+
791
+ return user.role === 'admin' || user.role === 'superuser';
792
+ };
793
+
794
+ // Test with admin role
795
+ const adminResult = await endpoint.authorize({
796
+ header: vi.fn().mockReturnValue('Bearer admin-token'),
797
+ services,
798
+ logger: mockLogger,
799
+ cookie: vi.fn(),
800
+ session: { userId: 'admin1', role: 'admin' },
801
+ });
802
+
803
+ expect(adminResult).toBe(true);
804
+
805
+ // Test with user role
806
+ const userResult = await endpoint.authorize({
807
+ header: vi.fn().mockReturnValue('Bearer user-token'),
808
+ services,
809
+ cookie: vi.fn(),
810
+ logger: mockLogger,
811
+ session: { userId: 'user1', role: 'user' },
812
+ });
813
+
814
+ expect(userResult).toBe(false);
815
+
816
+ // Test with no token
817
+ const noTokenResult = await endpoint.authorize({
818
+ header: vi.fn().mockReturnValue(undefined),
819
+ services,
820
+ logger: mockLogger,
821
+ session: { userId: 'user1', role: 'admin' },
822
+ cookie: vi.fn(),
823
+ });
824
+
825
+ expect(noTokenResult).toBe(false);
826
+ });
827
+ });
831
828
  });