diff options
author | friendica <info@friendica.com> | 2012-08-21 17:48:09 -0700 |
---|---|---|
committer | friendica <info@friendica.com> | 2012-08-21 17:48:09 -0700 |
commit | 9b9f35f8e57464ead49be0a8e2aa64b0d8a6573c (patch) | |
tree | e47eff4eeb51374fa6bf5cd161ed4dfdda56612f /include/account.php | |
parent | 2f81fb438508436ad6424c53f0f2dc878969b929 (diff) | |
download | volse-hubzilla-9b9f35f8e57464ead49be0a8e2aa64b0d8a6573c.tar.gz volse-hubzilla-9b9f35f8e57464ead49be0a8e2aa64b0d8a6573c.tar.bz2 volse-hubzilla-9b9f35f8e57464ead49be0a8e2aa64b0d8a6573c.zip |
NaCl passwords - (db update)
Diffstat (limited to 'include/account.php')
-rw-r--r-- | include/account.php | 31 |
1 files changed, 28 insertions, 3 deletions
diff --git a/include/account.php b/include/account.php index 283a7a8dc..b2835b48b 100644 --- a/include/account.php +++ b/include/account.php @@ -117,14 +117,16 @@ function create_account($arr) { return $result; } - $password_encoded = hash('whirlpool',$password); + $salt = random_string(32); + $password_encoded = hash('whirlpool', $salt . $password); $r = q("INSERT INTO account - ( account_parent, account_password, account_email, account_language, + ( account_parent, account_salt, account_password, account_email, account_language, account_created, account_flags, account_roles, account_expires, account_service_class ) - VALUES ( %d, '%s', '%s', '%s', '%s', %d, %d, '%s', '%s' )", + VALUES ( %d, '%s', '%s', '%s', '%s', '%s', %d, %d, '%s', '%s' )", intval($parent), + dbesc($salt), dbesc($password_encoded), dbesc($email), dbesc(get_best_language()), @@ -159,3 +161,26 @@ function create_account($arr) { return $result; } + +/** + * Verify login credentials + * + * Returns account record on success, null on failure + * + */ + +function account_verify_password($email,$pass) { + $r = q("select * from account where email = '%s'", + dbesc($email) + ); + if(! ($r && count($r))) + return null; + foreach($r as $record) { + if(hash('whirlpool',$record['account_salt'] . $pass) === $record['account_password']) { + return $record; + } + } + return null; +} + + |