mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-08 04:18:52 +00:00
[ticket/17351] Correctly handle md5 passwords rehashing
PHPBB-17351
This commit is contained in:
parent
3647cf2cfe
commit
e5d2e82ef5
2 changed files with 18 additions and 2 deletions
|
@ -100,7 +100,15 @@ class update_hashes extends \phpbb\console\command\command
|
||||||
while ($row = $this->db->sql_fetchrow($result))
|
while ($row = $this->db->sql_fetchrow($result))
|
||||||
{
|
{
|
||||||
$old_hash = preg_replace('/^\$CP\$/', '', $row['user_password']);
|
$old_hash = preg_replace('/^\$CP\$/', '', $row['user_password']);
|
||||||
$new_hash = $this->passwords_manager->hash($old_hash, array($this->default_type));
|
|
||||||
|
// If stored hash type is unknown then it's md5 hash with no prefix
|
||||||
|
// First rehash it using $H$ as hash type identifier (salted_md5)
|
||||||
|
if (!$this->passwords_manager->detect_algorithm($old_hash))
|
||||||
|
{
|
||||||
|
$old_hash = $this->passwords_manager->hash($old_hash, '$H$');
|
||||||
|
}
|
||||||
|
|
||||||
|
$new_hash = $this->passwords_manager->hash($old_hash, [$this->default_type]);
|
||||||
|
|
||||||
$sql = 'UPDATE ' . USERS_TABLE . "
|
$sql = 'UPDATE ' . USERS_TABLE . "
|
||||||
SET user_password = '" . $this->db->sql_escape($new_hash) . "'
|
SET user_password = '" . $this->db->sql_escape($new_hash) . "'
|
||||||
|
|
|
@ -107,7 +107,15 @@ class update_hashes extends \phpbb\cron\task\base
|
||||||
while ($row = $this->db->sql_fetchrow($result))
|
while ($row = $this->db->sql_fetchrow($result))
|
||||||
{
|
{
|
||||||
$old_hash = preg_replace('/^\$CP\$/', '', $row['user_password']);
|
$old_hash = preg_replace('/^\$CP\$/', '', $row['user_password']);
|
||||||
$new_hash = $this->passwords_manager->hash($old_hash, array($this->default_type));
|
|
||||||
|
// If stored hash type is unknown then it's md5 hash with no prefix
|
||||||
|
// First rehash it using $H$ as hash type identifier (salted_md5)
|
||||||
|
if (!$this->passwords_manager->detect_algorithm($old_hash))
|
||||||
|
{
|
||||||
|
$old_hash = $this->passwords_manager->hash($old_hash, '$H$');
|
||||||
|
}
|
||||||
|
|
||||||
|
$new_hash = $this->passwords_manager->hash($old_hash, [$this->default_type]);
|
||||||
|
|
||||||
// Increase number so we know that users were selected from the database
|
// Increase number so we know that users were selected from the database
|
||||||
$affected_rows++;
|
$affected_rows++;
|
||||||
|
|
Loading…
Add table
Reference in a new issue