TRCP refactoring
Some checks failed
Lint / lint (push) Failing after 11s

This commit is contained in:
Julien Valverdé
2024-09-07 02:14:11 +02:00
parent 58d0d85dda
commit 65ef5f0896
5 changed files with 55 additions and 88 deletions

View File

@@ -1,8 +1,8 @@
import { Config, Effect, Layer } from "effect"
import type { AnyRouter } from "@trpc/server"
import { Config, Context, Effect, Layer } from "effect"
import { ImportError } from "../../ImportError"
import { ExpressApp } from "../express"
import { TRPCUnknownContextCreator } from "./TRPCContextCreator"
import { TRPCAnyRouter } from "./TRPCRouter"
const importTRPCServerExpressAdapter = Effect.tryPromise({
@@ -10,17 +10,19 @@ const importTRPCServerExpressAdapter = Effect.tryPromise({
catch: cause => new ImportError({ path: "@trpc/server/adapters/express", cause }),
})
export const TRPCExpressRouteLive = (
export const TRPCExpressRouteLive = <T extends AnyRouter>(
routerTag: Context.Tag<"@thilalib/TRCP/TRPCRouter", T>,
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* TRPCAnyRouter,
router: yield* routerTag,
createContext: (yield* TRPCUnknownContextCreator).createExpressContext,
})
)

View File

@@ -1,14 +1,9 @@
import type { AnyRouter, AnyRouterDef, Router } from "@trpc/server"
import type { AnyRouter } from "@trpc/server"
import { Context, Effect, Layer } from "effect"
export class TRPCAnyRouter extends Context.Tag("@thilalib/TRCP/TRPCRouter")<TRPCAnyRouter,
AnyRouter
>() {}
export const make = <
A extends Router<AnyRouterDef>,
A extends AnyRouter,
E, R,
>(router: Effect.Effect<A, E, R>) => {
class TRPCRouter extends Context.Tag("@thilalib/TRCP/TRPCRouter")<TRPCRouter, A>() {}

View File

@@ -1,16 +1,10 @@
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 { ImportError } from "../../ImportError"
import { ExpressNodeHTTPServer } from "../express"
import { TRPCUnknownContextCreator } from "./TRPCContextCreator"
import { TRPCAnyRouter } from "./TRPCRouter"
export class TRPCWebSocketServer extends Context.Tag("@thilalib/TRPC/TRPCWebSocketServer")<TRPCWebSocketServer, {
wss: ws.Server
handler: ReturnType<typeof applyWSSHandler>
}>() {}
const importWS = Effect.tryPromise({
@@ -23,7 +17,16 @@ const importTRPCServerWSAdapter = Effect.tryPromise({
catch: cause => new ImportError({ path: "@trpc/server/adapters/ws", cause }),
})
export const TRPCWebSocketServerLive = (
export const make = <T extends AnyRouter>(
routerTag: Context.Tag<"@thilalib/TRCP/TRPCRouter", T>
) => {
class TRPCWebSocketServer extends Context.Tag("@thilalib/TRPC/TRPCWebSocketServer")<TRPCWebSocketServer, {
wss: ws.Server
handler: ReturnType<typeof applyWSSHandler<T>>
}>() {}
const TRPCWebSocketServerLive = (
config: {
readonly host: Config.Config<string>
}
@@ -46,7 +49,7 @@ export const TRPCWebSocketServerLive = (
wss,
handler: applyWSSHandler({
wss,
router: yield* TRPCAnyRouter,
router: yield* routerTag,
createContext: (yield* TRPCUnknownContextCreator).createWebSocketContext,
}),
}
@@ -62,3 +65,6 @@ export const TRPCWebSocketServerLive = (
}),
)
}))
return { TRPCWebSocketServer, TRPCWebSocketServerLive }
}

View File

@@ -16,11 +16,10 @@ const router = TRPCBuilder.pipe(Effect.map(t => t.router({
})))
const { TRPCRouter, TRPCRouterLive } = TRPC.TRPCRouter.make(router)
type TRouter = Context.Tag.Service<typeof TRPCRouter>
const ServerLive = Layer.empty.pipe(
Layer.provideMerge(TRPC.TRPCExpressRoute.TRPCExpressRouteLive({
Layer.provideMerge(TRPC.TRPCExpressRoute.TRPCExpressRouteLive(TRPCRouter, {
root: Config.succeed("/rpc")
})),

View File

@@ -1,35 +0,0 @@
import type { AnyRouter } from "@trpc/server"
import { Context, Effect, Layer } from "effect"
import * as TRPC from "."
const { TRPCBuilder, TRPCBuilderLive } = TRPC.TRPCBuilder.make<never>()
const router = TRPCBuilder.pipe(Effect.map(t => t.router({
ping: t.procedure.query(({ ctx }) => ctx.run(
Effect.succeed("pong")
)),
})))
export class TRPCAnyRouter extends Context.Tag("@thilalib/TRCP/TRPCRouter")<TRPCAnyRouter,
AnyRouter
>() {}
export class TRPCRouter extends Context.Tag("@thilalib/TRCP/TRPCRouter")<TRPCRouter,
Effect.Effect.Success<typeof router>
>() {}
const RouterLive = Layer.effect(TRPCRouter, router)
const AnyRouterLive = Layer.effect(TRPCAnyRouter, router)
const main = Effect.gen(function*() {
yield* TRPCAnyRouter
yield* TRPCRouter
})
const runnable = main.pipe(
Effect.provide(RouterLive),
Effect.provide(TRPCBuilderLive),
)