Friday, January 19, 2024

Blockchain Exploitation Labs - Part 1 Smart Contract Re-Entrancy


Why/What Blockchain Exploitation?

In this blog series we will analyze blockchain vulnerabilities and exploit them ourselves in various lab and development environments. If you would like to stay up to date on new posts follow and subscribe to the following:
Twitter: @ficti0n
Youtube: https://www.youtube.com/c/ConsoleCowboys
URL: http://cclabs.io
          http://consolecowboys.com

As of late I have been un-naturally obsessed with blockchains and crypto currency. With that obsession comes the normal curiosity of "How do I hack this and steal all the monies?"

However, as usual I could not find any actual walk thorough or solid examples of actually exploiting real code live. Just theory and half way explained examples.

That question with labs is exactly what we are going to cover in this series, starting with the topic title above of Re-Entrancy attacks which allow an attacker to siphon out all of the money held within a smart contract, far beyond that of their own contribution to the contract.
This will be a lab based series and I will show you how to use demo the code within various test environments and local environments in order to perform and re-create each attacks for yourself.  

Note: As usual this is live ongoing research and info will be released as it is coded and exploited.

If you are bored of reading already and just want to watch videos for this info or are only here for the demos and labs check out the first set of videos in the series at the link below and skip to the relevant parts for you, otherwise lets get into it:


Background Info:

This is a bit of a harder topic to write about considering most of my audience are hackers not Ethereum developers or blockchain architects. So you may not know what a smart contract is nor how it is situated within the blockchain development model. So I am going to cover a little bit of context to help with understanding.  I will cover the bare minimum needed as an attacker.

A Standard Application Model:
  • In client server we generally have the following:
  • Front End - what the user sees (HTML Etc)
  • Server Side - code that handles business logic
  • Back End - Your database for example MySQL

A Decentralized Application Model:

Now with a Decentralized applications (DAPP) on the blockchain you have similar front end server side technology however
  • Smart contracts are your access into the blockchain.
  • Your smart contract is kind of like an API
  • Essentially DAPPs are Ethereum enabled applications using smart contracts as an API to the blockchain data ledger
  • DAPPs can be banking applications, wallets, video games etc.

A blockchain is a trust-less peer to peer decentralized database or ledger

The back-end is distributed across thousands of nodes in its entirety on each node. Meaning every single node has a Full "database" of information called a ledger.  The second difference is that this ledger is immutable, meaning once data goes in, data cannot be changed. This will come into play later in this discussion about smart contracts.

Consensus:

The blockchain of these decentralized ledgers is synchronized by a consensus mechanism you may be familiar with called "mining" or more accurately, proof of work or optionally Proof of stake.

Proof of stake is simply staking large sums of coins which are at risk of loss if one were to perform a malicious action while helping to perform consensus of data.   

Much like proof of stake, proof of work(mining) validates hashing calculations to come to a consensus but instead of loss of coins there is a loss of energy, which costs money, without reward if malicious actions were to take place.

Each block contains transactions from the transaction pool combined with a nonce that meets the difficulty requirements.  Once a block is found and accepted it places them on the blockchain in which more then half of the network must reach a consensus on. 

The point is that no central authority controls the nodes or can shut them down. Instead there is consensus from all nodes using either proof of work or proof of stake. They are spread across the whole world leaving a single centralized jurisdiction as an impossibility.

Things to Note: 

First Note: Immutability

  • So, the thing to note is that our smart contracts are located on the blockchain
  • And the blockchain is immutable
  • This means an Agile development model is not going to work once a contract is deployed.
  • This means that updates to contracts is next to impossible
  • All you can really do is create a kill-switch or fail safe functions to disable and execute some actions if something goes wrong before going permanently dormant.
  • If you don't include a kill switch the contract is open and available and you can't remove it

Second Note:  Code Is Open Source
  • Smart Contracts are generally open source
  • Which means people like ourselves are manually bug hunting smart contracts and running static analysis tools against smart contract code looking for bugs.

When issues are found the only course of action is:
  • Kill the current contract which stays on the blockchain
  • Then deploy a whole new version.
  • If there is no killSwitch the contract will be available forever.
Now I know what you're thinking, these things are ripe for exploitation.
And you would be correct based on the 3rd note


Third Note: Security in the development process is lacking
  • Many contracts and projects do not even think about and SDLC.
  • They rarely add penetration testing and vulnerability testing in the development stages if at all
  • At best there is a bug bounty before the release of their main-nets
  • Which usually get hacked to hell and delayed because of it.
  • Things are getting better but they are still behind the curve, as the technology is new and blockchain mostly developers and marketers.  Not hackers or security testers.


Forth Note:  Potential Data Exposure via Future Broken Crypto
  • If sensitive data is placed on the blockchain it is there forever
  • Which means that if a cryptographic algorithm is broken anything which is encrypted with that algorithm is now accessible
  • We all know that algorithms are eventually broken!
  • So its always advisable to keep sensitive data hashed for integrity on the blockchain but not actually stored on the blockchain directly


 Exploitation of Re-Entrancy Vulnerabilities:

With a bit of the background out of the way let's get into the first attack in this series.

Re-Entrancy attacks allow an attacker to create a re-cursive loop within a contract by having the contract call the target function rather than a single request from a  user. Instead the request comes from the attackers contract which does not let the target contracts execution complete until the tasks intended by the attacker are complete. Usually this task will be draining the money out of the contract until all of the money for every user is in the attackers account.

Example Scenario:

Let's say that you are using a bank and you have deposited 100 dollars into your bank account.  Now when you withdraw your money from your bank account the bank account first sends you 100 dollars before updating your account balance.

Well what if when you received your 100 dollars, it was sent to malicious code that called the withdraw function again not letting  the initial target deduct your balance ?

With this scenario you could then request 100 dollars, then request 100 again and you now have 200 dollars sent to you from the bank. But 50% of that money is not yours. It's from the whole collection of money that the bank is tasked to maintain for its accounts.

Ok that's pretty cool, but what if that was in a re-cursive loop that did not BREAK until all accounts at the bank were empty?  

That is Re-Entrancy in a nutshell.   So let's look at some code.

Example Target Code:


           function withdraw(uint withdrawAmount) public returns (uint) {
       
1.         require(withdrawAmount <= balances[msg.sender]);
2.         require(msg.sender.call.value(withdrawAmount)());

3.          balances[msg.sender] -= withdrawAmount;
4.          return balances[msg.sender];
        }

Line 1: Checks that you are only withdrawing the amount you have in your account or sends back an error.
Line 2: Sends your requested amount to the address the requested that withdrawal.
Line 3: Deducts the amount you withdrew from your account from your total balance.
Line 4. Simply returns your current balance.

Ok this all seems logical.. however the issue is in Line 2 - Line 3.   The balance is being sent back to you before the balance is deducted. So if you were to call this from a piece of code which just accepts anything which is sent to it, but then re-calls the withdraw function you have a problem as it never gets to Line 3 which deducts the balance from your total. This means that Line 1 will always have enough money to keep withdrawing.

Let's take a look at how we would do that:

Example Attacking Code:


          function attack() public payable {
1.           bankAddress.withdraw(amount);
         }

2.    function () public payable {
         
3.            if (address(bankAddress).balance >= amount) {
4.               bankAddress.withdraw(amount);
                }
}

Line 1: This function is calling the banks withdraw function with an amount less than the total in your account
Line 2: This second function is something called a fallback function. This function is used to accept payments that come into the contract when no function is specified. You will notice this function does not have a name but is set to payable.
Line 3:  This line is checking that the target accounts balance is greater than the amount being withdrawn.
Line 4:  Then again calling the withdraw function to continue the loop which will in turn be sent back to the fallback function and repeat lines over and over until the target contracts balance is less than the amount being requested.



Review the diagram above which shows the code paths between the target and attacking code. During this whole process the first code example from the withdraw function is only ever getting to lines 1-2 until the bank is drained of money. It never actually deducts your requested amount until the end when the full contract balance is lower then your withdraw amount. At this point it's too late and there is no money left in the contract.


Setting up a Lab Environment and coding your Attack:

Hopefully that all made sense. If you watch the videos associated with this blog you will see it all in action.  We will now analyze code of a simple smart contract banking application. We will interface with this contract via our own smart contract we code manually and turn into an exploit to take advantage of the vulnerability.

Download the target code from the following link:

Then lets open up an online ethereum development platform at the following link where we will begin analyzing and exploiting smart contracts in real time in the video below:

Coding your Exploit and Interfacing with a Contract Programmatically:

The rest of this blog will continue in the video below where we will  manually code an interface to a full smart contract and write an exploit to take advantage of a Re-Entrency Vulnerability:

 


Conclusion: 

In this smart contract exploit writing intro we showed a vulnerability that allowed for re entry to a contract in a recursive loop. We then manually created an exploit to take advantage of the vulnerability. This is just the beginning, as this series progresses you will see other types of vulnerabilities and have the ability to code and exploit them yourself.  On this journey through the decentralized world you will learn how to code and craft exploits in solidity using various development environments and test nets.

Related word


  1. Pentest Tools Online
  2. Pentest Tools For Ubuntu
  3. Hacker Tools Linux
  4. Hacker Hardware Tools
  5. Hacking Tools
  6. Hacker Tools For Ios
  7. Pentest Recon Tools
  8. Hacking Tools Windows
  9. Hack Tools
  10. Top Pentest Tools
  11. Hacking Tools For Games
  12. Hackers Toolbox
  13. Physical Pentest Tools
  14. Black Hat Hacker Tools
  15. Hacking Tools Windows
  16. Hack Tools For Windows
  17. Blackhat Hacker Tools
  18. Hacker Tools Software
  19. Hack Tools For Mac
  20. Game Hacking
  21. Hacking Tools For Pc
  22. Hacker Tool Kit
  23. Hack Tools Download
  24. Hackers Toolbox
  25. Pentest Tools Website
  26. Pentest Tools For Mac
  27. Hacker Tools Software
  28. Hack Tools Pc
  29. Usb Pentest Tools
  30. Pentest Tools List
  31. Pentest Tools Github
  32. Pentest Tools Website Vulnerability
  33. Hacking Tools
  34. Pentest Tools Github
  35. Install Pentest Tools Ubuntu
  36. Pentest Automation Tools
  37. Pentest Tools Url Fuzzer
  38. Pentest Box Tools Download
  39. Hacking Tools For Games
  40. Hacking Tools For Windows
  41. Hacking Tools For Kali Linux
  42. Hacking App
  43. Ethical Hacker Tools
  44. Hacker Tools Mac
  45. Top Pentest Tools
  46. Hacking Tools For Windows Free Download
  47. Hacker Techniques Tools And Incident Handling
  48. How To Hack
  49. Pentest Tools Open Source
  50. Hack Tools
  51. Hacker Tools For Pc
  52. Install Pentest Tools Ubuntu
  53. Hack Tools Github
  54. Pentest Automation Tools
  55. Hacker Tools Free
  56. Hack Tools Github
  57. Pentest Automation Tools
  58. Hacker Tools Github
  59. Hacker Tools For Mac
  60. Hack Tools For Windows
  61. Pentest Tools List
  62. Hacking App
  63. Hack Tools
  64. Hack Website Online Tool
  65. Hacker
  66. Pentest Tools Kali Linux
  67. What Are Hacking Tools
  68. Pentest Tools Review
  69. New Hack Tools
  70. Hack Tools
  71. Nsa Hacker Tools
  72. Underground Hacker Sites
  73. Hacker Tools List
  74. Hacker Search Tools
  75. Hacking Tools Usb
  76. Hack Tools For Pc
  77. What Is Hacking Tools
  78. How To Make Hacking Tools
  79. Hacker Tools
  80. Best Pentesting Tools 2018
  81. Hacker Tools Linux
  82. Beginner Hacker Tools
  83. Easy Hack Tools
  84. Hacking Tools
  85. Hack Rom Tools
  86. Pentest Recon Tools
  87. Hack And Tools
  88. Hacker Tools 2019
  89. Hacks And Tools
  90. Nsa Hack Tools
  91. Hacker Tools Mac
  92. Hacking Tools Github
  93. Pentest Tools Free
  94. Hack Tools Pc
  95. Hacker Tools List
  96. Tools For Hacker
  97. Hacker Tools List
  98. Hack Tools For Games
  99. Hacking Tools Usb
  100. Hacker Tools List
  101. Hack Tool Apk
  102. Bluetooth Hacking Tools Kali
  103. Pentest Recon Tools
  104. Pentest Tools Download
  105. Best Hacking Tools 2019
  106. Android Hack Tools Github
  107. Nsa Hacker Tools
  108. Pentest Tools Port Scanner
  109. Pentest Tools Free
  110. Top Pentest Tools
  111. Android Hack Tools Github
  112. Hacking Tools
  113. How To Hack
  114. Hacker Tools Apk
  115. Hacks And Tools
  116. How To Install Pentest Tools In Ubuntu
  117. Hacker Tools Apk
  118. Pentest Tools Website Vulnerability
  119. Pentest Tools Review
  120. Nsa Hack Tools
  121. Hacker Tools 2020
  122. Hacking Tools
  123. Tools 4 Hack
  124. Hacking Tools Download
  125. Hacker Tools Windows
  126. Hack Tools
  127. Hacker Tools Online
  128. Hacker Tools 2019
  129. Hack Tools For Mac
  130. Nsa Hack Tools Download
  131. What Is Hacking Tools
  132. Hak5 Tools
  133. Hacking Tools Windows
  134. Pentest Tools Nmap
  135. Pentest Tools Framework
  136. Hacker Tool Kit
  137. Hacker Techniques Tools And Incident Handling
  138. Hacking Tools For Kali Linux
  139. Hacker Security Tools
  140. Hack And Tools
  141. Bluetooth Hacking Tools Kali
  142. Github Hacking Tools
  143. Pentest Tools For Mac
  144. Nsa Hack Tools Download
  145. Hacking Tools For Games
  146. Pentest Tools Apk
  147. Hacking Tools Mac
  148. Nsa Hack Tools Download
  149. Pentest Tools Download
  150. Hacker Search Tools
  151. Computer Hacker
  152. Growth Hacker Tools
  153. Hacker Tools For Windows
  154. Pentest Tools Online

No comments:

Bloomberg - UTV

Must Watch...Ad may come initially.. wait for video.Also keep volume on

Disclaimer



This Document is subject to changes without prior notice and is intended only for the person or entity to which it is addressed to and may contain confidential and/or privileged material and is not for any type of circulation. Any review, retransmission, or any other use is prohibited. Kindly note that this document does not constitute an offer or solicitation for the purchase or sale of any financial instrument or as an official confirmation of any transaction.


The information contained herein is from publicly available data or other sources believed to be reliable. While I would endeavour to update the information herein on reasonable basis, I am under no obligation to update or keep the information current. Also, there may be regulatory, compliance, or other reasons that may prevent me from doing so. I do not represent that information contained herein is accurate or complete and it should not be relied upon as such. This document is prepared for assistance only and is not intended to be and must not alone betaken as the basis for an investment decision. The user assumes the entire risk of any use made of this information. Each recipient of this document should make such investigations as it deems necessary to arrive at an independent evaluation of an investment in the securities of companies referred to in this document (including the merits and risks involved), and should consult its own advisors to determine the merits and risks of such an investment. The investment discussed or views expressed may not be suitable for all investors. I do not undertake to advise you as to any change of my views. I may have issued other reports that are inconsistent with and reach different conclusion from the information presented in this report. This report is not directed or intended for distribution to, or use by, any person or entity who is a citizen or resident of or located in any locality, state, country or other jurisdiction, where such distribution, publication, availability or use would be contrary to law, regulation or which would subject me to any registration or licensing requirement within such jurisdiction. The securities described herein may or may not be eligible for sale in all jurisdictions or to certain category of investors. Persons in whose possession this document may come are required to inform themselves of and to observe such restriction. I may have used the information set forth herein before publication and may have positions in, may from time to time purchase or sell or may be materially interested in any of the securities mentioned or related securities. I may from time to time solicit from, or perform investment banking, or other services for, any company mentioned herein. Without limiting any of the foregoing, in no event shall I or any third party involved in, or related to, computing or compiling the information have any liability for any damages of any kind.