2014-11-20 12:39:09 -03:00
Unauthenticated REST Interface
==============================
The REST API can be enabled with the `-rest` option.
Supported API
-------------
2015-04-21 15:20:24 -03:00
####Transactions
2015-05-18 10:55:03 -03:00
`GET /rest/tx/<TX-HASH>.<bin|hex|json>`
2014-11-20 12:39:09 -03:00
Given a transaction hash,
Returns a transaction, in binary, hex-encoded binary or JSON formats.
2014-12-29 16:26:47 -03:00
For full TX query capability, one must enable the transaction index via "txindex=1" command line / configuration option.
2015-04-21 15:20:24 -03:00
####Blocks
2015-05-18 10:55:03 -03:00
`GET /rest/block/<BLOCK-HASH>.<bin|hex|json>`
`GET /rest/block/notxdetails/<BLOCK-HASH>.<bin|hex|json>`
2014-11-20 12:39:09 -03:00
Given a block hash,
Returns a block, in binary, hex-encoded binary or JSON formats.
The HTTP request and response are both handled entirely in-memory, thus making maximum memory usage at least 2.66MB (1 MB max block, plus hex encoding) per request.
2014-12-06 06:54:09 -03:00
With the /notxdetails/ option JSON response will only contain the transaction hash instead of the complete transaction details. The option only affects the JSON response.
2015-04-21 15:20:24 -03:00
####Blockheaders
`GET /rest/headers/<COUNT>/<BLOCK-HASH>.<bin|hex>`
Given a block hash,
Returns < COUNT > amount of blockheaders in upward direction.
JSON is not supported.
####Chaininfos
2014-12-29 16:26:47 -03:00
`GET /rest/chaininfo.json`
Returns various state info regarding block chain processing.
Only supports JSON as output format.
* chain : (string) current network name as defined in BIP70 (main, test, regtest)
* blocks : (numeric) the current number of blocks processed in the server
* headers : (numeric) the current number of headers we have validated
* bestblockhash : (string) the hash of the currently best block
* difficulty : (numeric) the current difficulty
* verificationprogress : (numeric) estimate of verification progress [0..1]
* chainwork : (string) total amount of work in active chain, in hexadecimal
2014-11-20 12:39:09 -03:00
2015-05-18 10:55:03 -03:00
####Query UTXO set
2015-05-27 10:56:16 -03:00
`GET /rest/getutxos/<checkmempool>/<txid>-<n>/<txid>-<n>/.../<txid>-<n>.<bin|hex|json>`
2015-04-21 15:32:37 -03:00
2015-05-18 10:55:03 -03:00
The getutxo command allows querying of the UTXO set given a set of outpoints.
2015-04-21 15:32:37 -03:00
See BIP64 for input and output serialisation:
https://github.com/bitcoin/bips/blob/master/bip-0064.mediawiki
2015-05-18 10:55:03 -03:00
Example:
```
2015-05-27 10:56:16 -03:00
$ curl localhost:18332/rest/getutxos/checkmempool/b2cdfd7b89def827ff8af7cd9bff7627ff72e5e8b0f71210f92ea7a4000c5d75-0.json 2>/dev/null | json_pp
2015-05-18 10:55:03 -03:00
{
"chaintipHash" : "00000000fb01a7f3745a717f8caebee056c484e6e0bfe4a9591c235bb70506fb",
"chainHeight" : 325347,
"utxos" : [
{
"scriptPubKey" : {
"addresses" : [
"mi7as51dvLJsizWnTMurtRmrP8hG2m1XvD"
],
"type" : "pubkeyhash",
"hex" : "76a9141c7cebb529b86a04c683dfa87be49de35bcf589e88ac",
"reqSigs" : 1,
"asm" : "OP_DUP OP_HASH160 1c7cebb529b86a04c683dfa87be49de35bcf589e OP_EQUALVERIFY OP_CHECKSIG"
},
"value" : 8.8687,
"height" : 2147483647,
"txvers" : 1
}
],
"bitmap" : "1"
}
```
2015-04-21 15:32:37 -03:00
2014-11-20 12:39:09 -03:00
Risks
-------------
2015-03-05 05:51:52 -03:00
Running a webbrowser on the same node with a REST enabled bitcoind can be a risk. Accessing prepared XSS websites could read out tx/block data of your node by placing links like `<script src="http://127.0.0.1:8332/rest/tx/1234567890.json">` which might break the nodes privacy.