買比特幣 買比特幣
Ctrl+D 買比特幣
ads
首頁 > 屎幣 > Info

ROUTE:通過代碼看出DeFi中的套利機會_OUT價格

Author:

Time:1900/1/1 0:00:00

概述

去中心化金融是一種創建于區塊鏈上的金融,它不依賴券商、交易所或銀行等金融機構提供金融工具,而是利用區塊鏈上的智能合約進行金融活動。在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合約中的該代幣的余額。

因此根據上述分析,我們能得到一個套利的流程:

監控到Router?02合約存在ERC?20代幣;

監控到Router?02合約存在ERC?20代幣;

Web3游戲生態系統Fastex通過代幣銷售籌集2320萬美元:金色財經報道,由SoftConstruct孵化的Web3游戲生態系統 Fastex 通過出售其代幣 Fasttoken (FTN) 籌集了 2320 萬美元。FTN 是一種建立在以太坊 ( ETH-USD ) 網絡上的 ERC-20 加密貨幣,作為 Fastex 經濟的實用代幣,該代幣解鎖了 Fastex 生態系統中托管的所有 Web3 產品和服務。已有 100 多家游戲提供商采用 FTN 為其 GameFi 游戲提供支持。

籌集的資金將推動 Fastex 生態系統的發展,其中包括 Fastex Chain、ftNFT 市場、Fastex Pay 和 Fastex Verse metaverse。[2023/2/9 11:55:44]

調用addLiquidityETH添加該ERC?20代幣和WETH的流動性;

調用removeLiquidityETHSupportingFeeOnTransferTokens移除流動性。

局限性:

如果該代幣之前沒有和WETH組流動性,當第一次添加流動性時會損失一小部分流動性;

暫時未發現提取Router?02合約中的WETH和ETH的方法。

UniswapV2Pair

UniswapV2Pair合約,即所謂的流動性池,存儲著提供流動性的?2?種代幣,因為Pair合約中使用的是reserve來記錄余額而不是balanceOf(address(this)),因此有人直接誤轉流動性代幣到合約中時會出現balance和reserve出現差值,而Pair合約中存在平衡函數skim,我們可以調用該函數將這差值數量的代幣給提取出來:

可以看到該函數會將流動性池中兩種流動性代幣的balance和reserve差值數量的代幣轉移到to地址。

Web3人才網絡Braintrust通過代幣私募融資1億美元,Coatue領投:12月9日消息,Web3人才網絡Braintrust通過代幣私募融資1億美元,Coatue領投,Tiger Global、True Ventures、Blockchain Ventures、HashKey等參投。

據悉,Braintrust旨在將公司與Web3領域的技術人員聯系起來,該公司聲稱擁有70多萬名社區成員。根據周四的公告,Braintrust將使用這些資金來擴大其網絡,并通過贈款為社區項目提供資金。該公司表示,其70多萬會員都有資格申請旨在改善網絡的項目資助。(The Block)[2021/12/9 7:28:57]

流動性池中除了這兩種代幣外,也會因為誤轉、空投等原因存在其他的ERC?20代幣,如何提取這一部分的代幣呢?

對Pair合約的代碼分析后發現無法提取這一部分代幣,只有一種情況例外:當流動性池中存在該池的LP代幣時。

出現這種情況我們可以調用Pair合約的burn函數,移除流動性,取出相應的兩種流動性代幣:

UniswapV3SwapRouter

UniswapV3的SwapRouter合約中也會存在和UniswapV2Router一樣的情況,存在ERC?20代幣和ETH,但是幸運的是SwapRouter合約提供了幾個函數可以方便提取其中的代幣。

提取ERC?20代幣我們可以使用sweepToken函數:

提取ETH我們可以使用refundETH函數:

區塊鏈游戲GEOPOLY通過代幣私募融資300萬美元:12月6日消息,區塊鏈游戲GEOPOLY通過代幣私募在48小時內籌集300萬美元。GEOPOLY已發布其網站和白皮書。該項目已開始社區建設,計劃于12月12日進行NFT預售。Beta V2發布將在2021年Q4和2022年Q1之間的某個時間進行。GEOPOLY代幣也將在該時間段內推出,用戶可以在游戲中使用。GEO代幣將使用戶能夠在網絡和鏈上以NFT的形式購買、升級和銷售業務。GEO代幣將于2022年1月在中心化交易所上線。

公開TGE(代幣生成活動)將于12月15日在SushiSwap上進行,對所有人開放。PvP(玩家對玩家)原型發布、拍賣和候選發布計劃于2022年進行。(Bitcoinist)[2021/12/6 12:54:14]

也能夠直接調用unwrapWETH?9?函數將WETH還原成ETH并提取出來:

以上是對UniswapV3SwapRouter合約的套利分析。

在對Uniswap?V3?Pool合約的代碼進行分析后,發現沒有辦法提取其合約中的其他代幣,也不存在如UniswapV2Pair合約中balance和reserve有差值的情況。

SushiSwap

SushiSwap最初是一個Uniswap的分叉項目,后來發展成為一個獨立的生態系統,提供了許多不同的金融服務和產品。

因為SushiSwap和UniswapV2一樣,因此上述的針對UniswapV2的套利手段對與SushiSwap也同樣適用。

SushiXSwap

SushiXSwap是SushiSwap推出的基于LayerZero的全鏈交易協議,支持的網絡包括Optimism、Arbitrum、Fantom、BNBChain、Polygon和Avalanche。用戶可以在支持的網絡以及資產之間進行跨鏈交易。

DeFi協議Sovryn通過代幣銷售融資1000萬美元:3月3日消息,基于比特幣的DeFi協議Sovryn宣布,該公司已通過代幣預售融資1000萬美元。聯合創始人Yago表示,籌集的資金將保留在議定書的金庫中,社區將決定如何使用它們。(TheBlock)[2021/3/3 18:11:41]

如何提取SushiXSwap合約中的代幣呢?

SushiXSwap中主要的功能都通過cook函數實現,該函數提供了一系列的操作,支持操作列表如下:

其中有一個操作ACTION_DST_WITHDRAW_TOKEN,其代碼實現如下:

首先將傳入cook函數的data進行解碼,然后判斷amount是否等于?0?,等于?0?則將amount的值設為該合約的ERC?20代幣的余額或者ETH的余額。最后調用_transferTokens將代幣轉移到指定的地址:

因此我們只需要構造傳入cook函數的actions和datas,即將actions設置為ACTION_DST_WITHDRAW_TOKEN,在data中構造想要轉移的代幣、接收地址、數量,即可轉移出SushiXSwap合約中的代幣。

SushiBentoBox

SushiBentoBox是SushiSwap生態系統中的一個組件。BentoBox是一個高度靈活的去中心化金融利率優化產品。簡單來說,它是一個允許用戶存儲、借用和賺取利息的智能合約平臺。BentoBox的主要目的是優化用戶在DeFi領域中的收益。

動態 | 門羅幣網站錢包通過代碼審計 安全漏洞已修復:據Cointelegraph報道,門羅幣網站錢包XMRWallet宣布,已通過區塊鏈策略和科技顧問集團New Alchemy對其進行的代碼審計,“一些潛在的漏洞”現已得到修復,其風險得到緩解。

據悉,審計對象包括其網站流量和用戶界面等。[2018/7/25]

以太坊上的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,節點速度等。

參考?Reference

如何從defi中撿錢

WhatIsUniswap

SUshiAcademy

AboutDODO

1inchaggregationprotocol

關于我們

AtEoceneResearch,weprovidetheinsightsofintentionsandsecuritybehindeverythingyouknowordon'tknowofblockchain,andempowereveryindividualandorganizationtoanswercomplexquestionswehadn'tevendreamedofbackthen.

了解更多:Website|Medium|Twitter

來源:星球日報

Tags:SWAPTEROUTROUTEKokomoSwaptera幣錢包OUT價格ROUTE價格

屎幣
BASE:Bankless:一覽五大新興L2項目 如何進行早期交互?_worlddatabase

原文作者:Bankless原文編譯:MaryLiu,比推BitpushNews一年前,以太坊第二層(L2)擴展解決方案賽道的「四大」領頭羊是:Arbitrum、Optimism、zkSync和S.

1900/1/1 0:00:00
STA:值得關注的一些比特幣L2敘事項目_STACK

作者:James,Nest.fi;翻譯:金色財經0x25雖然比特幣長期以來一直被稱為安全和去中心化的價值存儲或“數字黃金”,但其支持更高級應用程序的潛力相對尚未開發.

1900/1/1 0:00:00
WOO:外部壓力下 DeFi之夏還能否重現?_DEF

狂熱的“DeFi之夏”在加密歷史中留下了濃墨重彩的一筆,而如今由于宏觀經濟狀況的惡化以及監管等因素造成的下行壓力.

1900/1/1 0:00:00
區塊鏈:警惕谷歌搜索廣告的區塊鏈騙局_GLEEC

背景 最近幾周ScamSniffer陸續收到多個用戶被搜索廣告釣魚的案例,他們都無一不例外錯點了Google的搜索廣告從而進入到惡意網站,并在使用中過程簽署了惡意簽名,最終導致錢包里的資產丟失.

1900/1/1 0:00:00
OIN:一文速覽如何參與SUI代幣銷售?_SUIA價格

原文作者:CryptoNova原文編譯:Felix,PANewsSui?的代幣銷售剛剛宣布將在本周進行,這里有你想了解關于?Sui?的所有信息,以及如何參與?SUI?代幣銷售.

1900/1/1 0:00:00
OSM:嚇得我一激靈:暗網銷售KYC錢包真相_evmos幣ieo價格

此前,CertiK對KYC黑市、演員雇傭以及KYC買賣曾做過一些調研。包括Telegram和Discord的各類平臺上都有兜售已通過KYC驗證的Web3.0交易所賬戶服務,包括KYC演員買賣等.

1900/1/1 0:00:00
ads