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

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