@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
@@ -5,475 +5,475 @@ import { z } from 'zod';
5
5
  import { EndpointFactory } from '../EndpointFactory';
6
6
 
7
7
  describe('EndpointFactory', () => {
8
- describe('joinPaths', () => {
9
- it('should join simple paths', () => {
10
- expect(EndpointFactory.joinPaths('/users', '/api')).toBe('/api/users');
11
- expect(EndpointFactory.joinPaths('users', '/api')).toBe('/api/users');
12
- expect(EndpointFactory.joinPaths('/users', 'api')).toBe('/api/users');
13
- expect(EndpointFactory.joinPaths('users', 'api')).toBe('/api/users');
14
- });
15
-
16
- it('should handle empty base path', () => {
17
- expect(EndpointFactory.joinPaths('/users', '')).toBe('/users');
18
- expect(EndpointFactory.joinPaths('users', '')).toBe('/users');
19
- });
20
-
21
- it('should handle empty segment path', () => {
22
- expect(EndpointFactory.joinPaths('', '/api')).toBe('/api');
23
- expect(EndpointFactory.joinPaths('', 'api')).toBe('/api');
24
- });
25
-
26
- it('should handle both paths empty', () => {
27
- expect(EndpointFactory.joinPaths('', '')).toBe('/');
28
- });
29
-
30
- it('should handle trailing slashes in base path', () => {
31
- expect(EndpointFactory.joinPaths('/users', '/api/')).toBe('/api/users');
32
- expect(EndpointFactory.joinPaths('users', '/api/')).toBe('/api/users');
33
- expect(EndpointFactory.joinPaths('/users', 'api/')).toBe('/api/users');
34
- expect(EndpointFactory.joinPaths('users', 'api/')).toBe('/api/users');
35
- });
36
-
37
- it('should handle root paths', () => {
38
- expect(EndpointFactory.joinPaths('/users', '/')).toBe('/users');
39
- expect(EndpointFactory.joinPaths('users', '/')).toBe('/users');
40
- expect(EndpointFactory.joinPaths('/', '/')).toBe('/');
41
- });
42
-
43
- it('should handle multiple slashes', () => {
44
- expect(EndpointFactory.joinPaths('//users', '/api')).toBe('/api//users');
45
- expect(EndpointFactory.joinPaths('/users', '//api')).toBe('/api/users');
46
- });
47
-
48
- it('should handle complex paths', () => {
49
- expect(EndpointFactory.joinPaths('/users/:id', '/api/v1')).toBe(
50
- '/api/v1/users/:id',
51
- );
52
- expect(
53
- EndpointFactory.joinPaths(
54
- '/posts/:postId/comments/:commentId',
55
- '/blog',
56
- ),
57
- ).toBe('/blog/posts/:postId/comments/:commentId');
58
- });
59
-
60
- it('should handle paths with query parameters notation', () => {
61
- expect(EndpointFactory.joinPaths('/users?page=1', '/api')).toBe(
62
- '/api/users?page=1',
63
- );
64
- expect(EndpointFactory.joinPaths('/search', '/api')).toBe('/api/search');
65
- });
66
-
67
- it('should handle nested segments', () => {
68
- expect(EndpointFactory.joinPaths('/admin/users', '/api')).toBe(
69
- '/api/admin/users',
70
- );
71
- expect(EndpointFactory.joinPaths('/v2/resources/items', '/api/v1')).toBe(
72
- '/api/v1/v2/resources/items',
73
- );
74
- });
75
-
76
- it('should not add extra slashes when paths already have them', () => {
77
- expect(EndpointFactory.joinPaths('/users', '/api')).toBe('/api/users');
78
- expect(EndpointFactory.joinPaths('/', '/api')).toBe('/api');
79
- });
80
-
81
- it('should preserve path parameters', () => {
82
- expect(EndpointFactory.joinPaths('/:id', '/users')).toBe('/users/:id');
83
- expect(
84
- EndpointFactory.joinPaths('/:userId/posts/:postId', '/api/users'),
85
- ).toBe('/api/users/:userId/posts/:postId');
86
- });
87
-
88
- it('should work with undefined base path (default parameter)', () => {
89
- expect(EndpointFactory.joinPaths('/users')).toBe('/users');
90
- expect(EndpointFactory.joinPaths('users')).toBe('/users');
91
- expect(EndpointFactory.joinPaths('')).toBe('/');
92
- });
93
- });
94
-
95
- describe('authorize', () => {
96
- const mockLogger: Logger = {
97
- debug: vi.fn(),
98
- info: vi.fn(),
99
- warn: vi.fn(),
100
- error: vi.fn(),
101
- fatal: vi.fn(),
102
- trace: vi.fn(),
103
- child: vi.fn(() => mockLogger),
104
- };
105
-
106
- it('should create a factory with authorization function', () => {
107
- const factory = new EndpointFactory();
108
- const authFn = async () => true;
109
-
110
- const authorizedFactory = factory.authorize(authFn);
111
-
112
- expect(authorizedFactory).toBeInstanceOf(EndpointFactory);
113
- expect(authorizedFactory).not.toBe(factory);
114
- });
115
-
116
- it('should apply authorization to created endpoints', async () => {
117
- const authFn = vi.fn().mockResolvedValue(true);
118
- const factory = new EndpointFactory()
119
- .services([])
120
- .logger(mockLogger)
121
- .authorize(authFn);
122
-
123
- const endpoint = factory
124
- .get('/test')
125
- .handle(async () => ({ success: true }));
126
-
127
- expect(endpoint.authorize).toBe(authFn);
128
- });
129
-
130
- it('should handle authorization with different service types', async () => {
131
- const AuthService = {
132
- serviceName: 'AuthService' as const,
133
-
134
- async register() {
135
- return { validateToken: (token: string) => token === 'valid' };
136
- },
137
- };
138
-
139
- const authFn = async ({ header, services }: any) => {
140
- const token = header('authorization')?.replace('Bearer ', '');
141
- return services.AuthService.validateToken(token);
142
- };
143
-
144
- const factory = new EndpointFactory()
145
- .services([AuthService])
146
- .logger(mockLogger)
147
- .authorize(authFn);
148
-
149
- const endpoint = factory
150
- .post('/protected')
151
- .body(z.object({ data: z.string() }))
152
- .handle(async () => ({ success: true }));
153
-
154
- expect(endpoint.authorize).toBe(authFn);
155
- });
156
-
157
- it('should chain with other factory methods', () => {
158
- const authFn = async () => true;
159
- const sessionFn = async () => ({ userId: 'user1' });
160
-
161
- const factory = new EndpointFactory()
162
- .route('/api')
163
- .services([])
164
- .logger(mockLogger)
165
- .authorize(authFn)
166
- .session(sessionFn);
167
-
168
- const endpoint = factory
169
- .get('/test')
170
- .handle(async () => ({ success: true }));
171
-
172
- expect(endpoint.authorize).toBe(authFn);
173
- expect(endpoint.getSession).toBe(sessionFn);
174
- });
175
-
176
- it('should preserve authorization in factory chains', () => {
177
- const authFn = async () => true;
178
- const newLogger = new ConsoleLogger();
179
-
180
- const factory = new EndpointFactory()
181
- .services([])
182
- .authorize(authFn)
183
- .logger(newLogger); // Chain after authorize
184
-
185
- const endpoint = factory
186
- .get('/test')
187
- .handle(async () => ({ success: true }));
188
-
189
- expect(endpoint.authorize).toBe(authFn);
190
- expect(endpoint.logger).toBe(newLogger);
191
- });
192
-
193
- it('should handle authorization function returning boolean', async () => {
194
- const authFn = ({ header }: any) => {
195
- return header('authorization') === 'Bearer valid-token';
196
- };
197
-
198
- const factory = new EndpointFactory()
199
- .services([])
200
- .logger(mockLogger)
201
- .authorize(authFn);
202
-
203
- const endpoint = factory
204
- .get('/test')
205
- .handle(async () => ({ success: true }));
206
-
207
- expect(endpoint.authorize).toBe(authFn);
208
- });
209
-
210
- it('should handle authorization function returning Promise<boolean>', async () => {
211
- const authFn = async ({ header }: any) => {
212
- await new Promise((resolve) => setTimeout(resolve, 1));
213
- return header('authorization') === 'Bearer valid-token';
214
- };
215
-
216
- const factory = new EndpointFactory()
217
- .services([])
218
- .logger(mockLogger)
219
- .authorize(authFn);
220
-
221
- const endpoint = factory
222
- .get('/test')
223
- .handle(async () => ({ success: true }));
224
-
225
- expect(endpoint.authorize).toBe(authFn);
226
- });
227
- });
228
-
229
- describe('route', () => {
230
- it('should create a sub-factory with path prefix', () => {
231
- const factory = new EndpointFactory();
232
- const apiFactory = factory.route('/api');
233
- const v1Factory = apiFactory.route('/v1');
234
-
235
- const endpoint = v1Factory.get('/users').handle(async () => []);
236
-
237
- expect(endpoint.route).toBe('/api/v1/users');
238
- });
239
-
240
- it('should preserve services, auth, and logger in sub-routes', () => {
241
- const authFn = async () => true;
242
- const sessionFn = async () => ({ userId: 'user1' });
243
-
244
- const TestService = {
245
- serviceName: 'TestService' as const,
246
- async register() {
247
- return {};
248
- },
249
- };
250
-
251
- const factory = new EndpointFactory()
252
- .services([TestService])
253
- .authorize(authFn)
254
- .session(sessionFn)
255
- .route('/api');
256
-
257
- const endpoint = factory.get('/test').handle(async () => ({}));
258
-
259
- expect(endpoint.route).toBe('/api/test');
260
- expect(endpoint.authorize).toBe(authFn);
261
- expect(endpoint.getSession).toBe(sessionFn);
262
- });
263
- });
264
-
265
- describe('services', () => {
266
- const Service1 = {
267
- serviceName: 'Service1' as const,
268
- async register() {
269
- return { method1: () => 'service1' };
270
- },
271
- };
272
-
273
- const Service2 = {
274
- serviceName: 'Service2' as const,
275
- async register() {
276
- return { method2: () => 'service2' };
277
- },
278
- };
279
-
280
- it('should add services to factory', () => {
281
- const factory = new EndpointFactory().services([Service1, Service2]);
282
- const endpoint = factory.get('/test').handle(async ({ services }) => ({
283
- result1: (await services[Service1.serviceName]).method1(),
284
- result2: (await services[Service2.serviceName]).method2(),
285
- }));
286
-
287
- expect(endpoint.services).toEqual([Service1, Service2]);
288
- });
289
-
290
- it('should handle duplicate services', () => {
291
- const factory = new EndpointFactory()
292
- .services([Service1])
293
- .services([Service1, Service2]);
294
-
295
- const endpoint = factory.get('/test').handle(async () => ({}));
296
-
297
- // Should contain unique services
298
- const serviceNames = endpoint.services.map((s) => s.serviceName);
299
- expect(serviceNames).toContain('Service1');
300
- expect(serviceNames).toContain('Service2');
301
- });
302
-
303
- it('should merge services in options', () => {
304
- const factory = new EndpointFactory({
305
- defaultServices: [Service1],
306
- }).services([Service2]);
307
-
308
- const endpoint = factory.get('/test').handle(async () => ({}));
309
-
310
- expect(endpoint.services).toEqual([Service2, Service1]);
311
- });
312
- });
313
-
314
- describe('logger', () => {
315
- it('should set custom logger', () => {
316
- const customLogger: Logger = {
317
- debug: vi.fn(),
318
- info: vi.fn(),
319
- warn: vi.fn(),
320
- error: vi.fn(),
321
- fatal: vi.fn(),
322
- trace: vi.fn(),
323
- child: vi.fn(),
324
- };
325
-
326
- const factory = new EndpointFactory().logger(customLogger);
327
- const endpoint = factory.get('/test').handle(async () => ({}));
328
-
329
- expect(endpoint.logger).toBe(customLogger);
330
- });
331
-
332
- it('should use default logger when not specified', () => {
333
- const factory = new EndpointFactory();
334
- const endpoint = factory.get('/test').handle(async () => ({}));
335
-
336
- expect(endpoint.logger).toBeDefined();
337
- expect(endpoint.logger).toBeInstanceOf(ConsoleLogger);
338
- });
339
- });
340
-
341
- describe('session', () => {
342
- it('should set session extractor', () => {
343
- const sessionFn = async () => ({ userId: '123', role: 'admin' });
344
- const factory = new EndpointFactory().session(sessionFn);
345
-
346
- const endpoint = factory.get('/test').handle(async ({ session }) => ({
347
- session,
348
- }));
349
-
350
- expect(endpoint.getSession).toBe(sessionFn);
351
- });
352
-
353
- it('should handle session with services', () => {
354
- const SessionService = {
355
- serviceName: 'SessionService' as const,
356
- async register() {
357
- return {
358
- getSession: (token: string) => ({ userId: token }),
359
- };
360
- },
361
- };
362
-
363
- const sessionFn = async ({ header, services }: any) => {
364
- const token = header('authorization');
365
- return services.SessionService.getSession(token);
366
- };
367
-
368
- const factory = new EndpointFactory()
369
- .services([SessionService])
370
- .session(sessionFn);
371
-
372
- const endpoint = factory.get('/test').handle(async () => ({}));
373
-
374
- expect(endpoint.getSession).toBe(sessionFn);
375
- });
376
- });
377
-
378
- describe('HTTP method builders', () => {
379
- const testMethods = [
380
- { method: 'get', httpMethod: 'GET' },
381
- { method: 'post', httpMethod: 'POST' },
382
- { method: 'put', httpMethod: 'PUT' },
383
- { method: 'delete', httpMethod: 'DELETE' },
384
- { method: 'patch', httpMethod: 'PATCH' },
385
- { method: 'options', httpMethod: 'OPTIONS' },
386
- ] as const;
387
-
388
- testMethods.forEach(({ method, httpMethod }) => {
389
- it(`should create ${httpMethod} endpoint`, () => {
390
- const factory = new EndpointFactory();
391
- const builder = (factory as any)[method]('/test');
392
- const endpoint = builder.handle(async () => ({}));
393
-
394
- expect(endpoint.method).toBe(httpMethod);
395
- expect(endpoint.route).toBe('/test');
396
- });
397
- });
398
-
399
- it('should apply basePath to all HTTP methods', () => {
400
- const factory = new EndpointFactory().route('/api/v1');
401
-
402
- testMethods.forEach(({ method, httpMethod }) => {
403
- const builder = (factory as any)[method]('/test');
404
- const endpoint = builder.handle(async () => ({}));
405
-
406
- expect(endpoint.method).toBe(httpMethod);
407
- expect(endpoint.route).toBe('/api/v1/test');
408
- });
409
- });
410
- });
411
-
412
- describe('constructor options', () => {
413
- it('should initialize with all options', () => {
414
- const authFn = async () => true;
415
- const sessionFn = async () => ({ userId: '123' });
416
- const logger: Logger = new ConsoleLogger();
417
-
418
- const TestService = {
419
- serviceName: 'TestService' as const,
420
- async register() {
421
- return {};
422
- },
423
- };
424
-
425
- const factory = new EndpointFactory({
426
- basePath: '/api',
427
- defaultServices: [TestService],
428
- defaultAuthorizeFn: authFn,
429
- defaultLogger: logger,
430
- defaultSessionExtractor: sessionFn,
431
- });
432
-
433
- const endpoint = factory.get('/test').handle(async () => ({}));
434
-
435
- expect(endpoint.route).toBe('/api/test');
436
- expect(endpoint.authorize).toBe(authFn);
437
- expect(endpoint.getSession).toBe(sessionFn);
438
- expect(endpoint.logger).toBe(logger);
439
- expect(endpoint.services).toEqual([TestService]);
440
- });
441
-
442
- it('should handle empty options', () => {
443
- const factory = new EndpointFactory({});
444
- const endpoint = factory.get('/test').handle(async () => ({}));
445
-
446
- expect(endpoint.route).toBe('/test');
447
- expect(endpoint.services).toEqual([]);
448
- });
449
- });
450
-
451
- describe('type safety', () => {
452
- it('should maintain type information through chains', () => {
453
- const TypedService = {
454
- serviceName: 'TypedService' as const,
455
- async register() {
456
- return { getData: () => ({ value: 42 }) };
457
- },
458
- };
459
-
460
- const factory = new EndpointFactory()
461
- .services([TypedService])
462
- .session(async () => ({ userId: '123' }));
463
-
464
- const endpoint = factory
465
- .post('/data')
466
- .body(z.object({ input: z.number() }))
467
- .output(z.object({ result: z.number() }))
468
- .handle(async ({ body, services }) => ({
469
- result:
470
- body.input +
471
- (await services[TypedService.serviceName]).getData().value,
472
- }));
473
-
474
- // Type assertions to ensure type safety
475
- expect(endpoint.route).toBe('/data');
476
- expect(endpoint.method).toBe('POST');
477
- });
478
- });
8
+ describe('joinPaths', () => {
9
+ it('should join simple paths', () => {
10
+ expect(EndpointFactory.joinPaths('/users', '/api')).toBe('/api/users');
11
+ expect(EndpointFactory.joinPaths('users', '/api')).toBe('/api/users');
12
+ expect(EndpointFactory.joinPaths('/users', 'api')).toBe('/api/users');
13
+ expect(EndpointFactory.joinPaths('users', 'api')).toBe('/api/users');
14
+ });
15
+
16
+ it('should handle empty base path', () => {
17
+ expect(EndpointFactory.joinPaths('/users', '')).toBe('/users');
18
+ expect(EndpointFactory.joinPaths('users', '')).toBe('/users');
19
+ });
20
+
21
+ it('should handle empty segment path', () => {
22
+ expect(EndpointFactory.joinPaths('', '/api')).toBe('/api');
23
+ expect(EndpointFactory.joinPaths('', 'api')).toBe('/api');
24
+ });
25
+
26
+ it('should handle both paths empty', () => {
27
+ expect(EndpointFactory.joinPaths('', '')).toBe('/');
28
+ });
29
+
30
+ it('should handle trailing slashes in base path', () => {
31
+ expect(EndpointFactory.joinPaths('/users', '/api/')).toBe('/api/users');
32
+ expect(EndpointFactory.joinPaths('users', '/api/')).toBe('/api/users');
33
+ expect(EndpointFactory.joinPaths('/users', 'api/')).toBe('/api/users');
34
+ expect(EndpointFactory.joinPaths('users', 'api/')).toBe('/api/users');
35
+ });
36
+
37
+ it('should handle root paths', () => {
38
+ expect(EndpointFactory.joinPaths('/users', '/')).toBe('/users');
39
+ expect(EndpointFactory.joinPaths('users', '/')).toBe('/users');
40
+ expect(EndpointFactory.joinPaths('/', '/')).toBe('/');
41
+ });
42
+
43
+ it('should handle multiple slashes', () => {
44
+ expect(EndpointFactory.joinPaths('//users', '/api')).toBe('/api//users');
45
+ expect(EndpointFactory.joinPaths('/users', '//api')).toBe('/api/users');
46
+ });
47
+
48
+ it('should handle complex paths', () => {
49
+ expect(EndpointFactory.joinPaths('/users/:id', '/api/v1')).toBe(
50
+ '/api/v1/users/:id',
51
+ );
52
+ expect(
53
+ EndpointFactory.joinPaths(
54
+ '/posts/:postId/comments/:commentId',
55
+ '/blog',
56
+ ),
57
+ ).toBe('/blog/posts/:postId/comments/:commentId');
58
+ });
59
+
60
+ it('should handle paths with query parameters notation', () => {
61
+ expect(EndpointFactory.joinPaths('/users?page=1', '/api')).toBe(
62
+ '/api/users?page=1',
63
+ );
64
+ expect(EndpointFactory.joinPaths('/search', '/api')).toBe('/api/search');
65
+ });
66
+
67
+ it('should handle nested segments', () => {
68
+ expect(EndpointFactory.joinPaths('/admin/users', '/api')).toBe(
69
+ '/api/admin/users',
70
+ );
71
+ expect(EndpointFactory.joinPaths('/v2/resources/items', '/api/v1')).toBe(
72
+ '/api/v1/v2/resources/items',
73
+ );
74
+ });
75
+
76
+ it('should not add extra slashes when paths already have them', () => {
77
+ expect(EndpointFactory.joinPaths('/users', '/api')).toBe('/api/users');
78
+ expect(EndpointFactory.joinPaths('/', '/api')).toBe('/api');
79
+ });
80
+
81
+ it('should preserve path parameters', () => {
82
+ expect(EndpointFactory.joinPaths('/:id', '/users')).toBe('/users/:id');
83
+ expect(
84
+ EndpointFactory.joinPaths('/:userId/posts/:postId', '/api/users'),
85
+ ).toBe('/api/users/:userId/posts/:postId');
86
+ });
87
+
88
+ it('should work with undefined base path (default parameter)', () => {
89
+ expect(EndpointFactory.joinPaths('/users')).toBe('/users');
90
+ expect(EndpointFactory.joinPaths('users')).toBe('/users');
91
+ expect(EndpointFactory.joinPaths('')).toBe('/');
92
+ });
93
+ });
94
+
95
+ describe('authorize', () => {
96
+ const mockLogger: Logger = {
97
+ debug: vi.fn(),
98
+ info: vi.fn(),
99
+ warn: vi.fn(),
100
+ error: vi.fn(),
101
+ fatal: vi.fn(),
102
+ trace: vi.fn(),
103
+ child: vi.fn(() => mockLogger),
104
+ };
105
+
106
+ it('should create a factory with authorization function', () => {
107
+ const factory = new EndpointFactory();
108
+ const authFn = async () => true;
109
+
110
+ const authorizedFactory = factory.authorize(authFn);
111
+
112
+ expect(authorizedFactory).toBeInstanceOf(EndpointFactory);
113
+ expect(authorizedFactory).not.toBe(factory);
114
+ });
115
+
116
+ it('should apply authorization to created endpoints', async () => {
117
+ const authFn = vi.fn().mockResolvedValue(true);
118
+ const factory = new EndpointFactory()
119
+ .services([])
120
+ .logger(mockLogger)
121
+ .authorize(authFn);
122
+
123
+ const endpoint = factory
124
+ .get('/test')
125
+ .handle(async () => ({ success: true }));
126
+
127
+ expect(endpoint.authorize).toBe(authFn);
128
+ });
129
+
130
+ it('should handle authorization with different service types', async () => {
131
+ const AuthService = {
132
+ serviceName: 'AuthService' as const,
133
+
134
+ async register() {
135
+ return { validateToken: (token: string) => token === 'valid' };
136
+ },
137
+ };
138
+
139
+ const authFn = async ({ header, services }: any) => {
140
+ const token = header('authorization')?.replace('Bearer ', '');
141
+ return services.AuthService.validateToken(token);
142
+ };
143
+
144
+ const factory = new EndpointFactory()
145
+ .services([AuthService])
146
+ .logger(mockLogger)
147
+ .authorize(authFn);
148
+
149
+ const endpoint = factory
150
+ .post('/protected')
151
+ .body(z.object({ data: z.string() }))
152
+ .handle(async () => ({ success: true }));
153
+
154
+ expect(endpoint.authorize).toBe(authFn);
155
+ });
156
+
157
+ it('should chain with other factory methods', () => {
158
+ const authFn = async () => true;
159
+ const sessionFn = async () => ({ userId: 'user1' });
160
+
161
+ const factory = new EndpointFactory()
162
+ .route('/api')
163
+ .services([])
164
+ .logger(mockLogger)
165
+ .authorize(authFn)
166
+ .session(sessionFn);
167
+
168
+ const endpoint = factory
169
+ .get('/test')
170
+ .handle(async () => ({ success: true }));
171
+
172
+ expect(endpoint.authorize).toBe(authFn);
173
+ expect(endpoint.getSession).toBe(sessionFn);
174
+ });
175
+
176
+ it('should preserve authorization in factory chains', () => {
177
+ const authFn = async () => true;
178
+ const newLogger = new ConsoleLogger();
179
+
180
+ const factory = new EndpointFactory()
181
+ .services([])
182
+ .authorize(authFn)
183
+ .logger(newLogger); // Chain after authorize
184
+
185
+ const endpoint = factory
186
+ .get('/test')
187
+ .handle(async () => ({ success: true }));
188
+
189
+ expect(endpoint.authorize).toBe(authFn);
190
+ expect(endpoint.logger).toBe(newLogger);
191
+ });
192
+
193
+ it('should handle authorization function returning boolean', async () => {
194
+ const authFn = ({ header }: any) => {
195
+ return header('authorization') === 'Bearer valid-token';
196
+ };
197
+
198
+ const factory = new EndpointFactory()
199
+ .services([])
200
+ .logger(mockLogger)
201
+ .authorize(authFn);
202
+
203
+ const endpoint = factory
204
+ .get('/test')
205
+ .handle(async () => ({ success: true }));
206
+
207
+ expect(endpoint.authorize).toBe(authFn);
208
+ });
209
+
210
+ it('should handle authorization function returning Promise<boolean>', async () => {
211
+ const authFn = async ({ header }: any) => {
212
+ await new Promise((resolve) => setTimeout(resolve, 1));
213
+ return header('authorization') === 'Bearer valid-token';
214
+ };
215
+
216
+ const factory = new EndpointFactory()
217
+ .services([])
218
+ .logger(mockLogger)
219
+ .authorize(authFn);
220
+
221
+ const endpoint = factory
222
+ .get('/test')
223
+ .handle(async () => ({ success: true }));
224
+
225
+ expect(endpoint.authorize).toBe(authFn);
226
+ });
227
+ });
228
+
229
+ describe('route', () => {
230
+ it('should create a sub-factory with path prefix', () => {
231
+ const factory = new EndpointFactory();
232
+ const apiFactory = factory.route('/api');
233
+ const v1Factory = apiFactory.route('/v1');
234
+
235
+ const endpoint = v1Factory.get('/users').handle(async () => []);
236
+
237
+ expect(endpoint.route).toBe('/api/v1/users');
238
+ });
239
+
240
+ it('should preserve services, auth, and logger in sub-routes', () => {
241
+ const authFn = async () => true;
242
+ const sessionFn = async () => ({ userId: 'user1' });
243
+
244
+ const TestService = {
245
+ serviceName: 'TestService' as const,
246
+ async register() {
247
+ return {};
248
+ },
249
+ };
250
+
251
+ const factory = new EndpointFactory()
252
+ .services([TestService])
253
+ .authorize(authFn)
254
+ .session(sessionFn)
255
+ .route('/api');
256
+
257
+ const endpoint = factory.get('/test').handle(async () => ({}));
258
+
259
+ expect(endpoint.route).toBe('/api/test');
260
+ expect(endpoint.authorize).toBe(authFn);
261
+ expect(endpoint.getSession).toBe(sessionFn);
262
+ });
263
+ });
264
+
265
+ describe('services', () => {
266
+ const Service1 = {
267
+ serviceName: 'Service1' as const,
268
+ async register() {
269
+ return { method1: () => 'service1' };
270
+ },
271
+ };
272
+
273
+ const Service2 = {
274
+ serviceName: 'Service2' as const,
275
+ async register() {
276
+ return { method2: () => 'service2' };
277
+ },
278
+ };
279
+
280
+ it('should add services to factory', () => {
281
+ const factory = new EndpointFactory().services([Service1, Service2]);
282
+ const endpoint = factory.get('/test').handle(async ({ services }) => ({
283
+ result1: (await services[Service1.serviceName]).method1(),
284
+ result2: (await services[Service2.serviceName]).method2(),
285
+ }));
286
+
287
+ expect(endpoint.services).toEqual([Service1, Service2]);
288
+ });
289
+
290
+ it('should handle duplicate services', () => {
291
+ const factory = new EndpointFactory()
292
+ .services([Service1])
293
+ .services([Service1, Service2]);
294
+
295
+ const endpoint = factory.get('/test').handle(async () => ({}));
296
+
297
+ // Should contain unique services
298
+ const serviceNames = endpoint.services.map((s) => s.serviceName);
299
+ expect(serviceNames).toContain('Service1');
300
+ expect(serviceNames).toContain('Service2');
301
+ });
302
+
303
+ it('should merge services in options', () => {
304
+ const factory = new EndpointFactory({
305
+ defaultServices: [Service1],
306
+ }).services([Service2]);
307
+
308
+ const endpoint = factory.get('/test').handle(async () => ({}));
309
+
310
+ expect(endpoint.services).toEqual([Service2, Service1]);
311
+ });
312
+ });
313
+
314
+ describe('logger', () => {
315
+ it('should set custom logger', () => {
316
+ const customLogger: Logger = {
317
+ debug: vi.fn(),
318
+ info: vi.fn(),
319
+ warn: vi.fn(),
320
+ error: vi.fn(),
321
+ fatal: vi.fn(),
322
+ trace: vi.fn(),
323
+ child: vi.fn(),
324
+ };
325
+
326
+ const factory = new EndpointFactory().logger(customLogger);
327
+ const endpoint = factory.get('/test').handle(async () => ({}));
328
+
329
+ expect(endpoint.logger).toBe(customLogger);
330
+ });
331
+
332
+ it('should use default logger when not specified', () => {
333
+ const factory = new EndpointFactory();
334
+ const endpoint = factory.get('/test').handle(async () => ({}));
335
+
336
+ expect(endpoint.logger).toBeDefined();
337
+ expect(endpoint.logger).toBeInstanceOf(ConsoleLogger);
338
+ });
339
+ });
340
+
341
+ describe('session', () => {
342
+ it('should set session extractor', () => {
343
+ const sessionFn = async () => ({ userId: '123', role: 'admin' });
344
+ const factory = new EndpointFactory().session(sessionFn);
345
+
346
+ const endpoint = factory.get('/test').handle(async ({ session }) => ({
347
+ session,
348
+ }));
349
+
350
+ expect(endpoint.getSession).toBe(sessionFn);
351
+ });
352
+
353
+ it('should handle session with services', () => {
354
+ const SessionService = {
355
+ serviceName: 'SessionService' as const,
356
+ async register() {
357
+ return {
358
+ getSession: (token: string) => ({ userId: token }),
359
+ };
360
+ },
361
+ };
362
+
363
+ const sessionFn = async ({ header, services }: any) => {
364
+ const token = header('authorization');
365
+ return services.SessionService.getSession(token);
366
+ };
367
+
368
+ const factory = new EndpointFactory()
369
+ .services([SessionService])
370
+ .session(sessionFn);
371
+
372
+ const endpoint = factory.get('/test').handle(async () => ({}));
373
+
374
+ expect(endpoint.getSession).toBe(sessionFn);
375
+ });
376
+ });
377
+
378
+ describe('HTTP method builders', () => {
379
+ const testMethods = [
380
+ { method: 'get', httpMethod: 'GET' },
381
+ { method: 'post', httpMethod: 'POST' },
382
+ { method: 'put', httpMethod: 'PUT' },
383
+ { method: 'delete', httpMethod: 'DELETE' },
384
+ { method: 'patch', httpMethod: 'PATCH' },
385
+ { method: 'options', httpMethod: 'OPTIONS' },
386
+ ] as const;
387
+
388
+ testMethods.forEach(({ method, httpMethod }) => {
389
+ it(`should create ${httpMethod} endpoint`, () => {
390
+ const factory = new EndpointFactory();
391
+ const builder = (factory as any)[method]('/test');
392
+ const endpoint = builder.handle(async () => ({}));
393
+
394
+ expect(endpoint.method).toBe(httpMethod);
395
+ expect(endpoint.route).toBe('/test');
396
+ });
397
+ });
398
+
399
+ it('should apply basePath to all HTTP methods', () => {
400
+ const factory = new EndpointFactory().route('/api/v1');
401
+
402
+ testMethods.forEach(({ method, httpMethod }) => {
403
+ const builder = (factory as any)[method]('/test');
404
+ const endpoint = builder.handle(async () => ({}));
405
+
406
+ expect(endpoint.method).toBe(httpMethod);
407
+ expect(endpoint.route).toBe('/api/v1/test');
408
+ });
409
+ });
410
+ });
411
+
412
+ describe('constructor options', () => {
413
+ it('should initialize with all options', () => {
414
+ const authFn = async () => true;
415
+ const sessionFn = async () => ({ userId: '123' });
416
+ const logger: Logger = new ConsoleLogger();
417
+
418
+ const TestService = {
419
+ serviceName: 'TestService' as const,
420
+ async register() {
421
+ return {};
422
+ },
423
+ };
424
+
425
+ const factory = new EndpointFactory({
426
+ basePath: '/api',
427
+ defaultServices: [TestService],
428
+ defaultAuthorizeFn: authFn,
429
+ defaultLogger: logger,
430
+ defaultSessionExtractor: sessionFn,
431
+ });
432
+
433
+ const endpoint = factory.get('/test').handle(async () => ({}));
434
+
435
+ expect(endpoint.route).toBe('/api/test');
436
+ expect(endpoint.authorize).toBe(authFn);
437
+ expect(endpoint.getSession).toBe(sessionFn);
438
+ expect(endpoint.logger).toBe(logger);
439
+ expect(endpoint.services).toEqual([TestService]);
440
+ });
441
+
442
+ it('should handle empty options', () => {
443
+ const factory = new EndpointFactory({});
444
+ const endpoint = factory.get('/test').handle(async () => ({}));
445
+
446
+ expect(endpoint.route).toBe('/test');
447
+ expect(endpoint.services).toEqual([]);
448
+ });
449
+ });
450
+
451
+ describe('type safety', () => {
452
+ it('should maintain type information through chains', () => {
453
+ const TypedService = {
454
+ serviceName: 'TypedService' as const,
455
+ async register() {
456
+ return { getData: () => ({ value: 42 }) };
457
+ },
458
+ };
459
+
460
+ const factory = new EndpointFactory()
461
+ .services([TypedService])
462
+ .session(async () => ({ userId: '123' }));
463
+
464
+ const endpoint = factory
465
+ .post('/data')
466
+ .body(z.object({ input: z.number() }))
467
+ .output(z.object({ result: z.number() }))
468
+ .handle(async ({ body, services }) => ({
469
+ result:
470
+ body.input +
471
+ (await services[TypedService.serviceName]).getData().value,
472
+ }));
473
+
474
+ // Type assertions to ensure type safety
475
+ expect(endpoint.route).toBe('/data');
476
+ expect(endpoint.method).toBe('POST');
477
+ });
478
+ });
479
479
  });