/** * @since 1.0.0 */ import * as MessageStorage from "@effect/cluster/MessageStorage" import * as RunnerHealth from "@effect/cluster/RunnerHealth" import * as Runners from "@effect/cluster/Runners" import * as RunnerStorage from "@effect/cluster/RunnerStorage" import type { Sharding } from "@effect/cluster/Sharding" import * as ShardingConfig from "@effect/cluster/ShardingConfig" import * as SocketRunner from "@effect/cluster/SocketRunner" import * as SqlMessageStorage from "@effect/cluster/SqlMessageStorage" import * as SqlRunnerStorage from "@effect/cluster/SqlRunnerStorage" import { layerClientProtocol, layerSocketServer } from "@effect/platform-node-shared/NodeClusterSocket" import type * as SocketServer from "@effect/platform/SocketServer" import * as RpcSerialization from "@effect/rpc/RpcSerialization" import type { SqlClient } from "@effect/sql/SqlClient" import type { ConfigError } from "effect/ConfigError" import * as Layer from "effect/Layer" export { /** * @since 1.0.0 * @category Re-exports */ layerClientProtocol, /** * @since 1.0.0 * @category Re-exports */ layerSocketServer } /** * @since 1.0.0 * @category Layers */ export const layer = < const ClientOnly extends boolean = false, const Storage extends "local" | "sql" | "byo" = never >( options?: { readonly serialization?: "msgpack" | "ndjson" | undefined readonly clientOnly?: ClientOnly | undefined readonly storage?: Storage | undefined readonly shardingConfig?: Partial | undefined } ): ClientOnly extends true ? Layer.Layer< Sharding | Runners.Runners | ("byo" extends Storage ? never : MessageStorage.MessageStorage), ConfigError, "local" extends Storage ? never : "byo" extends Storage ? (MessageStorage.MessageStorage | RunnerStorage.RunnerStorage) : SqlClient > : Layer.Layer< Sharding | Runners.Runners | ("byo" extends Storage ? never : MessageStorage.MessageStorage), SocketServer.SocketServerError | ConfigError, "local" extends Storage ? never : "byo" extends Storage ? (MessageStorage.MessageStorage | RunnerStorage.RunnerStorage) : SqlClient > => { const layer: Layer.Layer = options?.clientOnly // client only ? Layer.provide(SocketRunner.layerClientOnly, layerClientProtocol) // with server : Layer.provide(SocketRunner.layer, [layerSocketServer, layerClientProtocol]) const runnerHealth: Layer.Layer = options?.clientOnly ? Layer.empty as any // TODO: when bun supports adding custom CA certificates // : options?.runnerHealth === "k8s" // ? RunnerHealth.layerK8s().pipe( // Layer.provide([NodeFileSystem.layer, layerHttpClientK8s]) // ) : RunnerHealth.layerPing.pipe( Layer.provide(Runners.layerRpc), Layer.provide(layerClientProtocol) ) return layer.pipe( Layer.provide(runnerHealth), Layer.provideMerge( options?.storage === "local" ? MessageStorage.layerNoop : options?.storage === "byo" ? Layer.empty : Layer.orDie(SqlMessageStorage.layer) ), Layer.provide( options?.storage === "local" ? RunnerStorage.layerMemory : options?.storage === "byo" ? Layer.empty : Layer.orDie(SqlRunnerStorage.layer) ), Layer.provide(ShardingConfig.layerFromEnv(options?.shardingConfig)), Layer.provide( options?.serialization === "ndjson" ? RpcSerialization.layerNdjson : RpcSerialization.layerMsgPack ) ) as any }