@geekmidas/constructs 0.0.1

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 (329) hide show
  1. package/README.md +614 -0
  2. package/dist/AWSLambdaFunction-CpHFE2m6.d.mts +27 -0
  3. package/dist/AWSLambdaFunction-CwagvPG3.d.cts +27 -0
  4. package/dist/AWSLambdaFunction-DWIZYsCy.mjs +79 -0
  5. package/dist/AWSLambdaFunction-DWIZYsCy.mjs.map +1 -0
  6. package/dist/AWSLambdaFunction-qA5LqPsv.cjs +85 -0
  7. package/dist/AWSLambdaFunction-qA5LqPsv.cjs.map +1 -0
  8. package/dist/AWSLambdaSubscriberAdaptor-C1wQuucQ.d.mts +32 -0
  9. package/dist/AWSLambdaSubscriberAdaptor-CmPZ10JF.cjs +138 -0
  10. package/dist/AWSLambdaSubscriberAdaptor-CmPZ10JF.cjs.map +1 -0
  11. package/dist/AWSLambdaSubscriberAdaptor-G8y3YkWj.mjs +132 -0
  12. package/dist/AWSLambdaSubscriberAdaptor-G8y3YkWj.mjs.map +1 -0
  13. package/dist/AWSLambdaSubscriberAdaptor-QKVxR6qh.d.cts +32 -0
  14. package/dist/AmazonApiGatewayEndpointAdaptor-BoBh7vvD.d.mts +61 -0
  15. package/dist/AmazonApiGatewayEndpointAdaptor-Cx1oqcqh.mjs +124 -0
  16. package/dist/AmazonApiGatewayEndpointAdaptor-Cx1oqcqh.mjs.map +1 -0
  17. package/dist/AmazonApiGatewayEndpointAdaptor-DtzgQ9Vb.d.cts +61 -0
  18. package/dist/AmazonApiGatewayEndpointAdaptor-i74DEUbc.cjs +130 -0
  19. package/dist/AmazonApiGatewayEndpointAdaptor-i74DEUbc.cjs.map +1 -0
  20. package/dist/AmazonApiGatewayV1EndpointAdaptor-CLmBDYsl.mjs +42 -0
  21. package/dist/AmazonApiGatewayV1EndpointAdaptor-CLmBDYsl.mjs.map +1 -0
  22. package/dist/AmazonApiGatewayV1EndpointAdaptor-EhMd1YqV.d.mts +21 -0
  23. package/dist/AmazonApiGatewayV1EndpointAdaptor-GkMAUPL5.cjs +47 -0
  24. package/dist/AmazonApiGatewayV1EndpointAdaptor-GkMAUPL5.cjs.map +1 -0
  25. package/dist/AmazonApiGatewayV1EndpointAdaptor-Gw-j61qM.d.cts +21 -0
  26. package/dist/AmazonApiGatewayV2EndpointAdaptor-3RqegmJC.mjs +41 -0
  27. package/dist/AmazonApiGatewayV2EndpointAdaptor-3RqegmJC.mjs.map +1 -0
  28. package/dist/AmazonApiGatewayV2EndpointAdaptor-LUlpwmUW.d.cts +21 -0
  29. package/dist/AmazonApiGatewayV2EndpointAdaptor-YlFoFSS9.cjs +46 -0
  30. package/dist/AmazonApiGatewayV2EndpointAdaptor-YlFoFSS9.cjs.map +1 -0
  31. package/dist/AmazonApiGatewayV2EndpointAdaptor-zfd1gqXA.d.mts +21 -0
  32. package/dist/BaseFunctionBuilder-5QCHkchp.d.cts +31 -0
  33. package/dist/BaseFunctionBuilder-BFPVGnKi.d.mts +31 -0
  34. package/dist/BaseFunctionBuilder-BPE9JBbT.mjs +56 -0
  35. package/dist/BaseFunctionBuilder-BPE9JBbT.mjs.map +1 -0
  36. package/dist/BaseFunctionBuilder-DtO4Nwxm.cjs +62 -0
  37. package/dist/BaseFunctionBuilder-DtO4Nwxm.cjs.map +1 -0
  38. package/dist/Construct-BSEs6uwW.cjs +75 -0
  39. package/dist/Construct-BSEs6uwW.cjs.map +1 -0
  40. package/dist/Construct-BbKCIPQm.mjs +63 -0
  41. package/dist/Construct-BbKCIPQm.mjs.map +1 -0
  42. package/dist/Construct-Bm-PSO2V.d.cts +42 -0
  43. package/dist/Construct-DIguIyw4.d.mts +42 -0
  44. package/dist/Construct.cjs +4 -0
  45. package/dist/Construct.d.cts +2 -0
  46. package/dist/Construct.d.mts +2 -0
  47. package/dist/Construct.mjs +3 -0
  48. package/dist/Cron-Bgs6EQOb.mjs +20 -0
  49. package/dist/Cron-Bgs6EQOb.mjs.map +1 -0
  50. package/dist/Cron-DQiCj3ef.cjs +25 -0
  51. package/dist/Cron-DQiCj3ef.cjs.map +1 -0
  52. package/dist/Cron-FpAw03k6.d.mts +25 -0
  53. package/dist/Cron-ztnK6zgU.d.cts +25 -0
  54. package/dist/CronBuilder-B2clNQSP.d.mts +24 -0
  55. package/dist/CronBuilder-Cje9K8lZ.d.cts +24 -0
  56. package/dist/CronBuilder-DIBqJkh_.cjs +60 -0
  57. package/dist/CronBuilder-DIBqJkh_.cjs.map +1 -0
  58. package/dist/CronBuilder-DecAvvcn.mjs +54 -0
  59. package/dist/CronBuilder-DecAvvcn.mjs.map +1 -0
  60. package/dist/Endpoint-BaHC9y4Z.cjs +291 -0
  61. package/dist/Endpoint-BaHC9y4Z.cjs.map +1 -0
  62. package/dist/Endpoint-C7z9YJHK.d.cts +405 -0
  63. package/dist/Endpoint-DCn53Vd8.d.mts +405 -0
  64. package/dist/Endpoint-ierdM62O.mjs +279 -0
  65. package/dist/Endpoint-ierdM62O.mjs.map +1 -0
  66. package/dist/EndpointBuilder-BHFSpbPR.cjs +107 -0
  67. package/dist/EndpointBuilder-BHFSpbPR.cjs.map +1 -0
  68. package/dist/EndpointBuilder-BLUsoK3l.mjs +101 -0
  69. package/dist/EndpointBuilder-BLUsoK3l.mjs.map +1 -0
  70. package/dist/EndpointBuilder-Bfnb2oJr.d.mts +49 -0
  71. package/dist/EndpointBuilder-CP9RGwZH.d.cts +49 -0
  72. package/dist/EndpointFactory-BYdDVCNj.mjs +127 -0
  73. package/dist/EndpointFactory-BYdDVCNj.mjs.map +1 -0
  74. package/dist/EndpointFactory-CNtMXgIh.d.mts +52 -0
  75. package/dist/EndpointFactory-CXX4E6Gx.cjs +139 -0
  76. package/dist/EndpointFactory-CXX4E6Gx.cjs.map +1 -0
  77. package/dist/EndpointFactory-D2zgWbXZ.d.cts +52 -0
  78. package/dist/Function-BP58p9Mp.d.cts +59 -0
  79. package/dist/Function-BsBxc2wA.d.mts +59 -0
  80. package/dist/Function-C5mW-38v.mjs +72 -0
  81. package/dist/Function-C5mW-38v.mjs.map +1 -0
  82. package/dist/Function-CbO2NZx-.cjs +84 -0
  83. package/dist/Function-CbO2NZx-.cjs.map +1 -0
  84. package/dist/FunctionBuilder-BS1KgxA_.d.cts +24 -0
  85. package/dist/FunctionBuilder-C-PfPN3r.d.mts +24 -0
  86. package/dist/FunctionBuilder-CosgPmMl.mjs +53 -0
  87. package/dist/FunctionBuilder-CosgPmMl.mjs.map +1 -0
  88. package/dist/FunctionBuilder-DuOeWCAl.cjs +59 -0
  89. package/dist/FunctionBuilder-DuOeWCAl.cjs.map +1 -0
  90. package/dist/FunctionExecutionWrapper-Bx-Dl-2a.d.cts +24 -0
  91. package/dist/FunctionExecutionWrapper-CElXEjPe.cjs +42 -0
  92. package/dist/FunctionExecutionWrapper-CElXEjPe.cjs.map +1 -0
  93. package/dist/FunctionExecutionWrapper-DvglBBjE.d.mts +24 -0
  94. package/dist/FunctionExecutionWrapper-XGrSAAPD.mjs +36 -0
  95. package/dist/FunctionExecutionWrapper-XGrSAAPD.mjs.map +1 -0
  96. package/dist/HonoEndpointAdaptor-B0IO1zj2.d.mts +41 -0
  97. package/dist/HonoEndpointAdaptor-B4snrp7v.cjs +154 -0
  98. package/dist/HonoEndpointAdaptor-B4snrp7v.cjs.map +1 -0
  99. package/dist/HonoEndpointAdaptor-B6lW9Q1k.d.cts +41 -0
  100. package/dist/HonoEndpointAdaptor-D-M4-6Tf.mjs +148 -0
  101. package/dist/HonoEndpointAdaptor-D-M4-6Tf.mjs.map +1 -0
  102. package/dist/Subscriber-BoFm12i_.d.cts +33 -0
  103. package/dist/Subscriber-BwuCaC9G.mjs +28 -0
  104. package/dist/Subscriber-BwuCaC9G.mjs.map +1 -0
  105. package/dist/Subscriber-THGsj7Iy.d.mts +33 -0
  106. package/dist/Subscriber-iMRFG7ba.cjs +34 -0
  107. package/dist/Subscriber-iMRFG7ba.cjs.map +1 -0
  108. package/dist/SubscriberBuilder-CiPxgnKT.d.mts +26 -0
  109. package/dist/SubscriberBuilder-Dhz0C_t-.mjs +54 -0
  110. package/dist/SubscriberBuilder-Dhz0C_t-.mjs.map +1 -0
  111. package/dist/SubscriberBuilder-DuIgxuzc.d.cts +26 -0
  112. package/dist/SubscriberBuilder-wthr-FL9.cjs +60 -0
  113. package/dist/SubscriberBuilder-wthr-FL9.cjs.map +1 -0
  114. package/dist/adaptors/aws.cjs +19 -0
  115. package/dist/adaptors/aws.d.cts +15 -0
  116. package/dist/adaptors/aws.d.mts +15 -0
  117. package/dist/adaptors/aws.mjs +16 -0
  118. package/dist/adaptors/hono.cjs +12 -0
  119. package/dist/adaptors/hono.d.cts +9 -0
  120. package/dist/adaptors/hono.d.mts +9 -0
  121. package/dist/adaptors/hono.mjs +12 -0
  122. package/dist/chunk-CUT6urMc.cjs +30 -0
  123. package/dist/crons/Cron.cjs +8 -0
  124. package/dist/crons/Cron.d.cts +7 -0
  125. package/dist/crons/Cron.d.mts +7 -0
  126. package/dist/crons/Cron.mjs +8 -0
  127. package/dist/crons/CronBuilder.cjs +9 -0
  128. package/dist/crons/CronBuilder.d.cts +8 -0
  129. package/dist/crons/CronBuilder.d.mts +8 -0
  130. package/dist/crons/CronBuilder.mjs +9 -0
  131. package/dist/crons/index.cjs +16 -0
  132. package/dist/crons/index.cjs.map +1 -0
  133. package/dist/crons/index.d.cts +16 -0
  134. package/dist/crons/index.d.mts +16 -0
  135. package/dist/crons/index.mjs +14 -0
  136. package/dist/crons/index.mjs.map +1 -0
  137. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +10 -0
  138. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +9 -0
  139. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +9 -0
  140. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +10 -0
  141. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +12 -0
  142. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +10 -0
  143. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +10 -0
  144. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +12 -0
  145. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +12 -0
  146. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +10 -0
  147. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +10 -0
  148. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +12 -0
  149. package/dist/endpoints/Endpoint.cjs +9 -0
  150. package/dist/endpoints/Endpoint.d.cts +8 -0
  151. package/dist/endpoints/Endpoint.d.mts +8 -0
  152. package/dist/endpoints/Endpoint.mjs +8 -0
  153. package/dist/endpoints/EndpointBuilder.cjs +9 -0
  154. package/dist/endpoints/EndpointBuilder.d.cts +9 -0
  155. package/dist/endpoints/EndpointBuilder.d.mts +9 -0
  156. package/dist/endpoints/EndpointBuilder.mjs +9 -0
  157. package/dist/endpoints/EndpointFactory.cjs +11 -0
  158. package/dist/endpoints/EndpointFactory.d.cts +10 -0
  159. package/dist/endpoints/EndpointFactory.d.mts +10 -0
  160. package/dist/endpoints/EndpointFactory.mjs +10 -0
  161. package/dist/endpoints/HonoEndpointAdaptor.cjs +12 -0
  162. package/dist/endpoints/HonoEndpointAdaptor.d.cts +9 -0
  163. package/dist/endpoints/HonoEndpointAdaptor.d.mts +9 -0
  164. package/dist/endpoints/HonoEndpointAdaptor.mjs +12 -0
  165. package/dist/endpoints/TestEndpointAdaptor.cjs +54 -0
  166. package/dist/endpoints/TestEndpointAdaptor.cjs.map +1 -0
  167. package/dist/endpoints/TestEndpointAdaptor.d.cts +29 -0
  168. package/dist/endpoints/TestEndpointAdaptor.d.mts +29 -0
  169. package/dist/endpoints/TestEndpointAdaptor.mjs +53 -0
  170. package/dist/endpoints/TestEndpointAdaptor.mjs.map +1 -0
  171. package/dist/endpoints/helpers.cjs +10 -0
  172. package/dist/endpoints/helpers.d.cts +58 -0
  173. package/dist/endpoints/helpers.d.mts +58 -0
  174. package/dist/endpoints/helpers.mjs +9 -0
  175. package/dist/endpoints/index.cjs +16 -0
  176. package/dist/endpoints/index.cjs.map +1 -0
  177. package/dist/endpoints/index.d.cts +16 -0
  178. package/dist/endpoints/index.d.mts +16 -0
  179. package/dist/endpoints/index.mjs +15 -0
  180. package/dist/endpoints/index.mjs.map +1 -0
  181. package/dist/endpoints/parseHonoQuery.cjs +3 -0
  182. package/dist/endpoints/parseHonoQuery.d.cts +12 -0
  183. package/dist/endpoints/parseHonoQuery.d.mts +12 -0
  184. package/dist/endpoints/parseHonoQuery.mjs +3 -0
  185. package/dist/endpoints/parseQueryParams.cjs +3 -0
  186. package/dist/endpoints/parseQueryParams.d.cts +13 -0
  187. package/dist/endpoints/parseQueryParams.d.mts +13 -0
  188. package/dist/endpoints/parseQueryParams.mjs +3 -0
  189. package/dist/functions/AWSLambdaFunction.cjs +9 -0
  190. package/dist/functions/AWSLambdaFunction.d.cts +5 -0
  191. package/dist/functions/AWSLambdaFunction.d.mts +5 -0
  192. package/dist/functions/AWSLambdaFunction.mjs +9 -0
  193. package/dist/functions/BaseFunctionBuilder.cjs +4 -0
  194. package/dist/functions/BaseFunctionBuilder.d.cts +3 -0
  195. package/dist/functions/BaseFunctionBuilder.d.mts +3 -0
  196. package/dist/functions/BaseFunctionBuilder.mjs +4 -0
  197. package/dist/functions/Function.cjs +5 -0
  198. package/dist/functions/Function.d.cts +3 -0
  199. package/dist/functions/Function.d.mts +3 -0
  200. package/dist/functions/Function.mjs +4 -0
  201. package/dist/functions/FunctionBuilder.cjs +6 -0
  202. package/dist/functions/FunctionBuilder.d.cts +5 -0
  203. package/dist/functions/FunctionBuilder.d.mts +5 -0
  204. package/dist/functions/FunctionBuilder.mjs +6 -0
  205. package/dist/functions/FunctionExecutionWrapper.cjs +8 -0
  206. package/dist/functions/FunctionExecutionWrapper.d.cts +4 -0
  207. package/dist/functions/FunctionExecutionWrapper.d.mts +4 -0
  208. package/dist/functions/FunctionExecutionWrapper.mjs +8 -0
  209. package/dist/functions/TestFunctionAdaptor.cjs +38 -0
  210. package/dist/functions/TestFunctionAdaptor.cjs.map +1 -0
  211. package/dist/functions/TestFunctionAdaptor.d.cts +26 -0
  212. package/dist/functions/TestFunctionAdaptor.d.mts +26 -0
  213. package/dist/functions/TestFunctionAdaptor.mjs +37 -0
  214. package/dist/functions/TestFunctionAdaptor.mjs.map +1 -0
  215. package/dist/functions/index.cjs +10 -0
  216. package/dist/functions/index.d.cts +6 -0
  217. package/dist/functions/index.d.mts +6 -0
  218. package/dist/functions/index.mjs +7 -0
  219. package/dist/functions-DVDb5wEA.cjs +13 -0
  220. package/dist/functions-DVDb5wEA.cjs.map +1 -0
  221. package/dist/functions-mM-jcphA.mjs +8 -0
  222. package/dist/functions-mM-jcphA.mjs.map +1 -0
  223. package/dist/helpers-BeGM4pP_.cjs +95 -0
  224. package/dist/helpers-BeGM4pP_.cjs.map +1 -0
  225. package/dist/helpers-DbpO95aE.mjs +83 -0
  226. package/dist/helpers-DbpO95aE.mjs.map +1 -0
  227. package/dist/index-CuGR4L7O.d.mts +9 -0
  228. package/dist/index-Fg3N3EKD.d.cts +9 -0
  229. package/dist/index.cjs +4 -0
  230. package/dist/index.d.cts +4 -0
  231. package/dist/index.d.mts +4 -0
  232. package/dist/index.mjs +3 -0
  233. package/dist/parseHonoQuery-DopC24vB.cjs +37 -0
  234. package/dist/parseHonoQuery-DopC24vB.cjs.map +1 -0
  235. package/dist/parseHonoQuery-znDKBhdE.mjs +31 -0
  236. package/dist/parseHonoQuery-znDKBhdE.mjs.map +1 -0
  237. package/dist/parseQueryParams-BJaRh3OB.mjs +32 -0
  238. package/dist/parseQueryParams-BJaRh3OB.mjs.map +1 -0
  239. package/dist/parseQueryParams-BzPop4I1.cjs +38 -0
  240. package/dist/parseQueryParams-BzPop4I1.cjs.map +1 -0
  241. package/dist/publisher-Bw4770Hi.mjs +41 -0
  242. package/dist/publisher-Bw4770Hi.mjs.map +1 -0
  243. package/dist/publisher-lFQleddL.cjs +53 -0
  244. package/dist/publisher-lFQleddL.cjs.map +1 -0
  245. package/dist/publisher.cjs +4 -0
  246. package/dist/publisher.d.cts +13 -0
  247. package/dist/publisher.d.mts +13 -0
  248. package/dist/publisher.mjs +3 -0
  249. package/dist/subscribers/AWSLambdaSubscriberAdaptor.cjs +3 -0
  250. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +4 -0
  251. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +4 -0
  252. package/dist/subscribers/AWSLambdaSubscriberAdaptor.mjs +3 -0
  253. package/dist/subscribers/Subscriber.cjs +4 -0
  254. package/dist/subscribers/Subscriber.d.cts +3 -0
  255. package/dist/subscribers/Subscriber.d.mts +3 -0
  256. package/dist/subscribers/Subscriber.mjs +4 -0
  257. package/dist/subscribers/SubscriberBuilder.cjs +5 -0
  258. package/dist/subscribers/SubscriberBuilder.d.cts +4 -0
  259. package/dist/subscribers/SubscriberBuilder.d.mts +4 -0
  260. package/dist/subscribers/SubscriberBuilder.mjs +5 -0
  261. package/dist/subscribers/index.cjs +12 -0
  262. package/dist/subscribers/index.cjs.map +1 -0
  263. package/dist/subscribers/index.d.cts +10 -0
  264. package/dist/subscribers/index.d.mts +10 -0
  265. package/dist/subscribers/index.mjs +10 -0
  266. package/dist/subscribers/index.mjs.map +1 -0
  267. package/dist/types-Bp9ysFXd.d.cts +7 -0
  268. package/dist/types-DBKNYvsW.d.mts +7 -0
  269. package/dist/types.cjs +0 -0
  270. package/dist/types.d.cts +2 -0
  271. package/dist/types.d.mts +2 -0
  272. package/dist/types.mjs +0 -0
  273. package/package.json +91 -0
  274. package/src/Construct.ts +98 -0
  275. package/src/__tests__/Construct.environment.spec.ts +360 -0
  276. package/src/__tests__/publisher.setting.spec.ts +511 -0
  277. package/src/__tests__/publisher.spec.ts +454 -0
  278. package/src/adaptors/aws.ts +4 -0
  279. package/src/adaptors/hono.ts +1 -0
  280. package/src/crons/Cron.ts +137 -0
  281. package/src/crons/CronBuilder.ts +192 -0
  282. package/src/crons/__tests__/Cron.spec.ts +464 -0
  283. package/src/crons/index.ts +11 -0
  284. package/src/endpoints/AmazonApiGatewayEndpointAdaptor.ts +315 -0
  285. package/src/endpoints/AmazonApiGatewayV1EndpointAdaptor.ts +101 -0
  286. package/src/endpoints/AmazonApiGatewayV2EndpointAdaptor.ts +95 -0
  287. package/src/endpoints/Endpoint.ts +771 -0
  288. package/src/endpoints/EndpointBuilder.ts +308 -0
  289. package/src/endpoints/EndpointFactory.ts +329 -0
  290. package/src/endpoints/HonoEndpointAdaptor.ts +365 -0
  291. package/src/endpoints/TestEndpointAdaptor.ts +130 -0
  292. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.events.spec.ts +553 -0
  293. package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.spec.ts +927 -0
  294. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.events.spec.ts +721 -0
  295. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.factory-publisher.spec.ts +296 -0
  296. package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.spec.ts +441 -0
  297. package/src/endpoints/__tests__/Endpoint.spec.ts +800 -0
  298. package/src/endpoints/__tests__/EndpointBuilder.spec.ts +488 -0
  299. package/src/endpoints/__tests__/EndpointFactory.spec.ts +479 -0
  300. package/src/endpoints/__tests__/HonoEndpointAdaptor.events.spec.ts +569 -0
  301. package/src/endpoints/__tests__/HonoEndpointAdaptor.openapi.spec.ts +313 -0
  302. package/src/endpoints/__tests__/HonoEndpointAdaptor.spec.ts +1078 -0
  303. package/src/endpoints/__tests__/TestEndpointAdaptor.spec.ts +236 -0
  304. package/src/endpoints/__tests__/__snapshots__/HonoEndpointAdaptor.spec.ts.snap +54 -0
  305. package/src/endpoints/__tests__/endpoint-types.test.ts +88 -0
  306. package/src/endpoints/helpers.ts +99 -0
  307. package/src/endpoints/index.ts +5 -0
  308. package/src/endpoints/parseHonoQuery.ts +51 -0
  309. package/src/endpoints/parseQueryParams.ts +51 -0
  310. package/src/functions/AWSLambdaFunction.ts +222 -0
  311. package/src/functions/BaseFunctionBuilder.ts +110 -0
  312. package/src/functions/Function.ts +160 -0
  313. package/src/functions/FunctionBuilder.ts +182 -0
  314. package/src/functions/FunctionExecutionWrapper.ts +86 -0
  315. package/src/functions/TestFunctionAdaptor.ts +125 -0
  316. package/src/functions/__tests__/AWSLambdaFunctionAdaptor.spec.ts +376 -0
  317. package/src/functions/__tests__/Function.spec.ts +402 -0
  318. package/src/functions/__tests__/TestFunctionAdaptor.spec.ts +398 -0
  319. package/src/functions/index.ts +10 -0
  320. package/src/index.ts +14 -0
  321. package/src/publisher.ts +83 -0
  322. package/src/subscribers/AWSLambdaSubscriberAdaptor.ts +269 -0
  323. package/src/subscribers/Subscriber.ts +112 -0
  324. package/src/subscribers/SubscriberBuilder.ts +150 -0
  325. package/src/subscribers/__tests__/AWSLambdaSubscriberAdaptor.spec.ts +623 -0
  326. package/src/subscribers/__tests__/Subscriber.spec.ts +432 -0
  327. package/src/subscribers/index.ts +5 -0
  328. package/src/types.ts +13 -0
  329. package/tsdown.config.ts +3 -0
@@ -0,0 +1,511 @@
1
+ import type { Logger } from '@geekmidas/logger';
2
+ import { type Service, ServiceDiscovery } from '@geekmidas/services';
3
+ import { beforeEach, describe, expect, it, vi } from 'vitest';
4
+ import { z } from 'zod/v4';
5
+
6
+ import { EnvironmentParser } from '@geekmidas/envkit';
7
+ import { e } from '../endpoints';
8
+
9
+ import type { EventPublisher, PublishableMessage } from '@geekmidas/events';
10
+ import { publishConstructEvents } from '../publisher';
11
+
12
+ // Test event types
13
+ type TestEvent =
14
+ | PublishableMessage<'test.created', { id: string }>
15
+ | PublishableMessage<'test.updated', { id: string; changes: string[] }>
16
+ | PublishableMessage<'test.deleted', { id: string }>;
17
+
18
+ describe('publisher service setting combinations', () => {
19
+ const mockLogger: Logger = {
20
+ debug: vi.fn(),
21
+ info: vi.fn(),
22
+ warn: vi.fn(),
23
+ error: vi.fn(),
24
+ fatal: vi.fn(),
25
+ trace: vi.fn(),
26
+ child: vi.fn(() => mockLogger),
27
+ };
28
+
29
+ const serviceDiscovery = ServiceDiscovery.getInstance(
30
+ mockLogger,
31
+ new EnvironmentParser({}),
32
+ );
33
+
34
+ // Create mock publishers
35
+ const createMockPublisher = (_name: string): EventPublisher<TestEvent> => ({
36
+ publish: vi.fn().mockResolvedValue(undefined),
37
+ });
38
+
39
+ const createMockPublisherService = (
40
+ name: string,
41
+ ): Service<string, EventPublisher<TestEvent>> => {
42
+ const publisher = createMockPublisher(name);
43
+ return {
44
+ serviceName: `${name}-publisher-${Math.random()}`,
45
+ register: vi.fn().mockResolvedValue(publisher),
46
+ };
47
+ };
48
+
49
+ beforeEach(() => {
50
+ vi.clearAllMocks();
51
+ });
52
+
53
+ describe('setting publisher via endpoint.publisher()', () => {
54
+ it('should use publisher set directly on endpoint', async () => {
55
+ const mockPublisher = createMockPublisher('endpoint');
56
+ const mockPublisherService = createMockPublisherService('endpoint');
57
+ mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
58
+
59
+ const endpoint = e
60
+ .logger(mockLogger)
61
+ .post('/test')
62
+ .publisher(mockPublisherService)
63
+ .output(z.object({ id: z.string() }))
64
+ .event({
65
+ type: 'test.created',
66
+ payload: (response) => ({ id: response.id }),
67
+ })
68
+ .handle(async () => ({ id: '123' }));
69
+
70
+ await publishConstructEvents(
71
+ endpoint,
72
+ { id: '123' },
73
+ serviceDiscovery as ServiceDiscovery<any, any>,
74
+ );
75
+
76
+ expect(mockPublisher.publish).toHaveBeenCalledWith([
77
+ {
78
+ type: 'test.created',
79
+ payload: { id: '123' },
80
+ },
81
+ ]);
82
+ });
83
+ });
84
+
85
+ describe('setting publisher via factory.publisher()', () => {
86
+ it('should use publisher from factory when not overridden', async () => {
87
+ const mockPublisher = createMockPublisher('factory');
88
+ const mockPublisherService = createMockPublisherService('factory');
89
+ mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
90
+
91
+ // Create factory with publisher
92
+ const factory = e.logger(mockLogger).publisher(mockPublisherService);
93
+
94
+ // Create endpoint using factory
95
+ const endpoint = factory
96
+ .post('/test')
97
+ .output(z.object({ id: z.string() }))
98
+ .event({
99
+ type: 'test.created',
100
+ payload: (response) => ({ id: response.id }),
101
+ })
102
+ .handle(async () => ({ id: '123' }));
103
+
104
+ // Verify the publisher service is set on the endpoint
105
+ expect(endpoint.publisherService).toBeDefined();
106
+ expect(endpoint.publisherService?.serviceName).toBe(
107
+ mockPublisherService.serviceName,
108
+ );
109
+
110
+ await publishConstructEvents(
111
+ endpoint,
112
+ { id: '123' },
113
+ serviceDiscovery as ServiceDiscovery<any, any>,
114
+ );
115
+
116
+ expect(mockPublisher.publish).toHaveBeenCalledWith([
117
+ {
118
+ type: 'test.created',
119
+ payload: { id: '123' },
120
+ },
121
+ ]);
122
+ });
123
+
124
+ it('should work with factory that has logger and services', async () => {
125
+ const mockPublisher = createMockPublisher('factory-with-services');
126
+ const mockPublisherService = createMockPublisherService(
127
+ 'factory-with-services',
128
+ );
129
+ mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
130
+
131
+ // Create factory with logger, services, and publisher
132
+ const factory = e
133
+ .logger(mockLogger)
134
+ .services([])
135
+ .publisher(mockPublisherService);
136
+
137
+ const endpoint = factory
138
+ .post('/test')
139
+ .output(z.object({ id: z.string() }))
140
+ .event({
141
+ type: 'test.created',
142
+ payload: (response) => ({ id: response.id }),
143
+ })
144
+ .handle(async () => ({ id: '456' }));
145
+
146
+ // Verify the publisher service is set
147
+ expect(endpoint.publisherService).toBeDefined();
148
+ expect(endpoint.publisherService?.serviceName).toBe(
149
+ mockPublisherService.serviceName,
150
+ );
151
+
152
+ await publishConstructEvents(
153
+ endpoint,
154
+ { id: '456' },
155
+ serviceDiscovery as ServiceDiscovery<any, any>,
156
+ );
157
+
158
+ expect(mockPublisher.publish).toHaveBeenCalledWith([
159
+ {
160
+ type: 'test.created',
161
+ payload: { id: '456' },
162
+ },
163
+ ]);
164
+ });
165
+ });
166
+
167
+ describe('overriding factory publisher at endpoint level', () => {
168
+ it('should use endpoint publisher over factory publisher', async () => {
169
+ const factoryPublisher = createMockPublisher('factory');
170
+ const factoryPublisherService = createMockPublisherService('factory');
171
+ factoryPublisherService.register = vi
172
+ .fn()
173
+ .mockResolvedValue(factoryPublisher);
174
+
175
+ const endpointPublisher = createMockPublisher('endpoint-override');
176
+ const endpointPublisherService =
177
+ createMockPublisherService('endpoint-override');
178
+ endpointPublisherService.register = vi
179
+ .fn()
180
+ .mockResolvedValue(endpointPublisher);
181
+
182
+ // Create factory with publisher
183
+ const factory = e.logger(mockLogger).publisher(factoryPublisherService);
184
+
185
+ // Create endpoint that overrides factory publisher
186
+ const endpoint = factory
187
+ .post('/test')
188
+ .publisher(endpointPublisherService) // Override factory publisher
189
+ .output(z.object({ id: z.string() }))
190
+ .event({
191
+ type: 'test.updated',
192
+ payload: (response) => ({ id: response.id, changes: ['name'] }),
193
+ })
194
+ .handle(async () => ({ id: '789' }));
195
+
196
+ await publishConstructEvents(
197
+ endpoint,
198
+ { id: '789' },
199
+ serviceDiscovery as ServiceDiscovery<any, any>,
200
+ );
201
+
202
+ // Factory publisher should NOT be called
203
+ expect(factoryPublisher.publish).not.toHaveBeenCalled();
204
+
205
+ // Endpoint publisher SHOULD be called
206
+ expect(endpointPublisher.publish).toHaveBeenCalledWith([
207
+ {
208
+ type: 'test.updated',
209
+ payload: { id: '789', changes: ['name'] },
210
+ },
211
+ ]);
212
+ });
213
+ });
214
+
215
+ describe('publisher inheritance through endpoint builder chain', () => {
216
+ it('should maintain publisher through builder method chain', async () => {
217
+ const mockPublisher = createMockPublisher('chain');
218
+ const mockPublisherService = createMockPublisherService('chain');
219
+ mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
220
+
221
+ const endpoint = e
222
+ .logger(mockLogger)
223
+ .post('/test')
224
+ .publisher(mockPublisherService)
225
+ .body(z.object({ name: z.string() }))
226
+ .output(z.object({ id: z.string() }))
227
+ .event({
228
+ type: 'test.created',
229
+ payload: (response) => ({ id: response.id }),
230
+ })
231
+ .handle(async (_body) => ({ id: '999' }));
232
+
233
+ expect(endpoint.publisherService).toBeDefined();
234
+
235
+ await publishConstructEvents(
236
+ endpoint,
237
+ { id: '999' },
238
+ serviceDiscovery as ServiceDiscovery<any, any>,
239
+ );
240
+
241
+ expect(mockPublisher.publish).toHaveBeenCalledWith([
242
+ {
243
+ type: 'test.created',
244
+ payload: { id: '999' },
245
+ },
246
+ ]);
247
+ });
248
+
249
+ it('should maintain factory publisher through builder chain', async () => {
250
+ const mockPublisher = createMockPublisher('factory-chain');
251
+ const mockPublisherService = createMockPublisherService('factory-chain');
252
+ mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
253
+
254
+ const factory = e.logger(mockLogger).publisher(mockPublisherService);
255
+
256
+ const endpoint = factory
257
+ .post('/test')
258
+ .body(z.object({ name: z.string() }))
259
+ .query(z.object({ filter: z.string().optional() }))
260
+ .output(z.object({ id: z.string() }))
261
+ .event({
262
+ type: 'test.created',
263
+ payload: (response) => ({ id: response.id }),
264
+ })
265
+ .handle(async () => ({ id: '111' }));
266
+
267
+ expect(endpoint.publisherService).toBeDefined();
268
+
269
+ await publishConstructEvents(
270
+ endpoint,
271
+ { id: '111' },
272
+ serviceDiscovery as ServiceDiscovery<any, any>,
273
+ );
274
+
275
+ expect(mockPublisher.publish).toHaveBeenCalledWith([
276
+ {
277
+ type: 'test.created',
278
+ payload: { id: '111' },
279
+ },
280
+ ]);
281
+ });
282
+ });
283
+
284
+ describe('multiple endpoints with same/different publishers', () => {
285
+ it('should handle multiple endpoints from same factory', async () => {
286
+ const mockPublisher = createMockPublisher('shared-factory');
287
+ const mockPublisherService = createMockPublisherService('shared-factory');
288
+ mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
289
+
290
+ const factory = e.logger(mockLogger).publisher(mockPublisherService);
291
+
292
+ // Create multiple endpoints from same factory
293
+ const endpoint1 = factory
294
+ .post('/users')
295
+ .output(z.object({ id: z.string() }))
296
+ .event({
297
+ type: 'test.created',
298
+ payload: (response) => ({ id: response.id }),
299
+ })
300
+ .handle(async () => ({ id: 'user-1' }));
301
+
302
+ const endpoint2 = factory
303
+ .put('/users/:id')
304
+ .output(z.object({ id: z.string() }))
305
+ .event({
306
+ type: 'test.updated',
307
+ payload: (response) => ({ id: response.id, changes: ['status'] }),
308
+ })
309
+ .handle(async () => ({ id: 'user-2' }));
310
+
311
+ // Both endpoints should have the same publisher service
312
+ expect(endpoint1.publisherService?.serviceName).toBe(
313
+ mockPublisherService.serviceName,
314
+ );
315
+ expect(endpoint2.publisherService?.serviceName).toBe(
316
+ mockPublisherService.serviceName,
317
+ );
318
+
319
+ // Test both endpoints
320
+ await publishConstructEvents(
321
+ endpoint1,
322
+ { id: 'user-1' },
323
+ serviceDiscovery as ServiceDiscovery<any, any>,
324
+ );
325
+
326
+ await publishConstructEvents(
327
+ endpoint2,
328
+ { id: 'user-2' },
329
+ serviceDiscovery as ServiceDiscovery<any, any>,
330
+ );
331
+
332
+ // Publisher should be called twice
333
+ expect(mockPublisher.publish).toHaveBeenCalledTimes(2);
334
+ expect(mockPublisher.publish).toHaveBeenNthCalledWith(1, [
335
+ {
336
+ type: 'test.created',
337
+ payload: { id: 'user-1' },
338
+ },
339
+ ]);
340
+ expect(mockPublisher.publish).toHaveBeenNthCalledWith(2, [
341
+ {
342
+ type: 'test.updated',
343
+ payload: { id: 'user-2', changes: ['status'] },
344
+ },
345
+ ]);
346
+ });
347
+
348
+ it('should handle different publishers for different endpoints', async () => {
349
+ const publisher1 = createMockPublisher('endpoint-1');
350
+ const publisherService1 = createMockPublisherService('endpoint-1');
351
+ publisherService1.register = vi.fn().mockResolvedValue(publisher1);
352
+
353
+ const publisher2 = createMockPublisher('endpoint-2');
354
+ const publisherService2 = createMockPublisherService('endpoint-2');
355
+ publisherService2.register = vi.fn().mockResolvedValue(publisher2);
356
+
357
+ const endpoint1 = e
358
+ .logger(mockLogger)
359
+ .post('/api/v1/resource')
360
+ .publisher(publisherService1)
361
+ .output(z.object({ id: z.string() }))
362
+ .event({
363
+ type: 'test.created',
364
+ payload: (response) => ({ id: response.id }),
365
+ })
366
+ .handle(async () => ({ id: 'res-1' }));
367
+
368
+ const endpoint2 = e
369
+ .logger(mockLogger)
370
+ .post('/api/v2/resource')
371
+ .publisher(publisherService2)
372
+ .output(z.object({ id: z.string() }))
373
+ .event({
374
+ type: 'test.created',
375
+ payload: (response) => ({ id: response.id }),
376
+ })
377
+ .handle(async () => ({ id: 'res-2' }));
378
+
379
+ // Test both endpoints
380
+ await publishConstructEvents(
381
+ endpoint1,
382
+ { id: 'res-1' },
383
+ serviceDiscovery as ServiceDiscovery<any, any>,
384
+ );
385
+
386
+ await publishConstructEvents(
387
+ endpoint2,
388
+ { id: 'res-2' },
389
+ serviceDiscovery as ServiceDiscovery<any, any>,
390
+ );
391
+
392
+ // Each publisher should only be called once
393
+ expect(publisher1.publish).toHaveBeenCalledTimes(1);
394
+ expect(publisher1.publish).toHaveBeenCalledWith([
395
+ {
396
+ type: 'test.created',
397
+ payload: { id: 'res-1' },
398
+ },
399
+ ]);
400
+
401
+ expect(publisher2.publish).toHaveBeenCalledTimes(1);
402
+ expect(publisher2.publish).toHaveBeenCalledWith([
403
+ {
404
+ type: 'test.created',
405
+ payload: { id: 'res-2' },
406
+ },
407
+ ]);
408
+ });
409
+ });
410
+
411
+ describe('edge cases and error scenarios', () => {
412
+ it('should handle undefined publisher gracefully', async () => {
413
+ const endpoint = e
414
+ .logger(mockLogger)
415
+ .post('/test')
416
+ .output(z.object({ id: z.string() }))
417
+
418
+ .event({
419
+ // @ts-ignore
420
+ type: 'test.created',
421
+ // @ts-ignore
422
+ payload: (response) => ({ id: response.id }),
423
+ })
424
+ .handle(async () => ({ id: '000' }));
425
+
426
+ // Should not have publisher service
427
+ expect(endpoint.publisherService).toBeUndefined();
428
+
429
+ // Should not throw, but should warn
430
+ await publishConstructEvents(
431
+ endpoint,
432
+ { id: '000' },
433
+ serviceDiscovery as ServiceDiscovery<any, any>,
434
+ );
435
+
436
+ expect(mockLogger.warn).toHaveBeenCalledWith(
437
+ 'No publisher service available',
438
+ );
439
+ });
440
+
441
+ it('should handle publisher service registration failure', async () => {
442
+ const registrationError = new Error('Service registration failed');
443
+ const mockPublisherService = createMockPublisherService('failing');
444
+ mockPublisherService.register = vi
445
+ .fn()
446
+ .mockRejectedValue(registrationError);
447
+
448
+ const endpoint = e
449
+ .logger(mockLogger)
450
+ .post('/test')
451
+ .publisher(mockPublisherService)
452
+ .output(z.object({ id: z.string() }))
453
+ .event({
454
+ type: 'test.created',
455
+ payload: (response) => ({ id: response.id }),
456
+ })
457
+ .handle(async () => ({ id: '404' }));
458
+
459
+ // Should not throw but should log error
460
+ await publishConstructEvents(
461
+ endpoint,
462
+ { id: '404' },
463
+ serviceDiscovery as ServiceDiscovery<any, any>,
464
+ );
465
+
466
+ expect(mockLogger.error).toHaveBeenCalledWith(
467
+ registrationError,
468
+ 'Something went wrong publishing events',
469
+ );
470
+ });
471
+ });
472
+
473
+ describe('factory publisher with services', () => {
474
+ it('should maintain publisher with services factory', async () => {
475
+ const mockPublisher = createMockPublisher('services');
476
+ const mockPublisherService = createMockPublisherService('services');
477
+ mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
478
+
479
+ // Test a typical factory setup with logger, services, and publisher
480
+ const factory = e
481
+ .logger(mockLogger)
482
+ .services([])
483
+ .publisher(mockPublisherService);
484
+
485
+ const endpoint = factory
486
+ .post('/api/v1/users')
487
+ .output(z.object({ id: z.string() }))
488
+ .event({
489
+ type: 'test.created',
490
+ payload: (response) => ({ id: response.id }),
491
+ })
492
+ .handle(async () => ({ id: 'services-123' }));
493
+
494
+ expect(endpoint._path).toBe('/api/v1/users');
495
+ expect(endpoint.publisherService).toBeDefined();
496
+
497
+ await publishConstructEvents(
498
+ endpoint,
499
+ { id: 'services-123' },
500
+ serviceDiscovery as ServiceDiscovery<any, any>,
501
+ );
502
+
503
+ expect(mockPublisher.publish).toHaveBeenCalledWith([
504
+ {
505
+ type: 'test.created',
506
+ payload: { id: 'services-123' },
507
+ },
508
+ ]);
509
+ });
510
+ });
511
+ });