mirror of
https://github.com/tendermint/tendermint.git
synced 2026-01-05 13:05:09 +00:00
* version bump * update UPGRADING.md * add missing pr numbers to changelog pending * linkify changelog
7.8 KiB
7.8 KiB
Pending
v0.26.0
October 19, 2018
Special thanks to external contributors on this release: @bradyjoestar, @connorwstein, @goolAdapter, @HaoyangLiu, @james-ray, @overbool, @phymbert, @Slamper, @Uzair1995
This release is primarily about adding Version fields to various data structures, optimizing consensus messages for signing and verification in restricted environments (like HSMs and the Ethereum Virtual Machine), and aligning the consensus code with the specification. It also includes our first take at a generalized merkle proof system.
See the UPGRADING.md for details on upgrading to the new version.
Friendly reminder, we have a bug bounty program.
BREAKING CHANGES:
-
CLI/RPC/Config
- [config] #2232 timeouts as time.Duration, not ints
- [config] #2505 Remove Mempool.RecheckEmpty (it was effectively useless anyways)
- [config] #2490
mempool.walis disabled by default - [privval] #2459 Split
SocketPVMsgs implementations into Request and Response, where the Response may contain a error message (returned by the remote signer) - [state] #2644 Add Version field to State, breaking the format of State as encoded on disk.
- [rpc] #2298
/abci_querytakesproveargument instead oftrustedand switches the default behaviour toprove=false - [rpc] #2654 Remove all
node_info.other.*_versionfields in/statusand/net_info
-
Apps
-
Go API
- [config] #2232 timeouts as time.Duration, not ints
- [crypto/merkle & lite] #2298 Various changes to accomodate General Merkle trees
- [crypto/merkle] #2595 Remove all Hasher objects in favor of byte slices
- [crypto/merkle] #2635 merkle.SimpleHashFromTwoHashes is no longer exported
- [node] #2479 Remove node.RunForever
- [rpc/client] #2298
ABCIQueryOptions.Trusted->ABCIQueryOptions.Prove - [types] #2298 Remove
IndexandTotalfields fromTxProof. - [types] #2598
VoteTypeXxxare now of typeSignedMsgType byteand namedXxxType, eg.PrevoteType,PrecommitType.
-
Blockchain Protocol
- [types] Update SignBytes for
Vote/Proposal/Heartbeat: - [types] #2512 Remove the pubkey field from the validator hash
- [types] #2644 Add Version struct to Header
- [types] #2609 ConsensusParams.Hash() is the hash of the amino encoded struct instead of the Merkle tree of the fields
- [state] #2587 Require block.Time of the fist block to be genesis time
- [state] #2644 Require block.Version to match state.Version
- [types] #2670 Header.Hash() builds Merkle tree out of fields in the same order they appear in the header, instead of sorting by field name
- [types] Update SignBytes for
-
P2P Protocol
- [p2p] #2654 Add
ProtocolVersionstruct with protocol versions to top of DefaultNodeInfo and requireProtocolVersion.Blockto match during peer handshake
- [p2p] #2654 Add
FEATURES:
- [abci] #2557 Add
Codespacefield toResponse{CheckTx, DeliverTx, Query} - [abci] #2662 Add
BlockVersionandP2PVersiontoRequestInfo - [crypto/merkle] #2298 General Merkle Proof scheme for chaining various types of Merkle trees together
IMPROVEMENTS:
- Additional Metrics
- [config] #2232 Added ValidateBasic method, which performs basic checks
- [crypto/ed25519] #2558 Switch to use latest
golang.org/x/cryptothrough our fork at github.com/tendermint/crypto - [tools] #2238 Binary dependencies are now locked to a specific git commit
BUG FIXES:
- [autofile] #2428 Group.RotateFile need call Flush() before rename (@goolAdapter)
- [common] #2533 Fixed a bug in the
BitArray.Ormethod - [common] #2506 Fixed a bug in the
BitArray.Submethod (@james-ray) - [common] #2534 Fix
BitArray.PickRandomto choose uniformly from true bits - [consensus] #1690 Wait for timeoutPrecommit before starting next round
- [consensus] #1745 Wait for Proposal or timeoutProposal before entering prevote
- [consensus] #2642 Only propose ValidBlock, not LockedBlock
- [consensus] #2642 Initialized ValidRound and LockedRound to -1
- [consensus] #1637 Limit the amount of evidence that can be included in a block
- [evidence] #2515 Fix db iter leak (@goolAdapter)
- [libs/event] #2518 Fix event concurrency flaw (@goolAdapter)
- [node] #2434 Make node respond to signal interrupts while sleeping for genesis time
- [state] #2616 Pass nil to NewValidatorSet() when genesis file's Validators field is nil
- [p2p] #2555 Fix p2p switch FlushThrottle value (@goolAdapter)
- [p2p] #2668 Reconnect to originally dialed address (not self-reported address) for persistent peers