宇宙链 宇宙链
Ctrl+D收藏宇宙链
首页 > 币安币 > 正文

对 EIP-3074 的批评以及一种简单的替代

作者:

时间:1900/1/1 0:00:00

对于开发者来说,AUTH/AUTHCALL?机制非常具有吸引力。它可以让人们创建调用者来实现不同的批量处理策略、gas抽象模型和复杂的账户抽象方法等。

这种灵活性源于这一机制赋予了开发者极大的自由。AUTH/AUTHCALL?机制不要求开发者遵循特定的模式,而是要求用户签署一个?commit?哈希值,让开发者基于?commit?自行设置限制。

然而,这种灵活性是以牺牲安全性为代价的。在本文中,我想要介绍一种更简单的替代方案。这个方案具备?AUTH/AUTHCALL?机制的绝大多数优点,但是风险远低于后者。

为什么签署一个AUTH?commit?所带来的风险高于签署一个与存在漏洞/恶意合约相关的事务?

用户在签署与合约相关的事务时,所承担的风险是已知的,即,可能会损失在该合约控制范围内的资产。比方说,用户给一个ERC20合约签署了批准事务,授权恶意的DEX合约。这个恶意DEX合约就可以提走用户在ERC20合约中的全部余额。但是,它无法从该用户的其它ERC20合约中提走代币,除非得到该用户的批准。它也不能代表用户进行其它操作,因为这也需要专门获得用户的批准。

美国地区法官拒绝合并针对 FTX 五项拟议集体诉讼的请求:金色财经报道,美国地区法官 Jacqueline Scott Corley 拒绝原告提出的合并针对破产加密交易所 FTX 的五项拟议集体诉讼的请求。法官指出,FTX 及其他被告尚未有机会就此问题发表意见。

此前,包括 Julie Papadakis、Michael Elliott Jessup、Stephen T. Pierce、Elliott Lam 和 Russell Hawkins 在内的原告指控 FTX 前首席执行官 Sam Bankman-Fried 和其他高管挪用他们的资产,并在加利福尼亚州北区提起诉讼。(Cointelegraph)[2023/3/10 12:52:51]

相较之下,EIP3074不仅要求用户签署“空白支票”,而且假设调用者是诚实且没有漏洞的。一个恶意/存在漏洞的调用者可以代表用户执行任何操作?——访问用户持有的资产,代表用户进行投票,控制用户所有的合约等。

律所 Pomerantz 对 Argo Blockchain 及其部分高管提起集体诉讼:1月27日消息,律师事务所 Pomerantz 在纽约东区地方法院对比特币矿企 Argo Blockchain 及其部分高管提起集体诉讼,代表参与 Argo 首次公开募股发行的参与用户及 2021 年 9 月 23 日至 2022 年 10 月 10 日期间的 Argo 证券交易用户,向被告 Argo 提出索赔。

Pomerantz 指控其发行文件编制疏忽,因此载有对重要事实的不真实陈述,或遗漏陈述其他必要的事实,以使所作陈述不具误导性,以及并非按照规管其编制的规则和条例编制,此外在整个集体诉讼期间,被告对公司的业务、运营和前景做出了重大虚假和误导性陈述。[2023/1/27 11:32:23]

更糟糕的是,调用者随时都可以作恶,因为nonce实现是由调用者控制的。存在漏洞/恶意的nonce逻辑实现可以重放用户过去的事务。如果?commit?验证的其它部分的逻辑也存在漏洞,调用者就可以利用这个nonce逻辑实现来代表用户执行任何操作。即使漏洞被发现,用户也无法撤回空白支票。这个外部账户已经被永久入侵了。

去中心化交易平台 SIZE 计划新增对 Arbitrum 的支持:8月24日消息,由链上大宗交易平台 Integral 推出的去中心化交易平台 SIZE 计划新增对 Arbitrum 的支持。[2022/8/24 12:46:01]

编写一个正确的调用者程序很难,而且我们几乎可以肯定,调用者会不定期出现错误,从?EIP3074最后列出的调用者应该警惕的检查/漏洞/情况非详尽清单中可见一斑。这份清单势必会变得越来越长,很可能伴随着痛苦的发现过程。

此外,恶意参与者可以编写一个看似无害的调用者程序,但是故意留下一个细微的漏洞,等到大量外部账户授权该调用者之后才会被攻击者利用。

如果攻击者没有直接或立即利用这个漏洞从用户那里窃取资金,这个漏洞可能很长时间都不会被发现。

治理劫持示例

恶意去中心化交易所EveSwap为其用户编写了一个调用者程序。这个调用者程序通过空投EVE代币来为用户提供gas资助,并批量处理用户的批准和转账事务。

Midpoint 完成对 Blockchain World 的收购:金色财经报道,Midpoint宣布已完成对Blockchain World收购。BWL是一家专注于构建创新的、以消费者为中心的基于区块链的产品的公司。BWL拥有高级域名Blockchain.eu(欧洲)、Blockchain.com.au(澳大利亚)和Hivello.com;所有这些都预计将在 2022 年推出。

作为交易的对价,Midpoint已向BWL的现有股东发行了10,000,000 股普通股。对价股份的转售受到限制,解禁日为2022年9月14日。[2022/3/17 14:01:43]

EveSwap的调用者程序看似无害,而且永远不会窃取用户的代币,因为这样马上就会露馅。

用户很开心。交易都成功了,交易费也很便宜。几个月来平安无事。

然而,每当有人使用EveSwap交易AliceSwap的治理代币ALI时,会自动将用户的AliceSwap投票权委托给EveSwap。

动态 | BBKX平台ETF专区新增多个币对 其中ETH3L涨幅超12%:据BBKX.COM行情显示,BBKX交易平台ETF交易专区多个交易对大幅上涨,截至11:05(UTC+8),ETH3L/USDT当前净值1.015U,当前涨幅:13.53%涨幅明显,杠杆ETF 是一种锚定标的资产价格变化的指数基金。购买“3L”表示3倍做多,购买“3S”表示3倍做空,无需借还,不需要保证金,从而不会爆仓,用户可以在WEB端以及APP端ETF专区进行购买。目前已经上线BTC、ETH、EOS、XRP、BCH、LTC、BSV、ETC多个币种,后续还将上线更多币种,敬请期待

BBKX成立于2019年6月,已获得节点资本和链上产业基金联合战略投资。[2020/2/18]

一旦授权人数达到某个阈值,EveSwap就会通过治理提案劫持AliceSwap。

EveSwap用户不太可能注意到这个过程,因为交易总是成功的,但是最终会给AliceSwap带来毁灭性的打击。

跨链重放示例

EIP3074合理地建议?commit?应该包含?chainid。但是,这是由调用者,而非协议执行的。在另一条链上有着相同地址的调用者可能会跳过该检查。

EveSwap在兼容EVM的BobSpongeChain上运行,后者支持EIP3074。EveSwap在BobSpongeChain上部署了一个诚实的调用者。

用户使用该调用者在BobSpongeChain上交易,然后使用桥将资产转移到以太坊上。

EveSwap使用同一个部署密钥在以太坊上部署了另一个地址相同的调用者。这个在以太坊上的调用者不会检查?commit,只会检查?ownerOnly,并充当其所有者的通用AUTH/AUTHCALL代理。

这样一来,EveSwap就可以劫持用户在以太坊上的外部账户并卷走他们的资产了。

用户从未在以太坊上交易过,运行在BobSpongeChain上的调用者程序又经过了严格的安全审查。尽管如此,用户还是丢失了全部资产。

以太坊通过EIP155的重放保护来防范这种情况。AUTHCALL没有重放保护。由于所有?commit?检查都交给调用者完成,我们失去了以太坊提供的一切交易保护。攻击是在所难免的,因为保护措施很随意。如果要接受EIP3074,AUTH消息必须明确包含?chainid,而非将其作为?commit?的一部分。

我们还能采取什么别的手段?

我的提议是实现一个更明确的机制,在协议层面强制规定?commit?的含义。commit结构将是类型化的,钱包会以用户可读的形式将commit呈现出来。用户可以确切地知道事务是什么样子的,并确信这个事务不会在任何链上重放,无需依赖于调用者程序开发者的品行和能力。

一个可能的实现:

AUTH?将使用包含授权调用列表的类型化结构代替?commit?哈希值。每个调用都将指定{nonce,to,gas,calldata,value,chainid}。签名将被验证,整个授权调用列表将保存为?authorized_transactions?而非?authorized?地址变量。

AUTHCALL?将得到一个新的参数?index,该参数指向最后一个?AUTH?创建的列表中的地址。

用户地址的nonce将随?AUTHCALL?递增。nonce并非由调用者存储,而是实际的账户nonce。

利:

用户可以清楚地了解情况。

安全性由协议保障。

依然支持批处理和账户抽象。

弊:

nonce实现,不支持并行。

复杂调用者程序的事务处理起来很繁琐,因为用户必须查看并接受整个调用列表。

不同的实现可能支持不同的nonce方案。但是,无论我们使用什么机制,该机制必须由协议而非调用者执行。

无论如何都应该避免让复杂调用者执行大量用户调用。复杂操作应该作为普通的智能合约实现,而非尝试实现使用多个外部账户调用的算法。

替代方案:完全避免硬分叉

还有一个选择是完全避免AUTH机制,并通过?vbuterin?建议的另一种交易池来解决账户抽象和批量处理问题。

利:

无需硬分叉,可由智能合约和可以感知这些智能合约的节点支持。

可用于一切支持EIP3074的实现,而不会引入额外的风险。

弊:

不向后兼容已有的外部账户。用户需要部署一个合约钱包并将资产转移到该钱包内。

除非要求在不迁移的情况下支持已有的外部账户,否则这个选择看起来更安全。

原文链接:

https://blog.mycrypto.com/eip-3074/

作者:?MaartenZuidhoorn

翻译&校对:?闵敏&?阿剑

标签:AUTHCOMESWAPESWAUTH价格CCOM价格OneSwapSundaeSwap

币安币热门资讯
HomiEx(红米交易所)关于“USDT 7日定期(第五十期)”Staking 产品固定年化收益30%开启的公告

亲爱的用户: 为回馈新老用户长期的关注与支持,HomiExUSDT固定年化30%挖矿基金,今日开启7天定期产品认购,保本保息无风险,到期系统自动发放收益本金至HomiEx钱包账户.

1900/1/1 0:00:00
KuCoin上线e-Money (NGM)!

亲爱的KuCoin用户:我们很高兴的宣布,KuCoin将上线e-Money(NGM)项目并支持交易对NGM/USDT.

1900/1/1 0:00:00
幣安逐倉槓桿新增 KEEP、MIR、NU 資產

親愛的用戶:幣安逐倉杠桿已增加KEEP、MIR、NU資產,並開放KEEP/USDT、KEEP/BUSD、KEEP/BTC、MIR/USDT、MIR/BUSD、MIR/BTC、NU/BUSD、NU/USDT逐倉交易對.

1900/1/1 0:00:00
关于百万“刮刮乐”活动的公告

亲爱的PandaFe熊猫用户:由于活动系统正在进行全面优化升级,6月27日百万“刮刮乐”活动将暂停一期。活动系统升级完成后,为了回馈广大新老用户长久以来的支持,6月28日百万“刮刮乐”奖励翻倍重磅回归.

1900/1/1 0:00:00
Bitfinex加密市场一周回顾:暴跌暴涨,过山车般的震仓

1.?每周行情分析: BTC:继续震荡,期待结构性变化?上周比特币受政策影响,沿着趋势线一路下跌。4小时K线看,在两次重要的支撑位置31000美元附近几乎没有停留,放出巨量,快速下探刀29000美金附近的位置.

1900/1/1 0:00:00
关于部分币种和交易对调整的公告

DYDX关于关闭现有安全质押模块提案已通过:11月26日消息,DYDX关于关闭现有安全质押模块 (SSM)提案DIP 17已获得通过,此前dYdX安全质押模块允许用户质押DYDX,在协议出现流动性短缺事件的情况下提供保险能力.

1900/1/1 0:00:00