UNPKG

@logtail/next

Version:

Better Stack Telemetry Next.js client

118 lines (106 loc) 3.45 kB
/** * YOU PROBABLY DON'T NEED TO EDIT THIS FILE, UNLESS: * 1. You want to modify request context (see Part 1). * 2. You want to create a new middleware or type of procedure (see Part 3). * * TL;DR - This is where all the tRPC server stuff is created and plugged in. The pieces you will * need to use are documented accordingly near the end. */ import { initTRPC } from '@trpc/server'; import { type NextRequest } from 'next/server'; import superjson from 'superjson'; import { ZodError } from 'zod'; import { createBetterStackPlugin, type NextBetterStackTRPCMiddlewareCtx, } from './better-stack-trpc'; /** * 1. CONTEXT * * This section defines the "contexts" that are available in the backend API. * * These allow you to access things when processing a request, like the database, the session, etc. */ interface CreateContextOptions { headers: Headers; } /** * This helper generates the "internals" for a tRPC context. If you need to use it, you can export * it from here. * * Examples of things you may need it for: * - testing, so we don't have to mock Next.js' req/res * - tRPC's `createSSGHelpers`, where we don't have req/res * * @see https://create.t3.gg/en/usage/trpc#-serverapitrpcts */ export const createInnerTRPCContext = (opts: CreateContextOptions) => { return { headers: opts.headers, }; }; /** * This is the actual context you will use in your router. It will be used to process every request * that goes through your tRPC endpoint. * * @see https://trpc.io/docs/context */ export const createTRPCContext = (opts: { req: NextRequest }) => { // Fetch stuff that depends on the request return { req: opts.req, betterStackTRPCMeta: { foo: 'bar', randomNumber: Math.random(), }, ...createInnerTRPCContext({ headers: opts.req.headers, }), } satisfies NextBetterStackTRPCMiddlewareCtx; }; /** * 2. INITIALIZATION * * This is where the tRPC API is initialized, connecting the context and transformer. We also parse * ZodErrors so that you get typesafety on the frontend if your procedure fails due to validation * errors on the backend. */ const t = initTRPC.context<typeof createTRPCContext>().create({ transformer: superjson, errorFormatter({ shape, error }) { return { ...shape, data: { ...shape.data, zodError: error.cause instanceof ZodError ? error.cause.flatten() : null, }, }; }, }); /** * 3. ROUTER & PROCEDURE (THE IMPORTANT BIT) * * These are the pieces you use to build your tRPC API. You should import these a lot in the * "/src/server/api/routers" directory. */ /** * This is how you create new routers and sub-routers in your tRPC API. * * @see https://trpc.io/docs/router */ export const createTRPCRouter = t.router; /** * Create a procedure with the betterStackTRPCMiddleware already applied to extend other procedures from. */ const betterStackPlugin = createBetterStackPlugin(); const baseProcedure = t.procedure.unstable_concat(betterStackPlugin.betterStackProcedure); /** * Public (unauthenticated) procedure * * This is the base piece you use to build new queries and mutations on your tRPC API. It does not * guarantee that a user querying is authorized, but you can still access user session data if they * are logged in. */ export const publicProcedure = baseProcedure; // export const protectedProcedure = baseProcedure.use(authMiddleware)