mirror of
https://github.com/teloxide/teloxide.git
synced 2024-12-22 22:46:39 +01:00
add method SendLocation
This commit is contained in:
parent
7809356546
commit
70e29b4edf
2 changed files with 103 additions and 0 deletions
|
@ -94,3 +94,4 @@ pub mod forward_message;
|
||||||
pub mod send_photo;
|
pub mod send_photo;
|
||||||
pub mod send_media_group;
|
pub mod send_media_group;
|
||||||
pub mod send_audio;
|
pub mod send_audio;
|
||||||
|
pub mod send_location;
|
||||||
|
|
102
src/core/requests/send_location.rs
Normal file
102
src/core/requests/send_location.rs
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
use crate::core::{
|
||||||
|
requests::{RequestContext, ChatId, Request, RequestFuture, ResponseResult},
|
||||||
|
types::Message,
|
||||||
|
network,
|
||||||
|
};
|
||||||
|
|
||||||
|
use serde::Serialize;
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, Serialize)]
|
||||||
|
/// Use this method to send point on the map. On success, the sent [`Message`]
|
||||||
|
/// is returned.
|
||||||
|
pub struct SendLocation<'a> {
|
||||||
|
#[serde(skip_serializing)]
|
||||||
|
ctx: RequestContext<'a>,
|
||||||
|
|
||||||
|
/// Unique identifier for the target chat or username of the target channel
|
||||||
|
/// (in the format @channelusername)
|
||||||
|
chat_id: ChatId,
|
||||||
|
/// Latitude of the location
|
||||||
|
latitude: f64,
|
||||||
|
/// Longitude of the location
|
||||||
|
longitude: f64,
|
||||||
|
#[serde(skip_serializing_if="Option::is_none")]
|
||||||
|
/// Period in seconds for which the location will be updated
|
||||||
|
/// (see [Live Locations](https://telegram.org/blog/live-locations)),
|
||||||
|
/// should be between 60 and 86400.
|
||||||
|
live_period: Option<i32>,
|
||||||
|
#[serde(skip_serializing_if="Option::is_none")]
|
||||||
|
/// Sends the message silently. Users will receive a notification with
|
||||||
|
/// no sound.
|
||||||
|
disable_notification: Option<bool>,
|
||||||
|
#[serde(skip_serializing_if="Option::is_none")]
|
||||||
|
/// If the message is a reply, ID of the original message
|
||||||
|
reply_to_message_id: Option<i64>,
|
||||||
|
#[serde(skip_serializing_if="Option::is_none")]
|
||||||
|
reply_markup: Option<()>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> Request<'a> for SendLocation<'a> {
|
||||||
|
type ReturnValue = Message;
|
||||||
|
|
||||||
|
fn send(self) -> RequestFuture<'a, ResponseResult<Self::ReturnValue>> {
|
||||||
|
Box::pin(async move {
|
||||||
|
network::request_json(
|
||||||
|
&self.ctx.client,
|
||||||
|
&self.ctx.token,
|
||||||
|
"sendLocation",
|
||||||
|
&self
|
||||||
|
).await
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> SendLocation<'a> {
|
||||||
|
pub(crate) fn new(
|
||||||
|
ctx: RequestContext<'a>,
|
||||||
|
chat_id: ChatId,
|
||||||
|
latitude: f64,
|
||||||
|
longitude: f64,
|
||||||
|
) -> Self {
|
||||||
|
Self {
|
||||||
|
ctx,
|
||||||
|
chat_id,
|
||||||
|
latitude,
|
||||||
|
longitude,
|
||||||
|
live_period: None,
|
||||||
|
disable_notification: None,
|
||||||
|
reply_to_message_id: None,
|
||||||
|
reply_markup: None
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn chat_id<T: Into<ChatId>>(mut self, chat_id: T) -> Self {
|
||||||
|
self.chat_id = chat_id.into();
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn latitude<T: Into<f64>>(mut self, latitude: T) -> Self {
|
||||||
|
self.latitude = latitude.into();
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn longitude<T: Into<f64>>(mut self, longitude: T) -> Self {
|
||||||
|
self.longitude = longitude.into();
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn live_period<T: Into<i32>>(mut self, live_period: T) -> Self {
|
||||||
|
self.live_period = Some(live_period.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn disable_notification<T: Into<bool>>(mut self, val: T) -> Self {
|
||||||
|
self.disable_notification = Some(val.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn reply_to_message_id<T: Into<i64>>(mut self, val: T) -> Self {
|
||||||
|
self.reply_to_message_id = Some(val.into());
|
||||||
|
self
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue