diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 8d55c7780d..e9edbb78c5 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -15,7 +15,7 @@ jobs: golang-lint: strategy: matrix: - go-version: [1.21.x] + go-version: [1.23.x] os: [ubuntu-latest] runs-on: ${{ matrix.os }} steps: @@ -47,12 +47,9 @@ jobs: go mod tidy - name: golangci-lint - uses: golangci/golangci-lint-action@v3 - with: - # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version - version: v1.55.2 - working-directory: ./ - skip-pkg-cache: true - skip-cache: true - skip-build-cache: true - args: --timeout=99m --config ./.golangci.yml + env: + CGO_CFLAGS: "-O -D__BLST_PORTABLE__" + CGO_CFLAGS_ALLOW: "-O -D__BLST_PORTABLE__" + ANDROID_HOME: "" # Skip android test + run: | + make lint diff --git a/consensus/clique/clique.go b/consensus/clique/clique.go index 868171335a..3005a67c73 100644 --- a/consensus/clique/clique.go +++ b/consensus/clique/clique.go @@ -27,6 +27,7 @@ import ( "sync" "time" + "github.com/ethereum/go-ethereum/accounts" "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/common/gopool" "github.com/ethereum/go-ethereum/common/hexutil" @@ -51,6 +52,8 @@ const ( checkpointInterval = 1024 // Number of blocks after which to save the vote snapshot to the database inmemorySnapshots = 128 // Number of recent vote snapshots to keep in memory inmemorySignatures = 4096 // Number of recent block signatures to keep in memory + + wiggleTime = 500 * time.Millisecond // Random delay (per signer) to allow concurrent signers ) // Clique proof-of-authority protocol constants. @@ -139,6 +142,9 @@ var ( errRecentlySigned = errors.New("recently signed") ) +// SignerFn hashes and signs the data to be signed by a backing account. +type SignerFn func(signer accounts.Account, mimeType string, message []byte) ([]byte, error) + // ecrecover extracts the Ethereum account address from a signed header. func ecrecover(header *types.Header, sigcache *sigLRU) (common.Address, error) { // If the signature's already cached, return that @@ -176,6 +182,7 @@ type Clique struct { proposals map[common.Address]bool // Current list of proposals we are pushing signer common.Address // Ethereum address of the signing key + signFn SignerFn // Signer function to authorize hashes with lock sync.RWMutex // Protects the signer and proposals fields // The fields below are for testing only @@ -604,11 +611,12 @@ func (c *Clique) FinalizeAndAssemble(chain consensus.ChainHeaderReader, header * // Authorize injects a private key into the consensus engine to mint new blocks // with. -func (c *Clique) Authorize(signer common.Address) { +func (c *Clique) Authorize(signer common.Address, signFn SignerFn) { c.lock.Lock() defer c.lock.Unlock() c.signer = signer + c.signFn = signFn } func (c *Clique) Delay(chain consensus.ChainReader, header *types.Header, leftOver *time.Duration) *time.Duration { @@ -618,7 +626,71 @@ func (c *Clique) Delay(chain consensus.ChainReader, header *types.Header, leftOv // Seal implements consensus.Engine, attempting to create a sealed block using // the local signing credentials. func (c *Clique) Seal(chain consensus.ChainHeaderReader, block *types.Block, results chan<- *types.Block, stop <-chan struct{}) error { - panic("clique (poa) sealing not supported any more") + header := block.Header() + + // Sealing the genesis block is not supported + number := header.Number.Uint64() + if number == 0 { + return errUnknownBlock + } + // For 0-period chains, refuse to seal empty blocks (no reward but would spin sealing) + if c.config.Period == 0 && len(block.Transactions()) == 0 { + return errors.New("sealing paused while waiting for transactions") + } + // Don't hold the signer fields for the entire sealing procedure + c.lock.RLock() + signer, signFn := c.signer, c.signFn + c.lock.RUnlock() + + // Bail out if we're unauthorized to sign a block + snap, err := c.snapshot(chain, number-1, header.ParentHash, nil) + if err != nil { + return err + } + if _, authorized := snap.Signers[signer]; !authorized { + return errUnauthorizedSigner + } + // If we're amongst the recent signers, wait for the next block + for seen, recent := range snap.Recents { + if recent == signer { + // Signer is among recents, only wait if the current block doesn't shift it out + if limit := uint64(len(snap.Signers)/2 + 1); number < limit || seen > number-limit { + return errors.New("signed recently, must wait for others") + } + } + } + // Sweet, the protocol permits us to sign the block, wait for our time + delay := time.Unix(int64(header.Time), 0).Sub(time.Now()) // nolint: gosimple + if header.Difficulty.Cmp(diffNoTurn) == 0 { + // It's not our turn explicitly to sign, delay it a bit + wiggle := time.Duration(len(snap.Signers)/2+1) * wiggleTime + delay += time.Duration(rand.Int63n(int64(wiggle))) + + log.Trace("Out-of-turn signing requested", "wiggle", common.PrettyDuration(wiggle)) + } + // Sign all the things! + sighash, err := signFn(accounts.Account{Address: signer}, accounts.MimetypeClique, CliqueRLP(header)) + if err != nil { + return err + } + copy(header.Extra[len(header.Extra)-extraSeal:], sighash) + // Wait until sealing is terminated or delay timeout. + log.Trace("Waiting for slot to sign and propagate", "delay", common.PrettyDuration(delay)) + gopool.Submit(func() { + select { + case <-stop: + return + case <-time.After(delay): + } + + select { + case results <- block.WithSeal(header): + default: + log.Warn("Sealing result is not read by miner", "sealhash", SealHash(header)) + } + }) + + return nil } // CalcDifficulty is the difficulty adjustment algorithm. It returns the difficulty diff --git a/core/blockchain.go b/core/blockchain.go index 91857dcb1c..c975111b7a 100644 --- a/core/blockchain.go +++ b/core/blockchain.go @@ -25,6 +25,7 @@ import ( "runtime" "slices" "sort" + "strings" "sync" "sync/atomic" "time" @@ -346,16 +347,14 @@ func NewBlockChain(db ethdb.Database, cacheConfig *CacheConfig, genesis *Genesis } systemcontracts.GenesisHash = genesisHash log.Info("Initialised chain configuration", "config", chainConfig) - // Description of chainConfig is empty now - /* - log.Info("") - log.Info(strings.Repeat("-", 153)) - for _, line := range strings.Split(chainConfig.Description(), "\n") { - log.Info(line) - } - log.Info(strings.Repeat("-", 153)) - log.Info("") - */ + + log.Info("") + log.Info(strings.Repeat("-", 153)) + for _, line := range strings.Split(chainConfig.Description(), "\n") { + log.Info(line) + } + log.Info(strings.Repeat("-", 153)) + log.Info("") bc := &BlockChain{ chainConfig: chainConfig, diff --git a/core/blockchain_notries_test.go b/core/blockchain_notries_test.go index eda2a03b6c..a2c84748aa 100644 --- a/core/blockchain_notries_test.go +++ b/core/blockchain_notries_test.go @@ -188,17 +188,17 @@ func TestFastNode(t *testing.T) { // test full mode and succeed _, fastnode, blocks, err := makeTestBackendWithRemoteValidator(2048, FullVerify, nil) if err != nil { - t.Fatalf(err.Error()) + t.Fatalf("err: %v", err.Error()) } _, err = fastnode.chain.InsertChain(blocks) if err != nil { - t.Fatalf(err.Error()) + t.Fatalf("err: %v", err.Error()) } // test full mode and failed failed := &verifFailedStatus{status: types.StatusDiffHashMismatch, blockNumber: 204} _, fastnode, blocks, err = makeTestBackendWithRemoteValidator(2048, FullVerify, failed) if err != nil { - t.Fatalf(err.Error()) + t.Fatalf("err: %v", err.Error()) } _, err = fastnode.chain.InsertChain(blocks) if err == nil || fastnode.chain.CurrentBlock().Number.Uint64() != failed.blockNumber+10 { @@ -207,17 +207,17 @@ func TestFastNode(t *testing.T) { // test insecure mode and succeed _, fastnode, blocks, err = makeTestBackendWithRemoteValidator(2048, InsecureVerify, nil) if err != nil { - t.Fatalf(err.Error()) + t.Fatalf("err: %v", err.Error()) } _, err = fastnode.chain.InsertChain(blocks) if err != nil { - t.Fatalf(err.Error()) + t.Fatalf("err: %v", err.Error()) } // test insecure mode and failed failed = &verifFailedStatus{status: types.StatusImpossibleFork, blockNumber: 204} _, fastnode, blocks, err = makeTestBackendWithRemoteValidator(2048, FullVerify, failed) if err != nil { - t.Fatalf(err.Error()) + t.Fatalf("err: %v", err.Error()) } _, err = fastnode.chain.InsertChain(blocks) if err == nil || fastnode.chain.CurrentBlock().Number.Uint64() != failed.blockNumber+10 { diff --git a/core/rawdb/accessors_chain_test.go b/core/rawdb/accessors_chain_test.go index 798923bbfc..0110504518 100644 --- a/core/rawdb/accessors_chain_test.go +++ b/core/rawdb/accessors_chain_test.go @@ -465,7 +465,7 @@ func TestBlockBlobSidecarsStorage(t *testing.T) { t.Fatalf("no sidecars returned") } else { if err := checkBlobSidecarsRLP(bs, sidecars); err != nil { - t.Fatalf(err.Error()) + t.Fatalf("err: %v", err.Error()) } } diff --git a/core/verkle_witness_test.go b/core/verkle_witness_test.go index 43c5d84a17..dd489e561e 100644 --- a/core/verkle_witness_test.go +++ b/core/verkle_witness_test.go @@ -40,6 +40,7 @@ import ( ) var ( + //nolint:unused testVerkleChainConfig = ¶ms.ChainConfig{ ChainID: big.NewInt(1), HomesteadBlock: big.NewInt(0), @@ -80,7 +81,10 @@ var ( } ) -func TestProcessVerkle(t *testing.T) { +// TODO(Nathan): fix before verkle enabled +// +//nolint:unused +func testProcessVerkle(t *testing.T) { var ( code = common.FromHex(`6060604052600a8060106000396000f360606040526008565b00`) intrinsicContractCreationGas, _ = IntrinsicGas(code, nil, true, true, true, true) diff --git a/eth/fetcher/block_fetcher.go b/eth/fetcher/block_fetcher.go index c5694f7f51..ff0fd9f337 100644 --- a/eth/fetcher/block_fetcher.go +++ b/eth/fetcher/block_fetcher.go @@ -498,7 +498,7 @@ func (f *BlockFetcher) loop() { log.Trace("Fetching scheduled headers", "peer", peer, "list", hashes) // Create a closure of the fetch and schedule in on a new thread - fetchHeader, hashes := f.fetching[hashes[0]].fetchHeader, hashes + fetchHeader := f.fetching[hashes[0]].fetchHeader go func(peer string) { if f.fetchingHook != nil { diff --git a/eth/handler_eth_test.go b/eth/handler_eth_test.go index dfdfb26bc1..fab9283739 100644 --- a/eth/handler_eth_test.go +++ b/eth/handler_eth_test.go @@ -614,8 +614,6 @@ func testBroadcastBlock(t *testing.T, peers, bcasts int) { td = source.chain.GetTd(genesis.Hash(), genesis.NumberU64()) ) for i, sink := range sinks { - sink := sink // Closure for gorotuine below - sourcePipe, sinkPipe := p2p.MsgPipe() defer sourcePipe.Close() defer sinkPipe.Close() @@ -653,7 +651,6 @@ func testBroadcastBlock(t *testing.T, peers, bcasts int) { // Iterate through all the sinks and ensure the correct number got the block done := make(chan struct{}, peers) for _, ch := range blockChs { - ch := ch go func() { <-ch done <- struct{}{} diff --git a/eth/protocols/bsc/handler.go b/eth/protocols/bsc/handler.go index 9595c42688..989c7c71b2 100644 --- a/eth/protocols/bsc/handler.go +++ b/eth/protocols/bsc/handler.go @@ -38,8 +38,6 @@ type Backend interface { func MakeProtocols(backend Backend) []p2p.Protocol { protocols := make([]p2p.Protocol, len(ProtocolVersions)) for i, version := range ProtocolVersions { - version := version // Closure - protocols[i] = p2p.Protocol{ Name: ProtocolName, Version: version, diff --git a/eth/protocols/eth/handler_test.go b/eth/protocols/eth/handler_test.go index 139963514d..10ef0f0bce 100644 --- a/eth/protocols/eth/handler_test.go +++ b/eth/protocols/eth/handler_test.go @@ -698,7 +698,6 @@ func TestHandleNewBlock(t *testing.T) { // Run the tests for _, tc := range testCases { - tc := tc t.Run(tc.name, func(t *testing.T) { err := handleNewBlock(backend, tc.msg, localEth) if err != tc.err { diff --git a/eth/protocols/trust/handler.go b/eth/protocols/trust/handler.go index 5d27d78d75..958b6fd80e 100644 --- a/eth/protocols/trust/handler.go +++ b/eth/protocols/trust/handler.go @@ -34,8 +34,6 @@ type Backend interface { func MakeProtocols(backend Backend) []p2p.Protocol { protocols := make([]p2p.Protocol, len(ProtocolVersions)) for i, version := range ProtocolVersions { - version := version // Closure - protocols[i] = p2p.Protocol{ Name: ProtocolName, Version: version, diff --git a/internal/ethapi/api_test.go b/internal/ethapi/api_test.go index bad1d7abe4..e8d02fbabc 100644 --- a/internal/ethapi/api_test.go +++ b/internal/ethapi/api_test.go @@ -2503,7 +2503,6 @@ func TestFillBlobTransaction(t *testing.T) { }, } for _, tc := range suite { - tc := tc t.Run(tc.name, func(t *testing.T) { t.Parallel() @@ -3397,55 +3396,55 @@ func TestRPCGetBlobSidecars(t *testing.T) { fullBlob bool file string }{ - // 1. block without any txs(number) + // 0. block without any txs(number) { test: rpc.BlockNumberOrHashWithNumber(0), fullBlob: true, file: "number-1", }, - // 2. earliest tag + // 1. earliest tag { test: rpc.BlockNumberOrHashWithNumber(rpc.EarliestBlockNumber), fullBlob: true, file: "tag-earliest", }, - // 3. latest tag + // 2. latest tag { test: rpc.BlockNumberOrHashWithNumber(rpc.LatestBlockNumber), fullBlob: true, file: "tag-latest", }, - // 4. block is empty + // 3. block is empty { test: rpc.BlockNumberOrHashWithHash(common.Hash{}, false), fullBlob: true, file: "hash-empty", }, - // 5. block is not found + // 4. block is not found { test: rpc.BlockNumberOrHashWithHash(common.HexToHash("deadbeef"), false), fullBlob: true, file: "hash-notfound", }, - // 6. block is not found + // 5. block is not found { test: rpc.BlockNumberOrHashWithNumber(rpc.BlockNumber(genBlocks + 1)), fullBlob: true, file: "block-notfound", }, - // 7. block with blob tx + // 6. block with blob tx { test: rpc.BlockNumberOrHashWithNumber(rpc.BlockNumber(6)), fullBlob: true, file: "block-with-blob-tx", }, - // 8. block with sidecar + // 7. block with sidecar { test: rpc.BlockNumberOrHashWithNumber(rpc.BlockNumber(7)), fullBlob: true, file: "block-with-blobSidecars", }, - // 9. block with sidecar but show little + // 8. block with sidecar but show little { test: rpc.BlockNumberOrHashWithNumber(rpc.BlockNumber(7)), fullBlob: false, diff --git a/internal/ethapi/testdata/eth_getBlobSidecarByTxHash-block-with-blobSidecars-show-little.json b/internal/ethapi/testdata/eth_getBlobSidecarByTxHash-block-with-blobSidecars-show-little.json index ef227ae428..1397745cf4 100644 --- a/internal/ethapi/testdata/eth_getBlobSidecarByTxHash-block-with-blobSidecars-show-little.json +++ b/internal/ethapi/testdata/eth_getBlobSidecarByTxHash-block-with-blobSidecars-show-little.json @@ -10,7 +10,7 @@ "0xc00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000" ] }, - "blockHash": "0x6fe5e7eea22c44f700c95da066d6e0740894b6c1e993825cc63f634ad4f74250", + "blockHash": "0x22c19d38b338157697f939991a74da4129c53e196517a9aa8077f5246716fb0a", "blockNumber": "0x7", "txHash": "0xc520427e696154779f6b21ab03a0735769e1c029035a484f5876f60383a0a7ce", "txIndex": "0x0" diff --git a/internal/ethapi/testdata/eth_getBlobSidecarByTxHash-block-with-blobSidecars.json b/internal/ethapi/testdata/eth_getBlobSidecarByTxHash-block-with-blobSidecars.json index ba5fd7b587..980c693855 100644 --- a/internal/ethapi/testdata/eth_getBlobSidecarByTxHash-block-with-blobSidecars.json +++ b/internal/ethapi/testdata/eth_getBlobSidecarByTxHash-block-with-blobSidecars.json @@ -10,7 +10,7 @@ "0xc00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000" ] }, - "blockHash": "0x6fe5e7eea22c44f700c95da066d6e0740894b6c1e993825cc63f634ad4f74250", + "blockHash": "0x22c19d38b338157697f939991a74da4129c53e196517a9aa8077f5246716fb0a", "blockNumber": "0x7", "txHash": "0xc520427e696154779f6b21ab03a0735769e1c029035a484f5876f60383a0a7ce", "txIndex": "0x0" diff --git a/internal/ethapi/testdata/eth_getBlobSidecars-block-with-blobSidecars-show-little.json b/internal/ethapi/testdata/eth_getBlobSidecars-block-with-blobSidecars-show-little.json index ba853bd7ef..78b64ff1b1 100644 --- a/internal/ethapi/testdata/eth_getBlobSidecars-block-with-blobSidecars-show-little.json +++ b/internal/ethapi/testdata/eth_getBlobSidecars-block-with-blobSidecars-show-little.json @@ -11,7 +11,7 @@ "0xc00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000" ] }, - "blockHash": "0x6fe5e7eea22c44f700c95da066d6e0740894b6c1e993825cc63f634ad4f74250", + "blockHash": "0x22c19d38b338157697f939991a74da4129c53e196517a9aa8077f5246716fb0a", "blockNumber": "0x7", "txHash": "0xc520427e696154779f6b21ab03a0735769e1c029035a484f5876f60383a0a7ce", "txIndex": "0x0" diff --git a/internal/ethapi/testdata/eth_getBlobSidecars-block-with-blobSidecars.json b/internal/ethapi/testdata/eth_getBlobSidecars-block-with-blobSidecars.json index 2cb9331ed1..7acbc98013 100644 --- a/internal/ethapi/testdata/eth_getBlobSidecars-block-with-blobSidecars.json +++ b/internal/ethapi/testdata/eth_getBlobSidecars-block-with-blobSidecars.json @@ -11,7 +11,7 @@ "0xc00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000" ] }, - "blockHash": "0x6fe5e7eea22c44f700c95da066d6e0740894b6c1e993825cc63f634ad4f74250", + "blockHash": "0x22c19d38b338157697f939991a74da4129c53e196517a9aa8077f5246716fb0a", "blockNumber": "0x7", "txHash": "0xc520427e696154779f6b21ab03a0735769e1c029035a484f5876f60383a0a7ce", "txIndex": "0x0" diff --git a/internal/ethapi/testdata/eth_getBlobSidecars-tag-latest.json b/internal/ethapi/testdata/eth_getBlobSidecars-tag-latest.json index 2cb9331ed1..7acbc98013 100644 --- a/internal/ethapi/testdata/eth_getBlobSidecars-tag-latest.json +++ b/internal/ethapi/testdata/eth_getBlobSidecars-tag-latest.json @@ -11,7 +11,7 @@ "0xc00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000" ] }, - "blockHash": "0x6fe5e7eea22c44f700c95da066d6e0740894b6c1e993825cc63f634ad4f74250", + "blockHash": "0x22c19d38b338157697f939991a74da4129c53e196517a9aa8077f5246716fb0a", "blockNumber": "0x7", "txHash": "0xc520427e696154779f6b21ab03a0735769e1c029035a484f5876f60383a0a7ce", "txIndex": "0x0" diff --git a/internal/flags/flags_test.go b/internal/flags/flags_test.go index 91438d5d6e..82e23fb4d2 100644 --- a/internal/flags/flags_test.go +++ b/internal/flags/flags_test.go @@ -52,7 +52,6 @@ func TestPathExpansion(t *testing.T) { t.Setenv(`DDDXXX`, `/tmp`) for test, expected := range tests { - test, expected := test, expected t.Run(test, func(t *testing.T) { t.Parallel() diff --git a/internal/jsre/completion_test.go b/internal/jsre/completion_test.go index ae9334b4bc..8fbddbc299 100644 --- a/internal/jsre/completion_test.go +++ b/internal/jsre/completion_test.go @@ -87,7 +87,6 @@ func TestCompleteKeywords(t *testing.T) { }, } for _, test := range tests { - test := test t.Run(test.input, func(t *testing.T) { t.Parallel() diff --git a/miner/worker.go b/miner/worker.go index 1a0c929515..decc651cf5 100644 --- a/miner/worker.go +++ b/miner/worker.go @@ -1158,12 +1158,46 @@ func (w *worker) generateWork(params *generateParams, witness bool) *newPayloadR defer work.discard() if !params.noTxs { + interrupt := new(atomic.Int32) + timer := time.AfterFunc(w.config.Recommit, func() { + interrupt.Store(commitInterruptTimeout) + }) + defer timer.Stop() + err := w.fillTransactions(nil, work, nil, nil) if errors.Is(err, errBlockInterruptedByTimeout) { log.Warn("Block building is interrupted", "allowance", common.PrettyDuration(w.recommit)) } } body := types.Body{Transactions: work.txs, Withdrawals: params.withdrawals} + allLogs := make([]*types.Log, 0) + for _, r := range work.receipts { + allLogs = append(allLogs, r.Logs...) + } + // Collect consensus-layer requests if Prague is enabled. + var requests [][]byte + if w.chainConfig.IsPrague(work.header.Number, work.header.Time) { + // EIP-6110 deposits + depositRequests, err := core.ParseDepositLogs(allLogs, w.chainConfig) + if err != nil { + return &newPayloadResult{err: err} + } + requests = append(requests, depositRequests) + // create EVM for system calls + blockContext := core.NewEVMBlockContext(work.header, w.chain, &work.header.Coinbase) + vmenv := vm.NewEVM(blockContext, vm.TxContext{}, work.state, w.chainConfig, vm.Config{}) + // EIP-7002 withdrawals + withdrawalRequests := core.ProcessWithdrawalQueue(vmenv, work.state) + requests = append(requests, withdrawalRequests) + // EIP-7251 consolidations + consolidationRequests := core.ProcessConsolidationQueue(vmenv, work.state) + requests = append(requests, consolidationRequests) + } + if requests != nil { + reqHash := types.CalcRequestsHash(requests) + work.header.RequestsHash = &reqHash + } + fees := work.state.GetBalance(consensus.SystemAddress) block, receipts, err := w.engine.FinalizeAndAssemble(w.chain, work.header, work.state, &body, work.receipts) if err != nil { @@ -1176,6 +1210,7 @@ func (w *worker) generateWork(params *generateParams, witness bool) *newPayloadR // sidecars: work.sidecars, stateDB: work.state, receipts: receipts, + requests: requests, witness: work.witness, } } diff --git a/miner/worker_test.go b/miner/worker_test.go index e4325baf4f..3059387f34 100644 --- a/miner/worker_test.go +++ b/miner/worker_test.go @@ -21,6 +21,7 @@ import ( "testing" "time" + "github.com/ethereum/go-ethereum/accounts" "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/consensus" "github.com/ethereum/go-ethereum/consensus/clique" @@ -121,7 +122,9 @@ func newTestWorkerBackend(t *testing.T, chainConfig *params.ChainConfig, engine case *clique.Clique: gspec.ExtraData = make([]byte, 32+common.AddressLength+crypto.SignatureLength) copy(gspec.ExtraData[32:32+common.AddressLength], testBankAddress.Bytes()) - e.Authorize(testBankAddress) + e.Authorize(testBankAddress, func(account accounts.Account, s string, data []byte) ([]byte, error) { + return crypto.Sign(crypto.Keccak256(data), testBankKey) + }) case *ethash.Ethash: default: t.Fatalf("unexpected consensus engine type: %T", engine) diff --git a/params/config.go b/params/config.go index a24dcd6bda..18c528f9a5 100644 --- a/params/config.go +++ b/params/config.go @@ -496,6 +496,9 @@ func GetBuiltInChainConfig(ghash common.Hash) *ChainConfig { // NetworkNames are user friendly names to use in the chain spec banner. var NetworkNames = map[string]string{ MainnetChainConfig.ChainID.String(): "mainnet", + BSCChainConfig.ChainID.String(): "bsc", + ChapelChainConfig.ChainID.String(): "chapel", + RialtoChainConfig.ChainID.String(): "rialto", } // ChainConfig is the core config which determines the blockchain settings. @@ -603,7 +606,26 @@ func (b *ParliaConfig) String() string { } func (c *ChainConfig) Description() string { - return "" + var banner string + + // Create some basic network config output + network := NetworkNames[c.ChainID.String()] + if network == "" { + network = "unknown" + } + banner += fmt.Sprintf("Chain ID: %v (%s)\n", c.ChainID, network) + switch { + case c.Parlia != nil: + banner += "Consensus: Parlia (proof-of-staked--authority)\n" + case c.Ethash != nil: + banner += "Consensus: Beacon (proof-of-stake), merged from Ethash (proof-of-work)\n" + case c.Clique != nil: + banner += "Consensus: Beacon (proof-of-stake), merged from Clique (proof-of-authority)\n" + default: + banner += "Consensus: unknown\n" + } + + return banner } // String implements the fmt.Stringer interface. diff --git a/triedb/pathdb/buffer.go b/triedb/pathdb/buffer.go index 7ddb7831fc..27554b8abf 100644 --- a/triedb/pathdb/buffer.go +++ b/triedb/pathdb/buffer.go @@ -151,7 +151,7 @@ func (b *buffer) getSize() (uint64, uint64) { return b.nodes.size, 0 } -// getAllNodes returnthe trie nodes set are cached in nodebuffer. +// getAllNodes return the trie nodes set are cached in nodebuffer. func (b *buffer) getAllNodes() *nodeSet { return b.nodes } diff --git a/triedb/pathdb/disklayer.go b/triedb/pathdb/disklayer.go index aacf445353..8ecfc2bcac 100644 --- a/triedb/pathdb/disklayer.go +++ b/triedb/pathdb/disklayer.go @@ -60,7 +60,7 @@ type trienodebuffer interface { // getSize return the trienodebuffer used size. getSize() (uint64, uint64) - // getAllNodes returnthe trie nodes set are cached in trienodebuffer. + // getAllNodes return the trie nodes set are cached in trienodebuffer. getAllNodes() *nodeSet // getLayers return the size of cached difflayers. diff --git a/triedb/pathdb/journal.go b/triedb/pathdb/journal.go index 1bf20e88b2..1a6901dd01 100644 --- a/triedb/pathdb/journal.go +++ b/triedb/pathdb/journal.go @@ -275,7 +275,7 @@ func (db *Database) loadDiskLayer(r *rlp.Stream, journalTypeForReader JournalTyp } // Resolve nodes cached in aggregated buffer var nodes nodeSet - if err := nodes.decode(r); err != nil { + if err := nodes.decode(journalBuf); err != nil { return nil, err } @@ -331,12 +331,12 @@ func (db *Database) loadDiffLayer(parent layer, r *rlp.Stream, journalTypeForRea } // Read in-memory trie nodes from journal var nodes nodeSet - if err := nodes.decode(r); err != nil { + if err := nodes.decode(journalBuf); err != nil { return nil, err } // Read flat states set (with original value attached) from journal var stateSet StateSetWithOrigin - if err := stateSet.decode(r); err != nil { + if err := stateSet.decode(journalBuf); err != nil { return nil, err } @@ -379,7 +379,7 @@ func (dl *diskLayer) journal(w io.Writer, journalType JournalType) error { return err } // Step three, write the accumulated trie nodes into the journal - if err := dl.buffer.getAllNodes().encode(w); err != nil { + if err := dl.buffer.getAllNodes().encode(journalBuf); err != nil { return err } @@ -422,11 +422,11 @@ func (dl *diffLayer) journal(w io.Writer, journalType JournalType) error { return err } // Write the accumulated trie nodes into buffer - if err := dl.nodes.encode(w); err != nil { + if err := dl.nodes.encode(journalBuf); err != nil { return err } // Write the associated flat state set into buffer - if err := dl.states.encode(w); err != nil { + if err := dl.states.encode(journalBuf); err != nil { return err } @@ -445,7 +445,7 @@ func (dl *diffLayer) journal(w io.Writer, journalType JournalType) error { } } - log.Debug("Journaled pathdb diff layer", "root", dl.root, "parent", dl.parent.rootHash(), "id", dl.stateID(), "block", dl.block) + log.Info("Journaled pathdb diff layer", "root", dl.root, "parent", dl.parent.rootHash(), "id", dl.stateID(), "block", dl.block) return nil } diff --git a/version/version.go b/version/version.go index 03e8c198c1..198ff4d414 100644 --- a/version/version.go +++ b/version/version.go @@ -18,7 +18,7 @@ package version const ( Major = 1 // Major version component of the current release - Minor = 4 // Minor version component of the current release - Patch = 16 // Patch version component of the current release + Minor = 5 // Minor version component of the current release + Patch = 1 // Patch version component of the current release Meta = "" // Version metadata to append to the version string )