Random Number Generator
PoolTogether has abstracted the generation of random numbers by creating a request-based Random Number Generator interface.
It functions like so:
The user will first get the request fee. The fee will be expressed using an (address, amount) pair representing the required ERC20 and amount.
The user will then approve the RNG to spend that ERC20 of the amount
The user will then request the random number. The RNG will transfer the cost into itself and begin the request. The request returns a request identifier.
The user may check to see if the random number is available using the identifier.
When the random number is available the user may retrieve it with the identifier.
Let's look at these functions in detail.
Get the Request Fee
Many RNG services require tokens in order to operate. To get the cost of the rng you may do so using:
This function returns two values:
feeToken: the ERC20 that needs to be paid
requestFee: is the amount of the token that needs to be paid
Request a Random Number
Once the user has approved the RNG service spend, they may request a random number like so:
This function returns two values:
requestId: the unique id for this RNG request
lockBlock: the commitment block for this RNG request. Users of the RNG request shouldn't make any changes after the lockBlock, otherwise the RNG may be less secure. For example, the Prize Strategy will lock all ticket sales and movements after the lockBlock, as they affect the winner selection. Once the request is complete the Prize Strategy unlocks tickets.
Check if Request is Complete
The user may check if a request is complete:
Retrieve Random Number
Last updated
Was this helpful?