Riven/riven/src/models_impls.rs

34 lines
1.4 KiB
Rust
Raw Normal View History

use crate::consts::Champion;
2023-05-10 11:20:15 -07:00
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())
}
}