{"id":113838,"date":"2019-09-17T10:39:36","date_gmt":"2019-09-17T10:39:36","guid":{"rendered":"https:\/\/cryptoslate.com\/?p=113838"},"modified":"2019-11-07T02:27:17","modified_gmt":"2019-11-07T02:27:17","slug":"exploit-eos-io-unusable-two-hours","status":"publish","type":"post","link":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/","title":{"rendered":"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours"},"content":{"rendered":"<p>On Sept. 13, an attacker <a href=\"https:\/\/cryptoslate.com\/eosio-exploit-attacker-30000-eos-freeze\/\">flooded<\/a> the EOSIO network to drain $110,000 in <a href=\"http:\/\/cryptoslate.com\/coins\/eos\">EOS<\/a> from a gambling dApp. During the process, many user-facing applications were unusable due to congestion. Here's how the hacker did it, in detail.<\/p>\n<h2>Basics of the network congestion exploit<\/h2>\n<p>Four days ago, an attacker pushed the EOS network into \u201chigh congestion mode\u201d as part of a smart contract exploit. The maneuver temporarily made some free network resources unavailable, making many applications on the network \u201cunusable\u201d to smaller token holders for over two hours.<\/p>\n<p>Although the network was still accessible (for example, a block explorer would still work), many were &#8220;prevented from publishing updates&#8221; or &#8220;doing anything actively on the chain&#8221; unless they paid for prohibitively costly network resources.<\/p>\n<p>At the peak of network congestion, it required nearly 12 EOS to make a single feeless transaction on the network, said one community member. For context, Most blockchains attach a fee directly to transactions. EOSIO allows users to stake their tokens in exchange for network resources.<\/p>\n<p>The attacker was able to rent a huge amount of network resources on a recently opened resource exchange. These resources were leveraged to select which valid transactions would get included on the blockchain to manipulate gambling dApp outcomes.<\/p>\n<p>During this time, the maintainers of the gambling dApp did not have enough EOS on hand to take their contract offline (or take any preventative actions at all). This allowed the attacker to drain the smart contract for 30,000 EOS, at the cost of 300 EOS in rented network resources, at their leisure.<\/p>\n<h2>Identifying the attacker<\/h2>\n<p>Beginning Aug. 17, the user &#8220;<a href=\"https:\/\/bloks.io\/account\/mumachayinmm\">mumachayinmm<\/a>&#8221; started conducting tests against a variety of gambling dApps. After just under a month of testing, mumachayinmm rented the equivalent of 1.45 million EOS in network resources.<\/p>\n<p>Previously, this would have required some $5.8 million in tokens. But REX, a new service <a href=\"https:\/\/eosauthority.com\/rex_history\/\">launched<\/a> in May, allows users to stake their EOS for security and voting purposes while selling the network resources their stake entitles them to. After REX, 1.45 million EOS in network resources cost just $1,200.<\/p>\n<figure style=\"width: 641px\" class=\"wp-caption alignnone\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/lh4.googleusercontent.com\/OVAtUvJlFjClEThPPiSiRtcV3SE4HjCTwVReC7W0_pUZgQNmdMPk-nPcCJ2CPwjCMoGNkF8WMhoKDMbfhIgfyLe86JAcOsdeG4TE39eTWla7U5RNuz4bcTTQ47GpLM8t_PUtd3x-\" alt=\"Resources on the attacker's account\" width=\"641\" height=\"463\" \/><figcaption class=\"wp-caption-text\">Source: <a href=\"https:\/\/bloks.io\/account\/mumachayinmm\">Bloks.io<\/a><\/figcaption><\/figure>\n<p>On Sept. 13, mumachayinmm started flooding EOSIO with hundreds of thousands of transactions.<\/p>\n<figure style=\"width: 903px\" class=\"wp-caption alignnone\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/lh5.googleusercontent.com\/UNiHs1hBrCrWXoScTTDiME__xUhsnwq8hn6-MSrDMuwMSPm4gAV_DRppR8tA3JIcUYKYLyOVvbArQoaHMNhaFL2CBKdXaJ3QSgUM6H1Kg6076LE_S4dMs_7q5t2MOqGzLfZ_8-od\" alt=\"Spam transactions\" width=\"903\" height=\"746\" \/><figcaption class=\"wp-caption-text\">Sample of some of the attacker\u2019s spam transactions. Source: <a href=\"https:\/\/bloks.io\/account\/mumachayinmm\">Bloks.io<\/a><\/figcaption><\/figure>\n<h2>Technical details behind the gambling dApp exploit<\/h2>\n<p><a href=\"https:\/\/eosplay.com\/\">EOSPlay<\/a> is a decentralized gambling dApp that offers games such as poker and dice. What made the service exploitable was how it generated random numbers for these games.<\/p>\n<p>Instead of using a secure source of randomness, EOSPlay used the EOSIO blockchain as its source of entropy. Unfortunately, information on a blockchain can be manipulated.<\/p>\n<p>As an example, on Bitcoin miners who find a block get to select which transactions are included at their discretion, so long as they\u2019re legal transactions. Theoretically, if a dApp used transactions on Bitcoin to make calculations then large miners could game it.<\/p>\n<p>On EOSIO, a similar way to manipulate the blockchain is to amass enough network resources to include whichever transactions are desired over all other users.<\/p>\n<p>Specifically, what the attacker did was put deferred transactions into each block, <a href=\"https:\/\/twitter.com\/Dexaran\">said<\/a> Dexaran, a respected smart contract developer. These blocks were the ones EOSPlay used to calculate random numbers.<\/p>\n<p>By monopolizing network resources, the attacker could then calculate the random number before the contract could. If the number was a losing number, then the deferred transactions started an \u201cinfinite loop,\u201d pushing random number generation to the next block, said Dexaran.<\/p>\n<p>The maneuver allowed mumachayinmm to win on EOSPlay over and over again.<\/p>\n<figure style=\"width: 1600px\" class=\"wp-caption alignnone\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/lh4.googleusercontent.com\/7AkF3ARDDQmOwEIL8eqwk3tJ0rxpzRsBZLjNM0rn6e3fr54cDMM1NzvwvWT33fbZhytPn4SU17AdUVsZ1imqUTVdiygMSFVVyyZEgQ9XZr84NGMkzpWlT1A8NvkeozNlpO19FkzM\" alt=\"Illicit EOS winnings\" width=\"1600\" height=\"715\" \/><figcaption class=\"wp-caption-text\">Tens of thousands of EOS in illicit winnings. Source: <a href=\"https:\/\/bloks.io\/account\/mumachayinmm\">Bloks.io<\/a><\/figcaption><\/figure>\n<h2>EOSPlay helpless during the attack<\/h2>\n<p>To make matters worse, the maintainers behind the gambling dApp did not stake enough EOS to cover their contract operation costs when EOSIO\u2019s conservative mode was triggered. This was an oversight on the part of the maintainers.<\/p>\n<p>With network resources monopolized the maintainers needed to have enough liquid EOS on hand to ensure a transaction to halt the contract would go through. It appears they didn\u2019t have the tokens on hands, allowing the attacker to bide their time as the contract was drained.<\/p>\n<p>These spam attacks aren\u2019t unique to EOS. Networks such as <a href=\"http:\/\/cryptoslate.com\/coins\/bitcoin\">Bitcoin<\/a> and <a href=\"http:\/\/cryptoslate.com\/coins\/ethereum\">Ethereum<\/a> are also vulnerable to spam attacks should a wealthy token holder wish to pay for them (though they are prohibitively expensive in most cases).<\/p>\n<h2>Block.one executives respond<\/h2>\n<p><a href=\"http:\/\/cryptoslate.com\/companies\/block-one\">Block.one<\/a> CTO and creator of EOSIO <a href=\"http:\/\/cryptoslate.com\/people\/daniel-larimer\">Daniel Larimer<\/a> took to Twitter to dispel the \u201cFUD\u201d around the network congestion attacks. He asserted the network was \u201cworking as intended\u201d:<\/p>\n<blockquote class=\"twitter-tweet\" data-width=\"500\" data-dnt=\"true\">\n<p lang=\"en\" dir=\"ltr\"><a href=\"https:\/\/twitter.com\/hashtag\/EOS?src=hash&ref_src=twsrc%5Etfw\">#EOS<\/a> is operating correctly. This is no different than when attackers flood eth or bitcoin with high fee transaction spam. The network didn\u2019t freeze for token holders, there was just no extra bandwidth available for free use<a href=\"https:\/\/t.co\/nZQmCTlXFa\">https:\/\/t.co\/nZQmCTlXFa<\/a><\/p>\n<p>&mdash; Daniel Larimer (@bytemaster7) <a href=\"https:\/\/twitter.com\/bytemaster7\/status\/1172820931317850112?ref_src=twsrc%5Etfw\">September 14, 2019<\/a><\/p><\/blockquote>\n<p><script async src=\"https:\/\/platform.twitter.com\/widgets.js\" charset=\"utf-8\"><\/script><\/p>\n<p>Yet, these assertions are in conflict with Larimer\u2019s May 2018 comments while he was touting the \u201cfeeless\u201d design of EOSIO:<\/p>\n<blockquote><p>\u201cOn EOSIO, no single user has the ability to saturate the entire network no matter how much money they're willing to spend.\u201d<\/p><\/blockquote>\n<p><iframe loading=\"lazy\" title=\"How are Transactions Feeless on EOSIO?\" width=\"500\" height=\"281\" src=\"https:\/\/www.youtube.com\/embed\/ReAKvFG8cCE?feature=oembed\" frameborder=\"0\" allow=\"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen><\/iframe><\/p>\n<p>Yet, that is exactly what happened during this exploit. The attacker saturated the network by spending a paltry $1,200.<\/p>\n<p>Block.one CEO <a href=\"http:\/\/cryptoslate.com\/people\/brendan-blumer\">Brendan Blumer<\/a> also took to social media to defend EOSIO. Though, he was rather vague on specific actions until pressed by a community member.<\/p>\n<blockquote class=\"twitter-tweet\" data-width=\"500\" data-dnt=\"true\">\n<p lang=\"en\" dir=\"ltr\">We follow discussions on <a href=\"https:\/\/twitter.com\/hashtag\/EOS?src=hash&ref_src=twsrc%5Etfw\">#EOS<\/a> network evolution closely, and are aligned with our peers in maximising network security, performance, and capabilities. We are planning next steps carefully with a global set of sensitivities in mind, and a goal of healthy participation at heart<\/p>\n<p>&mdash; Brendan Blumer (@BrendanBlumer) <a href=\"https:\/\/twitter.com\/BrendanBlumer\/status\/1173157411852607488?ref_src=twsrc%5Etfw\">September 15, 2019<\/a><\/p><\/blockquote>\n<p><script async src=\"https:\/\/platform.twitter.com\/widgets.js\" charset=\"utf-8\"><\/script><\/p>\n<p>If a user stakes EOS they will always have access to network resources, he claims. But the amount will vary substantially, and when paying customers are using it all, it\u2019ll be necessary to pay to maintain the same level of access, stated Blumer.<\/p>\n<blockquote class=\"twitter-tweet\" data-width=\"500\" data-dnt=\"true\">\n<p lang=\"en\" dir=\"ltr\">If you stake EOS then you won\u2019t need to worry about losing access to bandwidth. If you expect an infinite amount of free bandwidth without ever paying for it, then you\u2019ll need to find someone willing to subsidise your use to avoid disruption when paying customers are using it all<\/p>\n<p>&mdash; Brendan Blumer (@BrendanBlumer) <a href=\"https:\/\/twitter.com\/BrendanBlumer\/status\/1173381399664943104?ref_src=twsrc%5Etfw\">September 15, 2019<\/a><\/p><\/blockquote>\n<p><script async src=\"https:\/\/platform.twitter.com\/widgets.js\" charset=\"utf-8\"><\/script><\/p>\n<h2>Issues raised<\/h2>\n<p>The recent exploit raises serious questions about the EOSIO blockchain. <a href=\"https:\/\/www.facebook.com\/thejaredmoore\">Jared Moore<\/a>, an active community member asked: If the network is at risk of sudden spikes in resource cost, how much liquid EOS should developers have on hand to ensure they\u2019re protected? Without guidance, dApp developers will continue to be vulnerable to these kinds of exploits, he argued.<\/p>\n<p>Another issue is access. As EOS gains more usage it\u2019s likely the network will eventually enter a state of constant \u201chigh congestion mode,\u201d voiced another enthusiast.<\/p>\n<p>This means developers and corporations, rather than small-time users, will dominate access to resources on the network\u2014raising questions as to who the network is built for. These same corporations could also monopolize resources on the network, said Moore, in essence becoming gatekeepers.<\/p>\n<p>On the bright side, such a scenario would make EOS like owning land, said another commentator, giving the token value through the network resources it entitles the owner to.<\/p>\n<p>Dexaran, a security engineer and the creator of the ERC-223 token standard, made the following suggestion to mitigate future congestion attacks on dApps:<\/p>\n<blockquote><p>\u201cIt would be nice to calculate how much <a href=\"https:\/\/cryptoslate.com\/coins\/eos\/\">EOS<\/a> you need to put into a \u2018reserve\u2019 account to make sure you have access to your contracts even during harsh congestion,\u201d he commented.<\/p><\/blockquote>\n<p>Another community member voiced a need for better ways to calculate staked EOS needs under different network conditions:<\/p>\n<blockquote><p>&#8220;The key issue here is that the community has gotten used to the amount of free transactions they receive when the network is relatively unused. We need better estimates of how much EOS you need staked during different network conditions.&#8221;<\/p><\/blockquote>\n<p>He went on to describe problems with how staking is treated on the network.<\/p>\n<blockquote><p>&#8220;I also have a really big issue with the fact that EOSIO does not prioritize &#8216;staking' transactions. When these conditions happen, folks attempting to stake more EOS should be allowed to (once per account) as a priority transaction. When I\u2019ve paid for huge sums of EOS, it\u2019s ridiculous when I get locked out and can\u2019t allocate more to my account. I can\u2019t &#8216;pay for more' even if I wanted to.&#8221;<\/p><\/blockquote>\n<p>Designing a public blockchain is a complicated business. Things will go wrong. Right now, it\u2019s very costly to build useful apps on any blockchain. Block.one executives should take the lead to make the development experience easier and less risky, paving the way for mass adoption, rather than maintaining hardliner positions that &#8216;nothing's wrong.'<\/p>\n","protected":false},"excerpt":{"rendered":"<p>On Sept. 13, an attacker flooded the EOSIO network to drain $110,000 in EOS from a gambling dApp. During the process, many user-facing applications were unusable due to congestion. Here&#8217;s how the hacker did it, in detail. Basics of the network congestion exploit Four days ago, an attacker pushed the EOS network into \u201chigh congestion [&hellip;]<\/p>\n","protected":false},"author":29,"featured_media":101722,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[120,16041,15323],"tags":[],"post_folder":[],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.9 (Yoast SEO v21.9.1) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours<\/title>\n<meta name=\"description\" content=\"On Sept. 13, an attacker flooded the EOSIO network to drain $110,000 in EOS from a gambling dApp. During the process, many user-facing applications were unusable due to congestion. Here&#039;s how the hacker did it, in detail.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours\" \/>\n<meta property=\"og:description\" content=\"On Sept. 13, an attacker flooded the EOSIO network to drain $110,000 in EOS from a gambling dApp. During the process, many user-facing applications were unusable due to congestion. Here&#039;s how the hacker did it, in detail.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/\" \/>\n<meta property=\"og:site_name\" content=\"CryptoSlate\" \/>\n<meta property=\"article:published_time\" content=\"2019-09-17T10:39:36+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2019-11-07T02:27:17+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cryptoslate.com\/wp-content\/uploads\/2019\/04\/eos-gridlock-social.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"1200\" \/>\n\t<meta property=\"og:image:height\" content=\"630\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"Mitchell Moos\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:title\" content=\"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours\" \/>\n<meta name=\"twitter:creator\" content=\"@cryptoslate\" \/>\n<meta name=\"twitter:site\" content=\"@cryptoslate\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Mitchell Moos\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"7 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"NewsArticle\",\"@id\":\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/\"},\"author\":{\"name\":\"Mitchell Moos\",\"@id\":\"https:\/\/cryptoslate.com\/#\/schema\/person\/aa4a99d396523bc811fbc52c632b6f81\"},\"headline\":\"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours\",\"datePublished\":\"2019-09-17T10:39:36+00:00\",\"dateModified\":\"2019-11-07T02:27:17+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/\"},\"wordCount\":1356,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/cryptoslate.com\/#organization\"},\"articleSection\":[\"Analysis\",\"Hacks\",\"Price Watch\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/#respond\"]}],\"copyrightYear\":\"2019\",\"copyrightHolder\":{\"@id\":\"https:\/\/cryptoslate.com\/#organization\"}},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/\",\"url\":\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/\",\"name\":\"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours\",\"isPartOf\":{\"@id\":\"https:\/\/cryptoslate.com\/#website\"},\"datePublished\":\"2019-09-17T10:39:36+00:00\",\"dateModified\":\"2019-11-07T02:27:17+00:00\",\"description\":\"On Sept. 13, an attacker flooded the EOSIO network to drain $110,000 in EOS from a gambling dApp. During the process, many user-facing applications were unusable due to congestion. Here's how the hacker did it, in detail.\",\"breadcrumb\":{\"@id\":\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/cryptoslate.com\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/cryptoslate.com\/#website\",\"url\":\"https:\/\/cryptoslate.com\/\",\"name\":\"CryptoSlate\",\"description\":\"Cryptocurrency News and Real-time Coin Data\",\"publisher\":{\"@id\":\"https:\/\/cryptoslate.com\/#organization\"},\"inLanguage\":\"en-US\"},{\"@type\":\"NewsMediaOrganization\",\"@id\":\"https:\/\/cryptoslate.com\/#organization\",\"name\":\"CryptoSlate\",\"url\":\"https:\/\/cryptoslate.com\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/cryptoslate.com\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/cryptoslate.com\/wp-content\/uploads\/2018\/05\/c-logo.jpg\",\"contentUrl\":\"https:\/\/cryptoslate.com\/wp-content\/uploads\/2018\/05\/c-logo.jpg\",\"width\":1000,\"height\":1000,\"caption\":\"CryptoSlate\"},\"image\":{\"@id\":\"https:\/\/cryptoslate.com\/#\/schema\/logo\/image\/\"},\"sameAs\":[\"https:\/\/twitter.com\/cryptoslate\",\"https:\/\/www.instagram.com\/cryptoslate\",\"https:\/\/www.linkedin.com\/company\/cryptoslate\",\"https:\/\/www.youtube.com\/c\/cryptoslate\",\"https:\/\/cryptoslate.substack.com\",\"https:\/\/t.me\/cryptoslatenews\",\"https:\/\/www.tiktok.com\/@cryptoslatenews\"],\"publishingPrinciples\":\"https:\/\/cryptoslate.com\/editorial-policy\/#editorial-principles\",\"ownershipFundingInfo\":\"https:\/\/cryptoslate.com\/disclaimers\/how-cryptoslate-makes-and-spends-money\/\",\"correctionsPolicy\":\"https:\/\/cryptoslate.com\/editorial-policy\/#corrections-feedback\",\"ethicsPolicy\":\"https:\/\/cryptoslate.com\/editorial-policy\/#editorial-principles\",\"foundingDate\":\"2017-08-04\",\"founder\":[{\"@type\":\"Person\",\"name\":\"Nate Whitehill\"},{\"@type\":\"Person\",\"name\":\"Matthew Blancarte\"}],\"contactPoint\":[{\"@type\":\"ContactPoint\",\"contactType\":\"customer support\",\"url\":\"https:\/\/cryptoslate.com\/contact\/\",\"availableLanguage\":\"en-US\"},{\"@type\":\"ContactPoint\",\"contactType\":\"sales\",\"url\":\"https:\/\/cryptoslate.com\/advertising\/\",\"availableLanguage\":\"en-US\"},{\"@type\":\"ContactPoint\",\"contactType\":\"newsroom\",\"url\":\"https:\/\/cryptoslate.com\/editorial-policy\/#corrections-feedback\",\"email\":\"tips@cryptoslate.com\",\"availableLanguage\":\"en-US\"}],\"masthead\":\"https:\/\/cryptoslate.com\/about\/#masthead\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/cryptoslate.com\/#\/schema\/person\/aa4a99d396523bc811fbc52c632b6f81\",\"name\":\"Mitchell Moos\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/cryptoslate.com\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/cryptoslate.com\/wp-content\/uploads\/2018\/11\/author-mitchell-moos-150x150.jpg\",\"contentUrl\":\"https:\/\/cryptoslate.com\/wp-content\/uploads\/2018\/11\/author-mitchell-moos-150x150.jpg\",\"caption\":\"Mitchell Moos\"},\"description\":\"Mitchell is a software enthusiast and entrepreneur. His first startup built algorithms for optimizing cryptocurrency mining. Prior to CryptoSlate, Mitchell was a project manager at a firm that built distributed software on Hyperledger. In his spare time he loves playing chess and hiking.\",\"sameAs\":[\"https:\/\/twitter.com\/MitchellMoos\"],\"url\":\"https:\/\/cryptoslate.com\/author\/mitchell-moos\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours","description":"On Sept. 13, an attacker flooded the EOSIO network to drain $110,000 in EOS from a gambling dApp. During the process, many user-facing applications were unusable due to congestion. Here's how the hacker did it, in detail.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/","og_locale":"en_US","og_type":"article","og_title":"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours","og_description":"On Sept. 13, an attacker flooded the EOSIO network to drain $110,000 in EOS from a gambling dApp. During the process, many user-facing applications were unusable due to congestion. Here's how the hacker did it, in detail.","og_url":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/","og_site_name":"CryptoSlate","article_published_time":"2019-09-17T10:39:36+00:00","article_modified_time":"2019-11-07T02:27:17+00:00","og_image":[{"width":1200,"height":630,"url":"https:\/\/cryptoslate.com\/wp-content\/uploads\/2019\/04\/eos-gridlock-social.jpg","type":"image\/jpeg"}],"author":"Mitchell Moos","twitter_card":"summary_large_image","twitter_title":"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours","twitter_creator":"@cryptoslate","twitter_site":"@cryptoslate","twitter_misc":{"Written by":"Mitchell Moos","Est. reading time":"7 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"NewsArticle","@id":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/#article","isPartOf":{"@id":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/"},"author":{"name":"Mitchell Moos","@id":"https:\/\/cryptoslate.com\/#\/schema\/person\/aa4a99d396523bc811fbc52c632b6f81"},"headline":"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours","datePublished":"2019-09-17T10:39:36+00:00","dateModified":"2019-11-07T02:27:17+00:00","mainEntityOfPage":{"@id":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/"},"wordCount":1356,"commentCount":0,"publisher":{"@id":"https:\/\/cryptoslate.com\/#organization"},"articleSection":["Analysis","Hacks","Price Watch"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/#respond"]}],"copyrightYear":"2019","copyrightHolder":{"@id":"https:\/\/cryptoslate.com\/#organization"}},{"@type":"WebPage","@id":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/","url":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/","name":"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours","isPartOf":{"@id":"https:\/\/cryptoslate.com\/#website"},"datePublished":"2019-09-17T10:39:36+00:00","dateModified":"2019-11-07T02:27:17+00:00","description":"On Sept. 13, an attacker flooded the EOSIO network to drain $110,000 in EOS from a gambling dApp. During the process, many user-facing applications were unusable due to congestion. Here's how the hacker did it, in detail.","breadcrumb":{"@id":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/cryptoslate.com\/exploit-eos-io-unusable-two-hours\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/cryptoslate.com\/"},{"@type":"ListItem","position":2,"name":"Understanding the exploit that made EOS.IO \u201cunusable\u201d for two hours"}]},{"@type":"WebSite","@id":"https:\/\/cryptoslate.com\/#website","url":"https:\/\/cryptoslate.com\/","name":"CryptoSlate","description":"Cryptocurrency News and Real-time Coin Data","publisher":{"@id":"https:\/\/cryptoslate.com\/#organization"},"inLanguage":"en-US"},{"@type":"NewsMediaOrganization","@id":"https:\/\/cryptoslate.com\/#organization","name":"CryptoSlate","url":"https:\/\/cryptoslate.com\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/cryptoslate.com\/#\/schema\/logo\/image\/","url":"https:\/\/cryptoslate.com\/wp-content\/uploads\/2018\/05\/c-logo.jpg","contentUrl":"https:\/\/cryptoslate.com\/wp-content\/uploads\/2018\/05\/c-logo.jpg","width":1000,"height":1000,"caption":"CryptoSlate"},"image":{"@id":"https:\/\/cryptoslate.com\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/twitter.com\/cryptoslate","https:\/\/www.instagram.com\/cryptoslate","https:\/\/www.linkedin.com\/company\/cryptoslate","https:\/\/www.youtube.com\/c\/cryptoslate","https:\/\/cryptoslate.substack.com","https:\/\/t.me\/cryptoslatenews","https:\/\/www.tiktok.com\/@cryptoslatenews"],"publishingPrinciples":"https:\/\/cryptoslate.com\/editorial-policy\/#editorial-principles","ownershipFundingInfo":"https:\/\/cryptoslate.com\/disclaimers\/how-cryptoslate-makes-and-spends-money\/","correctionsPolicy":"https:\/\/cryptoslate.com\/editorial-policy\/#corrections-feedback","ethicsPolicy":"https:\/\/cryptoslate.com\/editorial-policy\/#editorial-principles","foundingDate":"2017-08-04","founder":[{"@type":"Person","name":"Nate Whitehill"},{"@type":"Person","name":"Matthew Blancarte"}],"contactPoint":[{"@type":"ContactPoint","contactType":"customer support","url":"https:\/\/cryptoslate.com\/contact\/","availableLanguage":"en-US"},{"@type":"ContactPoint","contactType":"sales","url":"https:\/\/cryptoslate.com\/advertising\/","availableLanguage":"en-US"},{"@type":"ContactPoint","contactType":"newsroom","url":"https:\/\/cryptoslate.com\/editorial-policy\/#corrections-feedback","email":"tips@cryptoslate.com","availableLanguage":"en-US"}],"masthead":"https:\/\/cryptoslate.com\/about\/#masthead"},{"@type":"Person","@id":"https:\/\/cryptoslate.com\/#\/schema\/person\/aa4a99d396523bc811fbc52c632b6f81","name":"Mitchell Moos","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/cryptoslate.com\/#\/schema\/person\/image\/","url":"https:\/\/cryptoslate.com\/wp-content\/uploads\/2018\/11\/author-mitchell-moos-150x150.jpg","contentUrl":"https:\/\/cryptoslate.com\/wp-content\/uploads\/2018\/11\/author-mitchell-moos-150x150.jpg","caption":"Mitchell Moos"},"description":"Mitchell is a software enthusiast and entrepreneur. His first startup built algorithms for optimizing cryptocurrency mining. Prior to CryptoSlate, Mitchell was a project manager at a firm that built distributed software on Hyperledger. In his spare time he loves playing chess and hiking.","sameAs":["https:\/\/twitter.com\/MitchellMoos"],"url":"https:\/\/cryptoslate.com\/author\/mitchell-moos\/"}]}},"_links":{"self":[{"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/posts\/113838"}],"collection":[{"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/users\/29"}],"replies":[{"embeddable":true,"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/comments?post=113838"}],"version-history":[{"count":10,"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/posts\/113838\/revisions"}],"predecessor-version":[{"id":113866,"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/posts\/113838\/revisions\/113866"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/media\/101722"}],"wp:attachment":[{"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/media?parent=113838"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/categories?post=113838"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/tags?post=113838"},{"taxonomy":"post_folder","embeddable":true,"href":"https:\/\/cryptoslate.com\/wp-json\/wp\/v2\/post_folder?post=113838"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}