mirror of
https://github.com/MingweiSamuel/Riven.git
synced 2025-01-27 11:17:27 -08:00
69 lines
2.2 KiB
Rust
69 lines
2.2 KiB
Rust
use std::fmt;
|
|
|
|
use reqwest::{Error, Response, StatusCode};
|
|
|
|
/// Result containing RiotApiError on failure.
|
|
pub type Result<T> = std::result::Result<T, RiotApiError>;
|
|
|
|
/// An error that occurred while processing a Riot API request.
|
|
///
|
|
/// Although Riven may make multiple requests due to retries, this will always
|
|
/// contain exactly one reqwest::Error for the final request which failed.
|
|
#[derive(Debug)]
|
|
pub struct RiotApiError {
|
|
reqwest_error: Error,
|
|
retries: u8,
|
|
response: Option<Response>,
|
|
status_code: Option<StatusCode>,
|
|
}
|
|
impl RiotApiError {
|
|
pub(crate) fn new(
|
|
reqwest_error: Error,
|
|
retries: u8,
|
|
response: Option<Response>,
|
|
status_code: Option<StatusCode>,
|
|
) -> Self {
|
|
Self {
|
|
reqwest_error,
|
|
retries,
|
|
response,
|
|
status_code,
|
|
}
|
|
}
|
|
/// The reqwest::Error for the final failed request.
|
|
pub fn source_reqwest_error(&self) -> &Error {
|
|
&self.reqwest_error
|
|
}
|
|
/// The number of retires attempted. Zero means exactly one request, zero retries.
|
|
pub fn retries(&self) -> u8 {
|
|
self.retries
|
|
}
|
|
/// The failed response.
|
|
/// `Some(&reqwest::Response)` if the request was sent and failed.
|
|
/// `None` if the request was not sent, OR if parsing the response JSON failed.
|
|
pub fn response(&self) -> Option<&Response> {
|
|
self.response.as_ref()
|
|
}
|
|
/// The failed response.
|
|
/// `Some(reqwest::Response)` if the request was sent and failed.
|
|
/// `None` if the request was not sent, OR if parsing the response JSON failed.
|
|
pub fn take_response(&mut self) -> Option<Response> {
|
|
self.response.take()
|
|
}
|
|
/// The failed response's HTTP status code.
|
|
/// `Some(reqwest::StatusCode)` if the request was sent and failed, OR if parsing the response JSON failed.
|
|
/// `None` if the request was not sent.
|
|
pub fn status_code(&self) -> Option<StatusCode> {
|
|
self.status_code
|
|
}
|
|
}
|
|
impl fmt::Display for RiotApiError {
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
write!(f, "{:#?}", self)
|
|
}
|
|
}
|
|
impl std::error::Error for RiotApiError {
|
|
fn source(&self) -> Option<&(dyn std::error::Error + 'static)> {
|
|
Some(&self.reqwest_error)
|
|
}
|
|
}
|