Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.
nitowa 8180295b9f add why-this-works slide 10 місяці тому
SemSEpaper improve paper formatting, code coloring, add abstract+conclusion, add safe code example, fix typos 1 рік тому
SemSEpresentation add why-this-works slide 10 місяці тому
SemSEreport add why-this-works slide 10 місяці тому
papers add paper template 1 рік тому
.gitignore Add initial presentation 10 місяці тому
README.md add paper template 1 рік тому

README.md

SWC-124: Write to Arbitrary Storage Location

Introduction

The aim of this paper is to introduce the SWC-124 smart contract weakness. In order to do that, the paper will:

  • describe weakness itself and the consequences if the weakness is exploited;
  • describe the various forms it may take and construct minimal sample contracts for each variant. It will also describe variants that look similar but are not a weakness, and construct minimal contracts for these non-weaknesses;
  • collect vulnerable contracts used by different papers to motivate/illustrate the weakness;
  • summarize the code properties that tools are looking for so that they can detect the weakness;
  • sketch ways to potentially exploit the different variants of the weakness.

Weakness description

Smart contracts in Ethereum support persistent storage on the EVM level. It is the contracts responsibility to implement access control to sensitive information and doing so incorrectly may allow an attacker:

  • to read and overwrite sensitive data that should only be accessible to contract owners, maintainers etc.;
  • setting himself as the contract owner and circumventing authorization checks;
  • draining the contract of its funds by, for example, overwriting the address that collects the received tokens;
  • TODO: add more

Various forms

  1. Arrays + integer underflow/overflow
  2. Unchecked assembly calls
  3. TODO: add more

Samples

TODO

Code properties

TODO

Potential exploits

TODO