首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Chainlink VRF中获取历史随机数的最佳实践是什么?

在Chainlink VRF中获取历史随机数的最佳实践是什么?
EN

Stack Overflow用户
提问于 2022-06-16 04:31:55
回答 1查看 97关注 0票数 0

在这个项目中,我依赖Chainlink VRF获得一个随机的单词来决定抽奖获胜者,但是我没有在我的VRF订阅中保持最小的链路平衡,所以所有的请求都被挂起。(我认为事务发送不成功,所以我错误地多次调用该函数)。

在我将一些链接令牌传输到我的VRF订阅后,所有随机数都被发送到我的合同中。在这种情况下,我只需要这些随机词中的第一个进行抽奖,但我不确定存储在智能契约中的随机词现在是否是第一个。

如果基于随机词的事务由于某种原因没有成功,那么在历史上哪里可以找到随机词,以便这些事务能够被重新发送?

所以我的问题是:

获得由Chainlink VRF生成的历史随机词的最佳实践是什么?

提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-06-23 02:10:38

在做了一些研究之后,我会回答这个问题。

最佳实践是在智能契约中的数组中保留随机单词,或者在消费智能契约中添加fulfillment函数中的事件来记录requestId和相应的随机单词。

但是,如果在智能契约中没有事件或其他变量记录随机单词,则可以执行以下操作:

  1. 在智能契约VRFCoordinatorV2中从事件RandomWordsFulfilled中获取requestId和随机性,可以在VRF节点.

发送的事务中找到。

代码语言:javascript
复制
emit RandomWordsFulfilled(requestId, randomness, payment, success);

  1. VRFCoordinatorV2智能契约中的EventRandomWordsRequested获取numWords。

代码语言:javascript
复制
    emit RandomWordsRequested(
      keyHash,
      requestId,
      preSeed,
      subId,
      requestConfirmations,
      callbackGasLimit,
      numWords,
      msg.sender
    );

  1. 随机词是由SmartContractVRFCoordinatorV2中的函数fulfillRandomWords中定义的以下逻辑中的随机性和numWords生成的。您可以使用相同的逻辑获取历史随机词。

代码语言:javascript
复制
for (uint256 i = 0; i < numWords; i++) {
  randomWords[i] = uint256(keccak256(abi.encode(randomness, i)));
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72640487

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档