2014-05-07 11:14:39 -05:00
|
|
|
btcrpcclient
|
|
|
|
============
|
|
|
|
|
2014-05-09 01:16:47 -05:00
|
|
|
[![Build Status](https://travis-ci.org/conformal/btcrpcclient.png?branch=master)]
|
|
|
|
(https://travis-ci.org/conformal/btcrpcclient)
|
2014-05-09 01:26:37 -05:00
|
|
|
[![GoDoc](https://godoc.org/github.com/conformal/btcrpcclient?status.png)]
|
|
|
|
(http://godoc.org/github.com/conformal/btcrpcclient)
|
2014-05-09 01:16:47 -05:00
|
|
|
|
2014-05-10 02:47:59 -05:00
|
|
|
btcrpcclient implements a Websocket-enabled Bitcoin JSON-RPC client package
|
|
|
|
written in [Go](http://golang.org/). It provides a robust and easy to use
|
|
|
|
client for interfacing with a Bitcoin RPC server that uses a btcd/bitcoin core
|
|
|
|
compatible Bitcoin JSON-RPC API.
|
2014-05-07 11:14:39 -05:00
|
|
|
|
2014-05-10 02:47:59 -05:00
|
|
|
## Status
|
|
|
|
|
|
|
|
This package is currently under active development. It is already stable and
|
|
|
|
the infrastructure is complete. However, there are still several RPCs left to
|
|
|
|
implement and the API is not stable yet.
|
2014-05-07 11:14:39 -05:00
|
|
|
|
2014-05-09 20:48:05 -05:00
|
|
|
## Documentation
|
2014-05-01 23:18:43 -05:00
|
|
|
|
2014-05-09 20:48:05 -05:00
|
|
|
* [API Reference](http://godoc.org/github.com/conformal/btcrpcclient)
|
|
|
|
* [btcd Websockets Example](https://github.com/conformal/btcrpcclient/blob/master/examples/btcdwebsockets)
|
2014-06-05 20:58:47 -05:00
|
|
|
Connects to a btcd RPC server using TLS-secured websockets, registers for
|
|
|
|
block connected and block disconnected notifications, and gets the current
|
|
|
|
block count
|
|
|
|
* [btcwallet Websockets Example](https://github.com/conformal/btcrpcclient/blob/master/examples/btcwalletwebsockets)
|
|
|
|
Connects to a btcwallet RPC server using TLS-secured websockets, registers for
|
|
|
|
notifications about changes to account balances, and gets a list of unspent
|
|
|
|
transaction outputs (utxos) the wallet can sign
|
2014-05-09 20:48:05 -05:00
|
|
|
* [Bitcoin Core HTTP POST Example](https://github.com/conformal/btcrpcclient/blob/master/examples/bitcoincorehttp)
|
|
|
|
Connects to a bitcoin core RPC server using HTTP POST mode with TLS disabled
|
|
|
|
and gets the current block count
|
|
|
|
|
2014-05-10 02:47:59 -05:00
|
|
|
## Major Features
|
|
|
|
|
|
|
|
* Supports Websockets (btcd/btcwallet) and HTTP POST mode (bitcoin core)
|
|
|
|
* Provides callback and registration functions for btcd/btcwallet notifications
|
|
|
|
* Supports btcd extensions
|
2014-05-10 15:48:14 -05:00
|
|
|
* Translates to and from higher-level and easier to use Go types
|
|
|
|
* Offers a synchronous (blocking) and asynchronous API
|
2014-05-10 02:47:59 -05:00
|
|
|
* When running in Websockets mode (the default):
|
|
|
|
* Automatic reconnect handling (can be disabled)
|
|
|
|
* Outstanding commands are automatically reissued
|
|
|
|
* Registered notifications are automatically reregistered
|
|
|
|
* Back-off support on reconnect attempts
|
|
|
|
|
2014-05-09 20:48:05 -05:00
|
|
|
## Installation
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ go get github.com/conformal/btcrpcclient
|
|
|
|
```
|
2014-05-01 23:18:43 -05:00
|
|
|
|
2014-05-07 11:14:39 -05:00
|
|
|
## License
|
|
|
|
|
|
|
|
Package btcrpcclient is licensed under the [copyfree](http://copyfree.org) ISC
|
|
|
|
License.
|