mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-05-21 06:16:45 +00:00

* Block template cache improvement * Avoid concurrent calls to template builder * Clear cache on new block event * Move IsNearlySynced logic to within consensus and cache it for each template * Use a single consensus call for building template and checking synced Co-authored-by: msutton <mikisiton2@gmail.com>
47 lines
2.0 KiB
Go
47 lines
2.0 KiB
Go
package rpchandlers
|
|
|
|
import (
|
|
"github.com/kaspanet/kaspad/app/appmessage"
|
|
"github.com/kaspanet/kaspad/app/rpc/rpccontext"
|
|
"github.com/kaspanet/kaspad/domain/consensus/model/externalapi"
|
|
"github.com/kaspanet/kaspad/domain/consensus/utils/transactionhelper"
|
|
"github.com/kaspanet/kaspad/domain/consensus/utils/txscript"
|
|
"github.com/kaspanet/kaspad/infrastructure/network/netadapter/router"
|
|
"github.com/kaspanet/kaspad/util"
|
|
"github.com/kaspanet/kaspad/version"
|
|
)
|
|
|
|
// HandleGetBlockTemplate handles the respectively named RPC command
|
|
func HandleGetBlockTemplate(context *rpccontext.Context, _ *router.Router, request appmessage.Message) (appmessage.Message, error) {
|
|
getBlockTemplateRequest := request.(*appmessage.GetBlockTemplateRequestMessage)
|
|
|
|
payAddress, err := util.DecodeAddress(getBlockTemplateRequest.PayAddress, context.Config.ActiveNetParams.Prefix)
|
|
if err != nil {
|
|
errorMessage := &appmessage.GetBlockTemplateResponseMessage{}
|
|
errorMessage.Error = appmessage.RPCErrorf("Could not decode address: %s", err)
|
|
return errorMessage, nil
|
|
}
|
|
|
|
scriptPublicKey, err := txscript.PayToAddrScript(payAddress)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
coinbaseData := &externalapi.DomainCoinbaseData{ScriptPublicKey: scriptPublicKey, ExtraData: []byte(version.Version() + "/" + getBlockTemplateRequest.ExtraData)}
|
|
|
|
templateBlock, isNearlySynced, err := context.Domain.MiningManager().GetBlockTemplate(coinbaseData)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if uint64(len(templateBlock.Transactions[transactionhelper.CoinbaseTransactionIndex].Payload)) > context.Config.NetParams().MaxCoinbasePayloadLength {
|
|
errorMessage := &appmessage.GetBlockTemplateResponseMessage{}
|
|
errorMessage.Error = appmessage.RPCErrorf("Coinbase payload is above max length (%d). Try to shorten the extra data.", context.Config.NetParams().MaxCoinbasePayloadLength)
|
|
return errorMessage, nil
|
|
}
|
|
|
|
rpcBlock := appmessage.DomainBlockToRPCBlock(templateBlock)
|
|
|
|
return appmessage.NewGetBlockTemplateResponseMessage(rpcBlock, context.ProtocolManager.Context().HasPeers() && isNearlySynced), nil
|
|
}
|