@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
@@ -8,457 +8,457 @@ import { CronBuilder } from '../CronBuilder';
8
8
 
9
9
  // Mock service for testing
10
10
  class MockService implements Service<'MockService', MockService> {
11
- serviceName = 'MockService' as const;
11
+ serviceName = 'MockService' as const;
12
12
 
13
- async register() {
14
- return this;
15
- }
13
+ async register() {
14
+ return this;
15
+ }
16
16
 
17
- getValue() {
18
- return 'mock-value';
19
- }
17
+ getValue() {
18
+ return 'mock-value';
19
+ }
20
20
  }
21
21
 
22
22
  describe('Cron', () => {
23
- describe('Cron class', () => {
24
- it('should create a Cron instance with basic handler', () => {
25
- const handler = vi.fn().mockResolvedValue({ success: true });
26
- const cron = new Cron(handler);
27
-
28
- expect(cron).toBeInstanceOf(Cron);
29
- expect(cron.type).toBe(ConstructType.Cron);
30
- expect(cron.timeout).toBe(30000); // Default timeout
31
- // The handler is stored in the protected fn property
32
- });
33
-
34
- it('should create a Cron instance with timeout', () => {
35
- const handler = vi.fn().mockResolvedValue({ data: 'test' });
36
- const timeout = 60000;
37
- const cron = new Cron(handler, timeout);
38
-
39
- expect(cron.timeout).toBe(timeout);
40
- });
41
-
42
- it('should create a Cron instance with schedule expression', () => {
43
- const handler = vi.fn();
44
- const schedule: CronExpression = 'cron(0 12 * * MON)';
45
- const cron = new Cron(handler, undefined, schedule);
46
-
47
- expect(cron).toBeInstanceOf(Cron);
48
- expect(cron.type).toBe(ConstructType.Cron);
49
- // Schedule is protected, so we can't directly test it, but it should be set
50
- });
51
-
52
- it('should create a Cron instance with input schema', () => {
53
- const inputSchema = z.object({
54
- id: z.string(),
55
- count: z.number(),
56
- });
57
-
58
- const handler = vi.fn().mockImplementation(async ({ input }) => {
59
- return { processed: input.id };
60
- });
61
-
62
- const cron = new Cron(handler, undefined, undefined, inputSchema);
63
-
64
- expect(cron).toBeInstanceOf(Cron);
65
- expect(cron.input).toBe(inputSchema);
66
- });
67
-
68
- it('should create a Cron instance with output schema', () => {
69
- const outputSchema = z.object({
70
- result: z.string(),
71
- timestamp: z.number(),
72
- });
73
-
74
- const handler = vi.fn().mockResolvedValue({
75
- result: 'success',
76
- timestamp: Date.now(),
77
- });
78
-
79
- const cron = new Cron(
80
- handler,
81
- undefined,
82
- undefined,
83
- undefined,
84
- outputSchema,
85
- );
86
-
87
- expect(cron).toBeInstanceOf(Cron);
88
- expect(cron.outputSchema).toBe(outputSchema);
89
- });
90
-
91
- it('should create a Cron instance with services', () => {
92
- const mockService = new MockService();
93
- const services = [mockService];
94
-
95
- const handler = vi.fn().mockImplementation(async ({ services }) => {
96
- return { value: services.MockService.getValue() };
97
- });
98
-
99
- const cron = new Cron(
100
- handler,
101
- undefined,
102
- undefined,
103
- undefined,
104
- undefined,
105
- services,
106
- );
107
-
108
- expect(cron).toBeInstanceOf(Cron);
109
- expect(cron.services).toEqual(services);
110
- });
111
-
112
- it('should create a Cron instance with custom logger', () => {
113
- const customLogger = new ConsoleLogger();
114
-
115
- const handler = vi.fn().mockImplementation(async ({ logger }) => {
116
- logger.info('Cron executed');
117
- return { logged: true };
118
- });
119
-
120
- const cron = new Cron(
121
- handler,
122
- undefined,
123
- undefined,
124
- undefined,
125
- undefined,
126
- [],
127
- customLogger,
128
- );
129
-
130
- expect(cron).toBeInstanceOf(Cron);
131
- expect(cron.logger).toBe(customLogger);
132
- });
133
-
134
- it('should create a Cron with all parameters', () => {
135
- const inputSchema = z.object({ name: z.string() });
136
- const outputSchema = z.object({ greeting: z.string() });
137
- const schedule: RateExpression = 'rate(5 minutes)';
138
- const timeout = 60000;
139
- const service = new MockService();
140
- const logger = new ConsoleLogger();
141
-
142
- const handler = vi
143
- .fn()
144
- .mockImplementation(async ({ input, services }) => {
145
- return {
146
- greeting: `Hello ${input.name} from ${services.MockService.getValue()}`,
147
- };
148
- });
149
-
150
- const cron = new Cron(
151
- handler,
152
- timeout,
153
- schedule,
154
- inputSchema,
155
- outputSchema,
156
- [service],
157
- logger,
158
- );
159
-
160
- expect(cron).toBeInstanceOf(Cron);
161
- expect(cron.type).toBe(ConstructType.Cron);
162
- expect(cron.timeout).toBe(timeout);
163
- expect(cron.input).toBe(inputSchema);
164
- expect(cron.outputSchema).toBe(outputSchema);
165
- expect(cron.services).toEqual([service]);
166
- expect(cron.logger).toBe(logger);
167
- });
168
- });
169
-
170
- describe('Cron.isCron', () => {
171
- it('should return true for Cron instances', () => {
172
- const cron = new Cron(vi.fn());
173
- expect(Cron.isCron(cron)).toBe(true);
174
- });
175
-
176
- it('should return false for non-Cron objects', () => {
177
- expect(Cron.isCron({})).toBe(false);
178
- expect(Cron.isCron(null)).toBeFalsy();
179
- expect(Cron.isCron(undefined)).toBeFalsy();
180
- expect(Cron.isCron('string')).toBe(false);
181
- expect(Cron.isCron(123)).toBe(false);
182
- expect(Cron.isCron([])).toBe(false);
183
- });
184
-
185
- it('should return false for objects with similar structure', () => {
186
- const fakeCron = {
187
- __IS_FUNCTION__: true,
188
- type: 'SomethingElse',
189
- };
190
- expect(Cron.isCron(fakeCron)).toBe(false);
191
- });
192
-
193
- it('should return false for objects with __IS_FUNCTION__ but wrong type', () => {
194
- const fakeFunction = {
195
- __IS_FUNCTION__: true,
196
- type: ConstructType.Function,
197
- };
198
- expect(Cron.isCron(fakeFunction)).toBe(false);
199
- });
200
- });
201
-
202
- describe('CronBuilder', () => {
203
- it('should create a CronBuilder instance', () => {
204
- const builder = new CronBuilder();
205
- expect(builder).toBeInstanceOf(CronBuilder);
206
- });
207
-
208
- it('should set schedule with schedule() method', () => {
209
- const builder = new CronBuilder();
210
- const schedule: CronExpression = 'cron(0 0 * * SUN)';
211
-
212
- const result = builder.schedule(schedule);
213
- expect(result).toBe(builder); // Should return self for chaining
214
- });
215
-
216
- it('should build Cron with handle() method', () => {
217
- const builder = new CronBuilder();
218
- const handler = vi.fn().mockResolvedValue({ done: true });
219
-
220
- const cron = builder.handle(handler);
221
-
222
- expect(cron).toBeInstanceOf(Cron);
223
- expect(cron.type).toBe(ConstructType.Cron);
224
- });
225
-
226
- it('should build Cron with full builder chain', () => {
227
- const inputSchema = z.object({ task: z.string() });
228
- const outputSchema = z.object({ completed: z.boolean() });
229
- const schedule: RateExpression = 'rate(1 hour)';
230
- const service = new MockService();
231
- const logger = new ConsoleLogger();
232
-
233
- const handler = vi.fn().mockImplementation(async ({ input }) => {
234
- return { completed: input.task === 'test' };
235
- });
236
-
237
- const cron = new CronBuilder()
238
- .input(inputSchema)
239
- .output(outputSchema)
240
- .services([service])
241
- .logger(logger)
242
- .timeout(45000)
243
- .schedule(schedule)
244
- .handle(handler);
245
-
246
- expect(cron).toBeInstanceOf(Cron);
247
- expect(cron.type).toBe(ConstructType.Cron);
248
- expect(cron.timeout).toBe(45000);
249
- expect(cron.input).toBe(inputSchema);
250
- expect(cron.outputSchema).toBe(outputSchema);
251
- expect(cron.services).toEqual([service]);
252
- expect(cron.logger).toBe(logger);
253
- });
254
-
255
- it('should support method chaining in any order', () => {
256
- const builder = new CronBuilder();
257
- const schedule: CronExpression = 'cron(30 2 * * TUE)';
258
-
259
- const chained = builder
260
- .timeout(30000)
261
- .schedule(schedule)
262
- .input(z.object({ data: z.string() }));
263
-
264
- expect(chained).toBe(builder);
265
- });
266
- });
267
-
268
- describe('Schedule Expression Types', () => {
269
- it('should accept valid rate expressions', () => {
270
- const validRates: RateExpression[] = [
271
- 'rate(5 minutes)',
272
- 'rate(1 hour)',
273
- 'rate(7 days)',
274
- 'rate(30 seconds)',
275
- 'rate(2 weeks)',
276
- ];
277
-
278
- validRates.forEach((rate) => {
279
- const builder = new CronBuilder();
280
- expect(() => builder.schedule(rate)).not.toThrow();
281
- });
282
- });
283
-
284
- it('should accept valid cron expressions', () => {
285
- const validCrons: CronExpression[] = [
286
- 'cron(0 12 * * MON)',
287
- 'cron(15 10 * * FRI)',
288
- 'cron(0 0 1 JAN SUN)',
289
- 'cron(*/5 * * * *)',
290
- 'cron(0 0-23/2 * * *)',
291
- 'cron(30 4 1,15 * *)',
292
- 'cron(0 12 * DEC MON)',
293
- ];
294
-
295
- validCrons.forEach((cron) => {
296
- const builder = new CronBuilder();
297
- expect(() => builder.schedule(cron)).not.toThrow();
298
- });
299
- });
300
-
301
- it('should work with complex cron patterns', () => {
302
- const complexPatterns: CronExpression[] = [
303
- 'cron(*/15 * * * *)', // Every 15 minutes
304
- 'cron(0 */4 * * *)', // Every 4 hours
305
- 'cron(0 9-17 * * MON-FRI)', // Every hour 9-5 on weekdays
306
- 'cron(0 0 1-7 * SUN)', // First Sunday of month
307
- 'cron(*/30 8-18 * * *)', // Every 30 min during business hours
308
- ];
309
-
310
- complexPatterns.forEach((pattern) => {
311
- const builder = new CronBuilder();
312
- expect(() => builder.schedule(pattern)).not.toThrow();
313
- });
314
- });
315
-
316
- it('should handle all month names', () => {
317
- const months: CronExpression[] = [
318
- 'cron(0 0 1 JAN *)',
319
- 'cron(0 0 1 FEB *)',
320
- 'cron(0 0 1 MAR *)',
321
- 'cron(0 0 1 APR *)',
322
- 'cron(0 0 1 MAY *)',
323
- 'cron(0 0 1 JUN *)',
324
- 'cron(0 0 1 JUL *)',
325
- 'cron(0 0 1 AUG *)',
326
- 'cron(0 0 1 SEP *)',
327
- 'cron(0 0 1 OCT *)',
328
- 'cron(0 0 1 NOV *)',
329
- 'cron(0 0 1 DEC *)',
330
- ];
331
-
332
- months.forEach((expression) => {
333
- const builder = new CronBuilder();
334
- expect(() => builder.schedule(expression)).not.toThrow();
335
- });
336
- });
337
-
338
- it('should handle all weekday names', () => {
339
- const weekdays: CronExpression[] = [
340
- 'cron(0 0 * * SUN)',
341
- 'cron(0 0 * * MON)',
342
- 'cron(0 0 * * TUE)',
343
- 'cron(0 0 * * WED)',
344
- 'cron(0 0 * * THU)',
345
- 'cron(0 0 * * FRI)',
346
- 'cron(0 0 * * SAT)',
347
- ];
348
-
349
- weekdays.forEach((expression) => {
350
- const builder = new CronBuilder();
351
- expect(() => builder.schedule(expression)).not.toThrow();
352
- });
353
- });
354
- });
355
-
356
- describe('Cron configuration', () => {
357
- it('should store handler with error handling capability', () => {
358
- const error = new Error('Cron execution failed');
359
- const handler = vi.fn().mockRejectedValue(error);
360
-
361
- const cron = new Cron(handler);
362
-
363
- expect(cron).toBeInstanceOf(Cron);
364
- // Handler is stored but not directly accessible (protected)
365
- });
366
-
367
- it('should store input schema for validation', () => {
368
- const inputSchema = z.object({
369
- id: z.string().uuid(),
370
- amount: z.number().positive(),
371
- });
372
-
373
- const handler = vi.fn();
374
- const cron = new Cron(handler, undefined, undefined, inputSchema);
375
-
376
- expect(cron.input).toBe(inputSchema);
377
- });
378
-
379
- it('should store output schema for validation', () => {
380
- const outputSchema = z.object({
381
- status: z.enum(['success', 'failure']),
382
- count: z.number().int(),
383
- });
384
-
385
- const handler = vi.fn().mockResolvedValue({
386
- status: 'invalid',
387
- count: 3.14,
388
- });
389
-
390
- const cron = new Cron(
391
- handler,
392
- undefined,
393
- undefined,
394
- undefined,
395
- outputSchema,
396
- );
397
-
398
- expect(cron.outputSchema).toBe(outputSchema);
399
- });
400
-
401
- it('should work with multiple services', () => {
402
- class ServiceA implements Service<'ServiceA', ServiceA> {
403
- serviceName = 'ServiceA' as const;
404
- async register() {
405
- return this;
406
- }
407
- getA() {
408
- return 'A';
409
- }
410
- }
411
-
412
- class ServiceB implements Service<'ServiceB', ServiceB> {
413
- serviceName = 'ServiceB' as const;
414
- async register() {
415
- return this;
416
- }
417
- getB() {
418
- return 'B';
419
- }
420
- }
421
-
422
- const services = [new ServiceA(), new ServiceB()];
423
-
424
- const handler = vi.fn().mockImplementation(async ({ services }) => {
425
- return {
426
- a: services.ServiceA.getA(),
427
- b: services.ServiceB.getB(),
428
- };
429
- });
430
-
431
- const cron = new Cron(
432
- handler,
433
- undefined,
434
- undefined,
435
- undefined,
436
- undefined,
437
- services,
438
- );
439
-
440
- expect(cron.services).toEqual(services);
441
- });
442
-
443
- it('should maintain separate instances with different configurations', () => {
444
- const handler1 = vi.fn().mockResolvedValue({ cron: 1 });
445
- const handler2 = vi.fn().mockResolvedValue({ cron: 2 });
446
-
447
- const cron1 = new CronBuilder()
448
- .timeout(1000)
449
- .schedule('rate(5 minutes)')
450
- .handle(handler1);
451
-
452
- const cron2 = new CronBuilder()
453
- .timeout(2000)
454
- .schedule('cron(0 0 * * *)')
455
- .handle(handler2);
456
-
457
- expect(cron1).toBeInstanceOf(Cron);
458
- expect(cron2).toBeInstanceOf(Cron);
459
- expect(cron1.timeout).toBe(1000);
460
- expect(cron2.timeout).toBe(2000);
461
- expect(cron1).not.toBe(cron2);
462
- });
463
- });
23
+ describe('Cron class', () => {
24
+ it('should create a Cron instance with basic handler', () => {
25
+ const handler = vi.fn().mockResolvedValue({ success: true });
26
+ const cron = new Cron(handler);
27
+
28
+ expect(cron).toBeInstanceOf(Cron);
29
+ expect(cron.type).toBe(ConstructType.Cron);
30
+ expect(cron.timeout).toBe(30000); // Default timeout
31
+ // The handler is stored in the protected fn property
32
+ });
33
+
34
+ it('should create a Cron instance with timeout', () => {
35
+ const handler = vi.fn().mockResolvedValue({ data: 'test' });
36
+ const timeout = 60000;
37
+ const cron = new Cron(handler, timeout);
38
+
39
+ expect(cron.timeout).toBe(timeout);
40
+ });
41
+
42
+ it('should create a Cron instance with schedule expression', () => {
43
+ const handler = vi.fn();
44
+ const schedule: CronExpression = 'cron(0 12 * * MON)';
45
+ const cron = new Cron(handler, undefined, schedule);
46
+
47
+ expect(cron).toBeInstanceOf(Cron);
48
+ expect(cron.type).toBe(ConstructType.Cron);
49
+ // Schedule is protected, so we can't directly test it, but it should be set
50
+ });
51
+
52
+ it('should create a Cron instance with input schema', () => {
53
+ const inputSchema = z.object({
54
+ id: z.string(),
55
+ count: z.number(),
56
+ });
57
+
58
+ const handler = vi.fn().mockImplementation(async ({ input }) => {
59
+ return { processed: input.id };
60
+ });
61
+
62
+ const cron = new Cron(handler, undefined, undefined, inputSchema);
63
+
64
+ expect(cron).toBeInstanceOf(Cron);
65
+ expect(cron.input).toBe(inputSchema);
66
+ });
67
+
68
+ it('should create a Cron instance with output schema', () => {
69
+ const outputSchema = z.object({
70
+ result: z.string(),
71
+ timestamp: z.number(),
72
+ });
73
+
74
+ const handler = vi.fn().mockResolvedValue({
75
+ result: 'success',
76
+ timestamp: Date.now(),
77
+ });
78
+
79
+ const cron = new Cron(
80
+ handler,
81
+ undefined,
82
+ undefined,
83
+ undefined,
84
+ outputSchema,
85
+ );
86
+
87
+ expect(cron).toBeInstanceOf(Cron);
88
+ expect(cron.outputSchema).toBe(outputSchema);
89
+ });
90
+
91
+ it('should create a Cron instance with services', () => {
92
+ const mockService = new MockService();
93
+ const services = [mockService];
94
+
95
+ const handler = vi.fn().mockImplementation(async ({ services }) => {
96
+ return { value: services.MockService.getValue() };
97
+ });
98
+
99
+ const cron = new Cron(
100
+ handler,
101
+ undefined,
102
+ undefined,
103
+ undefined,
104
+ undefined,
105
+ services,
106
+ );
107
+
108
+ expect(cron).toBeInstanceOf(Cron);
109
+ expect(cron.services).toEqual(services);
110
+ });
111
+
112
+ it('should create a Cron instance with custom logger', () => {
113
+ const customLogger = new ConsoleLogger();
114
+
115
+ const handler = vi.fn().mockImplementation(async ({ logger }) => {
116
+ logger.info('Cron executed');
117
+ return { logged: true };
118
+ });
119
+
120
+ const cron = new Cron(
121
+ handler,
122
+ undefined,
123
+ undefined,
124
+ undefined,
125
+ undefined,
126
+ [],
127
+ customLogger,
128
+ );
129
+
130
+ expect(cron).toBeInstanceOf(Cron);
131
+ expect(cron.logger).toBe(customLogger);
132
+ });
133
+
134
+ it('should create a Cron with all parameters', () => {
135
+ const inputSchema = z.object({ name: z.string() });
136
+ const outputSchema = z.object({ greeting: z.string() });
137
+ const schedule: RateExpression = 'rate(5 minutes)';
138
+ const timeout = 60000;
139
+ const service = new MockService();
140
+ const logger = new ConsoleLogger();
141
+
142
+ const handler = vi
143
+ .fn()
144
+ .mockImplementation(async ({ input, services }) => {
145
+ return {
146
+ greeting: `Hello ${input.name} from ${services.MockService.getValue()}`,
147
+ };
148
+ });
149
+
150
+ const cron = new Cron(
151
+ handler,
152
+ timeout,
153
+ schedule,
154
+ inputSchema,
155
+ outputSchema,
156
+ [service],
157
+ logger,
158
+ );
159
+
160
+ expect(cron).toBeInstanceOf(Cron);
161
+ expect(cron.type).toBe(ConstructType.Cron);
162
+ expect(cron.timeout).toBe(timeout);
163
+ expect(cron.input).toBe(inputSchema);
164
+ expect(cron.outputSchema).toBe(outputSchema);
165
+ expect(cron.services).toEqual([service]);
166
+ expect(cron.logger).toBe(logger);
167
+ });
168
+ });
169
+
170
+ describe('Cron.isCron', () => {
171
+ it('should return true for Cron instances', () => {
172
+ const cron = new Cron(vi.fn());
173
+ expect(Cron.isCron(cron)).toBe(true);
174
+ });
175
+
176
+ it('should return false for non-Cron objects', () => {
177
+ expect(Cron.isCron({})).toBe(false);
178
+ expect(Cron.isCron(null)).toBeFalsy();
179
+ expect(Cron.isCron(undefined)).toBeFalsy();
180
+ expect(Cron.isCron('string')).toBe(false);
181
+ expect(Cron.isCron(123)).toBe(false);
182
+ expect(Cron.isCron([])).toBe(false);
183
+ });
184
+
185
+ it('should return false for objects with similar structure', () => {
186
+ const fakeCron = {
187
+ __IS_FUNCTION__: true,
188
+ type: 'SomethingElse',
189
+ };
190
+ expect(Cron.isCron(fakeCron)).toBe(false);
191
+ });
192
+
193
+ it('should return false for objects with __IS_FUNCTION__ but wrong type', () => {
194
+ const fakeFunction = {
195
+ __IS_FUNCTION__: true,
196
+ type: ConstructType.Function,
197
+ };
198
+ expect(Cron.isCron(fakeFunction)).toBe(false);
199
+ });
200
+ });
201
+
202
+ describe('CronBuilder', () => {
203
+ it('should create a CronBuilder instance', () => {
204
+ const builder = new CronBuilder();
205
+ expect(builder).toBeInstanceOf(CronBuilder);
206
+ });
207
+
208
+ it('should set schedule with schedule() method', () => {
209
+ const builder = new CronBuilder();
210
+ const schedule: CronExpression = 'cron(0 0 * * SUN)';
211
+
212
+ const result = builder.schedule(schedule);
213
+ expect(result).toBe(builder); // Should return self for chaining
214
+ });
215
+
216
+ it('should build Cron with handle() method', () => {
217
+ const builder = new CronBuilder();
218
+ const handler = vi.fn().mockResolvedValue({ done: true });
219
+
220
+ const cron = builder.handle(handler);
221
+
222
+ expect(cron).toBeInstanceOf(Cron);
223
+ expect(cron.type).toBe(ConstructType.Cron);
224
+ });
225
+
226
+ it('should build Cron with full builder chain', () => {
227
+ const inputSchema = z.object({ task: z.string() });
228
+ const outputSchema = z.object({ completed: z.boolean() });
229
+ const schedule: RateExpression = 'rate(1 hour)';
230
+ const service = new MockService();
231
+ const logger = new ConsoleLogger();
232
+
233
+ const handler = vi.fn().mockImplementation(async ({ input }) => {
234
+ return { completed: input.task === 'test' };
235
+ });
236
+
237
+ const cron = new CronBuilder()
238
+ .input(inputSchema)
239
+ .output(outputSchema)
240
+ .services([service])
241
+ .logger(logger)
242
+ .timeout(45000)
243
+ .schedule(schedule)
244
+ .handle(handler);
245
+
246
+ expect(cron).toBeInstanceOf(Cron);
247
+ expect(cron.type).toBe(ConstructType.Cron);
248
+ expect(cron.timeout).toBe(45000);
249
+ expect(cron.input).toBe(inputSchema);
250
+ expect(cron.outputSchema).toBe(outputSchema);
251
+ expect(cron.services).toEqual([service]);
252
+ expect(cron.logger).toBe(logger);
253
+ });
254
+
255
+ it('should support method chaining in any order', () => {
256
+ const builder = new CronBuilder();
257
+ const schedule: CronExpression = 'cron(30 2 * * TUE)';
258
+
259
+ const chained = builder
260
+ .timeout(30000)
261
+ .schedule(schedule)
262
+ .input(z.object({ data: z.string() }));
263
+
264
+ expect(chained).toBe(builder);
265
+ });
266
+ });
267
+
268
+ describe('Schedule Expression Types', () => {
269
+ it('should accept valid rate expressions', () => {
270
+ const validRates: RateExpression[] = [
271
+ 'rate(5 minutes)',
272
+ 'rate(1 hour)',
273
+ 'rate(7 days)',
274
+ 'rate(30 seconds)',
275
+ 'rate(2 weeks)',
276
+ ];
277
+
278
+ validRates.forEach((rate) => {
279
+ const builder = new CronBuilder();
280
+ expect(() => builder.schedule(rate)).not.toThrow();
281
+ });
282
+ });
283
+
284
+ it('should accept valid cron expressions', () => {
285
+ const validCrons: CronExpression[] = [
286
+ 'cron(0 12 * * MON)',
287
+ 'cron(15 10 * * FRI)',
288
+ 'cron(0 0 1 JAN SUN)',
289
+ 'cron(*/5 * * * *)',
290
+ 'cron(0 0-23/2 * * *)',
291
+ 'cron(30 4 1,15 * *)',
292
+ 'cron(0 12 * DEC MON)',
293
+ ];
294
+
295
+ validCrons.forEach((cron) => {
296
+ const builder = new CronBuilder();
297
+ expect(() => builder.schedule(cron)).not.toThrow();
298
+ });
299
+ });
300
+
301
+ it('should work with complex cron patterns', () => {
302
+ const complexPatterns: CronExpression[] = [
303
+ 'cron(*/15 * * * *)', // Every 15 minutes
304
+ 'cron(0 */4 * * *)', // Every 4 hours
305
+ 'cron(0 9-17 * * MON-FRI)', // Every hour 9-5 on weekdays
306
+ 'cron(0 0 1-7 * SUN)', // First Sunday of month
307
+ 'cron(*/30 8-18 * * *)', // Every 30 min during business hours
308
+ ];
309
+
310
+ complexPatterns.forEach((pattern) => {
311
+ const builder = new CronBuilder();
312
+ expect(() => builder.schedule(pattern)).not.toThrow();
313
+ });
314
+ });
315
+
316
+ it('should handle all month names', () => {
317
+ const months: CronExpression[] = [
318
+ 'cron(0 0 1 JAN *)',
319
+ 'cron(0 0 1 FEB *)',
320
+ 'cron(0 0 1 MAR *)',
321
+ 'cron(0 0 1 APR *)',
322
+ 'cron(0 0 1 MAY *)',
323
+ 'cron(0 0 1 JUN *)',
324
+ 'cron(0 0 1 JUL *)',
325
+ 'cron(0 0 1 AUG *)',
326
+ 'cron(0 0 1 SEP *)',
327
+ 'cron(0 0 1 OCT *)',
328
+ 'cron(0 0 1 NOV *)',
329
+ 'cron(0 0 1 DEC *)',
330
+ ];
331
+
332
+ months.forEach((expression) => {
333
+ const builder = new CronBuilder();
334
+ expect(() => builder.schedule(expression)).not.toThrow();
335
+ });
336
+ });
337
+
338
+ it('should handle all weekday names', () => {
339
+ const weekdays: CronExpression[] = [
340
+ 'cron(0 0 * * SUN)',
341
+ 'cron(0 0 * * MON)',
342
+ 'cron(0 0 * * TUE)',
343
+ 'cron(0 0 * * WED)',
344
+ 'cron(0 0 * * THU)',
345
+ 'cron(0 0 * * FRI)',
346
+ 'cron(0 0 * * SAT)',
347
+ ];
348
+
349
+ weekdays.forEach((expression) => {
350
+ const builder = new CronBuilder();
351
+ expect(() => builder.schedule(expression)).not.toThrow();
352
+ });
353
+ });
354
+ });
355
+
356
+ describe('Cron configuration', () => {
357
+ it('should store handler with error handling capability', () => {
358
+ const error = new Error('Cron execution failed');
359
+ const handler = vi.fn().mockRejectedValue(error);
360
+
361
+ const cron = new Cron(handler);
362
+
363
+ expect(cron).toBeInstanceOf(Cron);
364
+ // Handler is stored but not directly accessible (protected)
365
+ });
366
+
367
+ it('should store input schema for validation', () => {
368
+ const inputSchema = z.object({
369
+ id: z.string().uuid(),
370
+ amount: z.number().positive(),
371
+ });
372
+
373
+ const handler = vi.fn();
374
+ const cron = new Cron(handler, undefined, undefined, inputSchema);
375
+
376
+ expect(cron.input).toBe(inputSchema);
377
+ });
378
+
379
+ it('should store output schema for validation', () => {
380
+ const outputSchema = z.object({
381
+ status: z.enum(['success', 'failure']),
382
+ count: z.number().int(),
383
+ });
384
+
385
+ const handler = vi.fn().mockResolvedValue({
386
+ status: 'invalid',
387
+ count: 3.14,
388
+ });
389
+
390
+ const cron = new Cron(
391
+ handler,
392
+ undefined,
393
+ undefined,
394
+ undefined,
395
+ outputSchema,
396
+ );
397
+
398
+ expect(cron.outputSchema).toBe(outputSchema);
399
+ });
400
+
401
+ it('should work with multiple services', () => {
402
+ class ServiceA implements Service<'ServiceA', ServiceA> {
403
+ serviceName = 'ServiceA' as const;
404
+ async register() {
405
+ return this;
406
+ }
407
+ getA() {
408
+ return 'A';
409
+ }
410
+ }
411
+
412
+ class ServiceB implements Service<'ServiceB', ServiceB> {
413
+ serviceName = 'ServiceB' as const;
414
+ async register() {
415
+ return this;
416
+ }
417
+ getB() {
418
+ return 'B';
419
+ }
420
+ }
421
+
422
+ const services = [new ServiceA(), new ServiceB()];
423
+
424
+ const handler = vi.fn().mockImplementation(async ({ services }) => {
425
+ return {
426
+ a: services.ServiceA.getA(),
427
+ b: services.ServiceB.getB(),
428
+ };
429
+ });
430
+
431
+ const cron = new Cron(
432
+ handler,
433
+ undefined,
434
+ undefined,
435
+ undefined,
436
+ undefined,
437
+ services,
438
+ );
439
+
440
+ expect(cron.services).toEqual(services);
441
+ });
442
+
443
+ it('should maintain separate instances with different configurations', () => {
444
+ const handler1 = vi.fn().mockResolvedValue({ cron: 1 });
445
+ const handler2 = vi.fn().mockResolvedValue({ cron: 2 });
446
+
447
+ const cron1 = new CronBuilder()
448
+ .timeout(1000)
449
+ .schedule('rate(5 minutes)')
450
+ .handle(handler1);
451
+
452
+ const cron2 = new CronBuilder()
453
+ .timeout(2000)
454
+ .schedule('cron(0 0 * * *)')
455
+ .handle(handler2);
456
+
457
+ expect(cron1).toBeInstanceOf(Cron);
458
+ expect(cron2).toBeInstanceOf(Cron);
459
+ expect(cron1.timeout).toBe(1000);
460
+ expect(cron2.timeout).toBe(2000);
461
+ expect(cron1).not.toBe(cron2);
462
+ });
463
+ });
464
464
  });