本文意在講解StarkEX為支持快速取款而提出的解決方案。本方案的優點在于,其速度完全獨立于L2的運營者生成有效性證明的速度。
快速取款模塊已經運行在以太坊主網的StarkEx上,并且賦能了DeversiFi交易所和dYdX交易所。
而下文我們講解的方案除了快速取款以外,還有非常多的使用場景。我們先來了解一下需求是什么。
需求
區塊鏈使得兩方之間的免信任交互成為可能。Alice想發布一筆僅在特定條件滿足時才能執行的交易;Bob希望在條件滿足時能直接執行Alice的交易、不必再次獲得Alice的許可。我們把支持此類交互模式的元件稱作“有條件交易”。
在L1上實現CT不需要什么奇思妙想,因為智能合約可以保證時間和交易執行的耦合。但如果要求在L2中實現,那就有些挑戰了。比如,在StarkEx中,交易發起人簽名之后把交易傳遞給運營者,后者有責任來執行這筆交易,可是你用什么辦法來阻止運營者在所需條件滿足之前就執行這筆交易呢?
BlockFi破產計劃披露聲明獲美國破產法院的有條件批準:金色財經報道,BlockFi及其附屬公司宣布,其破產計劃披露聲明已獲得美國新區破產法院有條件批準并于2023年8月2日生效。BlockFi的第11章計劃最大限度地為客戶提供恢復,并為客戶提供盡可能快的分配。BlockFi和無擔保債權人官方委員會均建議所有有權投票的各方應在2023年9月11日投票截止日期之前投票接受該計劃。該計劃將為這些第11章案件得出公平且價值最大化的結論,從而盡快返還客戶資金。
BlockFi 表示如果該計劃得到確認,將集中精力在針對 Alameda、FTX、Three Arrows Capital、Emergent、Marex 和 Core Scientific 的訴訟中尋求索賠,以最大限度地為客戶爭取賠償,并抗辯第三方的索賠,BlockFi 的合格債權人有機會投票贊成該計劃,并將收到 BlockFi 的披露聲明和計劃、詳細的投票說明以及其他重要信息。[2023/8/3 16:15:30]
在本文中,我們只聚焦于在L2上實現依賴于L1事件的CT。也就是說,這種CT要能保證,運營者僅能在某個?鏈上事件?發生之后才能執行某筆簽過名的交易。更進一步,我們將加入一種依賴于另一個L2中事件的CT,從而支持StarkEx實例之間以及StarkNet中的互操作性。
Web3 Ventures Inc.獲批在加拿大證交所有條件上市:金色財經報道,專注于區塊鏈解決方案、去中心化應用程序和戰略投資的 Web 3.0 公司 Web3 Ventures Inc. 宣布已獲得加拿大證券交易所有條件批準上市,初步計劃將在今年秋季登陸加拿大證交所,股票代碼為“WEBV”。目前Web3 Ventures Inc. 對加密領域里的早期中小企業、項目和應用提供孵化、加速服務,主要關注區塊鏈透明度、安全身份、可驗證通信、游戲等垂直領域。(globenewswire)[2023/7/22 15:52:22]
下面,我們來形式化這種鏈上事件的概念,看看我們如何在StarkEx中的CT如何利用它。
有條件交易簡介
鏈上事件的注冊
CT使用了FactRegistry合約來跟蹤鏈上事件。實際上,只有在一個FactRegistry合約中注冊了的事件,才能“解鎖”CT。舉個例子,如果Alice直接在以太坊鏈上轉賬了1ETH給Bob,那CT是不能因此滿足執行前提的。
中芯國際:已知悉梁博士其有條件辭任的意愿:12月21日消息,中芯國際:董事會注意到,有媒體報道本公司執行董事及聯合首席執行官梁孟松博士擬辭任本公司職務的消息,并且本公司已知悉梁博士其有條件辭任的意愿。本公司目前正積極與梁博士核實其真實辭任之意愿,任何關于上述事宜的進一步公告將根據中國銀行間市場交易商協會相關自律規則適時作出。[2020/12/21 15:57:07]
在上面這個案例中,FactRegistry合約需要一個函數?transfer(),Alice傳入Bob的地址作為收款方。transfer()?函數做兩件事:把需要轉移的ETH發送給收款方;保存對這筆轉賬的記錄,比如存儲這筆轉賬相關參數的哈希值,到合約的存儲項中。FactRegistry合約還帶有一個?isValid()?函數,接受一條哈希值作為參數,返回一個布爾值——如果該條輸入的哈希值等于合約中記錄的某條哈希值,就返回?True。如此,這個記錄在合約中的哈希值,就可以當成是一個事實的證明。這個為FactRegistry合約引入一個新的事實的過程,通常稱為“事實注冊”。
加拿大Wealthsimple獲CSA有條件批準,將測試其加密貨幣平臺:總部位于多倫多的金融科技初創公司Wealthsimple已獲得加拿大證券管理委員會(CSA)的有條件批準,將對其最近已宣布的加密貨幣平臺進行為期兩年的測試。(Betakit)[2020/8/8]
一筆簽過名的CT所包含的鏈上事件的指紋有兩個字段:一個FactRegistry合約的地址;上述合約中應當記錄的事實。
StarkEx有條件交易
StarkEx會批量打包Layey-2中的交易,并使用一條發送到鏈上的STARK證明來結算這些交易。如果某一批次中包含CT,StarkEx將保證相關的事實已經注冊,以便能清算該批交易;否則,整批交易都會回滾。
有條件交易的案例
在本部分,我們會提出一些應用場景,并指出CT如何能用在這些場景中。
詳細案例——快速取款
在任意L2方案中,最初級的從L2轉出資金到L1中的辦法便是終局化一次L2的狀態更新。在基于有效性證明的系統中,終局化一次L2的狀態更新需要在鏈上提交一個相應的有效性證明,一般來說需要10分鐘。這就意味著,如果用戶使用這種方式來取款,就不得不等待至少10分鐘。
而快速取款的用意正是為了解耦這種依賴,讓用戶能夠在“區塊時間”內免信任地將資金取出,也即,就像使用普通的以太坊合約一樣。
那到底是怎么個流程呢?如果Alice想要從L2中取出1ETH到L1,Alice可以在L2上簽名一條將1ETH轉移給流動性提供者的CT,條件是LP在L1上轉移1ETH給Alice。Alice的CT僅能在她收到L1上的轉賬之后才能執行,所以她不會面臨對手方風險。
我們來看一個能夠協助CT的簡易的FactRegistry合約:
我們可以看到這個合約有一個payabe函數?transfer(),它的功能有兩個:
轉移一定數量的ETH到某個地址
登記keccack(amount,address,nonce)
Alice簽發的CT只有keccack(1ETH,Alice,nonce)在FactRegistry中注冊之后才能執行。而這個事實,也只有在給Alice的1ETH轉賬發生了之后才能成功注冊。Alice可以無需信任地取出1ETH,整個過程只需她的前面,和LP在以太坊鏈上發起的一筆交易。
更多應用場景
類似的流程可以捕捉到下列類型的事件,從而L2的CT也可以有更多的用途,例如:
如果ETH的價格跌到了1010DAI,Alice希望在L2賣出1ETH,換回在L1上的1000DAI
Alice希望在L2上給Bob10ETH,只要Bob以Alice的名義在Alice指定的dApp中存入9.5ETH
Alice希望在DeversiFi的L2上給Bob10ETH,只要Bob在dYdX的L2中給Alice的賬戶存入9.5ETH
總結
CT的第一種用途是快速取款,但StarkEx運營者可以用這一元件實現許多種類的L2-L1交互。
原文鏈接:
https://medium.com/starkware/conditional-transfers-the-key-to-interoperability-2e1de044fb65
作者:?StarkWare
翻譯:?阿劍
Tags:ALILICICEALICETALI價格galaxy-public-blockchainalice幣未來的價格預測AliceNet
尊敬的ZT用戶: ZT挖礦寶將于近期上線“ZTB/BONBON-羅素幣(RussellCoin,簡稱RC)”挖礦活動.
1900/1/1 0:00:00尊敬的LOEx用戶:LOEx國際站上線ENJ!并開放ENJ/USDT交易對具體時間如下:提幣:3月24日11:00充幣:3月23日11:00交易對:3月22日11:00注:未到充值開放時間請勿提.
1900/1/1 0:00:00Gate.io將于2021年3月20日14:00上線FireProtocol(FIRE)交易。我們將開啟FIRE超級福利,鎖倉理財年化收益100%.
1900/1/1 0:00:00此文整合并翻譯自@0xRafi發的推特thread1/由于Optimism團隊發布了消息表示其主網上線時間將提前.
1900/1/1 0:00:00總部位于英國的支付平臺Bottlepay,允許用戶發送BTC。?用戶可以在推特上,例如,"@bottlepay向@twitter用戶發送1000個薩特",立即將這個數量的加密貨幣從一個錢包發送到.
1900/1/1 0:00:00今天周日,比特幣不休市,沒有消息的刺激,市場顯得相對冷清,幣價一直在58000一線浮動,所以今天的分析寫的特別晚.
1900/1/1 0:00:00