effect 4.0.0-beta.43 → 4.0.0-beta.45

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 (918) hide show
  1. package/dist/Cache.d.ts +12 -43
  2. package/dist/Cache.d.ts.map +1 -1
  3. package/dist/Cache.js +15 -42
  4. package/dist/Cache.js.map +1 -1
  5. package/dist/Cause.d.ts +21 -21
  6. package/dist/Cause.d.ts.map +1 -1
  7. package/dist/Cause.js +89 -10
  8. package/dist/Cause.js.map +1 -1
  9. package/dist/Channel.d.ts +42 -19
  10. package/dist/Channel.d.ts.map +1 -1
  11. package/dist/Channel.js +86 -46
  12. package/dist/Channel.js.map +1 -1
  13. package/dist/Clock.d.ts +2 -2
  14. package/dist/Clock.d.ts.map +1 -1
  15. package/dist/Clock.js.map +1 -1
  16. package/dist/Config.d.ts +2 -2
  17. package/dist/ConfigProvider.d.ts +5 -5
  18. package/dist/ConfigProvider.d.ts.map +1 -1
  19. package/dist/ConfigProvider.js +5 -5
  20. package/dist/ConfigProvider.js.map +1 -1
  21. package/dist/Console.d.ts +2 -2
  22. package/dist/Console.d.ts.map +1 -1
  23. package/dist/Console.js.map +1 -1
  24. package/dist/Context.d.ts +1150 -0
  25. package/dist/Context.d.ts.map +1 -0
  26. package/dist/{ServiceMap.js → Context.js} +139 -139
  27. package/dist/Context.js.map +1 -0
  28. package/dist/DateTime.d.ts +2 -2
  29. package/dist/DateTime.d.ts.map +1 -1
  30. package/dist/DateTime.js +2 -2
  31. package/dist/DateTime.js.map +1 -1
  32. package/dist/Effect.d.ts +177 -177
  33. package/dist/Effect.d.ts.map +1 -1
  34. package/dist/Effect.js +81 -81
  35. package/dist/Effect.js.map +1 -1
  36. package/dist/Equal.d.ts.map +1 -1
  37. package/dist/Equal.js +16 -0
  38. package/dist/Equal.js.map +1 -1
  39. package/dist/ErrorReporter.d.ts +3 -3
  40. package/dist/ErrorReporter.d.ts.map +1 -1
  41. package/dist/ErrorReporter.js +1 -1
  42. package/dist/ErrorReporter.js.map +1 -1
  43. package/dist/ExecutionPlan.d.ts +6 -6
  44. package/dist/ExecutionPlan.d.ts.map +1 -1
  45. package/dist/ExecutionPlan.js +4 -4
  46. package/dist/ExecutionPlan.js.map +1 -1
  47. package/dist/Fiber.d.ts +7 -7
  48. package/dist/Fiber.d.ts.map +1 -1
  49. package/dist/Fiber.js.map +1 -1
  50. package/dist/FiberHandle.d.ts +2 -2
  51. package/dist/FiberHandle.d.ts.map +1 -1
  52. package/dist/FiberHandle.js +4 -4
  53. package/dist/FiberHandle.js.map +1 -1
  54. package/dist/FiberMap.d.ts +2 -2
  55. package/dist/FiberMap.d.ts.map +1 -1
  56. package/dist/FiberMap.js +4 -4
  57. package/dist/FiberMap.js.map +1 -1
  58. package/dist/FiberSet.d.ts +2 -2
  59. package/dist/FiberSet.d.ts.map +1 -1
  60. package/dist/FiberSet.js +4 -4
  61. package/dist/FiberSet.js.map +1 -1
  62. package/dist/FileSystem.d.ts +3 -3
  63. package/dist/FileSystem.d.ts.map +1 -1
  64. package/dist/FileSystem.js +3 -3
  65. package/dist/FileSystem.js.map +1 -1
  66. package/dist/Hash.js +1 -1
  67. package/dist/Hash.js.map +1 -1
  68. package/dist/Layer.d.ts +286 -268
  69. package/dist/Layer.d.ts.map +1 -1
  70. package/dist/Layer.js +133 -134
  71. package/dist/Layer.js.map +1 -1
  72. package/dist/LayerMap.d.ts +18 -18
  73. package/dist/LayerMap.d.ts.map +1 -1
  74. package/dist/LayerMap.js +18 -15
  75. package/dist/LayerMap.js.map +1 -1
  76. package/dist/Logger.d.ts +3 -3
  77. package/dist/Logger.d.ts.map +1 -1
  78. package/dist/Logger.js.map +1 -1
  79. package/dist/ManagedRuntime.d.ts +6 -6
  80. package/dist/ManagedRuntime.d.ts.map +1 -1
  81. package/dist/ManagedRuntime.js +18 -21
  82. package/dist/ManagedRuntime.js.map +1 -1
  83. package/dist/Metric.d.ts +19 -19
  84. package/dist/Metric.d.ts.map +1 -1
  85. package/dist/Metric.js +21 -21
  86. package/dist/Metric.js.map +1 -1
  87. package/dist/Path.d.ts +2 -2
  88. package/dist/Path.d.ts.map +1 -1
  89. package/dist/Path.js +2 -2
  90. package/dist/Path.js.map +1 -1
  91. package/dist/Pool.d.ts.map +1 -1
  92. package/dist/Pool.js +4 -4
  93. package/dist/Pool.js.map +1 -1
  94. package/dist/PubSub.d.ts.map +1 -1
  95. package/dist/PubSub.js +3 -3
  96. package/dist/PubSub.js.map +1 -1
  97. package/dist/Random.d.ts +2 -2
  98. package/dist/Random.d.ts.map +1 -1
  99. package/dist/Random.js +0 -23
  100. package/dist/Random.js.map +1 -1
  101. package/dist/RcMap.d.ts +2 -2
  102. package/dist/RcMap.d.ts.map +1 -1
  103. package/dist/RcMap.js +12 -12
  104. package/dist/RcMap.js.map +1 -1
  105. package/dist/Redactable.d.ts +139 -62
  106. package/dist/Redactable.d.ts.map +1 -1
  107. package/dist/Redactable.js +59 -55
  108. package/dist/Redactable.js.map +1 -1
  109. package/dist/References.d.ts +26 -14
  110. package/dist/References.d.ts.map +1 -1
  111. package/dist/References.js +0 -12
  112. package/dist/References.js.map +1 -1
  113. package/dist/Request.d.ts +5 -5
  114. package/dist/Request.d.ts.map +1 -1
  115. package/dist/Request.js.map +1 -1
  116. package/dist/RequestResolver.d.ts.map +1 -1
  117. package/dist/RequestResolver.js +6 -7
  118. package/dist/RequestResolver.js.map +1 -1
  119. package/dist/Resource.d.ts +0 -3
  120. package/dist/Resource.d.ts.map +1 -1
  121. package/dist/Resource.js +3 -3
  122. package/dist/Resource.js.map +1 -1
  123. package/dist/Schedule.d.ts +2 -2
  124. package/dist/Schedule.d.ts.map +1 -1
  125. package/dist/Schedule.js +2 -2
  126. package/dist/Schedule.js.map +1 -1
  127. package/dist/Scheduler.d.ts +4 -4
  128. package/dist/Scheduler.d.ts.map +1 -1
  129. package/dist/Scheduler.js +7 -4
  130. package/dist/Scheduler.js.map +1 -1
  131. package/dist/Schema.d.ts +531 -214
  132. package/dist/Schema.d.ts.map +1 -1
  133. package/dist/Schema.js +304 -103
  134. package/dist/Schema.js.map +1 -1
  135. package/dist/SchemaAST.d.ts.map +1 -1
  136. package/dist/SchemaAST.js +5 -15
  137. package/dist/SchemaAST.js.map +1 -1
  138. package/dist/SchemaGetter.d.ts +49 -5
  139. package/dist/SchemaGetter.d.ts.map +1 -1
  140. package/dist/SchemaGetter.js +64 -5
  141. package/dist/SchemaGetter.js.map +1 -1
  142. package/dist/SchemaTransformation.d.ts +145 -0
  143. package/dist/SchemaTransformation.d.ts.map +1 -1
  144. package/dist/SchemaTransformation.js +146 -0
  145. package/dist/SchemaTransformation.js.map +1 -1
  146. package/dist/Scope.d.ts +2 -2
  147. package/dist/Scope.d.ts.map +1 -1
  148. package/dist/Scope.js.map +1 -1
  149. package/dist/ScopedCache.d.ts.map +1 -1
  150. package/dist/ScopedCache.js +4 -4
  151. package/dist/ScopedCache.js.map +1 -1
  152. package/dist/Semaphore.d.ts +1 -1
  153. package/dist/Semaphore.d.ts.map +1 -1
  154. package/dist/Semaphore.js +1 -3
  155. package/dist/Semaphore.js.map +1 -1
  156. package/dist/Sink.d.ts +6 -6
  157. package/dist/Sink.d.ts.map +1 -1
  158. package/dist/Sink.js +1 -1
  159. package/dist/Sink.js.map +1 -1
  160. package/dist/Stdio.d.ts +2 -2
  161. package/dist/Stdio.d.ts.map +1 -1
  162. package/dist/Stdio.js +2 -2
  163. package/dist/Stdio.js.map +1 -1
  164. package/dist/Stream.d.ts +187 -117
  165. package/dist/Stream.d.ts.map +1 -1
  166. package/dist/Stream.js +133 -57
  167. package/dist/Stream.js.map +1 -1
  168. package/dist/Terminal.d.ts +3 -3
  169. package/dist/Terminal.d.ts.map +1 -1
  170. package/dist/Terminal.js +2 -2
  171. package/dist/Terminal.js.map +1 -1
  172. package/dist/Tracer.d.ts +16 -16
  173. package/dist/Tracer.d.ts.map +1 -1
  174. package/dist/Tracer.js +11 -8
  175. package/dist/Tracer.js.map +1 -1
  176. package/dist/Unify.d.ts +8 -2
  177. package/dist/Unify.d.ts.map +1 -1
  178. package/dist/Unify.js.map +1 -1
  179. package/dist/index.d.ts +81 -15
  180. package/dist/index.d.ts.map +1 -1
  181. package/dist/index.js +81 -15
  182. package/dist/index.js.map +1 -1
  183. package/dist/internal/core.js.map +1 -1
  184. package/dist/internal/effect.js +74 -74
  185. package/dist/internal/effect.js.map +1 -1
  186. package/dist/internal/layer.js +3 -3
  187. package/dist/internal/layer.js.map +1 -1
  188. package/dist/internal/random.js +2 -2
  189. package/dist/internal/random.js.map +1 -1
  190. package/dist/internal/rcRef.js +9 -9
  191. package/dist/internal/rcRef.js.map +1 -1
  192. package/dist/internal/references.js +13 -13
  193. package/dist/internal/references.js.map +1 -1
  194. package/dist/internal/request.js +6 -6
  195. package/dist/internal/request.js.map +1 -1
  196. package/dist/internal/schedule.js +1 -1
  197. package/dist/internal/schedule.js.map +1 -1
  198. package/dist/internal/schema/representation.js +11 -1
  199. package/dist/internal/schema/representation.js.map +1 -1
  200. package/dist/internal/schema/schema.d.ts +10 -1
  201. package/dist/internal/schema/schema.d.ts.map +1 -1
  202. package/dist/internal/schema/schema.js +21 -1
  203. package/dist/internal/schema/schema.js.map +1 -1
  204. package/dist/testing/TestSchema.d.ts +3 -3
  205. package/dist/testing/TestSchema.d.ts.map +1 -1
  206. package/dist/testing/TestSchema.js.map +1 -1
  207. package/dist/unstable/ai/AiError.d.ts +19 -19
  208. package/dist/unstable/ai/AiError.d.ts.map +1 -1
  209. package/dist/unstable/ai/AiError.js +2 -1
  210. package/dist/unstable/ai/AiError.js.map +1 -1
  211. package/dist/unstable/ai/Chat.d.ts +4 -4
  212. package/dist/unstable/ai/Chat.d.ts.map +1 -1
  213. package/dist/unstable/ai/Chat.js +3 -3
  214. package/dist/unstable/ai/Chat.js.map +1 -1
  215. package/dist/unstable/ai/EmbeddingModel.d.ts +6 -6
  216. package/dist/unstable/ai/EmbeddingModel.d.ts.map +1 -1
  217. package/dist/unstable/ai/EmbeddingModel.js +3 -3
  218. package/dist/unstable/ai/EmbeddingModel.js.map +1 -1
  219. package/dist/unstable/ai/IdGenerator.d.ts +2 -2
  220. package/dist/unstable/ai/IdGenerator.d.ts.map +1 -1
  221. package/dist/unstable/ai/IdGenerator.js +2 -2
  222. package/dist/unstable/ai/IdGenerator.js.map +1 -1
  223. package/dist/unstable/ai/LanguageModel.d.ts +2 -2
  224. package/dist/unstable/ai/LanguageModel.d.ts.map +1 -1
  225. package/dist/unstable/ai/LanguageModel.js +2 -2
  226. package/dist/unstable/ai/LanguageModel.js.map +1 -1
  227. package/dist/unstable/ai/McpSchema.d.ts +54 -54
  228. package/dist/unstable/ai/McpSchema.d.ts.map +1 -1
  229. package/dist/unstable/ai/McpSchema.js +15 -8
  230. package/dist/unstable/ai/McpSchema.js.map +1 -1
  231. package/dist/unstable/ai/McpServer.d.ts +22 -22
  232. package/dist/unstable/ai/McpServer.d.ts.map +1 -1
  233. package/dist/unstable/ai/McpServer.js +49 -46
  234. package/dist/unstable/ai/McpServer.js.map +1 -1
  235. package/dist/unstable/ai/Model.d.ts +3 -3
  236. package/dist/unstable/ai/Model.d.ts.map +1 -1
  237. package/dist/unstable/ai/Model.js +5 -5
  238. package/dist/unstable/ai/Model.js.map +1 -1
  239. package/dist/unstable/ai/Prompt.d.ts.map +1 -1
  240. package/dist/unstable/ai/Prompt.js +6 -9
  241. package/dist/unstable/ai/Prompt.js.map +1 -1
  242. package/dist/unstable/ai/Response.d.ts +1 -1
  243. package/dist/unstable/ai/Response.d.ts.map +1 -1
  244. package/dist/unstable/ai/Response.js +6 -7
  245. package/dist/unstable/ai/Response.js.map +1 -1
  246. package/dist/unstable/ai/ResponseIdTracker.d.ts +2 -2
  247. package/dist/unstable/ai/ResponseIdTracker.d.ts.map +1 -1
  248. package/dist/unstable/ai/ResponseIdTracker.js +2 -2
  249. package/dist/unstable/ai/ResponseIdTracker.js.map +1 -1
  250. package/dist/unstable/ai/Telemetry.d.ts +35 -2
  251. package/dist/unstable/ai/Telemetry.d.ts.map +1 -1
  252. package/dist/unstable/ai/Telemetry.js +2 -2
  253. package/dist/unstable/ai/Telemetry.js.map +1 -1
  254. package/dist/unstable/ai/Tokenizer.d.ts +2 -2
  255. package/dist/unstable/ai/Tokenizer.d.ts.map +1 -1
  256. package/dist/unstable/ai/Tokenizer.js +2 -2
  257. package/dist/unstable/ai/Tokenizer.js.map +1 -1
  258. package/dist/unstable/ai/Tool.d.ts +16 -16
  259. package/dist/unstable/ai/Tool.d.ts.map +1 -1
  260. package/dist/unstable/ai/Tool.js +41 -13
  261. package/dist/unstable/ai/Tool.js.map +1 -1
  262. package/dist/unstable/ai/Toolkit.d.ts +3 -3
  263. package/dist/unstable/ai/Toolkit.d.ts.map +1 -1
  264. package/dist/unstable/ai/Toolkit.js +10 -10
  265. package/dist/unstable/ai/Toolkit.js.map +1 -1
  266. package/dist/unstable/cli/Argument.d.ts +2 -3
  267. package/dist/unstable/cli/Argument.d.ts.map +1 -1
  268. package/dist/unstable/cli/Argument.js.map +1 -1
  269. package/dist/unstable/cli/CliError.d.ts +29 -8
  270. package/dist/unstable/cli/CliError.d.ts.map +1 -1
  271. package/dist/unstable/cli/CliError.js +8 -1
  272. package/dist/unstable/cli/CliError.js.map +1 -1
  273. package/dist/unstable/cli/CliOutput.d.ts +2 -2
  274. package/dist/unstable/cli/CliOutput.d.ts.map +1 -1
  275. package/dist/unstable/cli/CliOutput.js +2 -2
  276. package/dist/unstable/cli/CliOutput.js.map +1 -1
  277. package/dist/unstable/cli/Command.d.ts +14 -14
  278. package/dist/unstable/cli/Command.d.ts.map +1 -1
  279. package/dist/unstable/cli/Command.js +11 -10
  280. package/dist/unstable/cli/Command.js.map +1 -1
  281. package/dist/unstable/cli/Flag.d.ts +2 -3
  282. package/dist/unstable/cli/Flag.d.ts.map +1 -1
  283. package/dist/unstable/cli/Flag.js.map +1 -1
  284. package/dist/unstable/cli/GlobalFlag.d.ts +2 -2
  285. package/dist/unstable/cli/GlobalFlag.d.ts.map +1 -1
  286. package/dist/unstable/cli/GlobalFlag.js +2 -2
  287. package/dist/unstable/cli/GlobalFlag.js.map +1 -1
  288. package/dist/unstable/cli/HelpDoc.d.ts +8 -8
  289. package/dist/unstable/cli/HelpDoc.d.ts.map +1 -1
  290. package/dist/unstable/cli/Param.d.ts +30 -2
  291. package/dist/unstable/cli/Param.d.ts.map +1 -1
  292. package/dist/unstable/cli/Param.js +17 -7
  293. package/dist/unstable/cli/Param.js.map +1 -1
  294. package/dist/unstable/cli/Prompt.js +8 -2
  295. package/dist/unstable/cli/Prompt.js.map +1 -1
  296. package/dist/unstable/cli/internal/command.d.ts +5 -5
  297. package/dist/unstable/cli/internal/command.d.ts.map +1 -1
  298. package/dist/unstable/cli/internal/command.js +3 -3
  299. package/dist/unstable/cli/internal/command.js.map +1 -1
  300. package/dist/unstable/cli/internal/parser.js +94 -15
  301. package/dist/unstable/cli/internal/parser.js.map +1 -1
  302. package/dist/unstable/cluster/ClusterError.d.ts +7 -7
  303. package/dist/unstable/cluster/ClusterSchema.d.ts +12 -9
  304. package/dist/unstable/cluster/ClusterSchema.d.ts.map +1 -1
  305. package/dist/unstable/cluster/ClusterSchema.js +9 -9
  306. package/dist/unstable/cluster/ClusterSchema.js.map +1 -1
  307. package/dist/unstable/cluster/ClusterWorkflowEngine.d.ts.map +1 -1
  308. package/dist/unstable/cluster/ClusterWorkflowEngine.js +13 -14
  309. package/dist/unstable/cluster/ClusterWorkflowEngine.js.map +1 -1
  310. package/dist/unstable/cluster/Entity.d.ts +8 -8
  311. package/dist/unstable/cluster/Entity.d.ts.map +1 -1
  312. package/dist/unstable/cluster/Entity.js +12 -12
  313. package/dist/unstable/cluster/Entity.js.map +1 -1
  314. package/dist/unstable/cluster/EntityAddress.d.ts +2 -2
  315. package/dist/unstable/cluster/EntityProxy.js +3 -3
  316. package/dist/unstable/cluster/EntityProxy.js.map +1 -1
  317. package/dist/unstable/cluster/EntityProxyServer.d.ts.map +1 -1
  318. package/dist/unstable/cluster/EntityProxyServer.js +4 -4
  319. package/dist/unstable/cluster/EntityProxyServer.js.map +1 -1
  320. package/dist/unstable/cluster/EntityResource.d.ts +2 -2
  321. package/dist/unstable/cluster/EntityResource.d.ts.map +1 -1
  322. package/dist/unstable/cluster/EntityResource.js +2 -2
  323. package/dist/unstable/cluster/EntityResource.js.map +1 -1
  324. package/dist/unstable/cluster/Envelope.d.ts +3 -3
  325. package/dist/unstable/cluster/HttpRunner.js +2 -2
  326. package/dist/unstable/cluster/HttpRunner.js.map +1 -1
  327. package/dist/unstable/cluster/K8sHttpClient.d.ts +4 -4
  328. package/dist/unstable/cluster/K8sHttpClient.d.ts.map +1 -1
  329. package/dist/unstable/cluster/K8sHttpClient.js +2 -2
  330. package/dist/unstable/cluster/K8sHttpClient.js.map +1 -1
  331. package/dist/unstable/cluster/Message.d.ts +7 -4
  332. package/dist/unstable/cluster/Message.d.ts.map +1 -1
  333. package/dist/unstable/cluster/Message.js +5 -5
  334. package/dist/unstable/cluster/Message.js.map +1 -1
  335. package/dist/unstable/cluster/MessageStorage.d.ts +14 -14
  336. package/dist/unstable/cluster/MessageStorage.d.ts.map +1 -1
  337. package/dist/unstable/cluster/MessageStorage.js +8 -8
  338. package/dist/unstable/cluster/MessageStorage.js.map +1 -1
  339. package/dist/unstable/cluster/Reply.d.ts +2 -2
  340. package/dist/unstable/cluster/Reply.d.ts.map +1 -1
  341. package/dist/unstable/cluster/Reply.js +5 -5
  342. package/dist/unstable/cluster/Reply.js.map +1 -1
  343. package/dist/unstable/cluster/Runner.d.ts +1 -1
  344. package/dist/unstable/cluster/RunnerAddress.d.ts +1 -1
  345. package/dist/unstable/cluster/RunnerHealth.d.ts +2 -2
  346. package/dist/unstable/cluster/RunnerHealth.d.ts.map +1 -1
  347. package/dist/unstable/cluster/RunnerHealth.js +2 -2
  348. package/dist/unstable/cluster/RunnerHealth.js.map +1 -1
  349. package/dist/unstable/cluster/RunnerServer.js +1 -1
  350. package/dist/unstable/cluster/RunnerServer.js.map +1 -1
  351. package/dist/unstable/cluster/RunnerStorage.d.ts +12 -12
  352. package/dist/unstable/cluster/RunnerStorage.d.ts.map +1 -1
  353. package/dist/unstable/cluster/RunnerStorage.js +3 -3
  354. package/dist/unstable/cluster/RunnerStorage.js.map +1 -1
  355. package/dist/unstable/cluster/Runners.d.ts +3 -3
  356. package/dist/unstable/cluster/Runners.d.ts.map +1 -1
  357. package/dist/unstable/cluster/Runners.js +7 -7
  358. package/dist/unstable/cluster/Runners.js.map +1 -1
  359. package/dist/unstable/cluster/ShardId.d.ts +35 -49
  360. package/dist/unstable/cluster/ShardId.d.ts.map +1 -1
  361. package/dist/unstable/cluster/ShardId.js +65 -67
  362. package/dist/unstable/cluster/ShardId.js.map +1 -1
  363. package/dist/unstable/cluster/Sharding.d.ts +2 -2
  364. package/dist/unstable/cluster/Sharding.d.ts.map +1 -1
  365. package/dist/unstable/cluster/Sharding.js +21 -21
  366. package/dist/unstable/cluster/Sharding.js.map +1 -1
  367. package/dist/unstable/cluster/ShardingConfig.d.ts +2 -2
  368. package/dist/unstable/cluster/ShardingConfig.d.ts.map +1 -1
  369. package/dist/unstable/cluster/ShardingConfig.js +5 -5
  370. package/dist/unstable/cluster/ShardingConfig.js.map +1 -1
  371. package/dist/unstable/cluster/SingletonAddress.d.ts +2 -2
  372. package/dist/unstable/cluster/Snowflake.d.ts +2 -2
  373. package/dist/unstable/cluster/Snowflake.d.ts.map +1 -1
  374. package/dist/unstable/cluster/Snowflake.js +2 -2
  375. package/dist/unstable/cluster/Snowflake.js.map +1 -1
  376. package/dist/unstable/cluster/SqlMessageStorage.js +1 -1
  377. package/dist/unstable/cluster/SqlMessageStorage.js.map +1 -1
  378. package/dist/unstable/cluster/internal/entityManager.js +15 -14
  379. package/dist/unstable/cluster/internal/entityManager.js.map +1 -1
  380. package/dist/unstable/cluster/internal/entityReaper.js +2 -2
  381. package/dist/unstable/cluster/internal/entityReaper.js.map +1 -1
  382. package/dist/unstable/cluster/internal/resourceMap.js +3 -3
  383. package/dist/unstable/cluster/internal/resourceMap.js.map +1 -1
  384. package/dist/unstable/devtools/DevToolsClient.d.ts +2 -2
  385. package/dist/unstable/devtools/DevToolsClient.d.ts.map +1 -1
  386. package/dist/unstable/devtools/DevToolsClient.js +5 -5
  387. package/dist/unstable/devtools/DevToolsClient.js.map +1 -1
  388. package/dist/unstable/eventlog/Event.d.ts +0 -6
  389. package/dist/unstable/eventlog/Event.d.ts.map +1 -1
  390. package/dist/unstable/eventlog/Event.js +0 -5
  391. package/dist/unstable/eventlog/Event.js.map +1 -1
  392. package/dist/unstable/eventlog/EventGroup.d.ts +0 -2
  393. package/dist/unstable/eventlog/EventGroup.d.ts.map +1 -1
  394. package/dist/unstable/eventlog/EventGroup.js +0 -2
  395. package/dist/unstable/eventlog/EventGroup.js.map +1 -1
  396. package/dist/unstable/eventlog/EventJournal.d.ts +26 -9
  397. package/dist/unstable/eventlog/EventJournal.d.ts.map +1 -1
  398. package/dist/unstable/eventlog/EventJournal.js +128 -69
  399. package/dist/unstable/eventlog/EventJournal.js.map +1 -1
  400. package/dist/unstable/eventlog/EventLog.d.ts +91 -37
  401. package/dist/unstable/eventlog/EventLog.d.ts.map +1 -1
  402. package/dist/unstable/eventlog/EventLog.js +223 -149
  403. package/dist/unstable/eventlog/EventLog.js.map +1 -1
  404. package/dist/unstable/eventlog/EventLogEncryption.d.ts +11 -9
  405. package/dist/unstable/eventlog/EventLogEncryption.d.ts.map +1 -1
  406. package/dist/unstable/eventlog/EventLogEncryption.js +15 -17
  407. package/dist/unstable/eventlog/EventLogEncryption.js.map +1 -1
  408. package/dist/unstable/eventlog/EventLogMessage.d.ts +228 -0
  409. package/dist/unstable/eventlog/EventLogMessage.d.ts.map +1 -0
  410. package/dist/unstable/eventlog/EventLogMessage.js +214 -0
  411. package/dist/unstable/eventlog/EventLogMessage.js.map +1 -0
  412. package/dist/unstable/eventlog/EventLogRemote.d.ts +111 -193
  413. package/dist/unstable/eventlog/EventLogRemote.d.ts.map +1 -1
  414. package/dist/unstable/eventlog/EventLogRemote.js +167 -322
  415. package/dist/unstable/eventlog/EventLogRemote.js.map +1 -1
  416. package/dist/unstable/eventlog/EventLogServer.d.ts +26 -48
  417. package/dist/unstable/eventlog/EventLogServer.d.ts.map +1 -1
  418. package/dist/unstable/eventlog/EventLogServer.js +128 -199
  419. package/dist/unstable/eventlog/EventLogServer.js.map +1 -1
  420. package/dist/unstable/eventlog/EventLogServerEncrypted.d.ts +60 -0
  421. package/dist/unstable/eventlog/EventLogServerEncrypted.d.ts.map +1 -0
  422. package/dist/unstable/eventlog/EventLogServerEncrypted.js +166 -0
  423. package/dist/unstable/eventlog/EventLogServerEncrypted.js.map +1 -0
  424. package/dist/unstable/eventlog/EventLogServerUnencrypted.d.ts +183 -0
  425. package/dist/unstable/eventlog/EventLogServerUnencrypted.d.ts.map +1 -0
  426. package/dist/unstable/eventlog/EventLogServerUnencrypted.js +461 -0
  427. package/dist/unstable/eventlog/EventLogServerUnencrypted.js.map +1 -0
  428. package/dist/unstable/eventlog/EventLogSessionAuth.d.ts +117 -0
  429. package/dist/unstable/eventlog/EventLogSessionAuth.d.ts.map +1 -0
  430. package/dist/unstable/eventlog/EventLogSessionAuth.js +284 -0
  431. package/dist/unstable/eventlog/EventLogSessionAuth.js.map +1 -0
  432. package/dist/unstable/eventlog/{SqlEventLogJournal.d.ts → SqlEventJournal.d.ts} +2 -2
  433. package/dist/unstable/eventlog/SqlEventJournal.d.ts.map +1 -0
  434. package/dist/unstable/eventlog/{SqlEventLogJournal.js → SqlEventJournal.js} +20 -14
  435. package/dist/unstable/eventlog/SqlEventJournal.js.map +1 -0
  436. package/dist/unstable/eventlog/{SqlEventLogServer.d.ts → SqlEventLogServerEncrypted.d.ts} +5 -5
  437. package/dist/unstable/eventlog/SqlEventLogServerEncrypted.d.ts.map +1 -0
  438. package/dist/unstable/eventlog/{SqlEventLogServer.js → SqlEventLogServerEncrypted.js} +65 -24
  439. package/dist/unstable/eventlog/SqlEventLogServerEncrypted.js.map +1 -0
  440. package/dist/unstable/eventlog/SqlEventLogServerUnencrypted.d.ts +25 -0
  441. package/dist/unstable/eventlog/SqlEventLogServerUnencrypted.d.ts.map +1 -0
  442. package/dist/unstable/eventlog/SqlEventLogServerUnencrypted.js +354 -0
  443. package/dist/unstable/eventlog/SqlEventLogServerUnencrypted.js.map +1 -0
  444. package/dist/unstable/eventlog/index.d.ts +22 -2
  445. package/dist/unstable/eventlog/index.d.ts.map +1 -1
  446. package/dist/unstable/eventlog/index.js +22 -2
  447. package/dist/unstable/eventlog/index.js.map +1 -1
  448. package/dist/unstable/eventlog/internal/identityRootSecretDerivation.d.ts +2 -0
  449. package/dist/unstable/eventlog/internal/identityRootSecretDerivation.d.ts.map +1 -0
  450. package/dist/unstable/eventlog/internal/identityRootSecretDerivation.js +89 -0
  451. package/dist/unstable/eventlog/internal/identityRootSecretDerivation.js.map +1 -0
  452. package/dist/unstable/http/Etag.d.ts +2 -2
  453. package/dist/unstable/http/Etag.d.ts.map +1 -1
  454. package/dist/unstable/http/Etag.js +2 -2
  455. package/dist/unstable/http/Etag.js.map +1 -1
  456. package/dist/unstable/http/FetchHttpClient.d.ts +6 -3
  457. package/dist/unstable/http/FetchHttpClient.d.ts.map +1 -1
  458. package/dist/unstable/http/FetchHttpClient.js +5 -5
  459. package/dist/unstable/http/FetchHttpClient.js.map +1 -1
  460. package/dist/unstable/http/Headers.d.ts +5 -2
  461. package/dist/unstable/http/Headers.d.ts.map +1 -1
  462. package/dist/unstable/http/Headers.js +3 -3
  463. package/dist/unstable/http/Headers.js.map +1 -1
  464. package/dist/unstable/http/HttpClient.d.ts +8 -6
  465. package/dist/unstable/http/HttpClient.d.ts.map +1 -1
  466. package/dist/unstable/http/HttpClient.js +6 -6
  467. package/dist/unstable/http/HttpClient.js.map +1 -1
  468. package/dist/unstable/http/HttpClientError.d.ts +1 -1
  469. package/dist/unstable/http/HttpClientRequest.d.ts +2 -2
  470. package/dist/unstable/http/HttpClientRequest.d.ts.map +1 -1
  471. package/dist/unstable/http/HttpClientRequest.js +4 -4
  472. package/dist/unstable/http/HttpClientRequest.js.map +1 -1
  473. package/dist/unstable/http/HttpEffect.d.ts +6 -6
  474. package/dist/unstable/http/HttpEffect.d.ts.map +1 -1
  475. package/dist/unstable/http/HttpEffect.js +24 -24
  476. package/dist/unstable/http/HttpEffect.js.map +1 -1
  477. package/dist/unstable/http/HttpIncomingMessage.d.ts +2 -2
  478. package/dist/unstable/http/HttpIncomingMessage.d.ts.map +1 -1
  479. package/dist/unstable/http/HttpIncomingMessage.js +2 -2
  480. package/dist/unstable/http/HttpIncomingMessage.js.map +1 -1
  481. package/dist/unstable/http/HttpMiddleware.d.ts +3 -3
  482. package/dist/unstable/http/HttpMiddleware.d.ts.map +1 -1
  483. package/dist/unstable/http/HttpMiddleware.js +26 -14
  484. package/dist/unstable/http/HttpMiddleware.js.map +1 -1
  485. package/dist/unstable/http/HttpPlatform.d.ts +2 -2
  486. package/dist/unstable/http/HttpPlatform.d.ts.map +1 -1
  487. package/dist/unstable/http/HttpPlatform.js +2 -2
  488. package/dist/unstable/http/HttpPlatform.js.map +1 -1
  489. package/dist/unstable/http/HttpRouter.d.ts +7 -7
  490. package/dist/unstable/http/HttpRouter.d.ts.map +1 -1
  491. package/dist/unstable/http/HttpRouter.js +29 -29
  492. package/dist/unstable/http/HttpRouter.js.map +1 -1
  493. package/dist/unstable/http/HttpServer.d.ts +2 -2
  494. package/dist/unstable/http/HttpServer.d.ts.map +1 -1
  495. package/dist/unstable/http/HttpServer.js +2 -2
  496. package/dist/unstable/http/HttpServer.js.map +1 -1
  497. package/dist/unstable/http/HttpServerError.d.ts +3 -3
  498. package/dist/unstable/http/HttpServerError.d.ts.map +1 -1
  499. package/dist/unstable/http/HttpServerError.js +3 -3
  500. package/dist/unstable/http/HttpServerError.js.map +1 -1
  501. package/dist/unstable/http/HttpServerRequest.d.ts +4 -4
  502. package/dist/unstable/http/HttpServerRequest.d.ts.map +1 -1
  503. package/dist/unstable/http/HttpServerRequest.js +6 -6
  504. package/dist/unstable/http/HttpServerRequest.js.map +1 -1
  505. package/dist/unstable/http/HttpServerResponse.d.ts +2 -2
  506. package/dist/unstable/http/HttpServerResponse.d.ts.map +1 -1
  507. package/dist/unstable/http/HttpServerResponse.js +6 -6
  508. package/dist/unstable/http/HttpServerResponse.js.map +1 -1
  509. package/dist/unstable/http/Multipart.d.ts +6 -6
  510. package/dist/unstable/http/Multipart.d.ts.map +1 -1
  511. package/dist/unstable/http/Multipart.js +7 -7
  512. package/dist/unstable/http/Multipart.js.map +1 -1
  513. package/dist/unstable/httpapi/HttpApi.d.ts +9 -9
  514. package/dist/unstable/httpapi/HttpApi.d.ts.map +1 -1
  515. package/dist/unstable/httpapi/HttpApi.js +8 -8
  516. package/dist/unstable/httpapi/HttpApi.js.map +1 -1
  517. package/dist/unstable/httpapi/HttpApiBuilder.d.ts +0 -3
  518. package/dist/unstable/httpapi/HttpApiBuilder.d.ts.map +1 -1
  519. package/dist/unstable/httpapi/HttpApiBuilder.js +20 -20
  520. package/dist/unstable/httpapi/HttpApiBuilder.js.map +1 -1
  521. package/dist/unstable/httpapi/HttpApiClient.d.ts.map +1 -1
  522. package/dist/unstable/httpapi/HttpApiClient.js +1 -1
  523. package/dist/unstable/httpapi/HttpApiClient.js.map +1 -1
  524. package/dist/unstable/httpapi/HttpApiEndpoint.d.ts +7 -7
  525. package/dist/unstable/httpapi/HttpApiEndpoint.d.ts.map +1 -1
  526. package/dist/unstable/httpapi/HttpApiEndpoint.js +4 -4
  527. package/dist/unstable/httpapi/HttpApiEndpoint.js.map +1 -1
  528. package/dist/unstable/httpapi/HttpApiError.d.ts +13 -13
  529. package/dist/unstable/httpapi/HttpApiError.d.ts.map +1 -1
  530. package/dist/unstable/httpapi/HttpApiGroup.d.ts +8 -8
  531. package/dist/unstable/httpapi/HttpApiGroup.d.ts.map +1 -1
  532. package/dist/unstable/httpapi/HttpApiGroup.js +4 -4
  533. package/dist/unstable/httpapi/HttpApiGroup.js.map +1 -1
  534. package/dist/unstable/httpapi/HttpApiMiddleware.d.ts +6 -6
  535. package/dist/unstable/httpapi/HttpApiMiddleware.d.ts.map +1 -1
  536. package/dist/unstable/httpapi/HttpApiMiddleware.js +5 -5
  537. package/dist/unstable/httpapi/HttpApiMiddleware.js.map +1 -1
  538. package/dist/unstable/httpapi/HttpApiSecurity.d.ts +9 -6
  539. package/dist/unstable/httpapi/HttpApiSecurity.d.ts.map +1 -1
  540. package/dist/unstable/httpapi/HttpApiSecurity.js +6 -6
  541. package/dist/unstable/httpapi/HttpApiSecurity.js.map +1 -1
  542. package/dist/unstable/httpapi/OpenApi.d.ts +15 -15
  543. package/dist/unstable/httpapi/OpenApi.d.ts.map +1 -1
  544. package/dist/unstable/httpapi/OpenApi.js +23 -23
  545. package/dist/unstable/httpapi/OpenApi.js.map +1 -1
  546. package/dist/unstable/observability/OtlpExporter.d.ts.map +1 -1
  547. package/dist/unstable/observability/OtlpExporter.js +5 -5
  548. package/dist/unstable/observability/OtlpExporter.js.map +1 -1
  549. package/dist/unstable/observability/OtlpMetrics.js +1 -1
  550. package/dist/unstable/observability/OtlpMetrics.js.map +1 -1
  551. package/dist/unstable/observability/OtlpSerialization.d.ts +2 -2
  552. package/dist/unstable/observability/OtlpSerialization.d.ts.map +1 -1
  553. package/dist/unstable/observability/OtlpSerialization.js +2 -2
  554. package/dist/unstable/observability/OtlpSerialization.js.map +1 -1
  555. package/dist/unstable/observability/OtlpTracer.d.ts.map +1 -1
  556. package/dist/unstable/observability/OtlpTracer.js.map +1 -1
  557. package/dist/unstable/observability/PrometheusMetrics.d.ts +3 -3
  558. package/dist/unstable/observability/PrometheusMetrics.d.ts.map +1 -1
  559. package/dist/unstable/observability/PrometheusMetrics.js +4 -33
  560. package/dist/unstable/observability/PrometheusMetrics.js.map +1 -1
  561. package/dist/unstable/persistence/KeyValueStore.d.ts +23 -2
  562. package/dist/unstable/persistence/KeyValueStore.d.ts.map +1 -1
  563. package/dist/unstable/persistence/KeyValueStore.js +144 -2
  564. package/dist/unstable/persistence/KeyValueStore.js.map +1 -1
  565. package/dist/unstable/persistence/PersistedCache.d.ts +1 -2
  566. package/dist/unstable/persistence/PersistedCache.d.ts.map +1 -1
  567. package/dist/unstable/persistence/PersistedCache.js +10 -11
  568. package/dist/unstable/persistence/PersistedCache.js.map +1 -1
  569. package/dist/unstable/persistence/PersistedQueue.d.ts +4 -4
  570. package/dist/unstable/persistence/PersistedQueue.d.ts.map +1 -1
  571. package/dist/unstable/persistence/PersistedQueue.js +3 -3
  572. package/dist/unstable/persistence/PersistedQueue.js.map +1 -1
  573. package/dist/unstable/persistence/Persistence.d.ts +4 -4
  574. package/dist/unstable/persistence/Persistence.d.ts.map +1 -1
  575. package/dist/unstable/persistence/Persistence.js +3 -3
  576. package/dist/unstable/persistence/Persistence.js.map +1 -1
  577. package/dist/unstable/persistence/RateLimiter.d.ts +6 -6
  578. package/dist/unstable/persistence/RateLimiter.d.ts.map +1 -1
  579. package/dist/unstable/persistence/RateLimiter.js +3 -3
  580. package/dist/unstable/persistence/RateLimiter.js.map +1 -1
  581. package/dist/unstable/persistence/Redis.d.ts +3 -3
  582. package/dist/unstable/persistence/Redis.d.ts.map +1 -1
  583. package/dist/unstable/persistence/Redis.js +2 -2
  584. package/dist/unstable/persistence/Redis.js.map +1 -1
  585. package/dist/unstable/process/ChildProcessSpawner.d.ts +45 -2
  586. package/dist/unstable/process/ChildProcessSpawner.d.ts.map +1 -1
  587. package/dist/unstable/process/ChildProcessSpawner.js +2 -2
  588. package/dist/unstable/process/ChildProcessSpawner.js.map +1 -1
  589. package/dist/unstable/reactivity/Atom.d.ts +36 -36
  590. package/dist/unstable/reactivity/Atom.d.ts.map +1 -1
  591. package/dist/unstable/reactivity/Atom.js +9 -9
  592. package/dist/unstable/reactivity/Atom.js.map +1 -1
  593. package/dist/unstable/reactivity/AtomHttpApi.d.ts +4 -5
  594. package/dist/unstable/reactivity/AtomHttpApi.d.ts.map +1 -1
  595. package/dist/unstable/reactivity/AtomHttpApi.js +4 -4
  596. package/dist/unstable/reactivity/AtomHttpApi.js.map +1 -1
  597. package/dist/unstable/reactivity/AtomRegistry.d.ts +2 -2
  598. package/dist/unstable/reactivity/AtomRegistry.d.ts.map +1 -1
  599. package/dist/unstable/reactivity/AtomRegistry.js +3 -3
  600. package/dist/unstable/reactivity/AtomRegistry.js.map +1 -1
  601. package/dist/unstable/reactivity/AtomRpc.d.ts +4 -5
  602. package/dist/unstable/reactivity/AtomRpc.d.ts.map +1 -1
  603. package/dist/unstable/reactivity/AtomRpc.js +5 -5
  604. package/dist/unstable/reactivity/AtomRpc.js.map +1 -1
  605. package/dist/unstable/reactivity/Reactivity.d.ts +2 -2
  606. package/dist/unstable/reactivity/Reactivity.d.ts.map +1 -1
  607. package/dist/unstable/reactivity/Reactivity.js +6 -6
  608. package/dist/unstable/reactivity/Reactivity.js.map +1 -1
  609. package/dist/unstable/rpc/Rpc.d.ts +35 -14
  610. package/dist/unstable/rpc/Rpc.d.ts.map +1 -1
  611. package/dist/unstable/rpc/Rpc.js +30 -4
  612. package/dist/unstable/rpc/Rpc.js.map +1 -1
  613. package/dist/unstable/rpc/RpcClient.d.ts +21 -21
  614. package/dist/unstable/rpc/RpcClient.d.ts.map +1 -1
  615. package/dist/unstable/rpc/RpcClient.js +73 -40
  616. package/dist/unstable/rpc/RpcClient.js.map +1 -1
  617. package/dist/unstable/rpc/RpcClientError.d.ts +2 -2
  618. package/dist/unstable/rpc/RpcGroup.d.ts +8 -8
  619. package/dist/unstable/rpc/RpcGroup.d.ts.map +1 -1
  620. package/dist/unstable/rpc/RpcGroup.js +20 -20
  621. package/dist/unstable/rpc/RpcGroup.js.map +1 -1
  622. package/dist/unstable/rpc/RpcMiddleware.d.ts +8 -8
  623. package/dist/unstable/rpc/RpcMiddleware.d.ts.map +1 -1
  624. package/dist/unstable/rpc/RpcMiddleware.js +5 -5
  625. package/dist/unstable/rpc/RpcMiddleware.js.map +1 -1
  626. package/dist/unstable/rpc/RpcSchema.d.ts +3 -3
  627. package/dist/unstable/rpc/RpcSchema.d.ts.map +1 -1
  628. package/dist/unstable/rpc/RpcSchema.js +3 -3
  629. package/dist/unstable/rpc/RpcSchema.js.map +1 -1
  630. package/dist/unstable/rpc/RpcSerialization.d.ts +2 -2
  631. package/dist/unstable/rpc/RpcSerialization.d.ts.map +1 -1
  632. package/dist/unstable/rpc/RpcSerialization.js +2 -2
  633. package/dist/unstable/rpc/RpcSerialization.js.map +1 -1
  634. package/dist/unstable/rpc/RpcServer.d.ts +2 -2
  635. package/dist/unstable/rpc/RpcServer.d.ts.map +1 -1
  636. package/dist/unstable/rpc/RpcServer.js +21 -20
  637. package/dist/unstable/rpc/RpcServer.js.map +1 -1
  638. package/dist/unstable/rpc/RpcWorker.d.ts +2 -2
  639. package/dist/unstable/rpc/RpcWorker.d.ts.map +1 -1
  640. package/dist/unstable/rpc/RpcWorker.js +4 -4
  641. package/dist/unstable/rpc/RpcWorker.js.map +1 -1
  642. package/dist/unstable/rpc/Utils.d.ts +6 -3
  643. package/dist/unstable/rpc/Utils.d.ts.map +1 -1
  644. package/dist/unstable/rpc/Utils.js +46 -5
  645. package/dist/unstable/rpc/Utils.js.map +1 -1
  646. package/dist/unstable/schema/Model.d.ts +2 -2
  647. package/dist/unstable/schema/Model.d.ts.map +1 -1
  648. package/dist/unstable/schema/Model.js +2 -4
  649. package/dist/unstable/schema/Model.js.map +1 -1
  650. package/dist/unstable/schema/VariantSchema.d.ts +1 -1
  651. package/dist/unstable/schema/VariantSchema.d.ts.map +1 -1
  652. package/dist/unstable/schema/VariantSchema.js +1 -12
  653. package/dist/unstable/schema/VariantSchema.js.map +1 -1
  654. package/dist/unstable/socket/Socket.d.ts +10 -10
  655. package/dist/unstable/socket/Socket.d.ts.map +1 -1
  656. package/dist/unstable/socket/Socket.js +9 -9
  657. package/dist/unstable/socket/Socket.js.map +1 -1
  658. package/dist/unstable/socket/SocketServer.d.ts +5 -2
  659. package/dist/unstable/socket/SocketServer.d.ts.map +1 -1
  660. package/dist/unstable/socket/SocketServer.js +2 -2
  661. package/dist/unstable/socket/SocketServer.js.map +1 -1
  662. package/dist/unstable/sql/SqlClient.d.ts +5 -5
  663. package/dist/unstable/sql/SqlClient.d.ts.map +1 -1
  664. package/dist/unstable/sql/SqlClient.js +7 -7
  665. package/dist/unstable/sql/SqlClient.js.map +1 -1
  666. package/dist/unstable/sql/SqlConnection.d.ts +2 -2
  667. package/dist/unstable/sql/SqlConnection.d.ts.map +1 -1
  668. package/dist/unstable/sql/SqlConnection.js +5 -2
  669. package/dist/unstable/sql/SqlConnection.js.map +1 -1
  670. package/dist/unstable/sql/SqlError.d.ts +12 -12
  671. package/dist/unstable/sql/SqlModel.d.ts +8 -9
  672. package/dist/unstable/sql/SqlModel.d.ts.map +1 -1
  673. package/dist/unstable/sql/SqlModel.js +9 -35
  674. package/dist/unstable/sql/SqlModel.js.map +1 -1
  675. package/dist/unstable/sql/SqlResolver.js +11 -11
  676. package/dist/unstable/sql/SqlResolver.js.map +1 -1
  677. package/dist/unstable/sql/Statement.d.ts +2 -2
  678. package/dist/unstable/sql/Statement.d.ts.map +1 -1
  679. package/dist/unstable/sql/Statement.js +2 -2
  680. package/dist/unstable/sql/Statement.js.map +1 -1
  681. package/dist/unstable/workers/Transferable.d.ts +3 -3
  682. package/dist/unstable/workers/Transferable.d.ts.map +1 -1
  683. package/dist/unstable/workers/Transferable.js +7 -7
  684. package/dist/unstable/workers/Transferable.js.map +1 -1
  685. package/dist/unstable/workers/Worker.d.ts +3 -3
  686. package/dist/unstable/workers/Worker.d.ts.map +1 -1
  687. package/dist/unstable/workers/Worker.js +6 -3
  688. package/dist/unstable/workers/Worker.js.map +1 -1
  689. package/dist/unstable/workers/WorkerError.d.ts +5 -5
  690. package/dist/unstable/workers/WorkerRunner.d.ts +2 -2
  691. package/dist/unstable/workers/WorkerRunner.d.ts.map +1 -1
  692. package/dist/unstable/workers/WorkerRunner.js +5 -2
  693. package/dist/unstable/workers/WorkerRunner.js.map +1 -1
  694. package/dist/unstable/workflow/Activity.d.ts +7 -7
  695. package/dist/unstable/workflow/Activity.d.ts.map +1 -1
  696. package/dist/unstable/workflow/Activity.js +7 -7
  697. package/dist/unstable/workflow/Activity.js.map +1 -1
  698. package/dist/unstable/workflow/DurableClock.d.ts +0 -3
  699. package/dist/unstable/workflow/DurableClock.d.ts.map +1 -1
  700. package/dist/unstable/workflow/DurableClock.js +3 -3
  701. package/dist/unstable/workflow/DurableClock.js.map +1 -1
  702. package/dist/unstable/workflow/DurableDeferred.d.ts +1 -1
  703. package/dist/unstable/workflow/DurableDeferred.d.ts.map +1 -1
  704. package/dist/unstable/workflow/DurableDeferred.js +7 -7
  705. package/dist/unstable/workflow/DurableDeferred.js.map +1 -1
  706. package/dist/unstable/workflow/Workflow.d.ts +9 -9
  707. package/dist/unstable/workflow/Workflow.d.ts.map +1 -1
  708. package/dist/unstable/workflow/Workflow.js +18 -18
  709. package/dist/unstable/workflow/Workflow.js.map +1 -1
  710. package/dist/unstable/workflow/WorkflowEngine.d.ts +3 -3
  711. package/dist/unstable/workflow/WorkflowEngine.d.ts.map +1 -1
  712. package/dist/unstable/workflow/WorkflowEngine.js +5 -5
  713. package/dist/unstable/workflow/WorkflowEngine.js.map +1 -1
  714. package/dist/unstable/workflow/WorkflowProxyServer.d.ts.map +1 -1
  715. package/dist/unstable/workflow/WorkflowProxyServer.js +4 -4
  716. package/dist/unstable/workflow/WorkflowProxyServer.js.map +1 -1
  717. package/package.json +1 -1
  718. package/src/Cache.ts +18 -46
  719. package/src/Cause.ts +21 -21
  720. package/src/Channel.ts +120 -79
  721. package/src/Clock.ts +2 -2
  722. package/src/Config.ts +2 -2
  723. package/src/ConfigProvider.ts +5 -5
  724. package/src/Console.ts +2 -2
  725. package/src/{ServiceMap.ts → Context.ts} +337 -340
  726. package/src/DateTime.ts +2 -2
  727. package/src/Effect.ts +182 -184
  728. package/src/Equal.ts +17 -0
  729. package/src/ErrorReporter.ts +3 -3
  730. package/src/ExecutionPlan.ts +8 -9
  731. package/src/Fiber.ts +7 -7
  732. package/src/FiberHandle.ts +5 -5
  733. package/src/FiberMap.ts +5 -5
  734. package/src/FiberSet.ts +5 -5
  735. package/src/FileSystem.ts +3 -3
  736. package/src/Hash.ts +2 -2
  737. package/src/Layer.ts +333 -307
  738. package/src/LayerMap.ts +27 -26
  739. package/src/Logger.ts +3 -3
  740. package/src/ManagedRuntime.ts +32 -32
  741. package/src/Metric.ts +58 -58
  742. package/src/Path.ts +2 -2
  743. package/src/Pool.ts +5 -5
  744. package/src/PubSub.ts +3 -3
  745. package/src/Random.ts +2 -2
  746. package/src/RcMap.ts +14 -14
  747. package/src/Redactable.ts +146 -72
  748. package/src/References.ts +14 -14
  749. package/src/Request.ts +5 -5
  750. package/src/RequestResolver.ts +6 -7
  751. package/src/Resource.ts +4 -4
  752. package/src/Schedule.ts +2 -2
  753. package/src/Scheduler.ts +4 -4
  754. package/src/Schema.ts +837 -397
  755. package/src/SchemaAST.ts +5 -14
  756. package/src/SchemaGetter.ts +69 -11
  757. package/src/SchemaTransformation.ts +166 -0
  758. package/src/Scope.ts +2 -2
  759. package/src/ScopedCache.ts +5 -5
  760. package/src/Semaphore.ts +2 -4
  761. package/src/Sink.ts +9 -9
  762. package/src/Stdio.ts +2 -2
  763. package/src/Stream.ts +234 -158
  764. package/src/Terminal.ts +3 -3
  765. package/src/Tracer.ts +17 -17
  766. package/src/Unify.ts +26 -2
  767. package/src/index.ts +82 -16
  768. package/src/internal/core.ts +7 -7
  769. package/src/internal/effect.ts +106 -106
  770. package/src/internal/layer.ts +7 -7
  771. package/src/internal/random.ts +2 -2
  772. package/src/internal/rcRef.ts +10 -10
  773. package/src/internal/references.ts +13 -13
  774. package/src/internal/request.ts +8 -8
  775. package/src/internal/schedule.ts +3 -1
  776. package/src/internal/schema/representation.ts +8 -1
  777. package/src/internal/schema/schema.ts +24 -1
  778. package/src/testing/TestSchema.ts +3 -3
  779. package/src/unstable/ai/AiError.ts +3 -2
  780. package/src/unstable/ai/Chat.ts +3 -3
  781. package/src/unstable/ai/EmbeddingModel.ts +3 -3
  782. package/src/unstable/ai/IdGenerator.ts +2 -2
  783. package/src/unstable/ai/LanguageModel.ts +2 -2
  784. package/src/unstable/ai/McpSchema.ts +11 -9
  785. package/src/unstable/ai/McpServer.ts +68 -66
  786. package/src/unstable/ai/Model.ts +8 -8
  787. package/src/unstable/ai/Prompt.ts +6 -12
  788. package/src/unstable/ai/Response.ts +6 -8
  789. package/src/unstable/ai/ResponseIdTracker.ts +2 -4
  790. package/src/unstable/ai/Telemetry.ts +2 -2
  791. package/src/unstable/ai/Tokenizer.ts +2 -2
  792. package/src/unstable/ai/Tool.ts +25 -25
  793. package/src/unstable/ai/Toolkit.ts +12 -12
  794. package/src/unstable/cli/Argument.ts +3 -4
  795. package/src/unstable/cli/CliError.ts +22 -9
  796. package/src/unstable/cli/CliOutput.ts +2 -2
  797. package/src/unstable/cli/Command.ts +36 -30
  798. package/src/unstable/cli/Flag.ts +3 -4
  799. package/src/unstable/cli/GlobalFlag.ts +3 -3
  800. package/src/unstable/cli/HelpDoc.ts +8 -8
  801. package/src/unstable/cli/Param.ts +39 -16
  802. package/src/unstable/cli/Prompt.ts +13 -6
  803. package/src/unstable/cli/internal/command.ts +7 -7
  804. package/src/unstable/cli/internal/parser.ts +130 -21
  805. package/src/unstable/cluster/ClusterSchema.ts +12 -12
  806. package/src/unstable/cluster/ClusterWorkflowEngine.ts +14 -15
  807. package/src/unstable/cluster/Entity.ts +25 -25
  808. package/src/unstable/cluster/EntityProxy.ts +3 -3
  809. package/src/unstable/cluster/EntityProxyServer.ts +4 -4
  810. package/src/unstable/cluster/EntityResource.ts +2 -2
  811. package/src/unstable/cluster/HttpRunner.ts +2 -2
  812. package/src/unstable/cluster/K8sHttpClient.ts +2 -2
  813. package/src/unstable/cluster/Message.ts +8 -8
  814. package/src/unstable/cluster/MessageStorage.ts +11 -11
  815. package/src/unstable/cluster/Reply.ts +7 -7
  816. package/src/unstable/cluster/RunnerHealth.ts +2 -2
  817. package/src/unstable/cluster/RunnerServer.ts +1 -1
  818. package/src/unstable/cluster/RunnerStorage.ts +9 -9
  819. package/src/unstable/cluster/Runners.ts +7 -7
  820. package/src/unstable/cluster/ShardId.ts +84 -74
  821. package/src/unstable/cluster/Sharding.ts +26 -26
  822. package/src/unstable/cluster/ShardingConfig.ts +5 -5
  823. package/src/unstable/cluster/Snowflake.ts +2 -2
  824. package/src/unstable/cluster/SqlMessageStorage.ts +1 -1
  825. package/src/unstable/cluster/internal/entityManager.ts +27 -23
  826. package/src/unstable/cluster/internal/entityReaper.ts +2 -2
  827. package/src/unstable/cluster/internal/resourceMap.ts +3 -3
  828. package/src/unstable/devtools/DevToolsClient.ts +5 -5
  829. package/src/unstable/eventlog/Event.ts +0 -8
  830. package/src/unstable/eventlog/EventGroup.ts +0 -4
  831. package/src/unstable/eventlog/EventJournal.ts +146 -78
  832. package/src/unstable/eventlog/EventLog.ts +353 -232
  833. package/src/unstable/eventlog/EventLogEncryption.ts +18 -32
  834. package/src/unstable/eventlog/EventLogMessage.ts +277 -0
  835. package/src/unstable/eventlog/EventLogRemote.ts +263 -410
  836. package/src/unstable/eventlog/EventLogServer.ts +183 -275
  837. package/src/unstable/eventlog/EventLogServerEncrypted.ts +206 -0
  838. package/src/unstable/eventlog/EventLogServerUnencrypted.ts +749 -0
  839. package/src/unstable/eventlog/EventLogSessionAuth.ts +437 -0
  840. package/src/unstable/eventlog/{SqlEventLogJournal.ts → SqlEventJournal.ts} +26 -18
  841. package/src/unstable/eventlog/{SqlEventLogServer.ts → SqlEventLogServerEncrypted.ts} +102 -40
  842. package/src/unstable/eventlog/SqlEventLogServerUnencrypted.ts +500 -0
  843. package/src/unstable/eventlog/index.ts +27 -2
  844. package/src/unstable/eventlog/internal/identityRootSecretDerivation.ts +153 -0
  845. package/src/unstable/http/Etag.ts +2 -2
  846. package/src/unstable/http/FetchHttpClient.ts +5 -5
  847. package/src/unstable/http/Headers.ts +4 -4
  848. package/src/unstable/http/HttpClient.ts +9 -8
  849. package/src/unstable/http/HttpClientRequest.ts +5 -5
  850. package/src/unstable/http/HttpEffect.ts +35 -35
  851. package/src/unstable/http/HttpIncomingMessage.ts +2 -2
  852. package/src/unstable/http/HttpMiddleware.ts +28 -14
  853. package/src/unstable/http/HttpPlatform.ts +2 -2
  854. package/src/unstable/http/HttpRouter.ts +37 -37
  855. package/src/unstable/http/HttpServer.ts +2 -2
  856. package/src/unstable/http/HttpServerError.ts +4 -4
  857. package/src/unstable/http/HttpServerRequest.ts +7 -7
  858. package/src/unstable/http/HttpServerResponse.ts +8 -8
  859. package/src/unstable/http/Multipart.ts +8 -8
  860. package/src/unstable/httpapi/HttpApi.ts +18 -18
  861. package/src/unstable/httpapi/HttpApiBuilder.ts +20 -20
  862. package/src/unstable/httpapi/HttpApiClient.ts +4 -4
  863. package/src/unstable/httpapi/HttpApiEndpoint.ts +14 -14
  864. package/src/unstable/httpapi/HttpApiGroup.ts +16 -16
  865. package/src/unstable/httpapi/HttpApiMiddleware.ts +14 -14
  866. package/src/unstable/httpapi/HttpApiSecurity.ts +13 -13
  867. package/src/unstable/httpapi/OpenApi.ts +29 -31
  868. package/src/unstable/observability/OtlpExporter.ts +5 -5
  869. package/src/unstable/observability/OtlpMetrics.ts +1 -1
  870. package/src/unstable/observability/OtlpSerialization.ts +2 -2
  871. package/src/unstable/observability/OtlpTracer.ts +2 -2
  872. package/src/unstable/observability/PrometheusMetrics.ts +5 -5
  873. package/src/unstable/persistence/KeyValueStore.ts +226 -3
  874. package/src/unstable/persistence/PersistedCache.ts +20 -17
  875. package/src/unstable/persistence/PersistedQueue.ts +3 -3
  876. package/src/unstable/persistence/Persistence.ts +4 -4
  877. package/src/unstable/persistence/RateLimiter.ts +3 -3
  878. package/src/unstable/persistence/Redis.ts +2 -2
  879. package/src/unstable/process/ChildProcessSpawner.ts +46 -2
  880. package/src/unstable/reactivity/Atom.ts +79 -79
  881. package/src/unstable/reactivity/AtomHttpApi.ts +27 -12
  882. package/src/unstable/reactivity/AtomRegistry.ts +4 -4
  883. package/src/unstable/reactivity/AtomRpc.ts +20 -9
  884. package/src/unstable/reactivity/Reactivity.ts +6 -6
  885. package/src/unstable/rpc/Rpc.ts +59 -21
  886. package/src/unstable/rpc/RpcClient.ts +103 -54
  887. package/src/unstable/rpc/RpcGroup.ts +31 -31
  888. package/src/unstable/rpc/RpcMiddleware.ts +16 -16
  889. package/src/unstable/rpc/RpcSchema.ts +4 -4
  890. package/src/unstable/rpc/RpcSerialization.ts +2 -2
  891. package/src/unstable/rpc/RpcServer.ts +24 -22
  892. package/src/unstable/rpc/RpcWorker.ts +5 -5
  893. package/src/unstable/rpc/Utils.ts +63 -4
  894. package/src/unstable/schema/Model.ts +4 -6
  895. package/src/unstable/schema/VariantSchema.ts +4 -17
  896. package/src/unstable/socket/Socket.ts +9 -9
  897. package/src/unstable/socket/SocketServer.ts +2 -2
  898. package/src/unstable/sql/SqlClient.ts +11 -11
  899. package/src/unstable/sql/SqlConnection.ts +2 -2
  900. package/src/unstable/sql/SqlModel.ts +54 -82
  901. package/src/unstable/sql/SqlResolver.ts +11 -11
  902. package/src/unstable/sql/Statement.ts +2 -2
  903. package/src/unstable/workers/Transferable.ts +15 -17
  904. package/src/unstable/workers/Worker.ts +4 -4
  905. package/src/unstable/workers/WorkerRunner.ts +2 -2
  906. package/src/unstable/workflow/Activity.ts +14 -14
  907. package/src/unstable/workflow/DurableClock.ts +3 -3
  908. package/src/unstable/workflow/DurableDeferred.ts +8 -8
  909. package/src/unstable/workflow/Workflow.ts +23 -23
  910. package/src/unstable/workflow/WorkflowEngine.ts +6 -6
  911. package/src/unstable/workflow/WorkflowProxyServer.ts +4 -4
  912. package/dist/ServiceMap.d.ts +0 -1150
  913. package/dist/ServiceMap.d.ts.map +0 -1
  914. package/dist/ServiceMap.js.map +0 -1
  915. package/dist/unstable/eventlog/SqlEventLogJournal.d.ts.map +0 -1
  916. package/dist/unstable/eventlog/SqlEventLogJournal.js.map +0 -1
  917. package/dist/unstable/eventlog/SqlEventLogServer.d.ts.map +0 -1
  918. package/dist/unstable/eventlog/SqlEventLogServer.js.map +0 -1
@@ -0,0 +1,749 @@
1
+ /**
2
+ * @since 4.0.0
3
+ */
4
+ import * as Arr from "../../Array.ts"
5
+ import * as Context from "../../Context.ts"
6
+ import * as Data from "../../Data.ts"
7
+ import * as Effect from "../../Effect.ts"
8
+ import * as Layer from "../../Layer.ts"
9
+ import * as Option from "../../Option.ts"
10
+ import * as PubSub from "../../PubSub.ts"
11
+ import * as RcMap from "../../RcMap.ts"
12
+ import * as Redacted from "../../Redacted.ts"
13
+ import * as Schema from "../../Schema.ts"
14
+ import type * as Scope from "../../Scope.ts"
15
+ import * as Semaphore from "../../Semaphore.ts"
16
+ import * as Stream from "../../Stream.ts"
17
+ import type * as Rpc from "../rpc/Rpc.ts"
18
+ import type * as RpcGroup from "../rpc/RpcGroup.ts"
19
+ import * as RpcServer from "../rpc/RpcServer.ts"
20
+ import type * as Event from "./Event.ts"
21
+ import type * as EventGroup from "./EventGroup.ts"
22
+ import * as EventJournal from "./EventJournal.ts"
23
+ import { Entry, makeEntryIdUnsafe, makeRemoteIdUnsafe, RemoteEntry, type RemoteId } from "./EventJournal.ts"
24
+ import * as EventLog from "./EventLog.ts"
25
+ import {
26
+ ChangesRpc,
27
+ type EventLogAuthentication,
28
+ EventLogProtocolError,
29
+ EventLogRemoteRpcs,
30
+ type StoreId,
31
+ WriteEntriesUnencrypted
32
+ } from "./EventLogMessage.ts"
33
+ import * as EventLogServer from "./EventLogServer.ts"
34
+
35
+ /**
36
+ * @since 4.0.0
37
+ * @category EventLogServerUnencrypted
38
+ */
39
+ export class EventLogServerUnencrypted extends Context.Service<EventLogServerUnencrypted, {
40
+ readonly makeWrite: <Groups extends EventGroup.Any>(
41
+ schema: EventLog.EventLogSchema<Groups>
42
+ ) => <
43
+ Tag extends EventGroup.Events<Groups>["tag"],
44
+ Event extends Event.Any = Event.WithTag<EventGroup.Events<Groups>, Tag>
45
+ >(options: {
46
+ readonly storeId: StoreId
47
+ readonly event: Tag
48
+ readonly payload: Event.Payload<Event>
49
+ }) => Effect.Effect<
50
+ Event.Success<Event>,
51
+ EventLogServerStoreError | Event.Error<Event>
52
+ >
53
+ }>()("effect/eventlog/EventLogServerUnencrypted") {}
54
+
55
+ /**
56
+ * @since 4.0.0
57
+ * @category EventLogServerUnencrypted
58
+ */
59
+ export const makeWrite = <Groups extends EventGroup.Any>(
60
+ schema: EventLog.EventLogSchema<Groups>
61
+ ): Effect.Effect<
62
+ <
63
+ Tag extends EventGroup.Events<Groups>["tag"],
64
+ Event extends Event.Any = Event.WithTag<EventGroup.Events<Groups>, Tag>
65
+ >(options: {
66
+ readonly storeId: StoreId
67
+ readonly event: Tag
68
+ readonly payload: Event.Payload<Event>
69
+ }) => Effect.Effect<
70
+ Event.Success<Event>,
71
+ EventLogServerStoreError | Event.Error<Event>
72
+ >,
73
+ never,
74
+ EventLogServerUnencrypted
75
+ > => EventLogServerUnencrypted.useSync((_) => _.makeWrite(schema))
76
+
77
+ /**
78
+ * @since 4.0.0
79
+ * @category Layers
80
+ */
81
+ export const layerRpcHandlers: Layer.Layer<
82
+ Rpc.ToHandler<RpcGroup.Rpcs<typeof EventLogRemoteRpcs>> | EventLogAuthentication,
83
+ never,
84
+ Storage | StoreMapping | EventLogServerAuthorization | EventLog.Registry
85
+ > = Layer.unwrap(Effect.gen(function*() {
86
+ const storage = yield* Storage
87
+ const mapping = yield* StoreMapping
88
+ const auth = yield* EventLogServerAuthorization
89
+ const registry = yield* EventLog.Registry
90
+ const handler = yield* makeServerHandler
91
+ const remoteId = yield* storage.getId
92
+
93
+ const processEntries = Effect.fnUntraced(function*(options: {
94
+ readonly publicKey: string
95
+ readonly storeId: StoreId
96
+ readonly entries: Arr.NonEmptyReadonlyArray<Entry>
97
+ }) {
98
+ const entries = Arr.sort(options.entries, Entry.Order)
99
+ let history = yield* storage.entriesAfter(options.storeId, entries[0])
100
+ const persistedEntries = Arr.empty<Entry>()
101
+ for (const entry of entries) {
102
+ const [duplicate, conflicts, newHistory] = toConflicts(history, entry)
103
+ if (duplicate) continue
104
+ history = newHistory
105
+ yield* handler({
106
+ publicKey: options.publicKey,
107
+ storeId: options.storeId,
108
+ entry,
109
+ conflicts
110
+ })
111
+ persistedEntries.push(entry)
112
+ }
113
+ yield* storage.write(options.storeId, persistedEntries)
114
+ }, storage.withTransaction)
115
+
116
+ return EventLogServer.layerRpcHandlers({
117
+ remoteId,
118
+ getOrCreateSessionAuthBinding: (publicKey, signingPublicKey) =>
119
+ storage.getOrCreateSessionAuthBinding(publicKey, signingPublicKey),
120
+ onWrite: Effect.fnUntraced(function*(data) {
121
+ const request = yield* WriteEntriesUnencrypted.decode(data).pipe(
122
+ Effect.mapError((_) =>
123
+ new EventLogProtocolError({
124
+ requestTag: "WriteEntries",
125
+ publicKey: undefined,
126
+ code: "InternalServerError",
127
+ message: "Decoding failure"
128
+ })
129
+ )
130
+ )
131
+ if (!Arr.isReadonlyArrayNonEmpty(request.entries)) return
132
+
133
+ const resolvedStoreId = yield* mapping.resolve({
134
+ publicKey: request.publicKey,
135
+ storeId: request.storeId
136
+ }).pipe(
137
+ Effect.mapError((_) =>
138
+ new EventLogProtocolError({
139
+ requestTag: "WriteEntries",
140
+ publicKey: request.publicKey,
141
+ storeId: request.storeId,
142
+ code: "Unauthorized",
143
+ message: _.message
144
+ })
145
+ )
146
+ )
147
+ yield* auth.authorizeWrite({
148
+ publicKey: request.publicKey,
149
+ storeId: resolvedStoreId,
150
+ entries: request.entries
151
+ }).pipe(
152
+ Effect.mapError((_) =>
153
+ new EventLogProtocolError({
154
+ requestTag: "WriteEntries",
155
+ publicKey: request.publicKey,
156
+ storeId: request.storeId,
157
+ code: "Unauthorized",
158
+ message: _.message
159
+ })
160
+ )
161
+ )
162
+ yield* processEntries({
163
+ publicKey: request.publicKey,
164
+ storeId: resolvedStoreId,
165
+ entries: request.entries
166
+ }).pipe(
167
+ Effect.catchCause((_) =>
168
+ Effect.fail(
169
+ new EventLogProtocolError({
170
+ requestTag: "WriteEntries",
171
+ publicKey: request.publicKey,
172
+ code: "InternalServerError",
173
+ message: "Persistence failure"
174
+ })
175
+ )
176
+ ),
177
+ Effect.provideService(EventLog.Identity, makeClientIdentity(request.publicKey))
178
+ )
179
+ }),
180
+ changes: Effect.fnUntraced(function*(request) {
181
+ const storeId = yield* mapping.resolve({
182
+ publicKey: request.publicKey,
183
+ storeId: request.storeId
184
+ })
185
+ yield* auth.authorizeRead({
186
+ publicKey: request.publicKey,
187
+ storeId
188
+ })
189
+ return storage.changes({
190
+ storeId,
191
+ startSequence: request.startSequence,
192
+ compactors: registry.compactors
193
+ }).pipe(
194
+ Stream.mapArrayEffect((entries) => Effect.map(ChangesRpc.encodeUnencrypted(entries), Arr.of))
195
+ )
196
+ }, Stream.unwrap)
197
+ })
198
+ }))
199
+
200
+ /**
201
+ * @since 4.0.0
202
+ * @category errors
203
+ */
204
+ export class EventLogServerStoreError extends Data.TaggedError("EventLogServerStoreError")<{
205
+ readonly reason: "NotFound" | "PersistenceFailure"
206
+ readonly publicKey?: string | undefined
207
+ readonly storeId?: StoreId | undefined
208
+ readonly message?: string | undefined
209
+ }> {}
210
+
211
+ /**
212
+ * @since 4.0.0
213
+ * @category errors
214
+ */
215
+ export class EventLogServerAuthError extends Data.TaggedError("EventLogServerAuthError")<{
216
+ readonly reason: "Unauthorized" | "Forbidden"
217
+ readonly publicKey: string
218
+ readonly storeId?: StoreId | undefined
219
+ readonly message?: string | undefined
220
+ }> {}
221
+
222
+ /**
223
+ * @since 4.0.0
224
+ * @category context
225
+ */
226
+ export class EventLogServerAuthorization extends Context.Service<EventLogServerAuthorization, {
227
+ readonly authorizeWrite: (options: {
228
+ readonly publicKey: string
229
+ readonly storeId: StoreId
230
+ readonly entries: ReadonlyArray<Entry>
231
+ }) => Effect.Effect<void, EventLogServerAuthError>
232
+ readonly authorizeRead: (options: {
233
+ readonly publicKey: string
234
+ readonly storeId: StoreId
235
+ }) => Effect.Effect<void, EventLogServerAuthError>
236
+ readonly authorizeIdentity: (options: {
237
+ readonly publicKey: string
238
+ }) => Effect.Effect<void, EventLogServerAuthError>
239
+ }>()("effect/eventlog/EventLogServerUnencrypted/EventLogServerAuthorization") {}
240
+
241
+ /**
242
+ * @since 4.0.0
243
+ * @category context
244
+ */
245
+ export class StoreMapping extends Context.Service<StoreMapping, {
246
+ readonly resolve: (
247
+ options: {
248
+ readonly publicKey: string
249
+ readonly storeId: StoreId
250
+ }
251
+ ) => Effect.Effect<StoreId, EventLogServerStoreError>
252
+ readonly hasStore: (options: {
253
+ readonly publicKey: string
254
+ readonly storeId: StoreId
255
+ }) => Effect.Effect<boolean, EventLogServerStoreError>
256
+ }>()("effect/eventlog/EventLogServerUnencrypted/StoreMapping") {}
257
+
258
+ const toStoreNotFoundError = (options: {
259
+ readonly storeId: StoreId
260
+ readonly publicKey?: string | undefined
261
+ }) =>
262
+ new EventLogServerStoreError({
263
+ reason: "NotFound",
264
+ publicKey: options.publicKey,
265
+ storeId: options.storeId,
266
+ message: options.publicKey === undefined
267
+ ? `No provisioned store found for store id: ${options.storeId}`
268
+ : `No provisioned store found for public key: ${options.publicKey} and store id: ${options.storeId}`
269
+ })
270
+
271
+ /**
272
+ * @since 4.0.0
273
+ * @category store
274
+ */
275
+ export const layerStoreMappingStatic = (options: {
276
+ readonly storeId: StoreId
277
+ }): Layer.Layer<StoreMapping> =>
278
+ Layer.succeed(StoreMapping, {
279
+ resolve(request) {
280
+ if (request.storeId === options.storeId) {
281
+ return Effect.succeed(options.storeId)
282
+ }
283
+ return Effect.fail(toStoreNotFoundError(request))
284
+ },
285
+ hasStore: ({ storeId }) => Effect.succeed(storeId === options.storeId)
286
+ })
287
+
288
+ /**
289
+ * @since 4.0.0
290
+ * @category storage
291
+ */
292
+ export class Storage extends Context.Service<Storage, {
293
+ readonly getId: Effect.Effect<RemoteId>
294
+ readonly getOrCreateSessionAuthBinding: (
295
+ publicKey: string,
296
+ signingPublicKey: Uint8Array<ArrayBuffer>
297
+ ) => Effect.Effect<Uint8Array<ArrayBuffer>>
298
+ readonly entriesAfter: (storeId: StoreId, entry: Entry) => Effect.Effect<Array<Entry>>
299
+ readonly write: (
300
+ storeId: StoreId,
301
+ entries: ReadonlyArray<Entry>
302
+ ) => Effect.Effect<ReadonlyArray<RemoteEntry>>
303
+ readonly changes: (options: {
304
+ readonly storeId: StoreId
305
+ readonly startSequence: number
306
+ readonly compactors: ReadonlyMap<string, RegisteredCompactor>
307
+ }) => Stream.Stream<RemoteEntry>
308
+ readonly withTransaction: <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
309
+ }>()("effect/eventlog/EventLogServerUnencrypted/Storage") {}
310
+
311
+ const makeClientIdentity = (publicKey: string): EventLog.Identity["Service"] => ({
312
+ publicKey,
313
+ privateKey: constEmptyPrivateKey
314
+ })
315
+ const constEmptyPrivateKey = Redacted.make(new Uint8Array(32))
316
+
317
+ const makeServerWriteIdentityPublicKey = (storeId: StoreId): string => `effect-eventlog-server-write:${storeId}`
318
+
319
+ const entriesAfter = (journal: Array<RemoteEntry>, startSequence: number): ReadonlyArray<RemoteEntry> =>
320
+ journal.filter((entry) => entry.remoteSequence > startSequence)
321
+
322
+ const toConflicts = (
323
+ history: ReadonlyArray<Entry>,
324
+ originEntry: Entry
325
+ ): [duplicate: boolean, conflicts: Array<Entry>, newHistory: Array<Entry>] => {
326
+ let duplicate = false
327
+
328
+ for (let i = 0; i < history.length; i++) {
329
+ const entry = history[i]
330
+ if (entry.createdAtMillis < originEntry.createdAtMillis) {
331
+ continue
332
+ } else if (entry.idString === originEntry.idString) {
333
+ duplicate = true
334
+ continue
335
+ }
336
+
337
+ const newHistory = history.slice(i)
338
+ let conflicts: Array<Entry> = []
339
+ for (let j = 0; j < newHistory.length; j++) {
340
+ const scannedEntry = history[j]!
341
+ if (scannedEntry.event === originEntry.event && scannedEntry.primaryKey === originEntry.primaryKey) {
342
+ conflicts.push(scannedEntry)
343
+ }
344
+ }
345
+ return [duplicate, conflicts, newHistory]
346
+ }
347
+
348
+ return [duplicate, [], []]
349
+ }
350
+
351
+ type RegisteredCompactor = {
352
+ readonly events: ReadonlySet<string>
353
+ readonly effect: (options: {
354
+ readonly entries: ReadonlyArray<Entry>
355
+ readonly write: (entry: Entry) => Effect.Effect<void>
356
+ }) => Effect.Effect<void>
357
+ }
358
+
359
+ const representativeSequences = (options: {
360
+ readonly remoteEntries: ReadonlyArray<RemoteEntry>
361
+ readonly compactedCount: number
362
+ }): ReadonlyArray<number> | undefined => {
363
+ if (options.compactedCount === 0) {
364
+ return []
365
+ }
366
+ if (options.compactedCount > options.remoteEntries.length) {
367
+ return undefined
368
+ }
369
+
370
+ const maxSequence = options.remoteEntries[options.remoteEntries.length - 1]!.remoteSequence
371
+ if (options.compactedCount === 1) {
372
+ return [maxSequence]
373
+ }
374
+
375
+ const selected = options.remoteEntries
376
+ .slice(0, options.compactedCount - 1)
377
+ .map((entry) => entry.remoteSequence)
378
+ selected.push(maxSequence)
379
+ for (let i = 1; i < selected.length; i++) {
380
+ if (selected[i]! <= selected[i - 1]!) {
381
+ return undefined
382
+ }
383
+ }
384
+ return selected
385
+ }
386
+
387
+ const toCompactedRemoteEntries = (options: {
388
+ readonly compacted: ReadonlyArray<Entry>
389
+ readonly remoteEntries: ReadonlyArray<RemoteEntry>
390
+ }): ReadonlyArray<RemoteEntry> | undefined => {
391
+ const sequences = representativeSequences({
392
+ remoteEntries: options.remoteEntries,
393
+ compactedCount: options.compacted.length
394
+ })
395
+ if (sequences === undefined) {
396
+ return undefined
397
+ }
398
+
399
+ return options.compacted.map((entry, index) =>
400
+ new RemoteEntry({
401
+ remoteSequence: sequences[index]!,
402
+ entry
403
+ }, { disableChecks: true })
404
+ )
405
+ }
406
+
407
+ /**
408
+ * @since 4.0.0
409
+ * @category compaction
410
+ */
411
+ export const compactBacklog = Effect.fnUntraced(function*(options: {
412
+ readonly remoteEntries: ReadonlyArray<RemoteEntry>
413
+ readonly compactors: ReadonlyMap<string, RegisteredCompactor>
414
+ }) {
415
+ if (options.compactors.size === 0 || options.remoteEntries.length === 0) {
416
+ return options.remoteEntries
417
+ }
418
+
419
+ const compactedRemoteEntries: Array<RemoteEntry> = []
420
+ let index = 0
421
+
422
+ while (index < options.remoteEntries.length) {
423
+ const remoteEntry = options.remoteEntries[index]!
424
+ const compactor = options.compactors.get(remoteEntry.entry.event)
425
+ if (compactor === undefined) {
426
+ compactedRemoteEntries.push(remoteEntry)
427
+ index++
428
+ continue
429
+ }
430
+
431
+ const entries: Array<Entry> = [remoteEntry.entry]
432
+ const remoteGroup: Array<RemoteEntry> = [remoteEntry]
433
+ const compacted: Array<Entry> = []
434
+ index++
435
+
436
+ while (index < options.remoteEntries.length) {
437
+ const nextRemoteEntry = options.remoteEntries[index]!
438
+ const nextCompactor = options.compactors.get(nextRemoteEntry.entry.event)
439
+ if (nextCompactor !== compactor) {
440
+ break
441
+ }
442
+ entries.push(nextRemoteEntry.entry)
443
+ remoteGroup.push(nextRemoteEntry)
444
+ index++
445
+ }
446
+
447
+ yield* compactor.effect({
448
+ entries,
449
+ write(entry) {
450
+ return Effect.sync(() => {
451
+ compacted.push(entry)
452
+ })
453
+ }
454
+ }).pipe(Effect.orDie)
455
+
456
+ const projected = toCompactedRemoteEntries({
457
+ compacted,
458
+ remoteEntries: remoteGroup
459
+ })
460
+
461
+ if (projected === undefined) {
462
+ compactedRemoteEntries.push(...remoteGroup)
463
+ continue
464
+ }
465
+ compactedRemoteEntries.push(...projected)
466
+ }
467
+
468
+ return compactedRemoteEntries
469
+ })
470
+
471
+ /**
472
+ * @since 4.0.0
473
+ * @category storage
474
+ */
475
+ export const makeStorageMemory: Effect.Effect<Storage["Service"], never, Scope.Scope> = Effect.gen(function*() {
476
+ const knownIds = new Map<string, Map<string, number>>()
477
+ const journals = new Map<string, Array<RemoteEntry>>()
478
+ const sessionAuthBindings = new Map<string, Uint8Array<ArrayBuffer>>()
479
+ const remoteId = makeRemoteIdUnsafe()
480
+
481
+ const ensureKnownIds = (storeId: StoreId): Map<string, number> => {
482
+ let storeKnownIds = knownIds.get(storeId)
483
+ if (storeKnownIds) return storeKnownIds
484
+ storeKnownIds = new Map()
485
+ knownIds.set(storeId, storeKnownIds)
486
+ return storeKnownIds
487
+ }
488
+
489
+ const ensureJournal = (storeId: StoreId): Array<RemoteEntry> => {
490
+ let journal = journals.get(storeId)
491
+ if (journal) return journal
492
+ journal = []
493
+ journals.set(storeId, journal)
494
+ return journal
495
+ }
496
+
497
+ const pubsubs = yield* RcMap.make({
498
+ lookup: (_storeId: string) =>
499
+ Effect.acquireRelease(
500
+ PubSub.unbounded<RemoteEntry>(),
501
+ PubSub.shutdown
502
+ ),
503
+ idleTimeToLive: 60000
504
+ })
505
+
506
+ const write = Effect.fnUntraced(function*(storeId: StoreId, entries: ReadonlyArray<Entry>) {
507
+ const sequenceNumbers: Array<number> = []
508
+ const committed: Array<RemoteEntry> = []
509
+ const storeKnownIds = ensureKnownIds(storeId)
510
+ const journal = ensureJournal(storeId)
511
+ let lastSequenceNumber = Arr.last(journal).pipe(
512
+ Option.map((entry) => entry.remoteSequence),
513
+ Option.getOrElse(() => 0)
514
+ )
515
+ if (entries.some((entry) => storeKnownIds.has(entry.idString))) {
516
+ return yield* Effect.die("Duplicate entries")
517
+ }
518
+
519
+ for (const entry of entries) {
520
+ const remoteEntry = new RemoteEntry({
521
+ remoteSequence: ++lastSequenceNumber,
522
+ entry
523
+ }, { disableChecks: true })
524
+
525
+ sequenceNumbers.push(remoteEntry.remoteSequence)
526
+ committed.push(remoteEntry)
527
+ journal.push(remoteEntry)
528
+ storeKnownIds.set(entry.idString, remoteEntry.remoteSequence)
529
+ }
530
+
531
+ const pubsub = yield* RcMap.get(pubsubs, storeId)
532
+ yield* PubSub.publishAll(pubsub, committed)
533
+
534
+ return committed
535
+ }, Effect.scoped)
536
+
537
+ const transactionSemaphore = yield* Semaphore.make(1)
538
+
539
+ return Storage.of({
540
+ getId: Effect.succeed(remoteId),
541
+ getOrCreateSessionAuthBinding: (publicKey, signingPublicKey) =>
542
+ Effect.sync(() => {
543
+ const existing = sessionAuthBindings.get(publicKey)
544
+ if (existing) return existing
545
+ sessionAuthBindings.set(publicKey, signingPublicKey)
546
+ return signingPublicKey
547
+ }),
548
+ entriesAfter: (storeId, entry) =>
549
+ Effect.sync(() => {
550
+ const journal = ensureJournal(storeId)
551
+ return journal.filter((e) => Entry.Order(e.entry, entry) >= 0).map((e) => e.entry)
552
+ }),
553
+ write,
554
+ changes: Effect.fnUntraced(function*({ storeId, startSequence, compactors }) {
555
+ const pubsub = yield* RcMap.get(pubsubs, storeId)
556
+ const subscription = yield* PubSub.subscribe(pubsub)
557
+
558
+ const backlog = yield* compactBacklog({
559
+ remoteEntries: entriesAfter(ensureJournal(storeId), startSequence),
560
+ compactors
561
+ })
562
+ const replayedUpTo = backlog.length > 0 ? backlog[backlog.length - 1].remoteSequence : startSequence
563
+
564
+ return Stream.fromArray(backlog).pipe(
565
+ Stream.concat(
566
+ Stream.fromSubscription(subscription).pipe(
567
+ Stream.filter((entry) => entry.remoteSequence > replayedUpTo)
568
+ )
569
+ )
570
+ )
571
+ }, Stream.unwrap),
572
+ withTransaction: transactionSemaphore.withPermits(1)
573
+ })
574
+ })
575
+
576
+ /**
577
+ * @since 4.0.0
578
+ * @category storage
579
+ */
580
+ export const layerStorageMemory: Layer.Layer<Storage> = Layer.effect(Storage)(makeStorageMemory)
581
+
582
+ /**
583
+ * @since 4.0.0
584
+ * @category constructors
585
+ */
586
+ export const make = Effect.gen(function*() {
587
+ const storage = yield* Storage
588
+ const handler = yield* makeServerHandler
589
+
590
+ return EventLogServerUnencrypted.of({
591
+ makeWrite<Groups extends EventGroup.Any>(schema: EventLog.EventLogSchema<Groups>) {
592
+ const events = new Map<string, Event.AnyWithProps>()
593
+ for (const group of schema.groups as unknown as ReadonlyArray<EventGroup.EventGroup<Event.Any>>) {
594
+ for (const [tag, event] of Object.entries(group.events)) {
595
+ events.set(tag, event)
596
+ }
597
+ }
598
+ return Effect.fnUntraced(function*(options: {
599
+ readonly storeId: StoreId
600
+ readonly event: string
601
+ readonly payload: unknown
602
+ }) {
603
+ const publicKey = makeServerWriteIdentityPublicKey(options.storeId)
604
+ const schemaEvent = events.get(options.event)
605
+ if (schemaEvent === undefined) {
606
+ return yield* Effect.die(`Event schema not found for: "${options.event}"`)
607
+ }
608
+
609
+ const entry = new EventJournal.Entry({
610
+ id: makeEntryIdUnsafe(),
611
+ event: options.event,
612
+ primaryKey: schemaEvent.primaryKey(options.payload),
613
+ payload: yield* Schema.encodeUnknownEffect(schemaEvent.payloadMsgPack)(options.payload).pipe(
614
+ Effect.mapError((_) =>
615
+ new EventLogServerStoreError({
616
+ reason: "PersistenceFailure",
617
+ publicKey: publicKey,
618
+ storeId: options.storeId,
619
+ message: "Failed to encode event"
620
+ })
621
+ )
622
+ ) as Effect.Effect<any, EventLogServerStoreError>
623
+ }, { disableChecks: true })
624
+
625
+ const result = yield* handler({
626
+ publicKey,
627
+ storeId: options.storeId,
628
+ entry,
629
+ conflicts: []
630
+ }).pipe(
631
+ Effect.provideService(EventLog.Identity, makeClientIdentity(publicKey))
632
+ )
633
+
634
+ yield* storage.write(options.storeId, [entry])
635
+
636
+ return result
637
+ }, storage.withTransaction) as any
638
+ }
639
+ })
640
+ })
641
+
642
+ /**
643
+ * @since 4.0.0
644
+ * @category layers
645
+ */
646
+ export const layerServer: Layer.Layer<
647
+ EventLogServerUnencrypted | EventLog.Registry,
648
+ never,
649
+ Storage
650
+ > = Layer.effect(EventLogServerUnencrypted, make).pipe(
651
+ Layer.provideMerge(EventLog.layerRegistry)
652
+ )
653
+
654
+ /**
655
+ * @since 4.0.0
656
+ * @category layers
657
+ */
658
+ export const layer = <Groups extends EventGroup.Any, E, R>(
659
+ _schema: EventLog.EventLogSchema<Groups>,
660
+ layer: Layer.Layer<EventGroup.ToService<Groups>, E, R>
661
+ ): Layer.Layer<
662
+ never,
663
+ E,
664
+ | Exclude<R, EventLogServerUnencrypted | EventLog.Registry>
665
+ | EventLogServerAuthorization
666
+ | RpcServer.Protocol
667
+ | Storage
668
+ | StoreMapping
669
+ > =>
670
+ RpcServer.layer(EventLogRemoteRpcs).pipe(
671
+ Layer.provide(layerRpcHandlers),
672
+ Layer.provide(layer),
673
+ Layer.provide(layerServer)
674
+ )
675
+
676
+ /**
677
+ * @since 4.0.0
678
+ * @category layers
679
+ */
680
+ export const layerNoRpcServer = <Groups extends EventGroup.Any, E, R>(
681
+ _schema: EventLog.EventLogSchema<Groups>,
682
+ layer: Layer.Layer<EventGroup.ToService<Groups>, E, R>
683
+ ): Layer.Layer<
684
+ Rpc.ToHandler<RpcGroup.Rpcs<typeof EventLogRemoteRpcs>> | EventLogAuthentication,
685
+ E,
686
+ | Exclude<R, EventLogServerUnencrypted | EventLog.Registry>
687
+ | EventLogServerAuthorization
688
+ | Storage
689
+ | StoreMapping
690
+ > =>
691
+ layerRpcHandlers.pipe(
692
+ Layer.merge(layer),
693
+ Layer.provide(layerServer)
694
+ )
695
+
696
+ const makeServerHandler = Effect.gen(function*() {
697
+ const registry = yield* EventLog.Registry
698
+
699
+ return Effect.fnUntraced(
700
+ function*(options: {
701
+ readonly publicKey: string
702
+ readonly storeId: StoreId
703
+ readonly entry: Entry
704
+ readonly conflicts: ReadonlyArray<Entry>
705
+ readonly payload?: unknown
706
+ }): Effect.fn.Return<any, any, EventLog.Identity> {
707
+ const handler = registry.handlers.get(options.entry.event)
708
+ if (handler === undefined) {
709
+ return yield* Effect.logDebug(`Event handler not found for: "${options.entry.event}"`)
710
+ }
711
+
712
+ const decodePayload = Schema.decodeUnknownEffect(handler.event.payloadMsgPack)
713
+ const decodedConflicts: Array<{ readonly entry: Entry; readonly payload: unknown }> = []
714
+
715
+ for (const conflict of options.conflicts) {
716
+ decodedConflicts.push({
717
+ entry: conflict,
718
+ payload: yield* decodePayload(conflict.payload).pipe(
719
+ Effect.updateContext((input) => Context.merge(handler.context, input))
720
+ ) as any
721
+ })
722
+ }
723
+
724
+ const payloadEffect = "payload" in options
725
+ ? Effect.succeed(options.payload)
726
+ : decodePayload(options.entry.payload)
727
+
728
+ return yield* payloadEffect.pipe(
729
+ Effect.mapError((_) =>
730
+ new EventLogServerStoreError({
731
+ reason: "PersistenceFailure",
732
+ publicKey: options.publicKey,
733
+ storeId: options.storeId,
734
+ message: "Failed to decode event"
735
+ })
736
+ ),
737
+ Effect.flatMap((payload) =>
738
+ handler.handler({
739
+ storeId: options.storeId,
740
+ payload,
741
+ entry: options.entry,
742
+ conflicts: decodedConflicts
743
+ })
744
+ ),
745
+ Effect.updateContext((input) => Context.merge(handler.context, input))
746
+ ) as Effect.Effect<any, unknown, EventLog.Identity>
747
+ }
748
+ )
749
+ })