Search
VRF v2 replaces and enhances VRF v1.
See the VRF v2 documentation to learn more.
API reference for VRFConsumerBase
.
Name | Description |
---|---|
constructor | Initialize your consumer contract. |
Name | Description |
---|---|
requestRandomness | Make a request to the VRFCoordinator. |
fulfillRandomness | Called by VRFCoordinator when it receives a valid VRF proof. |
Initialize your consumer contract.
constructor(address _vrfCoordinator, address _link) public
_vrfCoordinator
: Address of the Chainlink VRF Coordinator. See Chainlink VRF Addresses for details._link
: Address of the LINK token. See LINK Token Addresses for details.Note:
_seed
has recently been deprecated.
Make a request to the VRF coordinator.
function requestRandomness(bytes32 _keyHash, uint256 _fee)
public returns (bytes32 requestId)
_keyHash
: The public key against which randomness is generated. See Chainlink VRF Addresses for details._fee
: The fee, in LINK, for the request. Specified by the oracle.RETURN
: The ID unique to a single request.Called by VRFCoordinator when it receives a valid VRF proof. Override this function to act upon the random number generated by Chainlink VRF.
function fulfillRandomness(bytes32 requestId, uint256 randomness)
internal virtual;
requestId
: The Id initially returned by requestRandomness
.randomness
: Random number generated by Chainlink VRF.Chainlink VRF provides powerful security guarantees and is easy to integrate. However, smart contract security is a nuanced topic. You can read about the top security considerations for VRF.