Tuesday, August 25, 2020

Blockchain Decentralized Application Hacking Course - A Journey Into Smart Contract Hacking And DApp Penetration Testing (Web 3.0)


Smart Contract Exploitation and Hacking Course Announcement


What Is this: 

For those who have been hitting me up on twitter and YouTube for more blockchain smart contract exploitation content this blog is for you. I have posted a video below explaining what this is and included a course outline of the content we are providing free for everyone. I was actually told recently that I am crazy for giving out this level of detailed content and training for free.. However, I believe in the original hacker ethic code from long ago, that information should be freely available for everyone!! In this frame of mind, the only pay for content will be if you wish to go the extra mile. For the person who wants to prove to themselves or others that they learned something via a certification package with detailed exam prep targets and guides, followed by a final exam CTF and reporting write-up. 

So I hope you enjoy this content. The content and walk through labs will be all free. This content will be posted regularly over the next few months 90% of it is already written and ready to go.

We will start off with the differences between Solidity and other languages and do a quick coding overview before we start hacking. This way everyone is on the same page when we start looking at coding examples of vulnerable targets or reviewing case study code. Then we will cover a wide range of typical issues that effect decentralized applications(DApps) and smart contracts on the Ethereum blockchain. How to spot them and exploit them with full walk-through style learning. Subjects we have already released (Re-Entrancy, Integer Attacks, Authorization) have been updated with new code, new examples, and case studies etc. Some of the learning content will be the same but with a lot of newly added content.  And in the case of Authorization completely re-written and expanded on. 

Basically this course was created to get the information out there in a clear concise way. Because when I started researching blockchain hacking all I found was a paragraph here and there on something that was overly technical or completely theoretical. I couldn't find any clear concise learning or examples. This drove me nuts trying to figure everything out, until I gave up and just coded my own vulnerabilities and hacked them. So hopefully this fills the knowledge gap to offer a clear and concise, Zero Fluff resource to those on the same path. 


CTF Exam: 

If you do enjoy this series over the next few months and want to challenge your skills and certify that you learned something we will be also offering pay for certification bundle that includes Decentralized Application (DApp) targets and detailed lab guides as preparation for a final exam against a more comprehensive CTF certification challenge target. More info on this as the months progress. 


Bug Bounty of Sorts: 

These labs are completed but we are working on a way to deliver the content which requires me to code up a course delivery software. So feel free to hack the course delivery software once its up, if you break in or bypass authorizations I will give you the full course for free provided you help me fix it. :P 


Pre- Requisites: 

This is more of a intermediate / advanced course with a white box code approach to bug hunting and a dynamic approach to application hacking and exploiting targets, with that said you will need the following pre-requisites: 

  • Ability to code in some language and understanding of coding concepts. 
  • Application hacking or development background with firm understanding of vulnerabilities


Contact Info:

As this is free, I only ask that you provide constructive feedback as we are creating other more advanced hacking courses on random subjects we are interested in. Most of which will be free.  And feedback helps us not do things which are not useful and integrate new ideas where they make sense.

Cheers and I hope this finds you well.

Twitter: 

Email: 

  • info@cclabs.io

WebPage:  


Intro Video: 



Course Outline / Release Order: 

Orange = = Whats included additionally for the full course

Blue = = What will be released free in blogs / videos 

(Mostly every Mondays) over the next few months


Building and Scoping Things

    Chapter 1: Cliff Notes on Blockchain

        Intro:

        What is a Blockchain and how is it secured

        Smart Contracts

        What is a Decentralized Application (DApp)?

        Diving into Blockchain Components:

        Distributed Vs Decentralized

        Provenance Use Case:

        Consensus and Mining:

            Hands on Lab - Blockchain Consensus walkthrough Lab

        Summary:

        References:


    Chapter 2: Threat Modeling and Scoping Engagements

        Architecture Considerations:

        Business Logic Locations and Technology Decisions

        Development Environments

        Threat Modeling

        Summary

        References:


    Chapter 3 – Solidity for Penetration Testers Part 1 (Hello World)

        About Solidity

            Hands on Lab - Remix interface overview

        Structure of a Smart Contract

            Hands on Lab – HelloWorld

        Summary

        References:


    Chapter 4 – Solidity for Penetration Testers Part 2

        Beyond Hello World

            Hands on Lab – Code HelloWorld bank

        Code Level Walk Through of HelloWorld Bank

        Checks Effects Interactions:

        Summary


Part 2: Hacking and Exploiting Things

    Chapter 5 - Glass Half Full or Glass Half Empty: Integer Attacks

        Underflows and Overflows

        Withdraw Function Vulnerable to an underflow

        Transfer Function Vulnerable to a Batch Overflow

        Batch Overflow Code Explanation:

            ERC20 Batch Overflow Case-Study

            Walkthrough of The Vulnerable Function

            Reviewing the Real Attack Transaction

            Hands on Lab - Exploiting Our Own ERC20 Batch Overflow

            Hands on Lab - Fixing the ERC20 Overflow

            Exam Prep - DApp Target + Detailed Lab Guide

            Hands on Lab -Safe Math Walk Through

        Integer Attacks Summary

        Integer Attacks References

          

    Chapter 6 - You Again: Leveraging Reentrancy Attacks

        Reentrancy Intro

        Checks Effects Interactions Pattern

        Simple Reentrancy Example Code

        Passing the Checks:

        Looping the Interaction:

        Updating the Effects:

        Attacking Code Example:

            Hands on Lab - Attacking a Simple Reentrancy

            Hands on Lab - Fixing the Checks Effects interaction Pattern

        Send vs Transfer Vs Call.Value

            Case Study – The Dao Hack

            Exam Prep - DApp Target + Detailed Lab Guide

        Reentrancy Summary

        Reentrancy References


    Chapter 7 Do You Have a Hall Pass: Access Control Attacks

        Understanding Smart Contract Authorization and Visibility

        Visibility:

        Simple Visibility Example:

        Implementing Authorization:

        Example Walk-through of No Authorization

        Thinking about Smart Contracts as unpublished API's for DApps

            Case of the Video Game Heist

        Enumerating functions in a contract

            Hands on Lab - Directly Calling Public Functions with Web3

            Hands on Lab - Example Fix with Simple Authorization

        Exit Scam Warning

            Hands on Lab - Example Fix-2 Using Modifiers for Simple Authentication

            Hands on Lab - Example Using Openzeppelin for Role Based Access Control

            Exam Prep - DApp Target + Detailed Lab Guide

        Authorization Summary:

        Authorization References


    Chapter 8 - Dude Where's My Data: Storage Vs Memory Attacks

       Intro - Not Written Yet – Up Next

       Code Example -  Not Written Yet – Up Next

       Case study? - Not Written Yet – Up Next

       Exploiting vulnerability -  Not Written Yet – Up Next

       Summary -  Not Written Yet – Up Next

       References -  Not Written Yet – Up Next


    Chapter 9 - Do I know you:  TxOrigin vs Message.sender Attacks

        What's the difference?

        Man In the Middle Via tx.origin

            Hands on Lab -  Simple tx.origin Example Walkthrough

            Hands on Lab -  Vulnerable TX.Origin Example Walkthrough

            Exam Prep - DApp Target + Detailed Lab Guide

        Action steps to familiarize yourself with the contract:

        Attack Options:

        Summary

        References


    Chapter 10 - Who Am I: Delegate Call Attacks

        How delegate calls work:

        Delegate Call vs Call

        Simple Delegate Call Example Code

        Simple Delegate Code Example Walkthrough

            Hands on Lab - Simple Delegate Example Walkthrough

        Variable Memory Issues with Delegate Calls

        DelegateCall Storage Simple Example Code

            Hands on Lab - DelegateCall Storage Walkthrough

            Exam Prep - DApp Target + Detailed Lab Guide

        Case Study - Parity Wallet Attack:

        Attack Transactions Explained

        Dangerous fallback function using delegatecall

        The Parity Wallet Code

        Delegate Chapter Summary

        Delegate References:


    Chapter 11 - Look into My Crystal Ball: Bad Randomness Issues

        Cryptographic Implementations and Predictable PRNGs

        Simple BlockHash Example

            Hands on Lab - BlockHash Vulnerability Walk and Talk

            Exam Prep - DApp Target + Detailed Lab Guide

        Preventing Randomness Issues

        Bad Randomness Summary

        Bad Randomness References


    Chapter 12 - Automated Static Application Security Testing

        Content - Not written - Up Next 

            Hands On Lab - Not written - Up Next 

        Summary Not written - Up Next 

        References - Not written - Up Next 


Chapter 13 - CTF Exam

        Final Exam and CTF Certification Exam Target 

        Final Exam Reporting


Appendices

    Appendix I – Pre-Requisite Suggestions:

        Programming Pre-Requisites:

        Web Application Hacking Pre-Requisites:

    Appendix II – Other Blockchain Learning Resources and Certifications

    Appendix III – Non-Exhaustive Scoping Questions

    Appendix IV – Non-Exhaustive List of things to check for



Related posts


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

No comments:

Post a Comment