Skip to content

Commit

Permalink
docs: add websocket versioning.
Browse files Browse the repository at this point in the history
This adds a section for versioning websockets accoring to
the per-method versioning sheme.
  • Loading branch information
dnldd committed Mar 20, 2022
1 parent 2f22fe4 commit 10524df
Showing 1 changed file with 84 additions and 1 deletion.
85 changes: 84 additions & 1 deletion docs/rpc_api_versioning.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
5. [Versioned Endpoint Deprecation And Removal Scheme](#DeprecationAndRemovalScheme)<br />
6. [Versioned Endpoint JSON-RPC Unit Testing](#UnitTesting)<br />
7. [Versioned Endpoint Documentation](#Documentation)<br />
8. [Websocket Endpoints And Example](#Websockets)


<a name="PerMethodVersioning" />
Expand Down Expand Up @@ -68,7 +69,7 @@ the `V2` version of the `existaddress` JSON-RPC endpoint will comprise of the
following components:

```go
// JSON-RPC versioned endpoint command definition.
// JSON-RPC versioned endpoint command definition.

// ExistsAddressV2Cmd defines the existsaddressv2 JSON-RPC command.
type ExistsAddressV2Cmd struct {
Expand Down Expand Up @@ -269,6 +270,88 @@ the JSON-RPC API documentation will be updated to include documentation for
// ...
```

<a name="Websockets" />

### 8. Websocket Endpoints & Example
Websocket endpoints will be versioned using the accessibilty scheme outlined
above. Using `rescan` websocket endpoint and the introduction of `rescanv2`
as an example:

```go
// Rescan websocket handler registrations.
var wsHandlersBeforeInit = map[types.Method]wsCommandHandler{
// ...
"rescan": handleRescanV2,
"rescanv1": handleRescan,
"rescanv2": handleRescanV2,
// ...
}
```

```go
// Versioned JSON-RPC endpoint command definition.

// RescanCmd defines the rescan JSON-RPC command.
type RescanCmd struct {
BlockHashes []string
}

// RescanV2Cmd defines the rescanv2 JSON-RPC command.
type RescanV2Cmd struct {
From string
To string
}
```

```go
// Rescan JSON-RPC result type registrations.
var rpcResultTypes = map[types.Method][]interface{}{
// Websocket commands.

// ...
"rescan": nil,
"rescanv1": nil,
"rescanv2": nil,
// ...
}
```

```go
// Rescan Websocket type registrations.
func init() {
// The commands in this file are only usable by websockets.
flags := dcrjson.UFWebsocketOnly

//...
dcrjson.MustRegister(Method("rescan"), (*RescanV2Cmd)(nil), flags)
dcrjson.MustRegister(Method("rescanv1"), (*RescanV1Cmd)(nil), flags)
dcrjson.MustRegister(Method("rescanv2"), (*RescanV2Cmd)(nil), flags)
//...
}
```

```go
// handleRescan implements the rescan command extension for websocket
// connections.
func handleRescan(wsc *wsClient, icmd interface{}) (interface{}, error) {
cmd, ok := icmd.(*types.RescanCmd)
if !ok {
return nil, dcrjson.ErrRPCInternal
}
// ...
}

// handleRescanV2 implements the rescanv2 command extension for websocket
// connections.
func handleRescanV2(wsc *wsClient, icmd interface{}) (interface{}, error) {
cmd, ok := icmd.(*types.RescanV2Cmd)
if !ok {
return nil, dcrjson.ErrRPCInternal
}
// ...
}
```

With the outlined schemes adhered to, the versioned endpoint should be ready
for use once `dcrctl` is rebuilt once the `rpc/jsonrpc/types` dependency is
replaced with the updated local changes.

0 comments on commit 10524df

Please sign in to comment.