|
|
// Copyright 2017-2018 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.
package rpcserver
// get block template handler not implemented
//import "fmt"
import "context"
//import "log"
//import "net/http"
import "github.com/intel-go/fastjson" import "github.com/osamingo/jsonrpc"
import "github.com/arnaucode/derosuite/config" import "github.com/arnaucode/derosuite/globals"
/* { "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_Handler struct{} 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 uint64 `json:"height"` 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"` White_peerlist_size uint64 `json:"white_peerlist_size"`
Status string `json:"status"` } )
// TODO
func (h GetInfo_Handler) ServeJSONRPC(c context.Context, params *fastjson.RawMessage) (interface{}, *jsonrpc.Error) { var result GetInfo_Result
top_id := chain.Get_Top_ID() result.Difficulty = chain.Get_Difficulty_At_Block(top_id) result.Height = chain.Get_Height() - 1 result.Status = "OK" result.Top_block_hash = top_id.String() result.Target = config.BLOCK_TIME result.Target_Height = chain.Get_Height() result.Tx_pool_size = uint64(len(chain.Mempool.Mempool_List_TX()))
if globals.Config.Name != config.Mainnet.Name { // anything other than mainnet is testnet at this point in time
result.Testnet = true }
return result, nil }
|