This library provides functions to generate and verify provably fair games.
Via Composer
composer require lucapuddu/php-provably-fair
$algorithm = 'sha256';
$serverSeed = 'server seed';
$clientSeed = 'client seed';
$nonce = '1';
$min = 15;
$max = 96;
- A hexadecimal string of variable length (depending on the algorithm used) is computed with hash_hmac. The function
uses the
$serverSeed
as key, and the$clientSeed
and$nonce
as data, concatenated with an hyphen:
$output1 = hash_hmac($algorithm, "{$clientSeed}-{$nonce}", $serverSeed);
echo $output1; // 78ed9330f00055f15765cb141088f316d507204a745ad4800fd719fcbfca071a
$output1
is then scaled to a number from0
to1
, by converting it to an integer number and then dividing it by the maximum result possible (which is equal to16 ^ length of $output1
)
$output2 = hexdec($output1) / (16 ** strlen($output1));
echo $output2; // 0.47237510628475
$output2
is scaled accordingly tomin
andmax
:
$result = $min + $output2 * ($max - $min);
echo $result; // 53.26238360906475
- The result is returned.
$algorithm = 'sha256';
$serverSeed = 'server seed';
$clientSeed = 'client seed';
$nonce = 'nonce';
$min = 23.75;
$max = 44;
$generator = Builder::make()
->algorithm($algorithm)
->serverSeed($serverSeed)
->clientSeed($clientSeed)
->nonce($nonce)
->range($min, $max)
->build();
$algorithm = 'sha512/256';
$min = 0;
$max = 100;
Get the full list of supported algorithms here.
...
$output = $generator->roll();
echo $output; //38.325308655221
// Change ProvablyFair state
$generator->setNonce('new nonce');
// Roll a new number
$output = $generator->roll();
echo $output; //23.752100169784
...
$generator->verify(38.325308655221); // true
If you discover any security related issues, please use the issue tracker on github or email me at info__at__lucapuddu.com
MIT. Please see the license file for more information.