1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
<?php namespace Spline\Cachet\Hashing;
use Illuminate\Hashing\BcryptHasher;
class SplineHasher extends BcryptHasher {
/**
* Check the given plain value against a hash.
*
* @param string $value
* @param string $hashedValue
* @param array $options
* @return bool
*/
public function check($value, $hashedValue, array $options = array())
{
if (starts_with($hashedValue, '{')) {
if (starts_with($hashedValue, '{SSHA}')) {
$hash = base64_decode(substr($hashedValue, 6));
$salt = substr($hash, 20);
if ((pack("H*", sha1($value.$salt)).$salt) == $hash) {
return true;
}
}
elseif (starts_with($hashedValue, '{SMD5}')) {
$hash = base64_decode(substr($hashedValue, 6));
$salt = substr($hash, 16);
if ((md5($value.$salt, true).$salt) == $hash) {
return true;
}
}
elseif (starts_with(strtolower($hashedValue), '{crypt}')) {
$hash = substr($hashedValue, 7);
if (password_verify($value, $hash)) {
return true;
}
}
return false;
}
return parent::check($value, $hashedValue, $options);
}
/**
* Check if the given hash has been hashed using the given options.
*
* @param string $hashedValue
* @param array $options
* @return bool
*/
public function needsRehash($hashedValue, array $options = array())
{
if (starts_with($hashedValue, '{')) {
return false;
}
return parent::needsRehash($hashedValue, $options);
}
}
|