Add error enum
This commit is contained in:
parent
057b952d11
commit
42d2f29bfc
3 changed files with 37 additions and 0 deletions
21
Cargo.lock
generated
21
Cargo.lock
generated
|
@ -179,6 +179,7 @@ dependencies = [
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"serde_repr",
|
"serde_repr",
|
||||||
"strum_macros",
|
"strum_macros",
|
||||||
|
"thiserror",
|
||||||
"time",
|
"time",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -840,6 +841,26 @@ dependencies = [
|
||||||
"windows-sys 0.52.0",
|
"windows-sys 0.52.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "thiserror"
|
||||||
|
version = "1.0.56"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "d54378c645627613241d077a3a79db965db602882668f9136ac42af9ecb730ad"
|
||||||
|
dependencies = [
|
||||||
|
"thiserror-impl",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "thiserror-impl"
|
||||||
|
version = "1.0.56"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "fa0faa943b50f3db30a20aa7e265dbc66076993efed8463e8de414e5d06d3471"
|
||||||
|
dependencies = [
|
||||||
|
"proc-macro2",
|
||||||
|
"quote",
|
||||||
|
"syn",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "time"
|
name = "time"
|
||||||
version = "0.3.32"
|
version = "0.3.32"
|
||||||
|
|
|
@ -12,3 +12,4 @@ strum_macros = { version = "0.26.1"}
|
||||||
time = { version = "0.3.32", features = ["serde", "serde-well-known"]}
|
time = { version = "0.3.32", features = ["serde", "serde-well-known"]}
|
||||||
serde_json = "1.0.113"
|
serde_json = "1.0.113"
|
||||||
serde_repr = "0.1.18"
|
serde_repr = "0.1.18"
|
||||||
|
thiserror = "1.0.56"
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
use serde::{de::DeserializeOwned, Deserialize, Serialize};
|
use serde::{de::DeserializeOwned, Deserialize, Serialize};
|
||||||
use serde_repr::{Deserialize_repr, Serialize_repr};
|
use serde_repr::{Deserialize_repr, Serialize_repr};
|
||||||
use std::net::IpAddr;
|
use std::net::IpAddr;
|
||||||
|
use thiserror::Error;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct ValueError(String);
|
pub struct ValueError(String);
|
||||||
|
@ -13,6 +14,20 @@ impl std::fmt::Display for ValueError {
|
||||||
|
|
||||||
impl std::error::Error for ValueError {}
|
impl std::error::Error for ValueError {}
|
||||||
|
|
||||||
|
#[derive(Debug, Error)]
|
||||||
|
pub enum Error {
|
||||||
|
#[error("unsupported API version {0}")]
|
||||||
|
UnsupportedApiVersion(u64),
|
||||||
|
#[error("invalid endpoint {0:?}")]
|
||||||
|
InvalidEndpoint(String),
|
||||||
|
#[error("request failed")]
|
||||||
|
Request(#[from] reqwest::Error),
|
||||||
|
#[error("decoding response body failed")]
|
||||||
|
Decode(#[from] serde_json::Error),
|
||||||
|
#[error("received error response {:?}: {}", .0.code, .0.reason)]
|
||||||
|
Response(Status),
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Debug, Serialize, Deserialize)]
|
#[derive(Debug, Serialize, Deserialize)]
|
||||||
#[serde(rename_all = "PascalCase")]
|
#[serde(rename_all = "PascalCase")]
|
||||||
pub struct FroniousResponse<T> {
|
pub struct FroniousResponse<T> {
|
||||||
|
|
Loading…
Reference in a new issue