Headline
CVE-2022-29240: Uninitialized memory read in LZ4 decompression leads to authentication bypass
Scylla is a real-time big data database that is API-compatible with Apache Cassandra and Amazon DynamoDB. When decompressing CQL frame received from user, Scylla assumes that user-provided uncompressed length is correct. If user provides fake length, that is greater than the real one, part of decompression buffer won’t be overwritten, and will be left uninitialized. This can be exploited in several ways, depending on the privileges of the user. 1. The main exploit is that an attacker with access to CQL port, but no user account, can bypass authentication, but only if there are other legitimate clients making connections to the cluster, and they use LZ4. 2. Attacker that already has a user account on the cluster can read parts of uninitialized memory, which can contain things like passwords of other users or fragments of other queries / results, which leads to authorization bypass and sensitive information disclosure. The bug has been patched in the following versions: Scylla Enterprise: 2020.1.14, 2021.1.12, 2022.1.0. Scylla Open Source: 4.6.7, 5.0.3. Users unable to upgrade should make sure none of their drivers connect to cluster using LZ4 compression, and that Scylla CQL port is behind firewall. Additionally make sure no untrusted client can connect to Scylla, by setting up authentication and applying workarounds from previous point (firewall, no lz4 compression).
Impact
When decompressing CQL frame received from user, Scylla assumes that user-provided uncompressed length is correct. If user provides fake length, that is greater than the real one, part of decompression buffer won’t be overwritten, and will be left uninitialized.
This can be exploited in several ways, depending on the privileges of the user.
The main exploit is that an attacker with access to CQL port, but no user account, can bypass authentication, but only if there are other legitimate clients making connections to the cluster, and they use LZ4.
Attacker that already has a user account on the cluster can read parts of uninitialized memory, which can contain things like passwords of other users or fragments of other queries / results, which leads to authorization bypass and sensitive information disclosure. Vector string for this attack: CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:H
Patches
The bug has been patched in the following versions:
Scylla Enterprise: 2020.1.14, 2021.1.12, 2022.1.0
Scylla Open Source: 4.6.7, 5.0.3
Workarounds
Apply our security checklist: https://docs.scylladb.com/operating-scylla/security/security-checklist/
For authentication bypass: Make sure none of your drivers connect to cluster using LZ4 compression, and that Scylla CQL port is behind firewall.
For authorization bypass / information disclosure: Make sure no untrusted client can connect to Scylla, by setting up authentication and applying workarounds from previous point (firewall, no lz4 compression).
Credit
Karol Baryła of ScyllaDB discovered the vulnerability in internal testing.
For more information
If you have any questions or comments about this advisory:
- Ask us on our Slack channel: http://slack.scylladb.com/
- Ask us on Google group: https://groups.google.com/d/forum/scylladb-users