ethereum/EIPs#4758 is a proposal which changes the behavior of the EVM SELFDESTRUCT
opcode and renames it to SENDALL
. SENDALL
removes the contract destruction aspect of SELFDESTRUCT
while retaining the behavior which transfers the balance of the executing contract to a target recipient, and immediately returns execution to the calling contract.
There are two main use-cases for selfdestruct after the London hard fork:
- Selfdestructable contracts with addresses generated by
CREATE2
can be destroyed, and new contracts created at the same address. This can serve as a contract update mechanism. - Contracts can be created, used, and selfdestructed within the same transaction. These are referred to as ephemeral contracts.
Addresses where contracts were destroyed and then recreated (whether as a result of a contract redeployment or ephemeral contracts making use of the same address more than once) are referred to as a re-inited addresses.
From genesis to block 12,799,316 (the time period looked at in the previous analysis work), there were 11304 contracts which created and redeployed child contracts, 69102 addresses which were re-inited one or more times.
Since London (block 12,965,000), 34 contracts redeployed child contracts, 233 contracts created ephemeral contracts at 97266 addresses, 235 addresses had multiple non-ephemeral contracts deployed at them. 1279 addresses where ephemeral contracts executed were re-inited.
Of all re-inited addresses and creators of re-inited addresses, 14 had nonzero Ether balances. Here are the ten addresses with the largest balances:
Address | Ether balance | Creator of re-inited contract | re-inited contract | Project |
---|---|---|---|---|
0x0000000000007f150bd6f54c40a34d7c3d5e9f56 | 1052.0346555690187 | ✔️ | ||
0x36049d479a97cde1fc6e2a5d2cae30b666ebf92b | 98.89128076172763 | ✔️ | Pine Finance | |
0x000000000035b5e5ad9019092c665357240f863e | 33.67848284726566 | ✔️ | ||
0x0000000099cb7fc48a935bceb9f05bbae54e8987 | 11.07584061230294 | ✔️ | ||
0xd412054cca18a61278ced6f674a526a6940ebd84 | 7.271706101417892 | ✔️ | Pine Finance | |
0xf2d47e78dea8e0f96902c85902323d2a2012b0c0 | 3.3781819040953978 | ✔️ | ||
0x00000000032962b51589768828ad878876299e14 | 3.051639286062525 | ✔️ | ||
0xd7c8bde678ec968ae7e085b507f7d0affd27b1e8 | 0.20852379 | ✔️ | ||
0xed63aeb5b66b47129532a3d56745387cc4d4a607 | 0.038416454655773064 | ✔️ |
Some next steps for the analysis are:
- Identifying contracts from the list of potentially-affected which hold large/valuable ERC20 balances.
- Identifying currently-existing selfdestructable contracts which were deployed via
CREATE2
and determining of these and their creators, which have large ERC20/Ether holdings.
Once there is a full list of potentially-affected contracts, further examination the solidity source or bytecode of these contracts can be useful.
The first step is to retrieve the raw dataset of contract creation / selfdestruct internal transaction traces from the BigQuery Ethereum dataset with the following query:
select block_hash, transaction_hash, trace_id, block_number, transaction_index, from_address, to_address, trace_type, call_type, status, value from `bigquery-public-data.crypto_ethereum.traces`
where (trace_type='suicide' or trace_type = 'create')
order by block_number asc, transaction_index asc
The dataset is somewhat large (30gb) and must be exported as multiple csv files to a GCS bucket. When exporting from BigQuery to GCS, choose data-*.csv
as the naming format for the exported files. Download these csvs to a folder data-traces
placed in the top-level directory of this repo. Execute the script rename-files.py
to rename the downloaded files so that their data is ordered properly (i.e. the layout of the data in data-0001.csv
, data-0002.csv
, ... is chronological. when the files are downloaded from the storage bucket, the numerical prefix assigned to a given csv is somewhat random).
Execute the analysis by running analyze.py
.
The analysis script producess these files as results:
creators-of-redeployed-addrs.csv
- list of any contract that created an child contract which was redeployed.creators-of-ephemeral-contracts.csv
- list of accounts which created ephemeral contracts.redeployed-addrs.csv
- a list of addresses which had contract redeployments.ephemeral-addrs.csv
- a list of addresses where ephemeral contracts executed.ephemeral-creators-which-reuse-addrs.csv
- creators of ephemeral contracts that executed at re-inited addresses.
To get a list of Ether balances for all accounts in these files, execute query_balances_for_creators_and_reinited_addrs.py
.