RPC-like client and server helpers for a magical end to end typed experience
ts-rest provides an RPC-like client side interface over your existing REST APIs, as well as allowing you define a separate contract implementation rather than going for a 'implementation is the contract' approach, which is best suited for smaller or simpler APIs.
If you have non typescript consumers, a public API, or maybe want to add type safety to your existing REST API? ts-rest is what you're looking for!
- End to end type safety
- Magic RPC-like API
- Tiny bundle size
- Well-tested and production ready
- No Code Generation
- Zod support for body parsing
- Full optional OpenAPI integration
Install the core package
yarn add @ts-rest/core # Optional react-query integration yarn add @ts-rest/react-query # Pick your backend yarn add @ts-rest/nest @ts-rest/express # For automatic server OpenAPI gen yarn add @ts-rest/open-api
Create a contract, implement it on your server then consume it in your client. Incrementally adopt, trial it with your team, then get shipping faster.
👉 Read more on the official Quickstart Guide 👈
Thanks goes to these wonderful people (emoji key):
This project follows the all-contributors specification. Contributions of any kind welcome!