0.1.17 #18

Merged
Thilawyn merged 37 commits from next into master 2024-09-07 20:56:30 +02:00
3 changed files with 48 additions and 63 deletions
Showing only changes of commit 527b8a8f22 - Show all commits

View File

@@ -1,8 +1,8 @@
import type { AnyRouter } from "@trpc/server"
import { Config, Context, Effect, Layer } from "effect"
import { Config, Effect, Layer } from "effect"
import { ExpressApp } from "../Express"
import { ImportError } from "../ImportError"
import { TRPCUnknownContextCreator } from "./TRPCContextCreator"
import { TRPCAnyRouter } from "./TRPCRouter"
const importTRPCServerExpressAdapter = Effect.tryPromise({
@@ -10,22 +10,17 @@ const importTRPCServerExpressAdapter = Effect.tryPromise({
catch: cause => new ImportError({ path: "@trpc/server/adapters/express", cause }),
})
export const TRPCExpressRouteLive = <
Tag,
TagShape extends AnyRouter,
>(
routerTag: Context.TagClass<Tag, "@thilalib/TRCP/TRPCRouter", TagShape>,
export const TRPCExpressRouteLive = (
config: {
readonly root: Config.Config<string>
},
}
) => Layer.effectDiscard(Effect.gen(function*() {
const { createExpressMiddleware } = yield* importTRPCServerExpressAdapter
const app = yield* ExpressApp.ExpressApp
app.use(yield* config.root,
createExpressMiddleware({
router: yield* routerTag,
router: yield* TRPCAnyRouter,
createContext: (yield* TRPCUnknownContextCreator).createExpressContext,
})
)

View File

@@ -1,10 +1,18 @@
import type { AnyRouter } from "@trpc/server"
import type { applyWSSHandler } from "@trpc/server/adapters/ws"
import { Config, Context, Effect, Layer } from "effect"
import type ws from "ws"
import { ExpressNodeHTTPServer } from "../Express"
import { ImportError } from "../ImportError"
import { TRPCUnknownContextCreator } from "./TRPCContextCreator"
import { TRPCAnyRouter } from "./TRPCRouter"
export class TRPCWebSocketServer extends Context.Tag("@thilalib/TRPC/TRPCWebSocketServer")<TRPCWebSocketServer, TRPCWebSocketServerService>() {}
export interface TRPCWebSocketServerService {
wss: ws.Server
handler: ReturnType<typeof applyWSSHandler>
}
const importWS = Effect.tryPromise({
@@ -17,19 +25,7 @@ const importTRPCServerWSAdapter = Effect.tryPromise({
catch: cause => new ImportError({ path: "@trpc/server/adapters/ws", cause }),
})
export const make = <
Tag,
TagShape extends AnyRouter,
>(
routerTag: Context.TagClass<Tag, "@thilalib/TRCP/TRPCRouter", TagShape>
) => {
class TRPCWebSocketServer extends Context.Tag("@thilalib/TRPC/TRPCWebSocketServer")<TRPCWebSocketServer, {
wss: ws.Server
handler: ReturnType<typeof applyWSSHandler<TagShape>>
}>() {}
const TRPCWebSocketServerLive = (
export const TRPCWebSocketServerLive = (
config: {
readonly host: Config.Config<string>
}
@@ -52,7 +48,7 @@ export const make = <
wss,
handler: applyWSSHandler({
wss,
router: yield* routerTag,
router: yield* TRPCAnyRouter,
createContext: (yield* TRPCUnknownContextCreator).createWebSocketContext,
}),
}
@@ -68,6 +64,3 @@ export const make = <
}),
)
}))
return { TRPCWebSocketServer, TRPCWebSocketServerLive }
}

View File

@@ -24,14 +24,11 @@ const router = TRPCBuilder.pipe(Effect.map(t => t.router({
const { TRPCRouter, TRPCRouterLive } = TRPC.TRPCRouter.make(router)
const { TRPCWebSocketServer, TRPCWebSocketServerLive } = TRPC.TRPCWebSocketServer.make(TRPCRouter)
const ServerLive = Layer.empty.pipe(
Layer.provideMerge(TRPC.TRPCExpressRoute.TRPCExpressRouteLive(TRPCRouter, {
Layer.provideMerge(TRPC.TRPCExpressRoute.TRPCExpressRouteLive({
root: Config.succeed("/rpc")
})),
Layer.provideMerge(TRPCWebSocketServerLive({
Layer.provideMerge(TRPC.TRPCWebSocketServer.TRPCWebSocketServerLive({
host: Config.succeed("/rpc")
})),