2020-09-19 18:00:23 +02:00
|
|
|
macro_rules! req_future {
|
|
|
|
(
|
|
|
|
$v2:vis def: | $( $arg:ident: $ArgTy:ty ),* $(,)? | $body:block
|
|
|
|
|
|
|
|
$(#[$($meta:tt)*])*
|
|
|
|
$v:vis $i:ident<$T:ident> ($inner:ident) -> $Out:ty
|
|
|
|
$(where $($wh:tt)*)?
|
|
|
|
) => {
|
|
|
|
#[pin_project::pin_project]
|
2021-01-21 07:45:20 +01:00
|
|
|
pub
|
|
|
|
// FIXME(waffle):
|
|
|
|
// The `pub` above should ideally be `$v`, but we currently can't do
|
|
|
|
// this due to compiler bug, see:
|
|
|
|
// - pin_project bug report <https://github.com/taiki-e/pin-project/issues/312>
|
|
|
|
// - related rustc issue <https://github.com/rust-lang/rust/issues/81007>
|
|
|
|
// - original fix (closed) <https://github.com/rust-lang/rust/pull/81029>
|
|
|
|
// - second iteration of the fix <https://github.com/rust-lang/rust/pull/81177>
|
|
|
|
struct $i<$T>
|
2020-09-19 18:00:23 +02:00
|
|
|
$(where $($wh)*)?
|
|
|
|
{
|
|
|
|
#[pin]
|
|
|
|
inner: $inner::$i<$T>
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<$T> $i<$T>
|
|
|
|
$(where $($wh)*)?
|
|
|
|
{
|
|
|
|
$v2 fn new($( $arg: $ArgTy ),*) -> Self {
|
|
|
|
Self { inner: $inner::def($( $arg ),*) }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// HACK(waffle): workaround for https://github.com/rust-lang/rust/issues/55997
|
|
|
|
mod $inner {
|
|
|
|
#![allow(type_alias_bounds)]
|
|
|
|
|
|
|
|
// Mostly to bring `use`s
|
|
|
|
#[allow(unused_imports)]
|
|
|
|
use super::{*, $i as _};
|
|
|
|
|
|
|
|
#[cfg(feature = "nightly")]
|
|
|
|
pub(crate) type $i<$T>
|
|
|
|
$(where $($wh)*)? = impl ::core::future::Future<Output = $Out>;
|
|
|
|
|
|
|
|
#[cfg(feature = "nightly")]
|
|
|
|
pub(crate) fn def<$T>($( $arg: $ArgTy ),*) -> $i<$T>
|
|
|
|
$(where $($wh)*)?
|
|
|
|
{
|
|
|
|
$body
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(not(feature = "nightly"))]
|
|
|
|
pub(crate) type $i<$T>
|
2020-10-20 11:17:07 +02:00
|
|
|
$(where $($wh)*)? = ::core::pin::Pin<Box<dyn ::core::future::Future<Output = $Out> + ::core::marker::Send + 'static>>;
|
2020-09-19 18:00:23 +02:00
|
|
|
|
|
|
|
#[cfg(not(feature = "nightly"))]
|
|
|
|
pub(crate) fn def<$T>($( $arg: $ArgTy ),*) -> $i<$T>
|
|
|
|
$(where $($wh)*)?
|
|
|
|
{
|
|
|
|
Box::pin($body)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<$T> ::core::future::Future for $i<$T>
|
|
|
|
$(where $($wh)*)?
|
|
|
|
{
|
|
|
|
type Output = $Out;
|
|
|
|
|
|
|
|
fn poll(self: ::core::pin::Pin<&mut Self>, cx: &mut ::core::task::Context<'_>) -> ::core::task::Poll<Self::Output> {
|
|
|
|
let this = self.project();
|
|
|
|
this.inner.poll(cx)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
}
|
2020-10-20 14:07:10 +02:00
|
|
|
|
2020-10-23 20:32:57 +02:00
|
|
|
/// Declares an item with a doc attribute computed by some macro expression.
|
|
|
|
/// This allows documentation to be dynamically generated based on input.
|
|
|
|
/// Necessary to work around https://github.com/rust-lang/rust/issues/52607.
|
|
|
|
macro_rules! calculated_doc {
|
|
|
|
(
|
|
|
|
$(
|
|
|
|
#[doc = $doc:expr]
|
|
|
|
$thing:item
|
|
|
|
)*
|
|
|
|
) => (
|
|
|
|
$(
|
|
|
|
#[doc = $doc]
|
|
|
|
$thing
|
|
|
|
)*
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-02-16 14:55:27 +01:00
|
|
|
/// Declare payload type, implement `Payload` trait and ::new method for it,
|
2020-10-23 20:32:57 +02:00
|
|
|
/// declare setters trait and implement it for all type which have payload.
|
|
|
|
macro_rules! impl_payload {
|
|
|
|
(
|
2021-02-16 14:55:27 +01:00
|
|
|
$(
|
2022-01-12 09:31:55 +01:00
|
|
|
@[multipart = $($multipart_attr:ident),*]
|
2021-02-16 14:55:27 +01:00
|
|
|
)?
|
2022-02-14 17:48:32 +01:00
|
|
|
$(
|
|
|
|
@[timeout_secs = $timeout_secs:ident]
|
|
|
|
)?
|
2020-10-23 20:32:57 +02:00
|
|
|
$(
|
|
|
|
#[ $($method_meta:tt)* ]
|
|
|
|
)*
|
|
|
|
$vi:vis $Method:ident ($Setters:ident) => $Ret:ty {
|
|
|
|
$(
|
|
|
|
required {
|
|
|
|
$(
|
|
|
|
$(
|
|
|
|
#[ $($field_meta:tt)* ]
|
|
|
|
)*
|
2020-11-01 23:35:02 +01:00
|
|
|
$v:vis $fields:ident : $FTy:ty $([$conv:ident])?
|
2020-10-23 20:32:57 +02:00
|
|
|
,
|
|
|
|
)*
|
|
|
|
}
|
|
|
|
)?
|
|
|
|
|
|
|
|
$(
|
|
|
|
optional {
|
|
|
|
$(
|
|
|
|
$(
|
|
|
|
#[ $($opt_field_meta:tt)* ]
|
|
|
|
)*
|
2020-11-01 23:35:02 +01:00
|
|
|
$opt_v:vis $opt_fields:ident : $OptFTy:ty $([$opt_conv:ident])?
|
2020-10-23 20:32:57 +02:00
|
|
|
),*
|
|
|
|
$(,)?
|
|
|
|
}
|
|
|
|
)?
|
|
|
|
}
|
|
|
|
) => {
|
2020-11-02 00:21:02 +01:00
|
|
|
#[serde_with_macros::skip_serializing_none]
|
2020-11-02 19:14:32 +01:00
|
|
|
#[must_use = "Requests do nothing unless sent"]
|
2020-10-23 20:32:57 +02:00
|
|
|
$(
|
|
|
|
#[ $($method_meta)* ]
|
|
|
|
)*
|
|
|
|
$vi struct $Method {
|
|
|
|
$(
|
|
|
|
$(
|
|
|
|
$(
|
|
|
|
#[ $($field_meta)* ]
|
|
|
|
)*
|
|
|
|
$v $fields : $FTy,
|
|
|
|
)*
|
|
|
|
)?
|
|
|
|
$(
|
|
|
|
$(
|
|
|
|
$(
|
|
|
|
#[ $($opt_field_meta)* ]
|
|
|
|
)*
|
|
|
|
$opt_v $opt_fields : core::option::Option<$OptFTy>,
|
|
|
|
)*
|
|
|
|
)?
|
|
|
|
}
|
|
|
|
|
|
|
|
impl $Method {
|
2020-11-15 08:51:36 +01:00
|
|
|
// We mirror Telegram API and can't do anything with too many arguments.
|
2020-11-13 18:47:47 +01:00
|
|
|
#[allow(clippy::too_many_arguments)]
|
2020-11-15 08:51:36 +01:00
|
|
|
// It's just easier for macros to generate such code.
|
2020-11-13 18:47:47 +01:00
|
|
|
#[allow(clippy::redundant_field_names)]
|
2021-01-15 19:51:15 +01:00
|
|
|
// It's obvious what this method does. (If you think it's not, feel free to open a PR)
|
|
|
|
#[allow(missing_docs)]
|
2020-11-01 23:35:02 +01:00
|
|
|
$vi fn new($($($fields : impl_payload!(@convert? $FTy $([$conv])?)),*)?) -> Self {
|
2020-10-23 20:32:57 +02:00
|
|
|
Self {
|
|
|
|
$(
|
|
|
|
$(
|
2020-11-01 23:35:02 +01:00
|
|
|
$fields: impl_payload!(@convert_map ($fields) $([$conv])?),
|
2020-10-23 20:32:57 +02:00
|
|
|
)*
|
|
|
|
)?
|
|
|
|
$(
|
|
|
|
$(
|
|
|
|
$opt_fields: None,
|
|
|
|
)*
|
|
|
|
)?
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl $crate::requests::Payload for $Method {
|
|
|
|
type Output = $Ret;
|
|
|
|
|
|
|
|
const NAME: &'static str = stringify!($Method);
|
2022-02-14 17:48:32 +01:00
|
|
|
|
|
|
|
$(
|
|
|
|
fn timeout_hint(&self) -> Option<std::time::Duration> {
|
|
|
|
self.$timeout_secs.map(<_>::into).map(std::time::Duration::from_secs)
|
|
|
|
}
|
|
|
|
)?
|
2020-10-23 20:32:57 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
calculated_doc! {
|
|
|
|
#[doc = concat!(
|
|
|
|
"Setters for fields of [`",
|
|
|
|
stringify!($Method),
|
|
|
|
"`]"
|
|
|
|
)]
|
|
|
|
$vi trait $Setters: $crate::requests::HasPayload<Payload = $Method> + ::core::marker::Sized {
|
|
|
|
$(
|
|
|
|
$(
|
2020-11-01 23:35:02 +01:00
|
|
|
impl_payload! { @setter $Method $fields : $FTy $([$conv])? }
|
2020-10-23 20:32:57 +02:00
|
|
|
)*
|
|
|
|
)?
|
|
|
|
$(
|
|
|
|
$(
|
2020-11-01 23:35:02 +01:00
|
|
|
impl_payload! { @setter_opt $Method $opt_fields : $OptFTy $([$opt_conv])? }
|
2020-10-23 20:32:57 +02:00
|
|
|
)*
|
|
|
|
)?
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<P> $Setters for P where P: crate::requests::HasPayload<Payload = $Method> {}
|
2021-02-16 14:55:27 +01:00
|
|
|
|
2022-01-12 09:31:55 +01:00
|
|
|
impl_payload! { @[$(multipart = $($multipart_attr),*)?] $Method req { $($($fields),*)? } opt { $($($opt_fields),*)? } }
|
2020-10-23 20:32:57 +02:00
|
|
|
};
|
|
|
|
(@setter_opt $Method:ident $field:ident : $FTy:ty [into]) => {
|
|
|
|
calculated_doc! {
|
|
|
|
#[doc = concat!(
|
|
|
|
"Setter for [`",
|
|
|
|
stringify!($field),
|
|
|
|
"`](",
|
|
|
|
stringify!($Method),
|
|
|
|
"::",
|
|
|
|
stringify!($field),
|
|
|
|
") field."
|
|
|
|
)]
|
2020-12-23 17:46:31 +01:00
|
|
|
#[allow(clippy::wrong_self_convention)]
|
2021-10-15 18:03:50 +02:00
|
|
|
#[must_use = "Payloads and requests do nothing unless sent"]
|
2020-10-23 20:32:57 +02:00
|
|
|
fn $field<T>(mut self, value: T) -> Self
|
|
|
|
where
|
|
|
|
T: Into<$FTy>,
|
|
|
|
{
|
|
|
|
self.payload_mut().$field = Some(value.into());
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2020-11-01 23:35:02 +01:00
|
|
|
(@setter_opt $Method:ident $field:ident : $FTy:ty [collect]) => {
|
|
|
|
calculated_doc! {
|
|
|
|
#[doc = concat!(
|
|
|
|
"Setter for [`",
|
|
|
|
stringify!($field),
|
|
|
|
"`](",
|
|
|
|
stringify!($Method),
|
|
|
|
"::",
|
|
|
|
stringify!($field),
|
|
|
|
") field."
|
|
|
|
)]
|
2020-12-23 17:46:31 +01:00
|
|
|
#[allow(clippy::wrong_self_convention)]
|
2021-10-15 18:03:50 +02:00
|
|
|
#[must_use = "Payloads and requests do nothing unless sent"]
|
2020-11-01 23:35:02 +01:00
|
|
|
fn $field<T>(mut self, value: T) -> Self
|
|
|
|
where
|
|
|
|
T: ::core::iter::IntoIterator<Item = <$FTy as ::core::iter::IntoIterator>::Item>,
|
|
|
|
{
|
|
|
|
self.payload_mut().$field = Some(value.into_iter().collect());
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2020-10-23 20:32:57 +02:00
|
|
|
(@setter_opt $Method:ident $field:ident : $FTy:ty) => {
|
|
|
|
calculated_doc! {
|
|
|
|
#[doc = concat!(
|
|
|
|
"Setter for [`",
|
|
|
|
stringify!($field),
|
|
|
|
"`](",
|
|
|
|
stringify!($Method),
|
|
|
|
"::",
|
|
|
|
stringify!($field),
|
|
|
|
") field."
|
|
|
|
)]
|
2020-12-23 17:46:31 +01:00
|
|
|
#[allow(clippy::wrong_self_convention)]
|
2021-10-15 18:03:50 +02:00
|
|
|
#[must_use = "Payloads and requests do nothing unless sent"]
|
2020-10-23 20:32:57 +02:00
|
|
|
fn $field(mut self, value: $FTy) -> Self {
|
|
|
|
self.payload_mut().$field = Some(value);
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@setter $Method:ident $field:ident : $FTy:ty [into]) => {
|
|
|
|
calculated_doc! {
|
|
|
|
#[doc = concat!(
|
|
|
|
"Setter for [`",
|
|
|
|
stringify!($field),
|
|
|
|
"`](",
|
|
|
|
stringify!($Method),
|
|
|
|
"::",
|
|
|
|
stringify!($field),
|
|
|
|
") field."
|
|
|
|
)]
|
2020-12-23 17:46:31 +01:00
|
|
|
#[allow(clippy::wrong_self_convention)]
|
2021-10-15 18:03:50 +02:00
|
|
|
#[must_use = "Payloads and requests do nothing unless sent"]
|
2020-10-23 20:32:57 +02:00
|
|
|
fn $field<T>(mut self, value: T) -> Self
|
|
|
|
where
|
|
|
|
T: Into<$FTy>,
|
|
|
|
{
|
|
|
|
self.payload_mut().$field = value.into();
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2020-11-01 23:35:02 +01:00
|
|
|
(@setter $Method:ident $field:ident : $FTy:ty [collect]) => {
|
|
|
|
calculated_doc! {
|
|
|
|
#[doc = concat!(
|
|
|
|
"Setter for [`",
|
|
|
|
stringify!($field),
|
|
|
|
"`](",
|
|
|
|
stringify!($Method),
|
|
|
|
"::",
|
|
|
|
stringify!($field),
|
|
|
|
") field."
|
|
|
|
)]
|
2020-12-23 17:46:31 +01:00
|
|
|
#[allow(clippy::wrong_self_convention)]
|
2021-10-15 18:03:50 +02:00
|
|
|
#[must_use = "Payloads and requests do nothing unless sent"]
|
2020-11-01 23:35:02 +01:00
|
|
|
fn $field<T>(mut self, value: T) -> Self
|
|
|
|
where
|
|
|
|
T: ::core::iter::IntoIterator<Item = <$FTy as ::core::iter::IntoIterator>::Item>,
|
|
|
|
{
|
|
|
|
self.payload_mut().$field = value.into_iter().collect();
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2020-10-23 20:32:57 +02:00
|
|
|
(@setter $Method:ident $field:ident : $FTy:ty) => {
|
|
|
|
calculated_doc! {
|
|
|
|
#[doc = concat!(
|
|
|
|
"Setter for [`",
|
|
|
|
stringify!($field),
|
|
|
|
"`](",
|
|
|
|
stringify!($Method),
|
|
|
|
"::",
|
|
|
|
stringify!($field),
|
|
|
|
") field."
|
|
|
|
)]
|
2020-12-23 17:46:31 +01:00
|
|
|
#[allow(clippy::wrong_self_convention)]
|
2021-10-15 18:03:50 +02:00
|
|
|
#[must_use = "Payloads and requests do nothing unless sent"]
|
2020-10-23 20:32:57 +02:00
|
|
|
fn $field(mut self, value: $FTy) -> Self {
|
|
|
|
self.payload_mut().$field = value;
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2020-11-01 23:35:02 +01:00
|
|
|
(@convert? $T:ty [into]) => {
|
2020-10-23 20:32:57 +02:00
|
|
|
impl ::core::convert::Into<$T>
|
|
|
|
};
|
2020-11-01 23:35:02 +01:00
|
|
|
(@convert? $T:ty [collect]) => {
|
|
|
|
impl ::core::iter::IntoIterator<Item = <$T as ::core::iter::IntoIterator>::Item>
|
|
|
|
};
|
|
|
|
(@convert? $T:ty) => {
|
2020-10-23 20:32:57 +02:00
|
|
|
$T
|
|
|
|
};
|
2020-11-01 23:35:02 +01:00
|
|
|
(@convert_map ($e:expr) [into]) => {
|
|
|
|
$e.into()
|
|
|
|
};
|
|
|
|
(@convert_map ($e:expr) [collect]) => {
|
|
|
|
$e.into_iter().collect()
|
|
|
|
};
|
|
|
|
(@convert_map ($e:expr)) => {
|
|
|
|
$e
|
|
|
|
};
|
2022-01-12 09:31:55 +01:00
|
|
|
(@[multipart = $($multipart_attr:ident),*] $Method:ident req { $($reqf:ident),* } opt { $($optf:ident),*} ) => {
|
2022-01-13 13:11:50 +01:00
|
|
|
impl crate::requests::MultipartPayload for $Method {
|
|
|
|
fn copy_files(&self, into: &mut dyn FnMut(crate::types::InputFile)) {
|
|
|
|
$(
|
|
|
|
crate::types::InputFileLike::copy_into(&self.$multipart_attr, into);
|
|
|
|
)*
|
|
|
|
}
|
|
|
|
|
|
|
|
fn move_files(&mut self, into: &mut dyn FnMut(crate::types::InputFile)) {
|
|
|
|
$(
|
|
|
|
crate::types::InputFileLike::move_into(&mut self.$multipart_attr, into);
|
|
|
|
)*
|
|
|
|
}
|
|
|
|
}
|
2021-02-16 14:55:27 +01:00
|
|
|
};
|
|
|
|
(@[] $($ignored:tt)*) => {}
|
2020-10-23 20:32:57 +02:00
|
|
|
}
|
2020-11-24 17:15:46 +01:00
|
|
|
|
2021-05-04 15:50:49 +02:00
|
|
|
macro_rules! download_forward {
|
|
|
|
($l:lifetime $T:ident $S:ty {$this:ident => $inner:expr}) => {
|
|
|
|
impl<$l, $T: $crate::net::Download<$l>> $crate::net::Download<$l> for $S {
|
|
|
|
type Err = <$T as $crate::net::Download<$l>>::Err;
|
|
|
|
|
|
|
|
type Fut = <$T as $crate::net::Download<$l>>::Fut;
|
|
|
|
|
|
|
|
fn download_file(
|
|
|
|
&self,
|
|
|
|
path: &str,
|
|
|
|
destination: &'w mut (dyn tokio::io::AsyncWrite
|
|
|
|
+ core::marker::Unpin
|
|
|
|
+ core::marker::Send),
|
|
|
|
) -> Self::Fut {
|
|
|
|
let $this = self;
|
|
|
|
($inner).download_file(path, destination)
|
|
|
|
}
|
|
|
|
|
|
|
|
type StreamErr = <$T as $crate::net::Download<$l>>::StreamErr;
|
|
|
|
|
|
|
|
type Stream = <$T as $crate::net::Download<$l>>::Stream;
|
|
|
|
|
|
|
|
fn download_file_stream(&self, path: &str) -> Self::Stream {
|
|
|
|
let $this = self;
|
|
|
|
($inner).download_file_stream(path)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-03-28 12:49:27 +02:00
|
|
|
// This macro is auto generated by [`cg`] from [`schema`].
|
|
|
|
//
|
2020-11-24 17:15:46 +01:00
|
|
|
// **DO NOT EDIT THIS MACRO**,
|
2021-03-28 12:49:27 +02:00
|
|
|
//
|
|
|
|
// Edit `cg` or `schema` instead.
|
|
|
|
//
|
|
|
|
// [cg]: https://github.com/teloxide/cg
|
|
|
|
// [`schema`]: https://github.com/WaffleLapkin/tg-methods-schema
|
2020-11-24 17:15:46 +01:00
|
|
|
macro_rules! requester_forward {
|
|
|
|
($i:ident $(, $rest:ident )* $(,)? => $body:ident, $ty:ident ) => {
|
|
|
|
requester_forward!(@method $i $body $ty);
|
|
|
|
$(
|
|
|
|
requester_forward!(@method $rest $body $ty);
|
|
|
|
)*
|
|
|
|
};
|
2021-07-03 22:35:13 +02:00
|
|
|
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method get_updates $body:ident $ty:ident) => {
|
|
|
|
type GetUpdates = $ty![GetUpdates];
|
|
|
|
|
2020-11-24 18:30:45 +01:00
|
|
|
fn get_updates(&self) -> Self::GetUpdates {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
|
|
|
$body!(get_updates this ())
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_webhook $body:ident $ty:ident) => {
|
|
|
|
type SetWebhook = $ty![SetWebhook];
|
|
|
|
|
2021-07-03 22:35:13 +02:00
|
|
|
fn set_webhook(&self, url: Url) -> Self::SetWebhook {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-07-03 22:35:13 +02:00
|
|
|
$body!(set_webhook this (url: Url))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method delete_webhook $body:ident $ty:ident) => {
|
|
|
|
type DeleteWebhook = $ty![DeleteWebhook];
|
|
|
|
|
2020-11-24 18:30:45 +01:00
|
|
|
fn delete_webhook(&self) -> Self::DeleteWebhook {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
|
|
|
$body!(delete_webhook this ())
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_webhook_info $body:ident $ty:ident) => {
|
|
|
|
type GetWebhookInfo = $ty![GetWebhookInfo];
|
|
|
|
|
2020-11-24 18:30:45 +01:00
|
|
|
fn get_webhook_info(&self) -> Self::GetWebhookInfo {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
|
|
|
$body!(get_webhook_info this ())
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_me $body:ident $ty:ident) => {
|
|
|
|
type GetMe = $ty![GetMe];
|
|
|
|
|
2020-11-24 18:30:45 +01:00
|
|
|
fn get_me(&self) -> Self::GetMe {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
|
|
|
$body!(get_me this ())
|
|
|
|
}
|
|
|
|
};
|
2021-03-14 20:44:33 +01:00
|
|
|
(@method log_out $body:ident $ty:ident) => {
|
|
|
|
type LogOut = $ty![LogOut];
|
|
|
|
|
|
|
|
fn log_out(&self) -> Self::LogOut {
|
|
|
|
let this = self;
|
|
|
|
$body!(log_out this ())
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method close $body:ident $ty:ident) => {
|
|
|
|
type Close = $ty![Close];
|
|
|
|
|
|
|
|
fn close(&self) -> Self::Close {
|
|
|
|
let this = self;
|
|
|
|
$body!(close this ())
|
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method send_message $body:ident $ty:ident) => {
|
|
|
|
type SendMessage = $ty![SendMessage];
|
|
|
|
|
|
|
|
fn send_message<C, T>(&self, chat_id: C, text: T) -> Self::SendMessage where C: Into<ChatId>,
|
|
|
|
T: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(send_message this (chat_id: C, text: T))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method forward_message $body:ident $ty:ident) => {
|
|
|
|
type ForwardMessage = $ty![ForwardMessage];
|
|
|
|
|
|
|
|
fn forward_message<C, F>(&self, chat_id: C, from_chat_id: F, message_id: i32) -> Self::ForwardMessage where C: Into<ChatId>,
|
|
|
|
F: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(forward_message this (chat_id: C, from_chat_id: F, message_id: i32))
|
|
|
|
}
|
|
|
|
};
|
2021-03-14 20:44:33 +01:00
|
|
|
(@method copy_message $body:ident $ty:ident) => {
|
|
|
|
type CopyMessage = $ty![CopyMessage];
|
|
|
|
|
|
|
|
fn copy_message<C, F>(&self, chat_id: C, from_chat_id: F, message_id: i32) -> Self::CopyMessage where C: Into<ChatId>,
|
|
|
|
F: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(copy_message this (chat_id: C, from_chat_id: F, message_id: i32))
|
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method send_photo $body:ident $ty:ident) => {
|
|
|
|
type SendPhoto = $ty![SendPhoto];
|
|
|
|
|
2020-12-28 12:30:18 +01:00
|
|
|
fn send_photo<C>(&self, chat_id: C, photo: InputFile) -> Self::SendPhoto where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2020-12-28 12:30:18 +01:00
|
|
|
$body!(send_photo this (chat_id: C, photo: InputFile))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_audio $body:ident $ty:ident) => {
|
|
|
|
type SendAudio = $ty![SendAudio];
|
|
|
|
|
2020-12-28 12:30:18 +01:00
|
|
|
fn send_audio<C>(&self, chat_id: C, audio: InputFile) -> Self::SendAudio where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2020-12-28 12:30:18 +01:00
|
|
|
$body!(send_audio this (chat_id: C, audio: InputFile))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_document $body:ident $ty:ident) => {
|
|
|
|
type SendDocument = $ty![SendDocument];
|
|
|
|
|
2020-12-28 12:30:18 +01:00
|
|
|
fn send_document<C>(&self, chat_id: C, document: InputFile) -> Self::SendDocument where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2020-12-28 12:30:18 +01:00
|
|
|
$body!(send_document this (chat_id: C, document: InputFile))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_video $body:ident $ty:ident) => {
|
|
|
|
type SendVideo = $ty![SendVideo];
|
|
|
|
|
2020-12-28 12:30:18 +01:00
|
|
|
fn send_video<C>(&self, chat_id: C, video: InputFile) -> Self::SendVideo where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2020-12-28 12:30:18 +01:00
|
|
|
$body!(send_video this (chat_id: C, video: InputFile))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_animation $body:ident $ty:ident) => {
|
|
|
|
type SendAnimation = $ty![SendAnimation];
|
|
|
|
|
2020-12-28 12:30:18 +01:00
|
|
|
fn send_animation<C>(&self, chat_id: C, animation: InputFile) -> Self::SendAnimation where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2020-12-28 12:30:18 +01:00
|
|
|
$body!(send_animation this (chat_id: C, animation: InputFile))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_voice $body:ident $ty:ident) => {
|
|
|
|
type SendVoice = $ty![SendVoice];
|
|
|
|
|
2020-12-28 12:30:18 +01:00
|
|
|
fn send_voice<C>(&self, chat_id: C, voice: InputFile) -> Self::SendVoice where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2020-12-28 12:30:18 +01:00
|
|
|
$body!(send_voice this (chat_id: C, voice: InputFile))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_video_note $body:ident $ty:ident) => {
|
|
|
|
type SendVideoNote = $ty![SendVideoNote];
|
|
|
|
|
|
|
|
fn send_video_note<C>(&self, chat_id: C, video_note: InputFile) -> Self::SendVideoNote where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(send_video_note this (chat_id: C, video_note: InputFile))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_media_group $body:ident $ty:ident) => {
|
|
|
|
type SendMediaGroup = $ty![SendMediaGroup];
|
|
|
|
|
|
|
|
fn send_media_group<C, M>(&self, chat_id: C, media: M) -> Self::SendMediaGroup where C: Into<ChatId>,
|
|
|
|
M: IntoIterator<Item = InputMedia> {
|
|
|
|
let this = self;
|
|
|
|
$body!(send_media_group this (chat_id: C, media: M))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_location $body:ident $ty:ident) => {
|
|
|
|
type SendLocation = $ty![SendLocation];
|
|
|
|
|
2021-02-22 09:30:13 +01:00
|
|
|
fn send_location<C>(&self, chat_id: C, latitude: f64, longitude: f64) -> Self::SendLocation where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-02-22 09:30:13 +01:00
|
|
|
$body!(send_location this (chat_id: C, latitude: f64, longitude: f64))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_live_location $body:ident $ty:ident) => {
|
|
|
|
type EditMessageLiveLocation = $ty![EditMessageLiveLocation];
|
|
|
|
|
|
|
|
fn edit_message_live_location<C>(&self, chat_id: C, message_id: i32, latitude: f64, longitude: f64) -> Self::EditMessageLiveLocation where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_message_live_location this (chat_id: C, message_id: i32, latitude: f64, longitude: f64))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_live_location_inline $body:ident $ty:ident) => {
|
|
|
|
type EditMessageLiveLocationInline = $ty![EditMessageLiveLocationInline];
|
|
|
|
|
|
|
|
fn edit_message_live_location_inline<I>(&self, inline_message_id: I, latitude: f64, longitude: f64) -> Self::EditMessageLiveLocationInline where I: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_message_live_location_inline this (inline_message_id: I, latitude: f64, longitude: f64))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method stop_message_live_location $body:ident $ty:ident) => {
|
|
|
|
type StopMessageLiveLocation = $ty![StopMessageLiveLocation];
|
|
|
|
|
|
|
|
fn stop_message_live_location<C>(&self, chat_id: C, message_id: i32, latitude: f64, longitude: f64) -> Self::StopMessageLiveLocation where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(stop_message_live_location this (chat_id: C, message_id: i32, latitude: f64, longitude: f64))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method stop_message_live_location_inline $body:ident $ty:ident) => {
|
|
|
|
type StopMessageLiveLocationInline = $ty![StopMessageLiveLocationInline];
|
|
|
|
|
|
|
|
fn stop_message_live_location_inline<I>(&self, inline_message_id: I, latitude: f64, longitude: f64) -> Self::StopMessageLiveLocationInline where I: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(stop_message_live_location_inline this (inline_message_id: I, latitude: f64, longitude: f64))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_venue $body:ident $ty:ident) => {
|
|
|
|
type SendVenue = $ty![SendVenue];
|
|
|
|
|
|
|
|
fn send_venue<C, T, A>(&self, chat_id: C, latitude: f64, longitude: f64, title: T, address: A) -> Self::SendVenue where C: Into<ChatId>,
|
|
|
|
T: Into<String>,
|
|
|
|
A: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(send_venue this (chat_id: C, latitude: f64, longitude: f64, title: T, address: A))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_contact $body:ident $ty:ident) => {
|
|
|
|
type SendContact = $ty![SendContact];
|
|
|
|
|
2021-02-22 06:47:50 +01:00
|
|
|
fn send_contact<C, P, F>(&self, chat_id: C, phone_number: P, first_name: F) -> Self::SendContact where C: Into<ChatId>,
|
|
|
|
P: Into<String>,
|
|
|
|
F: Into<String> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-02-22 06:47:50 +01:00
|
|
|
$body!(send_contact this (chat_id: C, phone_number: P, first_name: F))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_poll $body:ident $ty:ident) => {
|
|
|
|
type SendPoll = $ty![SendPoll];
|
|
|
|
|
2021-11-06 12:31:15 +01:00
|
|
|
fn send_poll<C, Q, O>(&self, chat_id: C, question: Q, options: O) -> Self::SendPoll where C: Into<ChatId>,
|
2020-11-24 17:15:46 +01:00
|
|
|
Q: Into<String>,
|
|
|
|
O: IntoIterator<Item = String> {
|
|
|
|
let this = self;
|
2021-11-06 12:31:15 +01:00
|
|
|
$body!(send_poll this (chat_id: C, question: Q, options: O))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_dice $body:ident $ty:ident) => {
|
|
|
|
type SendDice = $ty![SendDice];
|
|
|
|
|
2021-01-07 22:44:19 +01:00
|
|
|
fn send_dice<C>(&self, chat_id: C) -> Self::SendDice where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-01-07 22:44:19 +01:00
|
|
|
$body!(send_dice this (chat_id: C))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_chat_action $body:ident $ty:ident) => {
|
|
|
|
type SendChatAction = $ty![SendChatAction];
|
|
|
|
|
|
|
|
fn send_chat_action<C>(&self, chat_id: C, action: ChatAction) -> Self::SendChatAction where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(send_chat_action this (chat_id: C, action: ChatAction))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_user_profile_photos $body:ident $ty:ident) => {
|
|
|
|
type GetUserProfilePhotos = $ty![GetUserProfilePhotos];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn get_user_profile_photos(&self, user_id: i64) -> Self::GetUserProfilePhotos {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(get_user_profile_photos this (user_id: i64))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_file $body:ident $ty:ident) => {
|
|
|
|
type GetFile = $ty![GetFile];
|
|
|
|
|
|
|
|
fn get_file<F>(&self, file_id: F) -> Self::GetFile where F: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(get_file this (file_id: F))
|
|
|
|
}
|
|
|
|
};
|
2021-07-04 14:38:22 +02:00
|
|
|
(@method ban_chat_member $body:ident $ty:ident) => {
|
|
|
|
type BanChatMember = $ty![BanChatMember];
|
|
|
|
|
|
|
|
fn ban_chat_member<C>(&self, chat_id: C, user_id: i64) -> Self::BanChatMember where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(ban_chat_member this (chat_id: C, user_id: i64))
|
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method kick_chat_member $body:ident $ty:ident) => {
|
|
|
|
type KickChatMember = $ty![KickChatMember];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn kick_chat_member<C>(&self, chat_id: C, user_id: i64) -> Self::KickChatMember where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(kick_chat_member this (chat_id: C, user_id: i64))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method unban_chat_member $body:ident $ty:ident) => {
|
|
|
|
type UnbanChatMember = $ty![UnbanChatMember];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn unban_chat_member<C>(&self, chat_id: C, user_id: i64) -> Self::UnbanChatMember where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(unban_chat_member this (chat_id: C, user_id: i64))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method restrict_chat_member $body:ident $ty:ident) => {
|
|
|
|
type RestrictChatMember = $ty![RestrictChatMember];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn restrict_chat_member<C>(&self, chat_id: C, user_id: i64, permissions: ChatPermissions) -> Self::RestrictChatMember where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(restrict_chat_member this (chat_id: C, user_id: i64, permissions: ChatPermissions))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method promote_chat_member $body:ident $ty:ident) => {
|
|
|
|
type PromoteChatMember = $ty![PromoteChatMember];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn promote_chat_member<C>(&self, chat_id: C, user_id: i64) -> Self::PromoteChatMember where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(promote_chat_member this (chat_id: C, user_id: i64))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_chat_administrator_custom_title $body:ident $ty:ident) => {
|
|
|
|
type SetChatAdministratorCustomTitle = $ty![SetChatAdministratorCustomTitle];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn set_chat_administrator_custom_title<Ch, Cu>(&self, chat_id: Ch, user_id: i64, custom_title: Cu) -> Self::SetChatAdministratorCustomTitle where Ch: Into<ChatId>,
|
2020-11-24 17:15:46 +01:00
|
|
|
Cu: Into<String> {
|
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(set_chat_administrator_custom_title this (chat_id: Ch, user_id: i64, custom_title: Cu))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
2021-12-07 22:49:24 +01:00
|
|
|
(@method ban_chat_sender_chat $body:ident $ty:ident) => {
|
|
|
|
type BanChatSenderChat = $ty![BanChatSenderChat];
|
|
|
|
|
|
|
|
fn ban_chat_sender_chat<C>(&self, chat_id: C, sender_chat_id: i64) -> Self::BanChatSenderChat where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(ban_chat_sender_chat this (chat_id: C, sender_chat_id: i64))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method unban_chat_sender_chat $body:ident $ty:ident) => {
|
|
|
|
type UnbanChatSenderChat = $ty![UnbanChatSenderChat];
|
|
|
|
|
|
|
|
fn unban_chat_sender_chat<C>(&self, chat_id: C, sender_chat_id: i64) -> Self::UnbanChatSenderChat where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(unban_chat_sender_chat this (chat_id: C, sender_chat_id: i64))
|
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method set_chat_permissions $body:ident $ty:ident) => {
|
|
|
|
type SetChatPermissions = $ty![SetChatPermissions];
|
|
|
|
|
|
|
|
fn set_chat_permissions<C>(&self, chat_id: C, permissions: ChatPermissions) -> Self::SetChatPermissions where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(set_chat_permissions this (chat_id: C, permissions: ChatPermissions))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method export_chat_invite_link $body:ident $ty:ident) => {
|
|
|
|
type ExportChatInviteLink = $ty![ExportChatInviteLink];
|
|
|
|
|
|
|
|
fn export_chat_invite_link<C>(&self, chat_id: C) -> Self::ExportChatInviteLink where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(export_chat_invite_link this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
2021-03-15 21:43:42 +01:00
|
|
|
(@method create_chat_invite_link $body:ident $ty:ident) => {
|
|
|
|
type CreateChatInviteLink = $ty![CreateChatInviteLink];
|
|
|
|
|
|
|
|
fn create_chat_invite_link<C>(&self, chat_id: C) -> Self::CreateChatInviteLink where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(create_chat_invite_link this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_chat_invite_link $body:ident $ty:ident) => {
|
|
|
|
type EditChatInviteLink = $ty![EditChatInviteLink];
|
|
|
|
|
|
|
|
fn edit_chat_invite_link<C, I>(&self, chat_id: C, invite_link: I) -> Self::EditChatInviteLink where C: Into<ChatId>,
|
|
|
|
I: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_chat_invite_link this (chat_id: C, invite_link: I))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method revoke_chat_invite_link $body:ident $ty:ident) => {
|
|
|
|
type RevokeChatInviteLink = $ty![RevokeChatInviteLink];
|
|
|
|
|
|
|
|
fn revoke_chat_invite_link<C, I>(&self, chat_id: C, invite_link: I) -> Self::RevokeChatInviteLink where C: Into<ChatId>,
|
|
|
|
I: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(revoke_chat_invite_link this (chat_id: C, invite_link: I))
|
|
|
|
}
|
|
|
|
};
|
2021-11-06 12:32:16 +01:00
|
|
|
(@method approve_chat_join_request $body:ident $ty:ident) => {
|
|
|
|
type ApproveChatJoinRequest = $ty![ApproveChatJoinRequest];
|
|
|
|
|
|
|
|
fn approve_chat_join_request<C>(&self, chat_id: C, user_id: i64) -> Self::ApproveChatJoinRequest where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(approve_chat_join_request this (chat_id: C, user_id: i64))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method decline_chat_join_request $body:ident $ty:ident) => {
|
|
|
|
type DeclineChatJoinRequest = $ty![DeclineChatJoinRequest];
|
|
|
|
|
|
|
|
fn decline_chat_join_request<C>(&self, chat_id: C, user_id: i64) -> Self::DeclineChatJoinRequest where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(decline_chat_join_request this (chat_id: C, user_id: i64))
|
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method set_chat_photo $body:ident $ty:ident) => {
|
|
|
|
type SetChatPhoto = $ty![SetChatPhoto];
|
|
|
|
|
|
|
|
fn set_chat_photo<C>(&self, chat_id: C, photo: InputFile) -> Self::SetChatPhoto where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(set_chat_photo this (chat_id: C, photo: InputFile))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method delete_chat_photo $body:ident $ty:ident) => {
|
|
|
|
type DeleteChatPhoto = $ty![DeleteChatPhoto];
|
|
|
|
|
|
|
|
fn delete_chat_photo<C>(&self, chat_id: C) -> Self::DeleteChatPhoto where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(delete_chat_photo this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_chat_title $body:ident $ty:ident) => {
|
|
|
|
type SetChatTitle = $ty![SetChatTitle];
|
|
|
|
|
|
|
|
fn set_chat_title<C, T>(&self, chat_id: C, title: T) -> Self::SetChatTitle where C: Into<ChatId>,
|
|
|
|
T: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(set_chat_title this (chat_id: C, title: T))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_chat_description $body:ident $ty:ident) => {
|
|
|
|
type SetChatDescription = $ty![SetChatDescription];
|
|
|
|
|
|
|
|
fn set_chat_description<C>(&self, chat_id: C) -> Self::SetChatDescription where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(set_chat_description this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method pin_chat_message $body:ident $ty:ident) => {
|
|
|
|
type PinChatMessage = $ty![PinChatMessage];
|
|
|
|
|
|
|
|
fn pin_chat_message<C>(&self, chat_id: C, message_id: i32) -> Self::PinChatMessage where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(pin_chat_message this (chat_id: C, message_id: i32))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method unpin_chat_message $body:ident $ty:ident) => {
|
|
|
|
type UnpinChatMessage = $ty![UnpinChatMessage];
|
|
|
|
|
|
|
|
fn unpin_chat_message<C>(&self, chat_id: C) -> Self::UnpinChatMessage where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(unpin_chat_message this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
2021-03-14 20:44:33 +01:00
|
|
|
(@method unpin_all_chat_messages $body:ident $ty:ident) => {
|
|
|
|
type UnpinAllChatMessages = $ty![UnpinAllChatMessages];
|
|
|
|
|
|
|
|
fn unpin_all_chat_messages<C>(&self, chat_id: C) -> Self::UnpinAllChatMessages where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(unpin_all_chat_messages this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method leave_chat $body:ident $ty:ident) => {
|
|
|
|
type LeaveChat = $ty![LeaveChat];
|
|
|
|
|
|
|
|
fn leave_chat<C>(&self, chat_id: C) -> Self::LeaveChat where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(leave_chat this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_chat $body:ident $ty:ident) => {
|
|
|
|
type GetChat = $ty![GetChat];
|
|
|
|
|
|
|
|
fn get_chat<C>(&self, chat_id: C) -> Self::GetChat where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(get_chat this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_chat_administrators $body:ident $ty:ident) => {
|
|
|
|
type GetChatAdministrators = $ty![GetChatAdministrators];
|
|
|
|
|
|
|
|
fn get_chat_administrators<C>(&self, chat_id: C) -> Self::GetChatAdministrators where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(get_chat_administrators this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
2021-07-04 14:38:22 +02:00
|
|
|
(@method get_chat_member_count $body:ident $ty:ident) => {
|
|
|
|
type GetChatMemberCount = $ty![GetChatMemberCount];
|
|
|
|
|
|
|
|
fn get_chat_member_count<C>(&self, chat_id: C) -> Self::GetChatMemberCount where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(get_chat_member_count this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method get_chat_members_count $body:ident $ty:ident) => {
|
|
|
|
type GetChatMembersCount = $ty![GetChatMembersCount];
|
|
|
|
|
|
|
|
fn get_chat_members_count<C>(&self, chat_id: C) -> Self::GetChatMembersCount where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(get_chat_members_count this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_chat_member $body:ident $ty:ident) => {
|
|
|
|
type GetChatMember = $ty![GetChatMember];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn get_chat_member<C>(&self, chat_id: C, user_id: i64) -> Self::GetChatMember where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(get_chat_member this (chat_id: C, user_id: i64))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_chat_sticker_set $body:ident $ty:ident) => {
|
|
|
|
type SetChatStickerSet = $ty![SetChatStickerSet];
|
|
|
|
|
|
|
|
fn set_chat_sticker_set<C, S>(&self, chat_id: C, sticker_set_name: S) -> Self::SetChatStickerSet where C: Into<ChatId>,
|
|
|
|
S: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(set_chat_sticker_set this (chat_id: C, sticker_set_name: S))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method delete_chat_sticker_set $body:ident $ty:ident) => {
|
|
|
|
type DeleteChatStickerSet = $ty![DeleteChatStickerSet];
|
|
|
|
|
|
|
|
fn delete_chat_sticker_set<C>(&self, chat_id: C) -> Self::DeleteChatStickerSet where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(delete_chat_sticker_set this (chat_id: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method answer_callback_query $body:ident $ty:ident) => {
|
|
|
|
type AnswerCallbackQuery = $ty![AnswerCallbackQuery];
|
|
|
|
|
|
|
|
fn answer_callback_query<C>(&self, callback_query_id: C) -> Self::AnswerCallbackQuery where C: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(answer_callback_query this (callback_query_id: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_my_commands $body:ident $ty:ident) => {
|
|
|
|
type SetMyCommands = $ty![SetMyCommands];
|
|
|
|
|
|
|
|
fn set_my_commands<C>(&self, commands: C) -> Self::SetMyCommands where C: IntoIterator<Item = BotCommand> {
|
|
|
|
let this = self;
|
|
|
|
$body!(set_my_commands this (commands: C))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_my_commands $body:ident $ty:ident) => {
|
|
|
|
type GetMyCommands = $ty![GetMyCommands];
|
|
|
|
|
2020-11-24 18:30:45 +01:00
|
|
|
fn get_my_commands(&self) -> Self::GetMyCommands {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
|
|
|
$body!(get_my_commands this ())
|
|
|
|
}
|
|
|
|
};
|
2021-07-04 14:38:22 +02:00
|
|
|
(@method delete_my_commands $body:ident $ty:ident) => {
|
|
|
|
type DeleteMyCommands = $ty![DeleteMyCommands];
|
|
|
|
|
|
|
|
fn delete_my_commands(&self) -> Self::DeleteMyCommands {
|
|
|
|
let this = self;
|
|
|
|
$body!(delete_my_commands this ())
|
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
(@method answer_inline_query $body:ident $ty:ident) => {
|
|
|
|
type AnswerInlineQuery = $ty![AnswerInlineQuery];
|
|
|
|
|
|
|
|
fn answer_inline_query<I, R>(&self, inline_query_id: I, results: R) -> Self::AnswerInlineQuery where I: Into<String>,
|
|
|
|
R: IntoIterator<Item = InlineQueryResult> {
|
|
|
|
let this = self;
|
|
|
|
$body!(answer_inline_query this (inline_query_id: I, results: R))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_text $body:ident $ty:ident) => {
|
|
|
|
type EditMessageText = $ty![EditMessageText];
|
|
|
|
|
|
|
|
fn edit_message_text<C, T>(&self, chat_id: C, message_id: i32, text: T) -> Self::EditMessageText where C: Into<ChatId>,
|
|
|
|
T: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_message_text this (chat_id: C, message_id: i32, text: T))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_text_inline $body:ident $ty:ident) => {
|
|
|
|
type EditMessageTextInline = $ty![EditMessageTextInline];
|
|
|
|
|
|
|
|
fn edit_message_text_inline<I, T>(&self, inline_message_id: I, text: T) -> Self::EditMessageTextInline where I: Into<String>,
|
|
|
|
T: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_message_text_inline this (inline_message_id: I, text: T))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_caption $body:ident $ty:ident) => {
|
|
|
|
type EditMessageCaption = $ty![EditMessageCaption];
|
|
|
|
|
2020-12-28 12:30:18 +01:00
|
|
|
fn edit_message_caption<C>(&self, chat_id: C, message_id: i32) -> Self::EditMessageCaption where C: Into<ChatId> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2020-12-28 12:30:18 +01:00
|
|
|
$body!(edit_message_caption this (chat_id: C, message_id: i32))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_caption_inline $body:ident $ty:ident) => {
|
|
|
|
type EditMessageCaptionInline = $ty![EditMessageCaptionInline];
|
|
|
|
|
2020-12-28 12:30:18 +01:00
|
|
|
fn edit_message_caption_inline<I>(&self, inline_message_id: I) -> Self::EditMessageCaptionInline where I: Into<String> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2020-12-28 12:30:18 +01:00
|
|
|
$body!(edit_message_caption_inline this (inline_message_id: I))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_media $body:ident $ty:ident) => {
|
|
|
|
type EditMessageMedia = $ty![EditMessageMedia];
|
|
|
|
|
|
|
|
fn edit_message_media<C>(&self, chat_id: C, message_id: i32, media: InputMedia) -> Self::EditMessageMedia where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_message_media this (chat_id: C, message_id: i32, media: InputMedia))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_media_inline $body:ident $ty:ident) => {
|
|
|
|
type EditMessageMediaInline = $ty![EditMessageMediaInline];
|
|
|
|
|
|
|
|
fn edit_message_media_inline<I>(&self, inline_message_id: I, media: InputMedia) -> Self::EditMessageMediaInline where I: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_message_media_inline this (inline_message_id: I, media: InputMedia))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_reply_markup $body:ident $ty:ident) => {
|
|
|
|
type EditMessageReplyMarkup = $ty![EditMessageReplyMarkup];
|
|
|
|
|
|
|
|
fn edit_message_reply_markup<C>(&self, chat_id: C, message_id: i32) -> Self::EditMessageReplyMarkup where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_message_reply_markup this (chat_id: C, message_id: i32))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method edit_message_reply_markup_inline $body:ident $ty:ident) => {
|
|
|
|
type EditMessageReplyMarkupInline = $ty![EditMessageReplyMarkupInline];
|
|
|
|
|
|
|
|
fn edit_message_reply_markup_inline<I>(&self, inline_message_id: I) -> Self::EditMessageReplyMarkupInline where I: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(edit_message_reply_markup_inline this (inline_message_id: I))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method stop_poll $body:ident $ty:ident) => {
|
|
|
|
type StopPoll = $ty![StopPoll];
|
|
|
|
|
|
|
|
fn stop_poll<C>(&self, chat_id: C, message_id: i32) -> Self::StopPoll where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(stop_poll this (chat_id: C, message_id: i32))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method delete_message $body:ident $ty:ident) => {
|
|
|
|
type DeleteMessage = $ty![DeleteMessage];
|
|
|
|
|
|
|
|
fn delete_message<C>(&self, chat_id: C, message_id: i32) -> Self::DeleteMessage where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(delete_message this (chat_id: C, message_id: i32))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_sticker $body:ident $ty:ident) => {
|
|
|
|
type SendSticker = $ty![SendSticker];
|
|
|
|
|
|
|
|
fn send_sticker<C>(&self, chat_id: C, sticker: InputFile) -> Self::SendSticker where C: Into<ChatId> {
|
|
|
|
let this = self;
|
|
|
|
$body!(send_sticker this (chat_id: C, sticker: InputFile))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_sticker_set $body:ident $ty:ident) => {
|
|
|
|
type GetStickerSet = $ty![GetStickerSet];
|
|
|
|
|
|
|
|
fn get_sticker_set<N>(&self, name: N) -> Self::GetStickerSet where N: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(get_sticker_set this (name: N))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method upload_sticker_file $body:ident $ty:ident) => {
|
|
|
|
type UploadStickerFile = $ty![UploadStickerFile];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn upload_sticker_file(&self, user_id: i64, png_sticker: InputFile) -> Self::UploadStickerFile {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(upload_sticker_file this (user_id: i64, png_sticker: InputFile))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method create_new_sticker_set $body:ident $ty:ident) => {
|
|
|
|
type CreateNewStickerSet = $ty![CreateNewStickerSet];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn create_new_sticker_set<N, T, E>(&self, user_id: i64, name: N, title: T, sticker: InputSticker, emojis: E) -> Self::CreateNewStickerSet where N: Into<String>,
|
2020-11-24 17:15:46 +01:00
|
|
|
T: Into<String>,
|
|
|
|
E: Into<String> {
|
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(create_new_sticker_set this (user_id: i64, name: N, title: T, sticker: InputSticker, emojis: E))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method add_sticker_to_set $body:ident $ty:ident) => {
|
|
|
|
type AddStickerToSet = $ty![AddStickerToSet];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn add_sticker_to_set<N, E>(&self, user_id: i64, name: N, sticker: InputSticker, emojis: E) -> Self::AddStickerToSet where N: Into<String>,
|
2020-11-24 17:15:46 +01:00
|
|
|
E: Into<String> {
|
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(add_sticker_to_set this (user_id: i64, name: N, sticker: InputSticker, emojis: E))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_sticker_position_in_set $body:ident $ty:ident) => {
|
|
|
|
type SetStickerPositionInSet = $ty![SetStickerPositionInSet];
|
|
|
|
|
|
|
|
fn set_sticker_position_in_set<S>(&self, sticker: S, position: u32) -> Self::SetStickerPositionInSet where S: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(set_sticker_position_in_set this (sticker: S, position: u32))
|
|
|
|
}
|
2020-11-24 18:30:45 +01:00
|
|
|
};
|
|
|
|
(@method delete_sticker_from_set $body:ident $ty:ident) => {
|
2020-11-24 17:15:46 +01:00
|
|
|
type DeleteStickerFromSet = $ty![DeleteStickerFromSet];
|
|
|
|
|
|
|
|
fn delete_sticker_from_set<S>(&self, sticker: S) -> Self::DeleteStickerFromSet where S: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(delete_sticker_from_set this (sticker: S))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_sticker_set_thumb $body:ident $ty:ident) => {
|
|
|
|
type SetStickerSetThumb = $ty![SetStickerSetThumb];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn set_sticker_set_thumb<N>(&self, name: N, user_id: i64) -> Self::SetStickerSetThumb where N: Into<String> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(set_sticker_set_thumb this (name: N, user_id: i64))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method send_invoice $body:ident $ty:ident) => {
|
|
|
|
type SendInvoice = $ty![SendInvoice];
|
|
|
|
|
2021-05-04 15:47:16 +02:00
|
|
|
fn send_invoice<Ch, T, D, Pa, P, C, Pri>(&self, chat_id: Ch, title: T, description: D, payload: Pa, provider_token: P, currency: C, prices: Pri) -> Self::SendInvoice where Ch: Into<ChatId>,
|
|
|
|
T: Into<String>,
|
2020-11-24 17:15:46 +01:00
|
|
|
D: Into<String>,
|
|
|
|
Pa: Into<String>,
|
|
|
|
P: Into<String>,
|
|
|
|
C: Into<String>,
|
|
|
|
Pri: IntoIterator<Item = LabeledPrice> {
|
|
|
|
let this = self;
|
2021-05-04 15:47:16 +02:00
|
|
|
$body!(send_invoice this (chat_id: Ch, title: T, description: D, payload: Pa, provider_token: P, currency: C, prices: Pri))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method answer_shipping_query $body:ident $ty:ident) => {
|
|
|
|
type AnswerShippingQuery = $ty![AnswerShippingQuery];
|
|
|
|
|
|
|
|
fn answer_shipping_query<S>(&self, shipping_query_id: S, ok: bool) -> Self::AnswerShippingQuery where S: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(answer_shipping_query this (shipping_query_id: S, ok: bool))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method answer_pre_checkout_query $body:ident $ty:ident) => {
|
|
|
|
type AnswerPreCheckoutQuery = $ty![AnswerPreCheckoutQuery];
|
|
|
|
|
|
|
|
fn answer_pre_checkout_query<P>(&self, pre_checkout_query_id: P, ok: bool) -> Self::AnswerPreCheckoutQuery where P: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(answer_pre_checkout_query this (pre_checkout_query_id: P, ok: bool))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_passport_data_errors $body:ident $ty:ident) => {
|
|
|
|
type SetPassportDataErrors = $ty![SetPassportDataErrors];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn set_passport_data_errors<E>(&self, user_id: i64, errors: E) -> Self::SetPassportDataErrors where E: IntoIterator<Item = PassportElementError> {
|
2020-11-24 17:15:46 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(set_passport_data_errors this (user_id: i64, errors: E))
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|
|
|
|
};
|
2020-12-28 12:30:18 +01:00
|
|
|
(@method send_game $body:ident $ty:ident) => {
|
|
|
|
type SendGame = $ty![SendGame];
|
|
|
|
|
|
|
|
fn send_game<G>(&self, chat_id: u32, game_short_name: G) -> Self::SendGame where G: Into<String> {
|
|
|
|
let this = self;
|
|
|
|
$body!(send_game this (chat_id: u32, game_short_name: G))
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_game_score $body:ident $ty:ident) => {
|
|
|
|
type SetGameScore = $ty![SetGameScore];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn set_game_score(&self, user_id: i64, score: u64, chat_id: u32, message_id: i64) -> Self::SetGameScore {
|
2020-12-28 12:30:18 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(set_game_score this (user_id: i64, score: u64, chat_id: u32, message_id: i64))
|
2020-12-28 12:30:18 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method set_game_score_inline $body:ident $ty:ident) => {
|
|
|
|
type SetGameScoreInline = $ty![SetGameScoreInline];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn set_game_score_inline<I>(&self, user_id: i64, score: u64, inline_message_id: I) -> Self::SetGameScoreInline where I: Into<String> {
|
2020-12-28 12:30:18 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(set_game_score_inline this (user_id: i64, score: u64, inline_message_id: I))
|
2020-12-28 12:30:18 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
(@method get_game_high_scores $body:ident $ty:ident) => {
|
|
|
|
type GetGameHighScores = $ty![GetGameHighScores];
|
|
|
|
|
2021-03-15 21:43:42 +01:00
|
|
|
fn get_game_high_scores<T>(&self, user_id: i64, target: T) -> Self::GetGameHighScores where T: Into<TargetMessage> {
|
2020-12-28 12:30:18 +01:00
|
|
|
let this = self;
|
2021-03-15 21:43:42 +01:00
|
|
|
$body!(get_game_high_scores this (user_id: i64, target: T))
|
2020-12-28 12:30:18 +01:00
|
|
|
}
|
|
|
|
};
|
2020-11-24 17:15:46 +01:00
|
|
|
}
|