tsrpc
Version:
A TypeScript RPC Framework, with runtime type checking and built-in serialization, support both HTTP and WebSocket.
70 lines (50 loc) • 1.62 kB
Markdown
EN / [中文](https://tsrpc.cn/docs/introduction.html)
A TypeScript RPC framework with runtime type checking and binary serialization.
Official site: https://tsrpc.cn (English version is on the way)
- Runtime type checking
- Binary serialization
- Pure TypeScript, without any decorater or other language
- HTTP / WebSocket / and more protocols...
- Optional backward-compatibility to JSON
- High performance and reliable, verified by services over 100,000,000 users
```
npx create-tsrpc-app@latest
```
```ts
export interface ReqHello {
name: string;
}
export interface ResHello {
reply: string;
}
```
```ts
import { ApiCall } from "tsrpc";
export async function ApiHello(call: ApiCall<ReqHello, ResHello>) {
call.succ({
reply: 'Hello, ' + call.req.name
});
}
```
```ts
let ret = await client.callApi('Hello', {
name: 'World'
});
```
https://github.com/k8w/tsrpc-examples
The best TypeScript serialization algorithm ever.
Without any 3rd-party IDL language (like protobuf), it is fully based on TypeScript source file. Define the protocols directly by your code.
This is powered by [TSBuffer](https://github.com/tsbuffer), which is going to be open-source.
TypeScript has the best type system, with some unique advanced features like union type, intersection type, mapped type, etc.
TSBuffer may be the only serialization algorithm that support them all.
## API Reference
See [API Reference](./docs/api/tsrpc.md).