Unlink webhook certificate in another thread.

This commit is contained in:
levlam 2022-07-01 13:58:28 +03:00
parent 0749acb7e6
commit ca2bb3cec6
2 changed files with 17 additions and 4 deletions

View File

@ -8550,14 +8550,25 @@ void Client::webhook_error(Status status) {
} }
void Client::webhook_closed(Status status) { void Client::webhook_closed(Status status) {
if (has_webhook_certificate_) {
td::Scheduler::instance()->run_on_scheduler(get_database_scheduler_id(),
[actor_id = actor_id(this), path = get_webhook_certificate_path(),
status = std::move(status)](td::Unit) mutable {
LOG(INFO) << "Unlink certificate " << path;
td::unlink(path).ignore();
send_closure(actor_id, &Client::on_webhook_closed, std::move(status));
});
return;
}
on_webhook_closed(std::move(status));
}
void Client::on_webhook_closed(Status status) {
LOG(WARNING) << "Webhook closed: " << status LOG(WARNING) << "Webhook closed: " << status
<< ", webhook_query_type = " << (webhook_query_type_ == WebhookQueryType::Verify ? "verify" : "change"); << ", webhook_query_type = " << (webhook_query_type_ == WebhookQueryType::Verify ? "verify" : "change");
webhook_id_.release(); webhook_id_.release();
webhook_url_ = td::string(); webhook_url_ = td::string();
if (has_webhook_certificate_) { has_webhook_certificate_ = false;
td::unlink(get_webhook_certificate_path()).ignore();
has_webhook_certificate_ = false;
}
webhook_max_connections_ = 0; webhook_max_connections_ = 0;
webhook_ip_address_ = td::string(); webhook_ip_address_ = td::string();
webhook_fix_ip_address_ = false; webhook_fix_ip_address_ = false;

View File

@ -563,6 +563,8 @@ class Client final : public WebhookActor::Callback {
void save_webhook() const; void save_webhook() const;
td::string get_webhook_certificate_path() const; td::string get_webhook_certificate_path() const;
void on_webhook_closed(Status status);
void do_send_message(object_ptr<td_api::InputMessageContent> input_message_content, PromisedQueryPtr query); void do_send_message(object_ptr<td_api::InputMessageContent> input_message_content, PromisedQueryPtr query);
int64 get_send_message_query_id(PromisedQueryPtr query, bool is_multisend); int64 get_send_message_query_id(PromisedQueryPtr query, bool is_multisend);