mirror of
https://github.com/PaiGramTeam/telegram-bot-api.git
synced 2024-11-23 07:50:54 +00:00
Add "last_synchronization_error_date" to getWebhookInfo.
This commit is contained in:
parent
b4f0ebbaab
commit
afaa577b1a
@ -2499,6 +2499,9 @@ class Client::JsonWebhookInfo final : public Jsonable {
|
|||||||
if (client_->allowed_update_types_ != DEFAULT_ALLOWED_UPDATE_TYPES) {
|
if (client_->allowed_update_types_ != DEFAULT_ALLOWED_UPDATE_TYPES) {
|
||||||
object("allowed_updates", JsonUpdateTypes(client_->allowed_update_types_));
|
object("allowed_updates", JsonUpdateTypes(client_->allowed_update_types_));
|
||||||
}
|
}
|
||||||
|
if (client_->last_synchronization_error_date_ > 0) {
|
||||||
|
object("last_synchronization_error_date", client_->last_synchronization_error_date_);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -3515,6 +3518,18 @@ std::size_t Client::get_pending_update_count() const {
|
|||||||
return parameters_->shared_data_->tqueue_->get_size(tqueue_id_);
|
return parameters_->shared_data_->tqueue_->get_size(tqueue_id_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Client::update_last_synchronization_error_date() {
|
||||||
|
if (disconnection_time_ == 0 || !was_authorized_ || logging_out_ || closing_) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
auto now = td::Time::now();
|
||||||
|
if (last_update_creation_time_ > now - 10 || disconnection_time_ > now - 180) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
last_synchronization_error_date_ = get_unix_time();
|
||||||
|
}
|
||||||
|
|
||||||
ServerBotInfo Client::get_bot_info() const {
|
ServerBotInfo Client::get_bot_info() const {
|
||||||
ServerBotInfo res;
|
ServerBotInfo res;
|
||||||
res.id_ = bot_token_id_;
|
res.id_ = bot_token_id_;
|
||||||
@ -4227,12 +4242,14 @@ void Client::on_update_authorization_state() {
|
|||||||
}
|
}
|
||||||
td::reset_to_empty(pending_updates_);
|
td::reset_to_empty(pending_updates_);
|
||||||
}
|
}
|
||||||
|
last_update_creation_time_ = td::Time::now();
|
||||||
}
|
}
|
||||||
return loop();
|
return loop();
|
||||||
}
|
}
|
||||||
case td_api::authorizationStateLoggingOut::ID:
|
case td_api::authorizationStateLoggingOut::ID:
|
||||||
if (!logging_out_) {
|
if (!logging_out_) {
|
||||||
LOG(WARNING) << "Logging out";
|
LOG(WARNING) << "Logging out";
|
||||||
|
update_last_synchronization_error_date();
|
||||||
logging_out_ = true;
|
logging_out_ = true;
|
||||||
if (was_authorized_ && !closing_) {
|
if (was_authorized_ && !closing_) {
|
||||||
td::send_event(parent_, td::Event::raw(nullptr));
|
td::send_event(parent_, td::Event::raw(nullptr));
|
||||||
@ -4242,6 +4259,7 @@ void Client::on_update_authorization_state() {
|
|||||||
case td_api::authorizationStateClosing::ID:
|
case td_api::authorizationStateClosing::ID:
|
||||||
if (!closing_) {
|
if (!closing_) {
|
||||||
LOG(WARNING) << "Closing";
|
LOG(WARNING) << "Closing";
|
||||||
|
update_last_synchronization_error_date();
|
||||||
closing_ = true;
|
closing_ = true;
|
||||||
if (was_authorized_ && !logging_out_) {
|
if (was_authorized_ && !logging_out_) {
|
||||||
td::send_event(parent_, td::Event::raw(nullptr));
|
td::send_event(parent_, td::Event::raw(nullptr));
|
||||||
@ -4568,6 +4586,16 @@ void Client::on_update(object_ptr<td_api::Object> result) {
|
|||||||
case td_api::updateNewChatJoinRequest::ID:
|
case td_api::updateNewChatJoinRequest::ID:
|
||||||
add_update_chat_join_request(move_object_as<td_api::updateNewChatJoinRequest>(result));
|
add_update_chat_join_request(move_object_as<td_api::updateNewChatJoinRequest>(result));
|
||||||
break;
|
break;
|
||||||
|
case td_api::updateConnectionState::ID: {
|
||||||
|
auto update = move_object_as<td_api::updateConnectionState>(result);
|
||||||
|
if (update->state_->get_id() == td_api::connectionStateReady::ID) {
|
||||||
|
update_last_synchronization_error_date();
|
||||||
|
disconnection_time_ = 0;
|
||||||
|
} else if (disconnection_time_ == 0) {
|
||||||
|
disconnection_time_ = td::Time::now();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
// we are not interested in this update
|
// we are not interested in this update
|
||||||
break;
|
break;
|
||||||
@ -8028,6 +8056,7 @@ td::Status Client::process_set_webhook_query(PromisedQueryPtr &query) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
td::Status Client::process_get_webhook_info_query(PromisedQueryPtr &query) {
|
td::Status Client::process_get_webhook_info_query(PromisedQueryPtr &query) {
|
||||||
|
update_last_synchronization_error_date();
|
||||||
answer_query(JsonWebhookInfo(this), std::move(query));
|
answer_query(JsonWebhookInfo(this), std::move(query));
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
@ -8910,6 +8939,9 @@ void Client::add_update(UpdateType update_type, const T &update, int32 timeout,
|
|||||||
|
|
||||||
void Client::add_update_impl(UpdateType update_type, const td::VirtuallyJsonable &update, int32 timeout,
|
void Client::add_update_impl(UpdateType update_type, const td::VirtuallyJsonable &update, int32 timeout,
|
||||||
int64 webhook_queue_id) {
|
int64 webhook_queue_id) {
|
||||||
|
update_last_synchronization_error_date();
|
||||||
|
last_update_creation_time_ = td::Time::now();
|
||||||
|
|
||||||
if (((allowed_update_types_ >> static_cast<int32>(update_type)) & 1) == 0) {
|
if (((allowed_update_types_ >> static_cast<int32>(update_type)) & 1) == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -832,6 +832,8 @@ class Client final : public WebhookActor::Callback {
|
|||||||
|
|
||||||
std::size_t get_pending_update_count() const;
|
std::size_t get_pending_update_count() const;
|
||||||
|
|
||||||
|
void update_last_synchronization_error_date();
|
||||||
|
|
||||||
static bool is_chat_member(const object_ptr<td_api::ChatMemberStatus> &status);
|
static bool is_chat_member(const object_ptr<td_api::ChatMemberStatus> &status);
|
||||||
|
|
||||||
static td::string get_chat_member_status(const object_ptr<td_api::ChatMemberStatus> &status);
|
static td::string get_chat_member_status(const object_ptr<td_api::ChatMemberStatus> &status);
|
||||||
@ -983,6 +985,10 @@ class Client final : public WebhookActor::Callback {
|
|||||||
|
|
||||||
double local_unix_time_difference_ = 0; // Unix time - now()
|
double local_unix_time_difference_ = 0; // Unix time - now()
|
||||||
|
|
||||||
|
double disconnection_time_ = 0; // the time when Connection state changed from "Ready", or 0 if it is "Ready"
|
||||||
|
double last_update_creation_time_ = 0; // the time when the last update was added
|
||||||
|
int32 last_synchronization_error_date_ = 0; // the date of the last connection error
|
||||||
|
|
||||||
int32 previous_get_updates_offset_ = -1;
|
int32 previous_get_updates_offset_ = -1;
|
||||||
double previous_get_updates_start_time_ = 0;
|
double previous_get_updates_start_time_ = 0;
|
||||||
double previous_get_updates_finish_time_ = 0;
|
double previous_get_updates_finish_time_ = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user