HCC: A Language-Independent Hardening Contract Compiler for Smart Contracts

Jens-Rene Giesen,Sebastien Andreina,Michael Rodler,Ghassan O. Karame,Lucas Davi
2024-12-05
Abstract:Developing secure smart contracts remains a challenging task. Existing approaches are either impractical or leave the burden to developers for fixing bugs. In this paper, we propose the first practical smart contract compiler, called HCC, which automatically inserts security hardening checks at the source-code level based on a novel and language-independent code property graph (CPG) notation. The high expressiveness of our developed CPG allows us to mitigate all of the most common smart contract vulnerabilities, namely reentrancy, integer bugs, suicidal smart contracts, improper use of <a class="link-external link-http" href="http://tx.origin" rel="external noopener nofollow">this http URL</a>, untrusted delegate-calls, and unchecked low-level call bugs. Our large-scale evaluation on 10k real-world contracts and several sets of vulnerable contracts from related work demonstrates that HCC is highly practical, outperforms state-of-the-art contract hardening techniques, and effectively prevents all verified attack transactions without hampering functional correctness.
Cryptography and Security
What problem does this paper attempt to address?