* cleanup legacy "3 dot" check (#2625)
* Allow to peers behind NAT to get up to preferred_max connections (#2543)
Allow to peers behind NAT to get up to preffered_max connections
If peer has only outbound connections it's mot likely behind NAT and we should not stop it from getting more outbound connections
* Reduce usage of unwrap in p2p crate (#2627)
Also change store crate a bit
* Simplify (and fix) output_pos cleanup during chain compaction (#2609)
* expose leaf pos iterator
use it for various things in txhashset when iterating over outputs
* fix
* cleanup
* rebuild output_pos index (and clear it out first) when compacting the chain
* fixup tests
* refactor to match on (output, proof) tuple
* add comments to compact() to explain what is going on.
* get rid of some boxing around the leaf_set iterator
* cleanup
* [docs] Add switch commitment documentation (#2526)
* remove references to no-longer existing switch commitment hash
(as switch commitments were removed in ca8447f3bd
and moved into the blinding factor of the Pedersen Commitment)
* some rewording (points vs curves) and fix of small formatting issues
* Add switch commitment documentation
* [docs] Documents in grin repo had translated in Korean. (#2604)
* Start to M/W intro translate in Korean
* translate in Korean
* add korean translation on intro
* table_of_content.md translate in Korean.
* table_of_content_KR.md finish translate in Korean, start to translate State_KR.md
* add state_KR.md & commit some translation in State_KR.md
* WIP stat_KR.md translation
* add build_KR.md && stratum_KR.md
* finish translate stratum_KR.md & table_of_content_KR.md
* rename intro.KR.md to intro_KR.md
* add intro_KR.md file path each language's intro.md
* add Korean translation file path to stratum.md & table_of_contents.md
* fix difference with grin/master
* Fix TxHashSet file filter for Windows. (#2641)
* Fix TxHashSet file filter for Windows.
* rustfmt
* Updating regexp
* Adding in test case
* Display the current download rate rather than the average when syncing the chain (#2633)
* When syncing the chain, calculate the displayed download speed using the current rate from the most recent iteration, rather than the average download speed from the entire syncing process.
* Replace the explicitly ignored variables in the pattern with an implicit ignore
* remove root = true from editorconfig (#2655)
* Add Medium post to intro (#2654)
Spoke to @yeastplume who agreed it makes sense to add the "Grin Transactions Explained, Step-by-Step" Medium post to intro.md
Open for suggestions on a better location.
* add a new configure item for log_max_files (#2601)
* add a new configure item for log_max_files
* rustfmt
* use a constant instead of multiple 32
* rustfmt
* Fix the build warning of deprecated trim_right_matches (#2662)
* [DOC] state.md, build.md and chain directory documents translate in Korean. (#2649)
* add md files for translation.
* start to translation fast-sync, code_structure. add file build_KR.md, states_KR.md
* add dandelion_KR.md && simulation_KR.md for Korean translation.
* add md files for translation.
* start to translation fast-sync, code_structure. add file build_KR.md, states_KR.md
* add dandelion_KR.md && simulation_KR.md for Korean translation.
* remove some useless md files for translation. this is rearrange set up translation order.
* add dot end of sentence & translate build.md in korean
* remove fast-sync_KR.md
* finish build_KR.md translation
* finish build_KR.md translation
* finish translation state_KR.md & add phrase in state.md to move other language md file
* translate blocks_and_headers.md && chain_sync.md in Korean
* add . in chain_sync.md , translation finished in doc/chain dir.
* fix some miss typos
* Api documentation fixes (#2646)
* Fix the API documentation for Chain Validate (v1/chain/validate). It was documented as a POST, but it is actually a GET request, which can be seen in its handler ChainValidationHandler
* Update the API V1 route list response to include the headers and merkleproof routes. Also clarify that for the chain/outputs route you must specify either byids or byheight to select outputs.
* refactor(ci): reorganize CI related code (#2658)
Break-down the CI related code into smaller more maintainable pieces.
* Specify grin or nanogrins in API docs where applicable (#2642)
* Set Content-Type in API client (#2680)
* Reduce number of unwraps in chain crate (#2679)
* fix: the restart of state sync doesn't work sometimes (#2687)
* let check_txhashset_needed return true on abnormal case (#2684)
* Reduce number of unwwaps in api crate (#2681)
* Reduce number of unwwaps in api crate
* Format use section
* Small QoL improvements for wallet developers (#2651)
* Small changes for wallet devs
* Move create_nonce into Keychain trait
* Replace match by map_err
* Add flag to Slate to skip fee check
* Fix secp dependency
* Remove check_fee flag in Slate
* Add Japanese edition of build.md (#2697)
* catch the panic to avoid peer thread quit early (#2686)
* catch the panic to avoid peer thread quit before taking the chance to ban
* move catch wrapper logic down into the util crate
* log the panic info
* keep txhashset.rs untouched
* remove a warning
* [DOC] dandelion.md, simulation.md ,fast-sync.md and pruning.md documents translate in Korean. (#2678)
* Show response code in API client error message (#2683)
It's hard to investigate what happens when an API client error is
printed out
* Add some better logging for get_outputs_by_id failure states (#2705)
* Switch commitment doc fixes (#2645)
Fix some typos and remove the use of parentheses in a
couple of places to make the reading flow a bit better.
* docs: update/add new README.md badges (#2708)
Replace existing badges with SVG counterparts and add a bunch of new ones.
* Update intro.md (#2702)
Add mention of censoring attack prevented by range proofs
* use sandbox folder for txhashset validation on state sync (#2685)
* use sandbox folder for txhashset validation on state sync
* rustfmt
* use temp directory as the sandbox instead actual db_root txhashset dir
* rustfmt
* move txhashset overwrite to the end of full validation
* fix travis-ci test
* rustfmt
* fix: hashset have 2 folders including txhashset and header
* rustfmt
*
(1)switch to rebuild_header_mmr instead of copy the sandbox header mmr
(2)lock txhashset when overwriting and opening and rebuild
* minor improve on sandbox_dir
* add Japanese edition of state.md (#2703)
* Attempt to fix broken TUI locale (#2713)
Can confirm that on the same machine 1.0.2 TUI looks great and is broken on
the current master. Bump of `cursive` version fixed it for me.
Fixes #2676
* clean the header folder in sandbox (#2716)
* forgot to clean the header folder in sandbox in #2685
* Reduce number of unwraps in servers crate (#2707)
It doesn't include stratum server which is sufficiently changed in 1.1
branch and adapters, which is big enough for a separate PR.
* rustfmt
* change version to beta
30 KiB
Node API Documentation
Table of Contents
- Blocks Endpoint
- Headers Endpoint
- Chain Endpoint
- Status Endpoint
- TxHashSet Endpoint
- Pool Endpoint
- Peers Endpoint
Blocks Endpoint
GET Blocks
Returns data about a specific block given a hash, a height or an unspent commit.
Optionally return results as "compact blocks" by passing ?compact
query.
-
URL
- /v1/blocks/hash
- /v1/blocks/height
- /v1/blocks/commit
-
Method:
GET
-
URL Params
Required:
hash=[string]
orheight=[number]
orcommit=[string]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description header object The block header - hash string Hash of the current block - version number Version of the block - height number Height of this block since the genesis block (height 0) - previous string Hash of the block previous to this in the chain - prev_root string Root hash of the header MMR at the previous header - timestamp string RFC3339 timestamp at which the block was built - output_root string Merklish root of all the commitments in the TxHashSet - range_proof_root string Merklish root of all range proofs in the TxHashSet - kernel_root string Merklish root of all transaction kernels in the TxHashSet - nonce number Nonce increment used to mine this block - edge_bits number Size of the cuckoo graph (2_log of number of edges) - cuckoo_solution []number The Cuckoo solution for this block - total_difficulty number Total accumulated difficulty since genesis block - secondary_scaling number Variable difficulty scaling factor for secondary proof of work - total_kernel_offset string Total kernel offset since genesis block inputs []string Input transactions outputs []object Outputs transactions - output_type string The type of output Coinbase - commit string The homomorphic commitment representing the output's amount (as hex string) - spent bool Whether the output has been spent - proof string Rangeproof (as hex string) - proof_hash string Rangeproof hash (as hex string) - block_height number Block height at which the output is found - merkle_proof string Merkle proof kernels []object Transaction Kernels (a proof that a transaction sums to zero) - features object Options for a kernel's structure or use - bits number Representation of the features in bits - fee number Fee originally included in the transaction this proof is for - lock_height number The max lock_height of all inputs to this transaction - excess []number Remainder of the sum of all transaction commitments - excess_sig []number The signature proving the excess is a valid public key (signs the tx fee)
-
Error Response:
- Code: 404 or 500
- Content:
failed to parse input: Not found.
-
Sample Call:
$.ajax({ url: "/v1/blocks/1", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
Headers Endpoint
GET Headers
Returns data about a block headers given either a hash or height or an output commit.
-
URL
- /v1/headers/hash
- /v1/headers/height
- /v1/headers/commit
-
Method:
GET
-
URL Params
Required:
hash=[string]
orheight=[number]
orcommit=[string]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description header object The block header - hash string Hash of the current block - version number Version of the block - height number Height of this block since the genesis block (height 0) - previous string Hash of the block previous to this in the chain - prev_root string Root hash of the header MMR at the previous header - timestamp string RFC3339 timestamp at which the block was built - output_root string Merklish root of all the commitments in the TxHashSet - range_proof_root string Merklish root of all range proofs in the TxHashSet - kernel_root string Merklish root of all transaction kernels in the TxHashSet - nonce number Nonce increment used to mine this block - edge_bits number Size of the cuckoo graph (2_log of number of edges) - cuckoo_solution []number The Cuckoo solution for this block - total_difficulty number Total accumulated difficulty since genesis block - total_kernel_offset string Total kernel offset since genesis block
-
Error Response:
- Code: 404 or 500
- Content:
failed to parse input: Not found.
-
Sample Call:
$.ajax({ url: "/v1/headers/1", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
Chain Endpoint
GET Chain
Retrieves details about the state of the current fork tip.
-
URL
/v1/chain
-
Method:
GET
-
URL Params
None
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description height number Height of the tip (max height of the fork) last_block_pushed string Last block pushed to the fork prev_block_to_last string Block previous to last total_difficulty number Total difficulty accumulated on that fork since genesis block
-
Error Response:
- Code: 404 or 500
- Content:
failed to parse input: Not found.
-
Sample Call:
$.ajax({ url: "/v1/chain", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
POST Chain Compact
Trigger a compaction of the chain state to regain storage space.
-
URL
/v1/chain/compact
-
Method:
POST
-
URL Params
None
-
Data Params
None
-
Success Response:
- Code: 200
-
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/chain/compact", dataType: "json", type : "POST", success : function(r) { console.log(r); } });
GET Chain Validate
Trigger a validation of the chain state.
-
URL
/v1/chain/validate
-
Method:
GET
-
URL Params
None
-
Data Params
None
-
Success Response:
- Code: 200
-
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/chain/validate", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET Chain Outputs By IDs
Retrieves details about specifics outputs. Supports retrieval of multiple outputs in a single request.
-
URL
- /v1/chain/outputs/byids?id=x
- /v1/chain/outputs/byids?id=x,y,z
- /v1/chain/outputs/byids?id=x&id=y&id=z
-
Method:
GET
-
URL Params
Required:
id=[string]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description outputs []object Outputs - output_type string The type of output Coinbase - commit string The homomorphic commitment representing the output's amount (as hex string) - spent bool Whether the output has been spent - proof string Rangeproof (as hex string) - proof_hash string Rangeproof hash (as hex string) - block_height number Block height at which the output is found - merkle_proof string Merkle proof
-
Error Response:
- Code: 404 or 500
- Content:
[]
-
Sample Call:
$.ajax({ url: "/v1/chain/outputs/byids?id=0803516094a30830ed9fedff1c63251b51703ddffbb73f944d9e33e8fa5d17444f", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET Chain Outputs By Height
Retrieves details about specifics outputs. Supports retrieval of multiple outputs in a single request.
-
URL
/v1/chain/outputs/byheight?start_height=x&end_height=y
-
Method:
GET
-
URL Params
Required:
start_height=[number]
end_height=[number]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description header object The block header - hash string Hash of the current block - height number Height of this block since the genesis block (height 0) - previous string Hash of the block previous to this in the chain outputs []object Outputs - output_type string The type of output Coinbase - commit string The homomorphic commitment representing the output's amount (as hex string) - spent bool Whether the output has been spent - proof string Rangeproof (as hex string) - proof_hash string Rangeproof hash (as hex string) - block_height number Block height at which the output is found - merkle_proof string Merkle proof
-
Error Response:
- Code: 404 or 500
- Content:
[]
-
Sample Call:
$.ajax({ url: "/v1/chain/outputs/byheight?start_height=101&end_height=200", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
Status Endpoint
GET Status
Returns various information about the node and the network
-
URL
/v1/status
-
Method:
GET
-
URL Params
None
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description protocol_version number The node protocol version user_agent number The node user agent connections number The current number of connections tip object The state of the current fork tip height number Height of the tip (max height of the fork) last_block_pushed string Last block pushed to the fork prev_block_to_last string Block previous to last total_difficulty number Total difficulty accumulated on that fork since genesis block
-
Error Response:
- Code: 404 or 500
- Content:
failed to parse input: Not found.
-
Sample Call:
$.ajax({ url: "/v1/stats", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
TxHashSet Endpoint
GET TxHashSet Roots
Retrieve the roots of the TxHashSet
-
URL
/v1/txhashset/roots
-
Method:
GET
-
URL Params
None
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description output_root_hash string Output root hash range_proof_root_hash string Rangeproof root hash kernel_root_hash string Kernel set root hash
-
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/txhashset/roots", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET TxHashSet Last Outputs
Retrieves the last n outputs inserted into the tree.
-
URL
- /v1/txhashset/lastoutputs (gets last 10)
- /v1/txhashset/lastoutputs?n=x
-
Method:
GET
-
URL Params
Required:
n=[number]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Array of
Field Type Description hash string hash of the outputs -
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/txhashset/lastoutputs?n=20", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET TxHashSet Last Range Proofs
Retrieves the last n rangeproofs inserted in to the tree.
-
URL
- /v1/txhashset/lastrangeproofs (gets last 10)
- /v1/txhashset/lastrangeproofs?n=x
-
Method:
GET
-
URL Params
Required:
n=[number]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Array of
Field Type Description hash string hash of the rangeproofs -
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "v1/txhashset/lastrangeproofs", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET TxHashSet Last Kernels
Retrieves the last n kernels inserted in to the tree.
-
URL
- /v1/txhashset/lastkernels (gets last 10)
- /v1/txhashset/lastkernels?n=x
-
Method:
GET
-
URL Params
Required:
n=[number]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Array of
Field Type Description hash string hash of the kernels -
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/txhashset/lastkernels?n=20", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET TxHashSet Outputs
UTXO traversal. Retrieves last utxos since a start index until a max.
-
URL
/v1/txhashset/outputs?start_index=x&max=y
-
Method:
GET
-
URL Params
Required:
start_index=[number]
max=[number]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description highest_index number The last available output index last_retrieved_index number The last insertion index retrieved outputs []object Outputs - output_type string The type of output Coinbase - commit string The homomorphic commitment representing the output's amount (as hex string) - spent bool Whether the output has been spent - proof string Rangeproof (as hex string) - proof_hash string Rangeproof hash (as hex string) - block_height number Block height at which the output is found - merkle_proof string Merkle proof kernels []object Transaction Kernels (a proof that a transaction sums to zero) - features object Options for a kernel's structure or use - bits number Representation of the features in bits - fee number Fee originally included in the transaction this proof is for - lock_height number The max lock_height of all inputs to this transaction - excess []number Remainder of the sum of all transaction commitments - excess_sig []number The signature proving the excess is a valid public key (signs the tx fee)
-
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/txhashset/outputs?start_index=1&max=100", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET TxHashSet Merkle Proof
Build a merkle proof for a given output id and return a dummy output with merkle proof for position filled out.
-
URL
/v1/txhashset/merkleproof?id=x
-
Method:
GET
-
URL Params
Required:
id=[string]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description outputs []object Outputs - output_type string The type of output Coinbase - commit string The homomorphic commitment representing the output's amount (as hex string) - spent bool Whether the output has been spent - proof string Rangeproof (as hex string) - proof_hash string Rangeproof hash (as hex string) - block_height number Block height at which the output is found - merkle_proof string Merkle proof
-
Error Response:
- Code: 404 or 500
-
Sample Call:
$.ajax({ url: "/v1/txhashset/merkleproof?id=0803516094a30830ed9fedff1c63251b51703ddffbb73f944d9e33e8fa5d17444f", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
Pool Endpoint
GET Pool
Retrieves basic information about the transaction pool.
-
URL
/v1/pool
-
Method:
GET
-
URL Params
None
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description pool_size number Number of transactions in the memory pool
-
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/pool", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
POST Pool Push
Push new transaction to our local transaction pool. Add ?fluff
at the end of the URL to bypass Dandelion relay.
-
URL
/v1/pool/push
-
Method:
POST
-
URL Params
None
-
Data Params
file=[string]
(hex encoded transaction) -
Success Response:
- Code: 200
-
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/pool/push", dataType: "json", type : "POST", data: { file: tx }, success : function(r) { console.log(r); } });
Peers Endpoint
POST Peers Ban
Ban a specific peer.
-
URL
/v1/peers/a.b.c.d:p/ban
-
Method:
POST
-
URL Params
a.b.c.d:p=[string]
-
Data Params
None
-
Success Response:
- Code: 200
-
Error Response:
- Code: 400
-
Sample Call:
$.ajax({ url: "/v1/peers/192.168.1.1:13414/ban", dataType: "json", type : "POST", success : function(r) { console.log(r); } });
POST Peers Unban
Unban a specific peer.
-
URL
/v1/a.b.c.d:p/unban
-
Method:
POST
-
URL Params
a.b.c.d:p=[string]
-
Data Params
None
-
Success Response:
- Code: 200
-
Error Response:
- Code: 400
-
Sample Call:
$.ajax({ url: "/v1/192.168.1.1:13414/unban", dataType: "json", type : "POST", success : function(r) { console.log(r); } });
GET Peers All
Retrieves all peers in db.
-
URL
/v1/peers/all
-
Method:
GET
-
URL Params
None
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Array of
Field Type Description addr string Network address of the peer capabilities object What capabilities the peer advertises - bits number Representation of the capabilities in bits user_agent string The peer user agent flags string State the peer has been detected with. last_banned number The time the peer was last banned ban_reason string The reason for the ban -
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/peers/all", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET Peers Connected
Retrieves all connected peers
-
URL
/v1/peers/connected
-
Method:
GET
-
URL Params
None
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Array of
Field Type Description capabilities object What capabilities the peer advertises - bits number Representation of the capabilities in bits user_agent string The peer user agent version number Software version of the peer addr string Network address of the peer total_difficulty number Total of difficulty of the peer height number Height of the peer direction string Direction of the connection (Inbound -
Error Response:
- Code: 500
-
Sample Call:
$.ajax({ url: "/v1/peers/connected", dataType: "json", type : "GET", success : function(r) { console.log(r); } });
GET Peers
Retrieves information about a specific peer.
-
URL
/v1/peers/a.b.c.d
-
Method:
GET
-
URL Params
a.b.c.d=[string]
-
Data Params
None
-
Success Response:
- Code: 200
- Content:
Field Type Description addr string Network address of the peer capabilities object What capabilities the peer advertises - bits number Representation of the capabilities in bits user_agent string The peer user agent flags string State the peer has been detected with. last_banned number The time the peer was last banned ban_reason string The reason for the ban
-
Error Response:
- Code: 404 or 500
-
Sample Call:
$.ajax({ url: "/v1/peers/192.168.1.2", dataType: "json", type : "GET", success : function(r) { console.log(r); } });