English / 中文
Ontology Rpc Api
Version 0.7.0
Rpc API list
Method | Parameters | Description | Note |
---|---|---|---|
getbestblockhash | get the hash of the highest height block in the main chain | ||
getblock | height or blockhash,[verbose] | get block by block height or block hash | verbose can be 0 or 1,response is different |
getblockcount | get the number of blocks | ||
getblockhash | height | get block hash by block height | |
getconnectioncount | get the current number of connections for the node | ||
getgenerateblocktime | The time required to create a new block | ||
getrawtransaction | transactionhash | Returns the corresponding transaction information based on the specified hash value. | |
sendrawtransaction | hex | Broadcast transaction. | Serialized signed transactions constructed in the program into hexadecimal strings |
getstorage | script_hash | Returns the stored value according to the contract script hashes and stored key. | |
getversion | Get the version information of the query node | ||
getblocksysfee | According to the specified index, return the system fee before the block. | ||
getcontractstate | script_hash | According to the contract script hash, query the contract information. | |
getmempooltxstate | tx_hash | Query the transaction status in the memory pool. | |
getsmartcodeevent | Get smartcode event | ||
getblockheightbytxhash | tx_hash | get blockheight of txhash | |
getbalance | address | return balance of base58 account address. |
Introduction
Request parameter description:
Field | Type | Description |
---|---|---|
jsonrpc | string | jsonrpc version |
method | string | method name |
params | string | method required parameters |
id | int | any value |
Response parameter description:
Field | Type | Description |
---|---|---|
desc | string | resopnse description |
error | int64 | error code |
jsonrpc | string | jsonrpc version |
id | int | any value |
result | object | program execution result |
Note: The type of result varies with the request.
Block field description
Field | Type | Description |
---|---|---|
Header | *Header | |
Transactions | []*Transaction | |
hash | *Uint256 |
Header field description
Field | Type | Description |
---|---|---|
Version | uint32 | version number |
PrevBlockHash | Uint256 | The hash of the previous block |
TransactionsRoot | Uint256 | The root of the Merkle tree for all transactions in this block |
BlockRoot | Uint256 | blockroot |
Timestamp | int | block timestamp,uinix timestamp |
Height | int | block height |
ConsensusData | uint64 | |
NextBookkeeper | Address | Accounting contract hash value for the next block |
Bookkeepers | []*crypto.PubKey | |
SigData | [][]byte | |
Hash | Uint256 | Script to verify the block |
Transaction field description
Field | Type | Description |
---|---|---|
Version | byte | version number |
TxType | TransactionType | transaction type |
Payload | Payload | payload |
Nonce | uint32 | random number |
Attributes | []*TxAttribute | |
Fee | []*Fee | transaction fees |
NetworkFee | Fixed64 | neitwork fees |
Sigs | []*Sig | signature array |
Hash | *Uint256 | transaction hash |
Rpc API list
1. getbestblockhash
Get the hash of the highest height block in the main chain.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getbestblockhash",
"params": [],
"id": 1
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": "773dd2dae4a9c9275290f89b56e67d7363ea4826dfd4fc13cc01cf73a44b0d0e"
}
Response instruction:
Result: The hash of the highest block height in the main chain.
2. getblock
Get the block information by block hash or height.
Parameter instruction
Parameter | Type | Optional/required | Description |
---|---|---|---|
Hash/height | String/long | Required | Block hash/height |
Verbose | int | Optional | Optional parameter, the default value of verbose is 0. When verbose is 0, it returns the block serialized information, which is represented by a hexadecimal string. To get detailed information from it, you need to call the SDK to deserialize. When verbose is 1, the detailed information of the corresponding block is returned, which is represented by a JSON format string. |
Example
Request:
{
"jsonrpc": "2.0",
"method": "getblock",
"params": ["773dd2dae4a9c9275290f89b56e67d7363ea4826dfd4fc13cc01cf73a44b0d0e"],
"id": 1
}
or
{
"jsonrpc": "2.0",
"method": "getblock",
"params": [100],
"id": 1
}
Response when verbose is nil:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": "00000000ccc7612928aab25db55ab31c35c64929ce4d89f9a16d0753fddf9da63d0c339b77be0e825f3180b4d706045e42a101f5becea5d59a7d6aac58cdff0c0bd0b6a949c6405eae477bb053406c0a4f56a830289798e2d70dc77e0a1d927fa9fb93c47625f316f1bb594150e0f4c3b4c4c6394e0444f876c766b0130527ac46c766b0130c3648c00616c766b51c3c0519c009c6c766b0131527ac46c766b0131c3641000616c766b52c30052c461625400616c766b51c300c36c766b0132527ac46c766b0132c36165b3206c..."
}
Response when verbose = 1:
{
"desc": "SUCCESS",
"error": 0,
"id": 1,
"jsonpc": "2.0",
"result": {
"Hash": "95555da65d6feaa7cde13d6bf12131f750b670569d98c63813441cf24a99c0d2",
"Header": {
"Version": 0,
"PrevBlockHash": "205c905493c7c1e3be7cd58542e45aafb007edcb8363f8ff555f63745f1b7ce5",
"TransactionsRoot": "4452db2634d81e80048002c2f327b25ded4e547ebfcc1b28f28608938b9d2154",
"BlockRoot": "42e01a2b27c182d4e115883c3b166a0fbc019efe2498b568b7febcc83a35346e",
"Timestamp": 1522295648,
"Height": 2,
"ConsensusData": 10322907760044199803,
"NextBookkeeper": "TAAr9AH4NqxXSKur7XTUbmP8wsKD4KPL2t",
"Bookkeepers": [
"120203e45fe0189a36b284e6080c6983cf12879d239886ecee1e257ab992970ecaa000"
],
"SigData": [
"014ed021011a6e0a4e9771b0be9fd156f9fc411968ce1dc4aed18382c85f6827d50373f3e3931966066cdc7dfab52823b79c80df8af25569c33ddf8140df5385b6"
],
"Hash": "95555da65d6feaa7cde13d6bf12131f750b670569d98c63813441cf24a99c0d2"
},
"Transactions": [
{
"Version": 0,
"Nonce": 0,
"TxType": 0,
"Payload": {
"Nonce": 1522295648487066000
},
"Attributes": [],
"Fee": [],
"NetworkFee": 0,
"Sigs": [
{
"PubKeys": [
"120203e45fe0189a36b284e6080c6983cf12879d239886ecee1e257ab992970ecaa000"
],
"M": 1,
"SigData": [
"01021197ad4140a50442b700ad814aeb2595578bf4d97e187a69aacf35917be4a27f76bc1dad2ee9bb386be79ca9638e78e14c869edbc3556499b06cc9c9b9452e"
]
}
],
"Hash": "4452db2634d81e80048002c2f327b25ded4e547ebfcc1b28f28608938b9d2154"
}
]
}
}
3. getblockcount
Get the number of blocks in the main chain.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getblockcount",
"params": [],
"id": 1
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": 2519
}
Response instruction:
Result: the height of the main chain.
4. getblockhash
Returns the hash value of the corresponding block according to the specified index.
Parameter instruction
Index: block index.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getblockhash",
"params": [10000],
"id": 1
}
Reponse:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": "4c1e879872344349067c3b1a30781eeb4f9040d3795db7922f513f6f9660b9b2"
}
5. getconnectioncount
Get the current number of connections for the node.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getconnectioncount",
"params": [],
"id": 1
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": 10
}
6. getgenerateblocktime
Get a list of unconfirmed transactions in memory.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getgenerateblocktime",
"params": [],
"id": 1
}
Reponse:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": [
"b4534f6d4c17cda008a76a1968b7fa6256cd90ca448739eae8e828698ccc44e7"
]
}
These are the undetermined transactions received by the node, that is, those with zero confirmed transactions.
7. getrawtransaction
Returns the corresponding transaction information based on the specified hash value.
Parameter instruction
txid: transaction ID
Verbose: Optional parameter, the default value of verbose is 0, when verbose is 0, it returns the block serialized information, which is represented by a hexadecimal string. To get detailed information from it, you need to call the SDK to deserialize. When verbose is 1, the detailed information of the corresponding block is returned, which is represented by a JSON format string.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getrawtransaction",
"params": ["f4250dab094c38d8265acc15c366dc508d2e14bf5699e12d9df26577ed74d657"],
"id": 1
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": "80000001195876cb34364dc38b730077156c6bc3a7fc570044a66fbfeeea56f71327e8ab0000029b7cffdaa674beae0f930ebe6085af9093e5fe56b34a5c220ccdcf6efc336fc500c65eaf440000000f9a23e06f74cf86b8827a9108ec2e0f89ad956c9b7cffdaa674beae0f930ebe6085af9093e5fe56b34a5c220ccdcf6efc336fc50092e14b5e00000030aab52ad93f6ce17ca07fa88fc191828c58cb71014140915467ecd359684b2dc358024ca750609591aa731a0b309c7fb3cab5cd0836ad3992aa0a24da431f43b68883ea5651d548feb6bd3c8e16376e6e426f91f84c58232103322f35c7819267e721335948d385fae5be66e7ba8c748ac15467dcca0693692dac"
}
or
{
"desc": "SUCCESS",
"error": 0,
"id": 1,
"jsonpc": "2.0",
"result": {
"Version": 0,
"Nonce": 3377520203,
"TxType": 209,
"Payload": {
"Code": "00ff00000000000000000000000000000000000001087472616e736665722d000100017d439492af400d014c2b0cc4975d7252868d8001c484de9cde9d10c3bf49362e6d66a6c3b196b70164",
"GasLimit": 0,
"VmType": 255
},
"Attributes": [
{
"Usage": 0,
"Data": "34336234663163352d373764392d346634342d626262662d326539396136656538376237"
}
],
"Fee": [
{
"Amount": 0,
"Payer": "017d439492af400d014c2b0cc4975d7252868d80"
}
],
"NetworkFee": 0,
"Sigs": [
{
"PubKeys": [
"12020206b47806887dfb13679ae884e7843ef263f54a861792502100f6bb3f5bd896cc"
],
"M": 1,
"SigData": [
"012a0623b31b681c74866c9e72c255ac026a1fcc61867b3f1dc7a25266939e73a24c87c2aceda41174b85a872b11dbf7020a4d52dffbbfefdb704406738dd042bf"
]
}
],
"Hash": "a724c0215afa1aeb31be857f2fc69038cf557b4748941bfed8281473b39152e7"
}
}
8. sendrawtransaction
send transaction.
Parameter instruction
Hex: Serialized signed transactions constructed in the program into hexadecimal strings.Building the parameter,please refer to TestInvokefunction in ontology/http/func_test.go.
How to build the parameter?
Take the “AddAttribute” in the IdContract contract as an example
- build parameter
acct := account.Open(account.WALLET_FILENAME, []byte("passwordtest"))
acc, err := acct.GetDefaultAccount()
pubkey := keypair.SerializePublicKey(acc.PubKey())
funcName := "AddAttribute"
paras := []interface{}{[]byte("did:ont:" + acc.Address.ToBase58()),[]byte("key1"),[]byte("bytes"),[]byte("value1"),pubkey}
builder := neovm.NewParamsBuilder(new(bytes.Buffer))
err = BuildSmartContractParamInter(builder, []interface{}{funcName, params})
codeParams := builder.ToArray()
op_verify,_ := common.HexToBytes("69")
codeaddress,_ := common.HexToBytes("8055b362904715fd84536e754868f4c8d27ca3f6")
codeParams = BytesCombine(codeParams,op_verify)
codeParams = BytesCombine(codeParams,codeaddress)
func BytesCombine(pBytes ...[]byte) []byte {
len := len(pBytes)
s := make([][]byte, len)
for index := 0; index < len; index++ {
s[index] = pBytes[index]
}
sep := []byte("")
return bytes.Join(s, sep)
}
funcName:the smartcontract function name to be called, params: contract function required parameters, codeAddress: smartcontract address
- build transaction
tx := utils.NewInvokeTransaction(vmtypes.VmCode{ VmType: vmtypes.NEOVM, Code: codeParams, }) tx.Nonce = uint32(time.Now().Unix())
- sign transaction
hash := tx.Hash()
sign, _ := signature.Sign(acc.PrivateKey, hash[:])
tx.Sigs = append(tx.Sigs, &ctypes.Sig{
PubKeys: []keypair.PublicKey{acc.PublicKey},
M: 1,
SigData: [][]byte{sign},
})
- Convert transactions to hexadecimal strings
txbf := new(bytes.Buffer) err = tx.Serialize(txbf); common.ToHexString(txbf.Bytes())
Related struct
type Transaction struct {
Version byte
TxType TransactionType
Nonce uint32
Payload Payload
Attributes []*TxAttribute
Fee []*Fee
NetWorkFee common.Fixed64
Sigs []*Sig
hash *common.Uint256
}
type Sig struct {
PubKeys []keypair.PublicKey
M uint8
SigData [][]byte
}
Example
Request:
{
"jsonrpc": "2.0",
"method": "sendrawtransaction",
"params": ["80000001195876cb34364dc38b730077156c6bc3a7fc570044a66fbfeeea56f71327e8ab0000029b7cffdaa674beae0f930ebe6085af9093e5fe56b34a5c220ccdcf6efc336fc500c65eaf440000000f9a23e06f74cf86b8827a9108ec2e0f89ad956c9b7cffdaa674beae0f930ebe6085af9093e5fe56b34a5c220ccdcf6efc336fc50092e14b5e00000030aab52ad93f6ce17ca07fa88fc191828c58cb71014140915467ecd359684b2dc358024ca750609591aa731a0b309c7fb3cab5cd0836ad3992aa0a24da431f43b68883ea5651d548feb6bd3c8e16376e6e426f91f84c58232103322f35c7819267e721335948d385fae5be66e7ba8c748ac15467dcca0693692dac"],
"id": 1
}
Reponse
{
"desc": "SUCCESS",
"error": 0,
"id": 1,
"jsonpc": "2.0",
"result": "498db60e96828581eff991c58fa46abbfd97d2f4a4f9915a11f85c54f2a2fedf"
}
Note:result is txhash
9. getstorage
Returns the stored value according to the contract script hashes and stored key.
Parameter instruction
script_hash: Contract script hash.
Key: stored key (required to be converted into hex string)
Example
Request:
{
"jsonrpc": "2.0",
"method": "getstorage",
"params": ["03febccf81ac85e3d795bc5cbd4e84e907812aa3", "5065746572"],
"id": 15
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 15,
"result": "4c696e"
}
result: Hexadecimal string
10. getversion
Get the version information of the query node.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getversion",
"params": [],
"id": 3
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 3,
"result": {
"port": 0,
"nonce": 156443862,
"useragent": "/ONT:1.0.0/"
}
}
11. getsmartcodeevent
Get smartcode event.
Parameter instruction
blockheight: getsmartcodeevent by blockheight or txHash: getsmartcodeevent by txhash
Example
Request:
{
"jsonrpc": "2.0",
"method": "getsmartcodeevent",
"params": [3],
"id": 3
}
or
{
"jsonrpc": "2.0",
"method": "getsmartcodeevent",
"params": ["3ba4b4e463a717635614595378f2aac78feacc7d4dfda075bfcf9328cbbcdb7c"],
"id": 3
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 3,
"result": {
}
}
or
{
"desc": "SUCCESS",
"error": 0,
"id": 1,
"jsonpc": "2.0",
"result": [
{
"CodeHash":"80e7d2fc22c24c466f44c7688569cc6e6d6c6f92",
"TxHash":"7c3e38afb62db28c7360af7ef3c1baa66aeec27d7d2f60cd22c13ca85b2fd4f3"
"States": [
"transfer",
"TA63xZXqdPLtDeznWQ6Ns4UsbqprLrrLJk",
"TA23xZXqdPLtDeznWQ6Ns4UsbqprLrrLfgf",
100
]
}
]
}
Note: If params is a number, the response result will be the txhash list. If params is txhash, the response result will be smartcode event.
12. getblocksysfee
According to the specified index, return the system fee before the block.
Parameter instruction
Index: Block index
Example
Request:
{
"jsonrpc": "2.0",
"method": "getblocksysfee",
"params": [1005434],
"id": 1
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": "195500"
}
Response instruction:
Result: The system fee before the block and the unit is OntGas.
13. getcontractstate
According to the contract script hash, query the contract information.
Parameter instruction
script_hash: Contract script hash.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getcontractstate",
"params": ["fff49c809d302a2956e9dc0012619a452d4b846c",1],
"id": 1
}
Response:
{
"desc": "SUCCESS",
"error": 0,
"id": 1,
"jsonpc": "2.0",
"result": {
"VmType": 255,
"Code": "4f4e5420546f6b656e",
"NeedStorage": true,
"Name": "ONT",
"CodeVersion": "1.0",
"Author": "Ontology Team",
"Email": "contact@ont.io",
"Description": "Ontology Network ONT Token"
}
}
14. getmempooltxstate
Query the transaction status in the memory pool.
Parameter instruction
tx_hash: transaction hash.
Example
Request:
{
"jsonrpc": "2.0",
"method": "getmempooltxstate",
"params": ["773dd2dae4a9c9275290f89b56e67d7363ea4826dfd4fc13cc01cf73a44b0d0e"],
"id": 1
}
Response:
{
"desc":"SUCCESS",
"error":0,
"jsonrpc": "2.0",
"id": 1,
"result": {
}
}
15. getblockheightbytxhash
get blockheight by txhash
Parameter instruction
txhash: transaction hash
Example
Request:
{
"jsonrpc": "2.0",
"method": "getblockheightbytxhash",
"params": ["c453557af780fe403db6e954ebc9adeafd5818c596c6c60e5cc42851c5b41884"],
"id": 1
}
Response:
{
"desc": "SUCCESS",
"error": 0,
"id": 1,
"jsonpc": "2.0",
"result": 10
}
16. getbalance
return balance of base58 account address.
Parameter instruction
address: Base58-encoded form of account address
Example
Request:
{
"jsonrpc": "2.0",
"method": "getbalance",
"params": ["TA5uYzLU2vBvvfCMxyV2sdzc9kPqJzGZWq"],
"id": 1
}
Response:
{
"desc":"SUCCESS",
"error":0,
"id":1,
"jsonpc":"2.0",
"result":{
"ont":"24999862561046528",
"ong":"0"
}
}
17. getmerkleproof
return merkle proof
Parameter instruction
hash: transaction hash
Example
Request:
{
"jsonrpc": "2.0",
"method": "getmerkleproof",
"params": ["0087217323d87284d21c3539f216dd030bf9da480372456d1fa02eec74c3226d"],
"id": 1
}
Response:
{
"desc":"SUCCESS",
"error":0,
"id":1,
"jsonpc":"2.0",
"result":{
"Type": "MerkleProof",
"TransactionsRoot": "fe3a4ee8a44e3e588de55de1b8fe08f08b6184d9c062cf7316fb9481eb57b9e6",
"BlockHeight": 600,
"CurBlockRoot": "57476eba688531dec8555cb712835c7eda48a478431a2cfd3372aeee5298e711",
"CurBlockHeight": 6478,
"TargetHashes": [
"270cd10ea235cc18cba83a070fdf18ae576983b6b9a7bb9a3fec540b3786c85c",
"24e4697f9dd6cb944d0736bd3e11b64f64edec94fb599e25d4e5461d54174f0e",
"9a47ab04acf6bba7bb97b83eddeb0db20e11c0627b8079b40b60031d5bd63154",
"d1b513810b9b983014c9f8b7084b8ea8744eca8e7c942586c2b7c63f910363ca",
"54e88360efedcf5dbbc486ea0267724a98b027b3ba780617e32569bb3fbe56e8",
"e0c5ebca3ca191617d42e11db64778b047cd9a520538efd95d5a688cbba0c8d5",
"52bfb23b6456cac4e5e7143287e1518dd923c5b5d32d0bfe8d825dc8195ea62b",
"86d6be166ae1a53c052adc40b9b66c4f95f5e3b6ecc88afaea3750e1cbe98276",
"5588530cfc4d92e979717f8ae399ac4553a76e7537a981e8eaf078d60f1d39a6",
"3f15bec38bcf054e4f32efe475a09d3e80c2e90d3345a1428aaa262606f13267",
"f238ed8ceb1c10a08f7eaa390cdde44ed7d160abbde4702028407b55671e7aa8",
"b4813f1f27c0457726b58f8bf20bee70c100a4d5c5f1805e53dcd20f38479615",
"83893713ea8ace9214b28af854b75671c8aaa62bb74b0d43ad6fb83e3dee42db"
]
}
}
Errorcode
errorcode instruction
Field | Type | Description |
---|---|---|
0 | int64 | SUCCESS |
41001 | int64 | SESSION_EXPIRED: invalided or expired session |
41002 | int64 | SERVICE_CEILING: reach service limit |
41003 | int64 | ILLEGAL_DATAFORMAT: illegal dataformat |
41004 | int64 | INVALID_VERSION: invalid version |
42001 | int64 | INVALID_METHOD: invalid method |
42002 | int64 | INVALID_PARAMS: invalid params |
43001 | int64 | INVALID_TRANSACTION: invalid transaction |
43002 | int64 | INVALID_ASSET: invalid asset |
43003 | int64 | INVALID_BLOCK: invalid block |
44001 | int64 | UNKNOWN_TRANSACTION: unknown transaction |
44002 | int64 | UNKNOWN_ASSET: unknown asset |
44003 | int64 | UNKNOWN_BLOCK: unknown block |
45001 | int64 | INTERNAL_ERROR: internel error |
47001 | int64 | SMARTCODE_ERROR: smartcode error |