CVE-2025-31124 (GCVE-0-2025-31124)
Vulnerability from cvelistv5
Published
2025-03-31 19:38
Modified
2025-03-31 22:26
CWE
  • CWE-203 - Observable Discrepancy
  • CWE-204 - Observable Response Discrepancy
  • CWE-200 - Exposure of Sensitive Information to an Unauthorized Actor
Summary
Zitadel is open-source identity infrastructure software. ZITADEL administrators can enable a setting called "Ignoring unknown usernames" which helps mitigate attacks that try to guess/enumerate usernames. If enabled, ZITADEL will show the password prompt even if the user doesn't exist and report "Username or Password invalid". While the setting was correctly respected during the login flow, the user's username was normalized leading to a disclosure of the user's existence. This vulnerability is fixed in 2.71.6, 2.70.8, 2.69.9, 2.68.9, 2.67.13, 2.66.16, 2.65.7, 2.64.6, and 2.63.9.
Impacted products
Vendor Product Version
zitadel zitadel Version: >= 2.62.0, < 2.63.9
Version: >= 2.64.0-rc.1, < 2.64.6
Version: >= 2.65.0-rc.1, < 2.65.7
Version: >= 2.66.0-rc.1, < 2.66.16
Version: >= 2.67.0-rc.1, < 2.67.13
Version: >= 2.68.0-rc.1, < 2.68.9
Version: >= 2.69.0-rc.1, < 2.69.9
Version: >= 2.70.0-rc.1, < 2.70.8
Version: >= 2.71.0-rc.1, < 2.71.6
Create a notification for this product.
Show details on NVD website


{
  "containers": {
    "adp": [
      {
        "metrics": [
          {
            "other": {
              "content": {
                "id": "CVE-2025-31124",
                "options": [
                  {
                    "Exploitation": "none"
                  },
                  {
                    "Automatable": "yes"
                  },
                  {
                    "Technical Impact": "partial"
                  }
                ],
                "role": "CISA Coordinator",
                "timestamp": "2025-03-31T22:26:27.377115Z",
                "version": "2.0.3"
              },
              "type": "ssvc"
            }
          }
        ],
        "providerMetadata": {
          "dateUpdated": "2025-03-31T22:26:39.989Z",
          "orgId": "134c704f-9b21-4f2e-91b3-4a467353bcc0",
          "shortName": "CISA-ADP"
        },
        "title": "CISA ADP Vulnrichment"
      }
    ],
    "cna": {
      "affected": [
        {
          "product": "zitadel",
          "vendor": "zitadel",
          "versions": [
            {
              "status": "affected",
              "version": "\u003e= 2.62.0, \u003c 2.63.9"
            },
            {
              "status": "affected",
              "version": "\u003e= 2.64.0-rc.1, \u003c 2.64.6"
            },
            {
              "status": "affected",
              "version": "\u003e= 2.65.0-rc.1, \u003c 2.65.7"
            },
            {
              "status": "affected",
              "version": "\u003e= 2.66.0-rc.1, \u003c 2.66.16"
            },
            {
              "status": "affected",
              "version": "\u003e= 2.67.0-rc.1, \u003c 2.67.13"
            },
            {
              "status": "affected",
              "version": "\u003e= 2.68.0-rc.1, \u003c 2.68.9"
            },
            {
              "status": "affected",
              "version": "\u003e= 2.69.0-rc.1, \u003c 2.69.9"
            },
            {
              "status": "affected",
              "version": "\u003e= 2.70.0-rc.1, \u003c 2.70.8"
            },
            {
              "status": "affected",
              "version": "\u003e= 2.71.0-rc.1, \u003c 2.71.6"
            }
          ]
        }
      ],
      "descriptions": [
        {
          "lang": "en",
          "value": "Zitadel is open-source identity infrastructure software. ZITADEL administrators can enable a setting called \"Ignoring unknown usernames\" which helps mitigate attacks that try to guess/enumerate usernames. If enabled, ZITADEL will show the password prompt even if the user doesn\u0027t exist and report \"Username or Password invalid\". While the setting was correctly respected during the login flow, the user\u0027s username was normalized leading to a disclosure of the user\u0027s existence. This vulnerability is fixed in 2.71.6, 2.70.8, 2.69.9, 2.68.9, 2.67.13, 2.66.16, 2.65.7, 2.64.6, and 2.63.9."
        }
      ],
      "metrics": [
        {
          "cvssV3_1": {
            "attackComplexity": "LOW",
            "attackVector": "NETWORK",
            "availabilityImpact": "NONE",
            "baseScore": 5.3,
            "baseSeverity": "MEDIUM",
            "confidentialityImpact": "LOW",
            "integrityImpact": "NONE",
            "privilegesRequired": "NONE",
            "scope": "UNCHANGED",
            "userInteraction": "NONE",
            "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N",
            "version": "3.1"
          }
        }
      ],
      "problemTypes": [
        {
          "descriptions": [
            {
              "cweId": "CWE-203",
              "description": "CWE-203: Observable Discrepancy",
              "lang": "en",
              "type": "CWE"
            }
          ]
        },
        {
          "descriptions": [
            {
              "cweId": "CWE-204",
              "description": "CWE-204: Observable Response Discrepancy",
              "lang": "en",
              "type": "CWE"
            }
          ]
        },
        {
          "descriptions": [
            {
              "cweId": "CWE-200",
              "description": "CWE-200: Exposure of Sensitive Information to an Unauthorized Actor",
              "lang": "en",
              "type": "CWE"
            }
          ]
        }
      ],
      "providerMetadata": {
        "dateUpdated": "2025-03-31T19:38:12.235Z",
        "orgId": "a0819718-46f1-4df5-94e2-005712e83aaa",
        "shortName": "GitHub_M"
      },
      "references": [
        {
          "name": "https://github.com/zitadel/zitadel/security/advisories/GHSA-67m4-8g4w-633q",
          "tags": [
            "x_refsource_CONFIRM"
          ],
          "url": "https://github.com/zitadel/zitadel/security/advisories/GHSA-67m4-8g4w-633q"
        },
        {
          "name": "https://github.com/zitadel/zitadel/commit/14de8ecac2afafee4975ed7ac26f3ca4a2b0f82c",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/commit/14de8ecac2afafee4975ed7ac26f3ca4a2b0f82c"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.63.9",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.63.9"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.64.6",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.64.6"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.65.7",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.65.7"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.66.16",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.66.16"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.67.13",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.67.13"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.68.9",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.68.9"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.69.9",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.69.9"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.70.8",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.70.8"
        },
        {
          "name": "https://github.com/zitadel/zitadel/releases/tag/v2.71.6",
          "tags": [
            "x_refsource_MISC"
          ],
          "url": "https://github.com/zitadel/zitadel/releases/tag/v2.71.6"
        }
      ],
      "source": {
        "advisory": "GHSA-67m4-8g4w-633q",
        "discovery": "UNKNOWN"
      },
      "title": "Zitadel  allows User Enumeration by loginname attribute normalization"
    }
  },
  "cveMetadata": {
    "assignerOrgId": "a0819718-46f1-4df5-94e2-005712e83aaa",
    "assignerShortName": "GitHub_M",
    "cveId": "CVE-2025-31124",
    "datePublished": "2025-03-31T19:38:12.235Z",
    "dateReserved": "2025-03-26T15:04:52.626Z",
    "dateUpdated": "2025-03-31T22:26:39.989Z",
    "state": "PUBLISHED"
  },
  "dataType": "CVE_RECORD",
  "dataVersion": "5.1",
  "vulnerability-lookup:meta": {
    "nvd": "{\"cve\":{\"id\":\"CVE-2025-31124\",\"sourceIdentifier\":\"security-advisories@github.com\",\"published\":\"2025-03-31T20:15:15.707\",\"lastModified\":\"2025-04-01T20:26:22.890\",\"vulnStatus\":\"Awaiting Analysis\",\"cveTags\":[],\"descriptions\":[{\"lang\":\"en\",\"value\":\"Zitadel is open-source identity infrastructure software. ZITADEL administrators can enable a setting called \\\"Ignoring unknown usernames\\\" which helps mitigate attacks that try to guess/enumerate usernames. If enabled, ZITADEL will show the password prompt even if the user doesn\u0027t exist and report \\\"Username or Password invalid\\\". While the setting was correctly respected during the login flow, the user\u0027s username was normalized leading to a disclosure of the user\u0027s existence. This vulnerability is fixed in 2.71.6, 2.70.8, 2.69.9, 2.68.9, 2.67.13, 2.66.16, 2.65.7, 2.64.6, and 2.63.9.\"},{\"lang\":\"es\",\"value\":\"Zitadel es un software de infraestructura de identidad de c\u00f3digo abierto. Los administradores de ZITADEL pueden habilitar la configuraci\u00f3n \\\"Ignorar nombres de usuario desconocidos\\\", que ayuda a mitigar los ataques que intentan adivinar o enumerar nombres de usuario. Si se habilita, ZITADEL mostrar\u00e1 la solicitud de contrase\u00f1a incluso si el usuario no existe e informar\u00e1 \\\"Nombre de usuario o contrase\u00f1a no v\u00e1lidos\\\". Si bien la configuraci\u00f3n se respet\u00f3 correctamente durante el inicio de sesi\u00f3n, el nombre de usuario se normaliz\u00f3, lo que revel\u00f3 su existencia. Esta vulnerabilidad est\u00e1 corregida en las versiones 2.71.6, 2.70.8, 2.69.9, 2.68.9, 2.67.13, 2.66.16, 2.65.7, 2.64.6 y 2.63.9.\"}],\"metrics\":{\"cvssMetricV31\":[{\"source\":\"security-advisories@github.com\",\"type\":\"Secondary\",\"cvssData\":{\"version\":\"3.1\",\"vectorString\":\"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N\",\"baseScore\":5.3,\"baseSeverity\":\"MEDIUM\",\"attackVector\":\"NETWORK\",\"attackComplexity\":\"LOW\",\"privilegesRequired\":\"NONE\",\"userInteraction\":\"NONE\",\"scope\":\"UNCHANGED\",\"confidentialityImpact\":\"LOW\",\"integrityImpact\":\"NONE\",\"availabilityImpact\":\"NONE\"},\"exploitabilityScore\":3.9,\"impactScore\":1.4}]},\"weaknesses\":[{\"source\":\"security-advisories@github.com\",\"type\":\"Primary\",\"description\":[{\"lang\":\"en\",\"value\":\"CWE-200\"},{\"lang\":\"en\",\"value\":\"CWE-203\"},{\"lang\":\"en\",\"value\":\"CWE-204\"}]}],\"references\":[{\"url\":\"https://github.com/zitadel/zitadel/commit/14de8ecac2afafee4975ed7ac26f3ca4a2b0f82c\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.63.9\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.64.6\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.65.7\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.66.16\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.67.13\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.68.9\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.69.9\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.70.8\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/releases/tag/v2.71.6\",\"source\":\"security-advisories@github.com\"},{\"url\":\"https://github.com/zitadel/zitadel/security/advisories/GHSA-67m4-8g4w-633q\",\"source\":\"security-advisories@github.com\"}]}}",
    "vulnrichment": {
      "containers": "{\"adp\": [{\"title\": \"CISA ADP Vulnrichment\", \"metrics\": [{\"other\": {\"type\": \"ssvc\", \"content\": {\"id\": \"CVE-2025-31124\", \"role\": \"CISA Coordinator\", \"options\": [{\"Exploitation\": \"none\"}, {\"Automatable\": \"yes\"}, {\"Technical Impact\": \"partial\"}], \"version\": \"2.0.3\", \"timestamp\": \"2025-03-31T22:26:27.377115Z\"}}}], \"providerMetadata\": {\"orgId\": \"134c704f-9b21-4f2e-91b3-4a467353bcc0\", \"shortName\": \"CISA-ADP\", \"dateUpdated\": \"2025-03-31T22:26:35.962Z\"}}], \"cna\": {\"title\": \"Zitadel  allows User Enumeration by loginname attribute normalization\", \"source\": {\"advisory\": \"GHSA-67m4-8g4w-633q\", \"discovery\": \"UNKNOWN\"}, \"metrics\": [{\"cvssV3_1\": {\"scope\": \"UNCHANGED\", \"version\": \"3.1\", \"baseScore\": 5.3, \"attackVector\": \"NETWORK\", \"baseSeverity\": \"MEDIUM\", \"vectorString\": \"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N\", \"integrityImpact\": \"NONE\", \"userInteraction\": \"NONE\", \"attackComplexity\": \"LOW\", \"availabilityImpact\": \"NONE\", \"privilegesRequired\": \"NONE\", \"confidentialityImpact\": \"LOW\"}}], \"affected\": [{\"vendor\": \"zitadel\", \"product\": \"zitadel\", \"versions\": [{\"status\": \"affected\", \"version\": \"\u003e= 2.62.0, \u003c 2.63.9\"}, {\"status\": \"affected\", \"version\": \"\u003e= 2.64.0-rc.1, \u003c 2.64.6\"}, {\"status\": \"affected\", \"version\": \"\u003e= 2.65.0-rc.1, \u003c 2.65.7\"}, {\"status\": \"affected\", \"version\": \"\u003e= 2.66.0-rc.1, \u003c 2.66.16\"}, {\"status\": \"affected\", \"version\": \"\u003e= 2.67.0-rc.1, \u003c 2.67.13\"}, {\"status\": \"affected\", \"version\": \"\u003e= 2.68.0-rc.1, \u003c 2.68.9\"}, {\"status\": \"affected\", \"version\": \"\u003e= 2.69.0-rc.1, \u003c 2.69.9\"}, {\"status\": \"affected\", \"version\": \"\u003e= 2.70.0-rc.1, \u003c 2.70.8\"}, {\"status\": \"affected\", \"version\": \"\u003e= 2.71.0-rc.1, \u003c 2.71.6\"}]}], \"references\": [{\"url\": \"https://github.com/zitadel/zitadel/security/advisories/GHSA-67m4-8g4w-633q\", \"name\": \"https://github.com/zitadel/zitadel/security/advisories/GHSA-67m4-8g4w-633q\", \"tags\": [\"x_refsource_CONFIRM\"]}, {\"url\": \"https://github.com/zitadel/zitadel/commit/14de8ecac2afafee4975ed7ac26f3ca4a2b0f82c\", \"name\": \"https://github.com/zitadel/zitadel/commit/14de8ecac2afafee4975ed7ac26f3ca4a2b0f82c\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.63.9\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.63.9\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.64.6\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.64.6\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.65.7\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.65.7\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.66.16\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.66.16\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.67.13\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.67.13\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.68.9\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.68.9\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.69.9\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.69.9\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.70.8\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.70.8\", \"tags\": [\"x_refsource_MISC\"]}, {\"url\": \"https://github.com/zitadel/zitadel/releases/tag/v2.71.6\", \"name\": \"https://github.com/zitadel/zitadel/releases/tag/v2.71.6\", \"tags\": [\"x_refsource_MISC\"]}], \"descriptions\": [{\"lang\": \"en\", \"value\": \"Zitadel is open-source identity infrastructure software. ZITADEL administrators can enable a setting called \\\"Ignoring unknown usernames\\\" which helps mitigate attacks that try to guess/enumerate usernames. If enabled, ZITADEL will show the password prompt even if the user doesn\u0027t exist and report \\\"Username or Password invalid\\\". While the setting was correctly respected during the login flow, the user\u0027s username was normalized leading to a disclosure of the user\u0027s existence. This vulnerability is fixed in 2.71.6, 2.70.8, 2.69.9, 2.68.9, 2.67.13, 2.66.16, 2.65.7, 2.64.6, and 2.63.9.\"}], \"problemTypes\": [{\"descriptions\": [{\"lang\": \"en\", \"type\": \"CWE\", \"cweId\": \"CWE-203\", \"description\": \"CWE-203: Observable Discrepancy\"}]}, {\"descriptions\": [{\"lang\": \"en\", \"type\": \"CWE\", \"cweId\": \"CWE-204\", \"description\": \"CWE-204: Observable Response Discrepancy\"}]}, {\"descriptions\": [{\"lang\": \"en\", \"type\": \"CWE\", \"cweId\": \"CWE-200\", \"description\": \"CWE-200: Exposure of Sensitive Information to an Unauthorized Actor\"}]}], \"providerMetadata\": {\"orgId\": \"a0819718-46f1-4df5-94e2-005712e83aaa\", \"shortName\": \"GitHub_M\", \"dateUpdated\": \"2025-03-31T19:38:12.235Z\"}}}",
      "cveMetadata": "{\"cveId\": \"CVE-2025-31124\", \"state\": \"PUBLISHED\", \"dateUpdated\": \"2025-03-31T22:26:39.989Z\", \"dateReserved\": \"2025-03-26T15:04:52.626Z\", \"assignerOrgId\": \"a0819718-46f1-4df5-94e2-005712e83aaa\", \"datePublished\": \"2025-03-31T19:38:12.235Z\", \"assignerShortName\": \"GitHub_M\"}",
      "dataType": "CVE_RECORD",
      "dataVersion": "5.1"
    }
  }
}


Log in or create an account to share your comment.




Tags
Taxonomy of the tags.


Loading…

Loading…

Loading…

Sightings

Author Source Type Date

Nomenclature

  • Seen: The vulnerability was mentioned, discussed, or seen somewhere by the user.
  • Confirmed: The vulnerability is confirmed from an analyst perspective.
  • Exploited: This vulnerability was exploited and seen by the user reporting the sighting.
  • Patched: This vulnerability was successfully patched by the user reporting the sighting.
  • Not exploited: This vulnerability was not exploited or seen by the user reporting the sighting.
  • Not confirmed: The user expresses doubt about the veracity of the vulnerability.
  • Not patched: This vulnerability was not successfully patched by the user reporting the sighting.


Loading…

Loading…