effect 4.0.0-beta.2 → 4.0.0-beta.21
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.
- package/dist/Array.d.ts +127 -299
- package/dist/Array.d.ts.map +1 -1
- package/dist/Array.js +102 -62
- package/dist/Array.js.map +1 -1
- package/dist/Cache.d.ts +2 -2
- package/dist/Cache.d.ts.map +1 -1
- package/dist/Cache.js +6 -5
- package/dist/Cache.js.map +1 -1
- package/dist/Cause.d.ts +1 -1
- package/dist/Cause.d.ts.map +1 -1
- package/dist/Channel.d.ts +116 -30
- package/dist/Channel.d.ts.map +1 -1
- package/dist/Channel.js +82 -37
- package/dist/Channel.js.map +1 -1
- package/dist/Chunk.d.ts +54 -247
- package/dist/Chunk.d.ts.map +1 -1
- package/dist/Chunk.js +36 -67
- package/dist/Chunk.js.map +1 -1
- package/dist/Combiner.d.ts +280 -13
- package/dist/Combiner.d.ts.map +1 -1
- package/dist/Combiner.js +198 -7
- package/dist/Combiner.js.map +1 -1
- package/dist/Config.d.ts +165 -9
- package/dist/Config.d.ts.map +1 -1
- package/dist/Config.js +62 -7
- package/dist/Config.js.map +1 -1
- package/dist/ConfigProvider.d.ts +1 -1
- package/dist/Cron.d.ts +1 -1
- package/dist/Data.d.ts +534 -365
- package/dist/Data.d.ts.map +1 -1
- package/dist/Data.js +132 -79
- package/dist/Data.js.map +1 -1
- package/dist/DateTime.d.ts +23 -161
- package/dist/DateTime.d.ts.map +1 -1
- package/dist/DateTime.js +6 -51
- package/dist/DateTime.js.map +1 -1
- package/dist/Duration.d.ts +12 -12
- package/dist/Duration.d.ts.map +1 -1
- package/dist/Duration.js +12 -12
- package/dist/Duration.js.map +1 -1
- package/dist/Effect.d.ts +829 -692
- package/dist/Effect.d.ts.map +1 -1
- package/dist/Effect.js +263 -251
- package/dist/Effect.js.map +1 -1
- package/dist/Encoding.d.ts +194 -0
- package/dist/Encoding.d.ts.map +1 -0
- package/dist/Encoding.js +352 -0
- package/dist/Encoding.js.map +1 -0
- package/dist/Equal.d.ts +276 -109
- package/dist/Equal.d.ts.map +1 -1
- package/dist/Equal.js +124 -48
- package/dist/Equal.js.map +1 -1
- package/dist/ErrorReporter.d.ts +376 -0
- package/dist/ErrorReporter.d.ts.map +1 -0
- package/dist/ErrorReporter.js +246 -0
- package/dist/ErrorReporter.js.map +1 -0
- package/dist/Fiber.d.ts +2 -2
- package/dist/Fiber.d.ts.map +1 -1
- package/dist/Fiber.js.map +1 -1
- package/dist/FileSystem.d.ts +1 -1
- package/dist/FileSystem.d.ts.map +1 -1
- package/dist/FileSystem.js +5 -5
- package/dist/FileSystem.js.map +1 -1
- package/dist/Filter.d.ts +30 -34
- package/dist/Filter.d.ts.map +1 -1
- package/dist/Filter.js +15 -13
- package/dist/Filter.js.map +1 -1
- package/dist/Formatter.d.ts +131 -47
- package/dist/Formatter.d.ts.map +1 -1
- package/dist/Formatter.js +229 -51
- package/dist/Formatter.js.map +1 -1
- package/dist/Graph.d.ts +1 -1
- package/dist/Graph.d.ts.map +1 -1
- package/dist/Graph.js +5 -8
- package/dist/Graph.js.map +1 -1
- package/dist/HashMap.d.ts +15 -14
- package/dist/HashMap.d.ts.map +1 -1
- package/dist/HashMap.js +4 -4
- package/dist/HashMap.js.map +1 -1
- package/dist/Iterable.d.ts +40 -39
- package/dist/Iterable.d.ts.map +1 -1
- package/dist/Iterable.js +94 -22
- package/dist/Iterable.js.map +1 -1
- package/dist/JsonSchema.d.ts +299 -10
- package/dist/JsonSchema.d.ts.map +1 -1
- package/dist/JsonSchema.js +323 -4
- package/dist/JsonSchema.js.map +1 -1
- package/dist/Latch.d.ts +109 -0
- package/dist/Latch.d.ts.map +1 -0
- package/dist/Latch.js +72 -0
- package/dist/Latch.js.map +1 -0
- package/dist/Layer.d.ts +9 -9
- package/dist/Layer.d.ts.map +1 -1
- package/dist/Layer.js.map +1 -1
- package/dist/LayerMap.d.ts +4 -4
- package/dist/LayerMap.d.ts.map +1 -1
- package/dist/LogLevel.d.ts +32 -0
- package/dist/LogLevel.d.ts.map +1 -1
- package/dist/LogLevel.js +28 -100
- package/dist/LogLevel.js.map +1 -1
- package/dist/Logger.d.ts +29 -95
- package/dist/Logger.d.ts.map +1 -1
- package/dist/Logger.js +2 -3
- package/dist/Logger.js.map +1 -1
- package/dist/ManagedRuntime.d.ts +1 -1
- package/dist/ManagedRuntime.js +1 -1
- package/dist/Metric.d.ts +2 -2
- package/dist/Metric.d.ts.map +1 -1
- package/dist/Metric.js +1 -1
- package/dist/Metric.js.map +1 -1
- package/dist/Optic.d.ts +947 -18
- package/dist/Optic.d.ts.map +1 -1
- package/dist/Optic.js +454 -5
- package/dist/Optic.js.map +1 -1
- package/dist/Option.d.ts +22 -15
- package/dist/Option.d.ts.map +1 -1
- package/dist/Option.js +14 -7
- package/dist/Option.js.map +1 -1
- package/dist/Pipeable.d.ts +17 -0
- package/dist/Pipeable.d.ts.map +1 -1
- package/dist/Pipeable.js +19 -1
- package/dist/Pipeable.js.map +1 -1
- package/dist/PlatformError.d.ts +10 -9
- package/dist/PlatformError.d.ts.map +1 -1
- package/dist/PlatformError.js +2 -2
- package/dist/PlatformError.js.map +1 -1
- package/dist/Pool.d.ts +6 -4
- package/dist/Pool.d.ts.map +1 -1
- package/dist/Pool.js +7 -5
- package/dist/Pool.js.map +1 -1
- package/dist/PubSub.d.ts +3 -2
- package/dist/PubSub.d.ts.map +1 -1
- package/dist/PubSub.js +3 -2
- package/dist/PubSub.js.map +1 -1
- package/dist/Pull.d.ts.map +1 -1
- package/dist/Pull.js +1 -1
- package/dist/Pull.js.map +1 -1
- package/dist/Queue.d.ts.map +1 -1
- package/dist/Queue.js +0 -1
- package/dist/Queue.js.map +1 -1
- package/dist/Random.d.ts +35 -1
- package/dist/Random.d.ts.map +1 -1
- package/dist/Random.js +46 -12
- package/dist/Random.js.map +1 -1
- package/dist/RcMap.d.ts +2 -2
- package/dist/RcMap.d.ts.map +1 -1
- package/dist/RcMap.js +1 -1
- package/dist/RcMap.js.map +1 -1
- package/dist/RcRef.d.ts +1 -1
- package/dist/RcRef.d.ts.map +1 -1
- package/dist/Record.d.ts +24 -120
- package/dist/Record.d.ts.map +1 -1
- package/dist/Record.js +21 -41
- package/dist/Record.js.map +1 -1
- package/dist/Reducer.d.ts +166 -7
- package/dist/Reducer.d.ts.map +1 -1
- package/dist/Reducer.js +135 -1
- package/dist/Reducer.js.map +1 -1
- package/dist/References.d.ts +3 -3
- package/dist/References.d.ts.map +1 -1
- package/dist/Request.d.ts +1 -1
- package/dist/Request.d.ts.map +1 -1
- package/dist/Request.js +2 -1
- package/dist/Request.js.map +1 -1
- package/dist/RequestResolver.d.ts +6 -26
- package/dist/RequestResolver.d.ts.map +1 -1
- package/dist/RequestResolver.js +0 -20
- package/dist/RequestResolver.js.map +1 -1
- package/dist/Result.d.ts +12 -0
- package/dist/Result.d.ts.map +1 -1
- package/dist/Result.js +12 -0
- package/dist/Result.js.map +1 -1
- package/dist/Schedule.d.ts +47 -20
- package/dist/Schedule.d.ts.map +1 -1
- package/dist/Schedule.js +94 -34
- package/dist/Schedule.js.map +1 -1
- package/dist/Schema.d.ts +266 -50
- package/dist/Schema.d.ts.map +1 -1
- package/dist/Schema.js +426 -74
- package/dist/Schema.js.map +1 -1
- package/dist/SchemaAST.d.ts.map +1 -1
- package/dist/SchemaAST.js +7 -6
- package/dist/SchemaAST.js.map +1 -1
- package/dist/SchemaGetter.d.ts +2 -2
- package/dist/SchemaGetter.d.ts.map +1 -1
- package/dist/SchemaGetter.js +12 -14
- package/dist/SchemaGetter.js.map +1 -1
- package/dist/SchemaParser.d.ts +5 -0
- package/dist/SchemaParser.d.ts.map +1 -1
- package/dist/SchemaParser.js +10 -0
- package/dist/SchemaParser.js.map +1 -1
- package/dist/SchemaRepresentation.d.ts +44 -43
- package/dist/SchemaRepresentation.d.ts.map +1 -1
- package/dist/SchemaRepresentation.js +43 -24
- package/dist/SchemaRepresentation.js.map +1 -1
- package/dist/SchemaTransformation.d.ts +107 -3
- package/dist/SchemaTransformation.d.ts.map +1 -1
- package/dist/SchemaTransformation.js +159 -4
- package/dist/SchemaTransformation.js.map +1 -1
- package/dist/ScopedCache.d.ts +2 -2
- package/dist/ScopedCache.d.ts.map +1 -1
- package/dist/ScopedCache.js +1 -1
- package/dist/ScopedCache.js.map +1 -1
- package/dist/Semaphore.d.ts +211 -0
- package/dist/Semaphore.d.ts.map +1 -0
- package/dist/{PartitionedSemaphore.js → Semaphore.js} +97 -13
- package/dist/Semaphore.js.map +1 -0
- package/dist/ServiceMap.d.ts +39 -30
- package/dist/ServiceMap.d.ts.map +1 -1
- package/dist/ServiceMap.js +3 -3
- package/dist/ServiceMap.js.map +1 -1
- package/dist/Sink.d.ts +13 -13
- package/dist/Sink.d.ts.map +1 -1
- package/dist/Sink.js +53 -6
- package/dist/Sink.js.map +1 -1
- package/dist/Stream.d.ts +235 -423
- package/dist/Stream.d.ts.map +1 -1
- package/dist/Stream.js +124 -77
- package/dist/Stream.js.map +1 -1
- package/dist/Struct.d.ts +16 -0
- package/dist/Struct.d.ts.map +1 -1
- package/dist/Struct.js +22 -0
- package/dist/Struct.js.map +1 -1
- package/dist/SubscriptionRef.d.ts +2 -1
- package/dist/SubscriptionRef.d.ts.map +1 -1
- package/dist/SubscriptionRef.js +2 -1
- package/dist/SubscriptionRef.js.map +1 -1
- package/dist/SynchronizedRef.d.ts +2 -1
- package/dist/SynchronizedRef.d.ts.map +1 -1
- package/dist/SynchronizedRef.js +2 -1
- package/dist/SynchronizedRef.js.map +1 -1
- package/dist/Trie.d.ts +18 -17
- package/dist/Trie.d.ts.map +1 -1
- package/dist/Trie.js +5 -5
- package/dist/Trie.js.map +1 -1
- package/dist/TxChunk.d.ts +37 -37
- package/dist/TxChunk.d.ts.map +1 -1
- package/dist/TxChunk.js +3 -3
- package/dist/TxChunk.js.map +1 -1
- package/dist/TxDeferred.d.ts +328 -0
- package/dist/TxDeferred.d.ts.map +1 -0
- package/dist/TxDeferred.js +196 -0
- package/dist/TxDeferred.js.map +1 -0
- package/dist/TxHashMap.d.ts +84 -83
- package/dist/TxHashMap.d.ts.map +1 -1
- package/dist/TxHashMap.js +24 -24
- package/dist/TxHashMap.js.map +1 -1
- package/dist/TxHashSet.d.ts +35 -35
- package/dist/TxHashSet.d.ts.map +1 -1
- package/dist/TxHashSet.js +14 -14
- package/dist/TxHashSet.js.map +1 -1
- package/dist/TxPriorityQueue.d.ts +609 -0
- package/dist/TxPriorityQueue.d.ts.map +1 -0
- package/dist/TxPriorityQueue.js +415 -0
- package/dist/TxPriorityQueue.js.map +1 -0
- package/dist/TxPubSub.d.ts +585 -0
- package/dist/TxPubSub.d.ts.map +1 -0
- package/dist/TxPubSub.js +521 -0
- package/dist/TxPubSub.js.map +1 -0
- package/dist/TxQueue.d.ts +32 -32
- package/dist/TxQueue.d.ts.map +1 -1
- package/dist/TxQueue.js +26 -26
- package/dist/TxQueue.js.map +1 -1
- package/dist/TxReentrantLock.d.ts +523 -0
- package/dist/TxReentrantLock.d.ts.map +1 -0
- package/dist/TxReentrantLock.js +504 -0
- package/dist/TxReentrantLock.js.map +1 -0
- package/dist/TxRef.d.ts +34 -34
- package/dist/TxRef.d.ts.map +1 -1
- package/dist/TxRef.js +21 -14
- package/dist/TxRef.js.map +1 -1
- package/dist/TxSemaphore.d.ts +8 -8
- package/dist/TxSemaphore.d.ts.map +1 -1
- package/dist/TxSemaphore.js +7 -7
- package/dist/TxSemaphore.js.map +1 -1
- package/dist/TxSubscriptionRef.d.ts +508 -0
- package/dist/TxSubscriptionRef.d.ts.map +1 -0
- package/dist/TxSubscriptionRef.js +293 -0
- package/dist/TxSubscriptionRef.js.map +1 -0
- package/dist/Types.d.ts +84 -6
- package/dist/Types.d.ts.map +1 -1
- package/dist/index.d.ts +591 -20
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +591 -20
- package/dist/index.js.map +1 -1
- package/dist/internal/core.js +11 -3
- package/dist/internal/core.js.map +1 -1
- package/dist/internal/dateTime.js +3 -11
- package/dist/internal/dateTime.js.map +1 -1
- package/dist/internal/effect.js +263 -99
- package/dist/internal/effect.js.map +1 -1
- package/dist/internal/hashMap.js +5 -4
- package/dist/internal/hashMap.js.map +1 -1
- package/dist/internal/random.d.ts +2 -0
- package/dist/internal/random.d.ts.map +1 -0
- package/dist/internal/random.js +13 -0
- package/dist/internal/random.js.map +1 -0
- package/dist/internal/rcRef.js +3 -2
- package/dist/internal/rcRef.js.map +1 -1
- package/dist/internal/request.js +2 -2
- package/dist/internal/request.js.map +1 -1
- package/dist/internal/schema/annotations.js +2 -0
- package/dist/internal/schema/annotations.js.map +1 -1
- package/dist/internal/schema/schema.js +1 -0
- package/dist/internal/schema/schema.js.map +1 -1
- package/dist/internal/trie.js +5 -4
- package/dist/internal/trie.js.map +1 -1
- package/dist/testing/TestClock.d.ts +7 -6
- package/dist/testing/TestClock.d.ts.map +1 -1
- package/dist/testing/TestClock.js +6 -4
- package/dist/testing/TestClock.js.map +1 -1
- package/dist/testing/TestSchema.d.ts +8 -8
- package/dist/testing/TestSchema.d.ts.map +1 -1
- package/dist/testing/TestSchema.js.map +1 -1
- package/dist/unstable/ai/AiError.d.ts +128 -48
- package/dist/unstable/ai/AiError.d.ts.map +1 -1
- package/dist/unstable/ai/AiError.js +11 -12
- package/dist/unstable/ai/AiError.js.map +1 -1
- package/dist/unstable/ai/Chat.d.ts +3 -3
- package/dist/unstable/ai/Chat.d.ts.map +1 -1
- package/dist/unstable/ai/Chat.js +4 -3
- package/dist/unstable/ai/Chat.js.map +1 -1
- package/dist/unstable/ai/LanguageModel.d.ts +4 -2
- package/dist/unstable/ai/LanguageModel.d.ts.map +1 -1
- package/dist/unstable/ai/LanguageModel.js +86 -14
- package/dist/unstable/ai/LanguageModel.js.map +1 -1
- package/dist/unstable/ai/McpSchema.d.ts +163 -87
- package/dist/unstable/ai/McpSchema.d.ts.map +1 -1
- package/dist/unstable/ai/McpSchema.js +49 -12
- package/dist/unstable/ai/McpSchema.js.map +1 -1
- package/dist/unstable/ai/McpServer.d.ts +1 -1
- package/dist/unstable/ai/McpServer.d.ts.map +1 -1
- package/dist/unstable/ai/McpServer.js +35 -7
- package/dist/unstable/ai/McpServer.js.map +1 -1
- package/dist/unstable/ai/Model.d.ts +25 -7
- package/dist/unstable/ai/Model.d.ts.map +1 -1
- package/dist/unstable/ai/Model.js +22 -6
- package/dist/unstable/ai/Model.js.map +1 -1
- package/dist/unstable/ai/Prompt.d.ts +20 -20
- package/dist/unstable/ai/Prompt.d.ts.map +1 -1
- package/dist/unstable/ai/Response.d.ts +26 -26
- package/dist/unstable/ai/Response.d.ts.map +1 -1
- package/dist/unstable/ai/Response.js +1 -1
- package/dist/unstable/ai/Response.js.map +1 -1
- package/dist/unstable/ai/Tool.d.ts +19 -3
- package/dist/unstable/ai/Tool.d.ts.map +1 -1
- package/dist/unstable/ai/Tool.js +14 -9
- package/dist/unstable/ai/Tool.js.map +1 -1
- package/dist/unstable/ai/index.d.ts +1 -1
- package/dist/unstable/ai/index.js +1 -1
- package/dist/unstable/cli/CliError.d.ts +5 -5
- package/dist/unstable/cli/CliOutput.js +59 -6
- package/dist/unstable/cli/CliOutput.js.map +1 -1
- package/dist/unstable/cli/Command.d.ts +276 -19
- package/dist/unstable/cli/Command.d.ts.map +1 -1
- package/dist/unstable/cli/Command.js +234 -36
- package/dist/unstable/cli/Command.js.map +1 -1
- package/dist/unstable/cli/GlobalFlag.d.ts +125 -0
- package/dist/unstable/cli/GlobalFlag.d.ts.map +1 -0
- package/dist/unstable/cli/GlobalFlag.js +118 -0
- package/dist/unstable/cli/GlobalFlag.js.map +1 -0
- package/dist/unstable/cli/HelpDoc.d.ts +70 -2
- package/dist/unstable/cli/HelpDoc.d.ts.map +1 -1
- package/dist/unstable/cli/index.d.ts +4 -0
- package/dist/unstable/cli/index.d.ts.map +1 -1
- package/dist/unstable/cli/index.js +4 -0
- package/dist/unstable/cli/index.js.map +1 -1
- package/dist/unstable/cli/internal/command.d.ts +17 -8
- package/dist/unstable/cli/internal/command.d.ts.map +1 -1
- package/dist/unstable/cli/internal/command.js +32 -23
- package/dist/unstable/cli/internal/command.js.map +1 -1
- package/dist/unstable/cli/internal/completions/CommandDescriptor.js +7 -2
- package/dist/unstable/cli/internal/completions/CommandDescriptor.js.map +1 -1
- package/dist/unstable/cli/internal/help.d.ts +33 -0
- package/dist/unstable/cli/internal/help.d.ts.map +1 -0
- package/dist/unstable/cli/internal/help.js +107 -0
- package/dist/unstable/cli/internal/help.js.map +1 -0
- package/dist/unstable/cli/internal/parser.js +29 -36
- package/dist/unstable/cli/internal/parser.js.map +1 -1
- package/dist/unstable/cluster/ClusterCron.d.ts +1 -1
- package/dist/unstable/cluster/ClusterCron.d.ts.map +1 -1
- package/dist/unstable/cluster/ClusterCron.js +1 -1
- package/dist/unstable/cluster/ClusterCron.js.map +1 -1
- package/dist/unstable/cluster/ClusterWorkflowEngine.d.ts.map +1 -1
- package/dist/unstable/cluster/ClusterWorkflowEngine.js +4 -3
- package/dist/unstable/cluster/ClusterWorkflowEngine.js.map +1 -1
- package/dist/unstable/cluster/Entity.d.ts +7 -6
- package/dist/unstable/cluster/Entity.d.ts.map +1 -1
- package/dist/unstable/cluster/Entity.js.map +1 -1
- package/dist/unstable/cluster/EntityResource.d.ts +2 -2
- package/dist/unstable/cluster/EntityResource.d.ts.map +1 -1
- package/dist/unstable/cluster/Envelope.d.ts +1 -1
- package/dist/unstable/cluster/K8sHttpClient.d.ts +1 -1
- package/dist/unstable/cluster/K8sHttpClient.js +4 -4
- package/dist/unstable/cluster/K8sHttpClient.js.map +1 -1
- package/dist/unstable/cluster/Message.d.ts +10 -10
- package/dist/unstable/cluster/MessageStorage.d.ts.map +1 -1
- package/dist/unstable/cluster/MessageStorage.js +2 -1
- package/dist/unstable/cluster/MessageStorage.js.map +1 -1
- package/dist/unstable/cluster/Reply.d.ts +6 -6
- package/dist/unstable/cluster/Runner.d.ts +1 -1
- package/dist/unstable/cluster/Runners.d.ts.map +1 -1
- package/dist/unstable/cluster/Runners.js +4 -3
- package/dist/unstable/cluster/Runners.js.map +1 -1
- package/dist/unstable/cluster/Sharding.d.ts +2 -2
- package/dist/unstable/cluster/Sharding.d.ts.map +1 -1
- package/dist/unstable/cluster/Sharding.js +9 -7
- package/dist/unstable/cluster/Sharding.js.map +1 -1
- package/dist/unstable/cluster/ShardingConfig.d.ts +21 -21
- package/dist/unstable/cluster/ShardingConfig.d.ts.map +1 -1
- package/dist/unstable/cluster/ShardingConfig.js +20 -20
- package/dist/unstable/cluster/ShardingConfig.js.map +1 -1
- package/dist/unstable/cluster/SqlRunnerStorage.js +1 -1
- package/dist/unstable/cluster/SqlRunnerStorage.js.map +1 -1
- package/dist/unstable/cluster/internal/entityManager.js +5 -4
- package/dist/unstable/cluster/internal/entityManager.js.map +1 -1
- package/dist/unstable/cluster/internal/entityReaper.js +2 -1
- package/dist/unstable/cluster/internal/entityReaper.js.map +1 -1
- package/dist/unstable/cluster/internal/resourceRef.js +2 -1
- package/dist/unstable/cluster/internal/resourceRef.js.map +1 -1
- package/dist/unstable/devtools/DevToolsSchema.d.ts +36 -36
- package/dist/unstable/encoding/Msgpack.d.ts +1 -1
- package/dist/unstable/encoding/Ndjson.d.ts +1 -1
- package/dist/unstable/encoding/Sse.d.ts +4 -4
- package/dist/unstable/encoding/Sse.d.ts.map +1 -1
- package/dist/unstable/encoding/Sse.js +1 -1
- package/dist/unstable/encoding/Sse.js.map +1 -1
- package/dist/unstable/eventlog/EventJournal.d.ts +2 -2
- package/dist/unstable/eventlog/EventLog.d.ts.map +1 -1
- package/dist/unstable/eventlog/EventLog.js +2 -1
- package/dist/unstable/eventlog/EventLog.js.map +1 -1
- package/dist/unstable/eventlog/EventLogRemote.d.ts +6 -6
- package/dist/unstable/http/Cookies.d.ts +3 -3
- package/dist/unstable/http/Cookies.d.ts.map +1 -1
- package/dist/unstable/http/Cookies.js +2 -2
- package/dist/unstable/http/Cookies.js.map +1 -1
- package/dist/unstable/http/Headers.d.ts.map +1 -1
- package/dist/unstable/http/Headers.js +27 -10
- package/dist/unstable/http/Headers.js.map +1 -1
- package/dist/unstable/http/HttpBody.d.ts +17 -2
- package/dist/unstable/http/HttpBody.d.ts.map +1 -1
- package/dist/unstable/http/HttpBody.js +28 -1
- package/dist/unstable/http/HttpBody.js.map +1 -1
- package/dist/unstable/http/HttpClient.d.ts +37 -13
- package/dist/unstable/http/HttpClient.d.ts.map +1 -1
- package/dist/unstable/http/HttpClient.js +4 -4
- package/dist/unstable/http/HttpClient.js.map +1 -1
- package/dist/unstable/http/HttpClientError.d.ts +7 -7
- package/dist/unstable/http/HttpClientRequest.d.ts +27 -11
- package/dist/unstable/http/HttpClientRequest.d.ts.map +1 -1
- package/dist/unstable/http/HttpClientRequest.js +15 -3
- package/dist/unstable/http/HttpClientRequest.js.map +1 -1
- package/dist/unstable/http/HttpEffect.d.ts +3 -8
- package/dist/unstable/http/HttpEffect.d.ts.map +1 -1
- package/dist/unstable/http/HttpEffect.js +42 -56
- package/dist/unstable/http/HttpEffect.js.map +1 -1
- package/dist/unstable/http/HttpMethod.d.ts +4 -4
- package/dist/unstable/http/HttpMethod.d.ts.map +1 -1
- package/dist/unstable/http/HttpMethod.js +3 -3
- package/dist/unstable/http/HttpMethod.js.map +1 -1
- package/dist/unstable/http/HttpMiddleware.d.ts +1 -6
- package/dist/unstable/http/HttpMiddleware.d.ts.map +1 -1
- package/dist/unstable/http/HttpMiddleware.js +8 -17
- package/dist/unstable/http/HttpMiddleware.js.map +1 -1
- package/dist/unstable/http/HttpServerError.d.ts +20 -33
- package/dist/unstable/http/HttpServerError.d.ts.map +1 -1
- package/dist/unstable/http/HttpServerError.js +37 -44
- package/dist/unstable/http/HttpServerError.js.map +1 -1
- package/dist/unstable/http/HttpServerRequest.d.ts +1 -1
- package/dist/unstable/http/HttpServerRequest.d.ts.map +1 -1
- package/dist/unstable/http/HttpServerRespondable.d.ts +2 -2
- package/dist/unstable/http/HttpServerRespondable.d.ts.map +1 -1
- package/dist/unstable/http/HttpServerRespondable.js +5 -5
- package/dist/unstable/http/HttpServerRespondable.js.map +1 -1
- package/dist/unstable/http/HttpServerResponse.d.ts +2 -1
- package/dist/unstable/http/HttpServerResponse.d.ts.map +1 -1
- package/dist/unstable/http/HttpServerResponse.js +3 -1
- package/dist/unstable/http/HttpServerResponse.js.map +1 -1
- package/dist/unstable/http/Multipart.d.ts +3 -3
- package/dist/unstable/http/UrlParams.d.ts +14 -6
- package/dist/unstable/http/UrlParams.d.ts.map +1 -1
- package/dist/unstable/http/UrlParams.js +1 -1
- package/dist/unstable/http/UrlParams.js.map +1 -1
- package/dist/unstable/http/internal/preResponseHandler.d.ts +2 -0
- package/dist/unstable/http/internal/preResponseHandler.d.ts.map +1 -0
- package/dist/unstable/http/internal/preResponseHandler.js +10 -0
- package/dist/unstable/http/internal/preResponseHandler.js.map +1 -0
- package/dist/unstable/httpapi/HttpApi.d.ts +3 -3
- package/dist/unstable/httpapi/HttpApi.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApi.js.map +1 -1
- package/dist/unstable/httpapi/HttpApiBuilder.d.ts +11 -5
- package/dist/unstable/httpapi/HttpApiBuilder.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApiBuilder.js +23 -12
- package/dist/unstable/httpapi/HttpApiBuilder.js.map +1 -1
- package/dist/unstable/httpapi/HttpApiClient.d.ts +7 -2
- package/dist/unstable/httpapi/HttpApiClient.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApiClient.js +3 -3
- package/dist/unstable/httpapi/HttpApiClient.js.map +1 -1
- package/dist/unstable/httpapi/HttpApiEndpoint.d.ts +31 -44
- package/dist/unstable/httpapi/HttpApiEndpoint.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApiEndpoint.js +15 -24
- package/dist/unstable/httpapi/HttpApiEndpoint.js.map +1 -1
- package/dist/unstable/httpapi/HttpApiError.d.ts +11 -0
- package/dist/unstable/httpapi/HttpApiError.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApiError.js +29 -9
- package/dist/unstable/httpapi/HttpApiError.js.map +1 -1
- package/dist/unstable/httpapi/HttpApiGroup.d.ts +3 -3
- package/dist/unstable/httpapi/HttpApiGroup.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApiGroup.js.map +1 -1
- package/dist/unstable/httpapi/HttpApiMiddleware.d.ts +4 -4
- package/dist/unstable/httpapi/HttpApiMiddleware.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApiMiddleware.js.map +1 -1
- package/dist/unstable/httpapi/HttpApiScalar.d.ts +6 -0
- package/dist/unstable/httpapi/HttpApiScalar.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApiScalar.js.map +1 -1
- package/dist/unstable/httpapi/HttpApiSecurity.d.ts +2 -2
- package/dist/unstable/httpapi/HttpApiSecurity.d.ts.map +1 -1
- package/dist/unstable/httpapi/HttpApiSecurity.js.map +1 -1
- package/dist/unstable/httpapi/OpenApi.d.ts.map +1 -1
- package/dist/unstable/httpapi/OpenApi.js +32 -21
- package/dist/unstable/httpapi/OpenApi.js.map +1 -1
- package/dist/unstable/observability/Otlp.d.ts +12 -12
- package/dist/unstable/observability/Otlp.d.ts.map +1 -1
- package/dist/unstable/observability/OtlpExporter.d.ts +2 -2
- package/dist/unstable/observability/OtlpExporter.d.ts.map +1 -1
- package/dist/unstable/observability/OtlpExporter.js +1 -1
- package/dist/unstable/observability/OtlpExporter.js.map +1 -1
- package/dist/unstable/observability/OtlpLogger.d.ts +4 -4
- package/dist/unstable/observability/OtlpLogger.d.ts.map +1 -1
- package/dist/unstable/observability/OtlpLogger.js +7 -4
- package/dist/unstable/observability/OtlpLogger.js.map +1 -1
- package/dist/unstable/observability/OtlpMetrics.d.ts +4 -4
- package/dist/unstable/observability/OtlpMetrics.d.ts.map +1 -1
- package/dist/unstable/observability/OtlpTracer.d.ts +4 -4
- package/dist/unstable/observability/OtlpTracer.d.ts.map +1 -1
- package/dist/unstable/persistence/KeyValueStore.d.ts +1 -1
- package/dist/unstable/persistence/KeyValueStore.js +6 -6
- package/dist/unstable/persistence/KeyValueStore.js.map +1 -1
- package/dist/unstable/persistence/Persistable.d.ts +2 -2
- package/dist/unstable/persistence/Persistable.d.ts.map +1 -1
- package/dist/unstable/persistence/PersistedCache.d.ts +6 -5
- package/dist/unstable/persistence/PersistedCache.d.ts.map +1 -1
- package/dist/unstable/persistence/PersistedCache.js +2 -1
- package/dist/unstable/persistence/PersistedCache.js.map +1 -1
- package/dist/unstable/persistence/PersistedQueue.d.ts +12 -12
- package/dist/unstable/persistence/PersistedQueue.d.ts.map +1 -1
- package/dist/unstable/persistence/PersistedQueue.js +12 -11
- package/dist/unstable/persistence/PersistedQueue.js.map +1 -1
- package/dist/unstable/persistence/Persistence.d.ts +1 -1
- package/dist/unstable/persistence/Persistence.d.ts.map +1 -1
- package/dist/unstable/persistence/Persistence.js +2 -2
- package/dist/unstable/persistence/Persistence.js.map +1 -1
- package/dist/unstable/persistence/RateLimiter.d.ts +3 -3
- package/dist/unstable/persistence/RateLimiter.d.ts.map +1 -1
- package/dist/unstable/persistence/RateLimiter.js +1 -1
- package/dist/unstable/persistence/RateLimiter.js.map +1 -1
- package/dist/unstable/process/ChildProcess.d.ts +5 -128
- package/dist/unstable/process/ChildProcess.d.ts.map +1 -1
- package/dist/unstable/process/ChildProcess.js +1 -65
- package/dist/unstable/process/ChildProcess.js.map +1 -1
- package/dist/unstable/process/ChildProcessSpawner.d.ts +45 -7
- package/dist/unstable/process/ChildProcessSpawner.d.ts.map +1 -1
- package/dist/unstable/process/ChildProcessSpawner.js +21 -1
- package/dist/unstable/process/ChildProcessSpawner.js.map +1 -1
- package/dist/unstable/reactivity/Atom.d.ts +10 -10
- package/dist/unstable/reactivity/Atom.d.ts.map +1 -1
- package/dist/unstable/reactivity/Atom.js +16 -13
- package/dist/unstable/reactivity/Atom.js.map +1 -1
- package/dist/unstable/reactivity/AtomHttpApi.d.ts +8 -8
- package/dist/unstable/reactivity/AtomHttpApi.d.ts.map +1 -1
- package/dist/unstable/reactivity/AtomHttpApi.js +3 -3
- package/dist/unstable/reactivity/AtomHttpApi.js.map +1 -1
- package/dist/unstable/reactivity/AtomRegistry.d.ts +6 -0
- package/dist/unstable/reactivity/AtomRegistry.d.ts.map +1 -1
- package/dist/unstable/reactivity/AtomRegistry.js +24 -7
- package/dist/unstable/reactivity/AtomRegistry.js.map +1 -1
- package/dist/unstable/reactivity/AtomRpc.d.ts +1 -1
- package/dist/unstable/reactivity/AtomRpc.d.ts.map +1 -1
- package/dist/unstable/reactivity/AtomRpc.js +1 -1
- package/dist/unstable/reactivity/AtomRpc.js.map +1 -1
- package/dist/unstable/reactivity/Hydration.d.ts +39 -0
- package/dist/unstable/reactivity/Hydration.d.ts.map +1 -0
- package/dist/unstable/reactivity/Hydration.js +76 -0
- package/dist/unstable/reactivity/Hydration.js.map +1 -0
- package/dist/unstable/reactivity/index.d.ts +4 -0
- package/dist/unstable/reactivity/index.d.ts.map +1 -1
- package/dist/unstable/reactivity/index.js +4 -0
- package/dist/unstable/reactivity/index.js.map +1 -1
- package/dist/unstable/rpc/Rpc.d.ts +4 -4
- package/dist/unstable/rpc/Rpc.d.ts.map +1 -1
- package/dist/unstable/rpc/Rpc.js.map +1 -1
- package/dist/unstable/rpc/RpcClient.d.ts +5 -26
- package/dist/unstable/rpc/RpcClient.d.ts.map +1 -1
- package/dist/unstable/rpc/RpcClient.js +6 -13
- package/dist/unstable/rpc/RpcClient.js.map +1 -1
- package/dist/unstable/rpc/RpcGroup.d.ts +2 -2
- package/dist/unstable/rpc/RpcGroup.d.ts.map +1 -1
- package/dist/unstable/rpc/RpcGroup.js.map +1 -1
- package/dist/unstable/rpc/RpcMiddleware.d.ts +3 -3
- package/dist/unstable/rpc/RpcMiddleware.d.ts.map +1 -1
- package/dist/unstable/rpc/RpcMiddleware.js.map +1 -1
- package/dist/unstable/rpc/RpcSchema.d.ts +13 -0
- package/dist/unstable/rpc/RpcSchema.d.ts.map +1 -1
- package/dist/unstable/rpc/RpcSchema.js +14 -0
- package/dist/unstable/rpc/RpcSchema.js.map +1 -1
- package/dist/unstable/rpc/RpcSerialization.d.ts.map +1 -1
- package/dist/unstable/rpc/RpcSerialization.js +34 -9
- package/dist/unstable/rpc/RpcSerialization.js.map +1 -1
- package/dist/unstable/rpc/RpcServer.d.ts +0 -7
- package/dist/unstable/rpc/RpcServer.d.ts.map +1 -1
- package/dist/unstable/rpc/RpcServer.js +15 -15
- package/dist/unstable/rpc/RpcServer.js.map +1 -1
- package/dist/unstable/rpc/Utils.d.ts.map +1 -1
- package/dist/unstable/rpc/Utils.js +2 -1
- package/dist/unstable/rpc/Utils.js.map +1 -1
- package/dist/unstable/schema/Model.d.ts +1 -1
- package/dist/unstable/schema/Model.d.ts.map +1 -1
- package/dist/unstable/schema/VariantSchema.d.ts +3 -3
- package/dist/unstable/schema/VariantSchema.d.ts.map +1 -1
- package/dist/unstable/schema/VariantSchema.js +3 -3
- package/dist/unstable/schema/VariantSchema.js.map +1 -1
- package/dist/unstable/socket/Socket.d.ts +4 -4
- package/dist/unstable/socket/Socket.d.ts.map +1 -1
- package/dist/unstable/socket/Socket.js +6 -5
- package/dist/unstable/socket/Socket.js.map +1 -1
- package/dist/unstable/socket/SocketServer.d.ts +3 -3
- package/dist/unstable/sql/Migrator.d.ts +1 -1
- package/dist/unstable/sql/SqlClient.d.ts +1 -1
- package/dist/unstable/sql/SqlClient.d.ts.map +1 -1
- package/dist/unstable/sql/SqlError.d.ts +14 -14
- package/dist/unstable/sql/SqlError.d.ts.map +1 -1
- package/dist/unstable/sql/SqlError.js +9 -3
- package/dist/unstable/sql/SqlError.js.map +1 -1
- package/dist/unstable/sql/SqlModel.d.ts +2 -2
- package/dist/unstable/sql/SqlModel.d.ts.map +1 -1
- package/dist/unstable/sql/SqlModel.js +3 -3
- package/dist/unstable/sql/SqlModel.js.map +1 -1
- package/dist/unstable/sql/SqlSchema.d.ts +16 -5
- package/dist/unstable/sql/SqlSchema.d.ts.map +1 -1
- package/dist/unstable/sql/SqlSchema.js +17 -7
- package/dist/unstable/sql/SqlSchema.js.map +1 -1
- package/dist/unstable/sql/Statement.js +0 -1
- package/dist/unstable/sql/Statement.js.map +1 -1
- package/dist/unstable/workers/Worker.d.ts.map +1 -1
- package/dist/unstable/workers/Worker.js +2 -1
- package/dist/unstable/workers/Worker.js.map +1 -1
- package/dist/unstable/workflow/DurableClock.d.ts +3 -3
- package/dist/unstable/workflow/DurableClock.d.ts.map +1 -1
- package/dist/unstable/workflow/DurableClock.js +3 -3
- package/dist/unstable/workflow/DurableClock.js.map +1 -1
- package/dist/unstable/workflow/DurableDeferred.js +2 -2
- package/dist/unstable/workflow/DurableDeferred.js.map +1 -1
- package/dist/unstable/workflow/Workflow.d.ts +3 -3
- package/dist/unstable/workflow/Workflow.d.ts.map +1 -1
- package/dist/unstable/workflow/Workflow.js +1 -1
- package/dist/unstable/workflow/Workflow.js.map +1 -1
- package/dist/unstable/workflow/WorkflowEngine.d.ts +12 -1
- package/dist/unstable/workflow/WorkflowEngine.d.ts.map +1 -1
- package/dist/unstable/workflow/WorkflowEngine.js +137 -1
- package/dist/unstable/workflow/WorkflowEngine.js.map +1 -1
- package/package.json +2 -2
- package/src/Array.ts +190 -342
- package/src/Cache.ts +9 -8
- package/src/Cause.ts +1 -1
- package/src/Channel.ts +554 -138
- package/src/Chunk.ts +81 -268
- package/src/Combiner.ts +280 -13
- package/src/Config.ts +183 -21
- package/src/Data.ts +538 -374
- package/src/DateTime.ts +24 -164
- package/src/Duration.ts +15 -15
- package/src/Effect.ts +991 -800
- package/src/Encoding.ts +879 -0
- package/src/Equal.ts +278 -111
- package/src/ErrorReporter.ts +459 -0
- package/src/Fiber.ts +9 -2
- package/src/FileSystem.ts +7 -8
- package/src/Filter.ts +48 -58
- package/src/Formatter.ts +253 -51
- package/src/Graph.ts +24 -11
- package/src/HashMap.ts +15 -14
- package/src/Iterable.ts +105 -50
- package/src/JsonSchema.ts +383 -10
- package/src/Latch.ts +112 -0
- package/src/Layer.ts +11 -15
- package/src/LayerMap.ts +5 -5
- package/src/LogLevel.ts +37 -0
- package/src/Logger.ts +33 -100
- package/src/ManagedRuntime.ts +1 -1
- package/src/Metric.ts +4 -4
- package/src/Optic.ts +948 -19
- package/src/Option.ts +30 -20
- package/src/Pipeable.ts +32 -1
- package/src/PlatformError.ts +5 -5
- package/src/Pool.ts +13 -11
- package/src/PubSub.ts +10 -9
- package/src/Pull.ts +1 -1
- package/src/Queue.ts +0 -1
- package/src/Random.ts +51 -14
- package/src/RcMap.ts +5 -5
- package/src/RcRef.ts +1 -1
- package/src/Record.ts +43 -152
- package/src/Reducer.ts +166 -7
- package/src/References.ts +4 -4
- package/src/Request.ts +3 -2
- package/src/RequestResolver.ts +9 -29
- package/src/Result.ts +13 -0
- package/src/Schedule.ts +318 -160
- package/src/Schema.ts +661 -116
- package/src/SchemaAST.ts +7 -6
- package/src/SchemaGetter.ts +12 -14
- package/src/SchemaParser.ts +11 -0
- package/src/SchemaRepresentation.ts +43 -24
- package/src/SchemaTransformation.ts +189 -4
- package/src/ScopedCache.ts +3 -3
- package/src/Semaphore.ts +356 -0
- package/src/ServiceMap.ts +47 -38
- package/src/Sink.ts +78 -26
- package/src/Stream.ts +566 -601
- package/src/Struct.ts +26 -0
- package/src/SubscriptionRef.ts +3 -2
- package/src/SynchronizedRef.ts +3 -2
- package/src/Trie.ts +18 -17
- package/src/TxChunk.ts +72 -53
- package/src/TxDeferred.ts +394 -0
- package/src/TxHashMap.ts +332 -285
- package/src/TxHashSet.ts +111 -116
- package/src/TxPriorityQueue.ts +767 -0
- package/src/TxPubSub.ts +789 -0
- package/src/TxQueue.ts +241 -251
- package/src/TxReentrantLock.ts +753 -0
- package/src/TxRef.ts +50 -38
- package/src/TxSemaphore.ts +29 -32
- package/src/TxSubscriptionRef.ts +639 -0
- package/src/Types.ts +78 -2
- package/src/index.ts +600 -21
- package/src/internal/core.ts +12 -5
- package/src/internal/dateTime.ts +9 -30
- package/src/internal/effect.ts +744 -265
- package/src/internal/hashMap.ts +9 -7
- package/src/internal/random.ts +20 -0
- package/src/internal/rcRef.ts +4 -3
- package/src/internal/request.ts +2 -2
- package/src/internal/schema/annotations.ts +2 -0
- package/src/internal/schema/schema.ts +1 -0
- package/src/internal/trie.ts +16 -9
- package/src/testing/TestClock.ts +13 -11
- package/src/testing/TestSchema.ts +10 -10
- package/src/unstable/ai/AiError.ts +97 -44
- package/src/unstable/ai/Chat.ts +12 -11
- package/src/unstable/ai/LanguageModel.ts +129 -25
- package/src/unstable/ai/McpSchema.ts +59 -13
- package/src/unstable/ai/McpServer.ts +48 -9
- package/src/unstable/ai/Model.ts +40 -9
- package/src/unstable/ai/Prompt.ts +37 -37
- package/src/unstable/ai/Response.ts +25 -25
- package/src/unstable/ai/Tool.ts +19 -13
- package/src/unstable/ai/index.ts +1 -1
- package/src/unstable/cli/CliOutput.ts +75 -6
- package/src/unstable/cli/Command.ts +501 -60
- package/src/unstable/cli/GlobalFlag.ts +243 -0
- package/src/unstable/cli/HelpDoc.ts +80 -2
- package/src/unstable/cli/index.ts +5 -0
- package/src/unstable/cli/internal/command.ts +50 -34
- package/src/unstable/cli/internal/completions/CommandDescriptor.ts +7 -2
- package/src/unstable/cli/internal/help.ts +146 -0
- package/src/unstable/cli/internal/parser.ts +33 -54
- package/src/unstable/cluster/ClusterCron.ts +2 -2
- package/src/unstable/cluster/ClusterWorkflowEngine.ts +5 -4
- package/src/unstable/cluster/Entity.ts +11 -10
- package/src/unstable/cluster/EntityResource.ts +4 -4
- package/src/unstable/cluster/Envelope.ts +1 -1
- package/src/unstable/cluster/K8sHttpClient.ts +5 -5
- package/src/unstable/cluster/MessageStorage.ts +3 -5
- package/src/unstable/cluster/Runners.ts +6 -5
- package/src/unstable/cluster/Sharding.ts +12 -10
- package/src/unstable/cluster/ShardingConfig.ts +30 -31
- package/src/unstable/cluster/SqlRunnerStorage.ts +1 -1
- package/src/unstable/cluster/internal/entityManager.ts +9 -8
- package/src/unstable/cluster/internal/entityReaper.ts +2 -1
- package/src/unstable/cluster/internal/resourceRef.ts +2 -1
- package/src/unstable/encoding/Sse.ts +3 -5
- package/src/unstable/eventlog/EventLog.ts +2 -1
- package/src/unstable/http/Cookies.ts +3 -3
- package/src/unstable/http/Headers.ts +28 -13
- package/src/unstable/http/HttpBody.ts +42 -1
- package/src/unstable/http/HttpClient.ts +58 -23
- package/src/unstable/http/HttpClientRequest.ts +38 -13
- package/src/unstable/http/HttpEffect.ts +46 -68
- package/src/unstable/http/HttpMethod.ts +16 -4
- package/src/unstable/http/HttpMiddleware.ts +9 -24
- package/src/unstable/http/HttpServerError.ts +42 -45
- package/src/unstable/http/HttpServerRequest.ts +1 -1
- package/src/unstable/http/HttpServerRespondable.ts +6 -6
- package/src/unstable/http/HttpServerResponse.ts +4 -2
- package/src/unstable/http/Multipart.ts +2 -2
- package/src/unstable/http/UrlParams.ts +20 -5
- package/src/unstable/http/internal/preResponseHandler.ts +15 -0
- package/src/unstable/httpapi/HttpApi.ts +5 -5
- package/src/unstable/httpapi/HttpApiBuilder.ts +77 -21
- package/src/unstable/httpapi/HttpApiClient.ts +14 -6
- package/src/unstable/httpapi/HttpApiEndpoint.ts +67 -83
- package/src/unstable/httpapi/HttpApiError.ts +30 -9
- package/src/unstable/httpapi/HttpApiGroup.ts +6 -6
- package/src/unstable/httpapi/HttpApiMiddleware.ts +4 -4
- package/src/unstable/httpapi/HttpApiScalar.ts +6 -0
- package/src/unstable/httpapi/HttpApiSecurity.ts +3 -3
- package/src/unstable/httpapi/OpenApi.ts +41 -23
- package/src/unstable/observability/Otlp.ts +12 -12
- package/src/unstable/observability/OtlpExporter.ts +3 -3
- package/src/unstable/observability/OtlpLogger.ts +13 -9
- package/src/unstable/observability/OtlpMetrics.ts +4 -4
- package/src/unstable/observability/OtlpTracer.ts +4 -4
- package/src/unstable/persistence/KeyValueStore.ts +6 -6
- package/src/unstable/persistence/Persistable.ts +2 -2
- package/src/unstable/persistence/PersistedCache.ts +20 -9
- package/src/unstable/persistence/PersistedQueue.ts +25 -24
- package/src/unstable/persistence/Persistence.ts +3 -3
- package/src/unstable/persistence/RateLimiter.ts +4 -4
- package/src/unstable/process/ChildProcess.ts +6 -208
- package/src/unstable/process/ChildProcessSpawner.ts +75 -14
- package/src/unstable/reactivity/Atom.ts +27 -25
- package/src/unstable/reactivity/AtomHttpApi.ts +21 -20
- package/src/unstable/reactivity/AtomRegistry.ts +31 -7
- package/src/unstable/reactivity/AtomRpc.ts +3 -3
- package/src/unstable/reactivity/Hydration.ts +112 -0
- package/src/unstable/reactivity/index.ts +5 -0
- package/src/unstable/rpc/Rpc.ts +6 -6
- package/src/unstable/rpc/RpcClient.ts +12 -54
- package/src/unstable/rpc/RpcGroup.ts +4 -4
- package/src/unstable/rpc/RpcMiddleware.ts +3 -3
- package/src/unstable/rpc/RpcSchema.ts +17 -0
- package/src/unstable/rpc/RpcSerialization.ts +44 -9
- package/src/unstable/rpc/RpcServer.ts +21 -30
- package/src/unstable/rpc/Utils.ts +2 -1
- package/src/unstable/schema/VariantSchema.ts +6 -6
- package/src/unstable/socket/Socket.ts +16 -17
- package/src/unstable/sql/SqlClient.ts +1 -1
- package/src/unstable/sql/SqlError.ts +11 -9
- package/src/unstable/sql/SqlModel.ts +5 -5
- package/src/unstable/sql/SqlSchema.ts +41 -25
- package/src/unstable/sql/Statement.ts +0 -1
- package/src/unstable/workers/Worker.ts +2 -1
- package/src/unstable/workflow/DurableClock.ts +8 -8
- package/src/unstable/workflow/DurableDeferred.ts +2 -2
- package/src/unstable/workflow/Workflow.ts +6 -2
- package/src/unstable/workflow/WorkflowEngine.ts +185 -2
- package/dist/PartitionedSemaphore.d.ts +0 -52
- package/dist/PartitionedSemaphore.d.ts.map +0 -1
- package/dist/PartitionedSemaphore.js.map +0 -1
- package/dist/encoding/Base64.d.ts +0 -67
- package/dist/encoding/Base64.d.ts.map +0 -1
- package/dist/encoding/Base64.js +0 -146
- package/dist/encoding/Base64.js.map +0 -1
- package/dist/encoding/Base64Url.d.ts +0 -60
- package/dist/encoding/Base64Url.d.ts.map +0 -1
- package/dist/encoding/Base64Url.js +0 -89
- package/dist/encoding/Base64Url.js.map +0 -1
- package/dist/encoding/EncodingError.d.ts +0 -31
- package/dist/encoding/EncodingError.d.ts.map +0 -1
- package/dist/encoding/EncodingError.js +0 -22
- package/dist/encoding/EncodingError.js.map +0 -1
- package/dist/encoding/Hex.d.ts +0 -61
- package/dist/encoding/Hex.d.ts.map +0 -1
- package/dist/encoding/Hex.js +0 -115
- package/dist/encoding/Hex.js.map +0 -1
- package/dist/encoding/index.d.ts +0 -26
- package/dist/encoding/index.d.ts.map +0 -1
- package/dist/encoding/index.js +0 -27
- package/dist/encoding/index.js.map +0 -1
- package/dist/unstable/cli/internal/builtInFlags.d.ts +0 -7
- package/dist/unstable/cli/internal/builtInFlags.d.ts.map +0 -1
- package/dist/unstable/cli/internal/builtInFlags.js +0 -44
- package/dist/unstable/cli/internal/builtInFlags.js.map +0 -1
- package/src/PartitionedSemaphore.ts +0 -182
- package/src/encoding/Base64.ts +0 -366
- package/src/encoding/Base64Url.ts +0 -104
- package/src/encoding/EncodingError.ts +0 -35
- package/src/encoding/Hex.ts +0 -390
- package/src/encoding/index.ts +0 -31
- package/src/unstable/cli/internal/builtInFlags.ts +0 -78
|
@@ -61,11 +61,11 @@ export declare namespace HttpClient {
|
|
|
61
61
|
|
|
62
62
|
readonly get: (
|
|
63
63
|
url: string | URL,
|
|
64
|
-
options?: HttpClientRequest.Options.
|
|
64
|
+
options?: HttpClientRequest.Options.NoUrl
|
|
65
65
|
) => Effect.Effect<HttpClientResponse.HttpClientResponse, E, R>
|
|
66
66
|
readonly head: (
|
|
67
67
|
url: string | URL,
|
|
68
|
-
options?: HttpClientRequest.Options.
|
|
68
|
+
options?: HttpClientRequest.Options.NoUrl
|
|
69
69
|
) => Effect.Effect<HttpClientResponse.HttpClientResponse, E, R>
|
|
70
70
|
readonly post: (
|
|
71
71
|
url: string | URL,
|
|
@@ -132,7 +132,7 @@ export const execute: (
|
|
|
132
132
|
* @since 4.0.0
|
|
133
133
|
* @category accessors
|
|
134
134
|
*/
|
|
135
|
-
export const get: (url: string | URL, options?: HttpClientRequest.Options.
|
|
135
|
+
export const get: (url: string | URL, options?: HttpClientRequest.Options.NoUrl | undefined) => Effect.Effect<
|
|
136
136
|
HttpClientResponse.HttpClientResponse,
|
|
137
137
|
Error.HttpClientError,
|
|
138
138
|
HttpClient
|
|
@@ -142,7 +142,7 @@ export const get: (url: string | URL, options?: HttpClientRequest.Options.NoBody
|
|
|
142
142
|
* @since 4.0.0
|
|
143
143
|
* @category accessors
|
|
144
144
|
*/
|
|
145
|
-
export const head: (url: string | URL, options?: HttpClientRequest.Options.
|
|
145
|
+
export const head: (url: string | URL, options?: HttpClientRequest.Options.NoUrl | undefined) => Effect.Effect<
|
|
146
146
|
HttpClientResponse.HttpClientResponse,
|
|
147
147
|
Error.HttpClientError,
|
|
148
148
|
HttpClient
|
|
@@ -928,7 +928,7 @@ export const retry: {
|
|
|
928
928
|
/**
|
|
929
929
|
* Retries common transient errors, such as rate limiting, timeouts or network issues.
|
|
930
930
|
*
|
|
931
|
-
* Use `
|
|
931
|
+
* Use `retryOn` to focus on retrying errors, transient responses, or both.
|
|
932
932
|
*
|
|
933
933
|
* Specifying a `while` predicate allows you to consider other errors as
|
|
934
934
|
* transient, and is ignored in "response-only" mode.
|
|
@@ -940,7 +940,7 @@ export const retryTransient: {
|
|
|
940
940
|
/**
|
|
941
941
|
* Retries common transient errors, such as rate limiting, timeouts or network issues.
|
|
942
942
|
*
|
|
943
|
-
* Use `
|
|
943
|
+
* Use `retryOn` to focus on retrying errors, transient responses, or both.
|
|
944
944
|
*
|
|
945
945
|
* Specifying a `while` predicate allows you to consider other errors as
|
|
946
946
|
* transient, and is ignored in "response-only" mode.
|
|
@@ -949,26 +949,29 @@ export const retryTransient: {
|
|
|
949
949
|
* @category error handling
|
|
950
950
|
*/
|
|
951
951
|
<
|
|
952
|
-
B,
|
|
953
952
|
E,
|
|
953
|
+
B = never,
|
|
954
954
|
ES = never,
|
|
955
955
|
R1 = never,
|
|
956
|
-
const
|
|
957
|
-
|
|
958
|
-
|
|
956
|
+
const RetryOn extends "errors-only" | "response-only" | "errors-and-responses" =
|
|
957
|
+
| "errors-only"
|
|
958
|
+
| "response-only"
|
|
959
|
+
| "errors-and-responses",
|
|
960
|
+
Input = RetryOn extends "errors-only" ? E
|
|
961
|
+
: RetryOn extends "response-only" ? HttpClientResponse.HttpClientResponse
|
|
959
962
|
: HttpClientResponse.HttpClientResponse | E
|
|
960
963
|
>(
|
|
961
964
|
options: {
|
|
962
|
-
readonly
|
|
965
|
+
readonly retryOn?: RetryOn | undefined
|
|
963
966
|
readonly while?: Predicate.Predicate<NoInfer<E | ES>>
|
|
964
967
|
readonly schedule?: Schedule.Schedule<B, NoInfer<Input>, ES, R1>
|
|
965
968
|
readonly times?: number
|
|
966
|
-
}
|
|
969
|
+
}
|
|
967
970
|
): <R>(self: HttpClient.With<E, R>) => HttpClient.With<E | ES, R1 | R>
|
|
968
971
|
/**
|
|
969
972
|
* Retries common transient errors, such as rate limiting, timeouts or network issues.
|
|
970
973
|
*
|
|
971
|
-
* Use `
|
|
974
|
+
* Use `retryOn` to focus on retrying errors, transient responses, or both.
|
|
972
975
|
*
|
|
973
976
|
* Specifying a `while` predicate allows you to consider other errors as
|
|
974
977
|
* transient, and is ignored in "response-only" mode.
|
|
@@ -979,21 +982,53 @@ export const retryTransient: {
|
|
|
979
982
|
<
|
|
980
983
|
E,
|
|
981
984
|
R,
|
|
982
|
-
B,
|
|
985
|
+
B = never,
|
|
983
986
|
ES = never,
|
|
984
987
|
R1 = never,
|
|
985
|
-
const
|
|
986
|
-
|
|
987
|
-
|
|
988
|
+
const RetryOn extends "errors-only" | "response-only" | "errors-and-responses" =
|
|
989
|
+
| "errors-only"
|
|
990
|
+
| "response-only"
|
|
991
|
+
| "errors-and-responses",
|
|
992
|
+
Input = RetryOn extends "errors-only" ? E
|
|
993
|
+
: RetryOn extends "response-only" ? HttpClientResponse.HttpClientResponse
|
|
988
994
|
: HttpClientResponse.HttpClientResponse | E
|
|
989
995
|
>(
|
|
990
996
|
self: HttpClient.With<E, R>,
|
|
991
997
|
options: {
|
|
992
|
-
readonly
|
|
998
|
+
readonly retryOn?: RetryOn | undefined
|
|
993
999
|
readonly while?: Predicate.Predicate<NoInfer<E | ES>>
|
|
994
1000
|
readonly schedule?: Schedule.Schedule<B, NoInfer<Input>, ES, R1>
|
|
995
1001
|
readonly times?: number
|
|
996
|
-
}
|
|
1002
|
+
}
|
|
1003
|
+
): HttpClient.With<E | ES, R1 | R>
|
|
1004
|
+
/**
|
|
1005
|
+
* Retries common transient errors, such as rate limiting, timeouts or network issues.
|
|
1006
|
+
*
|
|
1007
|
+
* Use `retryOn` to focus on retrying errors, transient responses, or both.
|
|
1008
|
+
*
|
|
1009
|
+
* Specifying a `while` predicate allows you to consider other errors as
|
|
1010
|
+
* transient, and is ignored in "response-only" mode.
|
|
1011
|
+
*
|
|
1012
|
+
* @since 4.0.0
|
|
1013
|
+
* @category error handling
|
|
1014
|
+
*/
|
|
1015
|
+
<B, E, ES = never, R1 = never>(
|
|
1016
|
+
options: Schedule.Schedule<B, NoInfer<HttpClientResponse.HttpClientResponse | E>, ES, R1>
|
|
1017
|
+
): <R>(self: HttpClient.With<E, R>) => HttpClient.With<E | ES, R1 | R>
|
|
1018
|
+
/**
|
|
1019
|
+
* Retries common transient errors, such as rate limiting, timeouts or network issues.
|
|
1020
|
+
*
|
|
1021
|
+
* Use `retryOn` to focus on retrying errors, transient responses, or both.
|
|
1022
|
+
*
|
|
1023
|
+
* Specifying a `while` predicate allows you to consider other errors as
|
|
1024
|
+
* transient, and is ignored in "response-only" mode.
|
|
1025
|
+
*
|
|
1026
|
+
* @since 4.0.0
|
|
1027
|
+
* @category error handling
|
|
1028
|
+
*/
|
|
1029
|
+
<E, R, B, ES = never, R1 = never>(
|
|
1030
|
+
self: HttpClient.With<E, R>,
|
|
1031
|
+
options: Schedule.Schedule<B, NoInfer<HttpClientResponse.HttpClientResponse | E>, ES, R1>
|
|
997
1032
|
): HttpClient.With<E | ES, R1 | R>
|
|
998
1033
|
} = dual(
|
|
999
1034
|
2,
|
|
@@ -1006,26 +1041,26 @@ export const retryTransient: {
|
|
|
1006
1041
|
>(
|
|
1007
1042
|
self: HttpClient.With<E, R>,
|
|
1008
1043
|
options: {
|
|
1009
|
-
readonly
|
|
1044
|
+
readonly retryOn?: "errors-only" | "response-only" | "errors-and-responses" | undefined
|
|
1010
1045
|
readonly while?: Predicate.Predicate<E | ES>
|
|
1011
1046
|
readonly schedule?: Schedule.Schedule<B, any, ES, R1>
|
|
1012
1047
|
readonly times?: number
|
|
1013
1048
|
} | Schedule.Schedule<B, any, ES, R1>
|
|
1014
1049
|
): HttpClient.With<E | ES, R1 | R> => {
|
|
1015
1050
|
const isOnlySchedule = Schedule.isSchedule(options)
|
|
1016
|
-
const
|
|
1051
|
+
const retryOn = isOnlySchedule ? "errors-and-responses" : options.retryOn ?? "errors-and-responses"
|
|
1017
1052
|
const schedule = isOnlySchedule ? options : options.schedule
|
|
1018
1053
|
const passthroughSchedule = schedule && Schedule.passthrough(schedule)
|
|
1019
1054
|
const times = isOnlySchedule ? undefined : options.times
|
|
1020
1055
|
return transformResponse(
|
|
1021
1056
|
self,
|
|
1022
1057
|
flow(
|
|
1023
|
-
|
|
1058
|
+
retryOn === "errors-only" ? identity : Effect.repeat({
|
|
1024
1059
|
schedule: passthroughSchedule!,
|
|
1025
1060
|
times,
|
|
1026
1061
|
while: isTransientResponse
|
|
1027
1062
|
}),
|
|
1028
|
-
|
|
1063
|
+
retryOn === "response-only" ? identity : Effect.retry({
|
|
1029
1064
|
while: isOnlySchedule || options.while === undefined
|
|
1030
1065
|
? isTransientError
|
|
1031
1066
|
: Predicate.or(isTransientError, options.while),
|
|
@@ -61,12 +61,6 @@ export interface Options {
|
|
|
61
61
|
* @since 4.0.0
|
|
62
62
|
*/
|
|
63
63
|
export declare namespace Options {
|
|
64
|
-
/**
|
|
65
|
-
* @since 4.0.0
|
|
66
|
-
* @category models
|
|
67
|
-
*/
|
|
68
|
-
export interface NoBody extends Omit<Options, "method" | "url" | "body"> {}
|
|
69
|
-
|
|
70
64
|
/**
|
|
71
65
|
* @since 4.0.0
|
|
72
66
|
* @category models
|
|
@@ -133,7 +127,7 @@ export const make = <M extends HttpMethod>(
|
|
|
133
127
|
) =>
|
|
134
128
|
(
|
|
135
129
|
url: string | URL,
|
|
136
|
-
options?:
|
|
130
|
+
options?: Options.NoUrl | undefined
|
|
137
131
|
): HttpClientRequest =>
|
|
138
132
|
modify(empty, {
|
|
139
133
|
method,
|
|
@@ -145,7 +139,7 @@ export const make = <M extends HttpMethod>(
|
|
|
145
139
|
* @since 4.0.0
|
|
146
140
|
* @category constructors
|
|
147
141
|
*/
|
|
148
|
-
export const get: (url: string | URL, options?: Options.
|
|
142
|
+
export const get: (url: string | URL, options?: Options.NoUrl) => HttpClientRequest = make("GET")
|
|
149
143
|
|
|
150
144
|
/**
|
|
151
145
|
* @since 4.0.0
|
|
@@ -165,23 +159,33 @@ export const patch: (url: string | URL, options?: Options.NoUrl) => HttpClientRe
|
|
|
165
159
|
*/
|
|
166
160
|
export const put: (url: string | URL, options?: Options.NoUrl) => HttpClientRequest = make("PUT")
|
|
167
161
|
|
|
162
|
+
const del: (url: string | URL, options?: Options.NoUrl) => HttpClientRequest = make("DELETE")
|
|
163
|
+
|
|
164
|
+
export {
|
|
165
|
+
/**
|
|
166
|
+
* @since 4.0.0
|
|
167
|
+
* @category constructors
|
|
168
|
+
*/
|
|
169
|
+
del as delete
|
|
170
|
+
}
|
|
171
|
+
|
|
168
172
|
/**
|
|
169
173
|
* @since 4.0.0
|
|
170
174
|
* @category constructors
|
|
171
175
|
*/
|
|
172
|
-
export const
|
|
176
|
+
export const head: (url: string | URL, options?: Options.NoUrl) => HttpClientRequest = make("HEAD")
|
|
173
177
|
|
|
174
178
|
/**
|
|
175
179
|
* @since 4.0.0
|
|
176
180
|
* @category constructors
|
|
177
181
|
*/
|
|
178
|
-
export const
|
|
182
|
+
export const options: (url: string | URL, options?: Options.NoUrl) => HttpClientRequest = make("OPTIONS")
|
|
179
183
|
|
|
180
184
|
/**
|
|
181
185
|
* @since 4.0.0
|
|
182
186
|
* @category constructors
|
|
183
187
|
*/
|
|
184
|
-
export const
|
|
188
|
+
export const trace: (url: string | URL, options?: Options.NoUrl) => HttpClientRequest = make("TRACE")
|
|
185
189
|
|
|
186
190
|
/**
|
|
187
191
|
* @since 4.0.0
|
|
@@ -661,7 +665,7 @@ export const setBody: {
|
|
|
661
665
|
(self: HttpClientRequest, body: HttpBody.HttpBody): HttpClientRequest
|
|
662
666
|
} = dual(2, (self: HttpClientRequest, body: HttpBody.HttpBody): HttpClientRequest => {
|
|
663
667
|
let headers = self.headers
|
|
664
|
-
if (body._tag === "Empty") {
|
|
668
|
+
if (body._tag === "Empty" || body._tag === "FormData") {
|
|
665
669
|
headers = Headers.remove(Headers.remove(headers, "Content-Type"), "Content-length")
|
|
666
670
|
} else {
|
|
667
671
|
if (body.contentType) {
|
|
@@ -826,7 +830,28 @@ export const bodyFormData: {
|
|
|
826
830
|
* @category combinators
|
|
827
831
|
*/
|
|
828
832
|
(self: HttpClientRequest, body: FormData): HttpClientRequest
|
|
829
|
-
} = dual(2, (self: HttpClientRequest, body: FormData): HttpClientRequest => setBody(self, HttpBody.
|
|
833
|
+
} = dual(2, (self: HttpClientRequest, body: FormData): HttpClientRequest => setBody(self, HttpBody.formData(body)))
|
|
834
|
+
|
|
835
|
+
/**
|
|
836
|
+
* @since 4.0.0
|
|
837
|
+
* @category combinators
|
|
838
|
+
*/
|
|
839
|
+
export const bodyFormDataRecord: {
|
|
840
|
+
/**
|
|
841
|
+
* @since 4.0.0
|
|
842
|
+
* @category combinators
|
|
843
|
+
*/
|
|
844
|
+
(entries: HttpBody.FormDataInput): (self: HttpClientRequest) => HttpClientRequest
|
|
845
|
+
/**
|
|
846
|
+
* @since 4.0.0
|
|
847
|
+
* @category combinators
|
|
848
|
+
*/
|
|
849
|
+
(self: HttpClientRequest, entries: HttpBody.FormDataInput): HttpClientRequest
|
|
850
|
+
} = dual(
|
|
851
|
+
2,
|
|
852
|
+
(self: HttpClientRequest, entries: HttpBody.FormDataInput): HttpClientRequest =>
|
|
853
|
+
setBody(self, HttpBody.formDataRecord(entries))
|
|
854
|
+
)
|
|
830
855
|
|
|
831
856
|
/**
|
|
832
857
|
* @since 4.0.0
|
|
@@ -1,24 +1,24 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @since 4.0.0
|
|
3
3
|
*/
|
|
4
|
-
import type
|
|
4
|
+
import type * as Cause from "../../Cause.ts"
|
|
5
5
|
import * as Effect from "../../Effect.ts"
|
|
6
6
|
import * as Exit from "../../Exit.ts"
|
|
7
7
|
import * as Fiber from "../../Fiber.ts"
|
|
8
8
|
import { dual } from "../../Function.ts"
|
|
9
|
-
import {
|
|
9
|
+
import { reportCauseUnsafe } from "../../internal/effect.ts"
|
|
10
10
|
import * as Layer from "../../Layer.ts"
|
|
11
11
|
import * as Scope from "../../Scope.ts"
|
|
12
12
|
import * as ServiceMap from "../../ServiceMap.ts"
|
|
13
13
|
import * as Stream from "../../Stream.ts"
|
|
14
|
-
import * as UndefinedOr from "../../UndefinedOr.ts"
|
|
15
14
|
import * as HttpBody from "./HttpBody.ts"
|
|
16
15
|
import { type HttpMiddleware, tracer } from "./HttpMiddleware.ts"
|
|
17
|
-
import { causeResponse,
|
|
16
|
+
import { causeResponse, ClientAbort, HttpServerError, InternalError } from "./HttpServerError.ts"
|
|
18
17
|
import { HttpServerRequest } from "./HttpServerRequest.ts"
|
|
19
18
|
import * as Request from "./HttpServerRequest.ts"
|
|
20
19
|
import type { HttpServerResponse } from "./HttpServerResponse.ts"
|
|
21
20
|
import * as Response from "./HttpServerResponse.ts"
|
|
21
|
+
import { appendPreResponseHandlerUnsafe, requestPreResponseHandlers } from "./internal/preResponseHandler.ts"
|
|
22
22
|
|
|
23
23
|
/**
|
|
24
24
|
* @since 4.0.0
|
|
@@ -32,35 +32,12 @@ export const toHandled = <E, R, EH, RH>(
|
|
|
32
32
|
) => Effect.Effect<unknown, EH, RH>,
|
|
33
33
|
middleware?: HttpMiddleware | undefined
|
|
34
34
|
): Effect.Effect<void, never, Exclude<R | RH | HttpServerRequest, Scope.Scope>> => {
|
|
35
|
-
const
|
|
36
|
-
const fiber = Fiber.getCurrent()!
|
|
37
|
-
const request = ServiceMap.getUnsafe(fiber.services, HttpServerRequest)
|
|
38
|
-
const handler = fiber.getRef(PreResponseHandlers)
|
|
39
|
-
if (handler === undefined) {
|
|
40
|
-
;(request as any)[handledSymbol] = true
|
|
41
|
-
const eff = handleResponse(request, response)
|
|
42
|
-
if (effectIsExit(eff)) {
|
|
43
|
-
return eff._tag === "Success" ? Effect.succeed(response) : handleCause(eff.cause)
|
|
44
|
-
}
|
|
45
|
-
return Effect.matchCauseEffect(eff, {
|
|
46
|
-
onFailure: handleCause,
|
|
47
|
-
onSuccess: () => Effect.succeed(response)
|
|
48
|
-
})
|
|
49
|
-
}
|
|
50
|
-
return Effect.flatMapEager(handler(request, response), (sentResponse) => {
|
|
51
|
-
;(request as any)[handledSymbol] = true
|
|
52
|
-
return Effect.matchCauseEffectEager(handleResponse(request, sentResponse), {
|
|
53
|
-
onSuccess: () => Effect.succeed(response),
|
|
54
|
-
onFailure: handleCause
|
|
55
|
-
})
|
|
56
|
-
})
|
|
57
|
-
})
|
|
58
|
-
|
|
59
|
-
const handleCause = (cause: Cause<E | EH | HttpServerError>) =>
|
|
35
|
+
const handleCause = (cause: Cause.Cause<E | EH | HttpServerError>) =>
|
|
60
36
|
Effect.flatMapEager(causeResponse(cause), ([response, cause]) => {
|
|
61
37
|
const fiber = Fiber.getCurrent()!
|
|
38
|
+
reportCauseUnsafe(fiber, cause)
|
|
62
39
|
const request = ServiceMap.getUnsafe(fiber.services, HttpServerRequest)
|
|
63
|
-
const handler =
|
|
40
|
+
const handler = requestPreResponseHandlers.get(request.source)
|
|
64
41
|
const cont = cause.reasons.length === 0 ? Effect.succeed(response) : Effect.failCause(cause)
|
|
65
42
|
if (handler === undefined) {
|
|
66
43
|
;(request as any)[handledSymbol] = true
|
|
@@ -79,6 +56,23 @@ export const toHandled = <E, R, EH, RH>(
|
|
|
79
56
|
)
|
|
80
57
|
})
|
|
81
58
|
|
|
59
|
+
const responded = Effect.matchCauseEffect(self, {
|
|
60
|
+
onSuccess: (response) => {
|
|
61
|
+
const fiber = Fiber.getCurrent()!
|
|
62
|
+
const request = ServiceMap.getUnsafe(fiber.services, HttpServerRequest)
|
|
63
|
+
const handler = requestPreResponseHandlers.get(request.source)
|
|
64
|
+
if (handler === undefined) {
|
|
65
|
+
;(request as any)[handledSymbol] = true
|
|
66
|
+
return Effect.mapEager(handleResponse(request, response), () => response)
|
|
67
|
+
}
|
|
68
|
+
return Effect.flatMapEager(handler(request, response), (sentResponse) => {
|
|
69
|
+
;(request as any)[handledSymbol] = true
|
|
70
|
+
return Effect.mapEager(handleResponse(request, sentResponse), () => response)
|
|
71
|
+
})
|
|
72
|
+
},
|
|
73
|
+
onFailure: handleCause
|
|
74
|
+
})
|
|
75
|
+
|
|
82
76
|
const withMiddleware: Effect.Effect<
|
|
83
77
|
unknown,
|
|
84
78
|
E | EH | HttpServerError,
|
|
@@ -88,13 +82,16 @@ export const toHandled = <E, R, EH, RH>(
|
|
|
88
82
|
Effect.matchCauseEffect(tracer(middleware(responded)), {
|
|
89
83
|
onFailure(cause): Effect.Effect<void, EH, RH> {
|
|
90
84
|
const fiber = Fiber.getCurrent()!
|
|
85
|
+
reportCauseUnsafe(fiber, cause)
|
|
91
86
|
const request = ServiceMap.getUnsafe(fiber.services, HttpServerRequest)
|
|
92
|
-
if (handledSymbol in request)
|
|
93
|
-
return Effect.void
|
|
94
|
-
}
|
|
87
|
+
if (handledSymbol in request) return Effect.void
|
|
95
88
|
return Effect.matchCauseEffectEager(causeResponse(cause), {
|
|
96
|
-
onFailure
|
|
97
|
-
|
|
89
|
+
onFailure(_) {
|
|
90
|
+
return handleResponse(request, Response.empty({ status: 500 }))
|
|
91
|
+
},
|
|
92
|
+
onSuccess([response]) {
|
|
93
|
+
return handleResponse(request, response)
|
|
94
|
+
}
|
|
98
95
|
})
|
|
99
96
|
},
|
|
100
97
|
onSuccess(response): Effect.Effect<void, EH, RH> {
|
|
@@ -148,10 +145,10 @@ const scopeEjected = Symbol.for("effect/http/HttpEffect/scopeEjected")
|
|
|
148
145
|
const scoped = <A, E, R>(effect: Effect.Effect<A, E, R>) =>
|
|
149
146
|
Effect.withFiber((fiber) => {
|
|
150
147
|
const scope = Scope.makeUnsafe()
|
|
151
|
-
const
|
|
148
|
+
const prevServices = fiber.services
|
|
152
149
|
fiber.setServices(ServiceMap.add(fiber.services, Scope.Scope, scope))
|
|
153
150
|
return Effect.onExitPrimitive(effect, (exit) => {
|
|
154
|
-
fiber.setServices(
|
|
151
|
+
fiber.setServices(prevServices)
|
|
155
152
|
if (scopeEjected in scope) return undefined
|
|
156
153
|
return Scope.closeUnsafe(scope, exit)
|
|
157
154
|
}, true)
|
|
@@ -166,27 +163,13 @@ export type PreResponseHandler = (
|
|
|
166
163
|
response: HttpServerResponse
|
|
167
164
|
) => Effect.Effect<HttpServerResponse, HttpServerError>
|
|
168
165
|
|
|
169
|
-
/**
|
|
170
|
-
* @since 4.0.0
|
|
171
|
-
* @category Pre-response handlers
|
|
172
|
-
*/
|
|
173
|
-
export const PreResponseHandlers = ServiceMap.Reference<PreResponseHandler | undefined>(
|
|
174
|
-
"effect/http/HttpEffect/PreResponseHandlers",
|
|
175
|
-
{ defaultValue: () => undefined }
|
|
176
|
-
)
|
|
177
|
-
|
|
178
166
|
/**
|
|
179
167
|
* @since 4.0.0
|
|
180
168
|
* @category fiber refs
|
|
181
169
|
*/
|
|
182
|
-
export const appendPreResponseHandler = (handler: PreResponseHandler): Effect.Effect<void> =>
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
onUndefined: () => handler,
|
|
186
|
-
onDefined: (prev) => (request, response) =>
|
|
187
|
-
Effect.flatMap(prev(request, response), (response) => handler(request, response))
|
|
188
|
-
})
|
|
189
|
-
fiber.setServices(ServiceMap.add(fiber.services, PreResponseHandlers, next))
|
|
170
|
+
export const appendPreResponseHandler = (handler: PreResponseHandler): Effect.Effect<void, never, HttpServerRequest> =>
|
|
171
|
+
HttpServerRequest.use((request) => {
|
|
172
|
+
appendPreResponseHandlerUnsafe(request, handler)
|
|
190
173
|
return Effect.void
|
|
191
174
|
})
|
|
192
175
|
|
|
@@ -199,33 +182,28 @@ export const withPreResponseHandler: {
|
|
|
199
182
|
* @since 4.0.0
|
|
200
183
|
* @category fiber refs
|
|
201
184
|
*/
|
|
202
|
-
(handler: PreResponseHandler): <A, E, R>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
185
|
+
(handler: PreResponseHandler): <A, E, R>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R | HttpServerRequest>
|
|
203
186
|
/**
|
|
204
187
|
* @since 4.0.0
|
|
205
188
|
* @category fiber refs
|
|
206
189
|
*/
|
|
207
|
-
<A, E, R>(self: Effect.Effect<A, E, R>, handler: PreResponseHandler): Effect.Effect<A, E, R>
|
|
190
|
+
<A, E, R>(self: Effect.Effect<A, E, R>, handler: PreResponseHandler): Effect.Effect<A, E, R | HttpServerRequest>
|
|
208
191
|
} = dual<
|
|
209
192
|
/**
|
|
210
193
|
* @since 4.0.0
|
|
211
194
|
* @category fiber refs
|
|
212
195
|
*/
|
|
213
|
-
(handler: PreResponseHandler) => <A, E, R>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>,
|
|
196
|
+
(handler: PreResponseHandler) => <A, E, R>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R | HttpServerRequest>,
|
|
214
197
|
/**
|
|
215
198
|
* @since 4.0.0
|
|
216
199
|
* @category fiber refs
|
|
217
200
|
*/
|
|
218
|
-
<A, E, R>(self: Effect.Effect<A, E, R>, handler: PreResponseHandler) => Effect.Effect<A, E, R>
|
|
201
|
+
<A, E, R>(self: Effect.Effect<A, E, R>, handler: PreResponseHandler) => Effect.Effect<A, E, R | HttpServerRequest>
|
|
219
202
|
>(2, (self, handler) =>
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
onUndefined: () => handler,
|
|
225
|
-
onDefined: (prev) => (request, response) =>
|
|
226
|
-
Effect.flatMap(prev(request, response), (response) => handler(request, response))
|
|
227
|
-
})
|
|
228
|
-
))
|
|
203
|
+
HttpServerRequest.use((request) => {
|
|
204
|
+
appendPreResponseHandlerUnsafe(request, handler)
|
|
205
|
+
return self
|
|
206
|
+
}))
|
|
229
207
|
|
|
230
208
|
/**
|
|
231
209
|
* @since 4.0.0
|
|
@@ -262,7 +240,7 @@ export const toWebHandlerWith = <Provided, R = never, ReqR = Exclude<R, Provided
|
|
|
262
240
|
;(httpServerRequest as any)[resolveSymbol] = resolve
|
|
263
241
|
const fiber = Effect.runForkWith(ServiceMap.makeUnsafe(contextMap))(httpApp as any)
|
|
264
242
|
request.signal?.addEventListener("abort", () => {
|
|
265
|
-
fiber.interruptUnsafe(
|
|
243
|
+
fiber.interruptUnsafe(undefined, ClientAbort.annotation)
|
|
266
244
|
}, { once: true })
|
|
267
245
|
})
|
|
268
246
|
}
|
|
@@ -14,6 +14,7 @@ export type HttpMethod =
|
|
|
14
14
|
| "PATCH"
|
|
15
15
|
| "HEAD"
|
|
16
16
|
| "OPTIONS"
|
|
17
|
+
| "TRACE"
|
|
17
18
|
|
|
18
19
|
/**
|
|
19
20
|
* @since 4.0.0
|
|
@@ -24,7 +25,7 @@ export declare namespace HttpMethod {
|
|
|
24
25
|
* @since 4.0.0
|
|
25
26
|
* @category models
|
|
26
27
|
*/
|
|
27
|
-
export type NoBody = "GET" | "HEAD" | "OPTIONS"
|
|
28
|
+
export type NoBody = "GET" | "HEAD" | "OPTIONS" | "TRACE"
|
|
28
29
|
|
|
29
30
|
/**
|
|
30
31
|
* @since 4.0.0
|
|
@@ -36,12 +37,22 @@ export declare namespace HttpMethod {
|
|
|
36
37
|
/**
|
|
37
38
|
* @since 4.0.0
|
|
38
39
|
*/
|
|
39
|
-
export const hasBody = (method: HttpMethod):
|
|
40
|
+
export const hasBody = (method: HttpMethod): method is HttpMethod.WithBody =>
|
|
41
|
+
method !== "GET" && method !== "HEAD" && method !== "OPTIONS" && method !== "TRACE"
|
|
40
42
|
|
|
41
43
|
/**
|
|
42
44
|
* @since 4.0.0
|
|
43
45
|
*/
|
|
44
|
-
export const all: ReadonlySet<HttpMethod> = new Set([
|
|
46
|
+
export const all: ReadonlySet<HttpMethod> = new Set([
|
|
47
|
+
"GET",
|
|
48
|
+
"POST",
|
|
49
|
+
"PUT",
|
|
50
|
+
"DELETE",
|
|
51
|
+
"PATCH",
|
|
52
|
+
"HEAD",
|
|
53
|
+
"OPTIONS",
|
|
54
|
+
"TRACE"
|
|
55
|
+
])
|
|
45
56
|
|
|
46
57
|
/**
|
|
47
58
|
* @since 4.0.0
|
|
@@ -53,7 +64,8 @@ export const allShort = [
|
|
|
53
64
|
["DELETE", "del"],
|
|
54
65
|
["PATCH", "patch"],
|
|
55
66
|
["HEAD", "head"],
|
|
56
|
-
["OPTIONS", "options"]
|
|
67
|
+
["OPTIONS", "options"],
|
|
68
|
+
["TRACE", "trace"]
|
|
57
69
|
] as const
|
|
58
70
|
|
|
59
71
|
/**
|
|
@@ -12,13 +12,13 @@ import { TracerEnabled } from "../../References.ts"
|
|
|
12
12
|
import * as ServiceMap from "../../ServiceMap.ts"
|
|
13
13
|
import { ParentSpan } from "../../Tracer.ts"
|
|
14
14
|
import * as Headers from "./Headers.ts"
|
|
15
|
-
import type { PreResponseHandler } from "./HttpEffect.ts"
|
|
16
15
|
import { causeResponseStripped, exitResponse } from "./HttpServerError.ts"
|
|
17
16
|
import { HttpServerRequest } from "./HttpServerRequest.ts"
|
|
18
17
|
import * as Request from "./HttpServerRequest.ts"
|
|
19
18
|
import * as Response from "./HttpServerResponse.ts"
|
|
20
19
|
import type { HttpServerResponse } from "./HttpServerResponse.ts"
|
|
21
20
|
import * as TraceContext from "./HttpTraceContext.ts"
|
|
21
|
+
import { appendPreResponseHandlerUnsafe } from "./internal/preResponseHandler.ts"
|
|
22
22
|
|
|
23
23
|
/**
|
|
24
24
|
* @since 4.0.0
|
|
@@ -46,21 +46,16 @@ export declare namespace HttpMiddleware {
|
|
|
46
46
|
*/
|
|
47
47
|
export const make = <M extends HttpMiddleware>(middleware: M): M => middleware
|
|
48
48
|
|
|
49
|
-
|
|
50
|
-
* @since 4.0.0
|
|
51
|
-
* @category Logger
|
|
52
|
-
*/
|
|
53
|
-
export const LoggerDisabled = ServiceMap.Reference<boolean>("effect/http/HttpMiddleware/LoggerDisabled", {
|
|
54
|
-
defaultValue: constFalse
|
|
55
|
-
})
|
|
49
|
+
const loggerDisabledRequests = new WeakSet<object>()
|
|
56
50
|
|
|
57
51
|
/**
|
|
58
52
|
* @since 4.0.0
|
|
59
53
|
* @category Logger
|
|
60
54
|
*/
|
|
61
|
-
export const withLoggerDisabled = <A, E, R>(self: Effect.Effect<A, E, R>): Effect.Effect<A, E, R> =>
|
|
55
|
+
export const withLoggerDisabled = <A, E, R>(self: Effect.Effect<A, E, R>): Effect.Effect<A, E, R | HttpServerRequest> =>
|
|
62
56
|
Effect.withFiber((fiber) => {
|
|
63
|
-
|
|
57
|
+
const request = ServiceMap.getUnsafe(fiber.services, HttpServerRequest)
|
|
58
|
+
loggerDisabledRequests.add(request.source)
|
|
64
59
|
return self
|
|
65
60
|
})
|
|
66
61
|
|
|
@@ -102,7 +97,7 @@ export const logger: <E, R>(
|
|
|
102
97
|
const request = ServiceMap.getUnsafe(fiber.services, HttpServerRequest)
|
|
103
98
|
return Effect.withLogSpan(
|
|
104
99
|
Effect.flatMap(Effect.exit(httpApp), (exit) => {
|
|
105
|
-
if (
|
|
100
|
+
if (loggerDisabledRequests.has(request.source)) {
|
|
106
101
|
return exit
|
|
107
102
|
} else if (exit._tag === "Failure") {
|
|
108
103
|
const [response, cause] = causeResponseStripped(exit.cause)
|
|
@@ -147,10 +142,10 @@ export const tracer: <E, R>(
|
|
|
147
142
|
parent: TraceContext.fromHeaders(request.headers),
|
|
148
143
|
kind: "server"
|
|
149
144
|
})
|
|
150
|
-
const
|
|
145
|
+
const prevServices = fiber.services
|
|
151
146
|
fiber.setServices(ServiceMap.add(fiber.services, ParentSpan, span))
|
|
152
147
|
return Effect.onExitPrimitive(httpApp, (exit) => {
|
|
153
|
-
fiber.setServices(
|
|
148
|
+
fiber.setServices(prevServices)
|
|
154
149
|
const endTime = fiber.getRef(Clock).currentTimeNanosUnsafe()
|
|
155
150
|
fiber.currentScheduler.scheduleTask(() => {
|
|
156
151
|
const url = Request.toURL(request)
|
|
@@ -343,17 +338,7 @@ export const cors = (options?: {
|
|
|
343
338
|
headers: headersFromRequestOptions(request)
|
|
344
339
|
}))
|
|
345
340
|
}
|
|
346
|
-
|
|
347
|
-
const next = prev
|
|
348
|
-
? ((req: HttpServerRequest, res: HttpServerResponse) =>
|
|
349
|
-
Effect.flatMap(prev(req, res), (res) => preResponseHandler(req, res)))
|
|
350
|
-
: preResponseHandler
|
|
351
|
-
fiber.setServices(ServiceMap.add(fiber.services, PreResponseHandlers, next))
|
|
341
|
+
appendPreResponseHandlerUnsafe(request, preResponseHandler)
|
|
352
342
|
return httpApp
|
|
353
343
|
})
|
|
354
344
|
}
|
|
355
|
-
|
|
356
|
-
const PreResponseHandlers = ServiceMap.Reference<PreResponseHandler | undefined>(
|
|
357
|
-
"effect/http/HttpEffect/PreResponseHandlers",
|
|
358
|
-
{ defaultValue: () => undefined }
|
|
359
|
-
)
|