@geekmidas/constructs 3.0.6 → 3.0.7

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 (219) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/{AWSLambdaFunction-BF1gJJjG.d.mts → AWSLambdaFunction-CC8gMZhz.d.mts} +3 -3
  3. package/dist/{AWSLambdaFunction-BF1gJJjG.d.mts.map → AWSLambdaFunction-CC8gMZhz.d.mts.map} +1 -1
  4. package/dist/{AWSLambdaSubscriberAdaptor-OQvj2lKI.d.mts → AWSLambdaSubscriberAdaptor-Cmx9OQGG.d.mts} +2 -2
  5. package/dist/{AWSLambdaSubscriberAdaptor-OQvj2lKI.d.mts.map → AWSLambdaSubscriberAdaptor-Cmx9OQGG.d.mts.map} +1 -1
  6. package/dist/{AmazonApiGatewayEndpointAdaptor-Hi8Pbp2d.d.mts → AmazonApiGatewayEndpointAdaptor-DA0rS_1Y.d.mts} +4 -4
  7. package/dist/{AmazonApiGatewayEndpointAdaptor-Hi8Pbp2d.d.mts.map → AmazonApiGatewayEndpointAdaptor-DA0rS_1Y.d.mts.map} +1 -1
  8. package/dist/{AmazonApiGatewayV1EndpointAdaptor-cpwJzU4W.d.mts → AmazonApiGatewayV1EndpointAdaptor-C7rJzNvG.d.mts} +4 -4
  9. package/dist/{AmazonApiGatewayV1EndpointAdaptor-cpwJzU4W.d.mts.map → AmazonApiGatewayV1EndpointAdaptor-C7rJzNvG.d.mts.map} +1 -1
  10. package/dist/{AmazonApiGatewayV2EndpointAdaptor-LzH3hkB-.d.mts → AmazonApiGatewayV2EndpointAdaptor-d7NP-bZX.d.mts} +4 -4
  11. package/dist/{AmazonApiGatewayV2EndpointAdaptor-LzH3hkB-.d.mts.map → AmazonApiGatewayV2EndpointAdaptor-d7NP-bZX.d.mts.map} +1 -1
  12. package/dist/{Authorizer-Dx57psuM.cjs → Authorizer-BZ1LcZFt.cjs} +1 -1
  13. package/dist/{Authorizer-Dx57psuM.cjs.map → Authorizer-BZ1LcZFt.cjs.map} +1 -1
  14. package/dist/{Authorizer-DBsrDTuf.d.mts → Authorizer-C5_FC_Rq.d.mts} +1 -1
  15. package/dist/{Authorizer-DBsrDTuf.d.mts.map → Authorizer-C5_FC_Rq.d.mts.map} +1 -1
  16. package/dist/{Authorizer-4unKN3Xn.mjs → Authorizer-CZpg1Jqk.mjs} +1 -1
  17. package/dist/{Authorizer-4unKN3Xn.mjs.map → Authorizer-CZpg1Jqk.mjs.map} +1 -1
  18. package/dist/{BaseFunctionBuilder-CsvFjzA8.d.mts → BaseFunctionBuilder-Q5qIlF-F.d.mts} +2 -2
  19. package/dist/{BaseFunctionBuilder-CsvFjzA8.d.mts.map → BaseFunctionBuilder-Q5qIlF-F.d.mts.map} +1 -1
  20. package/dist/{Construct-C2SyofdS.d.mts → Construct-BjpXFNxy.d.mts} +1 -1
  21. package/dist/{Construct-C2SyofdS.d.mts.map → Construct-BjpXFNxy.d.mts.map} +1 -1
  22. package/dist/Construct.d.mts +1 -1
  23. package/dist/{Cron-CWxjO2Fg.d.mts → Cron-BljK1gsV.d.mts} +2 -2
  24. package/dist/{Cron-BDxW6fYg.d.cts.map → Cron-BljK1gsV.d.mts.map} +1 -1
  25. package/dist/{Cron-DEKZg5j4.cjs → Cron-C1vyfJ8B.cjs} +1 -1
  26. package/dist/{Cron-DEKZg5j4.cjs.map → Cron-C1vyfJ8B.cjs.map} +1 -1
  27. package/dist/{Cron-B3vrGuaD.mjs → Cron-CjWQEad0.mjs} +1 -1
  28. package/dist/{Cron-B3vrGuaD.mjs.map → Cron-CjWQEad0.mjs.map} +1 -1
  29. package/dist/{Cron-BDxW6fYg.d.cts → Cron-CllHkk3z.d.cts} +1 -1
  30. package/dist/{Cron-CWxjO2Fg.d.mts.map → Cron-CllHkk3z.d.cts.map} +1 -1
  31. package/dist/{CronBuilder-VXpyNfp2.mjs → CronBuilder-CAJFtnmZ.mjs} +2 -2
  32. package/dist/{CronBuilder-VXpyNfp2.mjs.map → CronBuilder-CAJFtnmZ.mjs.map} +1 -1
  33. package/dist/{CronBuilder-DJnXbDGK.d.mts → CronBuilder-CG54f9LM.d.mts} +4 -4
  34. package/dist/{CronBuilder-CginrW3H.d.cts.map → CronBuilder-CG54f9LM.d.mts.map} +1 -1
  35. package/dist/{CronBuilder-BHpY6w3b.cjs → CronBuilder-CSMd02lu.cjs} +2 -2
  36. package/dist/{CronBuilder-BHpY6w3b.cjs.map → CronBuilder-CSMd02lu.cjs.map} +1 -1
  37. package/dist/{CronBuilder-CginrW3H.d.cts → CronBuilder-i23l40xs.d.cts} +2 -2
  38. package/dist/{CronBuilder-DJnXbDGK.d.mts.map → CronBuilder-i23l40xs.d.cts.map} +1 -1
  39. package/dist/{Endpoint-DtFQFL63.d.mts → Endpoint-BET0JSZK.d.mts} +4 -4
  40. package/dist/{Endpoint-DtFQFL63.d.mts.map → Endpoint-BET0JSZK.d.mts.map} +1 -1
  41. package/dist/{EndpointBuilder-DIAsH97h.d.mts → EndpointBuilder-6kdrQyIh.d.mts} +5 -5
  42. package/dist/{EndpointBuilder-DIAsH97h.d.mts.map → EndpointBuilder-6kdrQyIh.d.mts.map} +1 -1
  43. package/dist/{EndpointBuilder-Dzqcm8Yv.d.cts → EndpointBuilder-CSwIguiR.d.cts} +1 -1
  44. package/dist/{EndpointBuilder-Dzqcm8Yv.d.cts.map → EndpointBuilder-CSwIguiR.d.cts.map} +1 -1
  45. package/dist/{EndpointBuilder-QdDf3x87.cjs → EndpointBuilder-EptJojG9.cjs} +3 -3
  46. package/dist/{EndpointBuilder-QdDf3x87.cjs.map → EndpointBuilder-EptJojG9.cjs.map} +1 -1
  47. package/dist/{EndpointBuilder-CMzbGG2c.mjs → EndpointBuilder-iDpnACRb.mjs} +3 -3
  48. package/dist/{EndpointBuilder-CMzbGG2c.mjs.map → EndpointBuilder-iDpnACRb.mjs.map} +1 -1
  49. package/dist/{EndpointFactory-pCuCu_1H.d.mts → EndpointFactory-CBagQW5j.d.mts} +4 -4
  50. package/dist/{EndpointFactory-pCuCu_1H.d.mts.map → EndpointFactory-CBagQW5j.d.mts.map} +1 -1
  51. package/dist/{EndpointFactory-AsfUsn-v.cjs → EndpointFactory-D2QxeaAh.cjs} +3 -3
  52. package/dist/{EndpointFactory-AsfUsn-v.cjs.map → EndpointFactory-D2QxeaAh.cjs.map} +1 -1
  53. package/dist/{EndpointFactory-C1rh407J.d.cts → EndpointFactory-DQYSH8XK.d.cts} +2 -2
  54. package/dist/{EndpointFactory-C1rh407J.d.cts.map → EndpointFactory-DQYSH8XK.d.cts.map} +1 -1
  55. package/dist/{EndpointFactory-CkPaFZA0.mjs → EndpointFactory-wgcqWod-.mjs} +3 -3
  56. package/dist/{EndpointFactory-CkPaFZA0.mjs.map → EndpointFactory-wgcqWod-.mjs.map} +1 -1
  57. package/dist/{Function-CZw1DRQ6.d.mts → Function-D74HrBnX.d.mts} +2 -2
  58. package/dist/{Function-CZw1DRQ6.d.mts.map → Function-D74HrBnX.d.mts.map} +1 -1
  59. package/dist/{FunctionBuilder-m5BNA2Ap.d.mts → FunctionBuilder-C_qPxC8g.d.mts} +4 -4
  60. package/dist/{FunctionBuilder-m5BNA2Ap.d.mts.map → FunctionBuilder-C_qPxC8g.d.mts.map} +1 -1
  61. package/dist/{FunctionExecutionWrapper-C7yYXIq-.d.mts → FunctionExecutionWrapper-xbTmBARx.d.mts} +2 -2
  62. package/dist/{FunctionExecutionWrapper-C7yYXIq-.d.mts.map → FunctionExecutionWrapper-xbTmBARx.d.mts.map} +1 -1
  63. package/dist/{HonoEndpointAdaptor-BXga7Jqh.d.mts → HonoEndpointAdaptor-C2deTEwW.d.mts} +5 -5
  64. package/dist/{HonoEndpointAdaptor-BXga7Jqh.d.mts.map → HonoEndpointAdaptor-C2deTEwW.d.mts.map} +1 -1
  65. package/dist/MswEndpointAdaptor-B41INCc7.mjs +108 -0
  66. package/dist/MswEndpointAdaptor-B41INCc7.mjs.map +1 -0
  67. package/dist/MswEndpointAdaptor-CA_fu6Wx.cjs +120 -0
  68. package/dist/MswEndpointAdaptor-CA_fu6Wx.cjs.map +1 -0
  69. package/dist/MswEndpointAdaptor-CXgYbOxw.d.mts +101 -0
  70. package/dist/MswEndpointAdaptor-CXgYbOxw.d.mts.map +1 -0
  71. package/dist/MswEndpointAdaptor-CsYvrQeB.d.cts +101 -0
  72. package/dist/MswEndpointAdaptor-CsYvrQeB.d.cts.map +1 -0
  73. package/dist/{Subscriber-BgB3RRxb.d.mts → Subscriber-9ObcUdcC.d.mts} +2 -2
  74. package/dist/{Subscriber-BgB3RRxb.d.mts.map → Subscriber-9ObcUdcC.d.mts.map} +1 -1
  75. package/dist/{Subscriber-BEhOdNQi.mjs → Subscriber-BH76wgkL.mjs} +1 -1
  76. package/dist/{Subscriber-BEhOdNQi.mjs.map → Subscriber-BH76wgkL.mjs.map} +1 -1
  77. package/dist/{Subscriber-Scz7hrV6.cjs → Subscriber-BgspJeS4.cjs} +1 -1
  78. package/dist/{Subscriber-Scz7hrV6.cjs.map → Subscriber-BgspJeS4.cjs.map} +1 -1
  79. package/dist/{SubscriberBuilder-DlUaG0Ej.mjs → SubscriberBuilder-B4md5wzs.mjs} +2 -2
  80. package/dist/{SubscriberBuilder-DlUaG0Ej.mjs.map → SubscriberBuilder-B4md5wzs.mjs.map} +1 -1
  81. package/dist/{SubscriberBuilder-B9uva8fZ.d.cts → SubscriberBuilder-Be7WBbCL.d.cts} +1 -1
  82. package/dist/{SubscriberBuilder-B9uva8fZ.d.cts.map → SubscriberBuilder-Be7WBbCL.d.cts.map} +1 -1
  83. package/dist/{SubscriberBuilder-B82h4v-S.cjs → SubscriberBuilder-BtL22ZJ9.cjs} +2 -2
  84. package/dist/{SubscriberBuilder-B82h4v-S.cjs.map → SubscriberBuilder-BtL22ZJ9.cjs.map} +1 -1
  85. package/dist/{SubscriberBuilder-DaQkh2Nt.d.mts → SubscriberBuilder-DsfIkgTF.d.mts} +2 -2
  86. package/dist/{SubscriberBuilder-DaQkh2Nt.d.mts.map → SubscriberBuilder-DsfIkgTF.d.mts.map} +1 -1
  87. package/dist/{TestEndpointAdaptor-G2T789bH.mjs → TestEndpointAdaptor-BFmgf7Fn.mjs} +1 -1
  88. package/dist/{TestEndpointAdaptor-G2T789bH.mjs.map → TestEndpointAdaptor-BFmgf7Fn.mjs.map} +1 -1
  89. package/dist/{TestEndpointAdaptor-DxXJoBBf.d.mts → TestEndpointAdaptor-C79Z-QS4.d.mts} +3 -3
  90. package/dist/{TestEndpointAdaptor-Clz_L8Xj.d.cts.map → TestEndpointAdaptor-C79Z-QS4.d.mts.map} +1 -1
  91. package/dist/{TestEndpointAdaptor-YlwOEisx.cjs → TestEndpointAdaptor-DYLDyAAC.cjs} +1 -1
  92. package/dist/{TestEndpointAdaptor-YlwOEisx.cjs.map → TestEndpointAdaptor-DYLDyAAC.cjs.map} +1 -1
  93. package/dist/{TestEndpointAdaptor-Clz_L8Xj.d.cts → TestEndpointAdaptor-pM8yskbb.d.cts} +1 -1
  94. package/dist/{TestEndpointAdaptor-DxXJoBBf.d.mts.map → TestEndpointAdaptor-pM8yskbb.d.cts.map} +1 -1
  95. package/dist/{TestFunctionAdaptor-CH6-gO_B.cjs → TestFunctionAdaptor-B859kIeb.cjs} +1 -1
  96. package/dist/{TestFunctionAdaptor-CH6-gO_B.cjs.map → TestFunctionAdaptor-B859kIeb.cjs.map} +1 -1
  97. package/dist/{TestFunctionAdaptor-DzT8GRdR.d.mts → TestFunctionAdaptor-C0A-VqnM.d.mts} +2 -2
  98. package/dist/{TestFunctionAdaptor-BHk2bDOV.d.cts.map → TestFunctionAdaptor-C0A-VqnM.d.mts.map} +1 -1
  99. package/dist/{TestFunctionAdaptor-C5CLuR-9.mjs → TestFunctionAdaptor-CqdSlhx1.mjs} +1 -1
  100. package/dist/{TestFunctionAdaptor-C5CLuR-9.mjs.map → TestFunctionAdaptor-CqdSlhx1.mjs.map} +1 -1
  101. package/dist/{TestFunctionAdaptor-BHk2bDOV.d.cts → TestFunctionAdaptor-Dbq55dKP.d.cts} +1 -1
  102. package/dist/{TestFunctionAdaptor-DzT8GRdR.d.mts.map → TestFunctionAdaptor-Dbq55dKP.d.cts.map} +1 -1
  103. package/dist/{TestSubscriberAdaptor-CPEiqSfE.d.mts → TestSubscriberAdaptor-BEyCFP9G.d.mts} +2 -2
  104. package/dist/{TestSubscriberAdaptor-CPEiqSfE.d.mts.map → TestSubscriberAdaptor-BEyCFP9G.d.mts.map} +1 -1
  105. package/dist/{TestSubscriberAdaptor-DQk5xzb0.d.cts → TestSubscriberAdaptor-BknOLRQw.d.cts} +1 -1
  106. package/dist/{TestSubscriberAdaptor-DQk5xzb0.d.cts.map → TestSubscriberAdaptor-BknOLRQw.d.cts.map} +1 -1
  107. package/dist/{TestSubscriberAdaptor-CwP3qNJ4.mjs → TestSubscriberAdaptor-CCcviuKa.mjs} +1 -1
  108. package/dist/{TestSubscriberAdaptor-CwP3qNJ4.mjs.map → TestSubscriberAdaptor-CCcviuKa.mjs.map} +1 -1
  109. package/dist/{TestSubscriberAdaptor-Dgxr_0vL.cjs → TestSubscriberAdaptor-_69o1d0f.cjs} +1 -1
  110. package/dist/{TestSubscriberAdaptor-Dgxr_0vL.cjs.map → TestSubscriberAdaptor-_69o1d0f.cjs.map} +1 -1
  111. package/dist/adaptors/aws.d.mts +16 -16
  112. package/dist/adaptors/hono.d.mts +9 -9
  113. package/dist/adaptors/testing.cjs +10 -4
  114. package/dist/adaptors/testing.d.cts +5 -4
  115. package/dist/adaptors/testing.d.mts +14 -13
  116. package/dist/adaptors/testing.mjs +8 -4
  117. package/dist/crons/Cron.cjs +1 -1
  118. package/dist/crons/Cron.d.cts +1 -1
  119. package/dist/crons/Cron.d.mts +6 -6
  120. package/dist/crons/Cron.mjs +1 -1
  121. package/dist/crons/CronBuilder.cjs +2 -2
  122. package/dist/crons/CronBuilder.d.cts +2 -2
  123. package/dist/crons/CronBuilder.d.mts +7 -7
  124. package/dist/crons/CronBuilder.mjs +2 -2
  125. package/dist/crons/index.cjs +2 -2
  126. package/dist/crons/index.d.cts +2 -2
  127. package/dist/crons/index.d.mts +11 -11
  128. package/dist/crons/index.mjs +2 -2
  129. package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +10 -10
  130. package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +11 -11
  131. package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +11 -11
  132. package/dist/endpoints/Authorizer.cjs +1 -1
  133. package/dist/endpoints/Authorizer.d.mts +1 -1
  134. package/dist/endpoints/Authorizer.mjs +1 -1
  135. package/dist/endpoints/Endpoint.d.mts +8 -8
  136. package/dist/endpoints/EndpointBuilder.cjs +3 -3
  137. package/dist/endpoints/EndpointBuilder.d.cts +1 -1
  138. package/dist/endpoints/EndpointBuilder.d.mts +9 -9
  139. package/dist/endpoints/EndpointBuilder.mjs +3 -3
  140. package/dist/endpoints/EndpointFactory.cjs +4 -4
  141. package/dist/endpoints/EndpointFactory.d.cts +2 -2
  142. package/dist/endpoints/EndpointFactory.d.mts +10 -10
  143. package/dist/endpoints/EndpointFactory.mjs +4 -4
  144. package/dist/endpoints/HonoEndpointAdaptor.d.mts +9 -9
  145. package/dist/endpoints/MswEndpointAdaptor.cjs +16 -0
  146. package/dist/endpoints/MswEndpointAdaptor.d.cts +10 -0
  147. package/dist/endpoints/MswEndpointAdaptor.d.mts +10 -0
  148. package/dist/endpoints/MswEndpointAdaptor.mjs +15 -0
  149. package/dist/endpoints/TestEndpointAdaptor.cjs +1 -1
  150. package/dist/endpoints/TestEndpointAdaptor.d.cts +1 -1
  151. package/dist/endpoints/TestEndpointAdaptor.d.mts +9 -9
  152. package/dist/endpoints/TestEndpointAdaptor.mjs +1 -1
  153. package/dist/endpoints/audit.d.mts +8 -8
  154. package/dist/endpoints/helpers.d.mts +8 -8
  155. package/dist/endpoints/index.cjs +4 -4
  156. package/dist/endpoints/index.d.cts +4 -4
  157. package/dist/endpoints/index.d.mts +14 -14
  158. package/dist/endpoints/index.mjs +4 -4
  159. package/dist/endpoints/lazyAccessors.d.cts +1 -1
  160. package/dist/endpoints/lazyAccessors.d.mts +9 -9
  161. package/dist/endpoints/processAudits.d.mts +8 -8
  162. package/dist/endpoints/rls.cjs +1 -1
  163. package/dist/endpoints/rls.d.mts +8 -8
  164. package/dist/endpoints/rls.mjs +1 -1
  165. package/dist/functions/AWSLambdaFunction.d.mts +4 -4
  166. package/dist/functions/BaseFunctionBuilder.d.mts +2 -2
  167. package/dist/functions/Function.d.mts +2 -2
  168. package/dist/functions/FunctionBuilder.d.mts +4 -4
  169. package/dist/functions/FunctionExecutionWrapper.d.mts +3 -3
  170. package/dist/functions/TestFunctionAdaptor.cjs +1 -1
  171. package/dist/functions/TestFunctionAdaptor.d.cts +1 -1
  172. package/dist/functions/TestFunctionAdaptor.d.mts +3 -3
  173. package/dist/functions/TestFunctionAdaptor.mjs +1 -1
  174. package/dist/functions/index.d.mts +5 -5
  175. package/dist/index-Cg2UDz1r.d.mts +12 -0
  176. package/dist/{index-DQo_Csy7.d.mts.map → index-Cg2UDz1r.d.mts.map} +1 -1
  177. package/dist/index.d.mts +3 -3
  178. package/dist/{lazyAccessors-C8AF1hNi.d.cts → lazyAccessors-Bxy5DBp4.d.cts} +1 -1
  179. package/dist/{lazyAccessors-Bled3FVc.d.mts.map → lazyAccessors-Bxy5DBp4.d.cts.map} +1 -1
  180. package/dist/{lazyAccessors-Bled3FVc.d.mts → lazyAccessors-CWFdtzSR.d.mts} +2 -2
  181. package/dist/{lazyAccessors-C8AF1hNi.d.cts.map → lazyAccessors-CWFdtzSR.d.mts.map} +1 -1
  182. package/dist/{publisher-BrzPGnm4.d.cts → publisher-BUDHcaz3.d.cts} +1 -1
  183. package/dist/{publisher-BrzPGnm4.d.cts.map → publisher-BUDHcaz3.d.cts.map} +1 -1
  184. package/dist/{publisher-CP4gpv-4.d.mts → publisher-DXglijK_.d.mts} +2 -2
  185. package/dist/{publisher-CP4gpv-4.d.mts.map → publisher-DXglijK_.d.mts.map} +1 -1
  186. package/dist/publisher.d.cts +1 -1
  187. package/dist/publisher.d.mts +2 -2
  188. package/dist/{rls-7XXX7DvY.mjs → rls-C0r4UKVm.mjs} +1 -1
  189. package/dist/{rls-7XXX7DvY.mjs.map → rls-C0r4UKVm.mjs.map} +1 -1
  190. package/dist/{rls-DxFqdIA0.cjs → rls-Cfb6w-tQ.cjs} +1 -1
  191. package/dist/{rls-DxFqdIA0.cjs.map → rls-Cfb6w-tQ.cjs.map} +1 -1
  192. package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +3 -3
  193. package/dist/subscribers/Subscriber.cjs +1 -1
  194. package/dist/subscribers/Subscriber.d.mts +2 -2
  195. package/dist/subscribers/Subscriber.mjs +1 -1
  196. package/dist/subscribers/SubscriberBuilder.cjs +2 -2
  197. package/dist/subscribers/SubscriberBuilder.d.cts +1 -1
  198. package/dist/subscribers/SubscriberBuilder.d.mts +3 -3
  199. package/dist/subscribers/SubscriberBuilder.mjs +2 -2
  200. package/dist/subscribers/TestSubscriberAdaptor.cjs +1 -1
  201. package/dist/subscribers/TestSubscriberAdaptor.d.cts +1 -1
  202. package/dist/subscribers/TestSubscriberAdaptor.d.mts +3 -3
  203. package/dist/subscribers/TestSubscriberAdaptor.mjs +1 -1
  204. package/dist/subscribers/index.cjs +2 -2
  205. package/dist/subscribers/index.d.cts +1 -1
  206. package/dist/subscribers/index.d.mts +5 -5
  207. package/dist/subscribers/index.d.mts.map +1 -1
  208. package/dist/subscribers/index.mjs +2 -2
  209. package/dist/{telemetry-C-kNOW3C.d.mts → telemetry-BJo1gcV1.d.mts} +1 -1
  210. package/dist/{telemetry-C-kNOW3C.d.mts.map → telemetry-BJo1gcV1.d.mts.map} +1 -1
  211. package/dist/telemetry.d.mts +1 -1
  212. package/dist/{types-aFmq5cKh.d.mts → types-BqPOdHEm.d.mts} +1 -1
  213. package/dist/{types-aFmq5cKh.d.mts.map → types-BqPOdHEm.d.mts.map} +1 -1
  214. package/dist/types.d.mts +1 -1
  215. package/package.json +17 -12
  216. package/src/adaptors/testing.ts +7 -0
  217. package/src/endpoints/MswEndpointAdaptor.ts +226 -0
  218. package/src/endpoints/__tests__/MswEndpointAdaptor.spec.ts +219 -0
  219. package/dist/index-DQo_Csy7.d.mts +0 -12
@@ -1,5 +1,5 @@
1
- import { HttpMethod } from "./types-aFmq5cKh.mjs";
2
- import { Endpoint, EndpointSchemas } from "./Endpoint-DtFQFL63.mjs";
1
+ import { HttpMethod } from "./types-BqPOdHEm.mjs";
2
+ import { Endpoint, EndpointSchemas } from "./Endpoint-BET0JSZK.mjs";
3
3
  import { Service, ServiceDiscovery, ServiceRecord } from "@geekmidas/services";
4
4
  import { AuditStorage, AuditableAction } from "@geekmidas/audit";
5
5
  import { Context, Hono } from "hono";
@@ -7,7 +7,7 @@ import { EnvironmentParser } from "@geekmidas/envkit";
7
7
  import { EventPublisher } from "@geekmidas/events";
8
8
  import { Logger } from "@geekmidas/logger";
9
9
  import { StandardSchemaV1 } from "@standard-schema/spec";
10
- import * as hono_types6 from "hono/types";
10
+ import * as hono_types8 from "hono/types";
11
11
 
12
12
  //#region src/endpoints/HonoEndpointAdaptor.d.ts
13
13
  interface HonoEndpointOptions {
@@ -38,7 +38,7 @@ declare class HonoEndpoint<TRoute extends string, TMethod extends HttpMethod, TI
38
38
  * This method is kept for backward compatibility but does nothing.
39
39
  */
40
40
  static applyEventMiddleware(_app: Hono, _serviceDiscovery: ServiceDiscovery<any>): void;
41
- static fromRoutes<TLogger extends Logger, TServices extends Service[]>(routes: string[], envParser: EnvironmentParser<{}>, app: Hono<hono_types6.BlankEnv, hono_types6.BlankSchema, "/"> | undefined, _logger: TLogger, cwd?: string, options?: HonoEndpointOptions): Promise<Hono>;
41
+ static fromRoutes<TLogger extends Logger, TServices extends Service[]>(routes: string[], envParser: EnvironmentParser<{}>, app: Hono<hono_types8.BlankEnv, hono_types8.BlankSchema, "/"> | undefined, _logger: TLogger, cwd?: string, options?: HonoEndpointOptions): Promise<Hono>;
42
42
  static addRoutes<TServices extends Service[] = [], TLogger extends Logger = Logger>(endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[], serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>>, app: Hono, options?: HonoEndpointOptions): void;
43
43
  static addRoute<TRoute extends string, TMethod extends HttpMethod, TInput extends EndpointSchemas = {}, TOutSchema extends StandardSchemaV1 | undefined = undefined, TServices extends Service[] = [], TLogger extends Logger = Logger, TSession = unknown, TEventPublisher extends EventPublisher<any> | undefined = undefined, TEventPublisherServiceName extends string = string, TAuditStorage extends AuditStorage | undefined = undefined, TAuditStorageServiceName extends string = string, TAuditAction extends AuditableAction<string, unknown> = AuditableAction<string, unknown>, TDatabase = undefined, TDatabaseServiceName extends string = string>(endpoint: Endpoint<TRoute, TMethod, TInput, TOutSchema, TServices, TLogger, TSession, TEventPublisher, TEventPublisherServiceName, TAuditStorage, TAuditStorageServiceName, TAuditAction, TDatabase, TDatabaseServiceName>, serviceDiscovery: ServiceDiscovery<ServiceRecord<TServices>>, app: Hono): void;
44
44
  static addDocsRoute<TServices extends Service[] = [], TLogger extends Logger = Logger>(endpoints: Endpoint<string, HttpMethod, any, any, TServices, TLogger>[], app: Hono, docsPath: string, openApiOptions?: HonoEndpointOptions['openApiOptions']): void;
@@ -47,4 +47,4 @@ declare class HonoEndpoint<TRoute extends string, TMethod extends HttpMethod, TI
47
47
 
48
48
  //#endregion
49
49
  export { HonoEndpoint, HonoEndpointOptions };
50
- //# sourceMappingURL=HonoEndpointAdaptor-BXga7Jqh.d.mts.map
50
+ //# sourceMappingURL=HonoEndpointAdaptor-C2deTEwW.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"HonoEndpointAdaptor-BXga7Jqh.d.mts","names":[],"sources":["../src/endpoints/HonoEndpointAdaptor.ts"],"sourcesContent":[],"mappings":"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"}
1
+ {"version":3,"file":"HonoEndpointAdaptor-C2deTEwW.d.mts","names":[],"sources":["../src/endpoints/HonoEndpointAdaptor.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;UAqCiB,mBAAA;;;AAAjB;AAqEA;;EAAyB,QAER,CAAA,EAAA,MAAA,GAAA,KAAA;EAAU;;;EAGD,cACT,CAAA,EAAA;IAAS,KAAA,CAAA,EAAA,MAAA;IAED,OAAA,CAAA,EAAA,MAAA;IAEF,WAAA,CAAA,EAAA,MAAA;EAAY,CAAA;;AAWhC,cArBU,YAqBV,CAAA,eAAA,MAAA,EAAA,gBAnBc,UAmBd,EAAA,eAlBa,eAkBb,GAAA,CAAA,CAAA,EAAA,mBAjBiB,gBAiBjB,GAAA,SAAA,GAAA,SAAA,EAAA,kBAhBgB,OAgBhB,EAAA,GAAA,EAAA,EAAA,gBAfc,MAed,GAfuB,MAevB,EAAA,WAAA,OAAA,EAAA,wBAbsB,cAatB,CAAA,GAAA,CAAA,GAAA,SAAA,GAAA,SAAA,EAAA,mCAAA,MAAA,GAAA,MAAA,EAAA,sBAXoB,YAWpB,GAAA,SAAA,GAAA,SAAA,EAAA,iCAAA,MAAA,GAAA,MAAA,EAAA,qBATmB,eASnB,CAAA,MAAA,EAAA,OAAA,CAAA,GATsD,eAStD,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,YAAA,SAAA,EAAA,6BAAA,MAAA,GAAA,MAAA,CAAA,CAAA;EAAM,iBACN,QAAA;EAAO,WACP,CAAA,QAAA,EAH0B,QAG1B,CAFA,MAEA,EADA,OACA,EAAA,MAAA,EACA,UADA,EAEA,SAFA,EAGA,OAHA,EAIA,QAJA,EAKA,eALA,EAMA,0BANA,EAOA,aAPA,EAQA,wBARA,EASA,YATA,EAUA,SAVA,EAWA,oBAXA,CAAA;EAAM,OACN,KAAA,EAAA,OAAA;EAAU,OACV,QAAA,CAAA,UAe8B,gBAf9B,CAAA,CAAA,CAAA,EAgBE,OAhBF,CAAA,GAAA,EAAA,MAAA,EAAA,CAAA,CAAA,CAAA,EAAA,IAAA,EAAA,OAAA,EAAA,MAAA,CAAA,EAkBQ,CAlBR,CAAA,EAkBS,OAlBT,CAAA,OAAA,CAAA;EAAS,QACT,CAAA,gBAAA,EAgCiB,gBAhCjB,CAgCkC,aAhClC,CAgCgD,SAhChD,CAAA,CAAA,EAAA,GAAA,EAiCI,IAjCJ,CAAA,EAAA,IAAA;EAAO;;;;;EAKiB,OACxB,oBAAA,CAAA,IAAA,EAsCK,IAtCL,EAAA,iBAAA,EAuCkB,gBAvClB,CAAA,GAAA,CAAA,CAAA,EAAA,IAAA;EAAY,OACZ,UAAA,CAAA,gBA4CsC,MA5CtC,EAAA,kBA4CgE,OA5ChE,EAAA,CAAA,CAAA,MAAA,EAAA,MAAA,EAAA,EAAA,SAAA,EA8CU,iBA9CV,CAAA,CAAA,CAAA,CAAA,EAAA,GAAA,EA+CE,IA/CF,CA8C2B,WAAA,CACzB,QAAA,EAAA,WAAA,CAAA,WAAA,EA/CF,GAAA,CAAA,GAAA,SAAA,EAAA,OAAA,EAgDQ,OAhDR,EAAA,GAAA,CAAA,EAAA,MAAA,EAAA,OAAA,CAAA,EAkDS,mBAlDT,CAAA,EAmDC,OAnDD,CAmDS,IAnDT,CAAA;EAAS,OACT,SAAA,CAAA,kBA6DiB,OA7DjB,EAAA,GAAA,EAAA,EAAA,gBA8De,MA9Df,GA8DwB,MA9DxB,CAAA,CAAA,SAAA,EAgEU,QAhEV,CAAA,MAAA,EAgE2B,UAhE3B,EAAA,GAAA,EAAA,GAAA,EAgEiD,SAhEjD,EAgE4D,OAhE5D,CAAA,EAAA,EAAA,gBAAA,EAiEiB,gBAjEjB,CAiEkC,aAjElC,CAiEgD,SAjEhD,CAAA,CAAA,EAAA,GAAA,EAkEI,IAlEJ,EAAA,OAAA,CAAA,EAmES,mBAnET,CAAA,EAAA,IAAA;EAAoB,OAdM,QAAA,CAAA,eAAA,MAAA,EAAA,gBA2IX,UA3IW,EAAA,eA4IZ,eA5IY,GAAA,CAAA,CAAA,EAAA,mBA6IR,gBA7IQ,GAAA,SAAA,GAAA,SAAA,EAAA,kBA8IT,OA9IS,EAAA,GAAA,EAAA,EAAA,gBA+IX,MA/IW,GA+IF,MA/IE,EAAA,WAAA,OAAA,EAAA,wBAiJH,cAjJG,CAAA,GAAA,CAAA,GAAA,SAAA,GAAA,SAAA,EAAA,mCAAA,MAAA,GAAA,MAAA,EAAA,sBAmJL,YAnJK,GAAA,SAAA,GAAA,SAAA,EAAA,iCAAA,MAAA,GAAA,MAAA,EAAA,qBAqJN,eArJM,CAAA,MAAA,EAAA,OAAA,CAAA,GAqJ6B,eArJ7B,CAAA,MAAA,EAAA,OAAA,CAAA,EAAA,YAAA,SAAA,EAAA,6BAAA,MAAA,GAAA,MAAA,CAAA,CAAA,QAAA,EA4JjB,QA5JiB,CA6J1B,MA7J0B,EA8J1B,OA9J0B,EA+J1B,MA/J0B,EAgK1B,UAhK0B,EAiK1B,SAjK0B,EAkK1B,OAlK0B,EAmK1B,QAnK0B,EAoK1B,eApK0B,EAqK1B,0BArK0B,EAsK1B,aAtK0B,EAuK1B,wBAvK0B,EAwK1B,YAxK0B,EAyK1B,SAzK0B,EA0K1B,oBA1K0B,CAAA,EAAA,gBAAA,EA4KT,gBA5KS,CA4KQ,aA5KR,CA4KsB,SA5KtB,CAAA,CAAA,EAAA,GAAA,EA6KtB,IA7KsB,CAAA,EAAA,IAAA;EAAQ,OAoBJ,YAAA,CAAA,kBAoeb,OApea,EAAA,GAAA,EAAA,EAAA,gBAqef,MAree,GAqeN,MAreM,CAAA,CAAA,SAAA,EAuepB,QAveoB,CAAA,MAAA,EAueH,UAveG,EAAA,GAAA,EAAA,GAAA,EAuemB,SAvenB,EAue8B,OAve9B,CAAA,EAAA,EAAA,GAAA,EAwe1B,IAxe0B,EAAA,QAAA,EAAA,MAAA,EAAA,cAAA,CAAA,EA0ed,mBA1ec,CAAA,gBAAA,CAAA,CAAA,EAAA,IAAA"}
@@ -0,0 +1,108 @@
1
+ import { HonoEndpoint } from "./HonoEndpointAdaptor-DOUODM7n.mjs";
2
+ import { ServiceDiscovery } from "@geekmidas/services";
3
+ import { Hono } from "hono";
4
+ import { EnvironmentParser } from "@geekmidas/envkit";
5
+ import { http } from "msw";
6
+
7
+ //#region src/endpoints/MswEndpointAdaptor.ts
8
+ /**
9
+ * Header used to identify which test context a request belongs to.
10
+ * Each concurrent test registers its own context (services, db transaction, etc.)
11
+ * and the MSW handler looks it up by this header value.
12
+ */
13
+ const TEST_CONTEXT_HEADER = "x-test-context-id";
14
+ const MSW_HTTP_METHODS = [
15
+ "get",
16
+ "post",
17
+ "put",
18
+ "patch",
19
+ "delete",
20
+ "options"
21
+ ];
22
+ /**
23
+ * Creates MSW HTTP handlers from endpoint constructs.
24
+ *
25
+ * Mounts endpoints on a Hono app and creates MSW handlers that intercept
26
+ * fetch requests and route them through `app.request()` — giving frontend
27
+ * tests full endpoint behavior (validation, auth, sessions) without HTTP.
28
+ *
29
+ * Each test registers its own isolated context via `registerContext()`,
30
+ * which is resolved per-request using the `x-test-context-id` header.
31
+ * This allows concurrent tests with their own transactions and services.
32
+ *
33
+ * @param endpoints - Array of endpoint constructs to create handlers for
34
+ * @param options - Configuration including baseURL
35
+ * @returns MSW handlers, the Hono app, and context management functions
36
+ */
37
+ function createMswHandlers(endpoints, options) {
38
+ const { baseURL } = options;
39
+ const contexts = /* @__PURE__ */ new Map();
40
+ /**
41
+ * Register an isolated context for a test.
42
+ * Creates a fresh ServiceDiscovery and pre-registers all provided services.
43
+ */
44
+ function registerContext(id, ctxOptions) {
45
+ const envParser = new EnvironmentParser({});
46
+ const serviceDiscovery = new ServiceDiscovery(envParser);
47
+ const serviceDefs = [];
48
+ if (ctxOptions.services) for (const [name, instance] of Object.entries(ctxOptions.services)) serviceDefs.push({
49
+ serviceName: name,
50
+ register: () => instance
51
+ });
52
+ if (ctxOptions.database !== void 0) {
53
+ for (const endpoint of endpoints) if (endpoint.databaseService) {
54
+ serviceDefs.push({
55
+ serviceName: endpoint.databaseService.serviceName,
56
+ register: () => ctxOptions.database
57
+ });
58
+ break;
59
+ }
60
+ }
61
+ if (ctxOptions.publisher) serviceDefs.push(ctxOptions.publisher);
62
+ if (ctxOptions.auditorStorage !== void 0) {
63
+ for (const endpoint of endpoints) if (endpoint.auditorStorageService) {
64
+ serviceDefs.push({
65
+ serviceName: endpoint.auditorStorageService.serviceName,
66
+ register: () => ctxOptions.auditorStorage
67
+ });
68
+ break;
69
+ }
70
+ }
71
+ if (serviceDefs.length > 0) serviceDiscovery.register(serviceDefs);
72
+ contexts.set(id, { serviceDiscovery });
73
+ }
74
+ const handlers = [];
75
+ for (const endpoint of endpoints) {
76
+ const method = endpoint.method.toLowerCase();
77
+ if (!MSW_HTTP_METHODS.includes(method)) continue;
78
+ const mswUrl = `${baseURL}${endpoint.route}`;
79
+ const mswMethod = http[method];
80
+ handlers.push(mswMethod(mswUrl, async ({ request }) => {
81
+ const contextId = request.headers.get(TEST_CONTEXT_HEADER);
82
+ const ctx = contextId ? contexts.get(contextId) : void 0;
83
+ if (!ctx) return new Response(JSON.stringify({
84
+ error: "Missing or unknown test context ID",
85
+ hint: `Set the '${TEST_CONTEXT_HEADER}' header to a registered context ID`
86
+ }), {
87
+ status: 500,
88
+ headers: { "content-type": "application/json" }
89
+ });
90
+ const app = new Hono();
91
+ HonoEndpoint.addRoute(endpoint, ctx.serviceDiscovery, app);
92
+ const response = await app.request(request);
93
+ return new Response(response.body, {
94
+ status: response.status,
95
+ statusText: response.statusText,
96
+ headers: response.headers
97
+ });
98
+ }));
99
+ }
100
+ return {
101
+ handlers,
102
+ registerContext
103
+ };
104
+ }
105
+
106
+ //#endregion
107
+ export { TEST_CONTEXT_HEADER, createMswHandlers };
108
+ //# sourceMappingURL=MswEndpointAdaptor-B41INCc7.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MswEndpointAdaptor-B41INCc7.mjs","names":["endpoints: Endpoint<any, any, any, any, any, any>[]","options: CreateMswHandlersOptions","id: string","ctxOptions: RegisterContextOptions","serviceDefs: Service[]","handlers: HttpHandler[]"],"sources":["../src/endpoints/MswEndpointAdaptor.ts"],"sourcesContent":["import { EnvironmentParser } from '@geekmidas/envkit';\nimport type { Service } from '@geekmidas/services';\nimport { ServiceDiscovery } from '@geekmidas/services';\nimport { Hono } from 'hono';\nimport { type HttpHandler, http } from 'msw';\nimport type { Endpoint } from './Endpoint';\nimport { HonoEndpoint } from './HonoEndpointAdaptor';\n\n/**\n * Header used to identify which test context a request belongs to.\n * Each concurrent test registers its own context (services, db transaction, etc.)\n * and the MSW handler looks it up by this header value.\n */\nexport const TEST_CONTEXT_HEADER = 'x-test-context-id';\n\n/**\n * Per-test context containing an isolated ServiceDiscovery instance.\n * Registered in the context map and looked up per-request via the context ID header.\n */\nexport interface MswTestContext {\n\tserviceDiscovery: ServiceDiscovery<any>;\n}\n\n/**\n * Options for creating MSW handlers from endpoint constructs.\n *\n * @example\n * ```typescript\n * import { createMswHandlers, registerTestContext } from '@geekmidas/constructs/testing';\n * import { setupServer } from 'msw/node';\n *\n * // Create handlers once (global)\n * const { handlers, registerContext, removeContext } = createMswHandlers(\n * [getUsers, createUser],\n * { baseURL: 'http://localhost:3000' },\n * );\n * const server = setupServer(...handlers);\n *\n * // Per test: register an isolated context with its own services/transaction\n * it('should list users', async ({ db }) => {\n * const contextId = crypto.randomUUID();\n * registerContext(contextId, {\n * services: { database: db, auth: mockAuth },\n * });\n *\n * const api = createApi({\n * baseURL: 'http://localhost:3000',\n * headers: { [TEST_CONTEXT_HEADER]: contextId },\n * });\n *\n * const result = await api('GET /users');\n * expect(result).toBeDefined();\n *\n * removeContext(contextId);\n * });\n * ```\n */\nexport interface CreateMswHandlersOptions {\n\t/** Base URL the client fetches from (e.g., 'http://localhost:3000') */\n\tbaseURL: string;\n}\n\n/**\n * Options for registering a per-test context.\n * Follows the same pattern as TestRequestAdaptor — services, database,\n * publisher, and auditorStorage are provided explicitly.\n */\nexport interface RegisterContextOptions {\n\t/** Service instances keyed by serviceName */\n\tservices?: Record<string, unknown>;\n\t/** Database instance — required when endpoints use .database() */\n\tdatabase?: unknown;\n\t/** Event publisher service definition */\n\tpublisher?: Service;\n\t/** Audit storage instance — required when endpoints use .auditor() */\n\tauditorStorage?: unknown;\n}\n\nconst MSW_HTTP_METHODS = [\n\t'get',\n\t'post',\n\t'put',\n\t'patch',\n\t'delete',\n\t'options',\n] as const;\n\ntype MswHttpMethod = (typeof MSW_HTTP_METHODS)[number];\n\n/**\n * Result of creating MSW handlers from endpoint constructs.\n */\nexport interface CreateMswHandlersResult {\n\t/** MSW handlers to pass to setupServer() */\n\thandlers: HttpHandler[];\n\t/** Register an isolated context for a test */\n\tregisterContext: (id: string, options: RegisterContextOptions) => void;\n}\n\n/**\n * Creates MSW HTTP handlers from endpoint constructs.\n *\n * Mounts endpoints on a Hono app and creates MSW handlers that intercept\n * fetch requests and route them through `app.request()` — giving frontend\n * tests full endpoint behavior (validation, auth, sessions) without HTTP.\n *\n * Each test registers its own isolated context via `registerContext()`,\n * which is resolved per-request using the `x-test-context-id` header.\n * This allows concurrent tests with their own transactions and services.\n *\n * @param endpoints - Array of endpoint constructs to create handlers for\n * @param options - Configuration including baseURL\n * @returns MSW handlers, the Hono app, and context management functions\n */\nexport function createMswHandlers(\n\tendpoints: Endpoint<any, any, any, any, any, any>[],\n\toptions: CreateMswHandlersOptions,\n): CreateMswHandlersResult {\n\tconst { baseURL } = options;\n\tconst contexts = new Map<string, MswTestContext>();\n\n\t/**\n\t * Register an isolated context for a test.\n\t * Creates a fresh ServiceDiscovery and pre-registers all provided services.\n\t */\n\tfunction registerContext(id: string, ctxOptions: RegisterContextOptions) {\n\t\tconst envParser = new EnvironmentParser({});\n\t\tconst serviceDiscovery = new ServiceDiscovery(envParser);\n\n\t\tconst serviceDefs: Service[] = [];\n\n\t\t// Register explicit services\n\t\tif (ctxOptions.services) {\n\t\t\tfor (const [name, instance] of Object.entries(ctxOptions.services)) {\n\t\t\t\tserviceDefs.push({\n\t\t\t\t\tserviceName: name,\n\t\t\t\t\tregister: () => instance,\n\t\t\t\t} as Service);\n\t\t\t}\n\t\t}\n\n\t\t// Register database service from endpoint metadata\n\t\tif (ctxOptions.database !== undefined) {\n\t\t\tfor (const endpoint of endpoints) {\n\t\t\t\tif (endpoint.databaseService) {\n\t\t\t\t\tserviceDefs.push({\n\t\t\t\t\t\tserviceName: endpoint.databaseService.serviceName,\n\t\t\t\t\t\tregister: () => ctxOptions.database,\n\t\t\t\t\t} as Service);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Register publisher service\n\t\tif (ctxOptions.publisher) {\n\t\t\tserviceDefs.push(ctxOptions.publisher);\n\t\t}\n\n\t\t// Register auditor storage service from endpoint metadata\n\t\tif (ctxOptions.auditorStorage !== undefined) {\n\t\t\tfor (const endpoint of endpoints) {\n\t\t\t\tif (endpoint.auditorStorageService) {\n\t\t\t\t\tserviceDefs.push({\n\t\t\t\t\t\tserviceName: endpoint.auditorStorageService.serviceName,\n\t\t\t\t\t\tregister: () => ctxOptions.auditorStorage,\n\t\t\t\t\t} as Service);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (serviceDefs.length > 0) {\n\t\t\tserviceDiscovery.register(serviceDefs);\n\t\t}\n\n\t\tcontexts.set(id, { serviceDiscovery });\n\t}\n\n\t// Create a Hono app per-request that uses the correct ServiceDiscovery.\n\t// We use a wrapper app that resolves the context from the header,\n\t// then delegates to a context-specific Hono app.\n\tconst handlers: HttpHandler[] = [];\n\n\tfor (const endpoint of endpoints) {\n\t\tconst method = endpoint.method.toLowerCase() as MswHttpMethod;\n\t\tif (!MSW_HTTP_METHODS.includes(method)) continue;\n\n\t\tconst mswUrl = `${baseURL}${endpoint.route}`;\n\t\tconst mswMethod = http[method];\n\n\t\thandlers.push(\n\t\t\tmswMethod(mswUrl, async ({ request }) => {\n\t\t\t\tconst contextId = request.headers.get(TEST_CONTEXT_HEADER);\n\t\t\t\tconst ctx = contextId ? contexts.get(contextId) : undefined;\n\n\t\t\t\tif (!ctx) {\n\t\t\t\t\treturn new Response(\n\t\t\t\t\t\tJSON.stringify({\n\t\t\t\t\t\t\terror: 'Missing or unknown test context ID',\n\t\t\t\t\t\t\thint: `Set the '${TEST_CONTEXT_HEADER}' header to a registered context ID`,\n\t\t\t\t\t\t}),\n\t\t\t\t\t\t{ status: 500, headers: { 'content-type': 'application/json' } },\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\t// Build a fresh Hono app with this context's ServiceDiscovery\n\t\t\t\tconst app = new Hono();\n\t\t\t\tHonoEndpoint.addRoute(endpoint, ctx.serviceDiscovery as any, app);\n\n\t\t\t\tconst response = await app.request(request);\n\n\t\t\t\treturn new Response(response.body, {\n\t\t\t\t\tstatus: response.status,\n\t\t\t\t\tstatusText: response.statusText,\n\t\t\t\t\theaders: response.headers,\n\t\t\t\t});\n\t\t\t}),\n\t\t);\n\t}\n\n\treturn {\n\t\thandlers,\n\t\tregisterContext,\n\t};\n}\n"],"mappings":";;;;;;;;;;;;AAaA,MAAa,sBAAsB;AAiEnC,MAAM,mBAAmB;CACxB;CACA;CACA;CACA;CACA;CACA;AACA;;;;;;;;;;;;;;;;AA6BD,SAAgB,kBACfA,WACAC,SAC0B;CAC1B,MAAM,EAAE,SAAS,GAAG;CACpB,MAAM,2BAAW,IAAI;;;;;CAMrB,SAAS,gBAAgBC,IAAYC,YAAoC;EACxE,MAAM,YAAY,IAAI,kBAAkB,CAAE;EAC1C,MAAM,mBAAmB,IAAI,iBAAiB;EAE9C,MAAMC,cAAyB,CAAE;AAGjC,MAAI,WAAW,SACd,MAAK,MAAM,CAAC,MAAM,SAAS,IAAI,OAAO,QAAQ,WAAW,SAAS,CACjE,aAAY,KAAK;GAChB,aAAa;GACb,UAAU,MAAM;EAChB,EAAY;AAKf,MAAI,WAAW,qBACd;QAAK,MAAM,YAAY,UACtB,KAAI,SAAS,iBAAiB;AAC7B,gBAAY,KAAK;KAChB,aAAa,SAAS,gBAAgB;KACtC,UAAU,MAAM,WAAW;IAC3B,EAAY;AACb;GACA;EACD;AAIF,MAAI,WAAW,UACd,aAAY,KAAK,WAAW,UAAU;AAIvC,MAAI,WAAW,2BACd;QAAK,MAAM,YAAY,UACtB,KAAI,SAAS,uBAAuB;AACnC,gBAAY,KAAK;KAChB,aAAa,SAAS,sBAAsB;KAC5C,UAAU,MAAM,WAAW;IAC3B,EAAY;AACb;GACA;EACD;AAGF,MAAI,YAAY,SAAS,EACxB,kBAAiB,SAAS,YAAY;AAGvC,WAAS,IAAI,IAAI,EAAE,iBAAkB,EAAC;CACtC;CAKD,MAAMC,WAA0B,CAAE;AAElC,MAAK,MAAM,YAAY,WAAW;EACjC,MAAM,SAAS,SAAS,OAAO,aAAa;AAC5C,OAAK,iBAAiB,SAAS,OAAO,CAAE;EAExC,MAAM,UAAU,EAAE,QAAQ,EAAE,SAAS,MAAM;EAC3C,MAAM,YAAY,KAAK;AAEvB,WAAS,KACR,UAAU,QAAQ,OAAO,EAAE,SAAS,KAAK;GACxC,MAAM,YAAY,QAAQ,QAAQ,IAAI,oBAAoB;GAC1D,MAAM,MAAM,YAAY,SAAS,IAAI,UAAU;AAE/C,QAAK,IACJ,QAAO,IAAI,SACV,KAAK,UAAU;IACd,OAAO;IACP,OAAO,WAAW,oBAAoB;GACtC,EAAC,EACF;IAAE,QAAQ;IAAK,SAAS,EAAE,gBAAgB,mBAAoB;GAAE;GAKlE,MAAM,MAAM,IAAI;AAChB,gBAAa,SAAS,UAAU,IAAI,kBAAyB,IAAI;GAEjE,MAAM,WAAW,MAAM,IAAI,QAAQ,QAAQ;AAE3C,UAAO,IAAI,SAAS,SAAS,MAAM;IAClC,QAAQ,SAAS;IACjB,YAAY,SAAS;IACrB,SAAS,SAAS;GAClB;EACD,EAAC,CACF;CACD;AAED,QAAO;EACN;EACA;CACA;AACD"}
@@ -0,0 +1,120 @@
1
+ const require_chunk = require('./chunk-CUT6urMc.cjs');
2
+ const require_HonoEndpointAdaptor = require('./HonoEndpointAdaptor-B5fKdLi7.cjs');
3
+ const __geekmidas_services = require_chunk.__toESM(require("@geekmidas/services"));
4
+ const hono = require_chunk.__toESM(require("hono"));
5
+ const __geekmidas_envkit = require_chunk.__toESM(require("@geekmidas/envkit"));
6
+ const msw = require_chunk.__toESM(require("msw"));
7
+
8
+ //#region src/endpoints/MswEndpointAdaptor.ts
9
+ /**
10
+ * Header used to identify which test context a request belongs to.
11
+ * Each concurrent test registers its own context (services, db transaction, etc.)
12
+ * and the MSW handler looks it up by this header value.
13
+ */
14
+ const TEST_CONTEXT_HEADER = "x-test-context-id";
15
+ const MSW_HTTP_METHODS = [
16
+ "get",
17
+ "post",
18
+ "put",
19
+ "patch",
20
+ "delete",
21
+ "options"
22
+ ];
23
+ /**
24
+ * Creates MSW HTTP handlers from endpoint constructs.
25
+ *
26
+ * Mounts endpoints on a Hono app and creates MSW handlers that intercept
27
+ * fetch requests and route them through `app.request()` — giving frontend
28
+ * tests full endpoint behavior (validation, auth, sessions) without HTTP.
29
+ *
30
+ * Each test registers its own isolated context via `registerContext()`,
31
+ * which is resolved per-request using the `x-test-context-id` header.
32
+ * This allows concurrent tests with their own transactions and services.
33
+ *
34
+ * @param endpoints - Array of endpoint constructs to create handlers for
35
+ * @param options - Configuration including baseURL
36
+ * @returns MSW handlers, the Hono app, and context management functions
37
+ */
38
+ function createMswHandlers(endpoints, options) {
39
+ const { baseURL } = options;
40
+ const contexts = /* @__PURE__ */ new Map();
41
+ /**
42
+ * Register an isolated context for a test.
43
+ * Creates a fresh ServiceDiscovery and pre-registers all provided services.
44
+ */
45
+ function registerContext(id, ctxOptions) {
46
+ const envParser = new __geekmidas_envkit.EnvironmentParser({});
47
+ const serviceDiscovery = new __geekmidas_services.ServiceDiscovery(envParser);
48
+ const serviceDefs = [];
49
+ if (ctxOptions.services) for (const [name, instance] of Object.entries(ctxOptions.services)) serviceDefs.push({
50
+ serviceName: name,
51
+ register: () => instance
52
+ });
53
+ if (ctxOptions.database !== void 0) {
54
+ for (const endpoint of endpoints) if (endpoint.databaseService) {
55
+ serviceDefs.push({
56
+ serviceName: endpoint.databaseService.serviceName,
57
+ register: () => ctxOptions.database
58
+ });
59
+ break;
60
+ }
61
+ }
62
+ if (ctxOptions.publisher) serviceDefs.push(ctxOptions.publisher);
63
+ if (ctxOptions.auditorStorage !== void 0) {
64
+ for (const endpoint of endpoints) if (endpoint.auditorStorageService) {
65
+ serviceDefs.push({
66
+ serviceName: endpoint.auditorStorageService.serviceName,
67
+ register: () => ctxOptions.auditorStorage
68
+ });
69
+ break;
70
+ }
71
+ }
72
+ if (serviceDefs.length > 0) serviceDiscovery.register(serviceDefs);
73
+ contexts.set(id, { serviceDiscovery });
74
+ }
75
+ const handlers = [];
76
+ for (const endpoint of endpoints) {
77
+ const method = endpoint.method.toLowerCase();
78
+ if (!MSW_HTTP_METHODS.includes(method)) continue;
79
+ const mswUrl = `${baseURL}${endpoint.route}`;
80
+ const mswMethod = msw.http[method];
81
+ handlers.push(mswMethod(mswUrl, async ({ request }) => {
82
+ const contextId = request.headers.get(TEST_CONTEXT_HEADER);
83
+ const ctx = contextId ? contexts.get(contextId) : void 0;
84
+ if (!ctx) return new Response(JSON.stringify({
85
+ error: "Missing or unknown test context ID",
86
+ hint: `Set the '${TEST_CONTEXT_HEADER}' header to a registered context ID`
87
+ }), {
88
+ status: 500,
89
+ headers: { "content-type": "application/json" }
90
+ });
91
+ const app = new hono.Hono();
92
+ require_HonoEndpointAdaptor.HonoEndpoint.addRoute(endpoint, ctx.serviceDiscovery, app);
93
+ const response = await app.request(request);
94
+ return new Response(response.body, {
95
+ status: response.status,
96
+ statusText: response.statusText,
97
+ headers: response.headers
98
+ });
99
+ }));
100
+ }
101
+ return {
102
+ handlers,
103
+ registerContext
104
+ };
105
+ }
106
+
107
+ //#endregion
108
+ Object.defineProperty(exports, 'TEST_CONTEXT_HEADER', {
109
+ enumerable: true,
110
+ get: function () {
111
+ return TEST_CONTEXT_HEADER;
112
+ }
113
+ });
114
+ Object.defineProperty(exports, 'createMswHandlers', {
115
+ enumerable: true,
116
+ get: function () {
117
+ return createMswHandlers;
118
+ }
119
+ });
120
+ //# sourceMappingURL=MswEndpointAdaptor-CA_fu6Wx.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MswEndpointAdaptor-CA_fu6Wx.cjs","names":["endpoints: Endpoint<any, any, any, any, any, any>[]","options: CreateMswHandlersOptions","id: string","ctxOptions: RegisterContextOptions","EnvironmentParser","ServiceDiscovery","serviceDefs: Service[]","handlers: HttpHandler[]","http","Hono"],"sources":["../src/endpoints/MswEndpointAdaptor.ts"],"sourcesContent":["import { EnvironmentParser } from '@geekmidas/envkit';\nimport type { Service } from '@geekmidas/services';\nimport { ServiceDiscovery } from '@geekmidas/services';\nimport { Hono } from 'hono';\nimport { type HttpHandler, http } from 'msw';\nimport type { Endpoint } from './Endpoint';\nimport { HonoEndpoint } from './HonoEndpointAdaptor';\n\n/**\n * Header used to identify which test context a request belongs to.\n * Each concurrent test registers its own context (services, db transaction, etc.)\n * and the MSW handler looks it up by this header value.\n */\nexport const TEST_CONTEXT_HEADER = 'x-test-context-id';\n\n/**\n * Per-test context containing an isolated ServiceDiscovery instance.\n * Registered in the context map and looked up per-request via the context ID header.\n */\nexport interface MswTestContext {\n\tserviceDiscovery: ServiceDiscovery<any>;\n}\n\n/**\n * Options for creating MSW handlers from endpoint constructs.\n *\n * @example\n * ```typescript\n * import { createMswHandlers, registerTestContext } from '@geekmidas/constructs/testing';\n * import { setupServer } from 'msw/node';\n *\n * // Create handlers once (global)\n * const { handlers, registerContext, removeContext } = createMswHandlers(\n * [getUsers, createUser],\n * { baseURL: 'http://localhost:3000' },\n * );\n * const server = setupServer(...handlers);\n *\n * // Per test: register an isolated context with its own services/transaction\n * it('should list users', async ({ db }) => {\n * const contextId = crypto.randomUUID();\n * registerContext(contextId, {\n * services: { database: db, auth: mockAuth },\n * });\n *\n * const api = createApi({\n * baseURL: 'http://localhost:3000',\n * headers: { [TEST_CONTEXT_HEADER]: contextId },\n * });\n *\n * const result = await api('GET /users');\n * expect(result).toBeDefined();\n *\n * removeContext(contextId);\n * });\n * ```\n */\nexport interface CreateMswHandlersOptions {\n\t/** Base URL the client fetches from (e.g., 'http://localhost:3000') */\n\tbaseURL: string;\n}\n\n/**\n * Options for registering a per-test context.\n * Follows the same pattern as TestRequestAdaptor — services, database,\n * publisher, and auditorStorage are provided explicitly.\n */\nexport interface RegisterContextOptions {\n\t/** Service instances keyed by serviceName */\n\tservices?: Record<string, unknown>;\n\t/** Database instance — required when endpoints use .database() */\n\tdatabase?: unknown;\n\t/** Event publisher service definition */\n\tpublisher?: Service;\n\t/** Audit storage instance — required when endpoints use .auditor() */\n\tauditorStorage?: unknown;\n}\n\nconst MSW_HTTP_METHODS = [\n\t'get',\n\t'post',\n\t'put',\n\t'patch',\n\t'delete',\n\t'options',\n] as const;\n\ntype MswHttpMethod = (typeof MSW_HTTP_METHODS)[number];\n\n/**\n * Result of creating MSW handlers from endpoint constructs.\n */\nexport interface CreateMswHandlersResult {\n\t/** MSW handlers to pass to setupServer() */\n\thandlers: HttpHandler[];\n\t/** Register an isolated context for a test */\n\tregisterContext: (id: string, options: RegisterContextOptions) => void;\n}\n\n/**\n * Creates MSW HTTP handlers from endpoint constructs.\n *\n * Mounts endpoints on a Hono app and creates MSW handlers that intercept\n * fetch requests and route them through `app.request()` — giving frontend\n * tests full endpoint behavior (validation, auth, sessions) without HTTP.\n *\n * Each test registers its own isolated context via `registerContext()`,\n * which is resolved per-request using the `x-test-context-id` header.\n * This allows concurrent tests with their own transactions and services.\n *\n * @param endpoints - Array of endpoint constructs to create handlers for\n * @param options - Configuration including baseURL\n * @returns MSW handlers, the Hono app, and context management functions\n */\nexport function createMswHandlers(\n\tendpoints: Endpoint<any, any, any, any, any, any>[],\n\toptions: CreateMswHandlersOptions,\n): CreateMswHandlersResult {\n\tconst { baseURL } = options;\n\tconst contexts = new Map<string, MswTestContext>();\n\n\t/**\n\t * Register an isolated context for a test.\n\t * Creates a fresh ServiceDiscovery and pre-registers all provided services.\n\t */\n\tfunction registerContext(id: string, ctxOptions: RegisterContextOptions) {\n\t\tconst envParser = new EnvironmentParser({});\n\t\tconst serviceDiscovery = new ServiceDiscovery(envParser);\n\n\t\tconst serviceDefs: Service[] = [];\n\n\t\t// Register explicit services\n\t\tif (ctxOptions.services) {\n\t\t\tfor (const [name, instance] of Object.entries(ctxOptions.services)) {\n\t\t\t\tserviceDefs.push({\n\t\t\t\t\tserviceName: name,\n\t\t\t\t\tregister: () => instance,\n\t\t\t\t} as Service);\n\t\t\t}\n\t\t}\n\n\t\t// Register database service from endpoint metadata\n\t\tif (ctxOptions.database !== undefined) {\n\t\t\tfor (const endpoint of endpoints) {\n\t\t\t\tif (endpoint.databaseService) {\n\t\t\t\t\tserviceDefs.push({\n\t\t\t\t\t\tserviceName: endpoint.databaseService.serviceName,\n\t\t\t\t\t\tregister: () => ctxOptions.database,\n\t\t\t\t\t} as Service);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Register publisher service\n\t\tif (ctxOptions.publisher) {\n\t\t\tserviceDefs.push(ctxOptions.publisher);\n\t\t}\n\n\t\t// Register auditor storage service from endpoint metadata\n\t\tif (ctxOptions.auditorStorage !== undefined) {\n\t\t\tfor (const endpoint of endpoints) {\n\t\t\t\tif (endpoint.auditorStorageService) {\n\t\t\t\t\tserviceDefs.push({\n\t\t\t\t\t\tserviceName: endpoint.auditorStorageService.serviceName,\n\t\t\t\t\t\tregister: () => ctxOptions.auditorStorage,\n\t\t\t\t\t} as Service);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (serviceDefs.length > 0) {\n\t\t\tserviceDiscovery.register(serviceDefs);\n\t\t}\n\n\t\tcontexts.set(id, { serviceDiscovery });\n\t}\n\n\t// Create a Hono app per-request that uses the correct ServiceDiscovery.\n\t// We use a wrapper app that resolves the context from the header,\n\t// then delegates to a context-specific Hono app.\n\tconst handlers: HttpHandler[] = [];\n\n\tfor (const endpoint of endpoints) {\n\t\tconst method = endpoint.method.toLowerCase() as MswHttpMethod;\n\t\tif (!MSW_HTTP_METHODS.includes(method)) continue;\n\n\t\tconst mswUrl = `${baseURL}${endpoint.route}`;\n\t\tconst mswMethod = http[method];\n\n\t\thandlers.push(\n\t\t\tmswMethod(mswUrl, async ({ request }) => {\n\t\t\t\tconst contextId = request.headers.get(TEST_CONTEXT_HEADER);\n\t\t\t\tconst ctx = contextId ? contexts.get(contextId) : undefined;\n\n\t\t\t\tif (!ctx) {\n\t\t\t\t\treturn new Response(\n\t\t\t\t\t\tJSON.stringify({\n\t\t\t\t\t\t\terror: 'Missing or unknown test context ID',\n\t\t\t\t\t\t\thint: `Set the '${TEST_CONTEXT_HEADER}' header to a registered context ID`,\n\t\t\t\t\t\t}),\n\t\t\t\t\t\t{ status: 500, headers: { 'content-type': 'application/json' } },\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\t// Build a fresh Hono app with this context's ServiceDiscovery\n\t\t\t\tconst app = new Hono();\n\t\t\t\tHonoEndpoint.addRoute(endpoint, ctx.serviceDiscovery as any, app);\n\n\t\t\t\tconst response = await app.request(request);\n\n\t\t\t\treturn new Response(response.body, {\n\t\t\t\t\tstatus: response.status,\n\t\t\t\t\tstatusText: response.statusText,\n\t\t\t\t\theaders: response.headers,\n\t\t\t\t});\n\t\t\t}),\n\t\t);\n\t}\n\n\treturn {\n\t\thandlers,\n\t\tregisterContext,\n\t};\n}\n"],"mappings":";;;;;;;;;;;;;AAaA,MAAa,sBAAsB;AAiEnC,MAAM,mBAAmB;CACxB;CACA;CACA;CACA;CACA;CACA;AACA;;;;;;;;;;;;;;;;AA6BD,SAAgB,kBACfA,WACAC,SAC0B;CAC1B,MAAM,EAAE,SAAS,GAAG;CACpB,MAAM,2BAAW,IAAI;;;;;CAMrB,SAAS,gBAAgBC,IAAYC,YAAoC;EACxE,MAAM,YAAY,IAAIC,qCAAkB,CAAE;EAC1C,MAAM,mBAAmB,IAAIC,sCAAiB;EAE9C,MAAMC,cAAyB,CAAE;AAGjC,MAAI,WAAW,SACd,MAAK,MAAM,CAAC,MAAM,SAAS,IAAI,OAAO,QAAQ,WAAW,SAAS,CACjE,aAAY,KAAK;GAChB,aAAa;GACb,UAAU,MAAM;EAChB,EAAY;AAKf,MAAI,WAAW,qBACd;QAAK,MAAM,YAAY,UACtB,KAAI,SAAS,iBAAiB;AAC7B,gBAAY,KAAK;KAChB,aAAa,SAAS,gBAAgB;KACtC,UAAU,MAAM,WAAW;IAC3B,EAAY;AACb;GACA;EACD;AAIF,MAAI,WAAW,UACd,aAAY,KAAK,WAAW,UAAU;AAIvC,MAAI,WAAW,2BACd;QAAK,MAAM,YAAY,UACtB,KAAI,SAAS,uBAAuB;AACnC,gBAAY,KAAK;KAChB,aAAa,SAAS,sBAAsB;KAC5C,UAAU,MAAM,WAAW;IAC3B,EAAY;AACb;GACA;EACD;AAGF,MAAI,YAAY,SAAS,EACxB,kBAAiB,SAAS,YAAY;AAGvC,WAAS,IAAI,IAAI,EAAE,iBAAkB,EAAC;CACtC;CAKD,MAAMC,WAA0B,CAAE;AAElC,MAAK,MAAM,YAAY,WAAW;EACjC,MAAM,SAAS,SAAS,OAAO,aAAa;AAC5C,OAAK,iBAAiB,SAAS,OAAO,CAAE;EAExC,MAAM,UAAU,EAAE,QAAQ,EAAE,SAAS,MAAM;EAC3C,MAAM,YAAYC,SAAK;AAEvB,WAAS,KACR,UAAU,QAAQ,OAAO,EAAE,SAAS,KAAK;GACxC,MAAM,YAAY,QAAQ,QAAQ,IAAI,oBAAoB;GAC1D,MAAM,MAAM,YAAY,SAAS,IAAI,UAAU;AAE/C,QAAK,IACJ,QAAO,IAAI,SACV,KAAK,UAAU;IACd,OAAO;IACP,OAAO,WAAW,oBAAoB;GACtC,EAAC,EACF;IAAE,QAAQ;IAAK,SAAS,EAAE,gBAAgB,mBAAoB;GAAE;GAKlE,MAAM,MAAM,IAAIC;AAChB,4CAAa,SAAS,UAAU,IAAI,kBAAyB,IAAI;GAEjE,MAAM,WAAW,MAAM,IAAI,QAAQ,QAAQ;AAE3C,UAAO,IAAI,SAAS,SAAS,MAAM;IAClC,QAAQ,SAAS;IACjB,YAAY,SAAS;IACrB,SAAS,SAAS;GAClB;EACD,EAAC,CACF;CACD;AAED,QAAO;EACN;EACA;CACA;AACD"}
@@ -0,0 +1,101 @@
1
+ import { Endpoint } from "./Endpoint-BET0JSZK.mjs";
2
+ import { Service, ServiceDiscovery } from "@geekmidas/services";
3
+ import { HttpHandler } from "msw";
4
+
5
+ //#region src/endpoints/MswEndpointAdaptor.d.ts
6
+
7
+ /**
8
+ * Header used to identify which test context a request belongs to.
9
+ * Each concurrent test registers its own context (services, db transaction, etc.)
10
+ * and the MSW handler looks it up by this header value.
11
+ */
12
+ declare const TEST_CONTEXT_HEADER = "x-test-context-id";
13
+ /**
14
+ * Per-test context containing an isolated ServiceDiscovery instance.
15
+ * Registered in the context map and looked up per-request via the context ID header.
16
+ */
17
+ interface MswTestContext {
18
+ serviceDiscovery: ServiceDiscovery<any>;
19
+ }
20
+ /**
21
+ * Options for creating MSW handlers from endpoint constructs.
22
+ *
23
+ * @example
24
+ * ```typescript
25
+ * import { createMswHandlers, registerTestContext } from '@geekmidas/constructs/testing';
26
+ * import { setupServer } from 'msw/node';
27
+ *
28
+ * // Create handlers once (global)
29
+ * const { handlers, registerContext, removeContext } = createMswHandlers(
30
+ * [getUsers, createUser],
31
+ * { baseURL: 'http://localhost:3000' },
32
+ * );
33
+ * const server = setupServer(...handlers);
34
+ *
35
+ * // Per test: register an isolated context with its own services/transaction
36
+ * it('should list users', async ({ db }) => {
37
+ * const contextId = crypto.randomUUID();
38
+ * registerContext(contextId, {
39
+ * services: { database: db, auth: mockAuth },
40
+ * });
41
+ *
42
+ * const api = createApi({
43
+ * baseURL: 'http://localhost:3000',
44
+ * headers: { [TEST_CONTEXT_HEADER]: contextId },
45
+ * });
46
+ *
47
+ * const result = await api('GET /users');
48
+ * expect(result).toBeDefined();
49
+ *
50
+ * removeContext(contextId);
51
+ * });
52
+ * ```
53
+ */
54
+ interface CreateMswHandlersOptions {
55
+ /** Base URL the client fetches from (e.g., 'http://localhost:3000') */
56
+ baseURL: string;
57
+ }
58
+ /**
59
+ * Options for registering a per-test context.
60
+ * Follows the same pattern as TestRequestAdaptor — services, database,
61
+ * publisher, and auditorStorage are provided explicitly.
62
+ */
63
+ interface RegisterContextOptions {
64
+ /** Service instances keyed by serviceName */
65
+ services?: Record<string, unknown>;
66
+ /** Database instance — required when endpoints use .database() */
67
+ database?: unknown;
68
+ /** Event publisher service definition */
69
+ publisher?: Service;
70
+ /** Audit storage instance — required when endpoints use .auditor() */
71
+ auditorStorage?: unknown;
72
+ }
73
+ /**
74
+ * Result of creating MSW handlers from endpoint constructs.
75
+ */
76
+ interface CreateMswHandlersResult {
77
+ /** MSW handlers to pass to setupServer() */
78
+ handlers: HttpHandler[];
79
+ /** Register an isolated context for a test */
80
+ registerContext: (id: string, options: RegisterContextOptions) => void;
81
+ }
82
+ /**
83
+ * Creates MSW HTTP handlers from endpoint constructs.
84
+ *
85
+ * Mounts endpoints on a Hono app and creates MSW handlers that intercept
86
+ * fetch requests and route them through `app.request()` — giving frontend
87
+ * tests full endpoint behavior (validation, auth, sessions) without HTTP.
88
+ *
89
+ * Each test registers its own isolated context via `registerContext()`,
90
+ * which is resolved per-request using the `x-test-context-id` header.
91
+ * This allows concurrent tests with their own transactions and services.
92
+ *
93
+ * @param endpoints - Array of endpoint constructs to create handlers for
94
+ * @param options - Configuration including baseURL
95
+ * @returns MSW handlers, the Hono app, and context management functions
96
+ */
97
+ declare function createMswHandlers(endpoints: Endpoint<any, any, any, any, any, any>[], options: CreateMswHandlersOptions): CreateMswHandlersResult;
98
+ //# sourceMappingURL=MswEndpointAdaptor.d.ts.map
99
+ //#endregion
100
+ export { CreateMswHandlersOptions, CreateMswHandlersResult, MswTestContext, RegisterContextOptions, TEST_CONTEXT_HEADER, createMswHandlers };
101
+ //# sourceMappingURL=MswEndpointAdaptor-CXgYbOxw.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MswEndpointAdaptor-CXgYbOxw.d.mts","names":[],"sources":["../src/endpoints/MswEndpointAdaptor.ts"],"sourcesContent":[],"mappings":";;;;;;;AAaA;AAMA;AAsCA;AAUA;AAAuC,cAtD1B,mBAAA,GAsD0B,mBAAA;;;AAMnB;AAmBpB;AAAwC,UAzEvB,cAAA,CAyEuB;EAAA,gBAE7B,EA1EQ,gBA0ER,CAAA,GAAA,CAAA;;AAEmD;AAkB9D;;;;;AAG0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA5DT,wBAAA;;;;;;;;;UAUA,sBAAA;;aAEL;;;;cAIC;;;;;;;UAmBI,uBAAA;;YAEN;;yCAE6B;;;;;;;;;;;;;;;;;iBAkBxB,iBAAA,YACJ,mDACF,2BACP"}
@@ -0,0 +1,101 @@
1
+ import { Endpoint } from "./Endpoint-CGdCGJkC.cjs";
2
+ import { Service, ServiceDiscovery } from "@geekmidas/services";
3
+ import { HttpHandler } from "msw";
4
+
5
+ //#region src/endpoints/MswEndpointAdaptor.d.ts
6
+
7
+ /**
8
+ * Header used to identify which test context a request belongs to.
9
+ * Each concurrent test registers its own context (services, db transaction, etc.)
10
+ * and the MSW handler looks it up by this header value.
11
+ */
12
+ declare const TEST_CONTEXT_HEADER = "x-test-context-id";
13
+ /**
14
+ * Per-test context containing an isolated ServiceDiscovery instance.
15
+ * Registered in the context map and looked up per-request via the context ID header.
16
+ */
17
+ interface MswTestContext {
18
+ serviceDiscovery: ServiceDiscovery<any>;
19
+ }
20
+ /**
21
+ * Options for creating MSW handlers from endpoint constructs.
22
+ *
23
+ * @example
24
+ * ```typescript
25
+ * import { createMswHandlers, registerTestContext } from '@geekmidas/constructs/testing';
26
+ * import { setupServer } from 'msw/node';
27
+ *
28
+ * // Create handlers once (global)
29
+ * const { handlers, registerContext, removeContext } = createMswHandlers(
30
+ * [getUsers, createUser],
31
+ * { baseURL: 'http://localhost:3000' },
32
+ * );
33
+ * const server = setupServer(...handlers);
34
+ *
35
+ * // Per test: register an isolated context with its own services/transaction
36
+ * it('should list users', async ({ db }) => {
37
+ * const contextId = crypto.randomUUID();
38
+ * registerContext(contextId, {
39
+ * services: { database: db, auth: mockAuth },
40
+ * });
41
+ *
42
+ * const api = createApi({
43
+ * baseURL: 'http://localhost:3000',
44
+ * headers: { [TEST_CONTEXT_HEADER]: contextId },
45
+ * });
46
+ *
47
+ * const result = await api('GET /users');
48
+ * expect(result).toBeDefined();
49
+ *
50
+ * removeContext(contextId);
51
+ * });
52
+ * ```
53
+ */
54
+ interface CreateMswHandlersOptions {
55
+ /** Base URL the client fetches from (e.g., 'http://localhost:3000') */
56
+ baseURL: string;
57
+ }
58
+ /**
59
+ * Options for registering a per-test context.
60
+ * Follows the same pattern as TestRequestAdaptor — services, database,
61
+ * publisher, and auditorStorage are provided explicitly.
62
+ */
63
+ interface RegisterContextOptions {
64
+ /** Service instances keyed by serviceName */
65
+ services?: Record<string, unknown>;
66
+ /** Database instance — required when endpoints use .database() */
67
+ database?: unknown;
68
+ /** Event publisher service definition */
69
+ publisher?: Service;
70
+ /** Audit storage instance — required when endpoints use .auditor() */
71
+ auditorStorage?: unknown;
72
+ }
73
+ /**
74
+ * Result of creating MSW handlers from endpoint constructs.
75
+ */
76
+ interface CreateMswHandlersResult {
77
+ /** MSW handlers to pass to setupServer() */
78
+ handlers: HttpHandler[];
79
+ /** Register an isolated context for a test */
80
+ registerContext: (id: string, options: RegisterContextOptions) => void;
81
+ }
82
+ /**
83
+ * Creates MSW HTTP handlers from endpoint constructs.
84
+ *
85
+ * Mounts endpoints on a Hono app and creates MSW handlers that intercept
86
+ * fetch requests and route them through `app.request()` — giving frontend
87
+ * tests full endpoint behavior (validation, auth, sessions) without HTTP.
88
+ *
89
+ * Each test registers its own isolated context via `registerContext()`,
90
+ * which is resolved per-request using the `x-test-context-id` header.
91
+ * This allows concurrent tests with their own transactions and services.
92
+ *
93
+ * @param endpoints - Array of endpoint constructs to create handlers for
94
+ * @param options - Configuration including baseURL
95
+ * @returns MSW handlers, the Hono app, and context management functions
96
+ */
97
+ declare function createMswHandlers(endpoints: Endpoint<any, any, any, any, any, any>[], options: CreateMswHandlersOptions): CreateMswHandlersResult;
98
+ //# sourceMappingURL=MswEndpointAdaptor.d.ts.map
99
+ //#endregion
100
+ export { CreateMswHandlersOptions, CreateMswHandlersResult, MswTestContext, RegisterContextOptions, TEST_CONTEXT_HEADER, createMswHandlers };
101
+ //# sourceMappingURL=MswEndpointAdaptor-CsYvrQeB.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MswEndpointAdaptor-CsYvrQeB.d.cts","names":[],"sources":["../src/endpoints/MswEndpointAdaptor.ts"],"sourcesContent":[],"mappings":";;;;;;;AAaA;AAMA;AAsCA;AAUA;AAAuC,cAtD1B,mBAAA,GAsD0B,mBAAA;;;AAMnB;AAmBpB;AAAwC,UAzEvB,cAAA,CAyEuB;EAAA,gBAE7B,EA1EQ,gBA0ER,CAAA,GAAA,CAAA;;AAEmD;AAkB9D;;;;;AAG0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA5DT,wBAAA;;;;;;;;;UAUA,sBAAA;;aAEL;;;;cAIC;;;;;;;UAmBI,uBAAA;;YAEN;;yCAE6B;;;;;;;;;;;;;;;;;iBAkBxB,iBAAA,YACJ,mDACF,2BACP"}
@@ -1,4 +1,4 @@
1
- import { Construct } from "./Construct-C2SyofdS.mjs";
1
+ import { Construct } from "./Construct-BjpXFNxy.mjs";
2
2
  import { Service, ServiceRecord } from "@geekmidas/services";
3
3
  import { EventPublisher, ExtractPublisherMessage } from "@geekmidas/events";
4
4
  import { Logger } from "@geekmidas/logger";
@@ -30,4 +30,4 @@ type SubscriberContext<TEventPublisher extends EventPublisher<any> | undefined,
30
30
  };
31
31
  //#endregion
32
32
  export { Subscriber, SubscriberContext, SubscriberHandler };
33
- //# sourceMappingURL=Subscriber-BgB3RRxb.d.mts.map
33
+ //# sourceMappingURL=Subscriber-9ObcUdcC.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Subscriber-BgB3RRxb.d.mts","names":[],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":[],"mappings":"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"}
1
+ {"version":3,"file":"Subscriber-9ObcUdcC.d.mts","names":[],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":[],"mappings":"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"}
@@ -25,4 +25,4 @@ var Subscriber = class extends Construct {
25
25
 
26
26
  //#endregion
27
27
  export { Subscriber };
28
- //# sourceMappingURL=Subscriber-BEhOdNQi.mjs.map
28
+ //# sourceMappingURL=Subscriber-BH76wgkL.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"Subscriber-BEhOdNQi.mjs","names":["DEFAULT_LOGGER","obj: any","handler: SubscriberHandler<\n\t\t\tTEventPublisher,\n\t\t\tTSubscribedEvents,\n\t\t\tTServices,\n\t\t\tTLogger,\n\t\t\tOutSchema\n\t\t>","timeout: number","_subscribedEvents?: TSubscribedEvents","outputSchema?: OutSchema","services: TServices","logger: TLogger","publisherService?: Service<\n\t\t\tTEventPublisherServiceName,\n\t\t\tTEventPublisher\n\t\t>"],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":["import type {\n\tEventPublisher,\n\tExtractPublisherMessage,\n} from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport { ConsoleLogger } from '@geekmidas/logger/console';\nimport type { InferStandardSchema } from '@geekmidas/schema';\nimport type { Service, ServiceRecord } from '@geekmidas/services';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { Construct, ConstructType } from '../Construct';\n\nconst DEFAULT_LOGGER = new ConsoleLogger() as any;\n\n// Helper type to extract payload types for subscribed events\ntype ExtractEventPayloads<\n\tTPublisher extends EventPublisher<any> | undefined,\n\tTEventTypes extends any[],\n> = TPublisher extends EventPublisher<any>\n\t? Extract<ExtractPublisherMessage<TPublisher>, { type: TEventTypes[number] }>\n\t: never;\n\nexport class Subscriber<\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n\tOutSchema extends StandardSchemaV1 | undefined = undefined,\n\tTEventPublisher extends EventPublisher<any> | undefined = undefined,\n\tTEventPublisherServiceName extends string = string,\n\tTSubscribedEvents extends\n\t\tExtractPublisherMessage<TEventPublisher>['type'][] = ExtractPublisherMessage<TEventPublisher>['type'][],\n> extends Construct<\n\tTLogger,\n\tTEventPublisherServiceName,\n\tTEventPublisher,\n\tOutSchema,\n\tTServices\n> {\n\t__IS_SUBSCRIBER__ = true;\n\n\tstatic isSubscriber(\n\t\tobj: any,\n\t): obj is Subscriber<any, any, any, any, any, any> {\n\t\treturn Boolean(\n\t\t\tobj &&\n\t\t\t\tobj.__IS_SUBSCRIBER__ === true &&\n\t\t\t\tobj.type === ConstructType.Subscriber,\n\t\t);\n\t}\n\n\tconstructor(\n\t\tpublic readonly handler: SubscriberHandler<\n\t\t\tTEventPublisher,\n\t\t\tTSubscribedEvents,\n\t\t\tTServices,\n\t\t\tTLogger,\n\t\t\tOutSchema\n\t\t>,\n\t\tpublic override readonly timeout: number = 30000,\n\t\tprotected _subscribedEvents?: TSubscribedEvents,\n\t\tpublic override readonly outputSchema?: OutSchema,\n\t\tpublic override readonly services: TServices = [] as unknown as TServices,\n\t\tpublic override readonly logger: TLogger = DEFAULT_LOGGER as TLogger,\n\t\tpublic override readonly publisherService?: Service<\n\t\t\tTEventPublisherServiceName,\n\t\t\tTEventPublisher\n\t\t>,\n\t) {\n\t\tsuper(\n\t\t\tConstructType.Subscriber,\n\t\t\tlogger,\n\t\t\tservices,\n\t\t\t[],\n\t\t\tpublisherService,\n\t\t\toutputSchema,\n\t\t);\n\t}\n\n\tget subscribedEvents(): TSubscribedEvents | undefined {\n\t\treturn this._subscribedEvents;\n\t}\n}\n\n// Handler type for subscribers that receives an array of events\nexport type SubscriberHandler<\n\tTEventPublisher extends EventPublisher<any> | undefined,\n\tTSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n\tOutSchema extends StandardSchemaV1 | undefined = undefined,\n> = (\n\tctx: SubscriberContext<\n\t\tTEventPublisher,\n\t\tTSubscribedEvents,\n\t\tTServices,\n\t\tTLogger\n\t>,\n) => OutSchema extends StandardSchemaV1\n\t? InferStandardSchema<OutSchema> | Promise<InferStandardSchema<OutSchema>>\n\t: any | Promise<any>;\n\n// Context type for subscriber handlers\nexport type SubscriberContext<\n\tTEventPublisher extends EventPublisher<any> | undefined,\n\tTSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n> = {\n\tevents: ExtractEventPayloads<TEventPublisher, TSubscribedEvents>[];\n\tservices: ServiceRecord<TServices>;\n\tlogger: TLogger;\n};\n"],"mappings":";;;;AAWA,MAAMA,mBAAiB,IAAI;AAU3B,IAAa,aAAb,cAQU,UAMR;CACD,oBAAoB;CAEpB,OAAO,aACNC,KACkD;AAClD,SAAO,QACN,OACC,IAAI,sBAAsB,QAC1B,IAAI,SAAS,cAAc,WAC5B;CACD;CAED,YACiBC,SAOSC,UAAkB,KACjCC,mBACeC,cACAC,WAAsB,CAAE,GACxBC,SAAkBP,kBAClBQ,kBAIxB;AACD,QACC,cAAc,YACd,QACA,UACA,CAAE,GACF,kBACA,aACA;EAxBe;EAOS;EACf;EACe;EACA;EACA;EACA;CAazB;CAED,IAAI,mBAAkD;AACrD,SAAO,KAAK;CACZ;AACD"}
1
+ {"version":3,"file":"Subscriber-BH76wgkL.mjs","names":["DEFAULT_LOGGER","obj: any","handler: SubscriberHandler<\n\t\t\tTEventPublisher,\n\t\t\tTSubscribedEvents,\n\t\t\tTServices,\n\t\t\tTLogger,\n\t\t\tOutSchema\n\t\t>","timeout: number","_subscribedEvents?: TSubscribedEvents","outputSchema?: OutSchema","services: TServices","logger: TLogger","publisherService?: Service<\n\t\t\tTEventPublisherServiceName,\n\t\t\tTEventPublisher\n\t\t>"],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":["import type {\n\tEventPublisher,\n\tExtractPublisherMessage,\n} from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport { ConsoleLogger } from '@geekmidas/logger/console';\nimport type { InferStandardSchema } from '@geekmidas/schema';\nimport type { Service, ServiceRecord } from '@geekmidas/services';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { Construct, ConstructType } from '../Construct';\n\nconst DEFAULT_LOGGER = new ConsoleLogger() as any;\n\n// Helper type to extract payload types for subscribed events\ntype ExtractEventPayloads<\n\tTPublisher extends EventPublisher<any> | undefined,\n\tTEventTypes extends any[],\n> = TPublisher extends EventPublisher<any>\n\t? Extract<ExtractPublisherMessage<TPublisher>, { type: TEventTypes[number] }>\n\t: never;\n\nexport class Subscriber<\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n\tOutSchema extends StandardSchemaV1 | undefined = undefined,\n\tTEventPublisher extends EventPublisher<any> | undefined = undefined,\n\tTEventPublisherServiceName extends string = string,\n\tTSubscribedEvents extends\n\t\tExtractPublisherMessage<TEventPublisher>['type'][] = ExtractPublisherMessage<TEventPublisher>['type'][],\n> extends Construct<\n\tTLogger,\n\tTEventPublisherServiceName,\n\tTEventPublisher,\n\tOutSchema,\n\tTServices\n> {\n\t__IS_SUBSCRIBER__ = true;\n\n\tstatic isSubscriber(\n\t\tobj: any,\n\t): obj is Subscriber<any, any, any, any, any, any> {\n\t\treturn Boolean(\n\t\t\tobj &&\n\t\t\t\tobj.__IS_SUBSCRIBER__ === true &&\n\t\t\t\tobj.type === ConstructType.Subscriber,\n\t\t);\n\t}\n\n\tconstructor(\n\t\tpublic readonly handler: SubscriberHandler<\n\t\t\tTEventPublisher,\n\t\t\tTSubscribedEvents,\n\t\t\tTServices,\n\t\t\tTLogger,\n\t\t\tOutSchema\n\t\t>,\n\t\tpublic override readonly timeout: number = 30000,\n\t\tprotected _subscribedEvents?: TSubscribedEvents,\n\t\tpublic override readonly outputSchema?: OutSchema,\n\t\tpublic override readonly services: TServices = [] as unknown as TServices,\n\t\tpublic override readonly logger: TLogger = DEFAULT_LOGGER as TLogger,\n\t\tpublic override readonly publisherService?: Service<\n\t\t\tTEventPublisherServiceName,\n\t\t\tTEventPublisher\n\t\t>,\n\t) {\n\t\tsuper(\n\t\t\tConstructType.Subscriber,\n\t\t\tlogger,\n\t\t\tservices,\n\t\t\t[],\n\t\t\tpublisherService,\n\t\t\toutputSchema,\n\t\t);\n\t}\n\n\tget subscribedEvents(): TSubscribedEvents | undefined {\n\t\treturn this._subscribedEvents;\n\t}\n}\n\n// Handler type for subscribers that receives an array of events\nexport type SubscriberHandler<\n\tTEventPublisher extends EventPublisher<any> | undefined,\n\tTSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n\tOutSchema extends StandardSchemaV1 | undefined = undefined,\n> = (\n\tctx: SubscriberContext<\n\t\tTEventPublisher,\n\t\tTSubscribedEvents,\n\t\tTServices,\n\t\tTLogger\n\t>,\n) => OutSchema extends StandardSchemaV1\n\t? InferStandardSchema<OutSchema> | Promise<InferStandardSchema<OutSchema>>\n\t: any | Promise<any>;\n\n// Context type for subscriber handlers\nexport type SubscriberContext<\n\tTEventPublisher extends EventPublisher<any> | undefined,\n\tTSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n> = {\n\tevents: ExtractEventPayloads<TEventPublisher, TSubscribedEvents>[];\n\tservices: ServiceRecord<TServices>;\n\tlogger: TLogger;\n};\n"],"mappings":";;;;AAWA,MAAMA,mBAAiB,IAAI;AAU3B,IAAa,aAAb,cAQU,UAMR;CACD,oBAAoB;CAEpB,OAAO,aACNC,KACkD;AAClD,SAAO,QACN,OACC,IAAI,sBAAsB,QAC1B,IAAI,SAAS,cAAc,WAC5B;CACD;CAED,YACiBC,SAOSC,UAAkB,KACjCC,mBACeC,cACAC,WAAsB,CAAE,GACxBC,SAAkBP,kBAClBQ,kBAIxB;AACD,QACC,cAAc,YACd,QACA,UACA,CAAE,GACF,kBACA,aACA;EAxBe;EAOS;EACf;EACe;EACA;EACA;EACA;CAazB;CAED,IAAI,mBAAkD;AACrD,SAAO,KAAK;CACZ;AACD"}
@@ -31,4 +31,4 @@ Object.defineProperty(exports, 'Subscriber', {
31
31
  return Subscriber;
32
32
  }
33
33
  });
34
- //# sourceMappingURL=Subscriber-Scz7hrV6.cjs.map
34
+ //# sourceMappingURL=Subscriber-BgspJeS4.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"Subscriber-Scz7hrV6.cjs","names":["ConsoleLogger","Construct","obj: any","ConstructType","handler: SubscriberHandler<\n\t\t\tTEventPublisher,\n\t\t\tTSubscribedEvents,\n\t\t\tTServices,\n\t\t\tTLogger,\n\t\t\tOutSchema\n\t\t>","timeout: number","_subscribedEvents?: TSubscribedEvents","outputSchema?: OutSchema","services: TServices","logger: TLogger","publisherService?: Service<\n\t\t\tTEventPublisherServiceName,\n\t\t\tTEventPublisher\n\t\t>"],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":["import type {\n\tEventPublisher,\n\tExtractPublisherMessage,\n} from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport { ConsoleLogger } from '@geekmidas/logger/console';\nimport type { InferStandardSchema } from '@geekmidas/schema';\nimport type { Service, ServiceRecord } from '@geekmidas/services';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { Construct, ConstructType } from '../Construct';\n\nconst DEFAULT_LOGGER = new ConsoleLogger() as any;\n\n// Helper type to extract payload types for subscribed events\ntype ExtractEventPayloads<\n\tTPublisher extends EventPublisher<any> | undefined,\n\tTEventTypes extends any[],\n> = TPublisher extends EventPublisher<any>\n\t? Extract<ExtractPublisherMessage<TPublisher>, { type: TEventTypes[number] }>\n\t: never;\n\nexport class Subscriber<\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n\tOutSchema extends StandardSchemaV1 | undefined = undefined,\n\tTEventPublisher extends EventPublisher<any> | undefined = undefined,\n\tTEventPublisherServiceName extends string = string,\n\tTSubscribedEvents extends\n\t\tExtractPublisherMessage<TEventPublisher>['type'][] = ExtractPublisherMessage<TEventPublisher>['type'][],\n> extends Construct<\n\tTLogger,\n\tTEventPublisherServiceName,\n\tTEventPublisher,\n\tOutSchema,\n\tTServices\n> {\n\t__IS_SUBSCRIBER__ = true;\n\n\tstatic isSubscriber(\n\t\tobj: any,\n\t): obj is Subscriber<any, any, any, any, any, any> {\n\t\treturn Boolean(\n\t\t\tobj &&\n\t\t\t\tobj.__IS_SUBSCRIBER__ === true &&\n\t\t\t\tobj.type === ConstructType.Subscriber,\n\t\t);\n\t}\n\n\tconstructor(\n\t\tpublic readonly handler: SubscriberHandler<\n\t\t\tTEventPublisher,\n\t\t\tTSubscribedEvents,\n\t\t\tTServices,\n\t\t\tTLogger,\n\t\t\tOutSchema\n\t\t>,\n\t\tpublic override readonly timeout: number = 30000,\n\t\tprotected _subscribedEvents?: TSubscribedEvents,\n\t\tpublic override readonly outputSchema?: OutSchema,\n\t\tpublic override readonly services: TServices = [] as unknown as TServices,\n\t\tpublic override readonly logger: TLogger = DEFAULT_LOGGER as TLogger,\n\t\tpublic override readonly publisherService?: Service<\n\t\t\tTEventPublisherServiceName,\n\t\t\tTEventPublisher\n\t\t>,\n\t) {\n\t\tsuper(\n\t\t\tConstructType.Subscriber,\n\t\t\tlogger,\n\t\t\tservices,\n\t\t\t[],\n\t\t\tpublisherService,\n\t\t\toutputSchema,\n\t\t);\n\t}\n\n\tget subscribedEvents(): TSubscribedEvents | undefined {\n\t\treturn this._subscribedEvents;\n\t}\n}\n\n// Handler type for subscribers that receives an array of events\nexport type SubscriberHandler<\n\tTEventPublisher extends EventPublisher<any> | undefined,\n\tTSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n\tOutSchema extends StandardSchemaV1 | undefined = undefined,\n> = (\n\tctx: SubscriberContext<\n\t\tTEventPublisher,\n\t\tTSubscribedEvents,\n\t\tTServices,\n\t\tTLogger\n\t>,\n) => OutSchema extends StandardSchemaV1\n\t? InferStandardSchema<OutSchema> | Promise<InferStandardSchema<OutSchema>>\n\t: any | Promise<any>;\n\n// Context type for subscriber handlers\nexport type SubscriberContext<\n\tTEventPublisher extends EventPublisher<any> | undefined,\n\tTSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n> = {\n\tevents: ExtractEventPayloads<TEventPublisher, TSubscribedEvents>[];\n\tservices: ServiceRecord<TServices>;\n\tlogger: TLogger;\n};\n"],"mappings":";;;;;AAWA,MAAM,iBAAiB,IAAIA;AAU3B,IAAa,aAAb,cAQUC,4BAMR;CACD,oBAAoB;CAEpB,OAAO,aACNC,KACkD;AAClD,SAAO,QACN,OACC,IAAI,sBAAsB,QAC1B,IAAI,SAASC,gCAAc,WAC5B;CACD;CAED,YACiBC,SAOSC,UAAkB,KACjCC,mBACeC,cACAC,WAAsB,CAAE,GACxBC,SAAkB,gBAClBC,kBAIxB;AACD,QACCP,gCAAc,YACd,QACA,UACA,CAAE,GACF,kBACA,aACA;EAxBe;EAOS;EACf;EACe;EACA;EACA;EACA;CAazB;CAED,IAAI,mBAAkD;AACrD,SAAO,KAAK;CACZ;AACD"}
1
+ {"version":3,"file":"Subscriber-BgspJeS4.cjs","names":["ConsoleLogger","Construct","obj: any","ConstructType","handler: SubscriberHandler<\n\t\t\tTEventPublisher,\n\t\t\tTSubscribedEvents,\n\t\t\tTServices,\n\t\t\tTLogger,\n\t\t\tOutSchema\n\t\t>","timeout: number","_subscribedEvents?: TSubscribedEvents","outputSchema?: OutSchema","services: TServices","logger: TLogger","publisherService?: Service<\n\t\t\tTEventPublisherServiceName,\n\t\t\tTEventPublisher\n\t\t>"],"sources":["../src/subscribers/Subscriber.ts"],"sourcesContent":["import type {\n\tEventPublisher,\n\tExtractPublisherMessage,\n} from '@geekmidas/events';\nimport type { Logger } from '@geekmidas/logger';\nimport { ConsoleLogger } from '@geekmidas/logger/console';\nimport type { InferStandardSchema } from '@geekmidas/schema';\nimport type { Service, ServiceRecord } from '@geekmidas/services';\nimport type { StandardSchemaV1 } from '@standard-schema/spec';\nimport { Construct, ConstructType } from '../Construct';\n\nconst DEFAULT_LOGGER = new ConsoleLogger() as any;\n\n// Helper type to extract payload types for subscribed events\ntype ExtractEventPayloads<\n\tTPublisher extends EventPublisher<any> | undefined,\n\tTEventTypes extends any[],\n> = TPublisher extends EventPublisher<any>\n\t? Extract<ExtractPublisherMessage<TPublisher>, { type: TEventTypes[number] }>\n\t: never;\n\nexport class Subscriber<\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n\tOutSchema extends StandardSchemaV1 | undefined = undefined,\n\tTEventPublisher extends EventPublisher<any> | undefined = undefined,\n\tTEventPublisherServiceName extends string = string,\n\tTSubscribedEvents extends\n\t\tExtractPublisherMessage<TEventPublisher>['type'][] = ExtractPublisherMessage<TEventPublisher>['type'][],\n> extends Construct<\n\tTLogger,\n\tTEventPublisherServiceName,\n\tTEventPublisher,\n\tOutSchema,\n\tTServices\n> {\n\t__IS_SUBSCRIBER__ = true;\n\n\tstatic isSubscriber(\n\t\tobj: any,\n\t): obj is Subscriber<any, any, any, any, any, any> {\n\t\treturn Boolean(\n\t\t\tobj &&\n\t\t\t\tobj.__IS_SUBSCRIBER__ === true &&\n\t\t\t\tobj.type === ConstructType.Subscriber,\n\t\t);\n\t}\n\n\tconstructor(\n\t\tpublic readonly handler: SubscriberHandler<\n\t\t\tTEventPublisher,\n\t\t\tTSubscribedEvents,\n\t\t\tTServices,\n\t\t\tTLogger,\n\t\t\tOutSchema\n\t\t>,\n\t\tpublic override readonly timeout: number = 30000,\n\t\tprotected _subscribedEvents?: TSubscribedEvents,\n\t\tpublic override readonly outputSchema?: OutSchema,\n\t\tpublic override readonly services: TServices = [] as unknown as TServices,\n\t\tpublic override readonly logger: TLogger = DEFAULT_LOGGER as TLogger,\n\t\tpublic override readonly publisherService?: Service<\n\t\t\tTEventPublisherServiceName,\n\t\t\tTEventPublisher\n\t\t>,\n\t) {\n\t\tsuper(\n\t\t\tConstructType.Subscriber,\n\t\t\tlogger,\n\t\t\tservices,\n\t\t\t[],\n\t\t\tpublisherService,\n\t\t\toutputSchema,\n\t\t);\n\t}\n\n\tget subscribedEvents(): TSubscribedEvents | undefined {\n\t\treturn this._subscribedEvents;\n\t}\n}\n\n// Handler type for subscribers that receives an array of events\nexport type SubscriberHandler<\n\tTEventPublisher extends EventPublisher<any> | undefined,\n\tTSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n\tOutSchema extends StandardSchemaV1 | undefined = undefined,\n> = (\n\tctx: SubscriberContext<\n\t\tTEventPublisher,\n\t\tTSubscribedEvents,\n\t\tTServices,\n\t\tTLogger\n\t>,\n) => OutSchema extends StandardSchemaV1\n\t? InferStandardSchema<OutSchema> | Promise<InferStandardSchema<OutSchema>>\n\t: any | Promise<any>;\n\n// Context type for subscriber handlers\nexport type SubscriberContext<\n\tTEventPublisher extends EventPublisher<any> | undefined,\n\tTSubscribedEvents extends ExtractPublisherMessage<TEventPublisher>['type'][],\n\tTServices extends Service[] = [],\n\tTLogger extends Logger = Logger,\n> = {\n\tevents: ExtractEventPayloads<TEventPublisher, TSubscribedEvents>[];\n\tservices: ServiceRecord<TServices>;\n\tlogger: TLogger;\n};\n"],"mappings":";;;;;AAWA,MAAM,iBAAiB,IAAIA;AAU3B,IAAa,aAAb,cAQUC,4BAMR;CACD,oBAAoB;CAEpB,OAAO,aACNC,KACkD;AAClD,SAAO,QACN,OACC,IAAI,sBAAsB,QAC1B,IAAI,SAASC,gCAAc,WAC5B;CACD;CAED,YACiBC,SAOSC,UAAkB,KACjCC,mBACeC,cACAC,WAAsB,CAAE,GACxBC,SAAkB,gBAClBC,kBAIxB;AACD,QACCP,gCAAc,YACd,QACA,UACA,CAAE,GACF,kBACA,aACA;EAxBe;EAOS;EACf;EACe;EACA;EACA;EACA;CAazB;CAED,IAAI,mBAAkD;AACrD,SAAO,KAAK;CACZ;AACD"}
@@ -1,4 +1,4 @@
1
- import { Subscriber } from "./Subscriber-BEhOdNQi.mjs";
1
+ import { Subscriber } from "./Subscriber-BH76wgkL.mjs";
2
2
  import { DEFAULT_LOGGER } from "@geekmidas/logger/console";
3
3
 
4
4
  //#region src/subscribers/SubscriberBuilder.ts
@@ -51,4 +51,4 @@ var SubscriberBuilder = class {
51
51
 
52
52
  //#endregion
53
53
  export { SubscriberBuilder };
54
- //# sourceMappingURL=SubscriberBuilder-DlUaG0Ej.mjs.map
54
+ //# sourceMappingURL=SubscriberBuilder-B4md5wzs.mjs.map