mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-08 17:38:26 +01:00
Add safeguards for when ext/hash is not compiled with PHP.
see #29518, for trunk. Built from https://develop.svn.wordpress.org/trunk@29751 git-svn-id: http://core.svn.wordpress.org/trunk@29523 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
2008fc0c89
commit
75ff6ae302
@ -669,7 +669,10 @@ function wp_validate_auth_cookie($cookie = '', $scheme = '') {
|
|||||||
$pass_frag = substr($user->user_pass, 8, 4);
|
$pass_frag = substr($user->user_pass, 8, 4);
|
||||||
|
|
||||||
$key = wp_hash( $username . '|' . $pass_frag . '|' . $expiration . '|' . $token, $scheme );
|
$key = wp_hash( $username . '|' . $pass_frag . '|' . $expiration . '|' . $token, $scheme );
|
||||||
$hash = hash_hmac( 'sha256', $username . '|' . $expiration . '|' . $token, $key );
|
|
||||||
|
// If ext/hash is not present, compat.php's hash_hmac() does not support sha256.
|
||||||
|
$algo = function_exists( 'hash' ) ? 'sha256' : 'sha1';
|
||||||
|
$hash = hash_hmac( $algo, $username . '|' . $expiration . '|' . $token, $key );
|
||||||
|
|
||||||
if ( ! hash_equals( $hash, $hmac ) ) {
|
if ( ! hash_equals( $hash, $hmac ) ) {
|
||||||
/**
|
/**
|
||||||
@ -734,7 +737,10 @@ function wp_generate_auth_cookie( $user_id, $expiration, $scheme = 'auth', $toke
|
|||||||
$pass_frag = substr($user->user_pass, 8, 4);
|
$pass_frag = substr($user->user_pass, 8, 4);
|
||||||
|
|
||||||
$key = wp_hash( $user->user_login . '|' . $pass_frag . '|' . $expiration . '|' . $token, $scheme );
|
$key = wp_hash( $user->user_login . '|' . $pass_frag . '|' . $expiration . '|' . $token, $scheme );
|
||||||
$hash = hash_hmac( 'sha256', $user->user_login . '|' . $expiration . '|' . $token, $key );
|
|
||||||
|
// If ext/hash is not present, compat.php's hash_hmac() does not support sha256.
|
||||||
|
$algo = function_exists( 'hash' ) ? 'sha256' : 'sha1';
|
||||||
|
$hash = hash_hmac( $algo, $user->user_login . '|' . $expiration . '|' . $token, $key );
|
||||||
|
|
||||||
$cookie = $user->user_login . '|' . $expiration . '|' . $token . '|' . $hash;
|
$cookie = $user->user_login . '|' . $expiration . '|' . $token . '|' . $hash;
|
||||||
|
|
||||||
|
@ -61,7 +61,12 @@ abstract class WP_Session_Tokens {
|
|||||||
* @return string A hash of the session token (a verifier).
|
* @return string A hash of the session token (a verifier).
|
||||||
*/
|
*/
|
||||||
final private function hash_token( $token ) {
|
final private function hash_token( $token ) {
|
||||||
|
// If ext/hash is not present, use sha1() instead.
|
||||||
|
if ( function_exists( 'hash' ) ) {
|
||||||
return hash( 'sha256', $token );
|
return hash( 'sha256', $token );
|
||||||
|
} else {
|
||||||
|
return sha1( $token );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user