// Copyright 2017-2021 DERO Project. All rights reserved. // Use of this source code in any form is governed by RESEARCH license. // license can be found in the LICENSE file. // GPG: 0F39 E425 8C65 3947 702A 8234 08B2 0360 A03A 9DE8 // // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL // THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, // STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // this package contains struct definitions and related processing code package rpc import "github.com/deroproject/derohe/cryptography/crypto" // this is used to print blockheader for the rpc and the daemon type BlockHeader_Print struct { Depth int64 `json:"depth"` Difficulty string `json:"difficulty"` Hash string `json:"hash"` Height int64 `json:"height"` TopoHeight int64 `json:"topoheight"` Major_Version uint64 `json:"major_version"` Minor_Version uint64 `json:"minor_version"` Nonce uint64 `json:"nonce"` Orphan_Status bool `json:"orphan_status"` SyncBlock bool `json:"syncblock"` SideBlock bool `json:"sideblock"` TXCount int64 `json:"txcount"` Reward uint64 `json:"reward"` Tips []string `json:"tips"` Timestamp uint64 `json:"timestamp"` } type ( GetBlockHeaderByTopoHeight_Params struct { TopoHeight uint64 `json:"topoheight"` } GetBlockHeaderByHeight_Result struct { Block_Header BlockHeader_Print `json:"block_header"` Status string `json:"status"` } ) // GetBlockHeaderByHash type ( GetBlockHeaderByHash_Params struct { Hash string `json:"hash"` } // no params GetBlockHeaderByHash_Result struct { Block_Header BlockHeader_Print `json:"block_header"` Status string `json:"status"` } ) // get block count type ( GetBlockCount_Params struct { // NO params } GetBlockCount_Result struct { Count uint64 `json:"count"` Status string `json:"status"` } ) // getblock type ( GetBlock_Params struct { Hash string `json:"hash,omitempty"` // Monero Daemon breaks if both are provided Height uint64 `json:"height,omitempty"` // Monero Daemon breaks if both are provided } // no params GetBlock_Result struct { Blob string `json:"blob"` Json string `json:"json"` Block_Header BlockHeader_Print `json:"block_header"` Status string `json:"status"` } ) // get block template request response type ( GetBlockTemplate_Params struct { Wallet_Address string `json:"wallet_address"` Reserve_size uint64 `json:"reserve_size"` } GetBlockTemplate_Result struct { Blocktemplate_blob string `json:"blocktemplate_blob"` Blockhashing_blob string `json:"blockhashing_blob"` Expected_reward uint64 `json:"expected_reward"` Difficulty uint64 `json:"difficulty"` Height uint64 `json:"height"` Prev_Hash string `json:"prev_hash"` Reserved_Offset uint64 `json:"reserved_offset"` Epoch uint64 `json:"epoch"` // used to expire pool jobs Status string `json:"status"` } ) type ( // array without name containing block template in hex SubmitBlock_Params struct { X []string } SubmitBlock_Result struct { BLID string `json:"blid"` Status string `json:"status"` } ) type ( GetLastBlockHeader_Params struct{} // no params GetLastBlockHeader_Result struct { Block_Header BlockHeader_Print `json:"block_header"` Status string `json:"status"` } ) const RECENT_BLOCK = int64(-1) // will give most recent data const RECENT_BATCH_BLOCK = int64(-2) // will give data from recent block batch for tx building //get encrypted balance call type ( GetEncryptedBalance_Params struct { Address string `json:"address"` SCID crypto.Hash `json:"scid"` Merkle_Balance_TreeHash string `json:"treehash,omitempty"` TopoHeight int64 `json:"topoheight,omitempty"` } // no params GetEncryptedBalance_Result struct { Data string `json:"data"` // balance is in hex form, 66 * 2 byte = 132 bytes Registration int64 `json:"registration"` // at what topoheight the account was registered Bits int `json:"bits"` // no. of bits required to access the public key from the chain Height int64 `json:"height"` // at what height is this balance Topoheight int64 `json:"topoheight"` // at what topoheight is this balance BlockHash string `json:"blockhash"` // blockhash at this topoheight Merkle_Balance_TreeHash string `json:"treehash"` DHeight int64 `json:"dheight"` // daemon height DTopoheight int64 `json:"dtopoheight"` // daemon topoheight DMerkle_Balance_TreeHash string `json:"dtreehash"` // daemon dmerkle tree hash Status string `json:"status"` } ) type ( GetTxPool_Params struct{} // no params GetTxPool_Result struct { Tx_list []string `json:"txs,omitempty"` Status string `json:"status"` } ) // get height http response as json type ( Daemon_GetHeight_Result struct { Height uint64 `json:"height"` StableHeight int64 `json:"stableheight"` TopoHeight int64 `json:"topoheight"` Status string `json:"status"` } ) type ( On_GetBlockHash_Params struct { X [1]uint64 } On_GetBlockHash_Result struct{} ) type ( GetTransaction_Params struct { Tx_Hashes []string `json:"txs_hashes"` Decode uint64 `json:"decode_as_json,omitempty"` // Monero Daemon breaks if this sent } // no params GetTransaction_Result struct { Txs_as_hex []string `json:"txs_as_hex"` Txs_as_json []string `json:"txs_as_json"` Txs []Tx_Related_Info `json:"txs"` Status string `json:"status"` } Tx_Related_Info struct { As_Hex string `json:"as_hex"` As_Json string `json:"as_json"` Block_Height int64 `json:"block_height"` Reward uint64 `json:"reward"` // miner tx rewards are decided by the protocol during execution Ignored bool `json:"ignored"` // tell whether this tx is okau as per client protocol or bein ignored In_pool bool `json:"in_pool"` Output_Indices []uint64 `json:"output_indices"` Tx_hash string `json:"tx_hash"` StateBlock string `json:"state_block"` // TX is built in reference to this block MinedBlock []string `json:"mined_block"` // TX is mined in this block, 1 or more Ring [][][]byte `json:"ring"` // ring members completed, since tx contains compressed Balance uint64 `json:"balance"` // if tx is SC, give SC balance at start Code string `json:"code"` // smart contract code at start BalanceNow uint64 `json:"balancenow"` // if tx is SC, give SC balance at current topo height CodeNow string `json:"codenow"` // smart contract code at current topo } ) type ( GetSC_Params struct { SCID string `json:"scid"` Code bool `json:"code,omitempty"` // if true code will be returned TopoHeight int64 `json:"topoheight,omitempty"` // all queries are related to this topoheight KeysUint64 []uint64 `json:"keysuint64,omitempty"` KeysString []string `json:"keysstring,omitempty"` KeysBytes [][]byte `json:"keysbytes,omitempty"` // all keys can also be represented as bytes } GetSC_Result struct { ValuesUint64 []string `json:"valuesuint64,omitempty"` ValuesString []string `json:"valuesstring,omitempty"` ValuesBytes []string `json:"valuesbytes,omitempty"` Balance uint64 `json:"balance"` Code string `json:"code"` Status string `json:"status"` } ) type ( GetRandomAddress_Params struct { SCID crypto.Hash `json:"scid"` } GetRandomAddress_Result struct { Address []string `json:"address"` // daemon will return around 20 address in 1 go Status string `json:"status"` } ) type ( SendRawTransaction_Params struct { Tx_as_hex string `json:"tx_as_hex"` } SendRawTransaction_Result struct { Status string `json:"status"` DoubleSpend bool `json:"double_spend"` FeeTooLow bool `json:"fee_too_low"` InvalidInput bool `json:"invalid_input"` InvalidOutput bool `json:"invalid_output"` Low_Mixin bool `json:"low_mixin"` Non_rct bool `json:"not_rct"` NotRelayed bool `json:"not_relayed"` Overspend bool `json:"overspend"` TooBig bool `json:"too_big"` Reason string `json:"string"` } ) /* { "id": "0", "jsonrpc": "2.0", "result": { "alt_blocks_count": 5, "difficulty": 972165250, "grey_peerlist_size": 2280, "height": 993145, "incoming_connections_count": 0, "outgoing_connections_count": 8, "status": "OK", "target": 60, "target_height": 993137, "testnet": false, "top_block_hash": "", "tx_count": 564287, "tx_pool_size": 45, "white_peerlist_size": 529 } }*/ type ( GetInfo_Params struct{} // no params GetInfo_Result struct { Alt_Blocks_Count uint64 `json:"alt_blocks_count"` Difficulty uint64 `json:"difficulty"` Grey_PeerList_Size uint64 `json:"grey_peerlist_size"` Height int64 `json:"height"` StableHeight int64 `json:"stableheight"` TopoHeight int64 `json:"topoheight"` Merkle_Balance_TreeHash string `json:"treehash"` AverageBlockTime50 float32 `json:"averageblocktime50"` Incoming_connections_count uint64 `json:"incoming_connections_count"` Outgoing_connections_count uint64 `json:"outgoing_connections_count"` Target uint64 `json:"target"` Target_Height uint64 `json:"target_height"` Testnet bool `json:"testnet"` Top_block_hash string `json:"top_block_hash"` Tx_count uint64 `json:"tx_count"` Tx_pool_size uint64 `json:"tx_pool_size"` Dynamic_fee_per_kb uint64 `json:"dynamic_fee_per_kb"` // our addition Total_Supply uint64 `json:"total_supply"` // our addition Median_Block_Size uint64 `json:"median_block_size"` // our addition White_peerlist_size uint64 `json:"white_peerlist_size"` Version string `json:"version"` Status string `json:"status"` } )