4 releases
0.1.3 | May 25, 2024 |
---|---|
0.1.2 | Feb 10, 2024 |
0.1.1 | Feb 6, 2024 |
0.1.0 | Feb 6, 2024 |
#1 in #fortnite
45KB
877 lines
Fortnite API
This crate is a wrapper for the Fortnite API.
Usage
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_news_v2(&http_client, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Endpoints
Endpoint | Function | Result Type |
---|---|---|
AES V2 | get_aes_keys_v2 |
AesV2 |
Banners V1 | get_banners_v1 |
BannersV1 |
Banners Colors V1 | get_banners_colors_v1 |
BannersColorsV1 |
Cosmetics V2 | get_cosmetics_v2 |
CosmeticsV2 |
Cosmetics New V2 | get_cosmetics_new_v2 |
CosmeticsNewV2 |
Cosmetic By ID V2 | get_cosmetic_by_id_v2 |
CosmeticV2 |
Creator Code V2 | get_creatorcode_v2 |
CreatorCodeV2 |
Map V1 | get_map_v1 |
MapV1 |
News V2 | get_news_v2 |
NewsV2 |
News Gamemode V2 | get_news_br_v2 get_news_stw_v2 get_news_creative_v2 |
News |
Playlists V1 | get_playlists_v1 |
PlaylistsV1 |
Playlists By ID V1 | get_playlist_by_id_v1 |
PlaylistV1 |
Shop BR V2 | get_shop_br_v2 get_shop_combined_v2 |
ShopV2 |
Stats V2 | get_stats_v2 get_stats_by_account_id_v2 |
StatsV2 |
Get the current AES keys.
Parameters
http_client
: The reqwest client.key_format
: The format of the AES keys. Can beNone
,Some(AesKeyFormat::Hex)
, orSome(AesKeyFormat::Base64)
.
Returns
The current AES keys.
Example
use fortnite_api::response_types::aes::AesKeyFormat;
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_aes_keys_v2(&http_client, Some(AesKeyFormat::Hex)).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the banners.
Parameters
http_client
: The reqwest client.language
: The language of the banners. Can beNone
or a language code.
Returns
The banners.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_banners_v1(&http_client, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the banner colors.
Parameters
http_client
: The reqwest client.
Returns
The banner colors.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_banners_colors_v1(&http_client).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the cosmetics.
Parameters
http_client
: The reqwest client.language
: The language of the cosmetics. Can beNone
or a language code.
Returns
The cosmetics.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_cosmetics_v2(&http_client, None).await;
assert!(result.is_ok());
}
Get the new cosmetics.
Parameters
http_client
: The reqwest client.language
: The language of the cosmetics. Can beNone
or a language code.
Returns
The new cosmetics.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_cosmetics_new_v2(&http_client, None).await;
assert!(result.is_ok());
}
Get the cosmetic by ID.
Parameters
http_client
: The reqwest client.cosmetic_id
: The ID of the cosmetic.language
: The language of the cosmetic. Can beNone
or a language code.
Returns
The cosmetic by ID.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_cosmetics_new_v2(&http_client, None).await;
assert!(result.is_ok());
let cosmetic_id = result.unwrap().items.first().unwrap().id.clone();
let result = fortnite_api::get_cosmetic_by_id_v2(&http_client, &cosmetic_id, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the creator code.
Parameters
http_client
: The reqwest client.name
: The name of the creator code.
Returns
The creator code.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_creatorcode_v2(&http_client, "trymacs").await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the map.
Parameters
http_client
: The reqwest client.language
: The language of the map. Can beNone
or a language code.
Returns
The map.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_map_v1(&http_client, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the news.
Parameters
http_client
: The reqwest client.language
: The language of the news. Can beNone
or a language code.
Returns
The news.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_news_v2(&http_client, None).await;
println!("Result: {:#?}", result);
}
Get the battle royale news.
Parameters
http_client
: The reqwest client.language
: The language of the news. Can beNone
or a language code.
Returns
The battle royale news.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_news_br_v2(&http_client, None).await;
println!("Result: {:#?}", result);
}
Get the save the world news.
Parameters
http_client
: The reqwest client.language
: The language of the news. Can beNone
or a language code.
Returns
The save the world news.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_news_stw_v2(&http_client, None).await;
println!("Result: {:#?}", result);
}
Get the creative news.
Parameters
http_client
: The reqwest client.language
: The language of the news. Can beNone
or a language code.
Returns
The creative news.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_news_creative_v2(&http_client, None).await;
println!("Result: {:#?}", result);
}
Get the playlists.
Parameters
http_client
: The reqwest client.language
: The language of the playlists. Can beNone
or a language code.
Returns
The playlists.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_playlists_v1(&http_client, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the playlist by ID.
Parameters
http_client
: The reqwest client.language
: The language of the playlists. Can beNone
or a language code.
Returns
The playlist by ID.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_playlists_v1(&http_client, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
let playlist_id = result.unwrap().first().unwrap().id.clone();
let result = fortnite_api::get_playlist_by_id_v1(&http_client, &playlist_id, None).await;
println!("Result: {:#?}", result);
}
Get the battle royale shop.
Parameters
http_client
: The reqwest client.language
: The language of the shop. Can beNone
or a language code.
Returns
The battle royale shop.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_shop_br_v2(&http_client, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the combined shop.
Parameters
http_client
: The reqwest client.language
: The language of the shop. Can beNone
or a language code.
Returns
The combined shop.
Example
#[tokio::main]
async fn main() {
let http_client = reqwest::Client::new();
let result = fortnite_api::get_shop_combined_v2(&http_client, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the player stats.
Parameters
http_client
: The reqwest client.api_key
: Your Fortnite API key.name
: The name of the player.account_type
: The account type of the player. Can beNone
orStatsAccountType
.time_window
: The time window of the stats. Can beNone
orStatsTimeWindow
.image
: The image of the stats. Can beNone
orStatsImage
.language
: The language of the shop. Can beNone
or a language code.
Returns
The player stats.
Example
use fortnite_api::response_types::stats::{StatsAccountType, StatsImage, StatsTimeWindow};
#[tokio::main]
async fn main() {
dotenv::dotenv().ok();
let http_client = reqwest::Client::new();
let api_key = std::env::var("FORTNITE_API_KEY")
.expect("Please set the FORTNITE_API_KEY environment variable");
let result =
fortnite_api::get_stats_v2(&http_client, api_key.clone(), "Test", None, None, None).await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Get the player stats by account ID.
Parameters
http_client
: The reqwest client.api_key
: Your Fortnite API key.account_id
: The account ID of the player.time_window
: The time window of the stats. Can beNone
orStatsTimeWindow
.image
: The image of the stats. Can beNone
orStatsImage
.
Returns
The player stats.
Example
use fortnite_api::response_types::stats::{StatsAccountType, StatsImage, StatsTimeWindow};
#[tokio::main]
async fn main() {
dotenv::dotenv().ok();
let http_client = reqwest::Client::new();
let api_key = std::env::var("FORTNITE_API_KEY")
.expect("Please set the FORTNITE_API_KEY environment variable");
let result = fortnite_api::get_stats_by_account_id_v2(
&http_client,
api_key.clone(),
"3f20d6f579db4e7ba71d80fc18576db2",
None,
None,
)
.await;
println!("Result: {:#?}", result);
assert!(result.is_ok());
}
Dependencies
~5–17MB
~217K SLoC