Wyvern是1阶去中心化交换协议。对比其他协议,例如Etherdelta、0x和Dexy是0阶的,也就是每个订单指定两个去中心化资产的交易。
而Wyvern将订单改为指定状态转换的谓词,也就是将订单定义为一个函数,将制造商的调用、交易对手的调用以及订单元数据映射为布尔值。以太坊上可表示的任何资产或资产的任何组合都可以通过Wyvern订单进行交换。
这样设计,可以表达任何更简单协议可以表达的命令,也可以优化gas,减少无用的调用,因组成协议组件被隔离,也有利于安全。
但也因为定义过细,对开发人员不友好,并且难以支持用户级工具。
因此,Wyvern后期发布了v3版本,重组了协议的几个核心组件,使部署 Wyvern 的分布式账本的用户能够自由交易。
金色财经挖矿数据播报:ETH今日全网算力上涨1.18%:金色财经报道,据蜘蛛矿池数据显示:
BTC全网算力165.488EH/s,挖矿难度23.14T,目前区块高度678382,理论收益0.00000603/T/天。
ETH全网算力524.120TH/s,挖矿难度6788.56T,目前区块高度12202704,理论收益0.00435137/100MH/天。
BSV全网算力0.663EH/s,挖矿难度0.09T,目前区块高度682075,理论收益0.00135756/T/天。
BCH全网算力1.499EH/s,挖矿难度0.22,目前区块高度682449,理论收益0.00060030/T/天。[2021/4/9 20:00:46]
以下是Wyvern的协议功能:
金色晨讯 | PayPal董事会成员:如果比特币成功 其价值可能会高达100万美元:1.PayPal董事会成员:如果比特币成功 其价值可能会高达100万美元
2.日本Rizuna银行取消与瑞波支持的区块链支付合作
3.Andreas Antonopoulos:无法完全解决BTC可扩展性问题
4.民意调查:亚洲将是未来十年大多数最重要的数字货币公司所在的大洲
5.赵东发文表示,USD交易所大量买入BTC会导致USDT正溢价
6.BB:比特币是比以往存在的任何东西都更好的价值储存手段
7.广州市黄浦区已投入使用4个基于区块链技术的5G智慧停车场
8.彭博社:许多ETF迫于监管需求将其名字中的区块链一词去掉
9.绝大多数的捐赠基金都在尝试加密投资[2019/4/15]
断言注册表
金色相对论 | 币信COO熊越:挖矿的风险管理取决于关键环节的判断:在本期金色相对论之“矿业危·机”中,针对金色财经内容合伙人佟扬“对于挖矿和资产管理上该如何理解,如何组合达到足够的避险能力?”的提问,工学硕士、经济学者、币信COO熊越表示:“挖矿的风险管理,就取决于在买矿机、卖币缴电费等几个关键环节上的判断。如果判断币价会上涨,可以借人民币;相应地,如果判断币价会跌,可以借比特币。也可以把风险和收益都转嫁一部分出去,让别人去买矿机,自己做矿场托管,赚一个稳定的服务费。真正战略层面上,只有一个绝招,就是便宜的电和便宜的矿机。”[2018/11/19]
订单生成者可以检查他们和他们的交易对手是否使用有效的注册表。
金色晨讯 | 美股区块链概念股普遍下跌 Coinbase上线稳定币:1.日本金融厅本周将通过虚拟货币交换业协会自主监管组织认证。
2.美股区块链概念股普遍下跌。
3.瑞士金融协会发布数字资产反标准。
4.甲骨文推出区块链应用程序云服务。
5.Coinbase上线稳定币USDC。
6.SEC专员表示比特币ETF申请人应关注流动性、托管和市场监测。
7.纽约州金融服务部(NYDFS)批准Coinbase托管信托公司成立。
8.国际证券监管机构IOSCO秘书长表示,数字货币交易所对全球可持续发展有重要作用。
9.阿尔巴尼亚政府考虑制定加密法规。[2018/10/24]
断言calldata
订单中的大部分逻辑是在调用和反向调用上构造谓词。每个订单的静态回调(谓词函数)接收调用、交易对手调用和订单元数据(以太币值、时间戳、匹配地址)的所有参数,并且必须决定是否允许订单匹配,如果允许,填写多少。
Call
第一次调用由订单制造者通过他们的代理合约执行。静态回调接收所有参数,调用目标、调用类型和调用数据等,并且必须验证调用是制造商愿意执行的调用(例如转移特定资产或一组资产)。
Countercall
第二次调用由交易对手执行,为方便起见,在源代码中将其称为“countercall”。静态回调接收所有参数,有countercall 目标、countercall 类型和 countercall 数据,并且必须验证调用是制造商愿意接受以换取他们自己的调用(例如转移特定资产或资产集)。
断言状态
静态调用在调用之后执行(如果静态调用失败,整个事务将被恢复),因此可以断言特定状态已更改,而不是断言调用数据的属性。
元数据包含挂单时间、挂单到期时间、反挂单挂单时间、调用中转入的ETH、当前订单成交值和匹配地址。
广义部分填充
订单签署最大成交,静态调用返回一个uint,如果订单匹配,它指定更新的成交值。订单的当前执行也可以由订单的制造者通过交易手动设置(这也允许订单取消)。将订单的成交设置为非零值也会隐式授权订单,因为部分成交订单的授权被缓存以避免不必要的签名检查。
订单必须始终由地址授权,该地址拥有将执行调用的代理合约。授权可以通过三种方式完成:签名消息、预先批准和比赛时间批准。
授权订单的最常见方法是在链下对订单哈希进行签名。这是无成本的,任何数量的订单都可以被签名、存储、索引,也许还可以在网站或自动订单簿上列出。为了避免取消不再需要的订单的必要性,制造商可以在不久的将来签署到期时间的订单,并且只要他们希望继续征求交易,就可以重新签署新订单。
可以通过向合约发送交易来授权订单。这种方法可能对由智能合约构建的订单特别感兴趣,智能合约本身不能在链下签署消息。链上授权会发出一个事件,该事件可以很容易地被将订单包含在其数据库中的订单簿索引。
当有即时构建订单(可能匹配现有的先前签署或批准的订单)匹配时,通过从订单地址发送匹配交易进行授权。如果制造者打算自己发送与订单匹配的交易,会很方便,且可以节省一点 gas(因为发送交易隐含了 calldata 验证)。
构造匹配的调用数据
匹配的调用数据可以以任何方式链下构建。协议并不关心最终的 calldata 是如何获得的,只关心它完成了订单的谓词功能。在实践中,订单簿维护者(中继者)可能会存储额外的元数据以及订单,这些订单可用于构建可能的匹配调用数据。
不对称
在可能的范围内,该协议被设计为对称的,这样订单不需要在任何特定的“边”上,并限制自己与另一“边”上的订单匹配。
第一个不对称是排序。必须首先执行一个调用,执行该调用可能会更改第二个调用的结果。传入的第一个调用首先执行。
第二个不对称是特殊情况下的以太币。由于以太坊的设计限制,以太币与ERC20 代币不同,只能通过来自该账户的交易从一个账户发送。为了便于使用,Wyvern 尽可能支持特殊情况的ETH:订单的匹配者可以选择将值与匹配交易一起传递,然后将其传递给交易对手并作为参数传递给谓词函数(可以断言例如已发送特定数量)。
Wyvern v3的更改
订单不能自行匹配。但来自同一制造商的两个单独的订单可以相互匹配。
利用双向调用匹配提供的额外表达能力,Wyvern v3 将协议的几乎所有辅助方面“推出”到订单上,而不是在交换合约中实现它们,以降低了协议的复杂性,为用户和中继者提供灵活性,并降低gas成本。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。