7.5
CWE
697
Advisory Published
Updated

CVE-2022-24787: Incorrect Comparison in Vyper

First published: Mon Apr 04 2022(Updated: )

Vyper is a Pythonic Smart Contract Language for the Ethereum Virtual Machine. In version 0.3.1 and prior, bytestrings can have dirty bytes in them, resulting in the word-for-word comparisons giving incorrect results. Even without dirty nonzero bytes, two bytestrings can compare to equal if one ends with `"\x00"` because there is no comparison of the length. A patch is available and expected to be part of the 0.3.2 release. There are currently no known workarounds.

Credit: security-advisories@github.com security-advisories@github.com

Affected SoftwareAffected VersionHow to fix
Vyperlang Vyper<=0.3.1

Never miss a vulnerability like this again

Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.

Frequently Asked Questions

  • What is CVE-2022-24787?

    CVE-2022-24787 is a vulnerability in the Vyper smart contract language that allows for incorrect word-for-word comparisons of bytestrings, resulting in incorrect results.

  • What is the severity of CVE-2022-24787?

    CVE-2022-24787 has a severity rating of 7.5 (high).

  • How does CVE-2022-24787 affect Vyperlang Vyper?

    CVE-2022-24787 affects Vyperlang Vyper version 0.3.1 and prior, allowing for incorrect comparison of bytestrings.

  • How can I fix CVE-2022-24787?

    To fix CVE-2022-24787, update to a version of Vyperlang Vyper that is 0.3.2 or later.

  • Where can I find more information about CVE-2022-24787?

    You can find more information about CVE-2022-24787 in the GitHub commit and advisory links: - GitHub Commit: [link] - GitHub Advisory: [link]

Contact

SecAlerts Pty Ltd.
132 Wickham Terrace
Fortitude Valley,
QLD 4006, Australia
info@secalerts.co
By using SecAlerts services, you agree to our services end-user license agreement. This website is safeguarded by reCAPTCHA and governed by the Google Privacy Policy and Terms of Service. All names, logos, and brands of products are owned by their respective owners, and any usage of these names, logos, and brands for identification purposes only does not imply endorsement. If you possess any content that requires removal, please get in touch with us.
© 2025 SecAlerts Pty Ltd.
ABN: 70 645 966 203, ACN: 645 966 203