kaspad/infrastructure/network/rpcclient/rpc_get_block_count.go
2023-08-23 15:11:28 +09:00

21 lines
750 B
Go

package rpcclient
import "github.com/c4ei/kaspad/app/appmessage"
// GetBlockCount sends an RPC request respective to the function's name and returns the RPC server's response
func (c *RPCClient) GetBlockCount() (*appmessage.GetBlockCountResponseMessage, error) {
err := c.rpcRouter.outgoingRoute().Enqueue(appmessage.NewGetBlockCountRequestMessage())
if err != nil {
return nil, err
}
response, err := c.route(appmessage.CmdGetBlockCountResponseMessage).DequeueWithTimeout(c.timeout)
if err != nil {
return nil, err
}
getBlockCountResponse := response.(*appmessage.GetBlockCountResponseMessage)
if getBlockCountResponse.Error != nil {
return nil, c.convertRPCError(getBlockCountResponse.Error)
}
return getBlockCountResponse, nil
}