在查看Chainlink Keepers文档时,它说您可以设置一个基于时间的守护者,这样它就可以根据CRON计划调用智能合同中的函数。
我们什么时候应该使用它而不是自定义逻辑触发器?它不要求我们的合同是兼容的,所以听起来可能更容易实现。
但是,饲养员将调用的函数是否必须是公共的,或者是否有一种方法来确保只有守护者才能调用该函数?例如,如果我有一个希望每小时运行一次的pickWinner()函数,并且不希望某个随机黑客提前调用它。
而且,基于时间的触发器是否有点效率,因为它说它部署了一份新的CronUpkeep合同来管理时间表?
发布于 2022-08-03 10:46:52
你有两个问题,第一个问题是:
在应该根据时间执行某些操作的场景中使用基于时间的触发器。例如,要每小时运行一次的函数pickWinner()。
可能还有其他一些项目,用户希望定期调用某些函数。假设您是DeFi协议的用户,您希望每小时调用claim()获取收益并进行再投资。在这种情况下,您可以创建一个基于时间的触发器并每小时调用claim()。
你的第二个问题是:
是的,你必须为你的函数写一个白名单,因为消费者合同不兼容基于时间的触发器。
Keepers将从CronUpkeep创建一个CronUpkeepFactory契约,您可以在正式文件中查看详细信息。如果您查看CronUpKeep.sol中的GitHub,您会发现合同中有performUpKeep和checkUpkeep函数。契约充当调用函数的委托,您可以根据CronUpKeep地址编写白名单。
https://ethereum.stackexchange.com/questions/132886
复制相似问题