mirror of
https://github.com/MingweiSamuel/Riven.git
synced 2025-01-13 20:37:27 -08:00
33 lines
1.4 KiB
Rust
33 lines
1.4 KiB
Rust
use crate::consts::Champion;
|
|
use crate::models::match_v5::Participant;
|
|
|
|
impl Participant {
|
|
/// This method takes the [`Self::champion_id`] field if it is valid
|
|
/// (`Ok`), otherwise it attempts to parse [`Self::champion_name`] and
|
|
/// returns the `Result`.
|
|
///
|
|
/// This is needed because some of Riot's [`Self::champion_id`] data is
|
|
/// corrupted, as they describe in the docs:
|
|
///
|
|
/// > Prior to patch 11.4, on Feb 18th, 2021, this field returned invalid
|
|
/// > championIds. We recommend determining the champion based on the
|
|
/// > championName field for matches played prior to patch 11.4.
|
|
///
|
|
/// This issue is reported here: <https://github.com/RiotGames/developer-relations/issues/553>.
|
|
pub fn champion(&self) -> Result<Champion, <Champion as std::str::FromStr>::Err> {
|
|
#[allow(deprecated)]
|
|
self.champion_id.or_else(|_| self.champion_name.parse())
|
|
}
|
|
|
|
/// This method returns the name portion of the riot ID for this summoner.
|
|
///
|
|
/// Prior to patch 14.5, this was in the [`Self::riot_id_name`] field.
|
|
/// After, this moved to the `Self.riot_id_game_name` field.
|
|
///
|
|
/// This method simply returns whichever of the two fields is not `None`.
|
|
pub fn riot_id_game_name(&self) -> Option<&str> {
|
|
self.riot_id_game_name
|
|
.as_deref()
|
|
.or(self.riot_id_name.as_deref())
|
|
}
|
|
}
|