mirror of
https://github.com/tdlight-team/tdlight-telegram-bot-api.git
synced 2024-11-26 22:16:51 +01:00
Add Message.paid_media and ExternalReplyInfo.paid_media.
This commit is contained in:
parent
3e1fee6d7a
commit
4fe3ba9c99
@ -1526,6 +1526,70 @@ class Client::JsonVoiceNote final : public td::Jsonable {
|
|||||||
const Client *client_;
|
const Client *client_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class Client::JsonPaidMedia final : public td::Jsonable {
|
||||||
|
public:
|
||||||
|
JsonPaidMedia(const td_api::PaidMedia *paid_media, const Client *client) : paid_media_(paid_media), client_(client) {
|
||||||
|
}
|
||||||
|
void store(td::JsonValueScope *scope) const {
|
||||||
|
auto object = scope->enter_object();
|
||||||
|
switch (paid_media_->get_id()) {
|
||||||
|
case td_api::paidMediaPreview::ID: {
|
||||||
|
auto media = static_cast<const td_api::paidMediaPreview *>(paid_media_);
|
||||||
|
object("type", "preview");
|
||||||
|
if (media->width_) {
|
||||||
|
object("width", media->width_);
|
||||||
|
}
|
||||||
|
if (media->height_) {
|
||||||
|
object("height", media->height_);
|
||||||
|
}
|
||||||
|
if (media->duration_) {
|
||||||
|
object("duration", media->duration_);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case td_api::paidMediaPhoto::ID: {
|
||||||
|
auto media = static_cast<const td_api::paidMediaPhoto *>(paid_media_);
|
||||||
|
object("type", "photo");
|
||||||
|
object("photo", JsonPhoto(media->photo_.get(), client_));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case td_api::paidMediaVideo::ID: {
|
||||||
|
auto media = static_cast<const td_api::paidMediaVideo *>(paid_media_);
|
||||||
|
object("type", "video");
|
||||||
|
object("video", JsonVideo(media->video_.get(), client_));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case td_api::paidMediaUnsupported::ID:
|
||||||
|
object("type", "other");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
UNREACHABLE();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
const td_api::PaidMedia *paid_media_;
|
||||||
|
const Client *client_;
|
||||||
|
};
|
||||||
|
|
||||||
|
class Client::JsonPaidMediaInfo final : public td::Jsonable {
|
||||||
|
public:
|
||||||
|
JsonPaidMediaInfo(const td_api::messagePaidMedia *paid_media, const Client *client)
|
||||||
|
: paid_media_(paid_media), client_(client) {
|
||||||
|
}
|
||||||
|
void store(td::JsonValueScope *scope) const {
|
||||||
|
auto object = scope->enter_object();
|
||||||
|
object("star_count", paid_media_->star_count_);
|
||||||
|
object("paid_media", td::json_array(paid_media_->media_, [client = client_](auto &media) {
|
||||||
|
return JsonPaidMedia(media.get(), client);
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
const td_api::messagePaidMedia *paid_media_;
|
||||||
|
const Client *client_;
|
||||||
|
};
|
||||||
|
|
||||||
class Client::JsonVenue final : public td::Jsonable {
|
class Client::JsonVenue final : public td::Jsonable {
|
||||||
public:
|
public:
|
||||||
explicit JsonVenue(const td_api::venue *venue) : venue_(venue) {
|
explicit JsonVenue(const td_api::venue *venue) : venue_(venue) {
|
||||||
@ -2593,6 +2657,11 @@ class Client::JsonExternalReplyInfo final : public td::Jsonable {
|
|||||||
object("document", JsonDocument(content->document_.get(), client_));
|
object("document", JsonDocument(content->document_.get(), client_));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case td_api::messagePaidMedia::ID: {
|
||||||
|
auto content = static_cast<const td_api::messagePaidMedia *>(reply_->content_.get());
|
||||||
|
object("paid_media", JsonPaidMediaInfo(content, client_));
|
||||||
|
break;
|
||||||
|
}
|
||||||
case td_api::messagePhoto::ID: {
|
case td_api::messagePhoto::ID: {
|
||||||
auto content = static_cast<const td_api::messagePhoto *>(reply_->content_.get());
|
auto content = static_cast<const td_api::messagePhoto *>(reply_->content_.get());
|
||||||
CHECK(content->photo_ != nullptr);
|
CHECK(content->photo_ != nullptr);
|
||||||
@ -2842,6 +2911,12 @@ void Client::JsonMessage::store(td::JsonValueScope *scope) const {
|
|||||||
add_caption(object, content->caption_, false);
|
add_caption(object, content->caption_, false);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case td_api::messagePaidMedia::ID: {
|
||||||
|
auto content = static_cast<const td_api::messagePaidMedia *>(message_->content.get());
|
||||||
|
object("paid_media", JsonPaidMediaInfo(content, client_));
|
||||||
|
add_caption(object, content->caption_, content->show_caption_above_media_);
|
||||||
|
break;
|
||||||
|
}
|
||||||
case td_api::messagePhoto::ID: {
|
case td_api::messagePhoto::ID: {
|
||||||
auto content = static_cast<const td_api::messagePhoto *>(message_->content.get());
|
auto content = static_cast<const td_api::messagePhoto *>(message_->content.get());
|
||||||
CHECK(content->photo_ != nullptr);
|
CHECK(content->photo_ != nullptr);
|
||||||
@ -3180,8 +3255,6 @@ void Client::JsonMessage::store(td::JsonValueScope *scope) const {
|
|||||||
object("boost_added", JsonChatBoostAdded(content));
|
object("boost_added", JsonChatBoostAdded(content));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case td_api::messagePaidMedia::ID:
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
UNREACHABLE();
|
UNREACHABLE();
|
||||||
}
|
}
|
||||||
@ -13632,8 +13705,6 @@ bool Client::need_skip_update_message(int64 chat_id, const object_ptr<td_api::me
|
|||||||
return true;
|
return true;
|
||||||
case td_api::messagePremiumGiftCode::ID:
|
case td_api::messagePremiumGiftCode::ID:
|
||||||
return true;
|
return true;
|
||||||
case td_api::messagePaidMedia::ID:
|
|
||||||
return true;
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -121,6 +121,8 @@ class Client final : public WebhookActor::Callback {
|
|||||||
class JsonVideo;
|
class JsonVideo;
|
||||||
class JsonVideoNote;
|
class JsonVideoNote;
|
||||||
class JsonVoiceNote;
|
class JsonVoiceNote;
|
||||||
|
class JsonPaidMedia;
|
||||||
|
class JsonPaidMediaInfo;
|
||||||
class JsonContact;
|
class JsonContact;
|
||||||
class JsonDice;
|
class JsonDice;
|
||||||
class JsonGame;
|
class JsonGame;
|
||||||
|
Loading…
Reference in New Issue
Block a user