PT-2026-29168 · Crates.Io · Zebra-Consensus+1
Published
2026-03-30
·
Updated
2026-03-30
·
CVE-2026-34377
CVSS v4.0
8.4
High
| AV:N/AC:L/AT:N/PR:H/UI:N/VC:N/VI:H/VA:H/SC:N/SI:H/SA:H |
CVE-2026-34377: Consensus Failure via Crafted V5 Authorization Data
Summary
A logic error in Zebra's transaction verification cache could allow a malicious miner to induce a consensus split. By matching a valid transaction's
txid while providing invalid authorization data, a miner could cause vulnerable Zebra nodes to accept an invalid block, leading to a consensus split from the rest of the Zcash network. To be clear, this would not allow invalid transactions to be accepted but could result in a consensus split between vulnerable Zebra nodes and invulnerable Zebra and Zcashd nodes.Severity
High - This is a Consensus Vulnerability that could allow a malicious miner to induce network partitioning, service disruption, and potential double-spend attacks against affected nodes.
Affected Versions
All Zebra versions supporting V5 transactions (Network Upgrade 5 and later) prior to version 4.3.0.
Description
The vulnerability exists in the
find verified unmined tx function within transaction.rs. This function was designed to optimize block verification by checking if a transaction was already verified in the mempool.The lookup mechanism used the ZIP-244
txid as the unique key. However, for V5 transactions, the txid specifically excludes the Authorization Data Root (signatures and proofs). Because Zebra returned a "verified" status based solely on the txid, it skipped the essential check v5 auth() call for the transaction version provided in the block.An attacker (specifically a malicious miner) could exploit this by:
- Observing a valid V5 transaction broadcast to the network and entering a Zebra node's mempool.
- Creating a block containing a modified version of that transaction. The modified version has the same
txidbut contains invalid signatures or proofs. - The affected Zebra node identifies the
txidin its mempool and incorrectly assumes the block's version of the transaction is already verified. - The node commits the block with the invalid transaction data.
- Other nodes (like
zcashdorzebranodes without that transaction in their mempool) reject the block, resulting in a chain fork where the poisoned Zebra node is isolated.
Impact
Consensus Failure
- Attack Vector: Network (specifically via a malicious miner).
- Effect: Network partition/consensus split.
- Scope: Any Zebra node utilizing the transaction verification cache optimization for V5 transactions.
Fixed Versions
This issue is fixed in Zebra 4.3.0.
The fix ensures that verification is only skipped if the transaction's full integrity—including authorization data—is validated against the mempool entry.
Mitigation
Users should upgrade to Zebra 4.3.0 or later immediately.
There are no known workarounds for this issue. Immediate upgrade is the only way to ensure the node remains on the correct consensus path and is protected against malicious chain forks.
Resources
Fix
Improper Verification of Cryptographic Signature
Found an issue in the description? Have something to add? Feel free to write us 👾
Weakness Enumeration
Related Identifiers
Affected Products
Zebra-Consensus
Zebrad