HetznerError

Enum HetznerError 

Source
pub enum HetznerError {
Show 14 variants Http(Error), Api { code: String, message: String, }, NotFound { resource_type: String, identifier: String, }, AlreadyExists { resource_type: String, name: String, }, InvalidParameter { parameter: String, reason: String, }, Validation(String), Timeout { operation: String, timeout_secs: u64, }, Serialization(Error), Unauthorized, Forbidden { details: String, }, RateLimited { retry_after: Option<u64>, }, ServerError { status_code: u16, details: String, }, InvalidToken(String), BuilderError(String),
}
Expand description

Comprehensive error type for Hetzner Cloud API operations.

This error type provides detailed context about what went wrong, including HTTP status codes, API error details, and contextual information.

§Examples

use lmrc_hetzner::{HetznerClient, HetznerError};

let client = HetznerClient::builder()
    .api_token("your-token".to_string())
    .build()?;

match client.get::<serde_json::Value>("/servers").await {
    Ok(servers) => println!("Got servers: {:?}", servers),
    Err(HetznerError::Unauthorized) => {
        eprintln!("Invalid API token");
    }
    Err(HetznerError::RateLimited { retry_after }) => {
        eprintln!("Rate limited, retry after: {:?}", retry_after);
    }
    Err(e) => eprintln!("Other error: {}", e),
}

Variants§

§

Http(Error)

HTTP request failed due to network or connection issues.

This typically indicates network problems, DNS failures, or connection timeouts.

§

Api

Hetzner API returned an error response.

Contains the error code and message from the API.

Fields

§code: String

Error code from Hetzner API (e.g., “invalid_input”, “rate_limit_exceeded”)

§message: String

Human-readable error message

§

NotFound

The requested resource was not found (HTTP 404).

This could mean the resource doesn’t exist or was already deleted.

Fields

§resource_type: String

Type of resource (e.g., “server”, “network”, “firewall”)

§identifier: String

The identifier used to lookup the resource

§

AlreadyExists

Resource already exists with the same name (HTTP 409).

Fields

§resource_type: String

Type of resource that already exists

§name: String

Name of the existing resource

§

InvalidParameter

Invalid input parameter or configuration.

§Examples

use lmrc_hetzner::HetznerError;

let err = HetznerError::InvalidParameter {
    parameter: "ip_range".to_string(),
    reason: "Must be a valid CIDR notation (e.g., 10.0.0.0/16)".to_string(),
};

Fields

§parameter: String

Name of the invalid parameter

§reason: String

Explanation of why it’s invalid

§

Validation(String)

Validation failed for input data.

§

Timeout

Operation timed out waiting for completion.

Fields

§operation: String

Description of the operation that timed out

§timeout_secs: u64

Timeout duration in seconds

§

Serialization(Error)

JSON serialization or deserialization failed.

§

Unauthorized

Authentication failed (HTTP 401).

Usually indicates an invalid or expired API token.

§

Forbidden

Permission denied (HTTP 403).

The API token is valid but lacks permission for this operation.

Fields

§details: String

Details about what permission is lacking

§

RateLimited

Rate limit exceeded (HTTP 429).

The API has rate limits. Wait before retrying.

Fields

§retry_after: Option<u64>

Suggested time to wait before retrying

§

ServerError

Server error from Hetzner API (HTTP 5xx).

Fields

§status_code: u16

HTTP status code

§details: String

Error details if available

§

InvalidToken(String)

Invalid API token format.

§

BuilderError(String)

Builder configuration error.

Trait Implementations§

Source§

impl Debug for HetznerError

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Display for HetznerError

Source§

fn fmt(&self, __formatter: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Error for HetznerError

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<Error> for HetznerError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.
Source§

impl From<Error> for HetznerError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T> ToStringFallible for T
where T: Display,

Source§

fn try_to_string(&self) -> Result<String, TryReserveError>

ToString::to_string, but without panic on OOM.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more