VDB
KO
MEDIUM 5.3

GHSA-j99g-7rqw-q9jg

nimiq-blockchain: Peer-triggerable panic during history sync

Details

### Impact `HistoryStore::put_historic_txns` uses an `assert!` to enforce invariants about `HistoricTransaction.block_number` (must be within the macro block being pushed and within the same epoch). During history sync, a peer can influence the `history: &[HistoricTransaction]` input passed into `Blockchain::push_history_sync`, and a malformed history list can violate these invariants and trigger a panic.

`extend_history_sync` calls `this.history_store.add_to_history(..)` before comparing the computed history root against the macro block header (`block.history_root()`), so the panic can happen before later rejection checks run.

### Patches [The patch for this vulnerability](https://github.com/nimiq/core-rs-albatross/commit/6f5511309c199d84b012fe6b9aba7e5582892c50) is included as part of [v1.3.0](https://github.com/nimiq/core-rs-albatross/releases/tag/v1.3.0).

### Workarounds No known workarounds.

Are you affected?

Enter the version of the package you're using.

Affected packages

crates.io / nimiq-blockchain
Introduced in: 0

No fixed version published yet for nimiq-blockchain. Pin to a known-safe version or switch to an alternative.

References