From 040b8b1b42dd620c52eead277beb9421570a0a75 Mon Sep 17 00:00:00 2001 From: EdJoPaTo Date: Thu, 15 Aug 2024 19:19:22 +0200 Subject: [PATCH] refactor: simplify From --- src/api/telegram_api_impl.rs | 37 +++++++++++++----------------------- 1 file changed, 13 insertions(+), 24 deletions(-) diff --git a/src/api/telegram_api_impl.rs b/src/api/telegram_api_impl.rs index d5c76c7..7a0b7fe 100644 --- a/src/api/telegram_api_impl.rs +++ b/src/api/telegram_api_impl.rs @@ -1,6 +1,5 @@ use super::Error; use super::HttpError; -use crate::api_traits::ErrorResponse; use crate::api_traits::TelegramApi; use multipart::client::lazy::Multipart; use serde_json::Value; @@ -61,29 +60,19 @@ impl From for Error { fn from(error: ureq::Error) -> Self { match error { ureq::Error::Status(code, response) => match response.into_string() { - Ok(message) => { - let json_result: Result = - serde_json::from_str(&message); - - match json_result { - Ok(result) => Self::Api(result), - Err(_) => { - let error = HttpError { code, message }; - Self::Http(error) - } - } - } - Err(_) => { - let message = "Failed to decode response".to_string(); - let error = HttpError { code, message }; - Self::Http(error) - } + Ok(message) => match serde_json::from_str(&message) { + Ok(json_result) => Self::Api(json_result), + Err(_) => Self::Http(HttpError { code, message }), + }, + Err(_) => Self::Http(HttpError { + code, + message: "Failed to decode response".to_string(), + }), }, - ureq::Error::Transport(transport_error) => { - let message = format!("{transport_error:?}"); - let error = HttpError { message, code: 500 }; - Self::Http(error) - } + ureq::Error::Transport(transport_error) => Self::Http(HttpError { + message: format!("{transport_error:?}"), + code: 500, + }), } } } @@ -106,7 +95,6 @@ impl TelegramApi for Api { None => prepared_request.call()?, Some(data) => { let json = Self::encode_params(&data)?; - prepared_request.send_string(&json)? } }; @@ -245,6 +233,7 @@ mod tests { use crate::api_params::StopPollParams; use crate::api_params::UnbanChatMemberParams; use crate::api_params::UnpinChatMessageParams; + use crate::api_traits::ErrorResponse; use crate::objects::BotCommand; use crate::objects::ChatPermissions; use crate::objects::InlineQueryResultVenue;