2021-02-17 18:00:16 +02:00

24 lines
862 B
Go

package rpcclient
import "github.com/kaspanet/kaspad/app/appmessage"
// GetBlocks sends an RPC request respective to the function's name and returns the RPC server's response
func (c *RPCClient) GetBlocks(lowHash string, includeBlockVerboseData bool,
includeTransactionVerboseData bool) (*appmessage.GetBlocksResponseMessage, error) {
err := c.rpcRouter.outgoingRoute().Enqueue(
appmessage.NewGetBlocksRequestMessage(lowHash, includeBlockVerboseData, includeTransactionVerboseData))
if err != nil {
return nil, err
}
response, err := c.route(appmessage.CmdGetBlocksResponseMessage).DequeueWithTimeout(c.timeout)
if err != nil {
return nil, err
}
GetBlocksResponse := response.(*appmessage.GetBlocksResponseMessage)
if GetBlocksResponse.Error != nil {
return nil, c.convertRPCError(GetBlocksResponse.Error)
}
return GetBlocksResponse, nil
}