forked from science-ation/science-ation
Add password hashing upgrade script
This commit is contained in:
parent
4c4e6c4a1f
commit
3c4e0605e6
63
scripts/science-ation_db_update.php
Normal file
63
scripts/science-ation_db_update.php
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
<?
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file is part of the Science-ation project
|
||||||
|
* Science-ation Website: https://science-ation.ca
|
||||||
|
*
|
||||||
|
* This file was part of the 'Science Fair In A Box' project
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* Copyright (C) 2005 Sci-Tech Ontario Inc <info@scitechontario.org>
|
||||||
|
* Copyright (C) 2005 James Grant <james@lightbox.org>
|
||||||
|
* Copyright (C) 2024 AlgoLibre Inc. <science-ation@algolibre.io>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public
|
||||||
|
* License as published by the Free Software Foundation, version 2.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; see the file COPYING. If not, write to
|
||||||
|
* the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||||
|
* Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once ('common.inc.php');
|
||||||
|
|
||||||
|
function hash_passwords() {
|
||||||
|
global $pdo;
|
||||||
|
|
||||||
|
$q = $pdo->prepare("SELECT `id`, `password`, `oldpassword` FROM `users`");
|
||||||
|
$q->execute();
|
||||||
|
|
||||||
|
while ($r = $q->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
print_r($r);
|
||||||
|
$id = $r['id'];
|
||||||
|
|
||||||
|
$password=$r['password'];
|
||||||
|
$oldpassword=$r['oldpassword'];
|
||||||
|
|
||||||
|
if (_password_not_hashed($password)) {
|
||||||
|
$password = password_hash($r['password'], PASSWORD_BCRYPT);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_password_not_hashed($oldpassword)) {
|
||||||
|
$oldpassword = password_hash($r['oldpassword'], PASSWORD_BCRYPT);
|
||||||
|
}
|
||||||
|
|
||||||
|
$stmt = $pdo->prepare("UPDATE `users` SET `password`=?, `oldpassword`=? WHERE `id`=?");
|
||||||
|
$stmt->execute([$password, $oldpassword, $id]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function _password_not_hashed($password) {
|
||||||
|
return (password_get_info($password)['algo'] == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
hash_passwords();
|
||||||
|
|
||||||
|
?>
|
Loading…
x
Reference in New Issue
Block a user