Enum mwbot::Error

source ·
#[non_exhaustive]
pub enum Error {
Show 37 variants HttpError(Error), InvalidHeaderValue(InvalidHeaderValue), InvalidJson(Error), LockFailure(AcquireError), InvalidTitle(Error), IoError(Error), TooManyRequests { retry_after: Option<u64>, }, InvalidEtag, BadToken, TokenFailure(String), InvalidHeadingLevel(u32), NotLoggedIn, NotLoggedInAsBot, PermissionDenied(String), Blocked { info: String, details: BlockDetails, }, PartiallyBlocked { info: String, details: BlockDetails, }, GloballyBlocked(String), GloballyRangeBlocked(String), GloballyXFFBlocked(String), UnknownBlock(String), LoginThrottled, WrongPassword, InvalidPage, Nobots, PageDoesNotExist(String), ProtectedPage, EditConflict, ContentTooBig(String), SpamFilter { info: String, matches: Vec<String>, }, UndoFailure(String), UnknownSaveFailure(Value), UploadWarning(Vec<UploadWarning>), Maxlag { info: String, retry_after: Option<u64>, }, Readonly { info: String, retry_after: Option<u64>, }, InternalException(ApiError), ApiError(ApiError), Unknown(String),
}
Expand description

Primary error class

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

HttpError(Error)

A HTTP error like a 4XX or 5XX status code

§

InvalidHeaderValue(InvalidHeaderValue)

Invalid header value, likely if the provided OAuth2 token or User-agent are invalid

§

InvalidJson(Error)

Error when decoding the JSON response from the API

§

LockFailure(AcquireError)

Error if unable to get request concurrency lock

§

InvalidTitle(Error)

§

IoError(Error)

§

TooManyRequests

A HTTP error with 429 status code

Fields

§retry_after: Option<u64>
§

InvalidEtag

etag header is invalid/missing

§

BadToken

Token invalid or expired

§

TokenFailure(String)

Unable to fetch a CSRF token

§

InvalidHeadingLevel(u32)

§

NotLoggedIn

When expected to be logged in but aren’t

§

NotLoggedInAsBot

When expected to be logged in but aren’t

§

PermissionDenied(String)

§

Blocked

Fields

§info: String
§details: BlockDetails
§

PartiallyBlocked

Fields

§info: String
§details: BlockDetails
§

GloballyBlocked(String)

§

GloballyRangeBlocked(String)

§

GloballyXFFBlocked(String)

§

UnknownBlock(String)

When we can’t group it into a more specific block

§

LoginThrottled

§

WrongPassword

§

InvalidPage

§

Nobots

When {{nobots}} matches

§

PageDoesNotExist(String)

Page does not exist

§

ProtectedPage

Page is protected

§

EditConflict

Edit conflict

§

ContentTooBig(String)

§

SpamFilter

Tripped the spam filter (aka SpamBlacklist)

Fields

§info: String
§matches: Vec<String>
§

UndoFailure(String)

If the edit could not be undone

§

UnknownSaveFailure(Value)

Some save failure happened, but we don’t know what it is

§

UploadWarning(Vec<UploadWarning>)

§

Maxlag

Fields

§info: String
§retry_after: Option<u64>
§

Readonly

When MediaWiki is in readonly mode

Fields

§info: String
§retry_after: Option<u64>
§

InternalException(ApiError)

An internal MediaWiki exception

§

ApiError(ApiError)

Any arbitrary error returned by the MediaWiki API

§

Unknown(String)

An error where we don’t know what to do nor have information to report back

Implementations§

source§

impl Error

Whether the issue is related to a specific page rather than a global issue

source

pub fn is_sitewide_block(&self) -> bool

Whether the issue is related to a sitewide block

source

pub fn retry_after(&self) -> Option<u64>

If the error merits a retry, how long should we wait?

Trait Implementations§

source§

impl Debug for Error

source§

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

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

impl Display for Error

source§

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

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

impl Error for Error

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<AcquireError> for Error

source§

fn from(source: AcquireError) -> Self

Converts to this type from the input type.
source§

impl From<ApiError> for Error

source§

fn from(apierr: ApiError) -> Self

Converts to this type from the input type.
source§

impl From<Error> for ConfigError

source§

fn from(source: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(source: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(source: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(source: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<InvalidHeaderValue> for Error

source§

fn from(source: InvalidHeaderValue) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

§

impl Freeze for Error

§

impl !RefUnwindSafe for Error

§

impl Send for Error

§

impl Sync for Error

§

impl Unpin for Error

§

impl !UnwindSafe for Error

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.

§

impl<T> Instrument for T

§

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

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

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> ToString for T
where T: Display + ?Sized,

source§

default 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.
§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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