teloxide-core 0.13.0

Core part of the `teloxide` library - telegram bot API client
Documentation
//! Generated by `codegen_payloads`, do not edit by hand.

use serde::Serialize;

use crate::types::{MessageEntity, ParseMode, True, UserId};

impl_payload! {
    /// Gifts a Telegram Premium subscription to the given user. Returns True on success.
    #[derive(Debug, PartialEq, Eq, Hash, Clone, Serialize)]
    pub GiftPremiumSubscription (GiftPremiumSubscriptionSetters) => True {
        required {
            /// Unique identifier of the target user
            pub user_id: UserId,
            /// Number of months the Telegram Premium subscription will be active for the user; must be one of 3, 6, or 12
            pub month_count: u8,
            /// Number of Telegram Stars to pay for the Telegram Premium subscription; must be 1000 for 3 months, 1500 for 6 months, and 2500 for 12 months
            pub star_count: u32,
        }
        optional {
            /// Text that will be shown along with the service message about the subscription; 0-128 characters
            pub text: String [into],
            /// Mode for parsing entities in the text. See [formatting options] for more details. Entities other than “bold”, “italic”, “underline”, “strikethrough”, “spoiler”, and “custom_emoji” are ignored.
            ///
            /// [formatting options]: https://core.telegram.org/bots/api#formatting-options
            pub text_parse_mode: ParseMode,
            /// List of special entities that appear in the gift text. It can be specified instead of `text_parse_mode`. See [formatting options] for more details. Entities other than “bold”, “italic”, “underline”, “strikethrough”, “spoiler”, and “custom_emoji” are ignored.
            ///
            /// [formatting options]: https://core.telegram.org/bots/api#formatting-options
            pub text_entities: Vec<MessageEntity> [collect],
        }
    }
}