CVE-2023-23931: Cipher.update_into can corrupt memory in pyca cryptography

Published Feb 7, 2023
·
Updated

cryptography is a package designed to expose cryptographic primitives and recipes to Python developers. In affected versions Cipher.updateinto would accept Python objects which implement the buffer protocol, but provide only immutable buffers. This would allow immutable objects (such as bytes) to be mutated, thus violating fundamental rules of Python and resulting in corrupted output. This now correctly raises an exception. This issue has been present since updateinto was originally introduced in cryptography 1.8.

Other sources

Previously, Cipher.updateinto would accept Python objects which implement the buffer protocol, but provide only immutable buffers:

pycon >>> outbuf = b"\x00" 32 >>> c = ciphers.Cipher(AES(b"\x00" 32), modes.ECB()).encryptor() >>> c.updateinto(b"\x00" 16, outbuf) 16 >>> outbuf b'\xdc\x95\xc0x\xa2@\x89\x89\xadH\xa2\x14\x92\x84 \x87\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00'

This would allow immutable objects (such as bytes) to be mutated, thus violating fundamental rules of Python. This is a soundness bug -- it allows programmers to misuse an API, it cannot be exploited by attacker controlled data alone.

This now correctly raises an exception.

This issue has been present since updateinto was originally introduced in cryptography 1.8.

GitHub

Affected Software

12 affected componentsFixes available
debian/python-cryptography<=2.6.1-3+deb10u2, <=3.3.2-1, <=38.0.4-3~deb12u1
2.6.1-3+deb10u438.0.4-341.0.7-442.0.5-2
ubuntu/python-cryptography<2.8-3ubuntu0.2
2.8-3ubuntu0.2
ubuntu/python-cryptography<3.4.8-1ubuntu2.1
3.4.8-1ubuntu2.1
ubuntu/python-cryptography<38.0.4-2ubuntu0.1
38.0.4-2ubuntu0.1
ubuntu/python-cryptography<39.0.1
39.0.1
pip/cryptography>=1.8<39.0.1
39.0.1
IBM Cognos Analytics<=12.0.0-12.0.3
IBM Cognos Analytics<=11.2.0-11.2.4 FP4
cryptography project Cryptography Python>=1.8<39.0.1
Cryptography.io Cryptography Python>=1.8<39.0.1
redhat/python-cryptography<39.0.1
39.0.1
redhat/cryptography<39.0.1
39.0.1

Event History

Feb 7, 2023
CVE Published
via Ubuntu·12:00 AM
CVE Published
via MITRE·08:54 PM
Data Sourced
via MITRE·08:54 PM
DescriptionSeverityWeakness
Advisory Published
via GitHub·08:54 PM
Data Sourced
via NVD·09:15 PM
RemedyDescriptionSeverityWeaknessAffected Software
Feb 20, 2023
Data Sourced
via Red Hat·02:01 PM
DescriptionSeverityAffected Software
Jan 12, 2024
Data Sourced
via Launchpad·12:16 AM
Description

Parent advisories

This vulnerability appears in the following advisories.

Free Weekly Intel

Don't miss critical vulnerabilities

Join thousands of security professionals who receive our weekly digest of trending CVEs, zero-days, and exploited vulnerabilities.

No spam. Unsubscribe anytime.

Frequently Asked Questions

1

What is CVE-2023-23931?

CVE-2023-23931 is a vulnerability in the cryptography package for Python that allows the use of objects implementing the buffer protocol to update immutable buffers.

2

What is the severity of CVE-2023-23931?

CVE-2023-23931 has a severity rating of medium with a CVSS score of 6.5.

3

Which software is affected by CVE-2023-23931?

The cryptography package for Python versions 1.8 up to and including 39.0.1 is affected by CVE-2023-23931.

4

How can I fix CVE-2023-23931?

To fix CVE-2023-23931, update the cryptography package to version 39.0.1 or higher.

5

Where can I find more information about CVE-2023-23931?

You can find more information about CVE-2023-23931 in the following references: [GitHub Advisory](https://github.com/pyca/cryptography/security/advisories/GHSA-w7pp-m8wf-vj6r), [GitHub Pull Request](https://github.com/pyca/cryptography/pull/8230/commits/94a50a9731f35405f0357fa5f3b177d46a726ab3), [NVD](https://nvd.nist.gov/vuln/detail/CVE-2023-23931).

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.
© 2026 SecAlerts Pty Ltd.
ABN: 70 645 966 203, ACN: 645 966 203