, 6 tweets, 2 min read Read on Twitter
Important turning point in the life of #ethereum's constantinople hard fork: medium.com/chainsecurity/…
A brief explanation follows, will take a few tweets.

In a smart contract transferring value to a recipient can be accomplished via the CALL operation. It is possible to configure this operation to send gas to the recipient.
If no gas is specified, then a fixed stipend of 2300 gas is sent. The recipient can be another contract. Solidity’s “transfer()” feature uses this.
Currently, it is not possible to make lasting changes in the state with 2300 gas. It possible to make a call to another contract or to issue events. Changing a storage entry costs 5000 gas.
After Constantinople however in certain cases changing a storage entry can be as low as 200 gas. One such case is when writing a “dirty” entry, i.e. an entry which had a value previously.
The attack here is that a malicious callee can change the storage of the caller during a transfer, if the caller doesn’t take precautions. The problem lies in the fact that smart contract developers operated under the assumption that “transfer()” was safe from reentrancy issues.
Missing some Tweet in this thread?
You can try to force a refresh.

Like this thread? Get email updates or save it to PDF!

Subscribe to Alex Beregszaszi
Profile picture

Get real-time email alerts when new unrolls (>4 tweets) are available from this author!

This content may be removed anytime!

Twitter may remove this content at anytime, convert it as a PDF, save and print for later use!

Try unrolling a thread yourself!

how to unroll video

1) Follow Thread Reader App on Twitter so you can easily mention us!

2) Go to a Twitter thread (series of Tweets by the same owner) and mention us with a keyword "unroll" @threadreaderapp unroll

You can practice here first or read more on our help page!

Follow Us on Twitter!

Did Thread Reader help you today?

Support us! We are indie developers!


This site is made by just three indie developers on a laptop doing marketing, support and development! Read more about the story.

Become a Premium Member ($3.00/month or $30.00/year) and get exclusive features!

Become Premium

Too expensive? Make a small donation by buying us coffee ($5) or help with server cost ($10)

Donate via Paypal Become our Patreon

Thank you for your support!