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
use serde::Serialize;
use crate::entities::{
inline_keyboard_markup::InlineKeyboardMarkup, input_message_content::InputMessageContent,
};
/// Represents a contact with a phone number. By default, this contact will be sent by the user. Alternatively, you can use *input\_message\_content* to send a message with the specified content instead of the contact.
///
/// API Reference: [link](https://core.telegram.org/bots/api/#inlinequeryresultcontact)
#[derive(Debug, Clone, Default, PartialEq, Serialize)]
pub struct InlineQueryResultContact {
/// Unique identifier for this result, 1-64 Bytes
pub id: String,
/// Contact's phone number
pub phone_number: String,
/// Contact's first name
pub first_name: String,
/// *Optional*. Contact's last name
#[serde(skip_serializing_if = "Option::is_none")]
pub last_name: Option<String>,
/// *Optional*. Additional data about the contact in the form of a [vCard](https://en.wikipedia.org/wiki/VCard), 0-2048 bytes
#[serde(skip_serializing_if = "Option::is_none")]
pub vcard: Option<String>,
/// *Optional*. [Inline keyboard](https://core.telegram.org/bots/features#inline-keyboards) attached to the message
#[serde(skip_serializing_if = "Option::is_none")]
pub reply_markup: Option<InlineKeyboardMarkup>,
/// *Optional*. Content of the message to be sent instead of the contact
#[serde(skip_serializing_if = "Option::is_none")]
pub input_message_content: Option<InputMessageContent>,
/// *Optional*. Url of the thumbnail for the result
#[serde(skip_serializing_if = "Option::is_none")]
pub thumbnail_url: Option<String>,
/// *Optional*. Thumbnail width
#[serde(skip_serializing_if = "Option::is_none")]
pub thumbnail_width: Option<i64>,
/// *Optional*. Thumbnail height
#[serde(skip_serializing_if = "Option::is_none")]
pub thumbnail_height: Option<i64>,
}
// Divider: all content below this line will be preserved after code regen