mirror of
https://github.com/teloxide/teloxide.git
synced 2024-12-22 14:35:36 +01:00
add method
This commit is contained in:
parent
2cb6ba9e33
commit
1ffd2697f1
2 changed files with 131 additions and 0 deletions
|
@ -88,3 +88,5 @@ mod tests {
|
||||||
pub mod get_me;
|
pub mod get_me;
|
||||||
pub mod send_message;
|
pub mod send_message;
|
||||||
pub mod forward_message;
|
pub mod forward_message;
|
||||||
|
pub mod send_photo;
|
||||||
|
mod utils;
|
||||||
|
|
129
src/core/requests/send_photo.rs
Normal file
129
src/core/requests/send_photo.rs
Normal file
|
@ -0,0 +1,129 @@
|
||||||
|
use std::path::Path;
|
||||||
|
|
||||||
|
use crate::core::requests::{RequestContext, ChatId, Request, RequestFuture, ResponseResult};
|
||||||
|
use crate::core::types::{ParseMode, Message};
|
||||||
|
use crate::core::requests::form_builder::FormBuilder;
|
||||||
|
use crate::core::network;
|
||||||
|
|
||||||
|
#[derive(Debug, Clone)]
|
||||||
|
pub struct SendPhoto<'a> {
|
||||||
|
ctx: RequestContext<'a>,
|
||||||
|
|
||||||
|
pub chat_id: ChatId,
|
||||||
|
// TODO: add enum Photo
|
||||||
|
pub photo: String,
|
||||||
|
pub caption: Option<String>,
|
||||||
|
pub parse_mode: Option<ParseMode>,
|
||||||
|
pub disable_notification: Option<bool>,
|
||||||
|
pub reply_to_message_id: Option<i64>,
|
||||||
|
|
||||||
|
// TODO: add reply_markup
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> Request<'a> for SendPhoto<'a> {
|
||||||
|
type ReturnValue = Message;
|
||||||
|
|
||||||
|
fn send(self) -> RequestFuture<'a, ResponseResult<Self::ReturnValue>> {
|
||||||
|
Box::pin(async move {
|
||||||
|
let params = FormBuilder::new()
|
||||||
|
.add("chat_id", &self.chat_id)
|
||||||
|
.add_file("photo", &self.photo)
|
||||||
|
.add_if_some("caption", self.caption.as_ref())
|
||||||
|
.add_if_some("parse_mode", self.parse_mode.as_ref())
|
||||||
|
.add_if_some(
|
||||||
|
"disable_notification",
|
||||||
|
self.disable_notification.as_ref()
|
||||||
|
)
|
||||||
|
.add_if_some(
|
||||||
|
"reply_to_message_id",
|
||||||
|
self.reply_to_message_id.as_ref()
|
||||||
|
)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
network::request(
|
||||||
|
&self.ctx.client,
|
||||||
|
&self.ctx.token,
|
||||||
|
"sendPhoto",
|
||||||
|
Some(params)
|
||||||
|
).await
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> SendPhoto<'a> {
|
||||||
|
pub(crate) fn new(
|
||||||
|
ctx: RequestContext<'a>,
|
||||||
|
chat_id: ChatId,
|
||||||
|
photo: String
|
||||||
|
) -> Self {
|
||||||
|
Self {
|
||||||
|
ctx,
|
||||||
|
chat_id,
|
||||||
|
photo,
|
||||||
|
caption: None,
|
||||||
|
parse_mode: None,
|
||||||
|
disable_notification: None,
|
||||||
|
reply_to_message_id: None
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn chat_id<T: Into<ChatId>>(mut self, chat_id: T) -> Self {
|
||||||
|
self.chat_id = chat_id.into();
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn photo<T: Into<String>>(mut self, photo: T) -> Self {
|
||||||
|
self.photo = photo.into();
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn caption<T: Into<String>>(mut self, caption: T) -> Self {
|
||||||
|
self.caption = Some(caption.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn parse_mode<T: Into<ParseMode>>(mut self, parse_mode: T) -> Self {
|
||||||
|
self.parse_mode = Some(parse_mode.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn disable_notification<T: Into<bool>>(mut self, disable_notification: T) -> Self {
|
||||||
|
self.disable_notification = Some(disable_notification.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn reply_to_message_id<T: Into<i64>>(mut self, reply_to_message_id: T) -> Self {
|
||||||
|
self.reply_to_message_id = Some(reply_to_message_id.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
use reqwest::r#async::Client;
|
||||||
|
|
||||||
|
const TOKEN: &str = "882997251:AAGImZKe4cO6vDzluWzCgYqebziIMroN7uU";
|
||||||
|
const USER_ID: i64 = 268486177;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn send_photo() {
|
||||||
|
use futures::FutureExt;
|
||||||
|
use futures::TryFutureExt;
|
||||||
|
tokio::run(async_send_photo().boxed().unit_error().compat())
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn async_send_photo() {
|
||||||
|
let client = Client::new();
|
||||||
|
let req = SendPhoto::new(
|
||||||
|
RequestContext {
|
||||||
|
client: &client,
|
||||||
|
token: TOKEN,
|
||||||
|
},
|
||||||
|
ChatId::Id(USER_ID),
|
||||||
|
"D:\\Снимок.png".to_string(),
|
||||||
|
);
|
||||||
|
|
||||||
|
println!("{:?}", req.send().await);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue