blob: a0538881230692151ee5a6f3564c9f7a87de9675 [file] [log] [blame]
id: GO-2022-1052
modules:
- module: github.com/tendermint/tendermint
versions:
- introduced: 0.34.0
fixed: 0.34.3
vulnerable_at: 0.34.2
packages:
- package: github.com/tendermint/tendermint/evidence
symbols:
- Pool.Update
- Pool.CheckEvidence
- package: github.com/tendermint/tendermint/consensus
symbols:
- State.tryAddVote
derived_symbols:
- BaseWAL.OnStart
- Handshaker.Handshake
- Handshaker.ReplayBlocks
- Reactor.OnStart
- Reactor.SwitchToConsensus
- RunReplayFile
- State.OnStart
- State.OpenWAL
- State.ReplayFile
- WALGenerateNBlocks
- WALWithNBlocks
summary: 'TODO(https://go.dev/issue/56443): fill in summary field'
description: |
Mishandling of timestamps during consensus process can cause a denial of service.
While reaching consensus, different tendermint nodes can observe a different
timestamp for a consensus evidence. This mismatch can cause the evidence to be
invalid, upon which the node producing the evidence will be asked to generate
a new evidence. This new evidence will be the same, which means it will again
be rejected by other nodes involved in the consensus. This loop will continue
until the peer nodes decide to disconnect from the node producing the evidence.
cves:
- CVE-2021-21271
ghsas:
- GHSA-p658-8693-mhvg
credits:
- cmwaters (Github)
references:
- advisory: https://github.com/tendermint/tendermint/security/advisories/GHSA-p658-8693-mhvg
- article: https://github.com/tendermint/tendermint/blob/v0.34.3/CHANGELOG.md#v0.34.3
- fix: https://github.com/tendermint/tendermint/commit/a2a6852ab99e4a0f9e79f0ea8c1726e262e25c76