2010-12-05 00:18:19 +00:00
|
|
|
<?php
|
2016-06-23 11:37:22 +12:00
|
|
|
|
|
|
|
namespace SilverStripe\Security;
|
|
|
|
|
2017-05-19 11:18:56 +01:00
|
|
|
use Error;
|
2016-06-23 11:37:22 +12:00
|
|
|
use Exception;
|
|
|
|
|
2010-12-05 00:18:19 +00:00
|
|
|
/**
|
2017-05-19 11:18:56 +01:00
|
|
|
* Convenience class for generating cryptographically secure pseudo-random strings/tokens
|
2010-12-05 00:18:19 +00:00
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
class RandomGenerator
|
|
|
|
{
|
|
|
|
/**
|
2017-05-19 11:18:56 +01:00
|
|
|
* @return string A 128-character, randomly generated ASCII string
|
|
|
|
* @throws Exception If no suitable CSPRNG is installed
|
2016-11-29 12:31:16 +13:00
|
|
|
*/
|
|
|
|
public function generateEntropy()
|
|
|
|
{
|
2017-05-19 11:18:56 +01:00
|
|
|
try {
|
2016-12-29 23:46:08 +13:00
|
|
|
return bin2hex(random_bytes(64));
|
2017-05-19 11:18:56 +01:00
|
|
|
} catch (Error $e) {
|
|
|
|
throw $e; // This is required so that Error exceptions in PHP 5 aren't caught below
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw new Exception(
|
|
|
|
'It appears there is no suitable CSPRNG (random number generator) installed. '
|
|
|
|
. 'Please review the server requirements documentation: '
|
|
|
|
. 'https://docs.silverstripe.org/en/getting_started/server_requirements/'
|
|
|
|
);
|
2016-12-29 23:46:08 +13:00
|
|
|
}
|
2016-11-29 12:31:16 +13:00
|
|
|
}
|
2012-11-08 16:33:19 +13:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
/**
|
|
|
|
* Generates a random token that can be used for session IDs, CSRF tokens etc., based on
|
|
|
|
* hash algorithms.
|
|
|
|
*
|
|
|
|
* If you are using it as a password equivalent (e.g. autologin token) do NOT store it
|
|
|
|
* in the database as a plain text but encrypt it with Member::encryptWithUserSettings.
|
|
|
|
*
|
2017-05-19 11:18:56 +01:00
|
|
|
* @param string $algorithm Any identifier listed in hash_algos() (Default: whirlpool)
|
|
|
|
* @return string Returned length will depend on the used $algorithm
|
2016-11-29 12:31:16 +13:00
|
|
|
*/
|
|
|
|
public function randomToken($algorithm = 'whirlpool')
|
|
|
|
{
|
|
|
|
return hash($algorithm, $this->generateEntropy());
|
|
|
|
}
|
2012-11-08 16:33:19 +13:00
|
|
|
}
|