Middlewares
You are able to add middleware(s) to a procedure with the t.procedure.use() method. The middleware(s) will wrap the invocation of the procedure and must pass through its return value.
Authorization​
In the example below any call to a protectedProcedure will ensure that the user is an "admin" before executing.
ts
ts
tip
See Error Handling to learn more about the TRPCError thrown in the above example.
Logging​
In the example below timings for queries are logged automatically.
ts
ts
Context Swapping​
A middleware can change properties of the context, and procedures will receive the new context value:
tsContext = {// user is nullableuser ?: {id : string;};}ÂconstisAuthed =middleware (({ctx ,next }) => {// `ctx.user` is nullableif (!ctx .user ) {throw newTRPCError ({code : 'UNAUTHORIZED' });}Âreturnnext ({ctx : {// ✅ user value is known to be non-null nowuser :ctx .user ,},});});ÂconstprotectedProcedure =publicProcedure .use (isAuthed );Âexport constappRouter =router ({userId :protectedProcedure .query (({ctx }) =>ctx .user .id ),});
tsContext = {// user is nullableuser ?: {id : string;};}ÂconstisAuthed =middleware (({ctx ,next }) => {// `ctx.user` is nullableif (!ctx .user ) {throw newTRPCError ({code : 'UNAUTHORIZED' });}Âreturnnext ({ctx : {// ✅ user value is known to be non-null nowuser :ctx .user ,},});});ÂconstprotectedProcedure =publicProcedure .use (isAuthed );Âexport constappRouter =router ({userId :protectedProcedure .query (({ctx }) =>ctx .user .id ),});