CVE-2022-41933 – org.xwiki.platform:xwiki-platform-security-authentication-default
Package
Manager: maven
Name: org.xwiki.platform:xwiki-platform-security-authentication-default
Vulnerable Version: >=13.1rc1 <13.10.8 || >=14.0.0 <14.4.3
Severity
Level: Medium
CVSS v3.1: CVSS:3.1/AV:N/AC:L/PR:H/UI:R/S:C/C:H/I:N/A:N
CVSS v4.0: CVSS:4.0/AV:N/AC:L/AT:N/PR:H/UI:P/VC:H/VI:N/VA:N/SC:N/SI:N/SA:N
EPSS: 0.001 pctl0.28361
Details
Plaintext storage of password after a reset in org.xwiki.platform:xwiki-platform-security-authentication-default ### Impact We discovered that when the reset a forgotten password feature of XWiki was used, the password was then stored in plain text in database. This only concerns XWiki 13.1RC1 and next versions. Note that it only concerns the reset password feature available from the "Forgot your password" link in the login view: the features allowing a user to change their password, or for an admin to change a user password are not impacted. This vulnerability is particularly dangerous in combination with other vulnerabilities allowing to perform data leak of personal data from users, such as https://github.com/xwiki/xwiki-platform/security/advisories/GHSA-599v-w48h-rjrm. Note that this vulnerability only concerns the users of the main wiki: in case of farms, the users registered on subwiki are not impacted thanks to a bug we discovered when investigating this. ### Patches The problem has been patched in version 14.6RC1, 14.4.3 and 13.10.8. The patch involves a migration of the impacted users as well as the history of the page, to ensure no password remains in plain text in the database. This migration also involves to inform the users about the possible disclosure of their passwords: by default, two emails are automatically sent to the impacted users. A first email to inform about the possibility that their password have been leaked, and a second email using the reset password feature to ask them to set a new password. See below for the configuration options to disable the mail sending. The first email contains by default the following text (could be translated depending on the wiki language settings): ``` Subject: Important security issue Dear user, due to a bug your password was stored in plain text in our wiki. We cannot exclude that your plain text password was exposed in a data leak. Therefore, you might receive a second email to choose a new password. Please contact the administrator in case of problem or for further questions. ``` It's possible to specify another text by creating a file at the root of the permanent directory named `140600000XWIKI19869-mail.txt`, this file should have same structure as used above: ``` Subject: [your custom subject] [your custom mail content] ``` This mail is sent plain text and cannot contain any variable. Note that the second mail for the reset password is using the standard feature, so you can find information about the email templates [there](https://www.xwiki.org/xwiki/bin/view/Documentation/AdminGuide/Authentication/#HMailTemplates). Also note that if the users doesn't have any registered email address obviously no mail will be sent, so it's the administrators responsibility to find a way to contact the user (through comment on the user profile, or any other channel used for that wiki). The administrator should be particularly careful on the presence of logs such as: ``` WARN WIKI19869DataMigrationListener - Reset email cannot be sent for user [reference = [xwiki:XWiki.Foo]] as no email address is provided ``` It's also possible for administrators to set some properties for the migration: it's possible to decide if the user password should be reset (default) or if the passwords should be kept but only hashed. Note that in the first option, the users won't be able to login anymore until they set a new password if they were impacted. Note that in both options, mails will be sent to users to inform them and encourage them to change their passwords. Two other properties are available to chose the behaviour regarding the mails to be sent: it's possible to chose to only send the first security email, or to only send the reset password email. It's important to note that those emails are sent after the migration during the initialization of the wiki, by reading a file creating by the migration in the permanent directory (the file is named `140600000XWIKI19869DataMigration-users.txt`): then it's possible for an administrator to chose to not sent any email when the migration is performed (by setting the properties to false), and to send them later in a future restart by then setting back the properties to true before the restart of the wiki. Also note that the file is deleted after the mails are sent. The mentioned properties can be found in `xwiki.properties` in the `[Security]` section: ``` #-# [Since 14.6RC1] #-# [Since 14.4.3] #-# [Since 13.10.8] #-# This option is only used when performing a migration from a wiki before the versions mentioning above. #-# This parameter defines if as part of the migration R140600000XWIKI19869 the passwords of impacted user should be #-# reset or not. It's advised to keep this value as true, now for some usecases advertised administrators might want #-# their users to keep their passwords nevertheless, then enable the configuration and set it to false before the #-# migration is executed. # security.migration.R140600000XWIKI19869.resetPassword = true #-# [Since 14.6RC1] #-# [Since 14.4.3] #-# [Since 13.10.8] #-# This option is only used when performing a migration from a wiki before the versions mentioned above. #-# This parameter defines if reset password emails should be sent as part of the migration R140600000XWIKI19869. #-# By default this value is set to true, so emails will be automatically produced. Now it's possible for admin to set #-# this option to false: note that in such case a file containing the list of users for whom a reset password email #-# should be sent will still be created in the permanent directory (named 140600000XWIKI19869DataMigration-users.txt). #-# If this file exists and this property is set back to true after the migration, the file will still be consumed to #-# send the emails, so it's possible to perform the migration and send the emails only later if needed. # security.migration.R140600000XWIKI19869.sendResetPasswordEmail = true #-# [Since 14.6RC1] #-# [Since 14.4.3] #-# [Since 13.10.8] #-# This option is only used when performing a migration from a wiki before the versions mentioned above. #-# #-# This parameter defines if a security email information should be sent as part of the migration R140600000XWIKI19869. #-# By default this value is set to true, so emails will be automatically
Metadata
Created: 2022-11-21T22:37:11Z
Modified: 2022-12-03T04:09:18Z
Source: https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2022/11/GHSA-q2hm-2h45-v5g3/GHSA-q2hm-2h45-v5g3.json
CWE IDs: ["CWE-312", "CWE-522"]
Alternative ID: GHSA-q2hm-2h45-v5g3
Finding: F020
Auto approve: 1