[go: up one dir, main page]

Skip to content

polkadot21/wallet_activity_fetcher

Repository files navigation

Top N Active Wallet Fetcher

This application is designed to fetch the top N active wallets on the Ethereum mainnet blockchain, where N is a user-defined parameter.

What is an active wallet?

An active wallet is one that engages in receiving or transferring ERC20 tokens. The activity score of a wallet increases with the number of transactions it participates in.

Disclaimer

Please note that the addresses obtained through this tool include both Externally Owned Addresses (EOAs) and Contract addresses. For instance, top 2 addresses for block 19305605:

[
    {
        "address": "0xdac17f958d2ee523a2206206994597c13d831ec7", // usdt
        "activity": 1114
    },
    {
        "address": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48", // usdc
        "activity": 248
    },
  ...
]

RPC Node Docs

For detailed information on the Ethereum JSON-RPC API and specifics about the eth_blockNumber method used by our application, please refer to the official documentation provided by GetBlock:

Ethereum JSON-RPC API Documentation

Env vars:

For the demo, the application fetches the top 5 active wallets from the past 100 blocks.

RPC_ENDPOINT=<RPC_ENDPOINT>
N_TOP_WALLETS=5
N_BLOCKS=100
LOG_LEVEL=debug
SAVE_PATH=<SAVE_PATH>

How to run?

Build & Run Locally

Provide the environment variables in a .env file.

# Fetch the dependencies for your application
go mod download

# Build your application
go build -o walletActivityParser .

# Run the application
./walletActivityParser

The results will be stored in a JSON file at ./<save_path>.

Docker

Provide the environment variables in a .env file.

# Build and run your application using Docker Compose
docker compose up --build -d

The results will be stored in a JSON file at ./exported_data/<save_path>.

About

Fetch active walllets in the Ethereum Blockchain

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published