比特币:金色观察|Wyvern:1阶去中心化交换协议

Wyvern是1阶去中心化交换协议。对比其他协议,例如Etherdelta、0x和Dexy是0阶的,也就是每个订单指定两个去中心化资产的交易。

而Wyvern将订单改为指定状态转换的谓词,也就是将订单定义为一个函数,将制造商的调用、交易对手的调用以及订单元数据映射为布尔值。以太坊上可表示的任何资产或资产的任何组合都可以通过Wyvern订单进行交换。

这样设计,可以表达任何更简单协议可以表达的命令,也可以优化gas,减少无用的调用,因组成协议组件被隔离,也有利于安全。

但也因为定义过细,对开发人员不友好,并且难以支持用户级工具。

因此,Wyvern后期发布了v3版本没,重组了协议的几个核心组件,使部署Wyvern的分布式账本的用户能够自由交易。

上海:给予“元宇宙”领域招商项目不超过项目投资30%的资金支持:金色财经报道,上海市人民政府办公厅印发《关于新时期强化投资促进加快建设现代化产业体系的政策措施》的通知。措施提出,围绕“元宇宙”基础设施、交互终端、数字工具等领域开展招商引资,开放50个以上市级重大元宇宙应用场景对外招商,持续开展供需对接和揭榜挂帅,加快引进三维图形、图像引擎、数字建模等“元宇宙”项目。加大“元宇宙”领域招商项目支持力度,对引进符合条件的关键技术、重点工程和产业化项目,按照规定给予不超过项目投资的30%、最高2000万元的支持。[2023/4/25 14:25:31]

以下是Wyvern的协议功能:

断言注册表

比特币矿企Hut 8 Mining 1月共产出188枚比特币:金色财经报道,比特币矿企Hut 8 Mining公布2023年1月运营进展,2023年1月Hut 8共产出188枚比特币,截至1月31日共持有9274枚比特币。Hut 8表示,预计将出售1月产出的比特币来支付运营成本。(PR News Wire)[2023/2/13 12:04:18]

订单生成者可以检查他们和他们的交易对手是否使用有效的注册表。

断言calldata

订单中的大部分逻辑是在调用和反向调用上构造谓词。每个订单的静态回调接收调用、交易对手调用和订单元数据的所有参数,并且必须决定是否允许订单匹配,如果允许,填写多少。

以太坊地址总数突破2.5亿个:金色财经报道,据OKlink数据显示,以太坊地址总数已突破2.5亿个,本文撰写是为254,421,836个,过去24小时增加71,489个,其中普通地址数203,492,770个,持币地址数86,487,304个,活跃地址数526,457个。此外,以太坊合约地址数已超过5000万,截至目前为50,929,035个。[2022/9/14 13:28:06]

Call

第一次调用由订单制造者通过他们的代理合约执行。静态回调接收所有参数,调用目标、调用类型和调用数据等,并且必须验证调用是制造商愿意执行的调用。

Countercall

乌克兰两大科技零售巨头Techno ?zhak和Stylus开始接受比特币支付:9月4日消息,乌克兰两家最大的科技零售商Techno ?zhak和Stylus现在已经开始接受比特币作为一种支付形式。这两家科技零售巨头将允许客户用比特币支付商品和服务。报道称,该公司将使用支付服务提供商Whitepay,作为公司在客户和商家之间的中间人。Whitepay是欧洲加密货币交易所WhiteBIT的子公司。

客户将可以在网上和实体店使用比特币支付。两家科技公司的实体店共有100多家零售店。亲自支付的客户将可以使用Whitepay的定制销售点系统,该系统会向商家提供二维码来记录交易。二维码将包括当前汇率的信息,以及在网络上完成交易所需的时间。

此前报道,今年早些时候,乌克兰总统Volodymyr Zelensky签署了一项关于虚拟货币法案,为比特币在该国经济中运行提供了法律框架。(Cryptoglobe)[2022/9/4 13:08:14]

第二次调用由交易对手执行,为方便起见,在源代码中将其称为“countercall”。静态回调接收所有参数,有countercall目标、countercall类型和countercall数据,并且必须验证调用是制造商愿意接受以换取他们自己的调用。

断言状态

静态调用在调用之后执行,因此可以断言特定状态已更改,而不是断言调用数据的属性。

元数据

元数据包含挂单时间、挂单到期时间、反挂单挂单时间、调用中转入的ETH、当前订单成交值和匹配地址。

广义部分填充

订单签署最大成交,静态调用返回一个uint,如果订单匹配,它指定更新的成交值。订单的当前执行也可以由订单的制造者通过交易手动设置。将订单的成交设置为非零值也会隐式授权订单,因为部分成交订单的授权被缓存以避免不必要的签名检查。

授权订单

订单必须始终由地址授权,该地址拥有将执行调用的代理合约。授权可以通过三种方式完成:签名消息、预先批准和比赛时间批准。

签名消息

授权订单的最常见方法是在链下对订单哈希进行签名。这是无成本的,任何数量的订单都可以被签名、存储、索引,也许还可以在网站或自动订单簿上列出。为了避免取消不再需要的订单的必要性,制造商可以在不久的将来签署到期时间的订单,并且只要他们希望继续征求交易,就可以重新签署新订单。

预先批准

可以通过向合约发送交易来授权订单。这种方法可能对由智能合约构建的订单特别感兴趣,智能合约本身不能在链下签署消息。链上授权会发出一个事件,该事件可以很容易地被希望将订单包含在其数据库中的订单簿索引。

当有即时构建订单匹配时,通过从订单地址发送匹配交易进行授权。如果制造者打算自己发送与订单匹配的交易,会很方便,且可以节省一点gas。

构造匹配的调用数据

匹配的调用数据可以以任何方式链下构建。协议并不关心最终的calldata是如何获得的,只关心它完成了订单的谓词功能。在实践中,订单簿维护者可能会存储额外的元数据以及订单,这些订单可用于构建可能的匹配调用数据。

不对称

在可能的范围内,该协议被设计为对称的,这样订单不需要在任何特定的“边”上,并限制自己与另一“边”上的订单匹配。

第一个不对称是排序。必须首先执行一个调用,执行该调用可能会更改第二个调用的结果。传入的第一个调用首先执行。

第二个不对称是特殊情况下的以太币。由于以太坊的设计限制,以太币与ERC20代币不同,只能通过来自该账户的交易从一个账户发送。为了便于使用,Wyvern尽可能支持特殊情况的ETH:订单的匹配者可以选择将值与匹配交易一起传递,然后将其传递给交易对手并作为参数传递给谓词函数。

Wyvernv3的更改

订单不能自行匹配。但来自同一制造商的两个单独的订单可以相互匹配。

利用双向调用匹配提供的额外表达能力,Wyvernv3将协议的几乎所有辅助方面“推出”到订单上,而不是在交换合约中实现它们,以降低了协议的复杂性,为用户和中继者提供灵活性,并降低gas成本。

来源:金色财经

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

地球链

[0:15ms0-0:931ms