Apache ZooKeeper: Authorization bypass in SASL Quorum Peer Authentication
Description
Authorization Bypass Through User-Controlled Key vulnerability in Apache ZooKeeper. If SASL Quorum Peer authentication is enabled in ZooKeeper (quorum.auth.enableSasl=true), the authorization is done by verifying that the instance part in SASL authentication ID is listed in zoo.cfg server list. The instance part in SASL auth ID is optional and if it's missing, like 'eve@EXAMPLE.COM', the authorization check will be skipped. As a result an arbitrary endpoint could join the cluster and begin propagating counterfeit changes to the leader, essentially giving it complete read-write access to the data tree. Quorum Peer authentication is not enabled by default.
Users are recommended to upgrade to version 3.9.1, 3.8.3, 3.7.2, which fixes the issue.
Alternately ensure the ensemble election/quorum communication is protected by a firewall as this will mitigate the issue.
See the documentation for more details on correct cluster administration.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Apache ZooKeeper's SASL Quorum Peer authentication can be bypassed when the instance part of the SASL auth ID is omitted, allowing an arbitrary endpoint to join the cluster with full read-write access.
Vulnerability
Overview
CVE-2023-44981 is an authorization bypass vulnerability in Apache ZooKeeper's SASL Quorum Peer authentication mechanism. When SASL Quorum Peer authentication is enabled (via quorum.auth.enableSasl=true), the authorization check verifies that the instance part of the SASL authentication ID is present in the server list defined in zoo.cfg. However, because the instance part is optional, an attacker can supply an SASL auth ID such as eve@EXAMPLE.COM (with no instance part), which causes the authorization check to be skipped entirely. This allows an unauthenticated endpoint to join the cluster [1][2].
Exploitation
An attacker can exploit this by providing a crafted SASL authentication ID that lacks the instance part. Since the authorization check is bypassed, the attacker's endpoint can join the ZooKeeper ensemble. The vulnerability requires that SASL Quorum Peer authentication be enabled, which is not the default configuration. However, in environments where this is enabled, an attacker with network access to the ZooKeeper cluster can exploit the flaw without any prior authentication [1][2].
Impact
A successful attack allows the malicious endpoint to propagate counterfeit changes to the leader, effectively granting the attacker complete read-write access to the entire data tree managed by ZooKeeper. This can lead to data integrity breaches, unauthorized modification of configuration data, and potential disruption of services that rely on ZooKeeper for coordination [1][2].
Mitigation
The vulnerability has been fixed in Apache ZooKeeper versions 3.9.1, 3.8.3, and 3.7.2. Users are strongly recommended to upgrade to one of these patched versions. As an interim mitigation, administrators can protect ensemble election and quorum communication using a firewall to restrict network access, which reduces the attack surface [1][2].
AI Insight generated on May 20, 2026. Synthesized from this CVE's description and the cited reference URLs; citations are validated against the source bundle.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
org.apache.zookeeper:zookeeperMaven | < 3.7.2 | 3.7.2 |
org.apache.zookeeper:zookeeperMaven | >= 3.8.0, < 3.8.3 | 3.8.3 |
org.apache.zookeeper:zookeeperMaven | >= 3.9.0, < 3.9.1 | 3.9.1 |
Affected products
123- osv-coords122 versionspkg:apk/chainguard/kafkapkg:apk/chainguard/kafka-bitnami-compatpkg:apk/chainguard/trinopkg:apk/chainguard/trino-configpkg:apk/chainguard/trino-oci-entrypointpkg:apk/chainguard/trino-plugin-ai-functionspkg:apk/chainguard/trino-plugin-bigquerypkg:apk/chainguard/trino-plugin-blackholepkg:apk/chainguard/trino-plugin-cassandrapkg:apk/chainguard/trino-plugin-clickhousepkg:apk/chainguard/trino-plugin-delta-lakepkg:apk/chainguard/trino-plugin-druidpkg:apk/chainguard/trino-plugin-duckdbpkg:apk/chainguard/trino-plugin-elasticsearchpkg:apk/chainguard/trino-plugin-exasolpkg:apk/chainguard/trino-plugin-exchange-filesystempkg:apk/chainguard/trino-plugin-exchange-hdfspkg:apk/chainguard/trino-plugin-fakerpkg:apk/chainguard/trino-plugin-functions-pythonpkg:apk/chainguard/trino-plugin-geospatialpkg:apk/chainguard/trino-plugin-google-sheetspkg:apk/chainguard/trino-plugin-hivepkg:apk/chainguard/trino-plugin-http-event-listenerpkg:apk/chainguard/trino-plugin-hudipkg:apk/chainguard/trino-plugin-icebergpkg:apk/chainguard/trino-plugin-ignitepkg:apk/chainguard/trino-plugin-jmxpkg:apk/chainguard/trino-plugin-kafkapkg:apk/chainguard/trino-plugin-kafka-event-listenerpkg:apk/chainguard/trino-plugin-lakehousepkg:apk/chainguard/trino-plugin-ldap-group-providerpkg:apk/chainguard/trino-plugin-lokipkg:apk/chainguard/trino-plugin-mariadbpkg:apk/chainguard/trino-plugin-memorypkg:apk/chainguard/trino-plugin-mlpkg:apk/chainguard/trino-plugin-mongodbpkg:apk/chainguard/trino-plugin-mysqlpkg:apk/chainguard/trino-plugin-mysql-event-listenerpkg:apk/chainguard/trino-plugin-opapkg:apk/chainguard/trino-plugin-openlineagepkg:apk/chainguard/trino-plugin-opensearchpkg:apk/chainguard/trino-plugin-oraclepkg:apk/chainguard/trino-plugin-password-authenticatorspkg:apk/chainguard/trino-plugin-pinotpkg:apk/chainguard/trino-plugin-postgresqlpkg:apk/chainguard/trino-plugin-prometheuspkg:apk/chainguard/trino-plugin-rangerpkg:apk/chainguard/trino-plugin-redispkg:apk/chainguard/trino-plugin-redshiftpkg:apk/chainguard/trino-plugin-resource-group-managerspkg:apk/chainguard/trino-plugin-session-property-managerspkg:apk/chainguard/trino-plugin-singlestorepkg:apk/chainguard/trino-plugin-snowflakepkg:apk/chainguard/trino-plugin-spooling-filesystempkg:apk/chainguard/trino-plugin-sqlserverpkg:apk/chainguard/trino-plugin-teradata-functionspkg:apk/chainguard/trino-plugin-thriftpkg:apk/chainguard/trino-plugin-tpcdspkg:apk/chainguard/trino-plugin-tpchpkg:apk/chainguard/trino-plugin-verticapkg:apk/wolfi/kafkapkg:apk/wolfi/kafka-bitnami-compatpkg:apk/wolfi/trinopkg:apk/wolfi/trino-configpkg:apk/wolfi/trino-oci-entrypointpkg:apk/wolfi/trino-plugin-ai-functionspkg:apk/wolfi/trino-plugin-bigquerypkg:apk/wolfi/trino-plugin-blackholepkg:apk/wolfi/trino-plugin-cassandrapkg:apk/wolfi/trino-plugin-clickhousepkg:apk/wolfi/trino-plugin-delta-lakepkg:apk/wolfi/trino-plugin-druidpkg:apk/wolfi/trino-plugin-duckdbpkg:apk/wolfi/trino-plugin-elasticsearchpkg:apk/wolfi/trino-plugin-exasolpkg:apk/wolfi/trino-plugin-exchange-filesystempkg:apk/wolfi/trino-plugin-exchange-hdfspkg:apk/wolfi/trino-plugin-fakerpkg:apk/wolfi/trino-plugin-functions-pythonpkg:apk/wolfi/trino-plugin-geospatialpkg:apk/wolfi/trino-plugin-google-sheetspkg:apk/wolfi/trino-plugin-hivepkg:apk/wolfi/trino-plugin-http-event-listenerpkg:apk/wolfi/trino-plugin-hudipkg:apk/wolfi/trino-plugin-icebergpkg:apk/wolfi/trino-plugin-ignitepkg:apk/wolfi/trino-plugin-jmxpkg:apk/wolfi/trino-plugin-kafkapkg:apk/wolfi/trino-plugin-kafka-event-listenerpkg:apk/wolfi/trino-plugin-lakehousepkg:apk/wolfi/trino-plugin-ldap-group-providerpkg:apk/wolfi/trino-plugin-lokipkg:apk/wolfi/trino-plugin-mariadbpkg:apk/wolfi/trino-plugin-memorypkg:apk/wolfi/trino-plugin-mlpkg:apk/wolfi/trino-plugin-mongodbpkg:apk/wolfi/trino-plugin-mysqlpkg:apk/wolfi/trino-plugin-mysql-event-listenerpkg:apk/wolfi/trino-plugin-opapkg:apk/wolfi/trino-plugin-openlineagepkg:apk/wolfi/trino-plugin-opensearchpkg:apk/wolfi/trino-plugin-oraclepkg:apk/wolfi/trino-plugin-password-authenticatorspkg:apk/wolfi/trino-plugin-pinotpkg:apk/wolfi/trino-plugin-postgresqlpkg:apk/wolfi/trino-plugin-prometheuspkg:apk/wolfi/trino-plugin-rangerpkg:apk/wolfi/trino-plugin-redispkg:apk/wolfi/trino-plugin-redshiftpkg:apk/wolfi/trino-plugin-resource-group-managerspkg:apk/wolfi/trino-plugin-session-property-managerspkg:apk/wolfi/trino-plugin-singlestorepkg:apk/wolfi/trino-plugin-snowflakepkg:apk/wolfi/trino-plugin-spooling-filesystempkg:apk/wolfi/trino-plugin-sqlserverpkg:apk/wolfi/trino-plugin-teradata-functionspkg:apk/wolfi/trino-plugin-thriftpkg:apk/wolfi/trino-plugin-tpcdspkg:apk/wolfi/trino-plugin-tpchpkg:apk/wolfi/trino-plugin-verticapkg:bitnami/zookeeperpkg:maven/org.apache.zookeeper/zookeeper
< 3.6.0-r4+ 121 more
- (no CPE)range: < 3.6.0-r4
- (no CPE)range: < 3.6.0-r4
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 3.6.0-r4
- (no CPE)range: < 3.6.0-r4
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 478-r2
- (no CPE)range: < 3.7.2
- (no CPE)range: < 3.7.2
- Apache Software Foundation/Apache ZooKeeperv5Range: 3.9.0
Patches
0No patches discovered yet.
Vulnerability mechanics
AI mechanics synthesis has not run for this CVE yet.
References
8- github.com/advisories/GHSA-7286-pgfv-vxvhghsaADVISORY
- lists.apache.org/thread/wf0yrk84dg1942z1o74kd8nycg6pgm5bghsavendor-advisoryWEB
- nvd.nist.gov/vuln/detail/CVE-2023-44981ghsaADVISORY
- www.openwall.com/lists/oss-security/2023/10/11/4ghsaWEB
- lists.debian.org/debian-lts-announce/2023/10/msg00029.htmlghsaWEB
- security.netapp.com/advisory/ntap-20240621-0007ghsaWEB
- www.debian.org/security/2023/dsa-5544ghsaWEB
- security.netapp.com/advisory/ntap-20240621-0007/mitre
News mentions
0No linked articles in our index yet.