Characterizing Transaction-Reverting Statements in Ethereum Smart Contracts
Smart contracts are programs running on blockchain to execute transactions. When input constraints or security properties are violated at runtime, the transaction being executed by a smart contract needs to be reverted to avoid undesirable consequences. On Ethereum, the most popular blockchain that...
Gespeichert in:
Hauptverfasser: | , , , , , |
---|---|
Format: | Artikel |
Sprache: | eng |
Schlagworte: | |
Online-Zugang: | Volltext bestellen |
Tags: |
Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
|
Zusammenfassung: | Smart contracts are programs running on blockchain to execute transactions.
When input constraints or security properties are violated at runtime, the
transaction being executed by a smart contract needs to be reverted to avoid
undesirable consequences. On Ethereum, the most popular blockchain that
supports smart contracts, developers can choose among three
transaction-reverting statements (i.e., require, if...revert, and if...throw)
to handle anomalous transactions. While these transaction-reverting statements
are vital for preventing smart contracts from exhibiting abnormal behaviors or
suffering malicious attacks, there is limited understanding of how they are
used in practice. In this work, we perform the first empirical study to
characterize transaction-reverting statements in Ethereum smart contracts. We
measured the prevalence of these statements in 3,866 verified smart contracts
from popular dapps and built a taxonomy of their purposes via manually
analyzing 557 transaction-reverting statements. We also compared template
contracts and their corresponding custom contracts to understand how developers
customize the use of transaction-reverting statements. Finally, we analyzed the
security impact of transaction-reverting statements by removing them from smart
contracts and comparing the mutated contracts against the original ones. Our
study led to important findings, which can shed light on further research in
the broad area of smart contract quality assurance and provide practical
guidance to smart contract developers on the appropriate use of
transaction-reverting statements. |
---|---|
DOI: | 10.48550/arxiv.2108.10799 |