国产乱人伦在线播放,99无码精品二区在线视频,最近在线更新8中文字幕免费,精品成人一区二区三区四区

您的位置:首頁 > 互聯(lián)網(wǎng) >

AirSwap公布智能合約的致命漏洞 用戶資產(chǎn)可被對(duì)手惡意偷盜

2019-10-09 11:39:32 來源: 鏈聞

2019 年 09 月 13 日 AirSwap 團(tuán)隊(duì)公布了一個(gè) AirSwap 智能合約中存在致命的漏洞,這一漏洞可以使得用戶的資產(chǎn)在某些情況下被對(duì)手惡意吃單『偷盜

2019 年 09 月 13 日 AirSwap 團(tuán)隊(duì)公布了一個(gè) AirSwap 智能合約中存在致命的漏洞,這一漏洞可以使得用戶的資產(chǎn)在某些情況下被對(duì)手惡意吃單『偷盜』,PeckShield 安全人員獨(dú)立分析了該漏洞,并與 AirSwap 團(tuán)隊(duì)溝通了細(xì)節(jié)和修復(fù)方案。

漏洞影響概述

PeckShield 安全人員深入分析 AirSwap 智能合約后發(fā)現(xiàn),這一漏洞只對(duì)最近上線的 Wrapper 有影響,AirSwap 團(tuán)隊(duì)在發(fā)現(xiàn)該問題后第一時(shí)間下線當(dāng)前合約,并將 AirSwap 網(wǎng)站回退到之前使用的合約,從合約上線到問題修復(fù)整個(gè)過程僅持續(xù)了 24 小時(shí),可見 AirSwap 團(tuán)隊(duì)對(duì)于合約安全的重視程度之高。

PeckShield 安全人員獨(dú)立分析了漏洞細(xì)節(jié),并與 AirSwap 團(tuán)隊(duì)溝通細(xì)節(jié)和修復(fù)的方案, 同時(shí)將該漏洞命名為“ItchySwap”。

PeckShield 在此提醒,由于這一漏洞可使用戶的資產(chǎn)被攻擊者惡意偷盜,受此次影響的賬號(hào)一共有 18 個(gè),其中有部分賬號(hào)有數(shù)萬至數(shù)十萬美元的資產(chǎn),這些賬號(hào)需要盡快完成升級(jí),或與 AirSwap 團(tuán)隊(duì)聯(lián)系。

ItchySwap 漏洞詳解

一、AirSwap 合約

在分析之前,為方便起見,我們先定義幾個(gè)概念:

1. maker:出售資產(chǎn)的一方;

2. taker:購買資產(chǎn)的一方;

3. order: maker 與 taker 之間發(fā)生資產(chǎn)交割的訂單;

4. Indexer: AirSwap 中的訂單簿,匯聚了當(dāng)前正在出售及需要購買的資產(chǎn)信息。

下圖說明了 maker、taker 和 Indexer 之間的交互流程:

**

**

AirSwap 智能合約漏洞詳解:用戶資產(chǎn)可被攻擊者惡意吃單?

AirSwap 是一個(gè)基于 Ethereum 的點(diǎn)對(duì)點(diǎn)去中心化交易所,它集成了 Swap Protocol ,在其中作為一個(gè)自動(dòng)托管服務(wù),允許交易的雙方(即 maker 和 taker)在以太坊上安全地交易任何資產(chǎn)。與許多去中心化交易所不同,AirSwap 雖然沒有對(duì)資金進(jìn)行托管控制,但仍然有一個(gè)用于匹配目的的集中式訂單簿,它實(shí)現(xiàn)了一個(gè)用于交易和訂單匹配的完全對(duì)等模型。

特別值得一提的是,有一個(gè)名為 Indexer 的鏈下服務(wù),可以聚合來自 maker 和 taker 的交易意圖,然后為他們提供匹配的服務(wù)。特別是,一旦 taker 找到了合適的 maker,他們就會(huì)開始進(jìn)行場外價(jià)格的談判。一旦達(dá)成協(xié)議,訂單將由 Taker 通過 Swap Protocol 在鏈上進(jìn)行填充和資產(chǎn)交割。

在 AirSwap 智能合約中, taker 將訂單上鏈及資產(chǎn)交割的過程在 AirSwap swap(Types.Order calldata_order) 函數(shù)之中,這一函數(shù)實(shí)現(xiàn)如下所示:

AirSwap 智能合約漏洞詳解:用戶資產(chǎn)可被攻擊者惡意吃單?

1)驗(yàn)證訂單有效性

訂單 order 參數(shù)有效性檢查,這些信息均由 taker 上鏈的時(shí)候指定的,也意味著這些信息都可以由 taker 篡改,具體包含:

1. 訂單還在有效期內(nèi);

2. 訂單還沒有被其它的 taker 吃單;

3. 訂單還沒有被取消;

4. 訂單的 nonce 大于最小值;

5. 設(shè)置訂單狀態(tài)為 TAKEN 狀態(tài)。

2)驗(yàn)證 taker 信息

AirSwap 智能合約漏洞詳解:用戶資產(chǎn)可被攻擊者惡意吃單?

確立有效的 taker,根據(jù) order 中指定或者等同于合約的調(diào)用方 msg.sender。

3)驗(yàn)證 maker 信息

AirSwap 智能合約漏洞詳解:用戶資產(chǎn)可被攻擊者惡意吃單?

驗(yàn)證 maker 的有效性,這里的驗(yàn)證分為兩種情況考慮:

1. 沒有 maker 簽名的訂單:需要保證 msg.sender 有權(quán)限操作這個(gè) maker 地址即可,即這筆 order 發(fā)起者有權(quán)限操作 maker 的資產(chǎn);

2. order 中指定了 maker 的簽名信息:驗(yàn)證簽名的有效性。

4) 資產(chǎn)交割**

**

AirSwap 智能合約漏洞詳解:用戶資產(chǎn)可被攻擊者惡意吃單?

如果上述的驗(yàn)證流程沒有問題,那么直接執(zhí)行 maker 和 taker 的資產(chǎn)交割。

二、Wrapper 合約

在上述的 AirSwap 合約中,用戶通過 swap() 函數(shù)執(zhí)行資產(chǎn)互換,這一流程非常清晰,沒有問題。但是這一合約存在一點(diǎn)不完美的地方,用戶只能通過 Token 進(jìn)行資產(chǎn)互換,無法直接用 ETH 平臺(tái)幣參與其中。用戶可以先把 ETH 轉(zhuǎn)換成 WETH, 再用 WETH 參與互換,但無論如何,用戶使用體驗(yàn)上多了一步。

為了降低用戶使用體驗(yàn)上的摩擦,AirSwap 團(tuán)隊(duì)與 2019 年 09 月 12 日 推出了 Wrapper 合約,其使用是自動(dòng)將用戶轉(zhuǎn)入的 ETH 轉(zhuǎn)換成 WETH 之后再參與資產(chǎn)互換的過程,其關(guān)鍵流程如下:

AirSwap 智能合約漏洞詳解:用戶資產(chǎn)可被攻擊者惡意吃單?

1. 驗(yàn)證 swap() 發(fā)起方與 taker 是相同的;

2. 如果用戶發(fā)起 swap() 有攜帶了 ETH 資產(chǎn),并且需要轉(zhuǎn)換的 token 為 WETH, 那么就自動(dòng)將 ETH 轉(zhuǎn)換成 WETH;

3. 直接調(diào)用 AirSwap 合約的 swap() 操作。

考慮到一種特殊的場景,Alice 希望通過 Wrapper 合約執(zhí)行 AirSwap 資產(chǎn)互換,這一過程需要先由 Alice 自行在 AirSwap 合約中授權(quán) Wrapper 合約,以允許 Wrapper 合約可以執(zhí)行各自的資產(chǎn)交割流程。

由于區(qū)塊鏈的透明性,Eve 看到了 Alice 的授權(quán)操作,那么他就可以向 Wrapper 合約發(fā)起一筆惡意的訂單,其包含的內(nèi)容如下:

1. order 中的有效時(shí)間、nonce 為一個(gè)非常大的數(shù)值;

2. order 中的 maker 對(duì)應(yīng)的賬號(hào)為 Alice 的賬號(hào);

3. order 中的 taker 為空;

4. order 的 signature 為空。

將上述構(gòu)造好的 order 代入 AirSwap 的 swap() 函數(shù),其中 1,2 兩步的驗(yàn)證由于是 taker 控制的,不會(huì)有問題,我們重點(diǎn)看下第三步驗(yàn)證 maker 信息:

AirSwap 智能合約漏洞詳解:用戶資產(chǎn)可被攻擊者惡意吃單?

由于此時(shí) AirSwap 合約是由 Wrapper 合約調(diào)用的,那么 msg.sender 即 Wrapper 合約的地址,前文講到,Wrapper 合約是經(jīng)過 Alice 授權(quán)可直接控制 Alice 的資產(chǎn),此時(shí)雖然 Eve 沒有權(quán)限操作 Alice 的資產(chǎn),但此時(shí)可以通過 Wrapper 控制,也就間接地控制了 Alice 的資產(chǎn)。

安全規(guī)避

PeckShield 安全人員分析發(fā)現(xiàn),截止至 2019 年 09 月 28 日為止,共有 6 個(gè)賬號(hào)執(zhí)行了revoke()操作,以解除對(duì)Wrapper合約的授權(quán),還有 12 個(gè)賬號(hào)存在安全風(fēng)險(xiǎn),這剩下的所有賬號(hào)應(yīng)當(dāng)立即執(zhí)行revoke()操作,或者將賬號(hào)中的資產(chǎn)轉(zhuǎn)移至未對(duì)Wrapper授權(quán)過的安全賬號(hào)。

任何的代碼在上線生產(chǎn)環(huán)境之前都應(yīng)當(dāng)?shù)玫匠浞值臏y試和驗(yàn)證,特別是承載著用戶價(jià)值的 DEX 平臺(tái)。在產(chǎn)品增加新特性之時(shí),一定要考慮到舊特性的兼容性與安全,新特性的引入不應(yīng)該觸發(fā)舊產(chǎn)品中設(shè)計(jì)不完備的地方。

附錄

AirSwap 智能合約漏洞詳解:用戶資產(chǎn)可被攻擊者惡意吃單?

關(guān)鍵詞: AirSwap 智能合約 致命漏洞

精選 導(dǎo)讀

募資55億港元萬物云啟動(dòng)招股 預(yù)計(jì)9月29日登陸港交所主板

萬科9月19日早間公告,萬物云當(dāng)日啟動(dòng)招股,預(yù)計(jì)發(fā)行價(jià)介乎每股47 1港元至52 7港元,預(yù)計(jì)9月29日登陸港交所主板。按發(fā)行1 167億股計(jì)算,萬

發(fā)布時(shí)間: 2022-09-20 10:39
管理   2022-09-20

公募基金二季度持股情況曝光 隱形重倉股多為高端制造業(yè)

隨著半年報(bào)披露收官,公募基金二季度持股情況曝光。截至今年二季度末,公募基金全市場基金總數(shù)為9794只,資產(chǎn)凈值為269454 75億元,同比上

發(fā)布時(shí)間: 2022-09-02 10:45
資訊   2022-09-02

又有上市公司宣布變賣房產(chǎn) 上市公司粉飾財(cái)報(bào)動(dòng)作不斷

再有上市公司宣布變賣房產(chǎn)。四川長虹25日稱,擬以1 66億元的轉(zhuǎn)讓底價(jià)掛牌出售31套房產(chǎn)。今年以來,A股公司出售房產(chǎn)不斷。根據(jù)記者不完全統(tǒng)

發(fā)布時(shí)間: 2022-08-26 09:44
資訊   2022-08-26

16天12連板大港股份回復(fù)深交所關(guān)注函 股份繼續(xù)沖高

回復(fù)交易所關(guān)注函后,大港股份繼續(xù)沖高。8月11日大港股份高開,隨后震蕩走高,接近收盤時(shí)觸及漲停,報(bào)20 2元 股。值得一提的是,在7月21日

發(fā)布時(shí)間: 2022-08-12 09:56
資訊   2022-08-12

萬家基金再添第二大股東 中泰證券擬受讓11%基金股權(quán)

7月13日,中泰證券發(fā)布公告,擬受讓齊河眾鑫投資有限公司(以下簡稱齊河眾鑫)所持有的萬家基金11%的股權(quán),交易雙方共同確定本次交易的標(biāo)的資

發(fā)布時(shí)間: 2022-07-14 09:39
管理   2022-07-14

央行連續(xù)7日每天30億元逆回購 對(duì)債市影響如何?

央行12日再次開展了30億元逆回購操作,中標(biāo)利率2 10%。這已是央行連續(xù)7日每天僅進(jìn)行30億元的逆回購縮量投放,創(chuàng)下去年1月以來的最低操作規(guī)

發(fā)布時(shí)間: 2022-07-13 09:38
資訊   2022-07-13

美元指數(shù)創(chuàng)近20年新高 黃金期貨創(chuàng)出逾9個(gè)月新低

由于對(duì)美聯(lián)儲(chǔ)激進(jìn)加息的擔(dān)憂,美元指數(shù)11日大漲近1%創(chuàng)出近20年新高。受此影響,歐美股市、大宗商品均走弱,而黃金期貨創(chuàng)出逾9個(gè)月新低。美

發(fā)布時(shí)間: 2022-07-13 09:36
資訊   2022-07-13

美股三大股指全線下跌 納斯達(dá)克跌幅創(chuàng)下記錄以來最大跌幅

今年上半年,美股持續(xù)回落。數(shù)據(jù)顯示,道瓊斯指數(shù)上半年下跌15 3%,納斯達(dá)克綜合指數(shù)下跌29 5%,標(biāo)普500指數(shù)下跌20 6%。其中,納斯達(dá)克連續(xù)

發(fā)布時(shí)間: 2022-07-04 09:51
推薦   2022-07-04

融資客熱情回升 兩市融資余額月內(nèi)增加超344億元

近期A股走強(qiáng),滬指6月以來上漲4%,融資客熱情明顯回升。數(shù)據(jù)顯示,截至6月16日,兩市融資余額1 479萬億元,月內(nèi)增加344 67億元,最近一個(gè)半

發(fā)布時(shí)間: 2022-06-20 09:41
資訊   2022-06-20

4個(gè)交易日凈買入超百億元 北向資金持續(xù)流入A股市場

北向資金凈流入態(tài)勢延續(xù)。繼6月15日凈買入133 59億元后,北向資金6月16日凈買入44 52億元。自5月27日至今,除6月13日以外,北向資金累計(jì)凈

發(fā)布時(shí)間: 2022-06-17 09:37
推薦   2022-06-17

熱門TAG

more
美聯(lián)儲(chǔ)今年已將基準(zhǔn)利率從接近零大幅上調(diào)至略高于3% EIA報(bào)告:美國原油庫存及戰(zhàn)略儲(chǔ)備減少,汽油及精煉油庫存輕微波動(dòng) 美國政府更廣泛推動(dòng)從汽油動(dòng)力汽車轉(zhuǎn)向電動(dòng)汽車的一部分 數(shù)據(jù)顯示:今年9月日本船企接單量延續(xù)8月下跌下跌趨勢 公告顯示:2022年前三季度TCL中環(huán)研發(fā)投入為27億元 占比營業(yè)收入5.42% 新的111.75億英鎊注資列在“對(duì)金融機(jī)構(gòu)的援助—支付給英格蘭銀行”標(biāo)題下 本次政府儲(chǔ)備肉投放面向北京18家主要連鎖超市門店及相關(guān)零售終端投放 有交易員預(yù)計(jì):如果LME不采取措施 接下來可能將有數(shù)十萬噸鋁流入LME 據(jù)報(bào)道:繼德國最大釀酒商拉德貝格啤酒公司9月宣布漲價(jià) 據(jù)報(bào)道:澳大利亞礦商Pilbara的鋰礦拍賣價(jià)再創(chuàng)新高 折算后的碳酸鋰成本 中集天達(dá)首次公開發(fā)行A股股票 招股書顯示此次擬公開發(fā)行股數(shù)不超過103, 多家銀行加強(qiáng)綠色金融頂層設(shè)計(jì) 致力于為經(jīng)濟(jì)社會(huì)綠色低碳轉(zhuǎn)型貢獻(xiàn)力量 萊特幣 比特幣 數(shù)字資產(chǎn) 火幣 以太經(jīng)典 比特股 EOS 比特幣現(xiàn)金 量子鏈 Hcash 泰達(dá)幣 瑞波幣 Qcash 比特幣鉆石 超級(jí)比特幣 優(yōu)幣 硬分叉 加密貨幣