前言
在2023.3.1号丹佛的WalletCon上,官宣由以太坊基金会开发人员设计实现的ERC-4337的核心合约已经通过了OpenZeppelin的审计,通过各项测试,目前审计后的合约已经顺利部署在以太坊主网以及若干测试网,后续可在各EVM兼容链上运作包括Polygon、Optimism、Arbitrum、BNBSmartChain、Avalanche和GnosisChain等。
本文将梳理4337标准的实现机制、审计报告结论与最新行业进展
1、账号抽象的背景
1.1、为什么产权分离是账户抽象的目标?
目前在以太坊中有两种账户,分别为外部账户和合约账户。外部账户的所有权和签名权理论上是同一个体单位持有的;简单来讲,持有私钥的人不只拥有这个账户的「所有权」,同时还有权利「签名转移所有资产」。所以当前以太坊上所有权和签名权是一体的,这样的外部账户设计可能会衍伸出一些值得讨论的问题:
私钥难保护:用户失去私钥意味着地失去所有资产。签名算法少:原生协议在验证交易上只能使用ECDSA签名和验签算法。签名权限高:无原生多签,单签即可执行任意操作多币种受限:交易手续费只能通过ETH支付,并不支持批量交易。交易隐私泄露:一对一交易容易分析账户持有者的隐私信息。其次单纯的合约钱包也有一定问题:
Uniswap员工AzFlin承认是FRENS代币创建者,但否认Rug Pull指控:8月12日消息,Meme代币FrensTech(FRENS)背后的开发者被指控进行Rug Pull,从项目中移除流动性。据链上专家@UniswapVillain披露,Uniswap早期员工AzFlin是FRENS的开发者。在部署FRENS代币数小时之后,AzFlin使用多链桥HOP从Base网络中转走14枚WETH(约合25,800美元),甚至卖掉了从流动性中提出的代币。
AzFlin承认自己是FRENS代币的开发者和部署者,但否认Rug Pull指控。AzFlin声称,项目的流动性从一开始就被锁定。他仅移除价值1枚ETH的流动性,这是他利用自己的开发者钱包资金提供的流动性。AzFlin承认,当FRENS市值达到3万美元时,他出售了代币。但他为自己的行为辩护,声称出售的代币最初是由他自己购买,目的是为项目引入流动性。根据其说法,所谓的Rug Pull只不过是FUD。[2023/8/12 16:22:19]
对合约钱包的操作必须由EOA发起,每笔交易将多消耗21000Gas。。需要EOA有足够的ETH来支付Gas,或者依靠Relayer支付Gas。上诉的约束让普通用户很难使用以太坊:
首先,使用以太坊上的任何应用,用户都必须持有以太其次,用户需要处理复杂的费用逻辑,Gasprice、Gaslimit、事务阻塞这些概念对用户来说过于复杂。最后,虽然许多区块链钱包或应用试图通过产品优化提高用户体验,但它们的实际效果甚微。破局之道在于实现账户抽象,将所有权和签名权解耦,从而才能逐个解决上述问题
拓展阅读:
以太坊账户抽象万字研报:拆解10个相关EIP提案与冲击千万级日活用户瓶颈的七年之路
陈茂波:让Web3稳慎走好创新发展的道路:4月9日消息,香港特区政府财政司司长陈茂波在香港特区政府网站发表司长随笔称,过去一段时间虚拟资产巿场大幅波动,最近也有虚拟资产交易所倒闭,让社会上一些人对Web3的前景感到怀疑。然而,我们认为这正是推动Web3发展的最好时机。下一阶段,巿场参与者需要更深入发展区块链技术,让其透明、高效、安全、去中介化、去平台化、低成本的特点和优势找到更广泛的应用场景、解决更多现有商业模式的痛点乃至打破垄断等问题,让用户可更广泛分享数据的经济价值,并为实体经济带来跨越式的进步。(金十)[2023/4/9 13:52:49]
虽然也有出现若干折中方案,如多签钱包和无需Gas的元交易机制,接下来咱们展开探讨。
1.2、EIP-4337与折中方案对比
1.2.1、折中1-多签合约钱包方案
多签钱包,即用智能合约实现多签功能的钱包合约账户。以Safe多签钱包为例,可以设定钱包的多签规则,如三人共管、两人签名可执行交易,而Argent钱包的做法也类似,创新点是引入所谓的监护人机制,对用户更友好,用户可以设定其他EOA账户或邮件/手机作为监护人,监护人可以许可交易、锁定钱包、协助恢复钱包。这样的做法给用户带来了便利,但由于它的钱包软件、钱包合约及后端程序的功能很复杂,它的方案很难成为行业通行的标准做法。
总之,这里很多的优点都源于合约本身的高度定制能力,同样的缺点则是依赖于EOA账户做管理员来驱动,这本质是签名算法的局限性。
相比之下对比传统多签合约钱包的方案,4337的优势则是可以自定义签名算法。这里的签名只需和合约中签名的算法绑定的,而签名这件事本身可以有多种算法实现,不同算法性能和交互模式不同,而这将带来的核心变化是,如更好的将签名的功能转入手机设备端实现从而实现便携的硬件钱包。这点主要的挑战是安卓等设备开放性过高,不可能私钥存手机,需要单独的签名芯片等。
赵长鹏:币安团队来自100多个国家,但仍然缺少大量人才:12月6日消息,币安首席执行官赵长鹏发推文称:“币安团队来自100多个国家,但仍然缺少大量(人才)。”[2022/12/6 21:25:40]
1.2.2、折中2-元交易标准
这点优化折中针对的是用户执行链上行为必须依赖已有ETH作为手续费,采用元交易标准后
用户体验上:用户虽然账户中没有ETH,但可仍通过网?界面铸造NFT:用户仅需签即可,我们创建交易、为之代付燃料费、将之提交上链执行。
幕后执行上:
用户对结构化数据进行签名,这个数据与签名是要求NFT合约铸造一个NFT给他数据与签名被发送给中继器链下中继器向链上发起交易,送到链上可信的传递者合约(Forwarder)而NFT合约是定制的,会将这样方式传递的交易中的原始发起者视为是用户,而非msg.sender因此在最终的NFT合约中,执行的NFTMint得到的对象就不是原始标准中的交易发起者了
例如最近火热的Lens免gas方案,就是非常标准的元交易执行模式,已经累计有上千万笔代付交易了
这个方案是有效的,但有两个缺点:
它引入了一个我们必须信任的链下?色中继器。如果他宕机了,或者有作恶的动机,则可能存在?险。我们最终交互的合约必须定制。这导致而无法与链上已经存在的、未定制的合约进行交互,这大幅减少能够适用的范围。为什么用这么多篇幅来讲述合约钱包和元交易呢?因为4337的实现里本身几乎就能涵盖上述的优点
Jared Grey以超过83%的得票率当选Sushi新任CEO:10月3日消息,今日结束的一项Sushi DAO社区投票结果显示,Eons Finance前首席执行官Jared Grey以超过83%的得票率当选Sushi新任“主厨”(即首席执行官)。[2022/10/3 18:38:40]
拓展阅读:
EIP-4337标准智能钱包实践研究报告:全景式呈现4337标准实例实现过程及机遇探讨
https://research.web3caff.com/zh/archives/4660
2、为什么4337可以实现产权分离?
现在在去中心化的领域是不存在免费的信任,身份验证必须基于密码学证明,所以无论哪种提案都是需要管理某种意义的私钥,而要实现体验上的折中,首要打破的就是目前账户权限的过于集中,整体改造方式按针对的对象或者环节可以分成三种大方向:
改造链上交易类型改造链上主体对象改造上链交易打包过程在下图,EIP-4337方案纳入了最新路线图,这也宣告着以太坊最终在这两条路径中做出了决定。
EIP-4337是迄今为止是AA的最佳方案。
被选用的核心原因是EIP-4337?完全避免了共识层协议更改,使用标准中提出了新的事务对象?UserOperation,用户将此对象发送到内存池中由?bundlers?从矿工维度批量打包交付合约执行交易事务。是个任何人可以开发链上合约,任何人可以自运行捆绑器的去中心化模式。
A股开盘:深证区块链50指数上涨0.56%:金色财经消息,A股开盘,上证指数报3100.55点,开盘上涨0.53%,深证成指报11251.27点,开盘上涨0.82%,深证区块链50指数报2777.49点,开盘上涨0.56%。区块链板块开盘上涨0.46%,数字货币板块开盘上涨0.35%。[2022/5/16 3:18:23]
2.1、4337运作原理
后续深入理解最新进展所面临的难题和挑战还是需要先理解原理,咱们从涉及的角色,分工,对照传统交易的执行流程来梳理。
2.1.1、4337标准涉及的角色
ERC-4337有五个主要组成部分:?UserOperation、Bundler、EntryPoint、WalletContract?和?PaymasterContract。
UserOperations用户操作对象,是用于与合约账户执行交易的伪交易对象。这些是由创建者的应用程序所创建的。Bundlers捆绑器,可能是某个矿工,从内存池中打包UserOperations并将它们发送到区块链上的EntryPoint合约的参与者。EntryPoint入口点合约,是处理交易验证和执行逻辑的智能合约。WalletContracts是用户最终拥有的链上身份,属于智能合约帐户。PaymasterContracts是可选的代付智能合约。2.1.2、4337交易的执行流程
我们来重新按完成一笔以太坊转账的流程来梳理下按照ERC-4337实现的交易是怎样的:
打开钱包:用户管理持有的私钥工具,如Metamask,Bitkeep,Bitizen等。交易签名:用私钥对新的若干字段做签名操作,称之为?UserOperation?用户操作对象。发送交易:称之为Bundlers打包者或是捆绑器,本质仍是由某个负责出块的矿工操作。矿工打包:bundlers?把用户发送的操作签名解析验证后由矿工单独再签名一笔交易来包裹用户的指令,批量地将用户的操作指令转发到某个合约钱包中再由合约来验证用户的签名并执行。由于交易是矿工签名并发送的,因此from是矿工,原先用户的签名和指令在则在参数之中。打包发送到作为路由器的智能合约中,执行验证并且进一步转发到各用户独立的合约钱包。入口点合约验证:EntryPoint?是处理交易验证和执行逻辑的智能合约。会反复和用户的合约账户进行交互以及验证,确保最终链上打包必然成功,否则全部交易都要回退。出块流程:完全不变。2.2、功能举例:入口点合约
迁入4337后,对任何账户的调度都需要先经过入口点合约,他需要解决的是
如果用户的「钱包合约」尚未部署,则用UO中的initCode字段去部署合约循环验证组合交易中UserOperation既有链下模拟验证也在合约也提供链上验证管理质押费计算gas成本,既要用于收取用户,也需要面对失败交易补偿捆绑器。3、为什么持续要关注ERC-4337?
ERC-4337的高开发投入以及快速的迭代进度,说明他能快速成为最终提案、并被各种应用广泛接纳、真正成为事实性行业标准,他带来的核心价值是大幅度降低普通用户使用Web3应用的门槛。届时,一个应用能否兼容ERC-4337,则将影响自己能否利用整个以太坊生态的其他组件、以快速发展。后续的DApp应用,也将必然需要能兼容从账户主体已然转移向ERC-4337的用户们。最终验证市场的还是用户本身,实现的方案是复杂的,这也仅仅是对于应用方的复杂对于用户本身而言,最终他们能够看到的是:
更流畅的交易体验,类似购物车,即使面对10个市场也能够一笔交易完成打包。更安全的接入入口,借助4337的自定义签名算法能力,使用手机专属安全芯片而无需携带硬件钱包,更沉浸的游戏环境,借助paymaster的代付能力,乃至可以定义半小时内的不超过XX金额的交易免除签名,避免了一场游戏被场外打断。真正的链上主体,可以被社交恢复,可以更换私钥密码,可以做交易的风险分层分级,兼容安全与使用便捷。如此种种对终端用户体验的提升,都是最终为什么要如此费力的推进ERC-4337的原因。
上篇更多是围绕ERC-4337运作机制、背景进行说明。下篇详细讲述当前被审计方案的优缺与实施细节,但涉及较多以太坊底层所以阅读难度较高,投稿在Web3Caff平台的research频道。阅读原文:https://research.web3caff.com/zh/archives/6900
参考文献
https://cointelegraph.com/news/ethereum-erc-4337-smart-accounts-launch-at-walletcon-account-abstraction-is-here
https://blog.openzeppelin.com/eip-4337-ethereum-account-abstraction-incremental-audit/#conclusions
https://blog.openzeppelin.com/eth-foundation-account-abstraction-audit/
https://eips.ethereum.org/EIPS/eip-4337
https://hackmd.io/@erc4337/test-suite
https://www.youtube.com/watch?v=eyT6WzJmWyc
https://notes.ethereum.org/@yoav/unified-erc-4337-mempool#What-does-censorship-resistance-require-of-ERC-4337
https://github.com/eth-infinitism/account-abstraction/issues/188
https://notes.ethereum.org/@yoav/unified-erc-4337-mempool
https://github.com/eth-infinitism/account-abstraction/blob/develop/reports/gas-checker.txt#enroll-beta
NFT现在无处不在,但你有没有想过哪条链最适合发展NFT?让我们深入了解不同链上的NFT市场。 文章将讨论:以太坊PolygonBNBChainSolanaFlowBitcoin从1月1日开始,
1900/1/1 0:00:00摘要以太坊将在4月完成上海升级,届时开放信标链质押ETH提款功能。上海升级是以太坊执行层的一次硬分叉,预计共实现9个EIP.
1900/1/1 0:00:00创作者经济是Web3社交的重要组成部分。在Web3的社交应用中,用户不仅可以享有完全的账户拥有权和数据拥有权,更重要的是能够获得一种点对点的创作收益,跳出平台抽成的限制.
1900/1/1 0:00:00LSDFi是基于LSD的?DeFi?产品,通过LSD,质押者可以将质押的?ETH?转化为一种可以交易的资产,从而解锁流动性,且LSD也降低了用户质押ETH的门槛,任意数量即可质押.
1900/1/1 0:00:00时光飞逝,2023年的第1季度即将结束。如果你没有时间跟上NFT领域,别担心,我会帮你的。我将提炼出2月发生的主要事件、我最兴奋的趋势,以及我对BLUR代币发布的看法.
1900/1/1 0:00:00美国正在打击加密货币,而亚洲却开始对加密货币进行放开。这篇文章我将介绍香港有关加密货币的最新消息。01加密禁令香港很早就是加密货币中心——Bitmex、Amber和FTX之前的所在地.
1900/1/1 0:00:00