WebSocket work
This commit is contained in:
@@ -4,8 +4,8 @@ import { Identifiable } from "@todo-tests/common/traits"
|
|||||||
import { Chunk, Effect, Layer, Stream } from "effect"
|
import { Chunk, Effect, Layer, Stream } from "effect"
|
||||||
import { ServicesLive } from "./Services"
|
import { ServicesLive } from "./Services"
|
||||||
import { TodoRepository, createDefaultTodos } from "./TodoRepository"
|
import { TodoRepository, createDefaultTodos } from "./TodoRepository"
|
||||||
import { ExpressApp } from "./express/ExpressApp"
|
import { ExpressApp } from "./http/ExpressApp"
|
||||||
import { ExpressHTTPServer } from "./express/ExpressHTTPServer"
|
import { ExpressHTTPServer } from "./http/ExpressHTTPServer"
|
||||||
import { RPCPlaygroundRoute } from "./rpc/RPCPlaygroundRoute"
|
import { RPCPlaygroundRoute } from "./rpc/RPCPlaygroundRoute"
|
||||||
import { RPCRouter } from "./rpc/RPCRouter"
|
import { RPCRouter } from "./rpc/RPCRouter"
|
||||||
import { RPCServerRoute } from "./rpc/RPCServerRoute"
|
import { RPCServerRoute } from "./rpc/RPCServerRoute"
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import { Effect, Layer } from "effect"
|
import { Effect, Layer } from "effect"
|
||||||
import { expressHandler } from "trpc-playground/handlers/express"
|
import { expressHandler } from "trpc-playground/handlers/express"
|
||||||
import { rpcHTTPPlaygroundRoot, rpcHTTPRoot } from "../config"
|
import { rpcHTTPPlaygroundRoot, rpcHTTPRoot } from "../config"
|
||||||
import { ExpressApp } from "../express/ExpressApp"
|
import { ExpressApp } from "../http/ExpressApp"
|
||||||
import { RPCRouter } from "./RPCRouter"
|
import { RPCRouter } from "./RPCRouter"
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import { createExpressMiddleware } from "@trpc/server/adapters/express"
|
import { createExpressMiddleware } from "@trpc/server/adapters/express"
|
||||||
import { Effect, Layer } from "effect"
|
import { Effect, Layer } from "effect"
|
||||||
import { rpcHTTPRoot } from "../config"
|
import { rpcHTTPRoot } from "../config"
|
||||||
import { ExpressApp } from "../express/ExpressApp"
|
import { ExpressApp } from "../http/ExpressApp"
|
||||||
import { TRPCContextCreator } from "../trpc/TRPCContextCreator"
|
import { TRPCContextCreator } from "../trpc/TRPCContextCreator"
|
||||||
import { RPCRouter } from "./RPCRouter"
|
import { RPCRouter } from "./RPCRouter"
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import { applyWSSHandler } from "@trpc/server/adapters/ws"
|
import { applyWSSHandler } from "@trpc/server/adapters/ws"
|
||||||
import { Context, Effect, Layer, Runtime } from "effect"
|
import { Context, Effect, Layer, Runtime } from "effect"
|
||||||
import ws from "ws"
|
import ws from "ws"
|
||||||
import { ExpressHTTPServer } from "../express/ExpressHTTPServer"
|
import { ExpressHTTPServer } from "../http/ExpressHTTPServer"
|
||||||
import { TRPCContextCreator } from "../trpc/TRPCContextCreator"
|
import { TRPCContextCreator } from "../trpc/TRPCContextCreator"
|
||||||
import { RPCRouter } from "./RPCRouter"
|
import { RPCRouter } from "./RPCRouter"
|
||||||
|
|
||||||
@@ -33,8 +33,12 @@ export module RPCWebSocketServer {
|
|||||||
}),
|
}),
|
||||||
|
|
||||||
({ wss, handler }) => Effect.gen(function*() {
|
({ wss, handler }) => Effect.gen(function*() {
|
||||||
|
yield* Effect.logInfo(`WebSocket server is closing. Waiting for existing connections to end...`)
|
||||||
|
|
||||||
handler.broadcastReconnectNotification()
|
handler.broadcastReconnectNotification()
|
||||||
wss.close()
|
yield* Effect.async(resume => {
|
||||||
|
wss.close(() => resume(Effect.logInfo(`WebSocket server closed`)))
|
||||||
|
})
|
||||||
}),
|
}),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user