टीआरपीसी एंड-टू-एंड टाइप-सुरक्षित एपीआई परत है जो आपके टाइपस्क्रिप्ट बैकएंड और फ्रंटएंड के बीच एपीआई अनुबंध, कोड जनरेशन और टाइप डुप्लिकेशन की आवश्यकता को समाप्त करती है। 2026 में, रिएक्ट क्वेरी इंटीग्रेशन और नेक्स्ट.जेएस ऐप राउटर सपोर्ट के साथ टीआरपीसी वी11 फुल-स्टैक टाइपस्क्रिप्ट अनुप्रयोगों के लिए मानक बन गया है। यह मार्गदर्शिका सेटअप से लेकर उत्पादन पैटर्न तक सब कुछ कवर करती है।
📋 Table of Contents
टीआरपीसी क्यों?
- शून्य एपीआई अनुबंध— बैकएंड प्रकार स्वचालित रूप से फ्रंटएंड पर उपलब्ध होते हैं
- कोई कोड जनरेशन नहीं– संकलन समय पर अनुमानित प्रकार, उत्पन्न नहीं
- पूर्ण टाइपस्क्रिप्ट– एपीआई कॉल, तर्क और रिटर्न प्रकारों के लिए स्वत: पूर्ण
- प्रतिक्रिया क्वेरी अंतर्निहित– कैशिंग, लोडिंग स्थिति, रीफ़ेचिंग कार्य स्वचालित रूप से
- फ़ंक्शन कॉल के समान DX —
trpc.user.getById.useQuery(1)
Next.js ऐप राउटर के साथ सेटअप
npm install @trpc/server @trpc/client @trpc/react-query @trpc/next
npm install @tanstack/react-query
npm install zod
src/
server/
api/
trpc.ts — tRPC base config
root.ts — root router
routers/
user.ts
post.ts
trpc/
react.tsx — client setup
server.ts — server-side caller
सर्वर सेटअप
// server/api/trpc.ts
import { initTRPC, TRPCError } from '@trpc/server';
import { ZodError } from 'zod';
// Context type — available in all procedures
export interface Context {
userId: string | null;
db: PrismaClient;
}
const t = initTRPC.context<Context>().create({
errorFormatter({ shape, error }) {
return {
...shape,
data: {
...shape.data,
zodError: error.cause instanceof ZodError ? error.cause.flatten() : null,
},
};
},
});
export const router = t.router;
export const publicProcedure = t.procedure;
// Auth middleware
const isAuthenticated = t.middleware(({ ctx, next }) => {
if (!ctx.userId) {
throw new TRPCError({ code: 'UNAUTHORIZED' });
}
return next({ ctx: { ...ctx, userId: ctx.userId } });
});
export const protectedProcedure = t.procedure.use(isAuthenticated);
// Rate limiting middleware
const withRateLimit = t.middleware(async ({ ctx, next }) => {
const key = `ratelimit:${ctx.userId ?? 'anonymous'}`;
const count = await redis.incr(key);
if (count === 1) await redis.expire(key, 60);
if (count > 100) throw new TRPCError({ code: 'TOO_MANY_REQUESTS' });
return next();
});
export const rateLimitedProcedure = protectedProcedure.use(withRateLimit);
राउटर्स
// server/api/routers/user.ts
import { z } from 'zod';
import { router, publicProcedure, protectedProcedure } from '../trpc';
export const userRouter = router({
// Query — get data
getById: publicProcedure
.input(z.number().int().positive())
.query(async ({ ctx, input }) => {
const user = await ctx.db.user.findUnique({ where: { id: input } });
if (!user) throw new TRPCError({ code: 'NOT_FOUND', message: `User ${input} not found` });
return user;
}),
// Query with pagination
list: publicProcedure
.input(z.object({
page: z.number().default(1),
limit: z.number().max(100).default(20),
search: z.string().optional(),
}))
.query(async ({ ctx, input }) => {
const { page, limit, search } = input;
const [users, total] = await ctx.db.$transaction([
ctx.db.user.findMany({
where: search ? { name: { contains: search, mode: 'insensitive' } } : undefined,
skip: (page - 1) * limit,
take: limit,
}),
ctx.db.user.count(),
]);
return { users, total, page, limit };
}),
// Mutation — create/update/delete
create: protectedProcedure
.input(z.object({
name: z.string().min(2).max(50),
email: z.string().email(),
}))
.mutation(async ({ ctx, input }) => {
return ctx.db.user.create({ data: input });
}),
update: protectedProcedure
.input(z.object({
id: z.number(),
name: z.string().optional(),
email: z.string().email().optional(),
}))
.mutation(async ({ ctx, input }) => {
const { id, ...data } = input;
return ctx.db.user.update({ where: { id }, data });
}),
// Subscription — real-time
onUserCreated: protectedProcedure.subscription(({ ctx }) => {
return observable<User>((emit) => {
const unsub = eventEmitter.on('user.created', (user) => {
emit.next(user);
});
return () => unsub();
});
}),
});
रूट राउटर
// server/api/root.ts
import { router } from './trpc';
import { userRouter } from './routers/user';
import { postRouter } from './routers/post';
export const appRouter = router({
user: userRouter,
post: postRouter,
});
export type AppRouter = typeof appRouter;
Next.js ऐप राउटर हैंडलर
// app/api/trpc/[trpc]/route.ts
import { fetchRequestHandler } from '@trpc/server/adapters/fetch';
import { appRouter } from '@/server/api/root';
import { createContext } from '@/server/api/context';
const handler = (req: Request) =>
fetchRequestHandler({
endpoint: '/api/trpc',
req,
router: appRouter,
createContext,
});
export { handler as GET, handler as POST };
रिएक्ट में क्लाइंट का उपयोग
// trpc/react.tsx
'use client';
import { createTRPCReact } from '@trpc/react-query';
import type { AppRouter } from '@/server/api/root';
export const trpc = createTRPCReact<AppRouter>();
// components/UserList.tsx
'use client';
import { trpc } from '@/trpc/react';
export function UserList() {
const { data, isLoading, error } = trpc.user.list.useQuery({
page: 1,
limit: 20,
search: 'alice',
});
const createUser = trpc.user.create.useMutation({
onSuccess: () => {
utils.user.list.invalidate(); // refetch list
},
});
const utils = trpc.useUtils();
if (isLoading) return <Spinner />;
if (error) return <Error message={error.message} />;
return (
<div>
{data?.users.map(user => <UserCard key={user.id} user={user} />)}
<button onClick={() => createUser.mutate({ name: 'Bob', email: 'bob@example.com' })}>
{createUser.isPending ? 'Creating...' : 'Add User'}
</button>
</div>
);
}
// Server component usage (no hook)
import { api } from '@/trpc/server';
export default async function Page() {
const users = await api.user.list.query({ page: 1, limit: 10 });
return <UserList initialData={users} />;
}
2026 में टीआरपीसी फुल-स्टैक टाइपस्क्रिप्ट प्रकार की सुरक्षा के लिए स्वर्ण मानक है। डीएक्स सुधार नाटकीय है – आपका आईडीई बिना किसी कोड जनरेशन चरण के एपीआई तर्क और रिटर्न प्रकारों को स्वत: पूर्ण करता है। इनपुट सत्यापन और नेक्स्ट.जेएस ऐप राउटर के लिए ज़ॉड के साथ संयुक्त, टीआरपीसी सबसे सख्त संभव टाइपस्क्रिप्ट फुल-स्टैक अनुभव बनाता है। इसे किसी भी प्रोजेक्ट के लिए उपयोग करें जहां टाइपस्क्रिप्ट का उपयोग क्लाइंट और सर्वर दोनों पर किया जाता है।
🔗 Share this article
✍️ Leave a Comment