mirror of
https://github.com/teloxide/teloxide.git
synced 2025-01-11 04:21:12 +01:00
commit
9189eb1aaa
3 changed files with 501 additions and 8 deletions
481
src/errors.rs
481
src/errors.rs
|
@ -3,6 +3,7 @@ use reqwest::StatusCode;
|
||||||
use thiserror::Error;
|
use thiserror::Error;
|
||||||
|
|
||||||
//<editor-fold desc="download">
|
//<editor-fold desc="download">
|
||||||
|
/// An error occurred after downloading a file.
|
||||||
#[derive(Debug, Error, From)]
|
#[derive(Debug, Error, From)]
|
||||||
pub enum DownloadError {
|
pub enum DownloadError {
|
||||||
#[error("A network error: {0}")]
|
#[error("A network error: {0}")]
|
||||||
|
@ -15,12 +16,13 @@ pub enum DownloadError {
|
||||||
//</editor-fold>
|
//</editor-fold>
|
||||||
|
|
||||||
//<editor-fold desc="request">
|
//<editor-fold desc="request">
|
||||||
|
/// An error occurred after making a request to Telegram.
|
||||||
#[derive(Debug, Error)]
|
#[derive(Debug, Error)]
|
||||||
pub enum RequestError {
|
pub enum RequestError {
|
||||||
#[error("A Telegram's error #{status_code}: {description}")]
|
#[error("A Telegram's error #{status_code}: {kind:?}")]
|
||||||
ApiError {
|
ApiError {
|
||||||
status_code: StatusCode,
|
status_code: StatusCode,
|
||||||
description: String,
|
kind: ApiErrorKind,
|
||||||
},
|
},
|
||||||
|
|
||||||
/// The group has been migrated to a supergroup with the specified
|
/// The group has been migrated to a supergroup with the specified
|
||||||
|
@ -29,7 +31,7 @@ pub enum RequestError {
|
||||||
MigrateToChatId(i64),
|
MigrateToChatId(i64),
|
||||||
|
|
||||||
/// In case of exceeding flood control, the number of seconds left to wait
|
/// In case of exceeding flood control, the number of seconds left to wait
|
||||||
/// before the request can be repeated
|
/// before the request can be repeated.
|
||||||
#[error("Retry after {0} seconds")]
|
#[error("Retry after {0} seconds")]
|
||||||
RetryAfter(i32),
|
RetryAfter(i32),
|
||||||
|
|
||||||
|
@ -41,3 +43,476 @@ pub enum RequestError {
|
||||||
}
|
}
|
||||||
|
|
||||||
//</editor-fold>
|
//</editor-fold>
|
||||||
|
|
||||||
|
/// A kind of an API error returned from Telegram.
|
||||||
|
#[derive(Debug, Deserialize, PartialEq, Copy, Hash, Eq, Clone)]
|
||||||
|
pub enum ApiErrorKind {
|
||||||
|
/// Occurs when the bot tries to send message to user who blocked the bot.
|
||||||
|
#[serde(rename = "Forbidden: bot was blocked by the user")]
|
||||||
|
BotBlocked,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to modify a message without modification content.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`EditMessageText`]
|
||||||
|
///
|
||||||
|
/// [`EditMessageText`]: crate::requests::payloads::EditMessageText
|
||||||
|
#[serde(rename = "Bad Request: message is not modified: specified new \
|
||||||
|
message content and reply markup are exactly the same \
|
||||||
|
as a current content and reply markup of the message")]
|
||||||
|
MessageNotModified,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to forward or delete a message which was deleted.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`ForwardMessage`]
|
||||||
|
/// 2. [`DeleteMessage`]
|
||||||
|
///
|
||||||
|
/// [`ForwardMessage`]: crate::requests::payloads::ForwardMessage
|
||||||
|
/// [`DeleteMessage`]: crate::requests::payloads::DeleteMessage
|
||||||
|
#[serde(rename = "Bad Request: MESSAGE_ID_INVALID")]
|
||||||
|
MessageIdInvalid,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to forward a message which does not exists.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`ForwardMessage`]
|
||||||
|
///
|
||||||
|
/// [`ForwardMessage`]: crate::requests::payloads::ForwardMessage
|
||||||
|
#[serde(rename = "Bad Request: message to forward not found")]
|
||||||
|
MessageToForwardNotFound,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to delete a message which does not exists.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`DeleteMessage`]
|
||||||
|
///
|
||||||
|
/// [`DeleteMessage`]: crate::requests::payloads::DeleteMessage
|
||||||
|
#[serde(rename = "Bad Request: message to delete not found")]
|
||||||
|
MessageToDeleteNotFound,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send a text message without text.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: message text is empty")]
|
||||||
|
MessageTextIsEmpty,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to edit a message after long time.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`EditMessageText`]
|
||||||
|
///
|
||||||
|
/// [`EditMessageText`]: crate::requests::payloads::EditMessageText
|
||||||
|
#[serde(rename = "Bad Request: message can't be edited")]
|
||||||
|
MessageCantBeEdited,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to delete a someone else's message in group where
|
||||||
|
/// it does not have enough rights.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`DeleteMessage`]
|
||||||
|
///
|
||||||
|
/// [`DeleteMessage`]: crate::requests::payloads::DeleteMessage
|
||||||
|
#[serde(rename = "Bad Request: message can't be deleted")]
|
||||||
|
MessageCantBeDeleted,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to edit a message which does not exists.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`EditMessageText`]
|
||||||
|
///
|
||||||
|
/// [`EditMessageText`]: crate::requests::payloads::EditMessageText
|
||||||
|
#[serde(rename = "Bad Request: message to edit not found")]
|
||||||
|
MessageToEditNotFound,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to reply to a message which does not exists.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: reply message not found")]
|
||||||
|
MessageToReplyNotFound,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to
|
||||||
|
#[serde(rename = "Bad Request: message identifier is not specified")]
|
||||||
|
MessageIdentifierNotSpecified,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send a message with text size greater then
|
||||||
|
/// 4096 symbols.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: message is too long")]
|
||||||
|
MessageIsTooLong,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send media group with more than 10 items.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMediaGroup`]
|
||||||
|
///
|
||||||
|
/// [`SendMediaGroup`]: crate::requests::payloads::SendMediaGroup
|
||||||
|
#[serde(rename = "Bad Request: Too much messages to send as an album")]
|
||||||
|
ToMuchMessages,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to stop poll that has already been stopped.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendPoll`]
|
||||||
|
///
|
||||||
|
/// [`SendPoll`]: crate::requests::payloads::SendPoll
|
||||||
|
#[serde(rename = "Bad Request: poll has already been closed")]
|
||||||
|
PollHasAlreadyClosed,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send poll with less than 2 options.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendPoll`]
|
||||||
|
///
|
||||||
|
/// [`SendPoll`]: crate::requests::payloads::SendPoll
|
||||||
|
#[serde(rename = "Bad Request: poll must have at least 2 option")]
|
||||||
|
PollMustHaveMoreOptions,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send poll with more than 10 options.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendPoll`]
|
||||||
|
///
|
||||||
|
/// [`SendPoll`]: crate::requests::payloads::SendPoll
|
||||||
|
#[serde(rename = "Bad Request: poll can't have more than 10 options")]
|
||||||
|
PollCantHaveMoreOptions,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send poll with empty option (without text).
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendPoll`]
|
||||||
|
///
|
||||||
|
/// [`SendPoll`]: crate::requests::payloads::SendPoll
|
||||||
|
#[serde(rename = "Bad Request: poll options must be non-empty")]
|
||||||
|
PollOptionsMustBeNonEmpty,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send poll with empty question (without text).
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendPoll`]
|
||||||
|
///
|
||||||
|
/// [`SendPoll`]: crate::requests::payloads::SendPoll
|
||||||
|
#[serde(rename = "Bad Request: poll question must be non-empty")]
|
||||||
|
PollQuestionMustBeNonEmpty,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send poll with total size of options more than
|
||||||
|
/// 100 symbols.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendPoll`]
|
||||||
|
///
|
||||||
|
/// [`SendPoll`]: crate::requests::payloads::SendPoll
|
||||||
|
#[serde(rename = "Bad Request: poll options length must not exceed 100")]
|
||||||
|
PollOptionsLengthTooLong,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send poll with question size more than 255
|
||||||
|
/// symbols.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendPoll`]
|
||||||
|
///
|
||||||
|
/// [`SendPoll`]: crate::requests::payloads::SendPoll
|
||||||
|
#[serde(rename = "Bad Request: poll question length must not exceed 255")]
|
||||||
|
PollQuestionLengthTooLong,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to stop poll with message without poll.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`StopPoll`]
|
||||||
|
///
|
||||||
|
/// [`StopPoll`]: crate::requests::payloads::StopPoll
|
||||||
|
#[serde(rename = "Bad Request: message with poll to stop not found")]
|
||||||
|
MessageWithPollNotFound,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to stop poll with message without poll.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`StopPoll`]
|
||||||
|
///
|
||||||
|
/// [`StopPoll`]: crate::requests::payloads::StopPoll
|
||||||
|
#[serde(rename = "Bad Request: message is not a poll")]
|
||||||
|
MessageIsNotAPoll,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send a message to chat in which it is not a
|
||||||
|
/// member.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: chat not found")]
|
||||||
|
ChatNotFound,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send method with unknown user_id.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`getUserProfilePhotos`]
|
||||||
|
///
|
||||||
|
/// [`getUserProfilePhotos`]:
|
||||||
|
/// crate::requests::payloads::getUserProfilePhotos
|
||||||
|
#[serde(rename = "Bad Request: user not found")]
|
||||||
|
UserNotFound,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send [`SetChatDescription`] with same text as
|
||||||
|
/// in the current description.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SetChatDescription`]
|
||||||
|
///
|
||||||
|
/// [`SetChatDescription`]: crate::requests::payloads::SetChatDescription
|
||||||
|
#[serde(rename = "Bad Request: chat description is not modified")]
|
||||||
|
ChatDescriptionIsNotModified,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to answer to query after timeout expire.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`AnswerCallbackQuery`]
|
||||||
|
///
|
||||||
|
/// [`AnswerCallbackQuery`]: crate::requests::payloads::AnswerCallbackQuery
|
||||||
|
#[serde(rename = "Bad Request: query is too old and response timeout \
|
||||||
|
expired or query id is invalid")]
|
||||||
|
InvalidQueryID,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send InlineKeyboardMarkup with invalid button
|
||||||
|
/// url.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: BUTTON_URL_INVALID")]
|
||||||
|
ButtonURLInvalid,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send button with data size more than 64 bytes.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: BUTTON_DATA_INVALID")]
|
||||||
|
ButtonDataInvalid,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send button with data size == 0.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: can't parse inline keyboard button: Text \
|
||||||
|
buttons are unallowed in the inline keyboard")]
|
||||||
|
TextButtonsAreUnallowed,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to get file by wrong file id.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`GetFile`]
|
||||||
|
///
|
||||||
|
/// [`GetFile`]: crate::requests::payloads::GetFile
|
||||||
|
#[serde(rename = "Bad Request: wrong file id")]
|
||||||
|
WrongFileID,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to do some with group which was deactivated.
|
||||||
|
#[serde(rename = "Bad Request: group is deactivated")]
|
||||||
|
GroupDeactivated,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to set chat photo from file ID
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SetChatPhoto`]
|
||||||
|
///
|
||||||
|
/// [`SetChatPhoto`]: crate::requests::payloads::SetChatPhoto
|
||||||
|
#[serde(rename = "Bad Request: Photo should be uploaded as an InputFile")]
|
||||||
|
PhotoAsInputFileRequired,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to add sticker to stickerset by invalid name.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`AddStickerToSet`]
|
||||||
|
///
|
||||||
|
/// [`AddStickerToSet`]: crate::requests::payloads::AddStickerToSet
|
||||||
|
#[serde(rename = "Bad Request: STICKERSET_INVALID")]
|
||||||
|
InvalidStickersSet,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to pin a message without rights to pin in this
|
||||||
|
/// chat.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`PinMessage`]
|
||||||
|
///
|
||||||
|
/// [`PinMessage`]: crate::requests::payloads::PinMessage
|
||||||
|
#[serde(rename = "Bad Request: not enough rights to pin a message")]
|
||||||
|
NotEnoughRightsToPinMessage,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to use method in group which is allowed only in a
|
||||||
|
/// supergroup or channel.
|
||||||
|
#[serde(rename = "Bad Request: method is available only for supergroups \
|
||||||
|
and channel")]
|
||||||
|
MethodNotAvailableInPrivateChats,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to demote chat creator.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`PromoteChatMember`]
|
||||||
|
///
|
||||||
|
/// [`PromoteChatMember`]: crate::requests::payloads::PromoteChatMember
|
||||||
|
#[serde(rename = "Bad Request: can't demote chat creator")]
|
||||||
|
CantDemoteChatCreator,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to restrict self in group chats.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`RestrictChatMember`]
|
||||||
|
///
|
||||||
|
/// [`RestrictChatMember`]: crate::requests::payloads::RestrictChatMember
|
||||||
|
#[serde(rename = "Bad Request: can't restrict self")]
|
||||||
|
CantRestrictSelf,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to restrict chat member without rights to
|
||||||
|
/// restrict in this chat.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`RestrictChatMember`]
|
||||||
|
///
|
||||||
|
/// [`RestrictChatMember`]: crate::requests::payloads::RestrictChatMember
|
||||||
|
#[serde(rename = "Bad Request: not enough rights to restrict/unrestrict \
|
||||||
|
chat member")]
|
||||||
|
NotEnoughRightsToRestrict,
|
||||||
|
|
||||||
|
/// Occurs when bot tries set webhook to protocol other than HTTPS.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SetWebhook`]
|
||||||
|
///
|
||||||
|
/// [`SetWebhook`]: crate::requests::payloads::SetWebhook
|
||||||
|
#[serde(rename = "Bad Request: bad webhook: HTTPS url must be provided \
|
||||||
|
for webhook")]
|
||||||
|
WebhookRequireHTTPS,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to set webhook to port other than 80, 88, 443 or
|
||||||
|
/// 8443.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SetWebhook`]
|
||||||
|
///
|
||||||
|
/// [`SetWebhook`]: crate::requests::payloads::SetWebhook
|
||||||
|
#[serde(rename = "Bad Request: bad webhook: Webhook can be set up only \
|
||||||
|
on ports 80, 88, 443 or 8443")]
|
||||||
|
BadWebhookPort,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to set webhook to unknown host.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SetWebhook`]
|
||||||
|
///
|
||||||
|
/// [`SetWebhook`]: crate::requests::payloads::SetWebhook
|
||||||
|
#[serde(rename = "Bad Request: bad webhook: Failed to resolve host: \
|
||||||
|
Name or service not known")]
|
||||||
|
UnknownHost,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to set webhook to invalid URL.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SetWebhook`]
|
||||||
|
///
|
||||||
|
/// [`SetWebhook`]: crate::requests::payloads::SetWebhook
|
||||||
|
#[serde(rename = "Bad Request: can't parse URL")]
|
||||||
|
CantParseUrl,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send message with unfinished entities.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: can't parse entities")]
|
||||||
|
CantParseEntities,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to use getUpdates while webhook is active.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`GetUpdates`]
|
||||||
|
///
|
||||||
|
/// [`GetUpdates`]: crate::requests::payloads::GetUpdates
|
||||||
|
#[serde(rename = "can't use getUpdates method while webhook is active")]
|
||||||
|
CantGetUpdates,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to do some in group where bot was kicked.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Unauthorized: bot was kicked from a chat")]
|
||||||
|
BotKicked,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send message to deactivated user.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Unauthorized: user is deactivated")]
|
||||||
|
UserDeactivated,
|
||||||
|
|
||||||
|
/// Occurs when you tries to initiate conversation with a user.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(
|
||||||
|
rename = "Unauthorized: bot can't initiate conversation with a user"
|
||||||
|
)]
|
||||||
|
CantInitiateConversation,
|
||||||
|
|
||||||
|
/// Occurs when you tries to send message to bot.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Unauthorized: bot can't send messages to bots")]
|
||||||
|
CantTalkWithBots,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to send button with invalid http url.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`SendMessage`]
|
||||||
|
///
|
||||||
|
/// [`SendMessage`]: crate::requests::payloads::SendMessage
|
||||||
|
#[serde(rename = "Bad Request: wrong HTTP URL")]
|
||||||
|
WrongHTTPurl,
|
||||||
|
|
||||||
|
/// Occurs when bot tries GetUpdate before the timeout. Make sure that only
|
||||||
|
/// one Updater is running.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`GetUpdates`]
|
||||||
|
///
|
||||||
|
/// [`GetUpdates`]: crate::requests::payloads::GetUpdates
|
||||||
|
#[serde(rename = "Conflict: terminated by other getUpdates request; \
|
||||||
|
make sure that only one bot instance is running")]
|
||||||
|
TerminatedByOtherGetUpdates,
|
||||||
|
|
||||||
|
/// Occurs when bot tries to get file by invalid file id.
|
||||||
|
///
|
||||||
|
/// May happen in methods:
|
||||||
|
/// 1. [`GetFile`]
|
||||||
|
///
|
||||||
|
/// [`GetFile`]: crate::requests::payloads::GetFile
|
||||||
|
#[serde(rename = "Bad Request: invalid file id")]
|
||||||
|
FileIdInvalid,
|
||||||
|
|
||||||
|
#[serde(other)]
|
||||||
|
Other,
|
||||||
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
#![allow(clippy::match_bool)]
|
#![allow(clippy::match_bool)]
|
||||||
|
|
||||||
pub use bot::Bot;
|
pub use bot::Bot;
|
||||||
pub use errors::{DownloadError, RequestError};
|
pub use errors::{ApiErrorKind, DownloadError, RequestError};
|
||||||
|
|
||||||
mod errors;
|
mod errors;
|
||||||
mod network;
|
mod network;
|
||||||
|
|
|
@ -4,7 +4,7 @@ use serde::Deserialize;
|
||||||
use crate::{
|
use crate::{
|
||||||
requests::ResponseResult,
|
requests::ResponseResult,
|
||||||
types::{False, ResponseParameters, True},
|
types::{False, ResponseParameters, True},
|
||||||
RequestError,
|
ApiErrorKind, RequestError,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
|
@ -22,7 +22,8 @@ pub enum TelegramResponse<R> {
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
ok: False,
|
ok: False,
|
||||||
|
|
||||||
description: String,
|
#[serde(rename = "description")]
|
||||||
|
kind: ApiErrorKind,
|
||||||
error_code: u16,
|
error_code: u16,
|
||||||
response_parameters: Option<ResponseParameters>,
|
response_parameters: Option<ResponseParameters>,
|
||||||
},
|
},
|
||||||
|
@ -33,7 +34,7 @@ impl<R> Into<ResponseResult<R>> for TelegramResponse<R> {
|
||||||
match self {
|
match self {
|
||||||
TelegramResponse::Ok { result, .. } => Ok(result),
|
TelegramResponse::Ok { result, .. } => Ok(result),
|
||||||
TelegramResponse::Err {
|
TelegramResponse::Err {
|
||||||
description,
|
kind,
|
||||||
error_code,
|
error_code,
|
||||||
response_parameters,
|
response_parameters,
|
||||||
..
|
..
|
||||||
|
@ -49,7 +50,7 @@ impl<R> Into<ResponseResult<R>> for TelegramResponse<R> {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Err(RequestError::ApiError {
|
Err(RequestError::ApiError {
|
||||||
description,
|
kind,
|
||||||
status_code: StatusCode::from_u16(error_code).unwrap(),
|
status_code: StatusCode::from_u16(error_code).unwrap(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -57,3 +58,20 @@ impl<R> Into<ResponseResult<R>> for TelegramResponse<R> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
use crate::types::Update;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn terminated_by_other_get_updates() {
|
||||||
|
let expected = ApiErrorKind::TerminatedByOtherGetUpdates;
|
||||||
|
if let TelegramResponse::Err{ kind, .. } = serde_json::from_str::<TelegramResponse<Update>>(r#"{"ok":false,"error_code":409,"description":"Conflict: terminated by other getUpdates request; make sure that only one bot instance is running"}"#).unwrap() {
|
||||||
|
assert_eq!(expected, kind);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
panic!("Этой херни здесь не должно быть");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue