diff --git a/td/generate/scheme/td_api.tl b/td/generate/scheme/td_api.tl index 06f62d8cb..659089ba8 100644 --- a/td/generate/scheme/td_api.tl +++ b/td/generate/scheme/td_api.tl @@ -889,7 +889,7 @@ starTransactionPartnerBot bot_user_id:int53 product_info:productInfo invoice_pay //@chat_id Identifier of the chat //@paid_media_message_id Identifier of the corresponding message with paid media; can be an identifier of a deleted message //@media Information about the bought media -starTransactionPartnerChannel chat_id:int53 paid_media_message_id:int53 media:vector = StarTransactionPartner; +starTransactionPartnerChannel chat_id:int53 paid_media_message_id:int53 media:vector = StarTransactionPartner; //@description The transaction is a transaction with unknown partner starTransactionPartnerUnsupported = StarTransactionPartner; @@ -2803,23 +2803,23 @@ inputInvoiceName name:string = InputInvoice; inputInvoiceTelegram purpose:TelegramPaymentPurpose = InputInvoice; -//@class MessageExtendedMedia @description Describes a paid media +//@class PaidMedia @description Describes a paid media //@description The media is hidden until the invoice is paid //@width Media width; 0 if unknown //@height Media height; 0 if unknown //@duration Media duration, in seconds; 0 if unknown //@minithumbnail Media minithumbnail; may be null -messageExtendedMediaPreview width:int32 height:int32 duration:int32 minithumbnail:minithumbnail = MessageExtendedMedia; +paidMediaPreview width:int32 height:int32 duration:int32 minithumbnail:minithumbnail = PaidMedia; //@description The media is a photo @photo The photo -messageExtendedMediaPhoto photo:photo = MessageExtendedMedia; +paidMediaPhoto photo:photo = PaidMedia; //@description The media is a video @video The video -messageExtendedMediaVideo video:video = MessageExtendedMedia; +paidMediaVideo video:video = PaidMedia; //@description The media is unsupported -messageExtendedMediaUnsupported = MessageExtendedMedia; +paidMediaUnsupported = PaidMedia; //@description Describes parameters of a Telegram Premium giveaway @@ -3142,7 +3142,7 @@ messageDocument document:document caption:formattedText = MessageContent; //@media Information about the media //@caption Media caption //@show_caption_above_media True, if the caption must be shown above the media; otherwise, the caption must be shown below the media -messagePaidMedia star_count:int53 media:vector caption:formattedText show_caption_above_media:Bool = MessageContent; +messagePaidMedia star_count:int53 media:vector caption:formattedText show_caption_above_media:Bool = MessageContent; //@description A photo message //@photo The photo @@ -3226,9 +3226,9 @@ messageStory story_sender_chat_id:int53 story_id:int32 via_mention:Bool = Messag //@is_test True, if the invoice is a test invoice //@need_shipping_address True, if the shipping address must be specified //@receipt_message_id The identifier of the message with the receipt, after the product has been purchased -//@extended_media Extended media attached to the invoice; may be null if none -//@extended_media_caption Extended media caption; may be null if none -messageInvoice product_info:productInfo currency:string total_amount:int53 start_parameter:string is_test:Bool need_shipping_address:Bool receipt_message_id:int53 extended_media:MessageExtendedMedia extended_media_caption:formattedText = MessageContent; +//@paid_media Extended media attached to the invoice; may be null if none +//@paid_media_caption Extended media caption; may be null if none +messageInvoice product_info:productInfo currency:string total_amount:int53 start_parameter:string is_test:Bool need_shipping_address:Bool receipt_message_id:int53 paid_media:PaidMedia paid_media_caption:formattedText = MessageContent; //@description A message with information about an ended call @is_video True, if the call was a video call @discard_reason Reason why the call was discarded @duration Call duration, in seconds messageCall is_video:Bool discard_reason:CallDiscardReason duration:int32 = MessageContent; @@ -3505,15 +3505,15 @@ textEntityTypeMediaTimestamp media_timestamp:int32 = TextEntityType; inputThumbnail thumbnail:InputFile width:int32 height:int32 = InputThumbnail; -//@class InputMessageExtendedMediaType @description Describes type of paid media to sent +//@class InputPaidMediaType @description Describes type of paid media to sent //@description The media is a photo. The photo must be at most 10 MB in size. The photo's width and height must not exceed 10000 in total. Width and height ratio must be at most 20 -inputMessageExtendedMediaTypePhoto = InputMessageExtendedMediaType; +inputPaidMediaTypePhoto = InputPaidMediaType; //@description The media is a video //@duration Duration of the video, in seconds //@supports_streaming True, if the video is supposed to be streamed -inputMessageExtendedMediaTypeVideo duration:int32 supports_streaming:Bool = InputMessageExtendedMediaType; +inputPaidMediaTypeVideo duration:int32 supports_streaming:Bool = InputPaidMediaType; //@description Describes a paid media to be sent @@ -3523,7 +3523,7 @@ inputMessageExtendedMediaTypeVideo duration:int32 supports_streaming:Bool = Inpu //@added_sticker_file_ids File identifiers of the stickers added to the media, if applicable //@width Media width //@height Media height -inputMessageExtendedMedia type:InputMessageExtendedMediaType media:InputFile thumbnail:inputThumbnail added_sticker_file_ids:vector width:int32 height:int32 = InputMessageExtendedMedia; +inputPaidMedia type:InputPaidMediaType media:InputFile thumbnail:inputThumbnail added_sticker_file_ids:vector width:int32 height:int32 = InputPaidMedia; //@class MessageSchedulingState @description Contains information about the time when a scheduled message will be sent @@ -3605,7 +3605,7 @@ inputMessageDocument document:InputFile thumbnail:inputThumbnail disable_content //@paid_media The content of the paid media //@caption Message caption; pass null to use an empty caption; 0-getOption("message_caption_length_max") characters //@show_caption_above_media True, if the caption must be shown above the video; otherwise, the caption must be shown below the video; not supported in secret chats -inputMessagePaidMedia star_count:int53 paid_media:vector caption:formattedText show_caption_above_media:Bool = InputMessageContent; +inputMessagePaidMedia star_count:int53 paid_media:vector caption:formattedText show_caption_above_media:Bool = InputMessageContent; //@description A photo message //@photo Photo to send. The photo must be at most 10 MB in size. The photo's width and height must not exceed 10000 in total. Width and height ratio must be at most 20 @@ -3690,7 +3690,7 @@ inputMessageGame bot_user_id:int53 game_short_name:string = InputMessageContent; //@start_parameter Unique invoice bot deep link parameter for the generation of this invoice. If empty, it would be possible to pay directly from forwards of the invoice message //@paid_media The content of paid media attached to the invoice; pass null if none //@paid_media_caption Paid media caption; pass null to use an empty caption; 0-getOption("message_caption_length_max") characters -inputMessageInvoice invoice:invoice title:string description:string photo_url:string photo_size:int32 photo_width:int32 photo_height:int32 payload:bytes provider_token:string provider_data:string start_parameter:string paid_media:inputMessageExtendedMedia paid_media_caption:formattedText = InputMessageContent; +inputMessageInvoice invoice:invoice title:string description:string photo_url:string photo_size:int32 photo_width:int32 photo_height:int32 payload:bytes provider_token:string provider_data:string start_parameter:string paid_media:inputPaidMedia paid_media_caption:formattedText = InputMessageContent; //@description A message with a poll. Polls can't be sent to secret chats. Polls can be sent only to a private chat with a bot //@question Poll question; 1-255 characters (up to 300 characters for bots). Only custom emoji entities are allowed to be added and only by Premium users diff --git a/td/telegram/MessageExtendedMedia.cpp b/td/telegram/MessageExtendedMedia.cpp index 561c78d4c..54ea02fb3 100644 --- a/td/telegram/MessageExtendedMedia.cpp +++ b/td/telegram/MessageExtendedMedia.cpp @@ -112,7 +112,7 @@ void MessageExtendedMedia::init_from_media(Td *td, telegram_api::object_ptr MessageExtendedMedia::get_message_extended_media( - Td *td, td_api::object_ptr &&paid_media, DialogId owner_dialog_id) { + Td *td, td_api::object_ptr &&paid_media, DialogId owner_dialog_id) { if (paid_media == nullptr) { return MessageExtendedMedia(); } @@ -127,11 +127,11 @@ Result MessageExtendedMedia::get_message_extended_media( auto file_type = FileType::None; switch (paid_media->type_->get_id()) { - case td_api::inputMessageExtendedMediaTypePhoto::ID: + case td_api::inputPaidMediaTypePhoto::ID: file_type = FileType::Photo; result.type_ = Type::Photo; break; - case td_api::inputMessageExtendedMediaTypeVideo::ID: + case td_api::inputPaidMediaTypeVideo::ID: file_type = FileType::Video; result.type_ = Type::Video; break; @@ -156,7 +156,7 @@ Result MessageExtendedMedia::get_message_extended_media( break; } case Type::Video: { - auto type = static_cast(paid_media->type_.get()); + auto type = static_cast(paid_media->type_.get()); FileView file_view = td->file_manager_->get_file_view(file_id); auto suggested_path = file_view.suggested_path(); const PathView path_view(suggested_path); @@ -197,25 +197,24 @@ bool MessageExtendedMedia::update_to(Td *td, return false; } -td_api::object_ptr MessageExtendedMedia::get_message_extended_media_object(Td *td) const { +td_api::object_ptr MessageExtendedMedia::get_message_extended_media_object(Td *td) const { if (type_ == Type::Empty) { return nullptr; } switch (type_) { case Type::Unsupported: - return td_api::make_object(); + return td_api::make_object(); case Type::Preview: - return td_api::make_object(dimensions_.width, dimensions_.height, duration_, - get_minithumbnail_object(minithumbnail_)); + return td_api::make_object(dimensions_.width, dimensions_.height, duration_, + get_minithumbnail_object(minithumbnail_)); case Type::Photo: { auto photo = get_photo_object(td->file_manager_.get(), photo_); CHECK(photo != nullptr); - return td_api::make_object(std::move(photo)); + return td_api::make_object(std::move(photo)); } case Type::Video: - return td_api::make_object( - td->videos_manager_->get_video_object(video_file_id_)); + return td_api::make_object(td->videos_manager_->get_video_object(video_file_id_)); default: UNREACHABLE(); return nullptr; diff --git a/td/telegram/MessageExtendedMedia.h b/td/telegram/MessageExtendedMedia.h index 41d9ccb5e..80ba060e6 100644 --- a/td/telegram/MessageExtendedMedia.h +++ b/td/telegram/MessageExtendedMedia.h @@ -57,7 +57,7 @@ class MessageExtendedMedia { MessageExtendedMedia(Td *td, telegram_api::object_ptr &&media, DialogId owner_dialog_id); static Result get_message_extended_media( - Td *td, td_api::object_ptr &&paid_media, DialogId owner_dialog_id); + Td *td, td_api::object_ptr &&paid_media, DialogId owner_dialog_id); bool is_empty() const { return type_ == Type::Empty; @@ -72,7 +72,7 @@ class MessageExtendedMedia { bool update_to(Td *td, telegram_api::object_ptr extended_media_ptr, DialogId owner_dialog_id); - td_api::object_ptr get_message_extended_media_object(Td *td) const; + td_api::object_ptr get_message_extended_media_object(Td *td) const; void append_file_ids(const Td *td, vector &file_ids) const; diff --git a/td/telegram/cli.cpp b/td/telegram/cli.cpp index 025ae69df..4d8893cd5 100644 --- a/td/telegram/cli.cpp +++ b/td/telegram/cli.cpp @@ -4971,9 +4971,8 @@ class CliClient final : public Actor { ChatId chat_id; get_args(args, chat_id, args); auto paid_media = transform(full_split(args), [this](const string &photo) { - return td_api::make_object( - td_api::make_object(), as_input_file(photo), nullptr, - vector(), 0, 0); + return td_api::make_object(td_api::make_object(), + as_input_file(photo), nullptr, vector(), 0, 0); }); send_message(chat_id, td_api::make_object(11, std::move(paid_media), as_caption("12_3_ __4__"), rand_bool())); @@ -4981,8 +4980,8 @@ class CliClient final : public Actor { ChatId chat_id; get_args(args, chat_id, args); auto paid_media = transform(full_split(args), [this](const string &video) { - return td_api::make_object( - td_api::make_object(10, true), as_input_file(video), nullptr, + return td_api::make_object( + td_api::make_object(10, true), as_input_file(video), nullptr, vector(), 0, 0); }); send_message(chat_id, td_api::make_object(12, std::move(paid_media),