@geekmidas/constructs 0.0.7 → 0.0.10

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 (284) hide show
  1. package/dist/{AWSLambdaFunction-CANc3Qo2.d.mts → AWSLambdaFunction-D5V3YVqv.d.cts} +5 -5
  2. package/dist/{AWSLambdaFunction-DWIZYsCy.mjs → AWSLambdaFunction-D_V-ZQmS.mjs} +3 -3
  3. package/dist/{AWSLambdaFunction-DWIZYsCy.mjs.map → AWSLambdaFunction-D_V-ZQmS.mjs.map} +1 -1
  4. package/dist/{AWSLambdaFunction-qA5LqPsv.cjs → AWSLambdaFunction-DhUb-Vs6.cjs} +3 -3
  5. package/dist/{AWSLambdaFunction-qA5LqPsv.cjs.map → AWSLambdaFunction-DhUb-Vs6.cjs.map} +1 -1
  6. package/dist/{AWSLambdaFunction-CwagvPG3.d.cts → AWSLambdaFunction-DvZcnL8a.d.mts} +5 -5
  7. package/dist/{AWSLambdaSubscriberAdaptor-QKVxR6qh.d.cts → AWSLambdaSubscriberAdaptor-D6kjKjSf.d.mts} +4 -4
  8. package/dist/{AWSLambdaSubscriberAdaptor-C6JYIZxn.d.mts → AWSLambdaSubscriberAdaptor-J_pSz6pu.d.cts} +4 -4
  9. package/dist/{AmazonApiGatewayEndpointAdaptor-BrB3RfbI.d.mts → AmazonApiGatewayEndpointAdaptor-B7MKo8h3.d.mts} +3 -3
  10. package/dist/{AmazonApiGatewayEndpointAdaptor-BFhJ2Rpz.d.cts → AmazonApiGatewayEndpointAdaptor-BnNd8tCz.d.cts} +2 -2
  11. package/dist/{AmazonApiGatewayEndpointAdaptor-B8mozTcG.cjs → AmazonApiGatewayEndpointAdaptor-DHBF_5jn.cjs} +2 -2
  12. package/dist/{AmazonApiGatewayEndpointAdaptor-B8mozTcG.cjs.map → AmazonApiGatewayEndpointAdaptor-DHBF_5jn.cjs.map} +1 -1
  13. package/dist/{AmazonApiGatewayEndpointAdaptor-Bmz6Cy1e.mjs → AmazonApiGatewayEndpointAdaptor-DHcUetbw.mjs} +2 -2
  14. package/dist/{AmazonApiGatewayEndpointAdaptor-Bmz6Cy1e.mjs.map → AmazonApiGatewayEndpointAdaptor-DHcUetbw.mjs.map} +1 -1
  15. package/dist/{AmazonApiGatewayV1EndpointAdaptor-Bd-o8ese.d.cts → AmazonApiGatewayV1EndpointAdaptor-BC-a2tt3.d.cts} +3 -3
  16. package/dist/{AmazonApiGatewayV1EndpointAdaptor-D4eZ-fx5.cjs → AmazonApiGatewayV1EndpointAdaptor-CmUxFoPx.cjs} +2 -2
  17. package/dist/{AmazonApiGatewayV1EndpointAdaptor-D4eZ-fx5.cjs.map → AmazonApiGatewayV1EndpointAdaptor-CmUxFoPx.cjs.map} +1 -1
  18. package/dist/{AmazonApiGatewayV1EndpointAdaptor-24g3dLn5.mjs → AmazonApiGatewayV1EndpointAdaptor-CsV6zyvn.mjs} +2 -2
  19. package/dist/{AmazonApiGatewayV1EndpointAdaptor-24g3dLn5.mjs.map → AmazonApiGatewayV1EndpointAdaptor-CsV6zyvn.mjs.map} +1 -1
  20. package/dist/{AmazonApiGatewayV1EndpointAdaptor-BtNXt0-4.d.mts → AmazonApiGatewayV1EndpointAdaptor-gO9OxdZl.d.mts} +4 -4
  21. package/dist/{AmazonApiGatewayV2EndpointAdaptor-DAJdtgek.d.mts → AmazonApiGatewayV2EndpointAdaptor-D1uz4wNg.d.mts} +4 -4
  22. package/dist/{AmazonApiGatewayV2EndpointAdaptor-Cc40RThv.mjs → AmazonApiGatewayV2EndpointAdaptor-_bFcbEa-.mjs} +2 -2
  23. package/dist/{AmazonApiGatewayV2EndpointAdaptor-Cc40RThv.mjs.map → AmazonApiGatewayV2EndpointAdaptor-_bFcbEa-.mjs.map} +1 -1
  24. package/dist/{AmazonApiGatewayV2EndpointAdaptor-J6tACl-N.cjs → AmazonApiGatewayV2EndpointAdaptor-cZbaqiUi.cjs} +2 -2
  25. package/dist/{AmazonApiGatewayV2EndpointAdaptor-J6tACl-N.cjs.map → AmazonApiGatewayV2EndpointAdaptor-cZbaqiUi.cjs.map} +1 -1
  26. package/dist/{AmazonApiGatewayV2EndpointAdaptor-DX-Uci5w.d.cts → AmazonApiGatewayV2EndpointAdaptor-zNFUPxSY.d.cts} +3 -3
  27. package/dist/Authorizer-Bbk9ziuG.d.mts +29 -0
  28. package/dist/Authorizer-iXsSB600.d.cts +29 -0
  29. package/dist/{BaseFunctionBuilder-DtO4Nwxm.cjs → BaseFunctionBuilder-BmsbV0BU.cjs} +2 -2
  30. package/dist/{BaseFunctionBuilder-DtO4Nwxm.cjs.map → BaseFunctionBuilder-BmsbV0BU.cjs.map} +1 -1
  31. package/dist/{BaseFunctionBuilder-5QCHkchp.d.cts → BaseFunctionBuilder-C4ZJPkIZ.d.cts} +2 -2
  32. package/dist/{BaseFunctionBuilder-Dda7AiID.d.mts → BaseFunctionBuilder-CxBX0arJ.d.mts} +2 -2
  33. package/dist/{BaseFunctionBuilder-BPE9JBbT.mjs → BaseFunctionBuilder-DCUtCdVL.mjs} +2 -2
  34. package/dist/{BaseFunctionBuilder-BPE9JBbT.mjs.map → BaseFunctionBuilder-DCUtCdVL.mjs.map} +1 -1
  35. package/dist/{Construct-BbKCIPQm.mjs → Construct-C3hsQBy4.mjs} +10 -13
  36. package/dist/Construct-C3hsQBy4.mjs.map +1 -0
  37. package/dist/{Construct-BSEs6uwW.cjs → Construct-VEI7M3fs.cjs} +10 -13
  38. package/dist/Construct-VEI7M3fs.cjs.map +1 -0
  39. package/dist/{Construct-Bm-PSO2V.d.cts → Construct-ci5u8Xnu.d.cts} +4 -2
  40. package/dist/{Construct-DdyYENBD.d.mts → Construct-zhmcmIdY.d.mts} +4 -2
  41. package/dist/Construct.cjs +1 -1
  42. package/dist/Construct.d.cts +1 -1
  43. package/dist/Construct.d.mts +1 -1
  44. package/dist/Construct.mjs +1 -1
  45. package/dist/{Cron-BxMXmn4t.d.cts → Cron-ByNYsQDH.d.mts} +4 -4
  46. package/dist/{Cron-CmZ6esMM.cjs → Cron-Dfgr8F9d.cjs} +5 -5
  47. package/dist/Cron-Dfgr8F9d.cjs.map +1 -0
  48. package/dist/{Cron-NDBlJhb3.d.mts → Cron-DkPL-Fms.d.cts} +4 -4
  49. package/dist/{Cron-D6hnZLk7.mjs → Cron-wP6Ob48_.mjs} +5 -5
  50. package/dist/Cron-wP6Ob48_.mjs.map +1 -0
  51. package/dist/{CronBuilder-C6K5AbIO.d.cts → CronBuilder-BknVTWLE.d.mts} +6 -5
  52. package/dist/{CronBuilder-s5x8V8hH.d.mts → CronBuilder-BqTTozUi.d.cts} +6 -5
  53. package/dist/{CronBuilder-Dfv5JguE.mjs → CronBuilder-C27c5oqh.mjs} +10 -5
  54. package/dist/CronBuilder-C27c5oqh.mjs.map +1 -0
  55. package/dist/{CronBuilder-Di7QK8Rt.cjs → CronBuilder-W1ZqCJ7m.cjs} +10 -5
  56. package/dist/CronBuilder-W1ZqCJ7m.cjs.map +1 -0
  57. package/dist/{Endpoint-COGAflGh.cjs → Endpoint-BjpQmTek.cjs} +21 -12
  58. package/dist/Endpoint-BjpQmTek.cjs.map +1 -0
  59. package/dist/{Endpoint-C7jPJzAH.d.mts → Endpoint-C16whGI-.d.mts} +45 -13
  60. package/dist/{Endpoint-DLLZvqoh.mjs → Endpoint-C98BwZjA.mjs} +21 -12
  61. package/dist/Endpoint-C98BwZjA.mjs.map +1 -0
  62. package/dist/{Endpoint-XUMNAXYy.d.cts → Endpoint-zHPjZ35J.d.cts} +45 -13
  63. package/dist/{EndpointBuilder-t6fVEKBH.d.cts → EndpointBuilder-B5l7zQU1.d.cts} +18 -12
  64. package/dist/{EndpointBuilder-CFtWQhcv.d.mts → EndpointBuilder-BzqR0xvt.d.mts} +18 -12
  65. package/dist/{EndpointBuilder-oXO_ka1-.mjs → EndpointBuilder-CCUx4vep.mjs} +28 -5
  66. package/dist/EndpointBuilder-CCUx4vep.mjs.map +1 -0
  67. package/dist/{EndpointBuilder-FJktpPOu.cjs → EndpointBuilder-D2Zu8i9b.cjs} +28 -5
  68. package/dist/EndpointBuilder-D2Zu8i9b.cjs.map +1 -0
  69. package/dist/{EndpointFactory-Kk1tpifs.cjs → EndpointFactory-C4YhgXOc.cjs} +41 -10
  70. package/dist/EndpointFactory-C4YhgXOc.cjs.map +1 -0
  71. package/dist/{EndpointFactory-DBRGrXAy.d.mts → EndpointFactory-KkyIOE62.d.cts} +29 -21
  72. package/dist/{EndpointFactory-eG8bDhOh.mjs → EndpointFactory-RAb2zcw0.mjs} +41 -10
  73. package/dist/EndpointFactory-RAb2zcw0.mjs.map +1 -0
  74. package/dist/{EndpointFactory-DInjHvFR.d.cts → EndpointFactory-VnSAdwdv.d.mts} +29 -21
  75. package/dist/{Function-CbO2NZx-.cjs → Function-1Fh6Tdkg.cjs} +4 -5
  76. package/dist/Function-1Fh6Tdkg.cjs.map +1 -0
  77. package/dist/{Function-BP58p9Mp.d.cts → Function-BbLYIKLL.d.cts} +3 -4
  78. package/dist/{Function-C5mW-38v.mjs → Function-D-QEfH7k.mjs} +4 -5
  79. package/dist/Function-D-QEfH7k.mjs.map +1 -0
  80. package/dist/{Function-C98H68DW.d.mts → Function-DFRZZCC-.d.mts} +3 -4
  81. package/dist/{FunctionBuilder-CosgPmMl.mjs → FunctionBuilder-Bxyr1Pf9.mjs} +11 -5
  82. package/dist/FunctionBuilder-Bxyr1Pf9.mjs.map +1 -0
  83. package/dist/{FunctionBuilder-DuOeWCAl.cjs → FunctionBuilder-DcEFYgbn.cjs} +11 -5
  84. package/dist/FunctionBuilder-DcEFYgbn.cjs.map +1 -0
  85. package/dist/{FunctionBuilder-BS1KgxA_.d.cts → FunctionBuilder-DdGjpiFT.d.cts} +6 -4
  86. package/dist/{FunctionBuilder-DBwR7jg7.d.mts → FunctionBuilder-DuktGyZc.d.mts} +6 -4
  87. package/dist/{FunctionExecutionWrapper-XGrSAAPD.mjs → FunctionExecutionWrapper-BL6PE6Dv.mjs} +2 -2
  88. package/dist/{FunctionExecutionWrapper-XGrSAAPD.mjs.map → FunctionExecutionWrapper-BL6PE6Dv.mjs.map} +1 -1
  89. package/dist/{FunctionExecutionWrapper-B0V7V8YS.d.mts → FunctionExecutionWrapper-CRYi047B.d.cts} +4 -4
  90. package/dist/{FunctionExecutionWrapper-Bx-Dl-2a.d.cts → FunctionExecutionWrapper-DaR-dSLw.d.mts} +4 -4
  91. package/dist/{FunctionExecutionWrapper-CElXEjPe.cjs → FunctionExecutionWrapper-Ee-CE8Fz.cjs} +2 -2
  92. package/dist/{FunctionExecutionWrapper-CElXEjPe.cjs.map → FunctionExecutionWrapper-Ee-CE8Fz.cjs.map} +1 -1
  93. package/dist/{HonoEndpointAdaptor-BrbM9vxd.d.cts → HonoEndpointAdaptor-CY1mXTe6.d.mts} +7 -6
  94. package/dist/{HonoEndpointAdaptor-CxcYKdzT.d.mts → HonoEndpointAdaptor-CYvrXBe-.d.cts} +9 -8
  95. package/dist/{HonoEndpointAdaptor-BlT1rWHV.mjs → HonoEndpointAdaptor-CyVPl4w2.mjs} +33 -16
  96. package/dist/HonoEndpointAdaptor-CyVPl4w2.mjs.map +1 -0
  97. package/dist/{HonoEndpointAdaptor-Ds433Q8w.cjs → HonoEndpointAdaptor-DcvZdYzx.cjs} +20 -3
  98. package/dist/HonoEndpointAdaptor-DcvZdYzx.cjs.map +1 -0
  99. package/dist/{Subscriber-CSt7EOlT.cjs → Subscriber-BL30GpWp.cjs} +2 -2
  100. package/dist/{Subscriber-CSt7EOlT.cjs.map → Subscriber-BL30GpWp.cjs.map} +1 -1
  101. package/dist/{Subscriber-DkCDcTUL.mjs → Subscriber-CTczVFsF.mjs} +2 -2
  102. package/dist/{Subscriber-DkCDcTUL.mjs.map → Subscriber-CTczVFsF.mjs.map} +1 -1
  103. package/dist/{Subscriber-BoFm12i_.d.cts → Subscriber-Cy28j8MS.d.cts} +2 -2
  104. package/dist/{Subscriber-BxH6n8zQ.d.mts → Subscriber-g3IWM1_d.d.mts} +2 -2
  105. package/dist/{SubscriberBuilder-BpSDPzBz.d.mts → SubscriberBuilder-BzK8kc2a.d.cts} +3 -3
  106. package/dist/{SubscriberBuilder-Bn9Hyi28.mjs → SubscriberBuilder-CekL3BoP.mjs} +2 -2
  107. package/dist/{SubscriberBuilder-Bn9Hyi28.mjs.map → SubscriberBuilder-CekL3BoP.mjs.map} +1 -1
  108. package/dist/{SubscriberBuilder-RsiOmnwq.cjs → SubscriberBuilder-D1hojYLa.cjs} +2 -2
  109. package/dist/{SubscriberBuilder-RsiOmnwq.cjs.map → SubscriberBuilder-D1hojYLa.cjs.map} +1 -1
  110. package/dist/{SubscriberBuilder-DgljKtYu.d.cts → SubscriberBuilder-YjQ7qIpQ.d.mts} +3 -3
  111. package/dist/{TestEndpointAdaptor-Ct4I-gDo.mjs → TestEndpointAdaptor-B4z9G5Ap.mjs} +3 -3
  112. package/dist/{TestEndpointAdaptor-Ct4I-gDo.mjs.map → TestEndpointAdaptor-B4z9G5Ap.mjs.map} +1 -1
  113. package/dist/{TestEndpointAdaptor-FJUob2W_.cjs → TestEndpointAdaptor-C-ahwGW6.cjs} +3 -3
  114. package/dist/{TestEndpointAdaptor-FJUob2W_.cjs.map → TestEndpointAdaptor-C-ahwGW6.cjs.map} +1 -1
  115. package/dist/{TestEndpointAdaptor-vboVyJ0w.d.mts → TestEndpointAdaptor-DGWuai69.d.mts} +2 -2
  116. package/dist/{TestEndpointAdaptor-wwEaVHAt.d.cts → TestEndpointAdaptor-uXliWYjS.d.cts} +2 -2
  117. package/dist/adaptors/aws.cjs +11 -11
  118. package/dist/adaptors/aws.d.cts +14 -13
  119. package/dist/adaptors/aws.d.mts +14 -13
  120. package/dist/adaptors/aws.mjs +11 -11
  121. package/dist/adaptors/hono.cjs +8 -8
  122. package/dist/adaptors/hono.d.cts +8 -7
  123. package/dist/adaptors/hono.d.mts +8 -7
  124. package/dist/adaptors/hono.mjs +8 -8
  125. package/dist/adaptors/testing.cjs +7 -7
  126. package/dist/adaptors/testing.d.cts +8 -7
  127. package/dist/adaptors/testing.d.mts +8 -7
  128. package/dist/adaptors/testing.mjs +7 -7
  129. package/dist/crons/Cron.cjs +6 -6
  130. package/dist/crons/Cron.d.cts +6 -6
  131. package/dist/crons/Cron.d.mts +6 -6
  132. package/dist/crons/Cron.mjs +6 -6
  133. package/dist/crons/CronBuilder.cjs +7 -7
  134. package/dist/crons/CronBuilder.d.cts +7 -7
  135. package/dist/crons/CronBuilder.d.mts +7 -7
  136. package/dist/crons/CronBuilder.mjs +7 -7
  137. package/dist/crons/index.cjs +7 -7
  138. package/dist/crons/index.d.cts +11 -11
  139. package/dist/crons/index.d.mts +11 -11
  140. package/dist/crons/index.mjs +7 -7
  141. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +7 -7
  142. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +8 -7
  143. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +8 -7
  144. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +7 -7
  145. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +8 -8
  146. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +9 -8
  147. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +9 -8
  148. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +8 -8
  149. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +8 -8
  150. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +9 -8
  151. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +9 -8
  152. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +8 -8
  153. package/dist/endpoints/Authorizer.cjs +15 -0
  154. package/dist/endpoints/Authorizer.cjs.map +1 -0
  155. package/dist/endpoints/Authorizer.d.cts +2 -0
  156. package/dist/endpoints/Authorizer.d.mts +2 -0
  157. package/dist/endpoints/Authorizer.mjs +14 -0
  158. package/dist/endpoints/Authorizer.mjs.map +1 -0
  159. package/dist/endpoints/Endpoint.cjs +6 -6
  160. package/dist/endpoints/Endpoint.d.cts +7 -6
  161. package/dist/endpoints/Endpoint.d.mts +7 -6
  162. package/dist/endpoints/Endpoint.mjs +6 -6
  163. package/dist/endpoints/EndpointBuilder.cjs +7 -7
  164. package/dist/endpoints/EndpointBuilder.d.cts +8 -7
  165. package/dist/endpoints/EndpointBuilder.d.mts +8 -7
  166. package/dist/endpoints/EndpointBuilder.mjs +7 -7
  167. package/dist/endpoints/EndpointFactory.cjs +8 -8
  168. package/dist/endpoints/EndpointFactory.d.cts +9 -8
  169. package/dist/endpoints/EndpointFactory.d.mts +9 -8
  170. package/dist/endpoints/EndpointFactory.mjs +8 -8
  171. package/dist/endpoints/HonoEndpointAdaptor.cjs +8 -8
  172. package/dist/endpoints/HonoEndpointAdaptor.d.cts +8 -7
  173. package/dist/endpoints/HonoEndpointAdaptor.d.mts +8 -7
  174. package/dist/endpoints/HonoEndpointAdaptor.mjs +8 -8
  175. package/dist/endpoints/TestEndpointAdaptor.cjs +7 -7
  176. package/dist/endpoints/TestEndpointAdaptor.d.cts +8 -7
  177. package/dist/endpoints/TestEndpointAdaptor.d.mts +8 -7
  178. package/dist/endpoints/TestEndpointAdaptor.mjs +7 -7
  179. package/dist/endpoints/helpers.cjs +7 -7
  180. package/dist/endpoints/helpers.d.cts +7 -6
  181. package/dist/endpoints/helpers.d.mts +7 -6
  182. package/dist/endpoints/helpers.mjs +7 -7
  183. package/dist/endpoints/index.cjs +8 -8
  184. package/dist/endpoints/index.d.cts +11 -10
  185. package/dist/endpoints/index.d.mts +11 -10
  186. package/dist/endpoints/index.mjs +8 -8
  187. package/dist/functions/AWSLambdaFunction.cjs +6 -6
  188. package/dist/functions/AWSLambdaFunction.d.cts +4 -4
  189. package/dist/functions/AWSLambdaFunction.d.mts +4 -4
  190. package/dist/functions/AWSLambdaFunction.mjs +6 -6
  191. package/dist/functions/BaseFunctionBuilder.cjs +2 -2
  192. package/dist/functions/BaseFunctionBuilder.d.cts +2 -2
  193. package/dist/functions/BaseFunctionBuilder.d.mts +2 -2
  194. package/dist/functions/BaseFunctionBuilder.mjs +2 -2
  195. package/dist/functions/Function.cjs +2 -2
  196. package/dist/functions/Function.d.cts +2 -2
  197. package/dist/functions/Function.d.mts +2 -2
  198. package/dist/functions/Function.mjs +2 -2
  199. package/dist/functions/FunctionBuilder.cjs +4 -4
  200. package/dist/functions/FunctionBuilder.d.cts +4 -4
  201. package/dist/functions/FunctionBuilder.d.mts +4 -4
  202. package/dist/functions/FunctionBuilder.mjs +4 -4
  203. package/dist/functions/FunctionExecutionWrapper.cjs +5 -5
  204. package/dist/functions/FunctionExecutionWrapper.d.cts +3 -3
  205. package/dist/functions/FunctionExecutionWrapper.d.mts +3 -3
  206. package/dist/functions/FunctionExecutionWrapper.mjs +5 -5
  207. package/dist/functions/TestFunctionAdaptor.cjs +5 -5
  208. package/dist/functions/TestFunctionAdaptor.d.cts +2 -2
  209. package/dist/functions/TestFunctionAdaptor.d.mts +2 -2
  210. package/dist/functions/TestFunctionAdaptor.mjs +5 -5
  211. package/dist/functions/index.cjs +5 -5
  212. package/dist/functions/index.d.cts +5 -5
  213. package/dist/functions/index.d.mts +5 -5
  214. package/dist/functions/index.mjs +5 -5
  215. package/dist/{functions-DVDb5wEA.cjs → functions-BtgBiuC_.cjs} +2 -2
  216. package/dist/{functions-DVDb5wEA.cjs.map → functions-BtgBiuC_.cjs.map} +1 -1
  217. package/dist/functions-DD-00sWF.mjs +8 -0
  218. package/dist/{functions-mM-jcphA.mjs.map → functions-DD-00sWF.mjs.map} +1 -1
  219. package/dist/{helpers-CM0U-4Vk.mjs → helpers-DtPeOhUV.mjs} +2 -2
  220. package/dist/{helpers-CM0U-4Vk.mjs.map → helpers-DtPeOhUV.mjs.map} +1 -1
  221. package/dist/{helpers-go4jiRvV.cjs → helpers-QM_FSjPY.cjs} +2 -2
  222. package/dist/{helpers-go4jiRvV.cjs.map → helpers-QM_FSjPY.cjs.map} +1 -1
  223. package/dist/index-CcmV3PKF.d.cts +9 -0
  224. package/dist/index-DQt3pQtF.d.mts +9 -0
  225. package/dist/index.cjs +1 -1
  226. package/dist/index.d.cts +1 -1
  227. package/dist/index.d.mts +1 -1
  228. package/dist/index.mjs +1 -1
  229. package/dist/publisher.d.cts +1 -1
  230. package/dist/publisher.d.mts +1 -1
  231. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +3 -3
  232. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +3 -3
  233. package/dist/subscribers/Subscriber.cjs +2 -2
  234. package/dist/subscribers/Subscriber.d.cts +2 -2
  235. package/dist/subscribers/Subscriber.d.mts +2 -2
  236. package/dist/subscribers/Subscriber.mjs +2 -2
  237. package/dist/subscribers/SubscriberBuilder.cjs +3 -3
  238. package/dist/subscribers/SubscriberBuilder.d.cts +3 -3
  239. package/dist/subscribers/SubscriberBuilder.d.mts +3 -3
  240. package/dist/subscribers/SubscriberBuilder.mjs +3 -3
  241. package/dist/subscribers/index.cjs +3 -3
  242. package/dist/subscribers/index.d.cts +5 -5
  243. package/dist/subscribers/index.d.mts +5 -5
  244. package/dist/subscribers/index.mjs +3 -3
  245. package/package.json +6 -6
  246. package/src/Construct.ts +11 -24
  247. package/src/crons/Cron.ts +2 -0
  248. package/src/crons/CronBuilder.ts +8 -0
  249. package/src/crons/__tests__/CronBuilder.state-isolation.spec.ts +227 -0
  250. package/src/endpoints/Authorizer.ts +34 -0
  251. package/src/endpoints/Endpoint.ts +67 -14
  252. package/src/endpoints/EndpointBuilder.ts +79 -12
  253. package/src/endpoints/EndpointFactory.ts +106 -27
  254. package/src/endpoints/HonoEndpointAdaptor.ts +29 -0
  255. package/src/endpoints/__tests__/Endpoint.cookies.spec.ts +85 -0
  256. package/src/endpoints/__tests__/Endpoint.headers.spec.ts +187 -0
  257. package/src/endpoints/__tests__/Endpoint.manifest.spec.ts +176 -0
  258. package/src/endpoints/__tests__/EndpointFactory.authorizers.spec.ts +259 -0
  259. package/src/endpoints/__tests__/EndpointFactory.reference-audit.spec.ts +190 -0
  260. package/src/endpoints/__tests__/EndpointFactory.state-isolation.spec.ts +155 -0
  261. package/src/functions/Function.ts +12 -2
  262. package/src/functions/FunctionBuilder.ts +9 -0
  263. package/src/functions/__tests__/FunctionBuilder.state-isolation.spec.ts +160 -0
  264. package/dist/Construct-BSEs6uwW.cjs.map +0 -1
  265. package/dist/Construct-BbKCIPQm.mjs.map +0 -1
  266. package/dist/Cron-CmZ6esMM.cjs.map +0 -1
  267. package/dist/Cron-D6hnZLk7.mjs.map +0 -1
  268. package/dist/CronBuilder-Dfv5JguE.mjs.map +0 -1
  269. package/dist/CronBuilder-Di7QK8Rt.cjs.map +0 -1
  270. package/dist/Endpoint-COGAflGh.cjs.map +0 -1
  271. package/dist/Endpoint-DLLZvqoh.mjs.map +0 -1
  272. package/dist/EndpointBuilder-FJktpPOu.cjs.map +0 -1
  273. package/dist/EndpointBuilder-oXO_ka1-.mjs.map +0 -1
  274. package/dist/EndpointFactory-Kk1tpifs.cjs.map +0 -1
  275. package/dist/EndpointFactory-eG8bDhOh.mjs.map +0 -1
  276. package/dist/Function-C5mW-38v.mjs.map +0 -1
  277. package/dist/Function-CbO2NZx-.cjs.map +0 -1
  278. package/dist/FunctionBuilder-CosgPmMl.mjs.map +0 -1
  279. package/dist/FunctionBuilder-DuOeWCAl.cjs.map +0 -1
  280. package/dist/HonoEndpointAdaptor-BlT1rWHV.mjs.map +0 -1
  281. package/dist/HonoEndpointAdaptor-Ds433Q8w.cjs.map +0 -1
  282. package/dist/functions-mM-jcphA.mjs +0 -8
  283. package/dist/index-BGr5gFrX.d.cts +0 -9
  284. package/dist/index-YM4W9XUq.d.mts +0 -9
package/dist/index.mjs CHANGED
@@ -1,3 +1,3 @@
1
- import { Construct, ConstructType } from "./Construct-BbKCIPQm.mjs";
1
+ import { Construct, ConstructType } from "./Construct-C3hsQBy4.mjs";
2
2
 
3
3
  export { Construct, ConstructType };
@@ -1,4 +1,4 @@
1
- import { Construct } from "./Construct-Bm-PSO2V.cjs";
1
+ import { Construct } from "./Construct-ci5u8Xnu.cjs";
2
2
  import { EventPublisher, MappedEvent } from "@geekmidas/events";
3
3
  import { Logger } from "@geekmidas/logger";
4
4
  import { Service, ServiceDiscovery } from "@geekmidas/services";
@@ -1,4 +1,4 @@
1
- import { Construct } from "./Construct-DdyYENBD.mjs";
1
+ import { Construct } from "./Construct-zhmcmIdY.mjs";
2
2
  import { Service, ServiceDiscovery } from "@geekmidas/services";
3
3
  import { EventPublisher, MappedEvent } from "@geekmidas/events";
4
4
  import { Logger } from "@geekmidas/logger";
@@ -1,4 +1,4 @@
1
- import "../Construct-Bm-PSO2V.cjs";
2
- import "../Subscriber-BoFm12i_.cjs";
3
- import { AWSLambdaHandler, AWSLambdaSubscriber } from "../AWSLambdaSubscriberAdaptor-QKVxR6qh.cjs";
1
+ import "../Construct-ci5u8Xnu.cjs";
2
+ import "../Subscriber-Cy28j8MS.cjs";
3
+ import { AWSLambdaHandler, AWSLambdaSubscriber } from "../AWSLambdaSubscriberAdaptor-J_pSz6pu.cjs";
4
4
  export { AWSLambdaHandler, AWSLambdaSubscriber };
@@ -1,4 +1,4 @@
1
- import "../Construct-DdyYENBD.mjs";
2
- import "../Subscriber-BxH6n8zQ.mjs";
3
- import { AWSLambdaHandler, AWSLambdaSubscriber } from "../AWSLambdaSubscriberAdaptor-C6JYIZxn.mjs";
1
+ import "../Construct-zhmcmIdY.mjs";
2
+ import "../Subscriber-g3IWM1_d.mjs";
3
+ import { AWSLambdaHandler, AWSLambdaSubscriber } from "../AWSLambdaSubscriberAdaptor-D6kjKjSf.mjs";
4
4
  export { AWSLambdaHandler, AWSLambdaSubscriber };
@@ -1,4 +1,4 @@
1
- require('../Construct-BSEs6uwW.cjs');
2
- const require_Subscriber = require('../Subscriber-CSt7EOlT.cjs');
1
+ require('../Construct-VEI7M3fs.cjs');
2
+ const require_Subscriber = require('../Subscriber-BL30GpWp.cjs');
3
3
 
4
4
  exports.Subscriber = require_Subscriber.Subscriber;
@@ -1,3 +1,3 @@
1
- import "../Construct-Bm-PSO2V.cjs";
2
- import { Subscriber, SubscriberContext, SubscriberHandler } from "../Subscriber-BoFm12i_.cjs";
1
+ import "../Construct-ci5u8Xnu.cjs";
2
+ import { Subscriber, SubscriberContext, SubscriberHandler } from "../Subscriber-Cy28j8MS.cjs";
3
3
  export { Subscriber, SubscriberContext, SubscriberHandler };
@@ -1,3 +1,3 @@
1
- import "../Construct-DdyYENBD.mjs";
2
- import { Subscriber, SubscriberContext, SubscriberHandler } from "../Subscriber-BxH6n8zQ.mjs";
1
+ import "../Construct-zhmcmIdY.mjs";
2
+ import { Subscriber, SubscriberContext, SubscriberHandler } from "../Subscriber-g3IWM1_d.mjs";
3
3
  export { Subscriber, SubscriberContext, SubscriberHandler };
@@ -1,4 +1,4 @@
1
- import "../Construct-BbKCIPQm.mjs";
2
- import { Subscriber } from "../Subscriber-DkCDcTUL.mjs";
1
+ import "../Construct-C3hsQBy4.mjs";
2
+ import { Subscriber } from "../Subscriber-CTczVFsF.mjs";
3
3
 
4
4
  export { Subscriber };
@@ -1,5 +1,5 @@
1
- require('../Construct-BSEs6uwW.cjs');
2
- require('../Subscriber-CSt7EOlT.cjs');
3
- const require_SubscriberBuilder = require('../SubscriberBuilder-RsiOmnwq.cjs');
1
+ require('../Construct-VEI7M3fs.cjs');
2
+ require('../Subscriber-BL30GpWp.cjs');
3
+ const require_SubscriberBuilder = require('../SubscriberBuilder-D1hojYLa.cjs');
4
4
 
5
5
  exports.SubscriberBuilder = require_SubscriberBuilder.SubscriberBuilder;
@@ -1,4 +1,4 @@
1
- import "../Construct-Bm-PSO2V.cjs";
2
- import "../Subscriber-BoFm12i_.cjs";
3
- import { SubscriberBuilder } from "../SubscriberBuilder-DgljKtYu.cjs";
1
+ import "../Construct-ci5u8Xnu.cjs";
2
+ import "../Subscriber-Cy28j8MS.cjs";
3
+ import { SubscriberBuilder } from "../SubscriberBuilder-BzK8kc2a.cjs";
4
4
  export { SubscriberBuilder };
@@ -1,4 +1,4 @@
1
- import "../Construct-DdyYENBD.mjs";
2
- import "../Subscriber-BxH6n8zQ.mjs";
3
- import { SubscriberBuilder } from "../SubscriberBuilder-BpSDPzBz.mjs";
1
+ import "../Construct-zhmcmIdY.mjs";
2
+ import "../Subscriber-g3IWM1_d.mjs";
3
+ import { SubscriberBuilder } from "../SubscriberBuilder-YjQ7qIpQ.mjs";
4
4
  export { SubscriberBuilder };
@@ -1,5 +1,5 @@
1
- import "../Construct-BbKCIPQm.mjs";
2
- import "../Subscriber-DkCDcTUL.mjs";
3
- import { SubscriberBuilder } from "../SubscriberBuilder-Bn9Hyi28.mjs";
1
+ import "../Construct-C3hsQBy4.mjs";
2
+ import "../Subscriber-CTczVFsF.mjs";
3
+ import { SubscriberBuilder } from "../SubscriberBuilder-CekL3BoP.mjs";
4
4
 
5
5
  export { SubscriberBuilder };
@@ -1,6 +1,6 @@
1
- require('../Construct-BSEs6uwW.cjs');
2
- const require_Subscriber = require('../Subscriber-CSt7EOlT.cjs');
3
- const require_SubscriberBuilder = require('../SubscriberBuilder-RsiOmnwq.cjs');
1
+ require('../Construct-VEI7M3fs.cjs');
2
+ const require_Subscriber = require('../Subscriber-BL30GpWp.cjs');
3
+ const require_SubscriberBuilder = require('../SubscriberBuilder-D1hojYLa.cjs');
4
4
 
5
5
  //#region src/subscribers/index.ts
6
6
  const s = new require_SubscriberBuilder.SubscriberBuilder();
@@ -1,10 +1,10 @@
1
- import "../Construct-Bm-PSO2V.cjs";
2
- import { Subscriber } from "../Subscriber-BoFm12i_.cjs";
3
- import { SubscriberBuilder } from "../SubscriberBuilder-DgljKtYu.cjs";
4
- import * as _geekmidas_logger8 from "@geekmidas/logger";
1
+ import "../Construct-ci5u8Xnu.cjs";
2
+ import { Subscriber } from "../Subscriber-Cy28j8MS.cjs";
3
+ import { SubscriberBuilder } from "../SubscriberBuilder-BzK8kc2a.cjs";
4
+ import * as _geekmidas_logger0 from "@geekmidas/logger";
5
5
 
6
6
  //#region src/subscribers/index.d.ts
7
- declare const s: SubscriberBuilder<[], _geekmidas_logger8.Logger, undefined, undefined, string, []>;
7
+ declare const s: SubscriberBuilder<[], _geekmidas_logger0.Logger, undefined, undefined, string, []>;
8
8
  //#endregion
9
9
  export { Subscriber, SubscriberBuilder, s };
10
10
  //# sourceMappingURL=index.d.cts.map
@@ -1,10 +1,10 @@
1
- import "../Construct-DdyYENBD.mjs";
2
- import { Subscriber } from "../Subscriber-BxH6n8zQ.mjs";
3
- import { SubscriberBuilder } from "../SubscriberBuilder-BpSDPzBz.mjs";
4
- import * as _geekmidas_logger5 from "@geekmidas/logger";
1
+ import "../Construct-zhmcmIdY.mjs";
2
+ import { Subscriber } from "../Subscriber-g3IWM1_d.mjs";
3
+ import { SubscriberBuilder } from "../SubscriberBuilder-YjQ7qIpQ.mjs";
4
+ import * as _geekmidas_logger1 from "@geekmidas/logger";
5
5
 
6
6
  //#region src/subscribers/index.d.ts
7
- declare const s: SubscriberBuilder<[], _geekmidas_logger5.Logger, undefined, undefined, string, []>;
7
+ declare const s: SubscriberBuilder<[], _geekmidas_logger1.Logger, undefined, undefined, string, []>;
8
8
  //#endregion
9
9
  export { Subscriber, SubscriberBuilder, s };
10
10
  //# sourceMappingURL=index.d.mts.map
@@ -1,6 +1,6 @@
1
- import "../Construct-BbKCIPQm.mjs";
2
- import { Subscriber } from "../Subscriber-DkCDcTUL.mjs";
3
- import { SubscriberBuilder } from "../SubscriberBuilder-Bn9Hyi28.mjs";
1
+ import "../Construct-C3hsQBy4.mjs";
2
+ import { Subscriber } from "../Subscriber-CTczVFsF.mjs";
3
+ import { SubscriberBuilder } from "../SubscriberBuilder-CekL3BoP.mjs";
4
4
 
5
5
  //#region src/subscribers/index.ts
6
6
  const s = new SubscriberBuilder();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@geekmidas/constructs",
3
- "version": "0.0.7",
3
+ "version": "0.0.10",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "exports": {
@@ -66,12 +66,12 @@
66
66
  "lodash.compact": "~3.0.1",
67
67
  "openapi-types": "~12.1.3",
68
68
  "fast-glob": "~3.3.3",
69
- "@geekmidas/logger": "0.0.1",
70
- "@geekmidas/events": "0.0.2",
71
69
  "@geekmidas/schema": "0.0.2",
72
70
  "@geekmidas/services": "0.0.1",
73
- "@geekmidas/cache": "0.0.7",
71
+ "@geekmidas/logger": "0.0.1",
74
72
  "@geekmidas/errors": "0.0.1",
73
+ "@geekmidas/cache": "0.0.7",
74
+ "@geekmidas/events": "0.0.2",
75
75
  "@geekmidas/rate-limit": "0.1.0"
76
76
  },
77
77
  "devDependencies": {
@@ -81,13 +81,13 @@
81
81
  "@types/lodash.uniqby": "~4.7.9",
82
82
  "@types/lodash.compact": "~3.0.9",
83
83
  "zod": "~4.1.12",
84
- "@geekmidas/testkit": "0.0.16"
84
+ "@geekmidas/testkit": "0.0.17"
85
85
  },
86
86
  "peerDependencies": {
87
87
  "@middy/core": ">=6.3.1",
88
88
  "@types/aws-lambda": ">=8.10.92",
89
89
  "hono": ">=4.8.2",
90
- "@geekmidas/envkit": "~0.0.7"
90
+ "@geekmidas/envkit": "~0.0.8"
91
91
  },
92
92
  "scripts": {
93
93
  "ts": "tsc --noEmit --skipLibCheck src/**/*.ts"
package/src/Construct.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { EnvironmentParser } from '@geekmidas/envkit';
1
+ import { SnifferEnvironmentParser } from '@geekmidas/envkit/sniffer';
2
2
  import type { EventPublisher, MappedEvent } from '@geekmidas/events';
3
3
  import type { Logger } from '@geekmidas/logger';
4
4
  import type { Service } from '@geekmidas/services';
@@ -20,6 +20,8 @@ export abstract class Construct<
20
20
 
21
21
  public readonly publisherService?: Service<TServiceName, T>,
22
22
  public outputSchema?: OutSchema,
23
+ public readonly timeout?: number,
24
+ public readonly memorySize?: number,
23
25
  ) {}
24
26
 
25
27
  /**
@@ -40,8 +42,7 @@ export abstract class Construct<
40
42
  * ```
41
43
  */
42
44
  async getEnvironment(): Promise<string[]> {
43
- const envVars = new Set<string>();
44
- const sniffer = new EnvironmentParser({});
45
+ const sniffer = new SnifferEnvironmentParser();
45
46
  const services: Service[] = compact([
46
47
  ...this.services,
47
48
  this.publisherService,
@@ -51,34 +52,20 @@ export abstract class Construct<
51
52
  // Run each service's register method with the sniffer to track env var access
52
53
  for (const service of services) {
53
54
  try {
54
- const config = service.register(sniffer);
55
+ const result = service.register(sniffer as any);
55
56
 
56
57
  // Await if it's a Promise (async services)
57
- const resolvedConfig =
58
- config && typeof config === 'object' && 'then' in config
59
- ? await Promise.resolve(config)
60
- : config;
61
-
62
- // If register returns a ConfigParser, collect its env vars
63
- if (
64
- resolvedConfig &&
65
- typeof resolvedConfig === 'object' &&
66
- 'getEnvironmentVariables' in resolvedConfig &&
67
- typeof resolvedConfig.getEnvironmentVariables === 'function'
68
- ) {
69
- const vars = resolvedConfig.getEnvironmentVariables();
70
- if (Array.isArray(vars)) {
71
- vars.forEach((v: string) => envVars.add(v));
72
- }
58
+ if (result && typeof result === 'object' && 'then' in result) {
59
+ await Promise.resolve(result);
73
60
  }
74
- } catch (serviceError) {
75
- // Service registration failed (e.g., missing env vars during .parse())
76
- // But env vars were already tracked during .create(), so we continue
61
+ } catch {
62
+ // Service registration may fail but env vars are still tracked
77
63
  continue;
78
64
  }
79
65
  }
80
66
 
81
- return Array.from(envVars).sort();
67
+ // Get tracked env vars directly from the sniffer
68
+ return sniffer.getEnvironmentVariables();
82
69
  } catch (error) {
83
70
  console.error(
84
71
  'Error determining environment variables for construct:',
package/src/crons/Cron.ts CHANGED
@@ -42,6 +42,7 @@ export class Cron<
42
42
  logger?: TLogger,
43
43
  publisherService?: Service<TEventPublisherServiceName, TEventPublisher>,
44
44
  events: any[] = [],
45
+ memorySize?: number,
45
46
  ) {
46
47
  super(
47
48
  fn,
@@ -53,6 +54,7 @@ export class Cron<
53
54
  logger,
54
55
  publisherService,
55
56
  events,
57
+ memorySize,
56
58
  );
57
59
  }
58
60
 
@@ -28,10 +28,16 @@ export class CronBuilder<
28
28
  TEventPublisherServiceName
29
29
  > {
30
30
  private _schedule?: ScheduleExpression;
31
+
31
32
  constructor() {
32
33
  super(ConstructType.Cron);
33
34
  }
34
35
 
36
+ memorySize(memorySize: number): this {
37
+ this._memorySize = memorySize;
38
+ return this;
39
+ }
40
+
35
41
  schedule(
36
42
  _expression: ScheduleExpression,
37
43
  ): CronBuilder<
@@ -175,6 +181,7 @@ export class CronBuilder<
175
181
  this._logger,
176
182
  this._publisher,
177
183
  this._events,
184
+ this._memorySize,
178
185
  );
179
186
 
180
187
  // Reset builder state after creating the cron to prevent pollution
@@ -186,6 +193,7 @@ export class CronBuilder<
186
193
  this.inputSchema = undefined;
187
194
  this.outputSchema = undefined;
188
195
  this._timeout = undefined;
196
+ this._memorySize = undefined;
189
197
 
190
198
  return cron;
191
199
  }
@@ -0,0 +1,227 @@
1
+ import { describe, expect, it } from 'vitest';
2
+ import { ConsoleLogger } from '@geekmidas/logger/console';
3
+ import { CronBuilder } from '../CronBuilder';
4
+ import type { Service } from '@geekmidas/services';
5
+
6
+ const ServiceA = {
7
+ serviceName: 'a' as const,
8
+ async register() {
9
+ return { test: () => 'a' };
10
+ },
11
+ } satisfies Service<'a', any>;
12
+
13
+ const ServiceB = {
14
+ serviceName: 'b' as const,
15
+ async register() {
16
+ return { test: () => 'b' };
17
+ },
18
+ } satisfies Service<'b', any>;
19
+
20
+ describe('CronBuilder - State Isolation', () => {
21
+ describe('singleton instance state reset', () => {
22
+ it('should reset services after handle() is called', () => {
23
+ const c = new CronBuilder();
24
+
25
+ // First cron with ServiceA and ServiceB
26
+ const cron1 = c
27
+ .schedule('rate(5 minutes)')
28
+ .services([ServiceA, ServiceB])
29
+ .handle(async () => ({}));
30
+
31
+ // Second cron should not have any services from first
32
+ const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
33
+
34
+ expect(cron1.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
35
+ expect(cron2.services.map((s) => s.serviceName)).toEqual([]);
36
+ });
37
+
38
+ it('should reset logger after handle() is called', () => {
39
+ const c = new CronBuilder();
40
+ const customLogger = new ConsoleLogger({ app: 'custom' });
41
+
42
+ // First cron with custom logger
43
+ const cron1 = c
44
+ .schedule('rate(5 minutes)')
45
+ .logger(customLogger)
46
+ .handle(async () => ({}));
47
+
48
+ // Second cron should have default logger (not the custom one)
49
+ const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
50
+
51
+ expect(cron1.logger).toBe(customLogger);
52
+ expect(cron2.logger).not.toBe(customLogger);
53
+ expect(cron2.logger).toBeInstanceOf(ConsoleLogger);
54
+ });
55
+
56
+ it('should reset schedule after handle() is called', () => {
57
+ const c = new CronBuilder();
58
+
59
+ // First cron with schedule
60
+ const cron1 = c.schedule('rate(5 minutes)').handle(async () => ({}));
61
+
62
+ // Second cron should not have schedule from first
63
+ const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
64
+
65
+ expect(cron1.schedule).toBe('rate(5 minutes)');
66
+ expect(cron2.schedule).toBe('rate(10 minutes)');
67
+
68
+ // Check internal state is reset
69
+ expect((c as any)._schedule).toBeUndefined();
70
+ });
71
+
72
+ it('should reset events after handle() is called', () => {
73
+ const c = new CronBuilder();
74
+
75
+ // Create first cron (events array should be empty initially)
76
+ const cron1 = c.schedule('rate(5 minutes)').handle(async () => ({}));
77
+
78
+ // Verify state was reset
79
+ expect((c as any)._events).toEqual([]);
80
+ expect((c as any)._services).toEqual([]);
81
+ expect((c as any)._schedule).toBeUndefined();
82
+ });
83
+
84
+ it('should reset input/output schemas after handle() is called', () => {
85
+ const c = new CronBuilder();
86
+ const inputSchema: any = { '~standard': { validate: () => ({}) } };
87
+ const outputSchema: any = { '~standard': { validate: () => ({}) } };
88
+
89
+ // First cron with schemas
90
+ const cron1 = c
91
+ .schedule('rate(5 minutes)')
92
+ .input(inputSchema)
93
+ .output(outputSchema)
94
+ .handle(async () => ({}));
95
+
96
+ // Second cron should not have schemas
97
+ const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
98
+
99
+ expect(cron1.input).toBe(inputSchema);
100
+ expect(cron1.outputSchema).toBe(outputSchema);
101
+ expect(cron2.input).toBeUndefined();
102
+ expect(cron2.outputSchema).toBeUndefined();
103
+ });
104
+
105
+ it('should reset timeout after handle() is called', () => {
106
+ const c = new CronBuilder();
107
+
108
+ // First cron with custom timeout
109
+ const cron1 = c
110
+ .schedule('rate(5 minutes)')
111
+ .timeout(5000)
112
+ .handle(async () => ({}));
113
+
114
+ // Second cron should have default timeout (30000)
115
+ const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
116
+
117
+ expect(cron1.timeout).toBe(5000);
118
+ expect(cron2.timeout).toBe(30000); // Default timeout
119
+ });
120
+ });
121
+
122
+ describe('method chaining before handle()', () => {
123
+ it('should accumulate services when chaining', () => {
124
+ const c = new CronBuilder();
125
+
126
+ const cron = c
127
+ .schedule('rate(5 minutes)')
128
+ .services([ServiceA])
129
+ .services([ServiceB])
130
+ .handle(async () => ({}));
131
+
132
+ expect(cron.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
133
+ });
134
+
135
+ it('should not share references between different builder chains', () => {
136
+ const c = new CronBuilder();
137
+
138
+ // Start two separate chains
139
+ const builder1 = c.schedule('rate(5 minutes)').services([ServiceA]);
140
+ const builder2 = c.schedule('rate(10 minutes)').services([ServiceB]);
141
+
142
+ // They should be the same instance (singleton)
143
+ expect(builder1).toBe(builder2);
144
+ expect(builder1).toBe(c);
145
+
146
+ // But after handle, state is reset
147
+ const cron1 = builder1.handle(async () => ({}));
148
+
149
+ // Now builder2 should have reset state
150
+ expect((builder2 as any)._services).toEqual([]);
151
+
152
+ // Add services again
153
+ const cron2 = builder2
154
+ .schedule('rate(15 minutes)')
155
+ .services([ServiceB])
156
+ .handle(async () => ({}));
157
+
158
+ expect(cron1.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
159
+ expect(cron2.services.map((s) => s.serviceName)).toEqual(['b']);
160
+ });
161
+ });
162
+
163
+ describe('sequential cron creation', () => {
164
+ it('should create independent crons sequentially', () => {
165
+ const c = new CronBuilder();
166
+
167
+ const cron1 = c
168
+ .schedule('rate(5 minutes)')
169
+ .services([ServiceA, ServiceB])
170
+ .handle(async () => ({ result: 1 }));
171
+
172
+ const cron2 = c
173
+ .schedule('rate(10 minutes)')
174
+ .services([ServiceA])
175
+ .handle(async () => ({ result: 2 }));
176
+
177
+ const cron3 = c
178
+ .schedule('rate(15 minutes)')
179
+ .handle(async () => ({ result: 3 }));
180
+
181
+ expect(cron1.services.map((s) => s.serviceName)).toEqual(['a', 'b']);
182
+ expect(cron1.schedule).toBe('rate(5 minutes)');
183
+
184
+ expect(cron2.services.map((s) => s.serviceName)).toEqual(['a']);
185
+ expect(cron2.schedule).toBe('rate(10 minutes)');
186
+
187
+ expect(cron3.services.map((s) => s.serviceName)).toEqual([]);
188
+ expect(cron3.schedule).toBe('rate(15 minutes)');
189
+ });
190
+ });
191
+
192
+ describe('publisher isolation', () => {
193
+ it('should reset publisher after handle() is called', () => {
194
+ const c = new CronBuilder();
195
+ const mockPublisher: any = {
196
+ serviceName: 'publisher',
197
+ async register() {
198
+ return { publish: () => {} };
199
+ },
200
+ };
201
+
202
+ const cron1 = c
203
+ .schedule('rate(5 minutes)')
204
+ .publisher(mockPublisher)
205
+ .handle(async () => ({}));
206
+
207
+ const cron2 = c.schedule('rate(10 minutes)').handle(async () => ({}));
208
+
209
+ expect((cron1 as any).publisherService).toBe(mockPublisher);
210
+ expect((cron2 as any).publisherService).toBeUndefined();
211
+ });
212
+ });
213
+
214
+ describe('cron expression types', () => {
215
+ it('should handle different schedule expression formats', () => {
216
+ const c = new CronBuilder();
217
+
218
+ const cron1 = c.schedule('rate(5 minutes)').handle(async () => ({}));
219
+ const cron2 = c.schedule('cron(0 12 * * ? *)').handle(async () => ({}));
220
+ const cron3 = c.schedule('rate(1 hour)').handle(async () => ({}));
221
+
222
+ expect(cron1.schedule).toBe('rate(5 minutes)');
223
+ expect(cron2.schedule).toBe('cron(0 12 * * ? *)');
224
+ expect(cron3.schedule).toBe('rate(1 hour)');
225
+ });
226
+ });
227
+ });
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Represents an authorizer configuration for endpoints
3
+ */
4
+ export interface Authorizer {
5
+ /**
6
+ * Unique identifier for the authorizer
7
+ */
8
+ name: string;
9
+ /**
10
+ * Type of authorizer (e.g., 'iam', 'jwt', 'custom')
11
+ */
12
+ type?: string;
13
+ /**
14
+ * Description of what this authorizer does
15
+ */
16
+ description?: string;
17
+ /**
18
+ * Additional metadata specific to the authorizer type
19
+ */
20
+ metadata?: Record<string, any>;
21
+ }
22
+
23
+ /**
24
+ * Helper to create an authorizer configuration
25
+ */
26
+ export function createAuthorizer(
27
+ name: string,
28
+ options?: Omit<Authorizer, 'name'>,
29
+ ): Authorizer {
30
+ return {
31
+ name,
32
+ ...options,
33
+ };
34
+ }