@effect-app/infra 4.0.0-beta.24 → 4.0.0-beta.241

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 (342) hide show
  1. package/CHANGELOG.md +1818 -0
  2. package/_check.sh +1 -1
  3. package/dist/CUPS.d.ts +12 -7
  4. package/dist/CUPS.d.ts.map +1 -1
  5. package/dist/CUPS.js +16 -12
  6. package/dist/Emailer/Sendgrid.d.ts +15 -15
  7. package/dist/Emailer/Sendgrid.d.ts.map +1 -1
  8. package/dist/Emailer/Sendgrid.js +21 -17
  9. package/dist/Emailer/fake.d.ts +1 -1
  10. package/dist/Emailer/fake.js +3 -3
  11. package/dist/Emailer/service.d.ts +13 -4
  12. package/dist/Emailer/service.d.ts.map +1 -1
  13. package/dist/Emailer/service.js +4 -3
  14. package/dist/Emailer.d.ts +1 -1
  15. package/dist/MainFiberSet.d.ts +12 -9
  16. package/dist/MainFiberSet.d.ts.map +1 -1
  17. package/dist/MainFiberSet.js +10 -6
  18. package/dist/Model/Repository/Registry.d.ts +21 -0
  19. package/dist/Model/Repository/Registry.d.ts.map +1 -0
  20. package/dist/Model/Repository/Registry.js +18 -0
  21. package/dist/Model/Repository/ext.d.ts +35 -16
  22. package/dist/Model/Repository/ext.d.ts.map +1 -1
  23. package/dist/Model/Repository/ext.js +60 -3
  24. package/dist/Model/Repository/internal/internal.d.ts +9 -6
  25. package/dist/Model/Repository/internal/internal.d.ts.map +1 -1
  26. package/dist/Model/Repository/internal/internal.js +141 -59
  27. package/dist/Model/Repository/legacy.d.ts +4 -2
  28. package/dist/Model/Repository/legacy.d.ts.map +1 -1
  29. package/dist/Model/Repository/makeRepo.d.ts +10 -6
  30. package/dist/Model/Repository/makeRepo.d.ts.map +1 -1
  31. package/dist/Model/Repository/makeRepo.js +5 -2
  32. package/dist/Model/Repository/service.d.ts +32 -24
  33. package/dist/Model/Repository/service.d.ts.map +1 -1
  34. package/dist/Model/Repository/validation.d.ts +47 -18
  35. package/dist/Model/Repository/validation.d.ts.map +1 -1
  36. package/dist/Model/Repository/validation.js +6 -6
  37. package/dist/Model/Repository.d.ts +2 -1
  38. package/dist/Model/Repository.d.ts.map +1 -1
  39. package/dist/Model/Repository.js +2 -1
  40. package/dist/Model/dsl.d.ts +6 -5
  41. package/dist/Model/dsl.d.ts.map +1 -1
  42. package/dist/Model/dsl.js +2 -3
  43. package/dist/Model/filter/filterApi.d.ts +5 -5
  44. package/dist/Model/filter/filterApi.d.ts.map +1 -1
  45. package/dist/Model/filter/types/errors.d.ts +1 -1
  46. package/dist/Model/filter/types/fields.d.ts +1 -1
  47. package/dist/Model/filter/types/path/common.d.ts +1 -1
  48. package/dist/Model/filter/types/path/eager.d.ts +1 -1
  49. package/dist/Model/filter/types/path/eager.d.ts.map +1 -1
  50. package/dist/Model/filter/types/path/eager.js +1 -1
  51. package/dist/Model/filter/types/path/index.d.ts +1 -1
  52. package/dist/Model/filter/types/utils.d.ts +1 -1
  53. package/dist/Model/filter/types/validator.d.ts +1 -1
  54. package/dist/Model/filter/types.d.ts +5 -5
  55. package/dist/Model/query/dsl.d.ts +216 -18
  56. package/dist/Model/query/dsl.d.ts.map +1 -1
  57. package/dist/Model/query/dsl.js +240 -5
  58. package/dist/Model/query/new-kid-interpreter.d.ts +116 -8
  59. package/dist/Model/query/new-kid-interpreter.d.ts.map +1 -1
  60. package/dist/Model/query/new-kid-interpreter.js +177 -6
  61. package/dist/Model/query.d.ts +1 -1
  62. package/dist/Model.d.ts +2 -1
  63. package/dist/Model.d.ts.map +1 -1
  64. package/dist/Model.js +2 -1
  65. package/dist/QueueMaker/SQLQueue.d.ts +7 -8
  66. package/dist/QueueMaker/SQLQueue.d.ts.map +1 -1
  67. package/dist/QueueMaker/SQLQueue.js +135 -117
  68. package/dist/QueueMaker/errors.d.ts +5 -3
  69. package/dist/QueueMaker/errors.d.ts.map +1 -1
  70. package/dist/QueueMaker/errors.js +4 -2
  71. package/dist/QueueMaker/memQueue.d.ts +9 -5
  72. package/dist/QueueMaker/memQueue.d.ts.map +1 -1
  73. package/dist/QueueMaker/memQueue.js +81 -65
  74. package/dist/QueueMaker/sbqueue.d.ts +8 -4
  75. package/dist/QueueMaker/sbqueue.d.ts.map +1 -1
  76. package/dist/QueueMaker/sbqueue.js +57 -55
  77. package/dist/QueueMaker/service.d.ts +4 -2
  78. package/dist/QueueMaker/service.d.ts.map +1 -1
  79. package/dist/QueueMaker/service.js +1 -1
  80. package/dist/RequestContext.d.ts +75 -35
  81. package/dist/RequestContext.d.ts.map +1 -1
  82. package/dist/RequestContext.js +14 -14
  83. package/dist/RequestFiberSet.d.ts +10 -7
  84. package/dist/RequestFiberSet.d.ts.map +1 -1
  85. package/dist/RequestFiberSet.js +12 -7
  86. package/dist/Store/ContextMapContainer.d.ts +22 -3
  87. package/dist/Store/ContextMapContainer.d.ts.map +1 -1
  88. package/dist/Store/ContextMapContainer.js +18 -4
  89. package/dist/Store/Cosmos/query.d.ts +13 -2
  90. package/dist/Store/Cosmos/query.d.ts.map +1 -1
  91. package/dist/Store/Cosmos/query.js +179 -41
  92. package/dist/Store/Cosmos.d.ts +2 -2
  93. package/dist/Store/Cosmos.d.ts.map +1 -1
  94. package/dist/Store/Cosmos.js +343 -244
  95. package/dist/Store/Disk.d.ts +3 -3
  96. package/dist/Store/Disk.d.ts.map +1 -1
  97. package/dist/Store/Disk.js +76 -36
  98. package/dist/Store/Memory.d.ts +7 -4
  99. package/dist/Store/Memory.d.ts.map +1 -1
  100. package/dist/Store/Memory.js +327 -62
  101. package/dist/Store/SQL/Pg.d.ts +4 -0
  102. package/dist/Store/SQL/Pg.d.ts.map +1 -0
  103. package/dist/Store/SQL/Pg.js +233 -0
  104. package/dist/Store/SQL/query.d.ts +49 -0
  105. package/dist/Store/SQL/query.d.ts.map +1 -0
  106. package/dist/Store/SQL/query.js +527 -0
  107. package/dist/Store/SQL.d.ts +21 -0
  108. package/dist/Store/SQL.d.ts.map +1 -0
  109. package/dist/Store/SQL.js +450 -0
  110. package/dist/Store/codeFilter.d.ts +2 -2
  111. package/dist/Store/codeFilter.d.ts.map +1 -1
  112. package/dist/Store/codeFilter.js +6 -3
  113. package/dist/Store/index.d.ts +6 -3
  114. package/dist/Store/index.d.ts.map +1 -1
  115. package/dist/Store/index.js +18 -4
  116. package/dist/Store/service.d.ts +39 -9
  117. package/dist/Store/service.d.ts.map +1 -1
  118. package/dist/Store/service.js +31 -7
  119. package/dist/Store/utils.d.ts +3 -2
  120. package/dist/Store/utils.d.ts.map +1 -1
  121. package/dist/Store/utils.js +5 -5
  122. package/dist/Store.d.ts +1 -1
  123. package/dist/adapters/SQL/Model.d.ts +32 -43
  124. package/dist/adapters/SQL/Model.d.ts.map +1 -1
  125. package/dist/adapters/SQL/Model.js +30 -39
  126. package/dist/adapters/SQL.d.ts +1 -1
  127. package/dist/adapters/ServiceBus.d.ts +14 -11
  128. package/dist/adapters/ServiceBus.d.ts.map +1 -1
  129. package/dist/adapters/ServiceBus.js +30 -21
  130. package/dist/adapters/cosmos-client.d.ts +5 -3
  131. package/dist/adapters/cosmos-client.d.ts.map +1 -1
  132. package/dist/adapters/cosmos-client.js +6 -4
  133. package/dist/adapters/index.d.ts +8 -2
  134. package/dist/adapters/index.d.ts.map +1 -1
  135. package/dist/adapters/index.js +8 -2
  136. package/dist/adapters/logger.d.ts +1 -1
  137. package/dist/adapters/logger.d.ts.map +1 -1
  138. package/dist/adapters/memQueue.d.ts +5 -3
  139. package/dist/adapters/memQueue.d.ts.map +1 -1
  140. package/dist/adapters/memQueue.js +6 -5
  141. package/dist/adapters/mongo-client.d.ts +4 -3
  142. package/dist/adapters/mongo-client.d.ts.map +1 -1
  143. package/dist/adapters/mongo-client.js +5 -3
  144. package/dist/adapters/redis-client.d.ts +6 -3
  145. package/dist/adapters/redis-client.d.ts.map +1 -1
  146. package/dist/adapters/redis-client.js +7 -3
  147. package/dist/api/ContextProvider.d.ts +12 -9
  148. package/dist/api/ContextProvider.d.ts.map +1 -1
  149. package/dist/api/ContextProvider.js +9 -7
  150. package/dist/api/codec.d.ts +1 -1
  151. package/dist/api/internal/RequestContextMiddleware.d.ts +3 -3
  152. package/dist/api/internal/RequestContextMiddleware.d.ts.map +1 -1
  153. package/dist/api/internal/RequestContextMiddleware.js +18 -7
  154. package/dist/api/internal/auth.d.ts +45 -7
  155. package/dist/api/internal/auth.d.ts.map +1 -1
  156. package/dist/api/internal/auth.js +162 -29
  157. package/dist/api/internal/events.d.ts +6 -4
  158. package/dist/api/internal/events.d.ts.map +1 -1
  159. package/dist/api/internal/events.js +18 -11
  160. package/dist/api/internal/health.d.ts +1 -1
  161. package/dist/api/layerUtils.d.ts +15 -7
  162. package/dist/api/layerUtils.d.ts.map +1 -1
  163. package/dist/api/layerUtils.js +7 -6
  164. package/dist/api/middlewares.d.ts +1 -1
  165. package/dist/api/reportError.d.ts +2 -2
  166. package/dist/api/reportError.d.ts.map +1 -1
  167. package/dist/api/reportError.js +3 -2
  168. package/dist/api/routing/middleware/RouterMiddleware.d.ts +5 -4
  169. package/dist/api/routing/middleware/RouterMiddleware.d.ts.map +1 -1
  170. package/dist/api/routing/middleware/middleware.d.ts +42 -3
  171. package/dist/api/routing/middleware/middleware.d.ts.map +1 -1
  172. package/dist/api/routing/middleware/middleware.js +53 -17
  173. package/dist/api/routing/middleware.d.ts +3 -4
  174. package/dist/api/routing/middleware.d.ts.map +1 -1
  175. package/dist/api/routing/middleware.js +1 -2
  176. package/dist/api/routing/schema/jwt.d.ts +1 -1
  177. package/dist/api/routing/schema/jwt.d.ts.map +1 -1
  178. package/dist/api/routing/schema/jwt.js +3 -2
  179. package/dist/api/routing/tsort.d.ts +1 -1
  180. package/dist/api/routing/tsort.d.ts.map +1 -1
  181. package/dist/api/routing/utils.d.ts +4 -4
  182. package/dist/api/routing/utils.d.ts.map +1 -1
  183. package/dist/api/routing/utils.js +3 -2
  184. package/dist/api/routing.d.ts +84 -38
  185. package/dist/api/routing.d.ts.map +1 -1
  186. package/dist/api/routing.js +115 -45
  187. package/dist/api/setupRequest.d.ts +13 -6
  188. package/dist/api/setupRequest.d.ts.map +1 -1
  189. package/dist/api/setupRequest.js +37 -11
  190. package/dist/api/util.d.ts +1 -1
  191. package/dist/arbs.d.ts +2 -2
  192. package/dist/arbs.d.ts.map +1 -1
  193. package/dist/arbs.js +5 -3
  194. package/dist/errorReporter.d.ts +7 -5
  195. package/dist/errorReporter.d.ts.map +1 -1
  196. package/dist/errorReporter.js +22 -26
  197. package/dist/errors.d.ts +1 -1
  198. package/dist/fileUtil.d.ts +2 -2
  199. package/dist/fileUtil.d.ts.map +1 -1
  200. package/dist/fileUtil.js +2 -2
  201. package/dist/index.d.ts +1 -1
  202. package/dist/logger/jsonLogger.d.ts +2 -2
  203. package/dist/logger/jsonLogger.d.ts.map +1 -1
  204. package/dist/logger/jsonLogger.js +4 -2
  205. package/dist/logger/logFmtLogger.d.ts +2 -2
  206. package/dist/logger/logFmtLogger.d.ts.map +1 -1
  207. package/dist/logger/logFmtLogger.js +2 -2
  208. package/dist/logger/shared.d.ts +2 -2
  209. package/dist/logger/shared.d.ts.map +1 -1
  210. package/dist/logger/shared.js +3 -3
  211. package/dist/logger.d.ts +2 -2
  212. package/dist/logger.d.ts.map +1 -1
  213. package/dist/otel.d.ts +75 -0
  214. package/dist/otel.d.ts.map +1 -0
  215. package/dist/otel.js +65 -0
  216. package/dist/rateLimit.d.ts +12 -4
  217. package/dist/rateLimit.d.ts.map +1 -1
  218. package/dist/rateLimit.js +7 -12
  219. package/dist/test.d.ts +3 -3
  220. package/dist/test.d.ts.map +1 -1
  221. package/dist/test.js +2 -2
  222. package/dist/vitest.d.ts +1 -1
  223. package/examples/query.ts +46 -38
  224. package/package.json +46 -37
  225. package/src/CUPS.ts +15 -11
  226. package/src/Emailer/Sendgrid.ts +65 -57
  227. package/src/Emailer/fake.ts +2 -2
  228. package/src/Emailer/service.ts +13 -3
  229. package/src/MainFiberSet.ts +12 -10
  230. package/src/Model/Repository/Registry.ts +34 -0
  231. package/src/Model/Repository/ext.ts +103 -11
  232. package/src/Model/Repository/internal/internal.ts +266 -151
  233. package/src/Model/Repository/legacy.ts +3 -1
  234. package/src/Model/Repository/makeRepo.ts +15 -10
  235. package/src/Model/Repository/service.ts +35 -23
  236. package/src/Model/Repository/validation.ts +5 -5
  237. package/src/Model/Repository.ts +1 -0
  238. package/src/Model/dsl.ts +5 -4
  239. package/src/Model/filter/types/path/eager.ts +1 -2
  240. package/src/Model/filter/types.ts +4 -4
  241. package/src/Model/query/dsl.ts +456 -20
  242. package/src/Model/query/new-kid-interpreter.ts +281 -7
  243. package/src/Model.ts +1 -0
  244. package/src/QueueMaker/SQLQueue.ts +150 -153
  245. package/src/QueueMaker/errors.ts +3 -1
  246. package/src/QueueMaker/memQueue.ts +111 -105
  247. package/src/QueueMaker/sbqueue.ts +76 -88
  248. package/src/QueueMaker/service.ts +3 -1
  249. package/src/RequestContext.ts +15 -16
  250. package/src/RequestFiberSet.ts +12 -7
  251. package/src/Store/ContextMapContainer.ts +46 -3
  252. package/src/Store/Cosmos/query.ts +214 -50
  253. package/src/Store/Cosmos.ts +491 -350
  254. package/src/Store/Disk.ts +106 -66
  255. package/src/Store/Memory.ts +365 -91
  256. package/src/Store/SQL/Pg.ts +364 -0
  257. package/src/Store/SQL/query.ts +603 -0
  258. package/src/Store/SQL.ts +736 -0
  259. package/src/Store/codeFilter.ts +5 -2
  260. package/src/Store/index.ts +20 -3
  261. package/src/Store/service.ts +60 -11
  262. package/src/Store/utils.ts +25 -23
  263. package/src/adapters/SQL/Model.ts +42 -41
  264. package/src/adapters/ServiceBus.ts +131 -121
  265. package/src/adapters/cosmos-client.ts +5 -3
  266. package/src/adapters/index.ts +7 -0
  267. package/src/adapters/memQueue.ts +5 -4
  268. package/src/adapters/mongo-client.ts +4 -2
  269. package/src/adapters/redis-client.ts +6 -2
  270. package/src/api/ContextProvider.ts +19 -16
  271. package/src/api/internal/RequestContextMiddleware.ts +24 -6
  272. package/src/api/internal/auth.ts +248 -44
  273. package/src/api/internal/events.ts +21 -12
  274. package/src/api/layerUtils.ts +13 -9
  275. package/src/api/reportError.ts +2 -1
  276. package/src/api/routing/middleware/RouterMiddleware.ts +5 -4
  277. package/src/api/routing/middleware/middleware.ts +60 -15
  278. package/src/api/routing/middleware.ts +2 -4
  279. package/src/api/routing/schema/jwt.ts +2 -1
  280. package/src/api/routing/utils.ts +2 -1
  281. package/src/api/routing.ts +309 -139
  282. package/src/api/setupRequest.ts +63 -12
  283. package/src/arbs.ts +5 -3
  284. package/src/errorReporter.ts +65 -75
  285. package/src/fileUtil.ts +1 -1
  286. package/src/logger/jsonLogger.ts +3 -1
  287. package/src/logger/logFmtLogger.ts +1 -1
  288. package/src/logger/shared.ts +3 -2
  289. package/src/otel.ts +152 -0
  290. package/src/rateLimit.ts +34 -23
  291. package/src/test.ts +2 -2
  292. package/test/auth.test.ts +101 -0
  293. package/test/contextProvider.test.ts +14 -11
  294. package/test/controller.test.ts +25 -29
  295. package/test/cosmos-query.test.ts +159 -0
  296. package/test/dist/auth.test.d.ts.map +1 -0
  297. package/test/dist/contextProvider.test.d.ts.map +1 -1
  298. package/test/dist/controller.test.d.ts.map +1 -1
  299. package/test/dist/cosmos-query.test.d.ts.map +1 -0
  300. package/test/dist/date-query.test.d.ts.map +1 -0
  301. package/test/dist/fixtures.d.ts +30 -12
  302. package/test/dist/fixtures.d.ts.map +1 -1
  303. package/test/dist/fixtures.js +17 -10
  304. package/test/dist/query.test.d.ts.map +1 -1
  305. package/test/dist/rawQuery.test.d.ts.map +1 -1
  306. package/test/dist/repository-ext.test.d.ts.map +1 -0
  307. package/test/dist/requires.test.d.ts.map +1 -1
  308. package/test/dist/router-generator.test.d.ts.map +1 -0
  309. package/test/dist/routing-interruptibility.test.d.ts.map +1 -0
  310. package/test/dist/rpc-context-map-streaming.test.d.ts.map +1 -0
  311. package/test/dist/rpc-e2e-invalidation.test.d.ts.map +1 -0
  312. package/test/dist/rpc-multi-middleware.test.d.ts.map +1 -1
  313. package/test/dist/rpc-stream-fullstack.test.d.ts.map +1 -0
  314. package/test/dist/sql-store.test.d.ts.map +1 -0
  315. package/test/fixtures.ts +16 -9
  316. package/test/layerUtils.test.ts +1 -1
  317. package/test/query.test.ts +901 -38
  318. package/test/rawQuery.test.ts +338 -20
  319. package/test/repository-ext.test.ts +62 -0
  320. package/test/requires.test.ts +10 -5
  321. package/test/router-generator.test.ts +187 -0
  322. package/test/routing-interruptibility.test.ts +66 -0
  323. package/test/rpc-context-map-streaming.test.ts +262 -0
  324. package/test/rpc-e2e-invalidation.test.ts +256 -0
  325. package/test/rpc-multi-middleware.test.ts +84 -9
  326. package/test/rpc-stream-fullstack.test.ts +304 -0
  327. package/test/sql-store.test.ts +1711 -0
  328. package/test/validateSample.test.ts +17 -12
  329. package/tsconfig.examples.json +1 -1
  330. package/tsconfig.json +2 -1
  331. package/tsconfig.json.bak +2 -2
  332. package/tsconfig.src.json +35 -35
  333. package/tsconfig.test.json +2 -2
  334. package/dist/Operations.d.ts +0 -55
  335. package/dist/Operations.d.ts.map +0 -1
  336. package/dist/Operations.js +0 -102
  337. package/dist/OperationsRepo.d.ts +0 -41
  338. package/dist/OperationsRepo.d.ts.map +0 -1
  339. package/dist/OperationsRepo.js +0 -14
  340. package/eslint.config.mjs +0 -24
  341. package/src/Operations.ts +0 -235
  342. package/src/OperationsRepo.ts +0 -16
package/CHANGELOG.md CHANGED
@@ -1,5 +1,1823 @@
1
1
  # @effect-app/infra
2
2
 
3
+ ## 4.0.0-beta.241
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies [b035b1c]
8
+ - effect-app@4.0.0-beta.241
9
+
10
+ ## 4.0.0-beta.240
11
+
12
+ ### Patch Changes
13
+
14
+ - c5e348f: Fix `provideOnRequestScope` leaking a single `ContextMap` across concurrent requests.
15
+
16
+ `Layer.buildWithScope(layer, requestScope)` resolves its `MemoMap` from the
17
+ ambient fiber context, which lives on the HTTP server fiber and is therefore
18
+ shared by every request that server handles. With the resulting memoization,
19
+ the first request to land on a freshly-started server built
20
+ `ContextMapContainer.layer` once; every subsequent overlapping request received
21
+ the same `ContextMap` instance — etags written by one request were observed
22
+ (or overwritten) by another, and the finalizer was anchored to the first
23
+ request's scope.
24
+
25
+ `provideOnRequestScope` now allocates a fresh `MemoMap` per call via
26
+ `Layer.makeMemoMap` and builds with `Layer.buildWithMemoMap(layer, memoMap,
27
+ requestScope)`. Each request gets its own `ContextMap`, the request-scope
28
+ binding from the earlier SSE fix is preserved, and the finalizer still only
29
+ fires once the response body has fully drained.
30
+
31
+ Adds regression coverage in `rpc-context-map-streaming.test.ts` for three
32
+ properties: mid-stream survival of ContextMap state, a fresh map on each
33
+ succeeding request, and isolation between overlapping concurrent requests.
34
+
35
+ - effect-app@4.0.0-beta.240
36
+
37
+ ## 4.0.0-beta.239
38
+
39
+ ### Patch Changes
40
+
41
+ - bb3f51d: Fix ContextMap finalizer running mid-stream on SSE responses. SSE handler now binds ContextMapContainer to the request scope via a shared `provideOnRequestScope` helper (also used by `RequestContextMiddleware`), so finalizers only run after the response body is fully drained. Adds `setupStreamingRequestContextFromCurrent` for use by streaming HTTP handlers.
42
+ - effect-app@4.0.0-beta.239
43
+
44
+ ## 4.0.0-beta.238
45
+
46
+ ### Patch Changes
47
+
48
+ - b63f10f: fix: nasty request scope bug
49
+ - effect-app@4.0.0-beta.238
50
+
51
+ ## 4.0.0-beta.237
52
+
53
+ ### Patch Changes
54
+
55
+ - 3cf0c42: Fix `ContextMap` memory leak: tie its lifecycle to the request scope.
56
+
57
+ `ContextMapContainer.layer` provides a fresh `ContextMap` per request via `Layer.effect`, but the inner `etags` and `store` maps were never released. Cached `RequestResolver` entries (and anything they closed over) stayed reachable as long as any fiber held a reference to the map, even after the request scope closed.
58
+
59
+ `ContextMap` is now built with `Effect.acquireRelease`, and `makeContextMap` exposes a `clear()` finalizer that empties both maps when the request scope closes. `Layer.effect` strips the `Scope` requirement automatically in Effect v4.
60
+
61
+ - effect-app@4.0.0-beta.237
62
+
63
+ ## 4.0.0-beta.236
64
+
65
+ ### Patch Changes
66
+
67
+ - effect-app@4.0.0-beta.236
68
+
69
+ ## 4.0.0-beta.235
70
+
71
+ ### Patch Changes
72
+
73
+ - 6cfd83d: update effect to latest beta
74
+ - Updated dependencies [ba4bdc3]
75
+ - Updated dependencies [6cfd83d]
76
+ - effect-app@4.0.0-beta.235
77
+
78
+ ## 4.0.0-beta.234
79
+
80
+ ### Patch Changes
81
+
82
+ - effect-app@4.0.0-beta.234
83
+
84
+ ## 4.0.0-beta.233
85
+
86
+ ### Patch Changes
87
+
88
+ - 57a1862: Update to effect 4.0.0-beta.67. Switch deps from `pkg.pr.new` snapshot back to npm beta tag.
89
+ - Updated dependencies [57a1862]
90
+ - effect-app@4.0.0-beta.233
91
+
92
+ ## 4.0.0-beta.232
93
+
94
+ ### Patch Changes
95
+
96
+ - 0263827: Update to effect `pkg.pr.new` snapshot at `a42ef66` (4.0.0-beta.66). Remove `Yieldable` and `asEffect()` (service tags are now `Effect` directly).
97
+ - Updated dependencies [0263827]
98
+ - Updated dependencies [0263827]
99
+ - Updated dependencies [0263827]
100
+ - effect-app@4.0.0-beta.232
101
+
102
+ ## 4.0.0-beta.231
103
+
104
+ ### Patch Changes
105
+
106
+ - 7ca66ce: Update to effect 4.0.0-beta.66. Remove `Yieldable` and `asEffect()` (service tags are now `Effect` directly).
107
+ - Updated dependencies [7ca66ce]
108
+ - effect-app@4.0.0-beta.231
109
+
110
+ ## 4.0.0-beta.230
111
+
112
+ ### Minor Changes
113
+
114
+ - 1cee480: Add aggregate query support: `Q.aggregate(schema, aggregateMap)` performs GROUP BY + aggregate functions at the database level (Memory, SQL, Cosmos).
115
+
116
+ - New `agg` DSL namespace: `agg.field(path)` (group-by), `agg.count()`, `agg.countWhen(op)`, `agg.sum(field)`, `agg.min(field)`, `agg.max(field)`
117
+ - New `aggregate(schema, aggregateMap)` query operator replaces in-memory grouping with a single DB-level query
118
+ - Memory store: pure JS group-by + aggregation
119
+ - SQL store: `GROUP BY` + `COUNT(CASE WHEN ...)` / `SUM` / `MIN` / `MAX`
120
+ - Cosmos store: `GROUP BY` + `SUM(IIF(...))` for conditional counts
121
+
122
+ ### Patch Changes
123
+
124
+ - effect-app@4.0.0-beta.230
125
+
126
+ ## 4.0.0-beta.229
127
+
128
+ ### Patch Changes
129
+
130
+ - effect-app@4.0.0-beta.229
131
+
132
+ ## 4.0.0-beta.228
133
+
134
+ ### Patch Changes
135
+
136
+ - effect-app@4.0.0-beta.228
137
+
138
+ ## 4.0.0-beta.227
139
+
140
+ ### Patch Changes
141
+
142
+ - bac9f1a: Fix Cosmos `projectComputed` parameter index shift when `relation(...).every(...)` is present. The shared filter `print` was invoked twice per `relation-every` (once eagerly for the `where` variable, again inside the `NOT EXISTS(... WHERE NOT (...))` branch), bumping the outer `@v` counter beyond the bound parameter array and producing SQL that referenced unbound placeholders — queries returned 0 rows on Cosmos while SQLite/Memory adapters were unaffected.
143
+ - effect-app@4.0.0-beta.227
144
+
145
+ ## 4.0.0-beta.226
146
+
147
+ ### Patch Changes
148
+
149
+ - f7290aa: Add `relation(...).length()` computed projection — emits `ARRAY_LENGTH` on Cosmos / `arrayLength` on SQL / native `.length` on Memory. Cheaper than `relation.count()` for unconditional array sizing (no subquery scan, just metadata read).
150
+
151
+ ```ts
152
+ projectComputed(
153
+ S.Struct({ id: S.String, packageCount: S.NonNegativeInt }),
154
+ computed({ packageCount: relation<OrderEnc>("packages").length() })
155
+ );
156
+ ```
157
+
158
+ - 8062ad3: Unify Emailer `sendMail` spans across implementations. `Fake.sendMail` and `Sendgrid.sendMail` now both emit as `Emailer.sendMail` with OTel-standard `messaging.system` attribute (`"fake"` / `"sendgrid"`).
159
+ - effect-app@4.0.0-beta.226
160
+
161
+ ## 4.0.0-beta.225
162
+
163
+ ### Patch Changes
164
+
165
+ - 39996f7: Unify `parseMany` span variants under a single span name. The four prior spans (`parseMany`, `parseMany2`, `parseManyProject`, `parseManyCollect`) now all emit as `parseMany` with `app.entity` and `app.query.mode` attributes (`"transform" | "project" | "collect"`). Reuses the same attribute key already set on the parent `Repository.query` span for consistency. `parseManyProject`/`parseManyCollect` previously lacked `app.entity` — now included.
166
+ - effect-app@4.0.0-beta.225
167
+
168
+ ## 4.0.0-beta.224
169
+
170
+ ### Patch Changes
171
+
172
+ - effect-app@4.0.0-beta.224
173
+
174
+ ## 4.0.0-beta.223
175
+
176
+ ### Patch Changes
177
+
178
+ - 2871841: RequestContextMiddleware: set request name to `HTTP <method> <path>` (strip query string) for clearer span/trace names.
179
+ - effect-app@4.0.0-beta.223
180
+
181
+ ## 4.0.0-beta.222
182
+
183
+ ### Patch Changes
184
+
185
+ - effect-app@4.0.0-beta.222
186
+
187
+ ## 4.0.0-beta.221
188
+
189
+ ### Patch Changes
190
+
191
+ - 439cbeb: Adopt module system from effect-smol: replace barrel imports with specific submodule imports (`import * as X from "effect-app/X"` / `import * as X from "effect/X"`).
192
+ - Updated dependencies [439cbeb]
193
+ - effect-app@4.0.0-beta.221
194
+
195
+ ## 4.0.0-beta.220
196
+
197
+ ### Patch Changes
198
+
199
+ - aa436d3: fix bs span
200
+ - effect-app@4.0.0-beta.220
201
+
202
+ ## 4.0.0-beta.219
203
+
204
+ ### Patch Changes
205
+
206
+ - 13c2fd9: doc span
207
+ - d738811: remove double prefix
208
+ - 724da29: replace useless span
209
+ - Updated dependencies [d738811]
210
+ - effect-app@4.0.0-beta.219
211
+
212
+ ## 4.0.0-beta.218
213
+
214
+ ### Minor Changes
215
+
216
+ - 95995d5: Add `collectFields`/`collectDistinctFields` to `relation()` DSL for collecting values from multiple fields of relation items into a single flattened array.
217
+
218
+ Example: given `T = { a: boolean, items: { x: string, y: string, z: number }[] }[]`, you can now collect all distinct `x` and `y` values into a single `string[]`:
219
+
220
+ ```ts
221
+ relation("items").collectDistinctFields(["x", "y"]);
222
+ ```
223
+
224
+ ### Patch Changes
225
+
226
+ - effect-app@4.0.0-beta.218
227
+
228
+ ## 4.0.0-beta.217
229
+
230
+ ### Patch Changes
231
+
232
+ - e3ceaba: Add computed projection expression sums with grouped and normalized variants for projectComputed relation aggregations.
233
+ - Updated dependencies [0e824ef]
234
+ - effect-app@4.0.0-beta.217
235
+
236
+ ## 4.0.0-beta.216
237
+
238
+ ### Patch Changes
239
+
240
+ - f28fce5: fix sqlite
241
+ - effect-app@4.0.0-beta.216
242
+
243
+ ## 4.0.0-beta.215
244
+
245
+ ### Patch Changes
246
+
247
+ - 24f5dd0: fix memory computation
248
+ - effect-app@4.0.0-beta.215
249
+
250
+ ## 4.0.0-beta.214
251
+
252
+ ### Minor Changes
253
+
254
+ - fb93244: Extend computed projections with additional relation operators:
255
+
256
+ - `relation(path).every(op)` — boolean, all elements match the filter (compiled as `NOT EXISTS(... WHERE NOT (filter))`).
257
+ - `relation(path).distinctCount(field, op?)` — distinct count of values at `field` within the relation.
258
+ - `relation(path).sum(field, op?)` — numeric sum over a relation field.
259
+ - `relation(path).collect(field, op?)` / `collectDistinct(field, op?)` — collect values into an array (with optional dedup).
260
+
261
+ All operators compile to native subqueries on SQL (sqlite/pg) and Cosmos, and to in-memory equivalents on the Memory store.
262
+
263
+ ### Patch Changes
264
+
265
+ - effect-app@4.0.0-beta.214
266
+
267
+ ## 4.0.0-beta.213
268
+
269
+ ### Minor Changes
270
+
271
+ - aac6308: Add computed projections for repository queries with adapter-level compilation for memory, SQL, and Cosmos stores.
272
+
273
+ ### Patch Changes
274
+
275
+ - 6613f3d: Document `Q.project` modes (`transform` / `project` / `collect`): how `select` is derived from the schema AST, the PM reverse-mapping behaviour per mode, and which decode errors surface vs `orDie`.
276
+ - effect-app@4.0.0-beta.213
277
+
278
+ ## 4.0.0-beta.212
279
+
280
+ ### Patch Changes
281
+
282
+ - Updated dependencies [8792221]
283
+ - effect-app@4.0.0-beta.212
284
+
285
+ ## 4.0.0-beta.211
286
+
287
+ ### Patch Changes
288
+
289
+ - ebbb799: Repository owns OTel span topology; store adapters annotate db._ semconv attrs on the current span instead of opening their own child spans. Eliminates 1-1 nested span chains (e.g. `Repository.query` → `Cosmos.filter`). Adds `annotateDb` helper alongside `withDbSpan` in `otel.ts`. Repo public ops (`find`, `all`, `query`, `queryRaw`, `mapped._`) get explicit `Repository.<op>` spans; internal codec steps (`encodeMany`, `parseMany`, `parseMany2`) keep bare names. `validateSample`opens per-iteration sub-spans to prevent attribute clobber. Adds WeakMap decoder cache for`parseMany2` schemas.
290
+ - e33f1eb: Drop OTel spans from ServiceBus client/sender/receiver/subscription lifecycle wrappers; keep `withLogSpan` + info logs only. Removes high-cardinality `sessionId` from log span names; promotes it to `messaging.session.id` log attribute via `Effect.annotateLogs`.
291
+ - effect-app@4.0.0-beta.211
292
+
293
+ ## 4.0.0-beta.210
294
+
295
+ ### Minor Changes
296
+
297
+ - 3a588e4: Standardize span attributes on OpenTelemetry semantic conventions.
298
+
299
+ All Store adapters (Cosmos, PostgreSQL, SQLite, Memory, Disk) and Queue adapters
300
+ (Service Bus, SQL, Memory) now emit OTel-compliant span names and attributes via
301
+ the new `@effect-app/infra/otel` helper module.
302
+
303
+ Span name convention: `<operation> <collection|destination>` (low cardinality).
304
+
305
+ Attribute key migration:
306
+
307
+ | Old | New |
308
+ | --------------------------------------------------- | --------------------------------------------------------------------------------- |
309
+ | `repository.table_name` / `repository.container_id` | `db.collection.name` |
310
+ | `repository.namespace` | `db.namespace` |
311
+ | `repository.model_name` / `itemType` | `app.entity` |
312
+ | `id` / `itemId` (entity span attr) | `app.entity.id` |
313
+ | `itemIds` | `app.entity.ids` |
314
+ | `db.cosmos.request_charge` | `azure.cosmosdb.operation.request_charge` |
315
+ | `db.cosmos.resource_count` | `db.response.returned_rows` |
316
+ | `db.cosmos.response_bytes` | `db.response.body.size` |
317
+ | `disk.file` / `disk.file_size` | `disk.file.path` / `disk.file.size` |
318
+ | `queue.name` | `messaging.destination.name` |
319
+ | `queue.sessionId` | `messaging.message.conversation_id` |
320
+ | `queue.type` | `messaging.system` |
321
+ | `queue.input` (full body) | `messaging.message.body` (+ `messaging.message.id`, `messaging.message.type`) |
322
+ | `message_tags` | `messaging.message.types` + `messaging.batch.message_count` |
323
+ | `request.name` | `code.function.name` (from `spanAttributes`) / `rpc.method` (middleware) |
324
+ | `request.locale` | `app.locale` |
325
+ | `request.namespace` | `app.tenant.id` |
326
+ | `request.source.id` | `client.id` |
327
+ | `request.user.sub` / `.roles` | `user.id` / `user.roles` |
328
+ | `requestInput` | `rpc.request.payload` |
329
+ | `connectionId` | `network.connection.id` |
330
+ | Span `Request.<module>.<method>` | Span `<module>/<method>` + `rpc.system`/`rpc.service`/`rpc.method` (kind: server) |
331
+ | `<spanPrefix>.<op>` (SQL/Model) | OTel db span via `withDbSpan`, with `dbSystem?` option |
332
+
333
+ New attributes added:
334
+
335
+ - `db.system.name` — e.g. `postgresql`, `sqlite`, `cosmosdb`, `memory`, `disk`
336
+ - `db.operation.name` — e.g. `find`, `all`, `filter`, `set`
337
+ - `db.query.text` — sanitized / parameterized SQL or Cosmos query (no bound values)
338
+ - `messaging.operation.name` — `publish`, `process`, `receive`
339
+
340
+ Breaking: dashboards/alerts keying on the previous attribute names must be
341
+ updated. Queue consumer spans no longer log raw message bodies — use
342
+ `messaging.message.id` and `messaging.message.type` instead.
343
+
344
+ ### Patch Changes
345
+
346
+ - effect-app@4.0.0-beta.210
347
+
348
+ ## 4.0.0-beta.209
349
+
350
+ ### Patch Changes
351
+
352
+ - c991be1: update packages
353
+ - Updated dependencies [c991be1]
354
+ - Updated dependencies [3bae238]
355
+ - effect-app@4.0.0-beta.209
356
+
357
+ ## 4.0.0-beta.208
358
+
359
+ ### Patch Changes
360
+
361
+ - effect-app@4.0.0-beta.208
362
+
363
+ ## 4.0.0-beta.207
364
+
365
+ ### Patch Changes
366
+
367
+ - b0db40f: Router handlers are now discriminated by `Resource[K]["stream"]`:
368
+
369
+ - Stream resources (`stream: true`) accept only `(req) => Stream<...>` handlers.
370
+ - Non-stream resources accept only `(req) => Effect<...>` (or generator yielding `Yieldable`).
371
+
372
+ Mixing — e.g. returning `Effect.fail(...)` or `Effect<Stream<...>>` from a stream handler — no longer type-checks.
373
+
374
+ The runtime `Stream.unwrap` branch that lifted `Effect`/`Effect<Stream>` returns into a `Stream` is removed; handlers for stream resources must return a `Stream` directly. Migrate `Effect.gen(...).pipe(Stream.unwrap)` patterns by returning the `Stream` directly, and convert `Effect.fail(err)` in stream handlers to `Stream.fail(err)`.
375
+
376
+ - Updated dependencies [8fffc3c]
377
+ - effect-app@4.0.0-beta.207
378
+
379
+ ## 4.0.0-beta.206
380
+
381
+ ### Patch Changes
382
+
383
+ - 54bfc59: Require middleware to flow through `makeRpcClient` and the live layer through `makeRouter`.
384
+
385
+ ### `makeRpcClient(middleware, generalErrors?)`
386
+
387
+ Signature drops the `rcs` (request-context map wrapper) parameter. `rcs` was only load-bearing on the type side for `RequestConfig` inference; that information is now derived from `middleware.requestContextMap`. `middleware` is required — the previous "rcs + optional middleware" overload is gone.
388
+
389
+ **Migration**:
390
+
391
+ ```diff
392
+ -makeRpcClient(RequestContextMap, undefined, AppMiddleware)
393
+ +makeRpcClient(AppMiddleware)
394
+ ```
395
+
396
+ For tests/clients without a real middleware, build a minimal stub (`{ requestContextMap, requestContext }`) or pass any value satisfying `ClientMiddleware<RCM>`.
397
+
398
+ ### `makeRouter(middlewareLive)`
399
+
400
+ `makeRouter()` no longer infers the live middleware layer from `meta.middleware.Default`. The Live layer is now passed explicitly to `makeRouter`, and the request classes only carry the middleware tag (schema-only). This decouples the router from any assumption that the middleware tag exposes a `Default` static.
401
+
402
+ **Migration**:
403
+
404
+ ```diff
405
+ -export const { Router, matchAll } = makeRouter()
406
+ +export const { Router, matchAll } = makeRouter(AppMiddleware.Default)
407
+ ```
408
+
409
+ - Updated dependencies [54bfc59]
410
+ - effect-app@4.0.0-beta.206
411
+
412
+ ## 4.0.0-beta.205
413
+
414
+ ### Patch Changes
415
+
416
+ - Updated dependencies [f313973]
417
+ - effect-app@4.0.0-beta.205
418
+
419
+ ## 4.0.0-beta.204
420
+
421
+ ### Patch Changes
422
+
423
+ - Updated dependencies [0a0030f]
424
+ - effect-app@4.0.0-beta.204
425
+
426
+ ## 4.0.0-beta.203
427
+
428
+ ### Patch Changes
429
+
430
+ - Updated dependencies [992d9fa]
431
+ - effect-app@4.0.0-beta.203
432
+
433
+ ## 4.0.0-beta.202
434
+
435
+ ### Patch Changes
436
+
437
+ - Updated dependencies [1186b09]
438
+ - effect-app@4.0.0-beta.202
439
+
440
+ ## 4.0.0-beta.201
441
+
442
+ ### Patch Changes
443
+
444
+ - d67d17a: Source middleware errors exclusively from the rpc middleware tag, and move command/stream invalidation wrap/unwrap entirely into the routing layer (server) and `apiClientFactory` (client). `InvalidationMiddleware` and `InvalidationMiddlewareLive` are removed.
445
+
446
+ ### Resource error schemas
447
+
448
+ Three sites that used to fold `RequestContextMap[*].error` into a request's own error schema now stop doing so:
449
+
450
+ - `makeRpcClient` / `makeRequestClass` — `failureSchema` is just `config.error` (still merged with the optional `generalErrors` parameter, which is the only remaining error mix on both type and runtime levels).
451
+ - `MiddlewareMaker.rpc()` — `error: options.error` only; the previous union with `rcm.config[*].error` is gone.
452
+ - Routing and `apiClientFactory.makeRpcGroupFromRequestsAndModuleName` — `Invalidation.makeCommandRpc` is called with `error: resource.error` (no widening with the composite middleware error union).
453
+
454
+ Middleware errors reach the client through the rpc's `middlewares[*].error` failure-union channel of `Rpc.exitSchema`, exposed by attaching the middleware tag to the rpc on both sides:
455
+
456
+ - **Server**: `makeRouter(middleware)` attaches the live composite tag (existing behavior).
457
+ - **Client**: new `middleware` option on `ClientForOptions` / `ApiClientFactory.makeFor(layer, { middleware })` attaches the same tag schema-only (no Live invoked). Threaded through `makeRpcGroupFromRequestsAndModuleName` to `RpcGroup.middleware(tag)`. Without it, stream rpcs (whose top-level `errorSchema` is forced to `Never` by effect-rpc) hit `SchemaError: Expected never | { _tag: "error", ... }` decoding middleware-thrown errors that bypass the in-stream `Stream.catch` wrap.
458
+
459
+ **Migration**: handlers that yield errors previously sourced from rcm (e.g. `yield* new UnauthorizedError()`) now require those errors to be declared explicitly on the resource — `Req.Query<T>()("...", fields, { success, error: UnauthorizedError })`. The handler error type no longer auto-includes the rcm union.
460
+
461
+ ### Invalidation wrap/unwrap
462
+
463
+ - `routing.ts` (server) provides a per-request `InvalidationSet` for commands, wraps the success value as `CommandResponseWithMetaData`, and converts handler-thrown failures into `CommandFailureWithMetaData` so accumulated invalidation keys reach the client on either path. Stream wrap (per-chunk envelope + final `done` chunk) was already in routing and is unchanged.
464
+ - `apiClientFactory.ts` (client) `unwrapCommand` strips both envelopes and forwards keys to `InvalidationKeysFromServer`.
465
+ - `InvalidationMiddleware` (the tag) and `InvalidationMiddlewareLive` (the layer) are **removed**. The middleware was the previous home of the wrap; with the wrap moved to routing/apiClientFactory, the middleware became a thin pass-through and is no longer needed. `DefaultGenericMiddlewares` and `DefaultGenericMiddlewaresLive` shrink accordingly — no migration needed for callers that used the defaults; callers that referenced `InvalidationMiddleware` / `InvalidationMiddlewareLive` directly should drop those imports.
466
+
467
+ Middleware-thrown errors are never wrapped: by definition the handler never ran, so there is nothing to invalidate. They flow raw on the Cause and the client decodes them via the middleware-tag failure-union channel described above.
468
+
469
+ - Updated dependencies [d67d17a]
470
+ - effect-app@4.0.0-beta.201
471
+
472
+ ## 4.0.0-beta.200
473
+
474
+ ### Patch Changes
475
+
476
+ - 0cff7c1: workaround middleware error issue
477
+ - Updated dependencies [8f1cf6a]
478
+ - Updated dependencies [0cff7c1]
479
+ - effect-app@4.0.0-beta.200
480
+
481
+ ## 4.0.0-beta.199
482
+
483
+ ### Patch Changes
484
+
485
+ - de9fb83: Annotate Cosmos read spans with response size, resource count, and request charge.
486
+
487
+ `Cosmos.queryRaw`, `Cosmos.all`, `Cosmos.filter`, and `Cosmos.find` now set `db.cosmos.request_charge`, `db.cosmos.response_bytes`, and (where applicable) `db.cosmos.resource_count` on the active span. Bytes are sourced from `diagnostics.clientSideRequestStatistics.totalResponsePayloadLengthInBytes` — no payload stringification.
488
+
489
+ - effect-app@4.0.0-beta.199
490
+
491
+ ## 4.0.0-beta.198
492
+
493
+ ### Patch Changes
494
+
495
+ - 32dbc54: fix stream type when no success specified
496
+ - Updated dependencies [32dbc54]
497
+ - effect-app@4.0.0-beta.198
498
+
499
+ ## 4.0.0-beta.197
500
+
501
+ ### Minor Changes
502
+
503
+ - 3dc0d2a: Add streaming as a `stream: true` config option on `Query` / `Command` instead of a separate request type.
504
+
505
+ `TaggedRequestFor` now exposes only `Query` and `Command` factories — the standalone `Stream` factory is removed. To produce a Stream of `success` values, pass `stream: true` in the request config. The request `type` field stays `"command" | "query"`; a new `stream: boolean` field carries the streaming flag (stripped from the stored handler config).
506
+
507
+ ```ts
508
+ // Query that streams results
509
+ Req.Query<T>()("Tag", {}, { stream: true, success: ... })
510
+
511
+ // Command that streams results
512
+ Req.Command<T>()("Tag", {}, { stream: true, success: ... })
513
+ ```
514
+
515
+ Vue client mapping (per-handler properties mirror the non-stream API — `.query`, `.fn`, `.mutate`):
516
+
517
+ - `query` + `stream: true` → exposes `.query` (read-only streaming, tracked Vue Query). Helper map key: `${name}Query`.
518
+ - `command` + `stream: true` → exposes `.fn` and `.mutate` (mutating streaming).
519
+ - Plain `query` / `command` unchanged.
520
+
521
+ Server routing dispatches via the new `stream` flag (`makeStreamRpc` for streaming commands/queries, `makeCommandRpc` / `Rpc.make` otherwise).
522
+
523
+ Also lifts the `Struct` / `TaggedStruct` and `Opaque` definitions in `effect-app/Schema` to use `S.Bottom` / `S.Opaque` directly, exposing `fields`, `mapFields`, and a `MakeIn` that allows `void` when all fields are optional. `TaggedRequestFor` request classes now use `Opaque(TaggedStruct(...))` instead of `TaggedClass`, and decoding/encoding services are derived from `success` / `error` rather than stored on the request.
524
+
525
+ **Migration**: replace `Req.Stream` with `Req.Query` or `Req.Command` and add `stream: true` to the config — `Query` for read-only streams, `Command` for mutating streams.
526
+
527
+ ### Patch Changes
528
+
529
+ - Updated dependencies [3dc0d2a]
530
+ - effect-app@4.0.0-beta.197
531
+
532
+ ## 4.0.0-beta.196
533
+
534
+ ### Patch Changes
535
+
536
+ - effect-app@4.0.0-beta.196
537
+
538
+ ## 4.0.0-beta.195
539
+
540
+ ### Patch Changes
541
+
542
+ - 774a9b3: `MiddlewareMaker.makeMiddlewareBasic` now derives each middleware's effective error from both the static `error` field on the tag AND the `rcm` config entry referenced by `dynamic.key`, rather than relying on the static field alone.
543
+
544
+ Middlewares declared with `dynamic: RequestContextMap.get("foo")` (instead of an explicit static `error: ...`) end up with `tag.error = Schema.Never` at runtime — `RpcMiddleware.Tag` defaults the static error to `Never` when not provided. The composite `MiddlewareMaker.Tag(...).middleware(...)` walked `make[*].error` to build its own error union, collapsing to `Union<Never, ...> ≡ Never`.
545
+
546
+ `Rpc.exitSchema` walks `rpc.middlewares[*].error` when building the wire-level failure union for every rpc kind. Empty-union meant middleware-thrown errors (`NotLoggedInError`, `UnauthorizedError`, etc.) never reached the wire schema. Query/command happened to work because their wire `errorSchema = resource.error` already covered the merge from `makeRpcClient`. Stream rpcs have `errorSchema` force-set to `Schema.Never` by effect-rpc, so the resource-level merge never reached the wire — middleware errors decoded as "Expected never, got X".
547
+
548
+ Per middleware, the new logic pushes both the static `_.error` (if non-`Never`) and `rcm[_.dynamic.key].error` (if non-`Never`) into the composite's failure union.
549
+
550
+ - Updated dependencies [774a9b3]
551
+ - effect-app@4.0.0-beta.195
552
+
553
+ ## 4.0.0-beta.194
554
+
555
+ ### Patch Changes
556
+
557
+ - effect-app@4.0.0-beta.194
558
+
559
+ ## 4.0.0-beta.193
560
+
561
+ ### Patch Changes
562
+
563
+ - 9569911: Stream resources accept `Effect.fail(...)` (and `Effect<Stream>`) from controller handlers — previously only `Stream.fail(...)` / a returned `Stream` worked. The router now lifts an Effect result to a Stream via `Stream.unwrap`, so failures from an `Effect` propagate as a failing Stream on the client, matching `Stream.fail(...)` behavior. Also removes the need for manual `.pipe(Stream.unwrap)` on generator handlers that return a `Stream`.
564
+ - effect-app@4.0.0-beta.193
565
+
566
+ ## 4.0.0-beta.192
567
+
568
+ ### Patch Changes
569
+
570
+ - dba5779: namespaces
571
+ - effect-app@4.0.0-beta.192
572
+
573
+ ## 4.0.0-beta.191
574
+
575
+ ### Patch Changes
576
+
577
+ - 50ce7e6: Replace typescript-eslint with oxlint-tsgolint for type-aware lint. Drop ESLint entirely from non-vue packages (cli, effect-app, infra) — they now use only `oxlint --type-aware`. Vue packages keep ESLint to run `@effect-app/no-await-effect` (no tsgolint equivalent) via `@typescript-eslint/parser` + `vue-eslint-parser`.
578
+ - Updated dependencies [50ce7e6]
579
+ - effect-app@4.0.0-beta.191
580
+
581
+ ## 4.0.0-beta.190
582
+
583
+ ### Patch Changes
584
+
585
+ - Updated dependencies [985176b]
586
+ - effect-app@4.0.0-beta.190
587
+
588
+ ## 4.0.0-beta.189
589
+
590
+ ### Patch Changes
591
+
592
+ - ea32222: Update to effect 4.0.0-beta.60 and use native `Rpc.custom` constructors (`makeCommandRpc`, `makeStreamRpc`) for metadata-wrapped RPC schemas instead of manually wrapping/unwrapping schemas inline.
593
+ - Updated dependencies [ea32222]
594
+ - effect-app@4.0.0-beta.189
595
+
596
+ ## 4.0.0-beta.188
597
+
598
+ ### Patch Changes
599
+
600
+ - b2e438f: Remove Operations service and repo
601
+ - Updated dependencies [b2e438f]
602
+ - effect-app@4.0.0-beta.188
603
+
604
+ ## 4.0.0-beta.187
605
+
606
+ ### Patch Changes
607
+
608
+ - Updated dependencies [0d4e0b8]
609
+ - effect-app@4.0.0-beta.187
610
+
611
+ ## 4.0.0-beta.186
612
+
613
+ ### Patch Changes
614
+
615
+ - effect-app@4.0.0-beta.186
616
+
617
+ ## 4.0.0-beta.185
618
+
619
+ ### Patch Changes
620
+
621
+ - effect-app@4.0.0-beta.185
622
+
623
+ ## 4.0.0-beta.184
624
+
625
+ ### Patch Changes
626
+
627
+ - effect-app@4.0.0-beta.184
628
+
629
+ ## 4.0.0-beta.183
630
+
631
+ ### Patch Changes
632
+
633
+ - effect-app@4.0.0-beta.183
634
+
635
+ ## 4.0.0-beta.182
636
+
637
+ ### Patch Changes
638
+
639
+ - effect-app@4.0.0-beta.182
640
+
641
+ ## 4.0.0-beta.181
642
+
643
+ ### Patch Changes
644
+
645
+ - Updated dependencies [583393f]
646
+ - effect-app@4.0.0-beta.181
647
+
648
+ ## 4.0.0-beta.180
649
+
650
+ ### Minor Changes
651
+
652
+ - 7fa3045: V1/V2/V3: stream and command requests carry invalidation metadata
653
+
654
+ **V1** – stream final response includes metadata
655
+
656
+ - `Invalidation.StreamResponseChunk` wraps each stream item as `{ _tag: "value", value }` and appends `{ _tag: "done", metadata }` at the end carrying all accumulated invalidation keys.
657
+
658
+ **V2** – invalidation keys included in failures
659
+
660
+ - `Invalidation.CommandFailureWithMetaData` and `Invalidation.StreamFailureChunk` carry keys accumulated up to the point of failure, so clients can invalidate queries even when a command or stream errors.
661
+ - `InvalidationMiddlewareLive` wraps command failures; `routing.ts` wraps stream failures.
662
+ - `apiClientFactory.ts` unwraps both on the client side, forwarding keys before re-failing with the original error.
663
+
664
+ **V3** – mid-stream metadata chunks
665
+
666
+ - `Invalidation.StreamResponseChunk` now also includes `{ _tag: "metadata", metadata }` for mid-stream invalidation.
667
+ - After each emitted value, the server drains accumulated keys and emits a "metadata" chunk if any keys were collected since the last drain (bucket reset via `InvalidationSet.drain`).
668
+ - `apiClientFactory.ts` processes "metadata" chunks the same as "done" chunks, forwarding keys to `InvalidationKeysFromServer` immediately.
669
+ - `makeInvalidationKeysService` accepts an optional `onAdded` callback that fires after each key addition, enabling `mutate.ts` to trigger query invalidation mid-stream without waiting for the stream to complete.
670
+
671
+ ### Patch Changes
672
+
673
+ - Updated dependencies [7fa3045]
674
+ - effect-app@4.0.0-beta.180
675
+
676
+ ## 4.0.0-beta.179
677
+
678
+ ### Patch Changes
679
+
680
+ - Updated dependencies [828d264]
681
+ - effect-app@4.0.0-beta.179
682
+
683
+ ## 4.0.0-beta.178
684
+
685
+ ### Patch Changes
686
+
687
+ - effect-app@4.0.0-beta.178
688
+
689
+ ## 4.0.0-beta.177
690
+
691
+ ### Minor Changes
692
+
693
+ - 89d8b3a: Add Effect RPC `Stream` support to the wrapper.
694
+
695
+ - New `Stream` request constructor on `TaggedRequestFor` parallel to `Query`/`Command`. Emits resources with `type: "stream"`.
696
+ - Server router (`@effect-app/infra` `routing.ts`) accepts stream resources whose handlers return a `Stream.Stream<A, E, R>` (or a function from input to one). Forwards `stream: true` to `Rpc.make` so `RpcSchema.Stream` wrapping is applied. Streams bypass `applyRequestTypeInterruptibility` and the `Effect.withSpan` wrapping (the RPC server adds its own span).
697
+ - Client (`apiClientFactory.ts`) detects stream resources, forwards `stream: true` when constructing `RpcGroup`, and exposes the per-request `handler` as a `Stream.Stream` (via `Stream.unwrap` over the `ManagedRuntime` context) instead of an `Effect`. `Invalidation.CommandResponseWithMetaData` continues to apply only to commands.
698
+ - New `RequestStreamHandler` / `RequestStreamHandlerWithInput` shapes in `clientFor.ts`; `RequestHandlers` dispatches on `type: "stream"`.
699
+
700
+ ### Patch Changes
701
+
702
+ - Updated dependencies [89d8b3a]
703
+ - effect-app@4.0.0-beta.177
704
+
705
+ ## 4.0.0-beta.176
706
+
707
+ ### Patch Changes
708
+
709
+ - pass options
710
+ - Updated dependencies
711
+ - effect-app@4.0.0-beta.176
712
+
713
+ ## 4.0.0-beta.175
714
+
715
+ ### Patch Changes
716
+
717
+ - effect-app@4.0.0-beta.175
718
+
719
+ ## 4.0.0-beta.174
720
+
721
+ ### Minor Changes
722
+
723
+ - 821468d: Add server-driven cache invalidation via RPC response headers.
724
+
725
+ - `effect-app/rpc`: new `Invalidation` module with `InvalidationKey` / `InvalidationKeys` schemas, `Invalidates` annotation (for declaring static invalidation on Rpc definitions), `InvalidationSet` reference (request-scoped accumulator), and `makeInvalidationSet` helper.
726
+ - `effect-app/middleware`: new `InvalidationMiddleware` RPC middleware tag; included in `DefaultGenericMiddlewares`.
727
+ - `effect-app/client`: new `InvalidationKeys` module with `InvalidationKeysFromServer` reference and `makeInvalidationKeysService` helper; `apiClientFactory` now taps HTTP responses to read the `x-invalidate` header and forward keys to `InvalidationKeysFromServer`.
728
+ - `@effect-app/infra`: new `InvalidationMiddlewareLive` RPC middleware implementation that owns the full lifecycle — creates a request-scoped `InvalidationSet` (backed by a `Ref`), pre-populates it from the `Invalidates` annotation, provides it to the handler, and after the handler completes registers an HTTP pre-response handler (via `appendPreResponseHandlerUnsafe`) to write the accumulated keys as an `x-invalidate` response header. No separate HTTP middleware is needed.
729
+ - `@effect-app/vue`: `invalidateQueries` / `useMutation` now reads server-provided invalidation keys from `InvalidationKeysFromServer` after each mutation and applies them alongside the client-side invalidation.
730
+
731
+ ### Patch Changes
732
+
733
+ - Updated dependencies [821468d]
734
+ - effect-app@4.0.0-beta.174
735
+
736
+ ## 4.0.0-beta.173
737
+
738
+ ### Patch Changes
739
+
740
+ - effect-app@4.0.0-beta.173
741
+
742
+ ## 4.0.0-beta.172
743
+
744
+ ### Patch Changes
745
+
746
+ - improve sentry
747
+ - effect-app@4.0.0-beta.172
748
+
749
+ ## 4.0.0-beta.171
750
+
751
+ ### Patch Changes
752
+
753
+ - Updated dependencies [d71d976]
754
+ - effect-app@4.0.0-beta.171
755
+
756
+ ## 4.0.0-beta.170
757
+
758
+ ### Patch Changes
759
+
760
+ - Updated dependencies [8f09f77]
761
+ - effect-app@4.0.0-beta.170
762
+
763
+ ## 4.0.0-beta.169
764
+
765
+ ### Patch Changes
766
+
767
+ - Updated dependencies [8ae8b53]
768
+ - effect-app@4.0.0-beta.169
769
+
770
+ ## 4.0.0-beta.168
771
+
772
+ ### Patch Changes
773
+
774
+ - Updated dependencies [178480a]
775
+ - effect-app@4.0.0-beta.168
776
+
777
+ ## 4.0.0-beta.167
778
+
779
+ ### Patch Changes
780
+
781
+ - Updated dependencies [140e192]
782
+ - effect-app@4.0.0-beta.167
783
+
784
+ ## 4.0.0-beta.166
785
+
786
+ ### Patch Changes
787
+
788
+ - Updated dependencies [dbcc53b]
789
+ - effect-app@4.0.0-beta.166
790
+
791
+ ## 4.0.0-beta.165
792
+
793
+ ### Patch Changes
794
+
795
+ - Updated dependencies [f88ea34]
796
+ - effect-app@4.0.0-beta.165
797
+
798
+ ## 4.0.0-beta.164
799
+
800
+ ### Patch Changes
801
+
802
+ - Updated dependencies [8cb3de4]
803
+ - effect-app@4.0.0-beta.164
804
+
805
+ ## 4.0.0-beta.163
806
+
807
+ ### Patch Changes
808
+
809
+ - Updated dependencies [b952f19]
810
+ - effect-app@4.0.0-beta.163
811
+
812
+ ## 4.0.0-beta.162
813
+
814
+ ### Patch Changes
815
+
816
+ - Updated dependencies [b52b424]
817
+ - effect-app@4.0.0-beta.162
818
+
819
+ ## 4.0.0-beta.161
820
+
821
+ ### Patch Changes
822
+
823
+ - effect-app@4.0.0-beta.161
824
+
825
+ ## 4.0.0-beta.160
826
+
827
+ ### Patch Changes
828
+
829
+ - 505bfa9: Add concurrent decode helper APIs and migrate decode callsites to use them.
830
+
831
+ - Add `withDefaultParseOptions` and keep `DefaultParseOptions` centralized.
832
+ - Export `decodeEffectConcurrently` and `decodeUnknownEffectConcurrently` from Schema and SchemaParser modules.
833
+ - Update repository, queue, client, form, and CLI decode paths to use concurrent decode helpers.
834
+ - Keep schema constructors free of hardcoded parse concurrency overrides.
835
+
836
+ - Updated dependencies [505bfa9]
837
+ - effect-app@4.0.0-beta.160
838
+
839
+ ## 4.0.0-beta.159
840
+
841
+ ### Patch Changes
842
+
843
+ - c1e73de:
844
+ - Updated dependencies [c1e73de]
845
+ - effect-app@4.0.0-beta.159
846
+
847
+ ## 4.0.0-beta.158
848
+
849
+ ### Patch Changes
850
+
851
+ - Updated dependencies [3c1f52d]
852
+ - Updated dependencies [6ae3050]
853
+ - effect-app@4.0.0-beta.158
854
+
855
+ ## 4.0.0-beta.157
856
+
857
+ ### Patch Changes
858
+
859
+ - 6fff09c: unify encoded function for when you use encodedKeys
860
+ - Updated dependencies [6fff09c]
861
+ - effect-app@4.0.0-beta.157
862
+
863
+ ## 4.0.0-beta.156
864
+
865
+ ### Patch Changes
866
+
867
+ - effect-app@4.0.0-beta.156
868
+
869
+ ## 4.0.0-beta.155
870
+
871
+ ### Patch Changes
872
+
873
+ - Updated dependencies [c215db8]
874
+ - effect-app@4.0.0-beta.155
875
+
876
+ ## 4.0.0-beta.154
877
+
878
+ ### Patch Changes
879
+
880
+ - effect-app@4.0.0-beta.154
881
+
882
+ ## 4.0.0-beta.153
883
+
884
+ ### Patch Changes
885
+
886
+ - effect-app@4.0.0-beta.153
887
+
888
+ ## 4.0.0-beta.152
889
+
890
+ ### Patch Changes
891
+
892
+ - effect-app@4.0.0-beta.152
893
+
894
+ ## 4.0.0-beta.151
895
+
896
+ ### Patch Changes
897
+
898
+ - 925214b: update packages
899
+ - effect-app@4.0.0-beta.151
900
+
901
+ ## 4.0.0-beta.150
902
+
903
+ ### Patch Changes
904
+
905
+ - Updated dependencies [85a8275]
906
+ - effect-app@4.0.0-beta.150
907
+
908
+ ## 4.0.0-beta.149
909
+
910
+ ### Patch Changes
911
+
912
+ - Updated dependencies [f317c5e]
913
+ - effect-app@4.0.0-beta.149
914
+
915
+ ## 4.0.0-beta.148
916
+
917
+ ### Patch Changes
918
+
919
+ - Updated dependencies [199e9a5]
920
+ - effect-app@4.0.0-beta.148
921
+
922
+ ## 4.0.0-beta.147
923
+
924
+ ### Patch Changes
925
+
926
+ - Updated dependencies [47e3742]
927
+ - effect-app@4.0.0-beta.147
928
+
929
+ ## 4.0.0-beta.146
930
+
931
+ ### Patch Changes
932
+
933
+ - Updated dependencies [a4dff57]
934
+ - effect-app@4.0.0-beta.146
935
+
936
+ ## 4.0.0-beta.145
937
+
938
+ ### Patch Changes
939
+
940
+ - Updated dependencies [12abb55]
941
+ - effect-app@4.0.0-beta.145
942
+
943
+ ## 4.0.0-beta.144
944
+
945
+ ### Patch Changes
946
+
947
+ - d31253f: Refactor eligible schema classes and tagged classes to Opaque schemas, and migrate constructor call sites to use `.make` for those models.
948
+ - Updated dependencies [11422f8]
949
+ - Updated dependencies [d31253f]
950
+ - effect-app@4.0.0-beta.144
951
+
952
+ ## 4.0.0-beta.143
953
+
954
+ ### Patch Changes
955
+
956
+ - Updated dependencies [79eb019]
957
+ - effect-app@4.0.0-beta.143
958
+
959
+ ## 4.0.0-beta.142
960
+
961
+ ### Patch Changes
962
+
963
+ - Updated dependencies [3436d44]
964
+ - Updated dependencies [025de47]
965
+ - effect-app@4.0.0-beta.142
966
+
967
+ ## 4.0.0-beta.141
968
+
969
+ ### Patch Changes
970
+
971
+ - Updated dependencies [7c25dbb]
972
+ - effect-app@4.0.0-beta.141
973
+
974
+ ## 4.0.0-beta.140
975
+
976
+ ### Patch Changes
977
+
978
+ - 1576688: Add configurable `fakeMailAddress` to `SendgridConfig`. Supports `{i}` placeholder for unique addresses, e.g. `"test+{i}@example.com"`.
979
+ - effect-app@4.0.0-beta.140
980
+
981
+ ## 4.0.0-beta.139
982
+
983
+ ### Patch Changes
984
+
985
+ - effect-app@4.0.0-beta.139
986
+
987
+ ## 4.0.0-beta.138
988
+
989
+ ### Patch Changes
990
+
991
+ - effect-app@4.0.0-beta.138
992
+
993
+ ## 4.0.0-beta.137
994
+
995
+ ### Patch Changes
996
+
997
+ - effect-app@4.0.0-beta.137
998
+
999
+ ## 4.0.0-beta.136
1000
+
1001
+ ### Patch Changes
1002
+
1003
+ - effect-app@4.0.0-beta.136
1004
+
1005
+ ## 4.0.0-beta.135
1006
+
1007
+ ### Patch Changes
1008
+
1009
+ - Updated dependencies [c7bbc41]
1010
+ - effect-app@4.0.0-beta.135
1011
+
1012
+ ## 4.0.0-beta.134
1013
+
1014
+ ### Patch Changes
1015
+
1016
+ - eed57c6: Fix `R` inference in `OneDSL`, `OneDSLExt.modify` and `OneDSLExt.update`. The callback's effect type was annotated as `Effect<…, E, FixEnv<R, Evt, S1, S2>>`, which deadlocked inference of `R` (TS6 fell back to `never`, tsgo to `unknown`, leaking `unknown` into yielded effects in generator handlers). Now matches the existing `AllDSLExt` pattern: bare `R` in the callback, `FixEnv<R, …>` only in the return type.
1017
+ - Updated dependencies [9d3495e]
1018
+ - Updated dependencies [f353d48]
1019
+ - effect-app@4.0.0-beta.134
1020
+
1021
+ ## 4.0.0-beta.133
1022
+
1023
+ ### Patch Changes
1024
+
1025
+ - 2f862a4: Apply `toCodecJson` in `SQLModel.JsonFromString` so SQL JSON string fields use the proper JSON-safe codec at the encode/decode boundary (aligns with queue, event, and gist call sites).
1026
+ - c3299f7: update packages
1027
+ - Updated dependencies [c3299f7]
1028
+ - effect-app@4.0.0-beta.133
1029
+
1030
+ ## 4.0.0-beta.132
1031
+
1032
+ ### Patch Changes
1033
+
1034
+ - effect-app@4.0.0-beta.132
1035
+
1036
+ ## 4.0.0-beta.131
1037
+
1038
+ ### Patch Changes
1039
+
1040
+ - 4a7d95a: Use request-type RPC annotations to drive interruptibility and retry behavior, apply command uninterruptibility through the router wrapper path, and add an in-memory E2E test covering command vs query interruption behavior.
1041
+ - effect-app@4.0.0-beta.131
1042
+
1043
+ ## 4.0.0-beta.130
1044
+
1045
+ ### Patch Changes
1046
+
1047
+ - Updated dependencies [ea1bd46]
1048
+ - effect-app@4.0.0-beta.130
1049
+
1050
+ ## 4.0.0-beta.129
1051
+
1052
+ ### Patch Changes
1053
+
1054
+ - effect-app@4.0.0-beta.129
1055
+
1056
+ ## 4.0.0-beta.128
1057
+
1058
+ ### Patch Changes
1059
+
1060
+ - Updated dependencies [57db551]
1061
+ - effect-app@4.0.0-beta.128
1062
+
1063
+ ## 4.0.0-beta.127
1064
+
1065
+ ### Patch Changes
1066
+
1067
+ - 71a0719: Merge `batchPar` into `batch`, expose `concurrency` via an optional `BatchOptions` argument, and make `batch` dual (data-first + data-last).
1068
+ - 4bc3d05: Repository `save`, `remove`, and `removeById` now accept plain `ReadonlyArray` instead of `NonEmptyReadonlyArray`. Callers no longer need to narrow or guard for non-emptiness before invoking — empty inputs short-circuit to a no-op, making it ergonomic to pass through query results directly.
1069
+ - effect-app@4.0.0-beta.127
1070
+
1071
+ ## 4.0.0-beta.126
1072
+
1073
+ ### Patch Changes
1074
+
1075
+ - Updated dependencies [458bb1b]
1076
+ - effect-app@4.0.0-beta.126
1077
+
1078
+ ## 4.0.0-beta.125
1079
+
1080
+ ### Patch Changes
1081
+
1082
+ - 7191fc1: `removeById` now takes `id | NonEmptyReadonlyArray<id>` instead of a variadic rest, and the extended repo's `removeById` accepts a `batch` option to chunk large deletes — consistent with `save` and `remove`.
1083
+ - effect-app@4.0.0-beta.125
1084
+
1085
+ ## 4.0.0-beta.124
1086
+
1087
+ ### Patch Changes
1088
+
1089
+ - c9e0c44: cleanup auth
1090
+ - 256ae85: cleanup
1091
+ - Updated dependencies [256ae85]
1092
+ - effect-app@4.0.0-beta.124
1093
+
1094
+ ## 4.0.0-beta.123
1095
+
1096
+ ### Patch Changes
1097
+
1098
+ - Updated dependencies [14aba14]
1099
+ - effect-app@4.0.0-beta.123
1100
+
1101
+ ## 4.0.0-beta.122
1102
+
1103
+ ### Patch Changes
1104
+
1105
+ - 27bf9b6: Fix `Repository.query` environment typing to exclude schema context provided through `makeRepo` options.
1106
+ - e02a258: Add optional batching overloads for repository `save` and `remove` helpers.
1107
+ - f052d38: Replace `(...) => Effect.gen` with `Effect.fnUntraced` and convert select multi-step `pipe` chains to `Effect.gen` across infra.
1108
+ - Updated dependencies [f052d38]
1109
+ - effect-app@4.0.0-beta.122
1110
+
1111
+ ## 4.0.0-beta.121
1112
+
1113
+ ### Patch Changes
1114
+
1115
+ - 1015582: Fix `Q.project` field selection with `Schema.encodeKeys` by deriving selected fields from the encoded schema shape.
1116
+ - Updated dependencies [5ac46cb]
1117
+ - effect-app@4.0.0-beta.121
1118
+
1119
+ ## 4.0.0-beta.120
1120
+
1121
+ ### Patch Changes
1122
+
1123
+ - Updated dependencies [f21190c]
1124
+ - effect-app@4.0.0-beta.120
1125
+
1126
+ ## 4.0.0-beta.119
1127
+
1128
+ ### Patch Changes
1129
+
1130
+ - db7ba34: Filter SSE events stream by storeId namespace
1131
+ - effect-app@4.0.0-beta.119
1132
+
1133
+ ## 4.0.0-beta.118
1134
+
1135
+ ### Patch Changes
1136
+
1137
+ - Update effect packages to 4.0.0-beta.52
1138
+ - Updated dependencies [bd26832]
1139
+ - Updated dependencies [08d2e70]
1140
+ - Updated dependencies
1141
+ - effect-app@4.0.0-beta.118
1142
+
1143
+ ## 4.0.0-beta.117
1144
+
1145
+ ### Patch Changes
1146
+
1147
+ - 1d85785: Wrap store seed effects with `Effect.uninterruptible` to prevent interruption during seeding
1148
+ - effect-app@4.0.0-beta.117
1149
+
1150
+ ## 4.0.0-beta.116
1151
+
1152
+ ### Patch Changes
1153
+
1154
+ - 7d5cefc: SQL and Pg stores now scope seed migration records by namespace and table name in shared databases to avoid cross-namespace seed collisions.
1155
+ - effect-app@4.0.0-beta.116
1156
+
1157
+ ## 4.0.0-beta.115
1158
+
1159
+ ### Patch Changes
1160
+
1161
+ - fe2caba: SQL and Pg stores: use separate `_migrations` table for seed tracking instead of inserting a marker row into the data table, preventing it from appearing in `all`/`filter` queries.
1162
+ - effect-app@4.0.0-beta.115
1163
+
1164
+ ## 4.0.0-beta.114
1165
+
1166
+ ### Patch Changes
1167
+
1168
+ - 1ab3cf7: SQLite per-namespace adapter: use separate `_migrations` table for seed tracking instead of inserting a marker row into the data table, preventing it from appearing in `all`/`filter` queries.
1169
+ - effect-app@4.0.0-beta.114
1170
+
1171
+ ## 4.0.0-beta.113
1172
+
1173
+ ### Minor Changes
1174
+
1175
+ - ddc5492: Add RepositoryRegistry service that tracks all repositories by modelName, with `seedNamespace` to seed all registered repos in parallel and `entries` to inspect the registry.
1176
+
1177
+ Make non-primary namespace seeding explicit: Store and Repository now expose `seedNamespace` instead of auto-seeding on access. Primary namespace is still seeded eagerly on initialization.
1178
+
1179
+ SQL stores: table creation (`CREATE TABLE IF NOT EXISTS`) is now part of `seedNamespace` instead of running eagerly at store construction, ensuring tables for non-primary namespaces are only created when explicitly seeded.
1180
+
1181
+ ### Patch Changes
1182
+
1183
+ - effect-app@4.0.0-beta.113
1184
+
1185
+ ## 4.0.0-beta.112
1186
+
1187
+ ### Patch Changes
1188
+
1189
+ - 8a4a6d2: fup
1190
+ - effect-app@4.0.0-beta.112
1191
+
1192
+ ## 4.0.0-beta.111
1193
+
1194
+ ### Patch Changes
1195
+
1196
+ - ca94edf: fix typo
1197
+ - Updated dependencies [ca94edf]
1198
+ - effect-app@4.0.0-beta.111
1199
+
1200
+ ## 4.0.0-beta.110
1201
+
1202
+ ### Minor Changes
1203
+
1204
+ - c313c07: Add per-namespace in-memory SQLite adapter via LayerMap. When `makeSqlClientLayer` option is provided to `SQLiteStoreLayer`, each namespace gets its own SQLite database instance managed by a `LayerMap`. Introduces `WithNsTransaction` service for namespace-aware SQL transactions, used by `makeSqlTransactionMiddleware`.
1205
+
1206
+ ### Patch Changes
1207
+
1208
+ - effect-app@4.0.0-beta.110
1209
+
1210
+ ## 4.0.0-beta.109
1211
+
1212
+ ### Patch Changes
1213
+
1214
+ - 82f66f1: use uninterruptiple
1215
+ - effect-app@4.0.0-beta.109
1216
+
1217
+ ## 4.0.0-beta.108
1218
+
1219
+ ### Patch Changes
1220
+
1221
+ - Updated dependencies [3e46e7b]
1222
+ - effect-app@4.0.0-beta.108
1223
+
1224
+ ## 4.0.0-beta.107
1225
+
1226
+ ### Patch Changes
1227
+
1228
+ - 902ca1b: fix
1229
+ - effect-app@4.0.0-beta.107
1230
+
1231
+ ## 4.0.0-beta.106
1232
+
1233
+ ### Patch Changes
1234
+
1235
+ - f22a026: Use `Effect.cached` in `getOrCreateStoreEffect` for proper memoization of the resolver effect.
1236
+ - effect-app@4.0.0-beta.106
1237
+
1238
+ ## 4.0.0-beta.105
1239
+
1240
+ ### Minor Changes
1241
+
1242
+ - 3d732b1: Rewrite `withRequestResolverCache` to use official `RequestResolver.withCache`, creating a cached resolver per ContextMap via `getOrCreateStoreEffect` with semaphore-guarded initialization.
1243
+
1244
+ ### Patch Changes
1245
+
1246
+ - 47e53f5: Fix `withRequestResolverCache` causing "RequestResolver did not complete request" errors by using the `preCheck` hook instead of handling cache in `runAll`. Cache hits for in-flight or completed requests are now handled before entries enter the batch, preventing uncompleted entries.
1247
+ - 5773159: Add `itemType` annotation to all repository spans
1248
+ - effect-app@4.0.0-beta.105
1249
+
1250
+ ## 4.0.0-beta.104
1251
+
1252
+ ### Patch Changes
1253
+
1254
+ - Updated dependencies [e944bca]
1255
+ - effect-app@4.0.0-beta.104
1256
+
1257
+ ## 4.0.0-beta.103
1258
+
1259
+ ### Patch Changes
1260
+
1261
+ - Updated dependencies [7119320]
1262
+ - effect-app@4.0.0-beta.103
1263
+
1264
+ ## 4.0.0-beta.102
1265
+
1266
+ ### Patch Changes
1267
+
1268
+ - 62627e9: Fix boolean handling in SQL SELECT and WHERE
1269
+ - effect-app@4.0.0-beta.102
1270
+
1271
+ ## 4.0.0-beta.101
1272
+
1273
+ ### Patch Changes
1274
+
1275
+ - effect-app@4.0.0-beta.101
1276
+
1277
+ ## 4.0.0-beta.100
1278
+
1279
+ ### Patch Changes
1280
+
1281
+ - 43611c7: enable cosmosdb large partition key hashes
1282
+ - effect-app@4.0.0-beta.100
1283
+
1284
+ ## 4.0.0-beta.99
1285
+
1286
+ ### Patch Changes
1287
+
1288
+ - 6a0e008: remove artificial Cosmos bulkSet delays
1289
+ - effect-app@4.0.0-beta.99
1290
+
1291
+ ## 4.0.0-beta.98
1292
+
1293
+ ### Patch Changes
1294
+
1295
+ - 5aed2e3: Add span to Cosmos `batchRemove` and include `namespace` attribute on all Cosmos store spans.
1296
+ - effect-app@4.0.0-beta.98
1297
+
1298
+ ## 4.0.0-beta.97
1299
+
1300
+ ### Patch Changes
1301
+
1302
+ - 3eb66e9: Fix CosmosDB store `filter` to trigger namespace seeding on first access. Previously, if `filter` was the first operation called on a namespace, seed data was never created.
1303
+ - effect-app@4.0.0-beta.97
1304
+
1305
+ ## 4.0.0-beta.96
1306
+
1307
+ ### Patch Changes
1308
+
1309
+ - Updated dependencies [5615e47]
1310
+ - effect-app@4.0.0-beta.96
1311
+
1312
+ ## 4.0.0-beta.95
1313
+
1314
+ ### Patch Changes
1315
+
1316
+ - 88838fb: Remove pick/omit customizations from Class/TaggedClass/Struct/TaggedStruct. Use `Struct.pick(X.fields, [...])` from `effect-app` instead.
1317
+ - Updated dependencies [88838fb]
1318
+ - effect-app@4.0.0-beta.95
1319
+
1320
+ ## 4.0.0-beta.94
1321
+
1322
+ ### Patch Changes
1323
+
1324
+ - effect-app@4.0.0-beta.94
1325
+
1326
+ ## 4.0.0-beta.93
1327
+
1328
+ ### Patch Changes
1329
+
1330
+ - 2d85646: fix SQL includes-any/all double-quoting values for SQLite (JSON.stringify only needed for Postgres jsonb)
1331
+ - effect-app@4.0.0-beta.93
1332
+
1333
+ ## 4.0.0-beta.92
1334
+
1335
+ ### Patch Changes
1336
+
1337
+ - b4ffee0: fix SQL whereEvery double-negation bug causing wrong query when operators like notIn are used (especially with empty arrays)
1338
+ - effect-app@4.0.0-beta.92
1339
+
1340
+ ## 4.0.0-beta.91
1341
+
1342
+ ### Patch Changes
1343
+
1344
+ - Updated dependencies [738b482]
1345
+ - effect-app@4.0.0-beta.91
1346
+
1347
+ ## 4.0.0-beta.90
1348
+
1349
+ ### Patch Changes
1350
+
1351
+ - d786b91: Fix SQL `whereSome`/`whereEvery` array relation queries using `EXISTS` with `json_each` (SQLite) / `jsonb_array_elements` (Pg).
1352
+ - effect-app@4.0.0-beta.90
1353
+
1354
+ ## 4.0.0-beta.89
1355
+
1356
+ ### Patch Changes
1357
+
1358
+ - 9a9e46c: Fix SQL select queries to read `_etag` from column instead of JSON data, preventing INSERT on update.
1359
+ - effect-app@4.0.0-beta.89
1360
+
1361
+ ## 4.0.0-beta.88
1362
+
1363
+ ### Patch Changes
1364
+
1365
+ - dfd5562: Fix SQL `IN`/`NOT IN` with null values to use `IS NULL`/`IS NOT NULL` instead of `IN (NULL, ...)`.
1366
+ - effect-app@4.0.0-beta.88
1367
+
1368
+ ## 4.0.0-beta.87
1369
+
1370
+ ### Patch Changes
1371
+
1372
+ - 5a709d1: Fix SQLite select query type coercion using `json_quote` and apply defaultValues in SQL WHERE clauses via `COALESCE`.
1373
+ - effect-app@4.0.0-beta.87
1374
+
1375
+ ## 4.0.0-beta.86
1376
+
1377
+ ### Patch Changes
1378
+
1379
+ - 70f1f27: Fix store seeding: break circular dependency where bulkSet re-entered seedNamespace, and add explicit seed markers to SQL/Pg stores using a dedicated `__seed__` namespace.
1380
+ - effect-app@4.0.0-beta.86
1381
+
1382
+ ## 4.0.0-beta.85
1383
+
1384
+ ### Patch Changes
1385
+
1386
+ - db285e9: Add per-namespace seeding to SQL (SQLite/PostgreSQL) and CosmosDB store adapters. Previously only the `primary` namespace was seeded at initialization; now each namespace is lazily seeded on first access using `Effect.cached` to guarantee at-most-once execution. Primary namespace continues to seed eagerly on initialization. CosmosDB uses namespace-specific marker documents for backward compatibility.
1387
+ - effect-app@4.0.0-beta.85
1388
+
1389
+ ## 4.0.0-beta.84
1390
+
1391
+ ### Patch Changes
1392
+
1393
+ - c80e781: Fix SQLite store namespace parameter ordering in filter queries. The `_namespace` placeholder was prepended to the WHERE clause but its value was appended to the end of the positional params array, causing it to bind to the wrong placeholder. PostgreSQL was unaffected (uses indexed `$N` placeholders).
1394
+ - effect-app@4.0.0-beta.84
1395
+
1396
+ ## 4.0.0-beta.83
1397
+
1398
+ ### Patch Changes
1399
+
1400
+ - d1fc90a: Strip `_etag` and `id` from the `data` JSON column in SQL store adapters (SQLite + PostgreSQL). These fields are already stored as dedicated columns and were redundantly duplicated inside the JSON blob. On read, `parseRow` now re-injects `id` from the row column. Backward compatible: existing rows with `_etag`/`id` in `data` continue to work as the column values take precedence.
1401
+ - effect-app@4.0.0-beta.83
1402
+
1403
+ ## 4.0.0-beta.82
1404
+
1405
+ ### Minor Changes
1406
+
1407
+ - 48f1457: Add storage namespace support to CosmosDB adapter via partition key prefixing. When `allowNamespace` is configured, the namespace from `storeId` is prepended to partition key values (e.g., `test-ns::primary`), isolating data per namespace within the same container.
1408
+ - 48f1457: Add storage namespace support to SQL adapters (SQLite and Postgres) via a `_namespace` column. When `allowNamespace` is configured, a `_namespace` column with composite primary key `(id, _namespace)` isolates data per namespace within the same table. New tables get the schema automatically; existing tables require manual migration.
1409
+ - 48f1457: Add SQL Store adapter for Effect SQL (SQLite + PostgreSQL). Table-per-repo with id/etag/data JSON columns, query DSL translation to SQL WHERE clauses, optimistic concurrency via etag.
1410
+ - 48f1457: Make `withSqlTransaction` in `setupRequest` configurable via `withTransaction` option (defaults to `false`). Add `requiresTransactionConfig` and `makeSqlTransactionMiddleware` for per-RPC transaction control as a dynamic middleware that requires `SqlClient` directly. Transactions are disabled by default; opt in with `withTransaction: true` or `requiresTransaction: true`.
1411
+
1412
+ ### Patch Changes
1413
+
1414
+ - effect-app@4.0.0-beta.82
1415
+
1416
+ ## 4.0.0-beta.81
1417
+
1418
+ ### Minor Changes
1419
+
1420
+ - fd67f0b: Add `withRequestResolverCache` to scope RequestResolver cache to the ContextMap (request-scoped). Add `getOrCreateStore` to ContextMap for generic scoped storage.
1421
+
1422
+ ### Patch Changes
1423
+
1424
+ - effect-app@4.0.0-beta.81
1425
+
1426
+ ## 4.0.0-beta.80
1427
+
1428
+ ### Patch Changes
1429
+
1430
+ - eaf0115: enforce local
1431
+ - effect-app@4.0.0-beta.80
1432
+
1433
+ ## 4.0.0-beta.79
1434
+
1435
+ ### Patch Changes
1436
+
1437
+ - d16845e: Remove `TaggedRequest` from `makeRpcClient`, now only `TaggedRequestFor` is returned. Remove all legacy `meta.moduleName` support — `id` and `moduleName` are now required on `Req` type. Remove `makeRpcGroup` (use `makeRpcGroupFromRequestsAndModuleName` instead).
1438
+ - Updated dependencies [d16845e]
1439
+ - effect-app@4.0.0-beta.79
1440
+
1441
+ ## 4.0.0-beta.78
1442
+
1443
+ ### Minor Changes
1444
+
1445
+ - 818e047: Router `matchFor` no longer requires `meta` property on resource when requests carry `moduleName` from `TaggedRequestFor`
1446
+
1447
+ ### Patch Changes
1448
+
1449
+ - effect-app@4.0.0-beta.78
1450
+
1451
+ ## 4.0.0-beta.77
1452
+
1453
+ ### Patch Changes
1454
+
1455
+ - Updated dependencies [3613e87]
1456
+ - effect-app@4.0.0-beta.77
1457
+
1458
+ ## 4.0.0-beta.76
1459
+
1460
+ ### Patch Changes
1461
+
1462
+ - fac725d: update effect to latest beta
1463
+ - Updated dependencies [a5248a9]
1464
+ - Updated dependencies [fac725d]
1465
+ - effect-app@4.0.0-beta.76
1466
+
1467
+ ## 4.0.0-beta.75
1468
+
1469
+ ### Patch Changes
1470
+
1471
+ - Updated dependencies [24f0a5a]
1472
+ - effect-app@4.0.0-beta.75
1473
+
1474
+ ## 4.0.0-beta.74
1475
+
1476
+ ### Patch Changes
1477
+
1478
+ - Updated dependencies [54ec1ef]
1479
+ - effect-app@4.0.0-beta.74
1480
+
1481
+ ## 4.0.0-beta.73
1482
+
1483
+ ### Patch Changes
1484
+
1485
+ - b53c59e: fix signature
1486
+ - effect-app@4.0.0-beta.73
1487
+
1488
+ ## 4.0.0-beta.72
1489
+
1490
+ ### Patch Changes
1491
+
1492
+ - Updated dependencies [0541f0d]
1493
+ - effect-app@4.0.0-beta.72
1494
+
1495
+ ## 4.0.0-beta.71
1496
+
1497
+ ### Patch Changes
1498
+
1499
+ - beae3a0: Remove `withDefaultConstructor` wrapper, use `S.withConstructorDefault` directly with `Effect.succeed`/`Effect.sync`.
1500
+ - Updated dependencies [beae3a0]
1501
+ - effect-app@4.0.0-beta.71
1502
+
1503
+ ## 4.0.0-beta.70
1504
+
1505
+ ### Patch Changes
1506
+
1507
+ - fdb9cb3: cleanup
1508
+ - effect-app@4.0.0-beta.70
1509
+
1510
+ ## 4.0.0-beta.69
1511
+
1512
+ ### Patch Changes
1513
+
1514
+ - dc465e3: update to latest effect beta
1515
+ - Updated dependencies [dc465e3]
1516
+ - effect-app@4.0.0-beta.69
1517
+
1518
+ ## 4.0.0-beta.68
1519
+
1520
+ ### Patch Changes
1521
+
1522
+ - Updated dependencies [e6f2341]
1523
+ - effect-app@4.0.0-beta.68
1524
+
1525
+ ## 4.0.0-beta.67
1526
+
1527
+ ### Patch Changes
1528
+
1529
+ - effect-app@4.0.0-beta.67
1530
+
1531
+ ## 4.0.0-beta.66
1532
+
1533
+ ### Patch Changes
1534
+
1535
+ - Updated dependencies [edc52e4]
1536
+ - effect-app@4.0.0-beta.66
1537
+
1538
+ ## 4.0.0-beta.65
1539
+
1540
+ ### Patch Changes
1541
+
1542
+ - Updated dependencies [31739d7]
1543
+ - Updated dependencies [1f103b2]
1544
+ - effect-app@4.0.0-beta.65
1545
+
1546
+ ## 4.0.0-beta.64
1547
+
1548
+ ### Patch Changes
1549
+
1550
+ - Updated dependencies [c1a6fdc]
1551
+ - effect-app@4.0.0-beta.64
1552
+
1553
+ ## 4.0.0-beta.63
1554
+
1555
+ ### Patch Changes
1556
+
1557
+ - 1f9d7da: fix missing toCodecJson usages
1558
+ - effect-app@4.0.0-beta.63
1559
+
1560
+ ## 4.0.0-beta.62
1561
+
1562
+ ### Patch Changes
1563
+
1564
+ - Updated dependencies [0b21a02]
1565
+ - effect-app@4.0.0-beta.62
1566
+
1567
+ ## 4.0.0-beta.61
1568
+
1569
+ ### Patch Changes
1570
+
1571
+ - effect-app@4.0.0-beta.61
1572
+
1573
+ ## 4.0.0-beta.60
1574
+
1575
+ ### Patch Changes
1576
+
1577
+ - 29c39d2: Fix repository `find` with transformed id fields in tagged union schemas
1578
+ - effect-app@4.0.0-beta.60
1579
+
1580
+ ## 4.0.0-beta.59
1581
+
1582
+ ### Patch Changes
1583
+
1584
+ - cec026d: update packages
1585
+ - Updated dependencies [cec026d]
1586
+ - effect-app@4.0.0-beta.59
1587
+
1588
+ ## 4.0.0-beta.58
1589
+
1590
+ ### Patch Changes
1591
+
1592
+ - effect-app@4.0.0-beta.58
1593
+
1594
+ ## 4.0.0-beta.57
1595
+
1596
+ ### Patch Changes
1597
+
1598
+ - fbf47b8: Fix repository `find` with transformed id fields (e.g. composite ids using `decodeTo`)
1599
+ - effect-app@4.0.0-beta.57
1600
+
1601
+ ## 4.0.0-beta.56
1602
+
1603
+ ### Patch Changes
1604
+
1605
+ - effect-app@4.0.0-beta.56
1606
+
1607
+ ## 4.0.0-beta.55
1608
+
1609
+ ### Patch Changes
1610
+
1611
+ - effect-app@4.0.0-beta.55
1612
+
1613
+ ## 4.0.0-beta.54
1614
+
1615
+ ### Patch Changes
1616
+
1617
+ - d867272: the return of `Context`
1618
+ - Updated dependencies [d867272]
1619
+ - effect-app@4.0.0-beta.54
1620
+
1621
+ ## 4.0.0-beta.53
1622
+
1623
+ ### Patch Changes
1624
+
1625
+ - Updated dependencies [ee9694e]
1626
+ - effect-app@4.0.0-beta.53
1627
+
1628
+ ## 4.0.0-beta.52
1629
+
1630
+ ### Patch Changes
1631
+
1632
+ - Updated dependencies [6252808]
1633
+ - effect-app@4.0.0-beta.52
1634
+
1635
+ ## 4.0.0-beta.51
1636
+
1637
+ ### Patch Changes
1638
+
1639
+ - effect-app@4.0.0-beta.51
1640
+
1641
+ ## 4.0.0-beta.50
1642
+
1643
+ ### Patch Changes
1644
+
1645
+ - effect-app@4.0.0-beta.50
1646
+
1647
+ ## 4.0.0-beta.49
1648
+
1649
+ ### Patch Changes
1650
+
1651
+ - Updated dependencies [e585c9c]
1652
+ - effect-app@4.0.0-beta.49
1653
+
1654
+ ## 4.0.0-beta.48
1655
+
1656
+ ### Patch Changes
1657
+
1658
+ - Updated dependencies [0c88f78]
1659
+ - effect-app@4.0.0-beta.48
1660
+
1661
+ ## 4.0.0-beta.47
1662
+
1663
+ ### Patch Changes
1664
+
1665
+ - Updated dependencies [3365758]
1666
+ - effect-app@4.0.0-beta.47
1667
+
1668
+ ## 4.0.0-beta.46
1669
+
1670
+ ### Patch Changes
1671
+
1672
+ - effect-app@4.0.0-beta.46
1673
+
1674
+ ## 4.0.0-beta.45
1675
+
1676
+ ### Patch Changes
1677
+
1678
+ - 10b55ff: update packages
1679
+ - Updated dependencies [10b55ff]
1680
+ - effect-app@4.0.0-beta.45
1681
+
1682
+ ## 4.0.0-beta.44
1683
+
1684
+ ### Patch Changes
1685
+
1686
+ - a37aa38: Update to effect beta 43
1687
+ - Updated dependencies [a37aa38]
1688
+ - effect-app@4.0.0-beta.44
1689
+
1690
+ ## 4.0.0-beta.43
1691
+
1692
+ ### Patch Changes
1693
+
1694
+ - dab6992: no need for .lock.lock
1695
+ - effect-app@4.0.0-beta.43
1696
+
1697
+ ## 4.0.0-beta.42
1698
+
1699
+ ### Patch Changes
1700
+
1701
+ - effect-app@4.0.0-beta.42
1702
+
1703
+ ## 4.0.0-beta.41
1704
+
1705
+ ### Patch Changes
1706
+
1707
+ - effect-app@4.0.0-beta.41
1708
+
1709
+ ## 4.0.0-beta.40
1710
+
1711
+ ### Patch Changes
1712
+
1713
+ - effect-app@4.0.0-beta.40
1714
+
1715
+ ## 4.0.0-beta.39
1716
+
1717
+ ### Patch Changes
1718
+
1719
+ - Updated dependencies [10e90d5]
1720
+ - effect-app@4.0.0-beta.39
1721
+
1722
+ ## 4.0.0-beta.38
1723
+
1724
+ ### Patch Changes
1725
+
1726
+ - Updated dependencies [0b3e00e]
1727
+ - effect-app@4.0.0-beta.38
1728
+
1729
+ ## 4.0.0-beta.37
1730
+
1731
+ ### Patch Changes
1732
+
1733
+ - Updated dependencies [947fe20]
1734
+ - effect-app@4.0.0-beta.37
1735
+
1736
+ ## 4.0.0-beta.36
1737
+
1738
+ ### Patch Changes
1739
+
1740
+ - effect-app@4.0.0-beta.36
1741
+
1742
+ ## 4.0.0-beta.35
1743
+
1744
+ ### Patch Changes
1745
+
1746
+ - effect-app@4.0.0-beta.35
1747
+
1748
+ ## 4.0.0-beta.34
1749
+
1750
+ ### Patch Changes
1751
+
1752
+ - 8c645d5: update to latest effect
1753
+ - Updated dependencies [8c645d5]
1754
+ - effect-app@4.0.0-beta.34
1755
+
1756
+ ## 4.0.0-beta.33
1757
+
1758
+ ### Patch Changes
1759
+
1760
+ - 4b95009: use Finite instead of Number
1761
+ - Updated dependencies [4b95009]
1762
+ - effect-app@4.0.0-beta.33
1763
+
1764
+ ## 4.0.0-beta.32
1765
+
1766
+ ### Patch Changes
1767
+
1768
+ - Updated dependencies [01d862a]
1769
+ - effect-app@4.0.0-beta.32
1770
+
1771
+ ## 4.0.0-beta.31
1772
+
1773
+ ### Patch Changes
1774
+
1775
+ - Updated dependencies [6b6d601]
1776
+ - effect-app@4.0.0-beta.31
1777
+
1778
+ ## 4.0.0-beta.30
1779
+
1780
+ ### Patch Changes
1781
+
1782
+ - Updated dependencies [5ec1f45]
1783
+ - effect-app@4.0.0-beta.30
1784
+
1785
+ ## 4.0.0-beta.29
1786
+
1787
+ ### Patch Changes
1788
+
1789
+ - Updated dependencies [a899d46]
1790
+ - effect-app@4.0.0-beta.29
1791
+
1792
+ ## 4.0.0-beta.28
1793
+
1794
+ ### Patch Changes
1795
+
1796
+ - Updated dependencies [0099208]
1797
+ - effect-app@4.0.0-beta.28
1798
+
1799
+ ## 4.0.0-beta.27
1800
+
1801
+ ### Patch Changes
1802
+
1803
+ - 601a1ff: update effect to 4.0.0-beta.37 and drop the Schema Class disableValidation workaround now that the patched effect schema covers it
1804
+ - Updated dependencies [601a1ff]
1805
+ - effect-app@4.0.0-beta.27
1806
+
1807
+ ## 4.0.0-beta.26
1808
+
1809
+ ### Patch Changes
1810
+
1811
+ - Updated dependencies [4da28e2]
1812
+ - effect-app@4.0.0-beta.26
1813
+
1814
+ ## 4.0.0-beta.25
1815
+
1816
+ ### Patch Changes
1817
+
1818
+ - Updated dependencies [6282d4b]
1819
+ - effect-app@4.0.0-beta.25
1820
+
3
1821
  ## 4.0.0-beta.24
4
1822
 
5
1823
  ### Patch Changes