RpcError

Struct RpcError 

Source
pub struct RpcError {
    pub code: i32,
    pub name: String,
    pub value: Option<u32>,
    pub caused_by: Option<u32>,
}
Expand description

The error type reported by the server when a request is misused.

These are returned when Telegram respond to an RPC with tl::types::RpcError.

Fields§

§code: i32

A numerical value similar to HTTP response status codes.

§name: String

The ASCII error name, normally in screaming snake case.

Digit words are removed from the name and put in the RpcError::value instead.

use grammers_mtsender::RpcError;
let rpc_error = RpcError::from(grammers_tl_types::types::RpcError {
        error_code: 500, error_message: "INTERDC_2_CALL_ERROR".into() });
assert_eq!(rpc_error.name, "INTERDC_CALL_ERROR");
assert_eq!(rpc_error.value, Some(2));
§value: Option<u32>

If the error contained an additional integer value, it will be present here and removed from the RpcError::name.

use grammers_mtsender::RpcError;
let rpc_error = RpcError::from(grammers_tl_types::types::RpcError {
        error_code: 420, error_message: "FLOOD_WAIT_31".into() });
assert_eq!(rpc_error.name, "FLOOD_WAIT");
assert_eq!(rpc_error.value, Some(31));
§caused_by: Option<u32>

The constructor identifier of the request that triggered this error. Won’t be present if the error was artificially constructed.

Implementations§

Source§

impl RpcError

Source

pub fn is(&self, rpc_error: &str) -> bool

Matches on the name of the RPC error (case-sensitive).

Useful in match arm guards. A single trailing or leading asterisk ('*') is allowed, and will instead check if the error name starts (or ends with) the input parameter.

§Examples
match request_result {
    Err(rpc_err) if rpc_err.is("SESSION_PASSWORD_NEEDED") => panic!(),
    Err(rpc_err) if rpc_err.is("PHONE_CODE_*") => {},
    _ => panic!()
}
Source

pub fn with_caused_by(self, constructor_id: u32) -> Self

Attaches the tl::Identifiable::CONSTRUCTOR_ID of the request that caused this error to the error information.

Trait Implementations§

Source§

impl Clone for RpcError

Source§

fn clone(&self) -> RpcError

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for RpcError

Source§

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

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

impl Display for RpcError

Source§

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

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

impl Error for RpcError

1.30.0 · 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<RpcError> for RpcError

Source§

fn from(error: RpcError) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for RpcError

Source§

fn eq(&self, other: &RpcError) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for RpcError

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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, 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.