0.1.17 #18
@@ -12,13 +12,13 @@ const importTRPCServerExpressAdapter = Effect.tryPromise({
|
||||
|
||||
export const TRPCExpressRouteLive = (
|
||||
config: {
|
||||
readonly path: Config.Config<string>
|
||||
readonly root: Config.Config<string>
|
||||
}
|
||||
) => Layer.effectDiscard(Effect.gen(function*() {
|
||||
const { createExpressMiddleware } = yield* importTRPCServerExpressAdapter
|
||||
const app = yield* ExpressApp.ExpressApp
|
||||
|
||||
app.use(yield* config.path,
|
||||
app.use(yield* config.root,
|
||||
createExpressMiddleware({
|
||||
router: yield* TRPCAnyRouter,
|
||||
createContext: (yield* TRPCUnknownContextCreator).createExpressContext,
|
||||
|
||||
@@ -1,18 +1,39 @@
|
||||
import { Console, Effect, identity } from "effect"
|
||||
import { Config, Effect, Layer } from "effect"
|
||||
import * as TRPC from "."
|
||||
import { ExpressApp, ExpressNodeHTTPServer } from "../express"
|
||||
|
||||
|
||||
const expansiveComputation = Effect.gen(function*() {
|
||||
yield* Console.log("executing")
|
||||
return "value"
|
||||
}).pipe(
|
||||
Effect.cached,
|
||||
type Services = never
|
||||
|
||||
const { TRPCContextCreator, TRPCContextCreatorLive } = TRPC.TRPCContextCreator.make<Services>()
|
||||
const { TRPCBuilder, TRPCBuilderLive } = TRPC.TRPCBuilder.make<Services>()
|
||||
|
||||
|
||||
const router = TRPCBuilder.pipe(Effect.map(t => t.router({
|
||||
ping: t.procedure.query(({ ctx }) => ctx.run(
|
||||
Effect.succeed("pong")
|
||||
)),
|
||||
})))
|
||||
|
||||
const { TRPCRouter, TRPCRouterLive } = TRPC.TRPCRouter.make(router)
|
||||
|
||||
|
||||
const ServerLive = Layer.empty.pipe(
|
||||
Layer.provideMerge(TRPC.TRPCExpressRoute.TRPCExpressRouteLive({
|
||||
root: Config.succeed("/rpc")
|
||||
})),
|
||||
|
||||
Layer.provideMerge(TRPCRouterLive),
|
||||
Layer.provideMerge(TRPCBuilderLive),
|
||||
Layer.provideMerge(TRPCContextCreatorLive),
|
||||
|
||||
Layer.provideMerge(ExpressNodeHTTPServer.ExpressNodeHTTPServerLive({
|
||||
port: Config.succeed(3000)
|
||||
})),
|
||||
Layer.provideMerge(ExpressApp.ExpressAppLive())
|
||||
)
|
||||
|
||||
await Effect.gen(function*() {
|
||||
const cached = yield* expansiveComputation
|
||||
yield* Console.log(yield* cached)
|
||||
yield* Console.log(yield* cached)
|
||||
yield* Console.log(yield* cached)
|
||||
}).pipe(
|
||||
Effect.runPromise
|
||||
await Layer.launch(ServerLive).pipe(
|
||||
Effect.scoped,
|
||||
Effect.runPromise,
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user