dcrd/dcrjson
2023-08-23 14:13:51 -05:00
..
cmdinfo_test.go dcrjson: update error types. 2020-12-17 13:36:37 -06:00
cmdinfo.go dcrjson: Introduce v3 and move types to module. 2019-07-19 08:49:49 -05:00
cmdparse_test.go dcrjson: update error types. 2020-12-17 13:36:37 -06:00
cmdparse.go dcrjson: Prepare v4.0.1. 2023-04-14 10:04:08 -05:00
CONTRIBUTORS Initial Decred Commit. 2016-02-07 14:00:12 -05:00
doc.go multi: Go 1.19 doc comment formatting. 2022-07-30 04:08:58 -05:00
error_test.go dcrjson: Prepare v4.0.1. 2023-04-14 10:04:08 -05:00
error.go multi: Remove a bunch of dup words in comments. 2023-08-23 14:13:51 -05:00
example_test.go dcrjson: Introduce v3 and move types to module. 2019-07-19 08:49:49 -05:00
go.mod dcrjson: Prepare v4.0.1. 2023-04-14 10:04:08 -05:00
go.sum dcrjson: Prepare v4.0.1. 2023-04-14 10:04:08 -05:00
help_test.go dcrjson: Prepare v4.0.1. 2023-04-14 10:04:08 -05:00
help.go multi: Go 1.19 doc comment formatting. 2022-07-30 04:08:58 -05:00
helpers_test.go dcrjson: Introduce v3 and move types to module. 2019-07-19 08:49:49 -05:00
helpers.go dcrjson: Introduce v3 and move types to module. 2019-07-19 08:49:49 -05:00
jsonerr.go dcrjson: Prepare v4.0.0. 2021-09-14 14:30:33 -05:00
jsonrpc_test.go multi: sprinkle on more errors.As/Is 2020-12-24 13:46:38 -06:00
jsonrpc.go dcrjson: Prepare v3.1.0. 2020-09-25 12:06:26 -05:00
jsonrpcerr.go rpcserver: Add invalidate/reconsiderblock support. 2021-01-07 17:48:17 -06:00
parse_test.go multi: preallocate memory. 2019-03-09 16:43:48 -06:00
parse.go dcrjson: Remove unused vote bit concat codec funcs. 2018-08-05 16:24:56 -05:00
README.md docs: Update for dcrjson v4 module. 2021-09-14 14:30:31 -05:00
register_test.go multi: Avoid range capture for Go 1.22 changes. 2023-07-31 11:36:52 -05:00
register.go dcrjson: Reject dup method type registrations. 2020-10-15 17:03:50 -05:00

dcrjson

Build Status ISC License Doc

Package dcrjson implements infrastructure for marshalling to and from the decred JSON-RPC API via concrete types. A comprehensive suite of tests is provided to ensure proper functionality.

Although this package was primarily written for the decred, it has intentionally been designed so it can be used as a standalone package for any projects needing to marshal to and from decred JSON-RPC requests and responses.

Note that although it's possible to use this package directly to implement an RPC client, it is not recommended since it is only intended as an infrastructure package. Instead, RPC clients should use the rpcclient package which provides a full blown RPC client with many features such as automatic connection management, websocket support, automatic notification re-registration on reconnect, and conversion from the raw underlying RPC types (strings, floats, ints, etc) to higher-level types with many nice and useful properties.

Installation and Updating

This package is part of the github.com/decred/dcrd/dcrjson/v4 module. Use the standard go tooling for working with modules to incorporate it.

Examples

  • Marshal Command Demonstrates how to create and marshal a command into a JSON-RPC request.

  • Parse Command Demonstrates how to unmarshal a JSON-RPC request and then parse the params of the concrete request into a concrete command.

  • Marshal Response Demonstrates how to marshal a JSON-RPC response.

  • Unmarshal Response Demonstrates how to unmarshal a JSON-RPC response and then unmarshal the result field in the response to a concrete type.

License

Package dcrjson is licensed under the copyfree ISC License.