erigon-pulse/turbo/jsonrpc/eth_mining.go

97 lines
3.2 KiB
Go

package jsonrpc
import (
"context"
"errors"
libcommon "github.com/ledgerwatch/erigon-lib/common"
"github.com/ledgerwatch/erigon-lib/gointerfaces/txpool"
"google.golang.org/grpc/status"
"github.com/ledgerwatch/erigon/common/hexutil"
"github.com/ledgerwatch/erigon/core/types"
)
// Coinbase implements eth_coinbase. Returns the current client coinbase address.
func (api *APIImpl) Coinbase(ctx context.Context) (libcommon.Address, error) {
return api.ethBackend.Etherbase(ctx)
}
// Hashrate implements eth_hashrate. Returns the number of hashes per second that the node is mining with.
func (api *APIImpl) Hashrate(ctx context.Context) (uint64, error) {
repl, err := api.mining.HashRate(ctx, &txpool.HashRateRequest{})
if err != nil {
if s, ok := status.FromError(err); ok {
return 0, errors.New(s.Message())
}
return 0, err
}
return repl.HashRate, err
}
// Mining returns an indication if this node is currently mining.
func (api *APIImpl) Mining(ctx context.Context) (bool, error) {
repl, err := api.mining.Mining(ctx, &txpool.MiningRequest{})
if err != nil {
if s, ok := status.FromError(err); ok {
return false, errors.New(s.Message())
}
return false, err
}
return repl.Enabled && repl.Running, err
}
// GetWork returns a work package for external miner.
//
// The work package consists of 3 strings:
//
// result[0] - 32 bytes hex encoded current block header pow-hash
// result[1] - 32 bytes hex encoded seed hash used for DAG
// result[2] - 32 bytes hex encoded boundary condition ("target"), 2^256/difficulty
// result[3] - hex encoded block number
func (api *APIImpl) GetWork(ctx context.Context) ([4]string, error) {
var res [4]string
repl, err := api.mining.GetWork(ctx, &txpool.GetWorkRequest{})
if err != nil {
if s, ok := status.FromError(err); ok {
return res, errors.New(s.Message())
}
return res, err
}
res[0] = repl.HeaderHash
res[1] = repl.SeedHash
res[2] = repl.Target
res[3] = repl.BlockNumber
return res, nil
}
// SubmitWork can be used by external miner to submit their POW solution.
// It returns an indication if the work was accepted.
// Note either an invalid solution, a stale work a non-existent work will return false.
func (api *APIImpl) SubmitWork(ctx context.Context, nonce types.BlockNonce, powHash, digest libcommon.Hash) (bool, error) {
repl, err := api.mining.SubmitWork(ctx, &txpool.SubmitWorkRequest{BlockNonce: nonce[:], PowHash: powHash.Bytes(), Digest: digest.Bytes()})
if err != nil {
if s, ok := status.FromError(err); ok {
return false, errors.New(s.Message())
}
return false, err
}
return repl.Ok, nil
}
// SubmitHashrate can be used for remote miners to submit their hash rate.
// This enables the node to report the combined hash rate of all miners
// which submit work through this node.
//
// It accepts the miner hash rate and an identifier which must be unique
func (api *APIImpl) SubmitHashrate(ctx context.Context, hashRate hexutil.Uint64, id libcommon.Hash) (bool, error) {
repl, err := api.mining.SubmitHashRate(ctx, &txpool.SubmitHashRateRequest{Rate: uint64(hashRate), Id: id.Bytes()})
if err != nil {
if s, ok := status.FromError(err); ok {
return false, errors.New(s.Message())
}
return false, err
}
return repl.Ok, nil
}