Безопасность

ZenGo призывает решить проблему безопасности кошельков dApp

Команда криптовалютного кошелька ZenGo без закрытых ключей и паролей обнаружила уязвимость, которая может стать причиной кражи токенов пользователей практически со всех кошельков dApp.

Несмотря на то, что об этой проблеме безопасности известно уже два года, генеральный директор ZenGo Уриэль Охайон (Ouriel Ohayon) бьет тревогу, утверждая, что уязвимость представляет опасность для пользователей. Уязвимость BaDApprove — это не ошибка кода. Проблема заключается в том, как кошельки взаимодействуют с пользователями и устанавливают разрешения транзакций по умолчанию.

В рамках исследования крупнейших кошельков, включая Metamask, Opera и imToken, Охайон обнаружил, что, когда пользователи одобряют определенную транзакцию, они часто по умолчанию одобряют все будущие транзакции. Это открывает путь для взаимодействия мошеннических децентрализованных приложений с со средствами пользователей без их ведома или согласия, даже путем кражи всех активов.

Ошибка хорошо документирована, однако расследование Охайона вновь поднимает один из базовых вопросов криптовалютной индустрии: должны ли криптовалютные компании делать все возможное для защиты пользователей или же владельцы криптовалют должны нести полную ответственность за свои цифровые активы?

Команда ZenGo организовала демонстрацию dApp, чтобы предупредить пользователей об этой уязвимости. На видео показан пользователь, который отправляет несколько FRT (валюта тестовой сети) в «мошенническое приложение для обмена» и позволяет ему вывести указанные токены и автоматизировать транзакции. Затем BaDApprove dApp выводит все средства с баланса пользователя.

Ситуация усугубляется тем, что многие кошельки не сообщают своим пользователям об этих разрешениях. Исследователь Tendermint и Cosmos Санни Аггарвал (Sunny Aggarwal) провел симуляцию и подтвердил наличие проблемы.

«Если децентрализованные приложения на Эфириуме хотят взаимодействовать с вашими токенами ERC20, они сначала должны получить одобрение на доступ к некоторому объему средств», — сказал Аггарвал. «В данном случае dApp просит одобрить доступ к чрезвычайно большому количеству токенов, не показывая, сколько именно их будет использоваться».

Аггарвал использовал популярный кошелек Metamask, который, по его словам, отображал сумму транзакции только после того, как он нажал «Показать подробности».

«И даже тогда вы увидите, что сумма отображается как 1.1579 ………… e+59» или в экспоненциальном представлении. Из-за этого многие пользователи могут «неправильно понять сумму и посчитать, что это примерно 1.15 токена».

Кошелек Metamask

«Это ошибка со стороны кошельков», — сказал он. «Кошельки должны отображать эту информацию для пользователей как можно более заметно и предупреждать их, если осуществляются какие-то действия».

Известная проблема

Проблема, на которую обратили внимание Охайон и ZenGo, уже давно известна в индустрии DeFi. Судя по всему, она до сих пор не была исправлена, так как участники индустрии не считают это уязвимостью или ошибкой, а лишь некорректно работающей функцией.

В сентябре 2018 года Джордан Рэндольф (Jordan Randolph), представитель децентрализованной биржи Ethex, изложил свой взгляд на проблему. «Однократные разрешения на перемещение почти бесконечного количества токенов… могут быть удобными», написал он. «Тем не менее, наличие почти бесконечного количества утвержденных токенов означает, что все ваши токены доступны для передачи по смарт-контракту». По его словам, предустановка кошелька сводится к выбору между удобством и безопасностью.

«Приложения, которые предлагают только один вариант — одобрение огромного количества токенов — несут в себе фатальную уязвимость в области безопасности», — написал он.

За последние несколько недель ZenGo обсудила эту проблему с разработчиками известных кошельков. Однако, зачастую исследователи сталкивались с непринятием.

«Эта проблема представляет собой известный риск и требует взаимодействия с пользователем. Мы добавили четкое уведомление для пользователей, когда они начинают взаимодействовать со сторонним dApp. Но мы все равно благодарим вас за ваш отчет», — ответил в Twitter представитель imToken Талу Бири (Tal Be’ery), одному из основателей ZenGo.

Генеральный директор imToken Бен Хе (Ben He) сказал: «Это не уязвимость безопасности, а плохая традиция всей экосистемы Эфириума, согласно которой большинство приложений dApps/DeFi запрашивают разрешение на неограниченное взаимодействие с токенами пользователей».

По его словам, для решения этой проблемы в браузере imToken dApp есть два всплывающих окна. Одно появляется, когда пользователь первый раз посещает URL-адрес dApp, а второе всплывает, запрашивая согласие пользователя перед заключением сделки.

«Очень важно, чтобы пользователь подписывал транзакции внимательно, и мы считаем, что это правильное и дружеское напоминание сообществу», — сказал он. «Мы совершенствуем свой пользовательский интерфейс, чтобы минимизировать проблемы».

Metamask представил аналогичный ответ на вопрос о неограниченных разрешениях.

«На самом деле это безопасная функция, которую пользователи регулярно используют ответственно. Это не какая-то ошибка или проблема», — сказал сотрудник службы поддержки MetaMask. «Это – не серьезная проблема стандарта ERC-20, но она имеет основополагающее значение для разрешений смарт-контрактов, позволяющих им взаимодействовать с токенами».

Фирма активно работает над добавлением мер безопасности, например, всплывающими сообщениями, которые запрашивают подтверждение для отправки средств и позволяют пользователям корректировать утвержденную сумму в дополнительных настройках. Кроме того, по словам представителя кошелька, Metamask «планирует предоставить пользователям еще больший контроль», например, функции, упрощающие отмену этого разрешения.

Охайон также сослался на Brave и Coinbase, отметив, что эти компании отображают «значимые предупреждения», хотя это не устраняет риск того, что пользователи dApp могут пострадать от действий злоумышленников.

«Некоторые компромиссы в области безопасности, которые могли бы быть приемлемыми в эпоху, когда пользователей было мало и они имели высокий уровень технический знаний, сейчас невозможны. Это связано с тем, что DeFi становится все популярнее, приобретает много пользователей без технических навыков и обрабатывает операции с криптовалютными токенами на миллиарды долларов», — написал в блоге исследователь ZenGo Алекс Манушкин.

Он считает, что если криптовалютная индустрия завоюет глобальную популярность, то должны быть приняты надлежащие меры предосторожности, чтобы избежать проблем.

Источник

Теги

Похожие статьи

Кнопка «Наверх»
  • bitcoinBitcoin (BTC) $ 6,354.42
  • ethereumEthereum (ETH) $ 132.87
  • rippleXRP (XRP) $ 0.173518
  • tetherTether (USDT) $ 1.00
  • bitcoin-cashBitcoin Cash (BCH) $ 217.90
  • bitcoin-cash-svBitcoin SV (BSV) $ 163.82
  • litecoinLitecoin (LTC) $ 38.79
  • eosEOS (EOS) $ 2.21
  • binancecoinBinance Coin (BNB) $ 12.53
  • okbOKB (OKB) $ 4.29
  • tezosTezos (XTZ) $ 1.59
  • leo-tokenLEO Token (LEO) $ 1.04
  • cardanoCardano (ADA) $ 0.030107
  • moneroMonero (XMR) $ 47.34
  • chainlinkChainLink (LINK) $ 2.24
  • stellarStellar (XLM) $ 0.040152
  • huobi-tokenHuobi Token (HT) $ 3.31
  • tronTRON (TRX) $ 0.011504
  • usd-coinUSD Coin (USDC) $ 1.00
  • crypto-com-chainCrypto.com Coin (CRO) $ 0.048303
  • dashDash (DASH) $ 64.49
  • ethereum-classicEthereum Classic (ETC) $ 4.86
  • neoNEO (NEO) $ 6.76
  • iotaIOTA (MIOTA) $ 0.143469
  • cosmosCosmos (ATOM) $ 1.94
  • nemNEM (XEM) $ 0.036243
  • zcashZcash (ZEC) $ 30.86
  • makerMaker (MKR) $ 293.92
  • paxos-standardPaxos Standard (PAX) $ 0.997106
  • ontologyOntology (ONT) $ 0.369784
  • dogecoinDogecoin (DOGE) $ 0.001817
  • basic-attention-tokenBasic Attention Token (BAT) $ 0.138086
  • vechainVeChain (VET) $ 0.003016
  • true-usdTrueUSD (TUSD) $ 0.998942
  • liskLisk (LSK) $ 0.964840
  • iconICON (ICX) $ 0.247585
  • decredDecred (DCR) $ 11.29
  • bitcoin-goldBitcoin Gold (BTG) $ 7.10
  • hedera-hashgraphHedera Hashgraph (HBAR) $ 0.031873
  • qtumQtum (QTUM) $ 1.22
  • augurAugur (REP) $ 10.00
  • algorandAlgorand (ALGO) $ 0.153493
  • 0x0x (ZRX) $ 0.150284
  • wavesWaves (WAVES) $ 0.955827
  • ravencoinRavencoin (RVN) $ 0.015447
  • bitcoin-diamondBitcoin Diamond (BCD) $ 0.473354
  • bytomBytom (BTM) $ 0.056403
  • monacoinMonaCoin (MONA) $ 1.18
  • daiDai (DAI) $ 1.02
  • enjincoinEnjin Coin (ENJ) $ 0.090459
  • gatechain-tokenGatechain Token (GT) $ 0.399657
  • kyber-networkKyber Network (KNC) $ 0.426973
  • kucoin-sharesKuCoin Shares (KCS) $ 0.922050
  • monacoMCO (MCO) $ 4.78
  • numeraireNumeraire (NMR) $ 16.12
  • theta-tokenTheta Network (THETA) $ 0.072977
  • omisegoOmiseGO (OMG) $ 0.516111
  • ftx-tokenFTX Token (FTT) $ 2.38
  • statusStatus (SNT) $ 0.017318
  • nanoNano (NANO) $ 0.487331
  • dxchainDxChain Token (DX) $ 0.001291
  • nexoNEXO (NEXO) $ 0.108782
  • holotokenHolo (HOT) $ 0.000330
  • digibyteDigiByte (DGB) $ 0.004490
  • energiEnergi (NRG) $ 2.15
  • havvenSynthetix Network Token (SNX) $ 0.613098
  • nervos-networkNervos Network (CKB) $ 0.003967
  • siacoinSiacoin (SC) $ 0.001271
  • digixdaoDigixDAO (DGD) $ 25.40
  • steemSteem (STEEM) $ 0.142914
  • zencashHorizen (ZEN) $ 5.58
  • bittorrent-2BitTorrent (BTT) $ 0.000223
  • v-systemsV.SYSTEMS (VSYS) $ 0.022939
  • bitsharesBitShares (BTS) $ 0.016277
  • hshareHyperCash (HC) $ 0.960242
  • bytecoinBytecoin (BCN) $ 0.000230
  • komodoKomodo (KMD) $ 0.356659
  • republic-protocolREN (REN) $ 0.046127
  • zilliqaZilliqa (ZIL) $ 0.003809
  • vergeVerge (XVG) $ 0.002456
  • quant-networkQuant (QNT) $ 3.97
  • iostokenIOST (IOST) $ 0.002996
  • seeleSeele (SEELE) $ 0.049375
  • decentralandDecentraland (MANA) $ 0.025675
  • aeternityAeternity (AE) $ 0.096411
  • celsius-degree-tokenCelsius Network (CEL) $ 0.073775
  • golemGolem (GNT) $ 0.033646
  • ardorArdor (ARDR) $ 0.032448
  • bmaxBitmax Token (BTMX) $ 0.038856
  • zcoinZcoin (XZC) $ 3.08
  • loopringLoopring (LRC) $ 0.026409
  • matic-networkMatic Network (MATIC) $ 0.010954
  • chilizChiliz (CHZ) $ 0.006275
  • gxchainGXChain (GXC) $ 0.456852
  • rif-tokenRIF Token (RIF) $ 0.050079
  • aelfaelf (ELF) $ 0.059216
  • stratisStratis (STRAT) $ 0.263332
  • ripio-credit-networkRipio Credit Network (RCN) $ 0.052148
  • digitex-futures-exchangeDigitex Futures Exchange (DGTX) $ 0.030537
  • pundi-xPundi X (NPXS) $ 0.000112
  • you-chainYOU Chain (YOU) $ 0.033006
  • usdkUSDK (USDK) $ 1.00
  • swipeSwipe (SXP) $ 0.385528
  • maidsafecoinMaidSafeCoin (MAID) $ 0.051684
  • arkArk (ARK) $ 0.155579
  • iexec-rlciExec RLC (RLC) $ 0.297245
  • crypteriumCrypterium (CRPT) $ 0.242887
  • electroneumElectroneum (ETN) $ 0.002020
  • solve-careSOLVE (SOLVE) $ 0.056623
  • yuan-chain-coinYuan Chain Coin (YCC) $ 0.005788
  • neon-exchangeNash Exchange (NEX) $ 0.729919
  • bit-z-tokenBit-Z Token (BZ) $ 0.141393
  • grinGrin (GRIN) $ 0.453403
  • tomochainTomoChain (TOMO) $ 0.242584
  • lambdaLambda (LAMB) $ 0.011914
  • nulsNuls (NULS) $ 0.195914
  • elastosElastos (ELA) $ 1.12
  • factomFactom (FCT) $ 1.76
  • beamBEAM (BEAM) $ 0.268829
  • saiSai (SAI) $ 1.02
  • enigmaEnigma (ENG) $ 0.107983
  • xmaxXMax (XMX) $ 0.000326
  • metaverse-etpMetaverse ETP (ETP) $ 0.109334
  • telosTelos (TLOS) $ 0.021495
  • fantomFantom (FTM) $ 0.003032
  • maximineMaximine (MXM) $ 0.001166
  • auroraAurora (AOA) $ 0.001174
  • erc20ERC20 (ERC20) $ 0.019788
Закрыть
Закрыть