diff options
author | Alex <i@neonxp.dev> | 2022-06-30 19:12:28 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-06-30 19:12:28 +0300 |
commit | 3d69d1e7eabf8dbf1cb502a87787fe9ed120edc8 (patch) | |
tree | 0c1b7a657b5e019484e935996323420874b5ef57 /README.md | |
parent | 058331685cbdb73a4610110eb5599c0628e51c26 (diff) | |
parent | 7c86c2bfcf7be89492bc3df54ad3aaaf8a589043 (diff) |
Merge pull request #3 from jon4hz/feat-no-paramsv1.2.0
feat: add wrapper supporting no request params
Diffstat (limited to 'README.md')
-rw-r--r-- | README.md | 23 |
1 files changed, 20 insertions, 3 deletions
@@ -38,18 +38,30 @@ Go 1.18+ required ) ``` -3. Write handler: +3. Write handlers: ```go + + // This handler supports request parameters func Multiply(ctx context.Context, args *Args) (int, error) { return args.A * args.B, nil } + + // This handler has no request parameters + func Hello(ctx context.Context) (string, error) { + return "World", 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) + A handler must have a context as first parameter and may have a second parameter, representing request paramters (input of any json serializable type). A handler always returns exactly two values (output of any json serializable type and error). + +4. Wrap the handler using one of the two functions `rpc.H` (supporting req params) or `rpc.HS` (no params) and register it with the server: -4. Wrap handler with `rpc.H` method and register it in server: ```go + // handler has params s.Register("multiply", rpc.H(Multiply)) + + // handler has no params + s.Register("hello", rpc.HS(Hello)) ``` 5. Run RPC server: @@ -96,6 +108,7 @@ func main() { s.Register("multiply", rpc.H(Multiply)) s.Register("divide", rpc.H(Divide)) + s.Register("hello", rpc.HS(Hello)) s.Run(context.Background()) } @@ -108,6 +121,10 @@ func Divide(ctx context.Context, args *Args) (*Quotient, error) { //... } +func Hello(ctx context.Context) (string, error) { + // ... +} + type Args struct { A int `json:"a"` B int `json:"b"` |