API exposing public statistics about Spark
Base URL: http://stats.filspark.com/
-
GET /retrieval-success-rate?from=2024-01-01&to=2024-01-31
-
GET /retrieval-success-rate?from=2024-01-01&to=2024-01-31&nonZero=true
Miners with no successful retrievals are excluded from the RSR calculation.
http://stats.filspark.com/retrieval-success-rate?nonZero=true
-
GET /miners/retrieval-success-rate/summary?from=<day>&to=<day>
http://stats.filspark.com/miners/retrieval-success-rate/summary
-
GET /miner/:id/retrieval-success-rate/summary?from=<day>&to=<day>
http://stats.filspark.com/miner/f0814049/retrieval-success-rate/summary
-
GET /miner/:id/deals/eligible/summary
http://stats.filspark.com/miner/f0814049/deals/eligible/summary
-
GET /client/:id/deals/eligible/summary
http://stats.filspark.com/client/f0215074/deals/eligible/summary
-
GET /allocator/:id/deals/eligible/summary
http://stats.filspark.com/allocator/f03015751/deals/eligible/summary
-
GET /participants/daily?from=<day>&to=<day>
-
GET /participants/monthly?from=<day>&to=<day>
-
GET /participants/accumulative/daily?from=<day>&to=<day>
-
GET /participants/change-rates?from=<day>&to=<day>
-
GET /participants/top-earning
-
GET /participants/top-measurements
http://stats.filspark.com/participants/top-measurements?from=yesterday&to=yesterday
-
GET /participants/summary
-
GET /participant/:address/scheduled-rewards?address=<address>&from=<day>&to=<day>
http://stats.filspark.com/participant/0x000000000000000000000000000000000000dEaD/scheduled-rewards
-
GET /participant/:address/reward-transfers?from=<day>&to=<day>
http://stats.filspark.com/participant//0x000000000000000000000000000000000000dEaD/reward-transfers
-
GET /stations/daily?from=<day>&to=<day>
-
GET /stations/monthly?from=<day>&to=<day>
-
GET /measurements/daily?from=<day>&to=<day>
-
GET /transfers/daily?from=<day>&to=<day>
-
GET /deals/daily?from=2024-01-01&to=2024-01-31
-
GET /deals/summary?from=2024-01-01&to=2024-01-31
-
GET /retrieval-result-codes/daily?from=2024-01-01&to=2024-01-31
For running the tests you will need a postgresql database running on your machine. You can either spin up your own postgres instance or use a prebuilt docker image.
Set up PostgreSQL with default settings:
- Port: 5432
- User: your system user name
- Password: blank
- Database: spark_stats
Alternatively, set the environment variable $DATABASE_URL
with
postgres://${USER}:${PASS}@${HOST}:${POST}/${DATABASE}
.
The Postgres user and database need to exist already, and the user needs full management permissions for the database.
Next, you need to create spark_evaluate
database.
psql postgres://localhost:5432/ -c "CREATE DATABASE spark_evaluate"
You can also run the following command to set up the PostgreSQL server via Docker:
docker run -d --name spark-db \
-e POSTGRES_HOST_AUTH_METHOD=trust \
-e POSTGRES_USER=$USER \
-e POSTGRES_DB=$USER \
-p 5432:5432 \
postgres
Afterwards, you need to create the databases spark_evaluate
and spark_stats
psql postgres://$USER@localhost/$USER -c 'CREATE DATABASE spark_stats'
psql postgres://$USER@localhost/$USER -c 'CREATE DATABASE spark_evaluate'
Finally, run database schema migration scripts.
npm run migrate
npm test
npm start -w stats
You can also run the service against live data in Spark DB running on Fly.io.
- Set up a proxy to forward connections to Spark DB Postgres. Connect to the reader replica running on port 5433 (not 5432).
The command below will forward connections to local post 5455 to Spark DB's reader replica.
fly proxy 5455:5433 -a spark-db
- Start the service and configure the database connection string to use the proxied connection. Look up the user and the password in our shared 1Password vault.
DATABASE_URL="postgres://user:password@localhost:5455/spark_stats" \
EVALUATE_DB_URL="postgres://user:password@localhost:5455/spark_evaluate" \
npm start -w stats
npm start -w observer
git push