编者按:本文来自:以太坊爱好者,作者:KevinBritz,翻译&校对:曾汨&阿剑,Odaily星球日报经授权转载。在Astro钱包过去两年的大部分时间里,我们都在研究各种形式的经济抽象。我们想要和区块链行业中更多的同仁分享我们的发现,希望可以为dApp如今所面临的诸多用户体验问题提供一些指导。尽管经济抽象并非一个新概念,但此前切实可行的用例寥寥无几。在本文中,我们将讨论如何实现一套通用的经济抽象方法。定义
鉴于这一术语已经被广泛使用,因此在讨论开始之前,我们希望给出一个明确的定义。经济抽象——能够原子化地使用任意一种区块链资产支付发起任意区块链交易的手续费以及交易操作本身。让我们举几个例子来进一步阐明它的意思:用户想要转移USDC,但苦于钱包中没有ETH来支付交易手续费。用户想要通过0xv3中继器来购买一只加密猫,而这需要使用ZRX来支付中继费,且加密猫的卖家只接受DAI,但用户手中只有USDC。组成
以太坊Layer2上总锁仓量回落至87.1亿美元:金色财经报道,L2BEAT数据显示,截至目前,以太坊Layer2上总锁仓量回落至87.1亿美元,近7日跌4.73%。其中锁仓量最高的为扩容方案ArbitrumOne,约58.1亿美元,占比66.09%,其次是Optimism,锁仓量16.9亿美元,占比19.5%。[2023/5/15 15:02:40]
实际上,在大多数区块链上经济抽象都被划分为两个组成部分:手续费抽象和代币抽象。如果二者都能实现,我们就拥有了完整的经济抽象。手续费抽象——能够原子化地使用区块链上的任意资产支付发起交易的手续费。通常来说,区块链协议需要依赖特定的基础代币来保障网络的安全性。一些协议以为只要支持用任意token来支付手续费,就能实现手续费抽象了,但这并不适合绝大多数协议。在下文的实现部分,我们将讨论如何在一个类似以太坊的协议上建构手续费抽象。代币抽象——能够原子化地使用区块链上的任意资产来达成交易。交易被执行的,其产生的操作或多或少会花掉一些资产,比如使用USDC购买一只加密猫,或在Compound上出借DAI。而有了代币抽象,我们的支付手段就不再局限于某一特定的代币了,而可以是区块链上的任何资产。实现
以太坊站上1400美元/枚续刷历史新高,日内涨幅超11%:行情显示,以太坊站上1400美元/枚续刷历史新高,日内涨幅超11%。[2021/1/19 16:31:59]
为了实现手续费及代币抽象,我们需要两个核心的区块链功能:手续费委托和多操作交易。绝大多数区块链都没有原生地支持这两个功能,因此需要进行额外的建构来达成我们的先决条件。我们将主要基于以太坊平台进行建构,但这同样适用于其它绝大多数智能合约平台。基础构建模块
在以太坊上实现这些核心功能的关键是使用智能合约钱包。传统的地址型钱包并不具备这些功能,但是我们可以通过智能合约为其添加额外的逻辑,从而实现新的核心功能。手续费委托——即指派另一支付者而非发送者本人支付交易手续费。如今的绝大部分智能合约钱包都采用Gas中继器来实现手续费委托。用户无需直接往其智能合约钱包中打入以太币用于支付交易手续费,而可以通过签名消息来完成交易的中继。由于用户的账户实际上是智能合约,因此只要钱包能够验证该合约调用,以上两种方式都行之有效。多操作交易——即在单笔交易内完成多个原子函数调用。不同于手续费委托,多操作交易尚未得到广泛应用。而要想在单笔原子交易内完成多笔操作,这一特性不可或缺。有人尝试使用Wrapper合约来解决这一问题,也取得了一些成果,然而对诸如msg.sender等元数据的隐藏使得它们难以成为通用化的解决方案。幸运的是,在智能合约钱包中集成这一功能相当简单,但截至目前只有Dapper这一家智能合约钱包支持了该功能。实现手续费抽象
声音 | V神:中继注册燃烧机制是以太坊在隐私解决方面的关键一步:V神在推特中转发了一篇介绍中继注册燃烧机制的文章。该机制目的在于抵制垃圾交易,其在以太坊第二层网络上建立一套仲裁注册机制,每一笔交易在发送广播中需要支付一定比例的费用,最后利用min_percent将其销毁。V神评论称,在中继研究取得较大进展之后,这是以太坊短期在隐私解决方案上的关键一步。[2019/7/18]
利用多操作交易,我们可以在标准的Gas中继器架构上再建构一层消息传输协议,从而实现手续费抽象。下面我们通过一个简单的案例来说明该协议如何扩展钱包以提供额外的功能。第0步:客户端钱包想要发送一笔由一组操作组合而成的交易。第1步:客户端钱包通知Gas中继器它想要发送哪笔交易,以及想要用何种资产支付交易手续费。第2步:中继器回复一个签过名的报价消息,即为中继用户请求的交易指定一个价格,该价格以用户指定的资产计算。第3步:客户端钱包增加一笔额外的操作,即转移指定价值的资产给中继器。第4步:这笔最终由操作组合而成的交易连同签过名的报价消息被发回给中继器。第5步:中继器验证交易和报价消息,然后将该交易发送至区块链上。有了这一功能,客户端钱包可以要求许多Gas中继器分别提供报价,最终选择报价最低的中继器发送交易。实现代币抽象
以太坊企业联盟今年或将发布统一业务区块链标准:据ethnews消息,伦敦区块链博览会上传出,以太坊企业联盟(EEA)很快将发布面向不断增长区块链生态系统的标准。虽然今天早些时候来自伦敦区块链博览会的消息细节很少,但EEA确实已经向ETHNews正式将有“一系列即将发布的公告”。[2018/4/20]
一旦有了多操作交易的加持,实现代币抽象也就轻而易举了,关键的难点在于交易分析。客户端钱包需要能够分析潜在的交易,以便知道在执行交易中的操作时会花费哪些资产,花费多少。我们在Astro中建构了一个改良版的以太坊节点,从而可以运行上述的分析,但由于这在很大程度上是一个工程挑战而非算法挑战,因此我们将它留给读者朋友们做练习。一旦我们可以确定这组操作中所需要及会产生的资产,钱包就可以轻松地连接至各个DEX来为用户完成这组资产的兑换。诸如0xAPI这样的聚合器非常适合聚合这些用户所需的兑换,或者钱包也可以选择使用诸如Uniswap这类更简单但滑点效率更低的解决方案。有了这组互换交易,钱包可以在用户的操作前后分别附加所需和所得资产的兑换操作来完成最终的交易。合体吧!
现在我们已经同时实现了手续费和代币抽象,而二者合体就能实现经济抽象了!我们还可以加入其它一些灵活的功能,比如即时授权,这样就无需再发送单独的交易来授权诸如0x和Uniswap之类的合约动用我们的资产了。此举也提升了用户的安全性,因为我们只需授权这笔交易动用所需数量的资产。
我们可以通过这一流程图清楚地说明引言中那个相当复杂的示例,抽象地展示这一笔交易最终包含的操作列表。如我们所见,用户可以支付0x协议的手续费、0x中继器的手续费、加密猫卖家的出价以及Gas中继器传送交易的费用,而这一切单靠钱包里的USDC就足以完成。感谢ClintonBembry、LindaXie、AparnaKrishnan、以及ClayRobbins对本文的审阅。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。