lucapuddu / php-provably-fair
PhpProvablyFair is a library that generates and verifies provably fair games.
Installs: 3 334
Dependents: 0
Suggesters: 0
Security: 0
Stars: 14
Watchers: 2
Forks: 3
Open Issues: 0
Requires
- php: ^7.2|^8.0
- ext-bcmath: *
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.15
- phpunit/phpunit: ^8
- squizlabs/php_codesniffer: ^3.5
README
This library provides functions to generate and verify provably fair games.
Installation
Via Composer
composer require lucapuddu/php-provably-fair
The algorithm
Parameters values used in this example
$algorithm = 'sha256'; $serverSeed = 'server seed'; $clientSeed = 'client seed'; $nonce = '1'; $min = 15; $max = 96;
Steps
- 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.
Usage
Create a ProvablyFair
Object
$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();
Default values
$algorithm = 'sha512/256';
$min = 0;
$max = 100;
Get the full list of supported algorithms here.
Roll a number
... $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
Verify a roll
...
$generator->verify(38.325308655221); // true
Security
If you discover any security related issues, please use the issue tracker on github or email me at info__at__lucapuddu.com
Authors
License
MIT. Please see the license file for more information.