From 440f3f4604f3489113f6705b8da67d839e52360e Mon Sep 17 00:00:00 2001 From: Alexander Kiryukhin Date: Mon, 31 Jan 2022 02:31:43 +0300 Subject: initial --- README.md | 74 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 README.md (limited to 'README.md') diff --git a/README.md b/README.md new file mode 100644 index 0000000..7f7c963 --- /dev/null +++ b/README.md @@ -0,0 +1,74 @@ +# JSON-RPC 2.0 + +Golang implementation of JSON-RPC 2.0 server with generics. + +Go 1.18+ required + +## Features: + +- [x] Batch request and responses +- [ ] WebSockets + +## Usage + +1. Create JSON-RPC 2.0 server: + ```go + s := jsonrpc2.New() + ``` +2. Write handler: + ```go + func Multiply(ctx context.Context, args *Args) (int, error) { + return args.A * args.B, nil + } + ``` + Handler must have exact two arguments (context and input of any json serializable type) and exact two return values (output of any json serializable type and error) +3. Wrap handler with `jsonrpc2.Wrap` method and register it in server: + ```go + s.Register("multiply", jsonrpc2.Wrap(Multiply)) + ``` +4. Use server as common http handler: + ```go + http.ListenAndServe(":8000", s) + ``` + +## Complete example + +[Full code](/examples/http) + +```go +package main + +import ( + "context" + "net/http" + + "github.com/neonxp/rpc" +) + +func main() { + s := jsonrpc2.New() + s.Register("multiply", jsonrpc2.Wrap(Multiply)) // Register handlers + s.Register("divide", jsonrpc2.Wrap(Divide)) + + http.ListenAndServe(":8000", s) +} + +func Multiply(ctx context.Context, args *Args) (int, error) { + //... +} + +func Divide(ctx context.Context, args *Args) (*Quotient, error) { + //... +} + +type Args struct { + A int `json:"a"` + B int `json:"b"` +} + +type Quotient struct { + Quo int `json:"quo"` + Rem int `json:"rem"` +} + +``` \ No newline at end of file -- cgit v1.2.3