Crates.io | bw-web-api-rs |
lib.rs | bw-web-api-rs |
version | 0.2.7 |
created_at | 2024-06-26 03:53:07.372796+00 |
updated_at | 2025-09-18 00:33:34.293536+00 |
description | A Rust client for the StarCraft: Remastered API |
homepage | |
repository | |
max_upload_size | |
id | 1284148 |
size | 54,396 |
A Rust client library for interacting with the StarCraft: Remastered API.
[dependencies]
bw-web-api-rs = "0.2"
Or via cargo:
cargo add bw-web-api-rs
This library uses async/await and requires an async runtime such as tokio.
use bw_web_api_rs::{
ApiClient, ApiConfig,
types::{Gateway, Leaderboard},
};
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let config = ApiConfig {
base_url: "http://127.0.0.1:37843".to_string(),
api_key: None
};
let client = ApiClient::new(config)?;
// Get player match info
let match_info = client
.get_matchmaker_player_info("MM-EBECDFA6-B0F4-11EF-8534-FA167A7650A3".to_string())
.await?;
// Get player profile (scr_profile field mask)
let profile = client
.get_aurora_profile_by_toon_scr_profile("By.SnOw1".to_string(), Gateway::Korea)
.await?;
// Fetch leaderboard metadata such as available seasons
let leaderboard_metadata = client.get_leaderboard().await?;
Ok(())
}
get_aurora_profile_by_toon_scr_profile(toon, gateway)
(and other field-mask variants) - Get player profile informationget_global_maps_1v1()
- Get available 1v1 mapsget_gateway_status()
- Get status of all gatewaysget_leaderboard()
- Get leaderboard metadata including available gamemodes, gateways, and leaderboardsget_leaderboard_entity(leaderboard_id)
- Get leaderboard entries for a specific leaderboardget_leaderboard_rank(leaderboard_id, toon, gateway)
- Get specific player's rankingsearch_leaderboard_by_battletag(leaderboard_id, battletag)
- Search a leaderboard for players matching a Battletagget_map_stats(toon, gateway)
- Get player's map statisticsget_matchmaker_gameinfo(toon, gateway, gamemode, season, offset, limit)
- Get player's match historyget_matchmaker_player_info(match_id)
- Get detailed match informationScrProfile
- Basic profile informationScrMmGameLoading
- Matchmaking game loading informationScrMmToonInfo
- Detailed matchmaking informationScrToonInfo
- Basic character informationTo find the port StarCraft: Remastered is using on Windows (requires administrator privileges):
(Get-NetTCPConnection -OwningProcess (Get-Process -Name StarCraft | Select-Object -ExpandProperty Id) | Where-Object {$_.State -eq "Listen"} | Sort-Object -Property LocalPort | Select-Object -First 1).LocalPort
The library provides a comprehensive error type ApiError
that covers:
This project is licensed under the MIT License - see the LICENSE file for details.