Magical Ancient – Yukthi CTF 2024 Finals

Introduction

In the Yukthi CTF 2024 Finals, “Magical Ancient” presents an exciting blockchain-based adventure. Participants will navigate through smart contract complexities, performing reentry attacks and exploiting contract loopholes to acquire special tokens. This challenge provides a hands-on learning experience, particularly for aspiring IT students interested in blockchain security and smart contract exploitation.

Getting Started with Selfmade Ninja Labs

To begin your journey with Selfmade Ninja Lab cloud lab training for aspiring students, follow these steps:

  1. Sign Up on Selfmade Ninja Labs
    • Visit Selfmade Ninja Labs to create your account (Click here)
    • If you don’t have an account, use Git Selfmade Ninja Sign-In to register (Click here)
  2. Activate WireGuard:
    • Ensure WireGuard is activated for seamless access.
  3. Access the Labs:
    • Navigate to the Selfmade Ninja Labs Dashboard
    • Click on Machine Labs from the main dashboard.
  4. Select Your Challenge:
    • On the left navbar, click My Lab dropdown, then select Challenge Lab.
    • Browse the list of challenges and search for Magical Ancient.
    • Click the Challenge button.
  5. Deploy and Start the Mission:
    • On the top-right of the screen, click Replay the Lab to redeploy it.
    • Click Start Mission to begin.
  6. Port Forwarding:
    • Use the provided IP in your terminal or Visual Studio Code (VS Code) to set up port forwarding. Once done, you’re ready to start the challenge.

What You Will Learn

  • Blockchain Reentry Attack: Understand the vulnerabilities within smart contracts that allow for reentry attacks.
  • Smart Contract Analysis: Learn how to dissect and analyze BSC (Binance Smart Chain) smart contracts to identify exploitable loopholes.
  • Interacting with Smart Contracts: Gain practical experience using tools like Remix IDE and Metamask to interact with and exploit contracts on the blockchain.
  • Selfmade Ninja Lab Cloud Lab Training: This challenge provides an ideal environment for aspiring IT students to refine their skills through practical, cloud-based training in blockchain and smart contract security.

Challenge 1: Magic Quest

Story

Upon discovering the village magician’s plight, with his magical sticks locked away, you embark on a quest to recover them. The journey starts with unlocking a door using a key hidden within smart contract files.

Challenge Flow

  1. Initial Discovery:
    An nmap scan uncovers an open port 80, revealing a website that prompts for a key. This initial discovery sets the stage for the challenges ahead, indicating the need to navigate through blockchain vulnerabilities to proceed.
    Website Request

    Based on the Nmap scan, I found that port 80 is open. I then performed port forwarding and accessed the web service on my local machine.

    Website Request

  2. Contract Analysis:
    The journey into blockchain exploitation begins with the extraction of blocksna.tar.gz, revealing two significant contracts: etherstorage.sol and attacker.sol. These contracts hint at a reentry attack scenario, a common vulnerability within smart contracts that allows for unauthorized Ether withdrawals.

    tar -xzvf blocksna.tar.gz

    Contract Extraction

    Delving deeper, you utilize Remix IDE to thoroughly analyze the contracts, pinpointing the precise vulnerability that will allow for the reentry attack. This step is critical, as understanding the contract’s logic is key to crafting a successful exploitation strategy.
    Remix IDE Setup

  3. Performing the Attack:
    The attack phase begins with the deployment of the EtherStorage contract. This contract acts as the target for your reentry attack, storing Ether that you aim to extract unlawfully. After deploying EtherStorage, you make an initial deposit of Ether to simulate a real-world scenario where the contract holds funds.
    Compile and Deploy EtherStorage

    With EtherStorage set up and funded, the next critical step involves deploying attacker.sol. This contract is designed to exploit the reentry vulnerability in EtherStorage. By feeding it the address of the EtherStorage contract, you prepare attacker.sol to interact directly with the target.
    Deploy attacker.sol and Interact

    The climax of the attack is reached when you execute the attack function within the attacker.sol contract, sending along 1 Ether as bait. This triggers the reentry exploit, allowing you to withdraw all the Ether contained within EtherStorage, far exceeding the initial amount sent.
    Attack Execution

    Successful execution of the attack not only retrieves the key 1tnettech398ytfl35tester7tech but also demonstrates the attack’s effectiveness by significantly increasing your Ether balance by 4 Ether — a clear sign of victory in the world of blockchain security.
    Successful Attack Outcome

Challenge 2: Final Triumph

Story

With the key from the first challenge in hand, your journey to revive the old magician’s stick by securing a special coin from the blockchain network begins.

Challenge Flow

  1. Website Interaction:

    You’re greeted by a webpage that features two crucial buttons: "Connect to Metamask" and "Check Balance," setting the stage for your task.

    Website Interaction

  2. Setting up the BSC Testnet in Metamask:
    Before proceeding, you ensure your Metamask is configured for the BSC testnet, enabling transactions and interactions with the contract.
    BSC Testnet Setup

  3. Acquiring Test BNB:
    To engage with the contract, you acquire Test BNB from a faucet, providing the necessary funds for transactions.
    Acquiring Test BNB

  4. Connect to BSC Testnet RPC URL:

    • Open this URL in your browser: BSC Testnet Chain
    • Connect your wallet using your Metamask account by following the instructions on the page.

    Metamask Connection

    • Now, your account is connected to the BSC Testnet.
  5. Accessing the Token Contract:
    With Metamask ready and Test BNB in hand, you navigate to the specified token address on BSC Scan, initiating your contract analysis.
    Accessing the Contract

  6. Analyzing the Contract:
    A thorough examination of the contract functionalities on BSC Scan uncovers a loophole for acquiring SNA tokens, pivotal for advancing in your quest.
    Contract Analysis

  7. Exploiting the User Function:
    To buy tokens, you discover the need to be an addedUser. Successfully exploiting the User function with your address and a 3-digit even number, you’re added as an authorized user.
    User Function Exploit

  8. Buying SNA Tokens:
    As an addedUser, you interact with the buyToken function to purchase SNA tokens, a crucial step towards your goal.
    Buying Tokens

  9. Verifying Token Acquisition:
    Returning to the initial webpage, you verify your SNA token balance, confirming the successful acquisition of the tokens and, consequently, the restoration of magical power to the magician’s stick.
    Token Balance Verification

Conclusion

The “Final Triumph” challenge concludes with the restoration of the magician’s stick, demonstrating the participant’s ability to navigate complex blockchain interactions and exploit smart contract vulnerabilities. This challenge highlights the value of Selfmade Ninja Lab cloud lab training for aspiring IT students, offering practical training in blockchain security and smart contract exploitation, essential skills for anyone looking to thrive in the evolving world of IT.

Leave a Comment

Realted Blog >>

Send the Alien Back home
🛡 Deep Dive into Path Traversal with "Send the Alien Back Home" - Selfmade Ninja Lab Cloud Lab Training for Aspiring IT Students 🛡
Hey Ninjas! 🥷  Welcome to an in-depth write-up for the "Send the Alien Back Home" CTF challenge!...
A Blockchain OSINT Challenge
Case 118 Unlocked: A Blockchain OSINT Challenge Guide
Introduction Case 118 Unlocked presents an exciting blockchain-based OSINT challenge on the Binance Smart...
Pickle Portal
Exploring the Pickle Portal Challenge: Python and Linux Skills Enhancement with Selfmade Ninja Lab
Introduction The Pickle Portal Challenge offers a deep dive into essential programming and system management...
1 2 3 5
Scroll to Top