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
use serde::Serialize;
use crate::entities::{
input_paid_media_photo::InputPaidMediaPhoto,
input_paid_media_video::InputPaidMediaVideo,
misc::input_file::{GetFiles, InputFile},
};
/// This object describes the paid media to be sent. Currently, it can be one of
///
/// * [InputPaidMediaPhoto](https://core.telegram.org/bots/api/#inputpaidmediaphoto)
/// * [InputPaidMediaVideo](https://core.telegram.org/bots/api/#inputpaidmediavideo)
///
/// API Reference: [link](https://core.telegram.org/bots/api/#inputpaidmedia)
#[derive(Debug, Clone, PartialEq, Serialize)]
#[serde(tag = "type")]
pub enum InputPaidMedia {
/// The paid media to send is a photo.
///
/// API Reference: [link](https://core.telegram.org/bots/api/#inputpaidmediaphoto)
#[serde(rename = "photo")]
Photo(InputPaidMediaPhoto),
/// The paid media to send is a video.
///
/// API Reference: [link](https://core.telegram.org/bots/api/#inputpaidmediavideo)
#[serde(rename = "video")]
Video(InputPaidMediaVideo),
}
impl Default for InputPaidMedia {
fn default() -> Self {
Self::Photo(InputPaidMediaPhoto::default())
}
}
impl From<InputPaidMediaPhoto> for InputPaidMedia {
fn from(value: InputPaidMediaPhoto) -> Self {
Self::Photo(value)
}
}
impl From<InputPaidMediaVideo> for InputPaidMedia {
fn from(value: InputPaidMediaVideo) -> Self {
Self::Video(value)
}
}
impl GetFiles for InputPaidMedia {
fn get_files(&self) -> Vec<&InputFile> {
match self {
Self::Photo(m) => m.get_files(),
Self::Video(m) => m.get_files(),
}
}
}
// Divider: all content below this line will be preserved after code regen