mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-23 13:24:18 +00:00
[REST] add /rest/chaininfos
This commit is contained in:
parent
e5153095ea
commit
59582c8b8d
@ -78,7 +78,7 @@ class RESTTest (BitcoinTestFramework):
|
|||||||
|
|
||||||
# check hex format response
|
# check hex format response
|
||||||
hex_string = http_get_call(url.hostname, url.port, '/rest/tx/'+tx_hash+self.FORMAT_SEPARATOR+"hex", True)
|
hex_string = http_get_call(url.hostname, url.port, '/rest/tx/'+tx_hash+self.FORMAT_SEPARATOR+"hex", True)
|
||||||
assert_equal(response.status, 200)
|
assert_equal(hex_string.status, 200)
|
||||||
assert_greater_than(int(response.getheader('content-length')), 10)
|
assert_greater_than(int(response.getheader('content-length')), 10)
|
||||||
|
|
||||||
# check block tx details
|
# check block tx details
|
||||||
@ -106,5 +106,12 @@ class RESTTest (BitcoinTestFramework):
|
|||||||
for tx in txs:
|
for tx in txs:
|
||||||
assert_equal(tx in json_obj['tx'], True)
|
assert_equal(tx in json_obj['tx'], True)
|
||||||
|
|
||||||
|
#test rest bestblock
|
||||||
|
bb_hash = self.nodes[0].getbestblockhash()
|
||||||
|
|
||||||
|
json_string = http_get_call(url.hostname, url.port, '/rest/chaininfo.json')
|
||||||
|
json_obj = json.loads(json_string)
|
||||||
|
assert_equal(json_obj['bestblockhash'], bb_hash)
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
RESTTest ().main ()
|
RESTTest ().main ()
|
||||||
|
33
src/rest.cpp
33
src/rest.cpp
@ -95,7 +95,7 @@ static bool rest_headers(AcceptedConnection* conn,
|
|||||||
bool fRun)
|
bool fRun)
|
||||||
{
|
{
|
||||||
vector<string> params;
|
vector<string> params;
|
||||||
enum RetFormat rf = ParseDataFormat(params, strReq);
|
const RetFormat rf = ParseDataFormat(params, strReq);
|
||||||
vector<string> path;
|
vector<string> path;
|
||||||
boost::split(path, params[0], boost::is_any_of("/"));
|
boost::split(path, params[0], boost::is_any_of("/"));
|
||||||
|
|
||||||
@ -159,7 +159,7 @@ static bool rest_block(AcceptedConnection* conn,
|
|||||||
bool showTxDetails)
|
bool showTxDetails)
|
||||||
{
|
{
|
||||||
vector<string> params;
|
vector<string> params;
|
||||||
enum RetFormat rf = ParseDataFormat(params, strReq);
|
const RetFormat rf = ParseDataFormat(params, strReq);
|
||||||
|
|
||||||
string hashStr = params[0];
|
string hashStr = params[0];
|
||||||
uint256 hash;
|
uint256 hash;
|
||||||
@ -226,13 +226,39 @@ static bool rest_block_notxdetails(AcceptedConnection* conn,
|
|||||||
return rest_block(conn, strReq, mapHeaders, fRun, false);
|
return rest_block(conn, strReq, mapHeaders, fRun, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool rest_chaininfo(AcceptedConnection* conn,
|
||||||
|
const std::string& strReq,
|
||||||
|
const std::map<std::string, std::string>& mapHeaders,
|
||||||
|
bool fRun)
|
||||||
|
{
|
||||||
|
vector<string> params;
|
||||||
|
const RetFormat rf = ParseDataFormat(params, strReq);
|
||||||
|
|
||||||
|
switch (rf) {
|
||||||
|
case RF_JSON: {
|
||||||
|
Array rpcParams;
|
||||||
|
Value chainInfoObject = getblockchaininfo(rpcParams, false);
|
||||||
|
|
||||||
|
string strJSON = write_string(chainInfoObject, false) + "\n";
|
||||||
|
conn->stream() << HTTPReply(HTTP_OK, strJSON, fRun) << std::flush;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
default: {
|
||||||
|
throw RESTERR(HTTP_NOT_FOUND, "output format not found (available: json)");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// not reached
|
||||||
|
return true; // continue to process further HTTP reqs on this cxn
|
||||||
|
}
|
||||||
|
|
||||||
static bool rest_tx(AcceptedConnection* conn,
|
static bool rest_tx(AcceptedConnection* conn,
|
||||||
const std::string& strReq,
|
const std::string& strReq,
|
||||||
const std::map<std::string, std::string>& mapHeaders,
|
const std::map<std::string, std::string>& mapHeaders,
|
||||||
bool fRun)
|
bool fRun)
|
||||||
{
|
{
|
||||||
vector<string> params;
|
vector<string> params;
|
||||||
enum RetFormat rf = ParseDataFormat(params, strReq);
|
const RetFormat rf = ParseDataFormat(params, strReq);
|
||||||
|
|
||||||
string hashStr = params[0];
|
string hashStr = params[0];
|
||||||
uint256 hash;
|
uint256 hash;
|
||||||
@ -287,6 +313,7 @@ static const struct {
|
|||||||
{"/rest/tx/", rest_tx},
|
{"/rest/tx/", rest_tx},
|
||||||
{"/rest/block/notxdetails/", rest_block_notxdetails},
|
{"/rest/block/notxdetails/", rest_block_notxdetails},
|
||||||
{"/rest/block/", rest_block_extended},
|
{"/rest/block/", rest_block_extended},
|
||||||
|
{"/rest/chaininfo", rest_chaininfo},
|
||||||
{"/rest/headers/", rest_headers},
|
{"/rest/headers/", rest_headers},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user