A tool that finds smart contracts with time locks on Ethereum main-net
To install PostgreSQL run the following command:
sudo apt-get install postgresql postgresql-contrib
To install pg_config and Build psycopg2 from Source, run the following command:
sudo apt-get install libpq-dev
Use the package manager pip to install the requirements.
pip3 install -r requirements.txt
To configure PostgreSQL run the following command:
sudo -u postgres psql
If it's your first time running the tool on a system, run the following commands in the PostgreSQL shell:
CREATE DATABASE tlsc;
CREATE USER kia WITH PASSWORD 'tlsc';
GRANT ALL PRIVILEGES ON DATABASE tlsc TO kia;
The rpc_finder package is used to find RPC endpoints for Erigon Ethereum nodes. It first fetches the list of synced Erigon nodes from Ethernodes.org and then checks if they are responding to JSON-RPC requests. The list of all running RPC endpoints is then stored in erigon_sorted_hosts.csv file.
To fetch all possible RPC endpoints, run the following command:
python rpc_finder/get_rpcs.py
After fetching all possible endpoints, in order to fetch only the RPC endpoints that are responding to JSON-RPC requests and are up-to-date, run the following command:
python rpc_finder/rpc_vitals_check.py
The tlsc_inspector package is used to inspect a given range of Ethereum blocks for contracts that have time locks. It first fetches the list of all running RPC endpoints from erigon_sorted_hosts.csv file. Then it starts up a number of processes to inspect blocks in parallel. Each process then runs several threads to fetch blocks from the RPC endpoints and inspect them for the contracts. The results are then stored in the PostgreSQL database. Each entry of the database has the following fields:
- contract_address: The address of the contract
- bytecode: The bytecode of the contract
- from_address: The address that created the contract
- tx_hash: The hash of the transaction that created the contract
- block_number: The block number in which the contract was created
To inspect a given range of blocks, run the following command:
python inspect_many.py -a START_BLOCK_RANGE -b END_BLOCK_RANGE
The inspector by default starts up as many processes as the number of available cpu cores. You can specify the number of processes to start up by using the -p flag:
python inspect_many.py -a START_BLOCK_RANGE -b END_BLOCK_RANGE -p NUMBER_OF_PROCESSES
The inspector creates a log file named inspector.log in the logs directory.
The contract_inspector package is used to inspect a given set of contract addresses for their ETH balance, recent transactions, and internal transactions. It first fetches the list of all running RPC endpoints from erigon_sorted_hosts.csv file. Then it starts up a number of processes to inspect contracts in parallel. Each process then runs several threads to inspect the contract transactions. The results are then stored in the PostgreSQL database. Each entry of the database has the following fields:
- contract_address: The address of the contract
- eth_balance: The ETH balance of the contract
- largest_tx_hash: The hash of the largest transaction to the contract
- largest_tx_block_number: The block number of the largest transaction to the contract
- largest_tx_value: The value of the largest transaction to the contract
Note that some information for contracts is fetched via block inspector.
To inspect a given set of contracts, run the following command:
python inspect_many.py -mc PATH_TO_CONTRACTS_CSV_FILE -p NUMBER_OF_PROCESSES
The block_inspector package is used to inspect a given set of blocks for their transactions. It first fetches the list of all running RPC endpoints from erigon_sorted_hosts.csv file. Then it starts up a number of processes to inspect blocks in parallel. Each process then runs several threads to inspect the block transactions. The results are then stored in the PostgreSQL database. Each entry of the database has the following fields:
- block_number: The block number
- reward: The block reward
- miner: The address of the miner
- miner payout: The miner payout
- gas used: The gas used in the block
- gas limit: The gas limit of the block
The block inspector also fetches the transactions to and from of a given set of contracts addresses. The results are then used to update the contracts_info table.
In order to inspect a given set of blocks, run the following command:
python inspect_many.py -mb -a START_BLOCK_RANGE -b END_BLOCK_RANGE -p NUMBER_OF_PROCESSES
The database package is used to create the PostgreSQL database and the tables. It also contains the models for the database tables.
In order to create the database and the tables, run the following command:
python create_db.py
Note that this command is automatically run when you run the inspect_many.py script. Also note that the database is created with the name tlsc and the user kia with the password tlsc. You can change these values in the create_db.py file.
Feel free to dive in! Open an issue or submit PRs.
Apache License 2.0 © Kianoush Arshi
- Check if contracts have time locks
- Implement a better way to inspect contracts
- Implement Block inspector
- Check token balances
- Add tests
- Add more documentation