- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要获取代币从特定时间到最近一轮的 Chainlink 价格。此时间因用户输入而异,但会根据 token 的心跳相对较短的窗口(最多 1 天到 2 周)。这用于计算智能合约和应用程序主页上的支出价格。
要获取历史价格数据,Chainlink 需要一个“roundId”,它是一个非增量值。
从 Chainlink 获取给定时间窗口的所有 roundId 或以开放、去中心化且可在 solidity 智能合约中访问的方式记录它们的最佳方式是什么?
最佳答案
Chainlink 喂价的每个代理合约都可以有多个基础聚合器合约,其中一个在任何给定实例中都被设置为“事件”合约。即,每当 Chainlink Labs 团队部署新版本的聚合器时,他们都会更新代理合约以将当前聚合器版本设置为新版本,并且所有新价格数据开始写入新聚合器。
基于此,如果您想要过去几周左右的代理合约/价格对的历史价格数据,您需要转到代理合约的当前聚合器,然后获取当前回合信息 (包括时间戳),然后返回到循环中的聚合器回合,直到您到达小于搜索参数时间戳的回合。
要查找代理合约的当前聚合器合约地址,您可以调用代理合约中的aggregator
getter 函数。
阶段 ID 可以被认为是一个递增的 ID 号,代理合约使用它来识别每个聚合器,因为它被添加到代理,所以第一个是 1,第二个是 2 等等。找出当前的是什么phase ID 是当前聚合器的,您可以在代理合约中使用 phaseId getter 函数。
Aggregator 轮次 ID 从 1 开始,每次增加 1。例如,您可以使用聚合器 latestRound
getter 函数找到它存储的最后一轮,然后从该数字开始作为 getRoundData
的输入参数,然后减少数字逐一循环,直到到达您的时间点。
与聚合器轮次 ID 不同,代理轮次 ID 是那些非常长的大数字,例如 36893488147419113293
,实际上只是基于聚合器阶段 ID 和聚合器轮次 ID 的派生值。这样做是为了确保代理轮 ID 的值始终在增加,并且不同聚合器的相同轮之间永远不会有任何重叠,例如,来自阶段 ID 1 的聚合器的第 5000 轮应该具有比第 5000 轮更低的代理轮 ID来自具有阶段 ID 2 的聚合器
在 Solidity 中,您可以使用以下公式轻松复制代理轮 ID 派生值,传入聚合器的阶段 ID 和聚合器轮 ID
return uint80(uint256(_phaseId) << 64 | _aggregatorRoundId);
您甚至可以获取该派生值并将其传递给代理合约 getRoundData
函数,并获得与在聚合器合约中调用 getRoundData
相同的数据结果给定聚合器回合 ID。
我发现一个玩转这些的好方法是直接在 etherescan 上与函数交互,并查看返回的数据。即这里是 Kovan ETH/USD proxy及其 latest aggregator
关于第二个问题的答案,最好的方法是从“现在”开始,即获取最新的聚合器,获取聚合器中的最新一轮,然后通过将聚合器轮 ID 减 1 来及时返回,并且继续获取定价信息,直到回合时间戳为<您的搜索时间戳。
最后,Solidity 中的循环不是很省油。您可以采用的另一种方法是将外部计算卸载到预言机,预言机可以为您提供正确的回合 ID,然后您可以使用它并在链上验证结果。 Here's an example该设计模式以外部适配器的形式出现,可根据时间戳检索历史价格数据。在 Kovan 上也有一个实时版本,查看自述文件以获取更多信息
关于blockchain - 以去中心化方式从 Chainlink 获取代币历史价格数据的最佳方式是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70377502/
我需要一些帮助。 我希望“总计”由“数量*价格=总计”计算(到目前为止没问题)。问题是我还需要通过“总/价格=数量”来计算“数量”,即如果一个字段发生更改,另一个字段也会自动更改。 我做了一个非常简单
我试图将每件商品的数量和价格相乘来计算总数,但我的警报中出现错误。 $.each(data.items, function(index, d){ var calcultest = d.pric
我想获得格式化的价格但没有货币符号,我只想使用 magento 的标准功能! $product->getFinalPrice(); => 19.9900 Mage::helper('core')->f
我正在尝试获取特定月份和年份中所有父类别的总价格。父类别是 parent_id == 0 的任何类别。我的查询如下所示: SELECT ROUND(SUM(od.total_price)) a
请帮我摆脱我的头痛..提前我为我的糟糕语言道歉,无论是英语还是mysql。希望有人能理解这个问题..:) 我有一个数据库,任何人都可以记录各个商店中各种产品的价格。以下查询是一个半理论示例,可能根本不
下面是我需要在数据库中设计的示例: 会有一个价格选项,如果有的话,会有一个特价选项,然后我想知道如果我希望其中一个选项是“免费”的,我该怎么做。 另请参阅根据所在国家/地区会有不同的货币。这是我的想法
商品价格格式 999,99 999 - 1 ..4 digits , - comma sign marks decimal point 99 - 2 digits after price Postg
我有这个表 stk +---------+--------------+ | Field | Type | +---------+--------------+ | id
是否有一个简单的格式化程序可以将我的字符串格式化为价格? 所以我的字符串是:300000 我想用空格来“300 000” or 1000000 "1 000 000" 张国荣 最佳答案 这样做: St
我想知道是否可以使用不依赖于 Excel 应用程序本地化(欧盟/美国)的 Excel 公式来自定义数字格式? 例如,我的值为 1291660。 然后使用公式=TEXT(A1;"# ##0,00") .
这是我的代码,对于价格 slider : $("#price-slider").ionRangeSlider({ min: 130, max: 575, onChange :
用户可以使用价格创建一个新实体。价格可以使用不同的货币(EUR,USD ...),因此我们可以乘以(price * convert_rate)得到实际价格。 我想做的是根据价格过滤记录,具体取决于前端
我正在尝试隐藏小数位在类型输入字段上,例如 数字从0.00开始 因此,输入字段中的第一个位置将为 0.00 我输入的1比它应该变成0.01 我输入的2比它应该变成0.12 比 0 所以它应该变成 1.
$res=mysql_query($qry); while($row= mysql_fetch_array($res)) { echo "".$row['Food_Name']." ".$row['P
我们正在为我们的新项目寻找信用卡网关。那里一片困惑,所有人都想把你切成碎片。每次我与他们交谈时,他们都有不同的费率,每次更新报价时,他们都会更改一些价格。 我们正在使用 .net、C#、asp.net
我已经创建了一个 jQuery 价格 slider ,但我不确定如何让过滤区域以实际价格范围开始?目前它有“$[object Object] - $[object Object]”,而我希望它有“$2
我已经创建了 jquery 价格 slider ,但我不确定如何过滤我的结果,以便在滑动时您只能看到具有该值范围内的产品。 HTML: Price range:
我有一个页面,其中有一个表格,我们可以在其中选择一个产品,输入它的数量和价格,然后应在最后一列中计算金额,并应添加新行以输入更多产品,直到我们完成为止。
我创建了电子商务网站,即将提供午餐和晚餐服务。我在这里提出问题/问题是因为我知道这里有很多可以帮助我的传奇人物。我在网站上添加了套餐/计划部分。 1. Weekly 2. Monthly 以下是订
我的网站需要一个简单的 jQuery 价格 slider 。从 0 英镑到 1000 英镑不等。 假设浏览器将 slider 设置为 100 英镑(例如),然后我需要一个立即购买按钮,该按钮将 sli
我是一名优秀的程序员,十分优秀!