| Crates.io | aoc_leaderboard |
| lib.rs | aoc_leaderboard |
| version | 0.2.0 |
| created_at | 2024-12-28 07:28:17.454053+00 |
| updated_at | 2025-01-19 07:37:03.045024+00 |
| description | Strongly-typed wrapper for Advent of Code leaderboard data |
| homepage | https://github.com/clechasseur/aoc_leaderbot#readme |
| repository | https://github.com/clechasseur/aoc_leaderbot |
| max_upload_size | |
| id | 1496906 |
| size | 91,092 |
Strongly-typed wrapper for an Advent of Code leaderboard and a convenient way to fetch its data.
Add aoc_leaderboard to your dependencies:
[dependencies]
aoc_leaderboard = "1.0.0"
or by running:
cargo add aoc_leaderboard
use std::env;
use aoc_leaderboard::aoc::Leaderboard;
use dotenvy::dotenv;
#[tokio::main]
async fn main() -> anyhow::Result<()> {
// Maybe your AoC token lives in a `.env` file?
let _ = dotenv();
// Fetch AoC session token and leaderboard ID from the environment.
let aoc_token = env::var("AOC_TOKEN")?;
let leaderboard_id = env::var("AOC_LEADERBOARD_ID")?.parse()?;
// Load the leaderboard from the AoC website.
// Careful not to call this more than once every **15 minutes**.
let year = 2024;
let leaderboard = Leaderboard::get(year, leaderboard_id, aoc_token).await?;
// Do something useful.
println!("Leaderboard for year {year} has {} members.", leaderboard.members.len());
Ok(())
}
The above example is available here. For complete API usage, see the docs.
aoc_leaderboard currently builds on Rust 1.70 or newer.