概述
去中心化金融是一種創建于區塊鏈上的金融,它不依賴券商、交易所或銀行等金融機構提供金融工具,而是利用區塊鏈上的智能合約進行金融活動。在DeFi中存在了大量的套利機會,包括但不限于清算、差價套利。本文將分析部分去中心化交易所以及聚合器在合約代碼上可能存在的套利機會。
分析
Uniswap
Uniswap是一個采用了自動做市商模型的去中心化的加密貨幣交易平臺,目前有兩個流行的版本,分別是UniswapV2和UniswapV3,我們將分別分析其中可能存在的套利機會。
UniswapV2Router
在UniswapV2中,用戶一般是通過Router合約與Pair合約以及Factory合約進行交互。通常來說Router只是會在交易中中轉代幣,而不會存儲代幣,但由于種種原因,如空投、轉賬失誤導致Router合約中存儲了某些代幣。那么如何將這些代幣提取出來呢?
通過分析UniswapV2Router?02合約的代碼,發現存在?removeLiquidityETHSupportingFeeOnTransferTokens?函數:
該函數用于移除其中一個代幣為WETH的流動性,其內部調用?removeLiquidity?函數時傳入的to的地址為?address(this),也就是會將兩種代幣先轉移到Router合約中,然后Router合約再將兩種代幣轉移到指定的地址。這里雖然轉移的WETH的數量是?removeLiquidity?返回的,無法修改,但是轉移的另一種Token的數量是?balanceOf(address(this)),即Router合約中的該代幣的余額。
因此根據上述分析,我們能得到一個套利的流程:
Celsius增加一個2500萬美元錢包用于提款:金色財經報道,Arkham Intelligence在一份報告中表示,目前在破產保護下運營的Celsius Network 建立了一個加密錢包,其中包含 2500 萬美元的數字資產,供 Celsius 的托管賬戶持有人提取。該錢包資產為1039萬美元的USDC、880 萬美元的ETH、431 萬美元的山寨幣和 157 萬美元的其他穩定幣,包括Binance USD、DAI、Paxos dollar 和 Gemini USD。
此外,根據區塊鏈交易數據,從 2500 萬美元的資金中提取了 1362 萬美元。Arkham 分析師在電報消息中告訴 CoinDesk,另外 400 萬美元的提款可能是BTC。
周三,Celsius臨時首席執行官Chris Ferraro在法庭聽證會上表示,托管賬戶持有人已經從這些加密貨幣中提取了 1770 萬美元,并在此過程中提取了另外 350 萬美元。這代表了 60% 的合格托管用戶和 80% 的加密貨幣價值。[2023/3/9 12:50:44]
監控到Router?02合約存在ERC?20代幣;
監控到Router?02合約存在ERC?20代幣;調用?addLiquidityETH?添加該ERC?20代幣和WETH的流動性;調用?removeLiquidityETHSupportingFeeOnTransferTokens?移除流動性。局限性:
如果該代幣之前沒有和WETH組流動性,當第一次添加流動性時會損失一小部分流動性;暫時未發現提取Router?02合約中的WETH和ETH的方法。UniswapV2Pair
UniswapV2Pair合約,即所謂的流動性池,存儲著提供流動性的?2?種代幣,因為Pair合約中使用的是reserve來記錄余額而不是?balanceOf(address(this)),因此有人直接誤轉流動性代幣到合約中時會出現balance和reserve出現差值,而Pair合約中存在平衡函數?skim,我們可以調用該函數將這差值數量的代幣給提取出來:
AnetaBTC在Cardano網絡上推出首個比特幣封裝資產cBTC:金色財經報道,Cardano網絡實現了一個重要的里程碑。AnetaBTC表示,它已經成功地在該網絡上鑄造了cBTC(一種封裝比特幣),標志著Cardano生態系統向前邁出了一大步。據悉,AnetaBTC是第一個在Cardano實現這一功能的項目。
CBTC是Cardano上的一種比特幣資產,類似于ETH上的封裝比特幣wBTC,但沒有中心化托管人。封裝資產有助于橋接來自其他生態系統的流動性,而在Cardano上的封裝比特幣可能有助于釋放比特幣市場的流動性。
在鑄造cBTC時,用戶將自己的ADA地址添加到BTC TX元數據中,存入BTC,然后由AnetaBTC進行處理和確認。cBTC被鑄造,然后發送到用戶的Cardano錢包。(U.Today)[2023/3/5 12:43:36]
可以看到該函數會將流動性池中兩種流動性代幣的balance和reserve差值數量的代幣轉移到to地址。
流動性池中除了這兩種代幣外,也會因為誤轉、空投等原因存在其他的ERC?20代幣,如何提取這一部分的代幣呢?
對Pair合約的代碼分析后發現無法提取這一部分代幣,只有一種情況例外:當流動性池中存在該池的LP代幣時。
出現這種情況我們可以調用Pair合約的?burn?函數,移除流動性,取出相應的兩種流動性代幣:
UniswapV3SwapRouter
UniswapV3的SwapRouter合約中也會存在和UniswapV2Router一樣的情況,存在ERC?20代幣和ETH,但是幸運的是SwapRouter合約提供了幾個函數可以方便提取其中的代幣。
Cardano將于2月11日把預生產環境升級至協議V8:2月9日消息,Cardano 開發公司 Input Output 與 Cardano 基金會提交更新提案,旨在將 Cardano 預生產環境升級至協議 V8,這將于 2023 年 2 月 11 日 08:00 生效。Input Output 表示,本次升級將為 Cardano 帶來新的加密原語,鼓勵與 Plutus 更好的互操作性和安全的跨鏈 DApp 開發。該環境將允許社區在 2 月 14 日主網上 SECP 升級倒計時之前繼續進行最后階段的集成和升級測試。
SECP(加密原語)的示例包括橢圓曲線數字簽名算法 (ECDSA) 和 Schnorr 簽名。這些允許用戶驗證特定簽名哈希數據的完整性。在新的加密原語實施后,Plutus 將能夠使用 ECDSA 和 Schnorr 標準輕松驗證來自其他區塊鏈的交易。[2023/2/9 11:57:25]
提取ERC?20代幣我們可以使用?sweepToken?函數:
提取ETH我們可以使用?refundETH?函數:
也能夠直接調用?unwrapWETH?9??函數將WETH還原成ETH并提取出來:
以上是對UniswapV3SwapRouter合約的套利分析。
在對Uniswap?V3?Pool合約的代碼進行分析后,發現沒有辦法提取其合約中的其他代幣,也不存在如UniswapV2Pair合約中balance和reserve有差值的情況。
特拉斯當選英國保守黨新黨首 將出任英國新任首相:9月5日消息,當地時間9月5日,英國議會下院保守黨籍議員團體“1922委員會”主席格雷厄姆·布雷迪公布了保守黨黨首選舉的投票結果。現任外交大臣伊麗莎白·特拉斯擊敗前財政大臣里希·蘇納克,當選為英國執政的保守黨新黨首。6日,現年47歲的特拉斯將前往蘇格蘭接受英國女王伊麗莎白二世的正式任命,成為英國新任首相。隨后,特拉斯將返回倫敦,在首相府門前發表就職演講,并公布新內閣成員名單。(財聯社)[2022/9/5 13:10:00]
SushiSwap
SushiSwap最初是一個Uniswap的分叉項目,后來發展成為一個獨立的生態系統,提供了許多不同的金融服務和產品。
因為SushiSwap和UniswapV2一樣,因此上述的針對UniswapV2的套利手段對與SushiSwap也同樣適用。
SushiXSwap
SushiXSwap是SushiSwap推出的基于LayerZero的全鏈交易協議,支持的網絡包括?Optimism、Arbitrum、Fantom、BNB?Chain、Polygon?和?Avalanche。用戶可以在支持的網絡以及資產之間進行跨鏈交易。
如何提取SushiXSwap合約中的代幣呢?
SushiXSwap中主要的功能都通過?cook?函數實現,該函數提供了一系列的操作,支持操作列表如下:
其中有一個操作?ACTION_DST_WITHDRAW_TOKEN,其代碼實現如下:
首先將傳入?cook?函數的data進行解碼,然后判斷amount是否等于?0?,等于?0?則將amount的值設為該合約的ERC?20代幣的余額或者ETH的余額。最后調用?_transferTokens?將代幣轉移到指定的地址:
報告:全球區塊鏈物聯網產業規模預計到2027年將達到52億美元:金色財經報道,根據Research And Markets發布的報告,據估計,2021年全球區塊鏈物聯網市場規模為5.4406億美元,2022年為7.9238億美元,預計將以45.81%的復合年增長率(CAGR)增長,到2027年將達到52.3012億美元。(BusinessWire)[2022/6/2 3:57:08]
因此我們只需要構造傳入?cook?函數的actions和datas,即將actions設置為?ACTION_DST_WITHDRAW_TOKEN?,在data中構造想要轉移的代幣、接收地址、數量,即可轉移出SushiXSwap合約中的代幣。
SushiBentoBox
SushiBentoBox是SushiSwap生態系統中的一個組件。BentoBox是一個高度靈活的去中心化金融利率優化產品。簡單來說,它是一個允許用戶存儲、借用和賺取利息的智能合約平臺。BentoBox的主要目的是優化用戶在DeFi領域中的收益。
以太坊上的BentoBox合約中存儲了大量了代幣,那么該合約是否存在套利的空間呢?
在BentoBox合約中用戶可以通過?deposit?函數進行存款操作,函數的實現如下:
可以看到用戶傳入指定的代幣地址,扣款地址,接收地址,數量,股份數量,函數首先做了一系列校驗,然后將amount或者share進行轉換,關鍵點在195-198行,這里做了一個校驗:amount<=_tokenBalanceOf(token).sub(total.elastic)。
在BentoBox合約中某種代幣的余額使用的是?total.elastic?來記錄,類似UniswapPair合約中的reserve,某些情況下會和?_tokenBalanceOf(token)?產生差值,我們可以利用?deposit?函數這里的特性,將差值部分真實轉換成自己在BentoBox合約中的余額。
因此我們傳入參數時將token設置為存在差值的代幣地址,將amount的值設置為差值,然后將from設置為BentoBox合約的地址,將to設置為自己的地址,在207?行時由于地址為BentoBox合約地址,因此不會進行轉賬,只是平衡了total.elastic?和?_tokenBalanceOf(token)?的值,將其轉換為to地址在合約內的余額。
DODO
DODO是一個去中心化交易平臺,使用獨創的主動做市商算法為Web3資產提供高效的鏈上流動性。DODO既自己提供流動性,也聚合其它交易所的流動性。
DODO有一系列合約,其中用戶會通過DODO?V2?Proxy?02合約進行代幣的兌換。和UniswapRouter合約類似,該合約也會因為各種原因存在一些代幣,我們應當如何提取這些代幣?
DODO?V2?Proxy?02?
在DODO?V2?Proxy?02合約中存在?externalSwap函數,用來調用DODO聚合的外部平臺進行兌換,如?0x?,?1inch,代碼實現如下:
1719-1721?行在對傳入的參數做校驗,然后?1724?行校驗fromToken是否為ETH,不是的話則會將調用者的代幣轉移到合約中,然后進行授權,在分析了DODOAPPROVE?合約的代碼后發現只需要將fromTokenAmount設置為?0?即可繞過:
然后會對調用的外部合約做校驗,是白名單內的才能夠調用,這里的?swapTarget,calldataConcat都是由用戶可控的,因此可以將?swapTarget?設置為0x或者1inch的合約地址,然后?calldataConcat?設置為其合約的view函數的編碼,從而讓返回的值為true,也能通過后面的require校驗:
接下來會將合約中的toToken,全部轉移給調用者,這里的toToken可以是ERC?20代幣,也可以是ETH,發送完后會進行最小的預期數量校驗,我們將?minReturnAmount?的值設置為非常小的值即可通過。最后兩個函數調用無關緊要。
通過以上的步驟我們就能夠提取出DODO?V2?Proxy?02合約中的ERC?20代幣以及ETH。
1inch
1inch是一個去中心化交易所聚合器,它從多個DEX中匯集流動性,以便為用戶提供最佳的代幣兌換價格。通過整合來自不同來源的流動性,1inch幫助用戶優化交易并在各個平臺之間找到最優惠的價格。1inch的智能合約自動在各個去中心化交易所之間進行交易,使用戶能夠輕松地在不同交易所之間獲取最佳價格和最低滑點。此外,1inch還提供了其他功能,如流動性挖礦和治理代幣。
1inch的主要合約是AggregationRouter,現在使用較多的是V?4和V?5版本,這兩個合約也會因為各種原因存在一些代幣,我們可以通過構造的傳入函數中的參數,提取合約中的代幣。
AggregationRouterV?5?
AggregationRouterV?5合約存在?swap?函數,其實現如下:
校驗了desc中的minReturnAmount后,從desc中獲取srcToken和dstToken,接下來986-997?行可以通過構造desc結構體中的flags和srcToken進行繞過:
然后執行函數?_execute,這里會進行call調用,并會校驗執行狀態,由于executor由用戶傳入,因此這里我們可以使用?0?地址進行繞過:
然后獲取合約中dstToken的余額。1007-1018?行我們可以構造desc中flags以及minReturnAmount進行繞過:
最后會將合約中的dstToken余額都轉到dstReceiver地址中,該地址也由用戶控制:
通過以上的步驟,我們能構造傳入?swap?函數的參數從而將AggregationRouterV?5合約中的代幣提走。
AggregationRouterV?4?
AggregationRouterV?4與AggregationRouterV?5差別不大,AggregationRouterV?4中也存在?swap?函數,實現如下:
可以發現跟AggregationRouterV?5的?swap?函數的實現是一樣的,只是AggregationRouterV?5對call進行了優化,因此使用和AggregationRouterV?5一樣的方法即可提取出存在AggregationRouterV?4合約中的代幣。
總結
本文簡單介紹了部分去中心化交易所以及聚合器,并探討了其中可能存在的套利,從合約代碼層面分析了套利的原理,但在實際中能否成功還和諸多因素相關,如GAS,節點速度等。
NexGenVenture是一家規模超千萬美元的基金,是一個聚焦年輕degen與青年才俊的投資機構,并且堅信新時代年輕力量有潛力塑造并賦能超萬億美元加密貨幣市場的未來.
1900/1/1 0:00:00自第一個加密貨幣出現以來,單體區塊鏈一直是行業標準,但這種情況正在迅速改變。2023年,隨著以太坊合并成功、Layer2Rollups生態爆發,以太坊系統轉向了模塊化架構.
1900/1/1 0:00:00注:本文來自@BirkSamo推特,MarsBit整理如下:有小伙伴轉了這條Thread,問我咋看,我們討論完感覺自己寫的好牛逼啊,遂發出來分享一下.
1900/1/1 0:00:00VC協議是最受關注、最難理解的文件之一。什么是「骯臟條款」,什么是「標準條款」?前Point72員工@FabiusMercurius發布了詳細推文,整理行內VC潛規則和條款.
1900/1/1 0:00:00備受矚目的2023香港Web3嘉年華將在本周拉開帷幕。本次活動由萬向區塊鏈實驗室、Hashkey協辦,即將聚集上百個Web3領先項目,香港特別行政區政府財政司司長、Binance創始人,OKX總.
1900/1/1 0:00:00Hermes是一個建立在Metis上的DEX,目前正在進行V2版本的開發。該版本將包括全鏈擴展、統一流動性、去中心化流動性管理和新的Gauge系統等重大升級.
1900/1/1 0:00:00