Back

What is tRPC and how can we use it in our Apps

March 6, 2023

4 min read

Introduction

There are various ways available out there to make APIs like REST APIs, GraphQL, tRPC, and many more but today in this blog we are gonna have a look at what is tRPC how it works, why one should use tRPC, and a lot more.

Building our application fully typesafe is a thing that every developer wants to do nowadays so that they would never run into runtime errors like the Reading property of undefined. tRPC allows us to build and use fully typesafe APIs without any schema or code generation like GraphQL.

Why tRPC over REST or GraphQL ?

GraphQL and REST are the dominant way to implement typesafe APIs. If your front-end and back-end both are in Typescript then with the help of tRPC we can share types directly between our client and server, without relying on any extra code generation like we do in GraphQL.

tRPC is for full-stack Typescript developers. It makes it easy to write endpoints that you can safely use in both the front and backend of your app. Type errors with your API contracts will be caught at build time, reducing the surface for bugs in your application at runtime.

Features of tRPC

tRPC comes with a lot of features including

How to setup/use tRPC

1. Define backend router

Image description

Here in this image we are creating three end point to get all the users, a particular user with I’d and to create a new user.

2. Creating router instance

Image description

In this step we are initializing the tRPC backend. It’s a good practise to do this in a separate file and export the helper function instead of whole tRPC.

next we will initialize our main router, commonly referred to as appRouter and we will also export the type of the router which we’ll later use on the client.

Image description

3. Add a query procedure

use publicProcedure.query() to add a query procedure to the router.

In the following image, we are creating a procedure called userList that returns the list of users from our DB.

Image description

4. Using input parser to validate procedure inputs

To implement the userById procedure, we need to accept input from the client. tRPC lets you define input parsers to validate and parse the input. You can define your own input parser or use a validation library of your choice, like zod, yup, or superstruct.

You define your input parser on publicProcedure.input(), which can then be accessed on the resolver function as shown below:

Image description

here at line number 8 we will have type of input as : string and at line number 10 we will have type of user as : User | undefined

5. Adding a mutation procedure

Similar to GraphQL, tRPC makes a distinction between query and mutation procedures.

The way a procedure works on the server doesn’t change much between a query and a mutation. The method name is different, and the way that the client will use this procedure changes - but everything else is the same!

Let’s add a userCreate mutation by adding it as a new property on our router object:

Image description

Image description

now we can use your backend on the client.

1. setup the tRPC Client

Links in tRPC are similar to links in GraphQL, they let us control the data flow before being sent to the server. In the example above, we use the httpBatchLink, which automatically batches up multiple calls into a single HTTP request

Image description

2. Querying & mutating

You now have access to your API procedures on the trpc object. Try it out!

Image description

now in this image at line no 2 we will automatically have user with type

const user : {
            name : string;
            id : string;
     } | undefined

and createUser with type

const createUser : {
            name : string;
            id : string;
}