1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
use super::*;
use crate::{
errors,
internal::{BoxFuture, Client},
types::{
input_file::{InputFile, PngSticker},
sticker::MaskPosition,
user,
},
};
#[derive(Debug, Clone)]
#[must_use = "methods do nothing unless turned into a future"]
pub struct AddStickerToSet<'a, C> {
client: &'a Client<C>,
token: Token,
user_id: user::Id,
name: &'a str,
png_sticker: PngSticker<'a>,
emojis: &'a str,
mask_position: Option<MaskPosition>,
}
impl<'a, C> AddStickerToSet<'a, C> {
pub(crate) const fn new(
client: &'a Client<C>,
token: Token,
user_id: user::Id,
name: &'a str,
png_sticker: PngSticker<'a>,
emojis: &'a str,
) -> Self {
Self {
client,
token,
user_id,
name,
png_sticker,
emojis,
mask_position: None,
}
}
pub fn mask_position(mut self, mask_position: MaskPosition) -> Self {
self.mask_position = Some(mask_position);
self
}
}
impl<C> IntoFuture for AddStickerToSet<'_, C>
where
C: hyper::client::connect::Connect + Sync + 'static,
C::Transport: 'static,
C::Future: 'static,
{
type Future = BoxFuture<Self::Item, Self::Error>;
type Item = ();
type Error = errors::MethodCall;
fn into_future(self) -> Self::Future {
let mut multipart = Multipart::new(5)
.string("user_id", &self.user_id)
.str("name", self.name)
.str("emojis", self.emojis)
.maybe_json("mask_position", self.mask_position);
match self.png_sticker.media {
InputFile::File {
filename, bytes, ..
} => multipart = multipart.file("png_sticker", filename, bytes),
InputFile::Id(sticker) | InputFile::Url(sticker) => {
multipart = multipart.str("png_sticker", sticker);
}
}
let (boundary, body) = multipart.finish();
Box::new(
send_method::<bool, C>(
self.client,
&self.token,
"addStickerToSet",
Some(boundary),
body,
)
.map(|_| ()),
)
}
}