data:image/s3,"s3://crabby-images/045c7/045c72bfb4791f1a31e3204d158ba83c25d079ca" alt=""
By: Dikla Barda, Roaman Zaikin & Oded Vanunu
On February 24, Check Point Blockchain Threat Intel System observed a sophisticated attack on a DeFi protocol, Infini.
Infini is a digital banking platform in the crypto space that offers its users savings yields and other financial services. The platform aims to make crypto assets more accessible practical for everyday transactions.
Unfortunately, this project recently suffered a security breach that targeted its yield management system, resulting in the loss of approximately 50 million USDC. The attacker exploited compromised private keys, carefully manipulated access controls, and executed a precise sequence of transactions to drain funds.
Here, we’ll break down this heist step by step.
The Compromised Private Key
The attack began with transactions from address 0xc49b5e5B9DA66B9126c1a62e9761E6b2147DE3E1, which held administrative privileges in the protocol. Infini has stated that they believe this private key may have been compromised.
Private key security is one of the most challenging aspects of blockchain security. Even with best practices in place, sophisticated attackers can sometimes gain access through various vectors, including phishing, malware, or other techniques. Without a full investigation, it’s premature to draw conclude exactly how the administrative access was obtained.
With this key, the attacker could sign transactions as if they were the legitimate owners—a critical first step that gave them initial access to the protocol.
Exploiting the Role-Based Access Control System
Looking at the decompiled contract code, we can see the core function that determines role authorization:
The compromised address had admin privileges, which allowed the attacker to grant the REDEEMER_ROLE to themselves using the stolen key.
Setting Up the Extraction Path
Before funds could be withdrawn, the attacker needed to register their address as a valid destination. Looking at the contract code, we can see the critical function:
This function registers an address in the map_4 mapping, which the withdrawal function checks during execution.
The attacker used the compromised key to call this function and register their address as a valid destination, setting up the path for the funds to exit the protocol.
The Withdrawal Function
The heart of this exploit was the ability to call the token redemption function, which has the hex signature 0xcfda09ef. Let’s examine this critical function:
This function works by:
With the REDEEMER_ROLE and their address registered in map_4, the attacker could now call this function to drain funds to their wallet.
The Execution
The attack culminated in a transaction that called the 0xcfda09ef function with these parameters:
Copy
0xcfda09ef000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb480000000000000000000000000000000000000000000000000000229dc42982570000000000000000000000003ac96134fb0e42a52d33045aee50b89790f05ed0000000000000000000000000e0e83f21d5b6da61c9cf75d3b89fbcacfbfde32700000000000000000000000000000000000000000000000000000000000000a00000000000000000000000000000000000000000000000000000000000000000
When decoded:
The Bounty Offer
Following the attack, Infini took an approach that has become increasingly common in the DeFi space. The protocol team sent an on-chain message to the attacker, offering a bounty of 20% of the stolen funds (approximately 10 million USDC) if the remaining funds were returned.
The message was embedded in a transaction to the attacker’s wallet and read:
This approach, sometimes called a “white hat agreement” or “bug bounty after the fact,” has occasionally been successful in recovering funds from attacks where the exploiter is primarily motivated by financial gain rather than causing harm to the protocol. The strategy acknowledges that legal recovery of crypto assets can be difficult and time-consuming, while offering the attacker a legitimate way to profit from their discovery without risking legal consequences.
As of the time of writing, it remains to be seen whether the attacker will accept this offer.
Security Lessons
This attack highlights several critical security considerations for DeFi protocols:
Conclusion
This case study demonstrates how seemingly isolated security vulnerabilities can be chained together into devastating attacks. The attacker methodically:
Each step built upon the previous one, ultimately leading to a complete protocol compromise. While the code contained various security checks, the fundamental issue was that once the private key was compromised, the role-based system could be manipulated from within.
This attack reinforces that security is only as strong as its weakest link, and sophisticated attackers will exploit multiple small vulnerabilities to achieve their goals.