Update TDLib to 1.8.29.

This commit is contained in:
levlam 2024-05-04 00:21:18 +03:00
parent 8ced3a1e60
commit a5a1c509eb
4 changed files with 24 additions and 31 deletions

2
td

@ -1 +1 @@
Subproject commit 38d31da77a72619cf7ec5d479338a48274cc7446 Subproject commit af69dd4397b6dc1bf23ba0fd0bf429fcba6454f6

View File

@ -1634,7 +1634,7 @@ class Client::JsonPollOption final : public td::Jsonable {
} }
void store(td::JsonValueScope *scope) const { void store(td::JsonValueScope *scope) const {
auto object = scope->enter_object(); auto object = scope->enter_object();
object("text", option_->text_); object("text", option_->text_->text_);
object("voter_count", option_->voter_count_); object("voter_count", option_->voter_count_);
// ignore is_chosen // ignore is_chosen
} }
@ -1650,7 +1650,7 @@ class Client::JsonPoll final : public td::Jsonable {
void store(td::JsonValueScope *scope) const { void store(td::JsonValueScope *scope) const {
auto object = scope->enter_object(); auto object = scope->enter_object();
object("id", td::to_string(poll_->id_)); object("id", td::to_string(poll_->id_));
object("question", poll_->question_); object("question", poll_->question_->text_);
object("options", td::json_array(poll_->options_, [](auto &option) { return JsonPollOption(option.get()); })); object("options", td::json_array(poll_->options_, [](auto &option) { return JsonPollOption(option.get()); }));
object("total_voter_count", poll_->total_voter_count_); object("total_voter_count", poll_->total_voter_count_);
if (poll_->open_period_ != 0 && poll_->close_date_ != 0) { if (poll_->open_period_ != 0 && poll_->close_date_ != 0) {
@ -2395,7 +2395,7 @@ class Client::JsonGiveawayCompleted final : public td::Jsonable {
class Client::JsonChatBoostAdded final : public td::Jsonable { class Client::JsonChatBoostAdded final : public td::Jsonable {
public: public:
JsonChatBoostAdded(const td_api::messageChatBoost *chat_boost) : chat_boost_(chat_boost) { explicit JsonChatBoostAdded(const td_api::messageChatBoost *chat_boost) : chat_boost_(chat_boost) {
} }
void store(td::JsonValueScope *scope) const { void store(td::JsonValueScope *scope) const {
auto object = scope->enter_object(); auto object = scope->enter_object();
@ -3895,8 +3895,7 @@ class Client::JsonBusinessMessagesDeleted final : public td::Jsonable {
auto object = scope->enter_object(); auto object = scope->enter_object();
object("business_connection_id", update_->connection_id_); object("business_connection_id", update_->connection_id_);
object("chat", JsonChat(update_->chat_id_, client_)); object("chat", JsonChat(update_->chat_id_, client_));
object("message_ids", object("message_ids", td::json_array(update_->message_ids_, as_client_message_id));
td::json_array(update_->message_ids_, [](int64 message_id) { return as_client_message_id(message_id); }));
} }
private: private:
@ -6142,7 +6141,7 @@ void Client::check_reply_parameters(td::Slice chat_id_str, InputReplyParameters
} }
if (message_thread_id <= 0) { if (message_thread_id <= 0) {
// if message thread isn't specified, then the message to reply can be only from a different chat // if message thread isn't specified, then the message to be replied can be only from a different chat
if (reply_parameters.reply_in_chat_id == chat_id) { if (reply_parameters.reply_in_chat_id == chat_id) {
reply_parameters.reply_in_chat_id = 0; reply_parameters.reply_in_chat_id = 0;
} }
@ -6172,13 +6171,13 @@ void Client::check_reply_parameters(td::Slice chat_id_str, InputReplyParameters
on_success = std::move(on_reply_message_resolved)]( on_success = std::move(on_reply_message_resolved)](
int64 reply_in_chat_id, PromisedQueryPtr query) mutable { int64 reply_in_chat_id, PromisedQueryPtr query) mutable {
if (!have_message_access(reply_in_chat_id)) { if (!have_message_access(reply_in_chat_id)) {
return fail_query_with_error(std::move(query), 400, "MESSAGE_NOT_FOUND", "message to reply not found"); return fail_query_with_error(std::move(query), 400, "MESSAGE_NOT_FOUND", "message to be replied not found");
} }
send_request(make_object<td_api::getMessage>(reply_in_chat_id, reply_to_message_id), send_request(make_object<td_api::getMessage>(reply_in_chat_id, reply_to_message_id),
td::make_unique<TdOnCheckMessageCallback<decltype(on_success)>>( td::make_unique<TdOnCheckMessageCallback<decltype(on_success)>>(
this, reply_in_chat_id, reply_to_message_id, allow_sending_without_reply, "message to reply", this, reply_in_chat_id, reply_to_message_id, allow_sending_without_reply,
std::move(query), std::move(on_success))); "message to be replied", std::move(query), std::move(on_success)));
}; };
if (reply_parameters.reply_in_chat_id.empty()) { if (reply_parameters.reply_in_chat_id.empty()) {
return on_reply_chat_resolved(chat_id, std::move(query)); return on_reply_chat_resolved(chat_id, std::move(query));
@ -9249,7 +9248,7 @@ td::Result<td_api::object_ptr<td_api::inputMessageInvoice>> Client::get_input_me
provider_token.str(), provider_data.str(), start_parameter.str(), std::move(extended_media)); provider_token.str(), provider_data.str(), start_parameter.str(), std::move(extended_media));
} }
td::Result<td::vector<td::string>> Client::get_poll_options(const Query *query) { td::Result<td::vector<td_api::object_ptr<td_api::formattedText>>> Client::get_poll_options(const Query *query) {
auto input_options = query->arg("options"); auto input_options = query->arg("options");
LOG(INFO) << "Parsing JSON object: " << input_options; LOG(INFO) << "Parsing JSON object: " << input_options;
auto r_value = json_decode(input_options); auto r_value = json_decode(input_options);
@ -9263,12 +9262,12 @@ td::Result<td::vector<td::string>> Client::get_poll_options(const Query *query)
return td::Status::Error(400, "Expected an Array of String as options"); return td::Status::Error(400, "Expected an Array of String as options");
} }
td::vector<td::string> options; td::vector<object_ptr<td_api::formattedText>> options;
for (auto &input_option : value.get_array()) { for (auto &input_option : value.get_array()) {
if (input_option.type() != td::JsonValue::Type::String) { if (input_option.type() != td::JsonValue::Type::String) {
return td::Status::Error(400, "Expected an option to be of type String"); return td::Status::Error(400, "Expected an option to be of type String");
} }
options.push_back(input_option.get_string().str()); options.push_back(make_object<td_api::formattedText>(input_option.get_string().str(), td::Auto()));
} }
return std::move(options); return std::move(options);
} }
@ -9953,8 +9952,9 @@ td::Status Client::process_send_poll_query(PromisedQueryPtr &query) {
int32 open_period = get_integer_arg(query.get(), "open_period", 0, 0, 10 * 60); int32 open_period = get_integer_arg(query.get(), "open_period", 0, 0, 10 * 60);
int32 close_date = get_integer_arg(query.get(), "close_date", 0); int32 close_date = get_integer_arg(query.get(), "close_date", 0);
auto is_closed = to_bool(query->arg("is_closed")); auto is_closed = to_bool(query->arg("is_closed"));
do_send_message(make_object<td_api::inputMessagePoll>(question.str(), std::move(options), is_anonymous, do_send_message(make_object<td_api::inputMessagePoll>(make_object<td_api::formattedText>(question.str(), td::Auto()),
std::move(poll_type), open_period, close_date, is_closed), std::move(options), is_anonymous, std::move(poll_type),
open_period, close_date, is_closed),
std::move(query)); std::move(query));
return td::Status::OK(); return td::Status::OK();
} }
@ -10254,8 +10254,8 @@ td::Status Client::process_edit_message_live_location_query(PromisedQueryPtr &qu
[this, inline_message_id = inline_message_id.str(), location = std::move(location), heading, [this, inline_message_id = inline_message_id.str(), location = std::move(location), heading,
proximity_alert_radius](object_ptr<td_api::ReplyMarkup> reply_markup, PromisedQueryPtr query) mutable { proximity_alert_radius](object_ptr<td_api::ReplyMarkup> reply_markup, PromisedQueryPtr query) mutable {
send_request( send_request(
make_object<td_api::editInlineMessageLiveLocation>(inline_message_id, std::move(reply_markup), make_object<td_api::editInlineMessageLiveLocation>(
std::move(location), heading, proximity_alert_radius), inline_message_id, std::move(reply_markup), std::move(location), 0, heading, proximity_alert_radius),
td::make_unique<TdOnEditInlineMessageCallback>(std::move(query))); td::make_unique<TdOnEditInlineMessageCallback>(std::move(query)));
}); });
} else { } else {
@ -10268,8 +10268,8 @@ td::Status Client::process_edit_message_live_location_query(PromisedQueryPtr &qu
reply_markup = std::move(reply_markup)](int64 chat_id, int64 message_id, reply_markup = std::move(reply_markup)](int64 chat_id, int64 message_id,
PromisedQueryPtr query) mutable { PromisedQueryPtr query) mutable {
send_request(make_object<td_api::editMessageLiveLocation>( send_request(make_object<td_api::editMessageLiveLocation>(
chat_id, message_id, std::move(reply_markup), std::move(location), heading, chat_id, message_id, std::move(reply_markup), std::move(location), 0,
proximity_alert_radius), heading, proximity_alert_radius),
td::make_unique<TdOnEditMessageCallback>(this, std::move(query))); td::make_unique<TdOnEditMessageCallback>(this, std::move(query)));
}); });
}); });
@ -10956,7 +10956,7 @@ td::Status Client::process_get_chat_member_query(PromisedQueryPtr &query) {
auto chat_id = query->arg("chat_id"); auto chat_id = query->arg("chat_id");
TRY_RESULT(user_id, get_user_id(query.get())); TRY_RESULT(user_id, get_user_id(query.get()));
check_chat(chat_id, AccessRights::ReadMembers, std::move(query), check_chat(chat_id, user_id == my_id_ ? AccessRights::Read : AccessRights::ReadMembers, std::move(query),
[this, user_id](int64 chat_id, PromisedQueryPtr query) { [this, user_id](int64 chat_id, PromisedQueryPtr query) {
get_chat_member(chat_id, user_id, std::move(query), get_chat_member(chat_id, user_id, std::move(query),
[this, chat_type = get_chat_type(chat_id)](object_ptr<td_api::chatMember> &&chat_member, [this, chat_type = get_chat_type(chat_id)](object_ptr<td_api::chatMember> &&chat_member,
@ -12950,14 +12950,8 @@ void Client::add_update_message_reaction_count(object_ptr<td_api::updateMessageR
void Client::add_update_business_connection(object_ptr<td_api::updateBusinessConnection> &&update) { void Client::add_update_business_connection(object_ptr<td_api::updateBusinessConnection> &&update) {
CHECK(update != nullptr); CHECK(update != nullptr);
const auto *connection = add_business_connection(std::move(update->connection_), true); const auto *connection = add_business_connection(std::move(update->connection_), true);
auto left_time = connection->date_ + 86400 - get_unix_time();
if (left_time > 0) {
auto webhook_queue_id = connection->user_id_ + (static_cast<int64>(10) << 33); auto webhook_queue_id = connection->user_id_ + (static_cast<int64>(10) << 33);
add_update(UpdateType::BusinessConnection, JsonBusinessConnection(connection, this), left_time, webhook_queue_id); add_update(UpdateType::BusinessConnection, JsonBusinessConnection(connection, this), 86400, webhook_queue_id);
} else {
LOG(DEBUG) << "Skip updateBusinessConnection with date " << connection->date_ << ", because current date is "
<< get_unix_time();
}
} }
void Client::add_update_business_messages_deleted(object_ptr<td_api::updateBusinessMessagesDeleted> &&update) { void Client::add_update_business_messages_deleted(object_ptr<td_api::updateBusinessMessagesDeleted> &&update) {

View File

@ -563,7 +563,7 @@ class Client final : public WebhookActor::Callback {
static object_ptr<td_api::messageSendOptions> get_message_send_options(bool disable_notification, static object_ptr<td_api::messageSendOptions> get_message_send_options(bool disable_notification,
bool protect_content); bool protect_content);
static td::Result<td::vector<td::string>> get_poll_options(const Query *query); static td::Result<td::vector<object_ptr<td_api::formattedText>>> get_poll_options(const Query *query);
static td::Result<object_ptr<td_api::ReactionType>> get_reaction_type(td::JsonValue &&value); static td::Result<object_ptr<td_api::ReactionType>> get_reaction_type(td::JsonValue &&value);

View File

@ -590,8 +590,7 @@ void WebhookActor::send_updates() {
void WebhookActor::handle(td::unique_ptr<td::HttpQuery> response) { void WebhookActor::handle(td::unique_ptr<td::HttpQuery> response) {
SCOPE_EXIT { SCOPE_EXIT {
bool dummy = false; td::Scheduler::instance()->destroy_on_scheduler_unique_ptr(SharedData::get_file_gc_scheduler_id(), response);
td::Scheduler::instance()->destroy_on_scheduler(SharedData::get_file_gc_scheduler_id(), response, dummy);
}; };
auto connection_id = get_link_token(); auto connection_id = get_link_token();