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
use serde::{Deserialize, Serialize};
use crate::entities::{
paid_media_photo::PaidMediaPhoto, paid_media_preview::PaidMediaPreview,
paid_media_video::PaidMediaVideo,
};
/// This object describes paid media. Currently, it can be one of
///
/// * [PaidMediaPreview](https://core.telegram.org/bots/api/#paidmediapreview)
/// * [PaidMediaPhoto](https://core.telegram.org/bots/api/#paidmediaphoto)
/// * [PaidMediaVideo](https://core.telegram.org/bots/api/#paidmediavideo)
///
/// API Reference: [link](https://core.telegram.org/bots/api/#paidmedia)
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(tag = "type")]
pub enum PaidMedia {
/// The paid media isn't available before the payment.
///
/// API Reference: [link](https://core.telegram.org/bots/api/#paidmediapreview)
#[serde(rename = "preview")]
Preview(PaidMediaPreview),
/// The paid media is a photo.
///
/// API Reference: [link](https://core.telegram.org/bots/api/#paidmediaphoto)
#[serde(rename = "photo")]
Photo(PaidMediaPhoto),
/// The paid media is a video.
///
/// API Reference: [link](https://core.telegram.org/bots/api/#paidmediavideo)
#[serde(rename = "video")]
Video(PaidMediaVideo),
}
impl Default for PaidMedia {
fn default() -> Self {
Self::Preview(PaidMediaPreview::default())
}
}
impl From<PaidMediaPreview> for PaidMedia {
fn from(value: PaidMediaPreview) -> Self {
Self::Preview(value)
}
}
impl From<PaidMediaPhoto> for PaidMedia {
fn from(value: PaidMediaPhoto) -> Self {
Self::Photo(value)
}
}
impl From<PaidMediaVideo> for PaidMedia {
fn from(value: PaidMediaVideo) -> Self {
Self::Video(value)
}
}
// Divider: all content below this line will be preserved after code regen