作者:Eden Network,翻譯:金色財經xiaozou
2023年3月1日,ERC-4337上線以太坊主網,增強了智能合約代表用戶進行交易的能力。但實際上,到底發生了什么變化?
ERC-4337并沒有觸及以太坊所依賴的核心共識層,而是添加了一個層,使開發人員有機會從根本上改變用戶的鏈上交互和交易方式。
本文,我們將研究ERC-4337引入的五個主要技術組件,以及它們是如何協同工作執行用戶交易的。
ERC-4337標準有五個關鍵組件值得關注:UserOperation、Bundler、EntryPoint、Aggregator和Paymaster。
1、UserOperation
簡單來說:UserOperation捕捉用戶的意圖和操作,包括與發送方、有效負載和gas費相關的信息。由于它的設計是為了避免更改共識,以太坊團隊選擇創建一個全新的結構,以獲取代表用戶發送的交易所包含的全部必要元素。
為了避免混淆,他們特意沒有將其稱為“交易”。
更具體地說:智能合約錢包現在可以創建叫做UserOperation(userOp)的偽交易對象,代表用戶所期望的交易意圖,而無需初始化傳統交易。
LBank 未受到 Infura 宕機影響,用戶可正常充提 ERC20 代幣:據官方消息,受 Ethereum 的API服務供應商 Infura 宕機影響,多家交易平臺疑似暫停 ETH 以及 ERC20 代幣充提服務。
LBank技術總監表示,團隊從2016年起就開始自建BTC, ETH等主流資產的節點與錢包,不依賴于Infura等外部服務商的API服務,因為此次不受影響,用戶可正常使用 ERC20 代幣充值及提現服務。[2020/11/11 12:20:29]
UserOperation不能訪問任何在模擬和執行之間可能發生變化的信息,例如當前區塊時間、哈希值、區塊號等。這是為了確保它的有效性,并且能夠為其鏈上交易執行支付費用。
UserOperation同樣只允許訪問與發送方地址相關的數據。
與交易類似:UserOperation包含sender、to、calldata、maxFeePerGas、maxPriorityFee、signature和nonce字段。
與交易不同:nonce和signature字段的使用不是由協議定義的,而是由各帳戶實現定義的。
UserOperation內存池
簡單來說:UserOperation內存池是一個等待網絡處理的未執行UserOperations的池。UserOperations被發往UserOperation內存池,而非傳統的公共內存池。
Coinbase發布ERC-20標準代幣上幣安全審查指南:Coinbase發布ERC-20標準代幣的上幣安全審查指南,具體來說,在評估上市的ERC-20代幣時,Coinbase主要會以4種標準執行安全評估,分別是驗證源代碼、行業標準庫的使用、特權角色(超級用戶)的權力范圍和簡單的模塊化設計。[2020/8/18]
更具體地說:UserOperation內存池是任一個UserOperation作為真正交易上鏈之前的最后一個“停靠站”,然后,稱為bundler(下文將詳細介紹)的新質押者可以從該內存池里提取各UserOperation,充當了EOA角色,支付gas費并將UserOperations發送到共識層作為交易執行。
這是一個專用的高級UserOperation內存池,僅供UserOperations使用,也稱為canonical內存池。該內存池遵循并嚴格執行ERC-4337規則。ERC也允許為UserOperations提供不遵循canonical內存池規則的替代內存池(alt-mempool)。
遵守ERC規則的UserOperations被發送到canonical內存池。那些不遵守ERC規則的可以被發送到其他規則不同的替代內存池。這些替代內存池中的UserOperations僅被發送給該池的參與者。
Bundlers可以通過加入白名單或加入另一個不同ID的替代內存池來應對canonical內存池的異常情況。Bundlers可以自由加入canonical內存池(他們必須無一例外地遵守ERC規則)及替代池。
注:UserOperations內存池的最終版本尚未完全定義,因此預計會有進一步的變化。然而,一個完全去中心化的內存池對于協議的采用和健康來說是必不可少的。
公告 | EbuyCoin交易所于今日上線USDT(ERC20)及USDT(TRC20):據官網公告,EbuyCoin交易所于2020年2月22日21:30(GMT+8)上線USDT(ERC20)和USDT(TRC20),同時開放幣種充值、提幣。?
USDT(ERC20)是Tether公司基于以太坊ERC20協議發行的,充提幣地址是ETH地址(以數字0和小寫x開頭),充提幣走ETH網絡。
USDT(TRC20)是Tether公司基于TRON(波場)網絡的TRC20協議發行的,充提幣地址是TRON地址(以大寫字母T開頭),充提幣走TRON網絡。
平臺提示用戶充提時請務必核對USDT的主鏈類型,否則轉賬資產將無法找回。
EbuyCoin交易所總部位于新加坡,是由美國哈佛大學和新加坡南洋理工大學的計算機與金融風險管理專家團隊管理運營的大型數字資產交易平臺,在數字資產交易及風險管理方面,擁有豐富的經驗和完善的體系。[2020/2/22]
2、Bundler
簡單來說:Bundler充當著它從canonical內存池和替代內存池中所提取的全部UserOperations的EOA的角色,Bundler將UserOperations發送到EntryPoint合約進行驗證和完整性檢查,然后,最后進入我們在ERC-4337出現之前的世界里所習慣的交易流程。
更具體地說:Bundler是一個專門的操作員,它監聽UserOperation內存池和所有內存池,提取多個UserOperations,將它們打包在一起,并將交易包發送給EntryPoint合約執行。這看起來非常像從EOA到智能合約的交易,其中UserOperations的執行就如內部交易。“from”地址將是Bundler,“to”地址將是EntryPoint合約。
分析 | 以太坊主流交易所交易量縮水 ERC20代幣對以太坊市值占比持續下滑:據 TokenGazer 數據分析顯示,截止至 10?月 11?日 11 時,以太坊價格為$190.66,總市值為$20,609.88M,主流交易所24H交易量約為$91.39M,環比昨日縮水48.07%;近期以太坊對比特幣匯率平穩波動;基本面方面,以太坊鏈上交易量略有下滑、鏈上DApp交易量縮量明顯、算力有一定增長、新增地址保持較高速率增長;以太坊 30 天開發者指數約為 2.27;以太坊與 BTC 180 天關聯度平穩波動,30 天 ROI有一定回調;ERC20 代幣總市值約為以太坊總市值的 56.56%,持續下滑。[2019/10/11]
Bunders選擇將哪些UserOperations對象包含在他們的打包交易中,基于與今天以太坊的區塊建設者所使用的類似的價值最大化邏輯。
成為Bundler的經濟模型/動機是什么?
交易上鏈時,Bundler充當“from”地址,正因如此,Bundler將使用ETH為交易包支付gas費。Bundler作為所有單個UserOperation執行的一部分,隨后會獲得費用補償。
在接收UserOperation之前,Bundler將模擬它來驗證簽名,確保UserOperation可以支付費用,并確保UserOperation在模擬和執行時以相同的方式運行。要靠Bundler來避免包含驗證失敗的UserOperations,避免吸收那些無法支付的gas成本。
注意:在ERC-4337框架中,區塊建設者也可以充當Bundlers角色,以提供更強大的執行保證,但這并不是必需的。如果沒有這種更強大的執行保證,交易包將被發送到公共池,并且有可能發生搶先交易,導致交易包交易失敗。
CommerceBlock (CBT) 上線Gatecoin:5月9日,Gatecoin交易所已經上線了CommerceBlock (CBT) ,用戶可以用BTC和ETH交易CBT。[2018/5/9]
3、Paymaster
簡單來說:Paymaster是一個可選的質押者,可以為其他用戶的交易支付費用。為什么?Paymaster可以為以太坊交易帶來許多有趣的新功能,例如:
應用開發者可以很容易地為他們的用戶補貼費用,例如作為一種獲客手段。
用戶可以使用ERC-20代幣或信用卡或其他訂閱服務等鏈下支付方式輕松支付gas費。
更具體地說:ERC-4337流程并沒有強制要求必須使用paymaster。UserOperation使用paymaster通常有以下兩種選擇:
驗證Paymaster:這些paymaster提供與鏈下流程相關聯的gas抽象。例如,它可以讓用戶用信用卡或訂閱服務支付交易費用,而不會損害他們的賬戶托管。
存款Paymaster:這些paymaster提供與鏈上ERC-20代幣相關聯的gas抽象。
Paymaster要么必須限制其存儲使用,要么必須進行質押。
注:為了防止濫用,系統將降低速度或暫時封禁提交大量無效UserOperations的Paymaster。為了防止實體的“女巫攻擊”,全局實體需要在系統中進行質押,這使得拒絕服務(DoS)攻擊的成本很高。該質押不會被罰沒,可隨時提取,但會受延遲限制。不訪問全局存儲的全局實體例外。
4、Aggregator
簡單來說:Aggregator是一類特殊的參與者,利用helper智能合約來處理批量UserOperation簽名,并將它們轉換成一個簽名,也就是將其聚合。
更具體地說:Aggregator是一個受合約帳戶信任的helper智能合約,用于驗證聚合簽名。UserOperations包由Aggregator在單個步驟中進行驗證,而不是單獨驗證每個簽名。Aggregator旨在提高大規模交易處理的效率和成本。
當前的現實:ERC-4337的交易量還不夠高,不足以顯現簽名聚合的好處,但交易量正在快速增長,一旦達到臨界值,Aggregator就會成為一個關鍵的利益相關者,促進大規模交易。
壓縮的實現過程超出了本文的討論范圍。然而,它已經整合進ERC-4337的設計中。最流行的壓縮方法就是使用BLS簽名聚合。
從用戶的角度來看,他們看不出有任何不同,但是開發人員需要在智能帳戶中部署BLS簽名邏輯。
5、EntryPoint
簡單來說:EntryPoint合約是一個單例合約,驗證并執行發送給它的UserOperations包。它檢查并確保由bundler發送的提交到鏈上的所有UserOperations都是真實有效的。
更具體地說:EntryPoint合約是所有符合ERC-4337標準的智能合約錢包必須使用的全局入口點,以便在EVM上進行交易。這一概念類似于單個質押存款合約。
EntryPoint的使用簡化了智能合約錢包使用的邏輯,將確保安全所需的更復雜功能推至入口點,而不是錢包本身。其核心目的是防止錢包在進入網絡之前進行不必要或未經授權的操作。
EntryPoint序列
下圖展示了EntryPoint是如何管理Bundler發送的UserOperation包的。通常有兩個階段,但在使用aggregator的情況下,會增加一個階段。
EntryPoint序列相對簡單,有兩個階段:
如果存在aggregator:
如果沒有aggregator:
序列中的每個循環都有自己的角色,如下:
循環1:Aggregator循環
如果一個交易包使用了aggregator,那么EntryPoint會首先檢查aggregator。由Entry Point來驗證簽名。
循環2:驗證循環
首先,它會檢查合約帳戶是否存在。如果不存在,它就會創建一個。
如果沒有定義paymaster:序列驗證Contract Account在EntryPoint中是否有足夠的存款來支付gas費。如果存款充足,它就會為UserOperation付費。
如果定義了paymaster:序列驗證paymaster在EntryPoint合約中是否有足夠的存款。如果存款充足,那么合約將驗證UserOperation。
循環3:執行循環
它使用callData調用合約帳戶。
如果定義了paymaster,它將調用paymaster中的自定義費用邏輯。
只有在UserOperation通過序列循環的考驗后,才能最終上鏈。
結論:
雖然為了避免混淆,ERC-4337特意使用了不包含“交易”字眼的用語,但實際上,它可以被視為用戶交易上鏈的替代流程。一旦把所有組成部分連接起來,協議就有能力向現有EOA交易流程引入新的用戶意圖層。
AA(賬戶抽象)錢包的用戶將把他們的意圖傳遞給UserOperations內存池。Bundlers將這些意圖轉換為網絡可以像以前一樣處理的簽名交易。
雖然對于開發者來說,這看起來像是一個有額外步驟的“交易”,但對于用戶來說,這就是手動輸入用戶名/密碼并將其記在筆記本上以確保安全,或使用OAuth只點擊幾下就可訪問web3應用程序之間的區別。
金色薦讀
金色財經 善歐巴
迪新財訊
Chainlink預言機
區塊律動BlockBeats
白話區塊鏈
金色早8點
Odaily星球日報
Arcane Labs
歐科云鏈
多位 KOL 紛紛發文預警 NFT 借貸協議 ParaSpace 團隊內部出現矛盾,并建議用戶盡快撤資.
1900/1/1 0:00:00作者:Mary Liu 2023 年 5 月 22 日,總部位于中國香港的 CEX(中心化加密貨幣交易所)Hotbit 突然官宣停止運營.
1900/1/1 0:00:00行業的風向總隨著巨頭公司而動。自從亞馬遜公司推出 NFT 市場的消息傳出后,大眾的目光就鎖定在了亞馬遜的身上,作為科技巨頭的亞馬遜入局 NFT 對整個行業都有著舉足輕重的意義.
1900/1/1 0:00:00Web3 的出現意味著價值不再需要主要由社交媒體中介積累,而社交媒體中介的主要用途是促進聯系。Web3 社交具有三個特征:無平臺、社交數據可移植、可組合.
1900/1/1 0:00:00原文作者:New Order,Medium 介紹 至少可以說,市場上最近發生的事情確實令人震驚.
1900/1/1 0:00:00作者:Lim Yu Qian,Coingecko研究員;翻譯:金色財經xiaozou1、頭部去中心化社交媒體有哪些?視頻流媒體Odysee和內容共享論壇Steemit是202.
1900/1/1 0:00:00