CWE
305 863
Advisory Published
CVE Published
Updated

CVE-2023-47090

First published: Thu Oct 19 2023(Updated: )

## Background NATS.io is a high performance open source pub-sub distributed communication technology, built for the cloud, on-premise, IoT, and edge computing. NATS users exist within accounts, and once using accounts, the old authorization block is not applicable. ## Problem Description Without any authorization rules in the nats-server, users can connect without authentication. Before nats-server 2.2.0, all authentication and authorization rules for a nats-server lived in an "authorization" block, defining users. With nats-server 2.2.0 all users live inside accounts. When using the authorization block, whose syntax predates this, those users will be placed into the implicit global account, "$G". Users inside accounts go into the newer "accounts" block. If an "accounts" block is defined, in simple deployment scenarios this is often used only to enable client access to the system account. When the only account added is the system account "$SYS", the nats-server would create an implicit user in "$G" and set it as the `no_auth_user` account, enabling the same "without authentication" logic as without any rules. This preserved the ability to connect simply, and then add one authenticated login for system access. But with an "authorization" block, this is wrong. Users exist in the global account, with login rules. And in simple testing, they might still connect fine without administrators seeing that authentication has been disabled. The blind-spot on our part came from encouraging and documenting a switch to using only "accounts", instead of "authorization". In the fixed versions, using an "authorization" block will inhibit the implicit creation of a "$G" user and setting it as the `no_auth_user` target. In unfixed versions, just creating a second account, with no users, will also inhibit this behavior. ## Affected versions NATS Server: * 2.2.0 up to and including 2.9.22 and 2.10.1 * Fixed with nats-io/nats-server: 2.10.2 and backported to 2.9.23 ## Workarounds In the "accounts" block, define a second non-system account, leave it empty. accounts { SYS: { users: [ { user: sysuser, password: makemeasandwich } ] } DUMMY: {} # for security, before 2.10.2 } system_account: SYS ## Solution Any one of these: 1. Upgrade the NATS server to at least 2.10.2 (or 2.9.23) 2. Or define a dummy account 3. Or complete the migration of authorization entries to be inside a named account in the "accounts" block ## Credits Problem reported by Alex Herrington. Addressed publicly in a GitHub Discussion prior to this advisory.

Credit: cve@mitre.org cve@mitre.org

Affected SoftwareAffected VersionHow to fix
go/github.com/nats-io/nats-server/v2>=2.10.0<2.10.2
2.10.2
go/github.com/nats-io/nats-server/v2>=2.2.0<2.9.23
2.9.23
Linuxfoundation Nats-server>=2.2.0<2.9.23
Linuxfoundation Nats-server>=2.10.0<2.10.2
>=2.2.0<2.9.23
>=2.10.0<2.10.2

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 the severity of CVE-2023-47090?

    The severity of CVE-2023-47090 is medium with a CVSS score of 6.5.

  • How does CVE-2023-47090 affect NATS?

    CVE-2023-47090 affects NATS nats-server versions before 2.9.23 and 2.10.x before 2.10.2.

  • What is the problem description of CVE-2023-47090?

    CVE-2023-47090 is an authentication bypass vulnerability in NATS nats-server.

  • How can I fix CVE-2023-47090?

    To fix CVE-2023-47090, update to NATS nats-server version 2.9.23 or 2.10.2.

  • Where can I find more information about CVE-2023-47090?

    More information about CVE-2023-47090 can be found in the following references: - [GitHub Security Advisory](https://github.com/nats-io/nats-server/security/advisories/GHSA-fr2g-9hjm-wr23) - [Openwall Mailing List](https://www.openwall.com/lists/oss-security/2023/10/13/2) - [GitHub Pull Request](https://github.com/nats-io/nats-server/pull/4605)

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