You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

9.0 KiB

Pending

v0.26.0

October 29, 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.

Please note that we are still making breaking changes to the protocols. While the new Version fields should help us to keep the software backwards compatible even while upgrading the protocols, we cannot guarantee that new releases will be compatible with old chains just yet. Thanks for bearing with us!

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.wal is 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_query takes prove argument instead of trusted and switches the default behaviour to prove=false
    • [rpc] #2654 Remove all node_info.other.*_version fields in /status and /net_info
  • Apps

    • [abci] #2298 ResponseQuery.Proof is now a structured merkle.Proof, not just arbitrary bytes
    • [abci] #2644 Add Version to Header and shift all fields by one
    • [abci] #2662 Bump the field numbers for some ResponseInfo fields to make room for AppVersion
  • 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 Index and Total fields from TxProof.
    • [types] #2598 VoteTypeXxx are now of type SignedMsgType byte and named XxxType, eg. PrevoteType, PrecommitType.
  • Blockchain Protocol

    • [abci] #2636 Add ValidatorParams field to ConsensusParams. (Used to control which pubkey types validators can use, by abci type)
    • [types] Update SignBytes for Vote/Proposal/Heartbeat:
      • #2459 Use amino encoding instead of JSON in SignBytes.
      • #2598 Reorder fields and use fixed sized encoding.
      • #2598 Change Type field fromt string to byte and use new SignedMsgType to enumerate.
    • [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] #2682 Use proto3 varint encoding for ints that are usually unsigned (instead of zigzag encoding).
  • P2P Protocol

    • [p2p] #2654 Add ProtocolVersion struct with protocol versions to top of DefaultNodeInfo and require ProtocolVersion.Block to match during peer handshake

FEATURES:

  • [abci] #2557 Add Codespace field to Response{CheckTx, DeliverTx, Query}
  • [abci] #2662 Add BlockVersion and P2PVersion to RequestInfo
  • [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/crypto through our fork at github.com/tendermint/crypto
  • [tools] #2238 Binary dependencies are now locked to a specific git commit
  • [libs/log] #2706 Add year to log format

BUG FIXES:

  • [autofile] #2428 Group.RotateFile need call Flush() before rename (@goolAdapter)
  • [common] #2533 Fixed a bug in the BitArray.Or method
  • [common] #2506 Fixed a bug in the BitArray.Sub method (@james-ray)
  • [common] #2534 Fix BitArray.PickRandom to 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] #2583 ensure valid block property with faulty proposer
  • [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
  • [consensus] #2646 Simplify Proposal message (align with spec)
  • [crypto] #2733 Fix general merkle keypath to start w/ last op's key
  • [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