mirror of
https://github.com/tdlight-team/tdlight-telegram-bot-api.git
synced 2025-01-14 05:47:32 +01:00
Add "business_message" and "edited_business_message" updates.
This commit is contained in:
parent
b9d4d57678
commit
c783b1c821
@ -4513,11 +4513,13 @@ class Client::TdOnGetCallbackQueryMessageCallback final : public TdQueryCallback
|
|||||||
|
|
||||||
class Client::TdOnGetStickerSetCallback final : public TdQueryCallback {
|
class Client::TdOnGetStickerSetCallback final : public TdQueryCallback {
|
||||||
public:
|
public:
|
||||||
TdOnGetStickerSetCallback(Client *client, int64 set_id, int64 new_callback_query_user_id, int64 new_message_chat_id)
|
TdOnGetStickerSetCallback(Client *client, int64 set_id, int64 new_callback_query_user_id, int64 new_message_chat_id,
|
||||||
|
const td::string &new_message_business_connection_id)
|
||||||
: client_(client)
|
: client_(client)
|
||||||
, set_id_(set_id)
|
, set_id_(set_id)
|
||||||
, new_callback_query_user_id_(new_callback_query_user_id)
|
, new_callback_query_user_id_(new_callback_query_user_id)
|
||||||
, new_message_chat_id_(new_message_chat_id) {
|
, new_message_chat_id_(new_message_chat_id)
|
||||||
|
, new_message_business_connection_id_(new_message_business_connection_id) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void on_result(object_ptr<td_api::Object> result) final {
|
void on_result(object_ptr<td_api::Object> result) final {
|
||||||
@ -4528,12 +4530,13 @@ class Client::TdOnGetStickerSetCallback final : public TdQueryCallback {
|
|||||||
<< new_callback_query_user_id_ << "/new message in chat " << new_message_chat_id_ << ": "
|
<< new_callback_query_user_id_ << "/new message in chat " << new_message_chat_id_ << ": "
|
||||||
<< td::oneline(to_string(error));
|
<< td::oneline(to_string(error));
|
||||||
}
|
}
|
||||||
return client_->on_get_sticker_set(set_id_, new_callback_query_user_id_, new_message_chat_id_, nullptr);
|
return client_->on_get_sticker_set(set_id_, new_callback_query_user_id_, new_message_chat_id_,
|
||||||
|
new_message_business_connection_id_, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(result->get_id() == td_api::stickerSet::ID);
|
CHECK(result->get_id() == td_api::stickerSet::ID);
|
||||||
client_->on_get_sticker_set(set_id_, new_callback_query_user_id_, new_message_chat_id_,
|
client_->on_get_sticker_set(set_id_, new_callback_query_user_id_, new_message_chat_id_,
|
||||||
move_object_as<td_api::stickerSet>(result));
|
new_message_business_connection_id_, move_object_as<td_api::stickerSet>(result));
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -4541,6 +4544,7 @@ class Client::TdOnGetStickerSetCallback final : public TdQueryCallback {
|
|||||||
int64 set_id_;
|
int64 set_id_;
|
||||||
int64 new_callback_query_user_id_;
|
int64 new_callback_query_user_id_;
|
||||||
int64 new_message_chat_id_;
|
int64 new_message_chat_id_;
|
||||||
|
td::string new_message_business_connection_id_;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Client::TdOnGetChatCustomEmojiStickerSetCallback final : public TdQueryCallback {
|
class Client::TdOnGetChatCustomEmojiStickerSetCallback final : public TdQueryCallback {
|
||||||
@ -5422,6 +5426,7 @@ void Client::on_get_callback_query_message(object_ptr<td_api::message> message,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Client::on_get_sticker_set(int64 set_id, int64 new_callback_query_user_id, int64 new_message_chat_id,
|
void Client::on_get_sticker_set(int64 set_id, int64 new_callback_query_user_id, int64 new_message_chat_id,
|
||||||
|
const td::string &new_message_business_connection_id,
|
||||||
object_ptr<td_api::stickerSet> sticker_set) {
|
object_ptr<td_api::stickerSet> sticker_set) {
|
||||||
if (new_callback_query_user_id != 0) {
|
if (new_callback_query_user_id != 0) {
|
||||||
auto &queue = new_callback_query_queues_[new_callback_query_user_id];
|
auto &queue = new_callback_query_queues_[new_callback_query_user_id];
|
||||||
@ -5437,6 +5442,13 @@ void Client::on_get_sticker_set(int64 set_id, int64 new_callback_query_user_id,
|
|||||||
|
|
||||||
CHECK(!queue.queue_.empty());
|
CHECK(!queue.queue_.empty());
|
||||||
}
|
}
|
||||||
|
if (!new_message_business_connection_id.empty()) {
|
||||||
|
auto &queue = new_business_message_queues_[new_message_business_connection_id];
|
||||||
|
CHECK(queue.has_active_request_);
|
||||||
|
queue.has_active_request_ = false;
|
||||||
|
|
||||||
|
CHECK(!queue.queue_.empty());
|
||||||
|
}
|
||||||
|
|
||||||
CHECK(set_id != 0);
|
CHECK(set_id != 0);
|
||||||
if (set_id != GREAT_MINDS_SET_ID) {
|
if (set_id != GREAT_MINDS_SET_ID) {
|
||||||
@ -5452,6 +5464,9 @@ void Client::on_get_sticker_set(int64 set_id, int64 new_callback_query_user_id,
|
|||||||
if (new_message_chat_id != 0) {
|
if (new_message_chat_id != 0) {
|
||||||
process_new_message_queue(new_message_chat_id, 2);
|
process_new_message_queue(new_message_chat_id, 2);
|
||||||
}
|
}
|
||||||
|
if (!new_message_business_connection_id.empty()) {
|
||||||
|
process_new_business_message_queue(new_message_business_connection_id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Client::on_get_sticker_set_name(int64 set_id, const td::string &name) {
|
void Client::on_get_sticker_set_name(int64 set_id, const td::string &name) {
|
||||||
@ -6459,6 +6474,12 @@ void Client::on_update(object_ptr<td_api::Object> result) {
|
|||||||
case td_api::updateBusinessConnection::ID:
|
case td_api::updateBusinessConnection::ID:
|
||||||
add_update_business_connection(move_object_as<td_api::updateBusinessConnection>(result));
|
add_update_business_connection(move_object_as<td_api::updateBusinessConnection>(result));
|
||||||
break;
|
break;
|
||||||
|
case td_api::updateNewBusinessMessage::ID:
|
||||||
|
add_new_business_message(move_object_as<td_api::updateNewBusinessMessage>(result));
|
||||||
|
break;
|
||||||
|
case td_api::updateBusinessMessageEdited::ID:
|
||||||
|
add_business_message_edited(move_object_as<td_api::updateBusinessMessageEdited>(result));
|
||||||
|
break;
|
||||||
case td_api::updateConnectionState::ID: {
|
case td_api::updateConnectionState::ID: {
|
||||||
auto update = move_object_as<td_api::updateConnectionState>(result);
|
auto update = move_object_as<td_api::updateConnectionState>(result);
|
||||||
if (update->state_->get_id() == td_api::connectionStateReady::ID) {
|
if (update->state_->get_id() == td_api::connectionStateReady::ID) {
|
||||||
@ -12185,6 +12206,10 @@ td::Slice Client::get_update_type_name(UpdateType update_type) {
|
|||||||
return td::Slice("message_reaction_count");
|
return td::Slice("message_reaction_count");
|
||||||
case UpdateType::BusinessConnection:
|
case UpdateType::BusinessConnection:
|
||||||
return td::Slice("business_connection");
|
return td::Slice("business_connection");
|
||||||
|
case UpdateType::BusinessMessage:
|
||||||
|
return td::Slice("business_message");
|
||||||
|
case UpdateType::EditedBusinessMessage:
|
||||||
|
return td::Slice("edited_business_message");
|
||||||
default:
|
default:
|
||||||
UNREACHABLE();
|
UNREACHABLE();
|
||||||
return td::Slice();
|
return td::Slice();
|
||||||
@ -12400,8 +12425,9 @@ void Client::process_new_callback_query_queue(int64 user_id, int state) {
|
|||||||
auto message_sticker_set_id = message_info == nullptr ? 0 : get_sticker_set_id(message_info->content);
|
auto message_sticker_set_id = message_info == nullptr ? 0 : get_sticker_set_id(message_info->content);
|
||||||
if (!have_sticker_set_name(message_sticker_set_id)) {
|
if (!have_sticker_set_name(message_sticker_set_id)) {
|
||||||
queue.has_active_request_ = true;
|
queue.has_active_request_ = true;
|
||||||
return send_request(make_object<td_api::getStickerSet>(message_sticker_set_id),
|
return send_request(
|
||||||
td::make_unique<TdOnGetStickerSetCallback>(this, message_sticker_set_id, user_id, 0));
|
make_object<td_api::getStickerSet>(message_sticker_set_id),
|
||||||
|
td::make_unique<TdOnGetStickerSetCallback>(this, message_sticker_set_id, user_id, 0, td::string()));
|
||||||
}
|
}
|
||||||
auto reply_to_message_id = get_same_chat_reply_to_message_id(message_info);
|
auto reply_to_message_id = get_same_chat_reply_to_message_id(message_info);
|
||||||
if (reply_to_message_id > 0) {
|
if (reply_to_message_id > 0) {
|
||||||
@ -12410,8 +12436,9 @@ void Client::process_new_callback_query_queue(int64 user_id, int state) {
|
|||||||
reply_to_message_info == nullptr ? 0 : get_sticker_set_id(reply_to_message_info->content);
|
reply_to_message_info == nullptr ? 0 : get_sticker_set_id(reply_to_message_info->content);
|
||||||
if (!have_sticker_set_name(reply_sticker_set_id)) {
|
if (!have_sticker_set_name(reply_sticker_set_id)) {
|
||||||
queue.has_active_request_ = true;
|
queue.has_active_request_ = true;
|
||||||
return send_request(make_object<td_api::getStickerSet>(reply_sticker_set_id),
|
return send_request(
|
||||||
td::make_unique<TdOnGetStickerSetCallback>(this, reply_sticker_set_id, user_id, 0));
|
make_object<td_api::getStickerSet>(reply_sticker_set_id),
|
||||||
|
td::make_unique<TdOnGetStickerSetCallback>(this, reply_sticker_set_id, user_id, 0, td::string()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -12548,6 +12575,20 @@ void Client::add_update_business_connection(object_ptr<td_api::updateBusinessCon
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Client::add_new_business_message(object_ptr<td_api::updateNewBusinessMessage> &&update) {
|
||||||
|
CHECK(update != nullptr);
|
||||||
|
CHECK(!update->connection_id_.empty());
|
||||||
|
new_business_message_queues_[update->connection_id_].queue_.emplace(std::move(update->message_), false);
|
||||||
|
process_new_business_message_queue(update->connection_id_);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Client::add_business_message_edited(object_ptr<td_api::updateBusinessMessageEdited> &&update) {
|
||||||
|
CHECK(update != nullptr);
|
||||||
|
CHECK(!update->connection_id_.empty());
|
||||||
|
new_business_message_queues_[update->connection_id_].queue_.emplace(std::move(update->message_), true);
|
||||||
|
process_new_business_message_queue(update->connection_id_);
|
||||||
|
}
|
||||||
|
|
||||||
td::int64 Client::choose_added_member_id(const td_api::messageChatAddMembers *message_add_members) const {
|
td::int64 Client::choose_added_member_id(const td_api::messageChatAddMembers *message_add_members) const {
|
||||||
CHECK(message_add_members != nullptr);
|
CHECK(message_add_members != nullptr);
|
||||||
for (auto &member_user_id : message_add_members->member_user_ids_) {
|
for (auto &member_user_id : message_add_members->member_user_ids_) {
|
||||||
@ -12780,6 +12821,7 @@ td::int64 Client::get_same_chat_reply_to_message_id(const MessageInfo *message_i
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Client::drop_internal_reply_to_message_in_another_chat(object_ptr<td_api::message> &message) {
|
void Client::drop_internal_reply_to_message_in_another_chat(object_ptr<td_api::message> &message) {
|
||||||
|
CHECK(message != nullptr);
|
||||||
if (message->reply_to_ != nullptr && message->reply_to_->get_id() == td_api::messageReplyToMessage::ID) {
|
if (message->reply_to_ != nullptr && message->reply_to_->get_id() == td_api::messageReplyToMessage::ID) {
|
||||||
auto *reply_to = static_cast<td_api::messageReplyToMessage *>(message->reply_to_.get());
|
auto *reply_to = static_cast<td_api::messageReplyToMessage *>(message->reply_to_.get());
|
||||||
auto reply_in_chat_id = reply_to->chat_id_;
|
auto reply_in_chat_id = reply_to->chat_id_;
|
||||||
@ -12969,8 +13011,9 @@ void Client::process_new_message_queue(int64 chat_id, int state) {
|
|||||||
auto message_sticker_set_id = get_sticker_set_id(message_ref->content_);
|
auto message_sticker_set_id = get_sticker_set_id(message_ref->content_);
|
||||||
if (!have_sticker_set_name(message_sticker_set_id)) {
|
if (!have_sticker_set_name(message_sticker_set_id)) {
|
||||||
queue.has_active_request_ = true;
|
queue.has_active_request_ = true;
|
||||||
return send_request(make_object<td_api::getStickerSet>(message_sticker_set_id),
|
return send_request(
|
||||||
td::make_unique<TdOnGetStickerSetCallback>(this, message_sticker_set_id, 0, chat_id));
|
make_object<td_api::getStickerSet>(message_sticker_set_id),
|
||||||
|
td::make_unique<TdOnGetStickerSetCallback>(this, message_sticker_set_id, 0, chat_id, td::string()));
|
||||||
}
|
}
|
||||||
if (reply_to_message_id > 0) {
|
if (reply_to_message_id > 0) {
|
||||||
auto reply_to_message_info = get_message(chat_id, reply_to_message_id, true);
|
auto reply_to_message_info = get_message(chat_id, reply_to_message_id, true);
|
||||||
@ -12978,8 +13021,9 @@ void Client::process_new_message_queue(int64 chat_id, int state) {
|
|||||||
auto reply_sticker_set_id = get_sticker_set_id(reply_to_message_info->content);
|
auto reply_sticker_set_id = get_sticker_set_id(reply_to_message_info->content);
|
||||||
if (!have_sticker_set_name(reply_sticker_set_id)) {
|
if (!have_sticker_set_name(reply_sticker_set_id)) {
|
||||||
queue.has_active_request_ = true;
|
queue.has_active_request_ = true;
|
||||||
return send_request(make_object<td_api::getStickerSet>(reply_sticker_set_id),
|
return send_request(
|
||||||
td::make_unique<TdOnGetStickerSetCallback>(this, reply_sticker_set_id, 0, chat_id));
|
make_object<td_api::getStickerSet>(reply_sticker_set_id),
|
||||||
|
td::make_unique<TdOnGetStickerSetCallback>(this, reply_sticker_set_id, 0, chat_id, td::string()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -13050,6 +13094,57 @@ void Client::process_new_message_queue(int64 chat_id, int state) {
|
|||||||
new_message_queues_.erase(chat_id);
|
new_message_queues_.erase(chat_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Client::process_new_business_message_queue(const td::string &connection_id) {
|
||||||
|
auto &queue = new_business_message_queues_[connection_id];
|
||||||
|
if (queue.has_active_request_) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (logging_out_ || closing_) {
|
||||||
|
new_business_message_queues_.erase(connection_id);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
while (!queue.queue_.empty()) {
|
||||||
|
auto &message_ref = queue.queue_.front().message_;
|
||||||
|
|
||||||
|
drop_internal_reply_to_message_in_another_chat(message_ref->message_);
|
||||||
|
|
||||||
|
auto message_sticker_set_id = get_sticker_set_id(message_ref->message_->content_);
|
||||||
|
if (!have_sticker_set_name(message_sticker_set_id)) {
|
||||||
|
queue.has_active_request_ = true;
|
||||||
|
return send_request(
|
||||||
|
make_object<td_api::getStickerSet>(message_sticker_set_id),
|
||||||
|
td::make_unique<TdOnGetStickerSetCallback>(this, message_sticker_set_id, 0, 0, connection_id));
|
||||||
|
}
|
||||||
|
if (message_ref->reply_to_message_ != nullptr) {
|
||||||
|
drop_internal_reply_to_message_in_another_chat(message_ref->reply_to_message_);
|
||||||
|
auto reply_sticker_set_id = get_sticker_set_id(message_ref->reply_to_message_->content_);
|
||||||
|
if (!have_sticker_set_name(reply_sticker_set_id)) {
|
||||||
|
queue.has_active_request_ = true;
|
||||||
|
return send_request(
|
||||||
|
make_object<td_api::getStickerSet>(reply_sticker_set_id),
|
||||||
|
td::make_unique<TdOnGetStickerSetCallback>(this, reply_sticker_set_id, 0, 0, connection_id));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
auto message = std::move(message_ref);
|
||||||
|
auto is_edited = queue.queue_.front().is_edited_;
|
||||||
|
queue.queue_.pop();
|
||||||
|
if (need_skip_update_message(0, message->message_, is_edited)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto message_date = message->message_->edit_date_ == 0 ? message->message_->date_ : message->message_->edit_date_;
|
||||||
|
auto now = get_unix_time();
|
||||||
|
auto left_time = message_date + 86400 - now;
|
||||||
|
auto webhook_queue_id = message->message_->chat_id_ + (static_cast<int64>(11) << 33);
|
||||||
|
auto update_type = is_edited ? UpdateType::EditedBusinessMessage : UpdateType::BusinessMessage;
|
||||||
|
auto message_info = create_business_message(connection_id, std::move(message));
|
||||||
|
add_update(update_type, JsonMessage(message_info.get(), true, get_update_type_name(update_type).str(), this),
|
||||||
|
left_time, webhook_queue_id);
|
||||||
|
}
|
||||||
|
new_business_message_queues_.erase(connection_id);
|
||||||
|
}
|
||||||
|
|
||||||
td::unique_ptr<Client::MessageInfo> Client::delete_message(int64 chat_id, int64 message_id, bool only_from_cache) {
|
td::unique_ptr<Client::MessageInfo> Client::delete_message(int64 chat_id, int64 message_id, bool only_from_cache) {
|
||||||
auto message_info = std::move(messages_[{chat_id, message_id}]);
|
auto message_info = std::move(messages_[{chat_id, message_id}]);
|
||||||
if (message_info == nullptr) {
|
if (message_info == nullptr) {
|
||||||
@ -13179,7 +13274,7 @@ void Client::init_message(MessageInfo *message_info, object_ptr<td_api::message>
|
|||||||
auto sticker_set_id = get_sticker_set_id(message_info->content);
|
auto sticker_set_id = get_sticker_set_id(message_info->content);
|
||||||
if (!have_sticker_set_name(sticker_set_id)) {
|
if (!have_sticker_set_name(sticker_set_id)) {
|
||||||
send_request(make_object<td_api::getStickerSet>(sticker_set_id),
|
send_request(make_object<td_api::getStickerSet>(sticker_set_id),
|
||||||
td::make_unique<TdOnGetStickerSetCallback>(this, sticker_set_id, 0, 0));
|
td::make_unique<TdOnGetStickerSetCallback>(this, sticker_set_id, 0, 0, td::string()));
|
||||||
}
|
}
|
||||||
} else if (message->content_->get_id() == td_api::messagePoll::ID) {
|
} else if (message->content_->get_id() == td_api::messagePoll::ID) {
|
||||||
message_info->content = std::move(message->content_);
|
message_info->content = std::move(message->content_);
|
||||||
|
@ -245,6 +245,7 @@ class Client final : public WebhookActor::Callback {
|
|||||||
void on_get_callback_query_message(object_ptr<td_api::message> message, int64 user_id, int state);
|
void on_get_callback_query_message(object_ptr<td_api::message> message, int64 user_id, int state);
|
||||||
|
|
||||||
void on_get_sticker_set(int64 set_id, int64 new_callback_query_user_id, int64 new_message_chat_id,
|
void on_get_sticker_set(int64 set_id, int64 new_callback_query_user_id, int64 new_message_chat_id,
|
||||||
|
const td::string &new_message_business_connection_id,
|
||||||
object_ptr<td_api::stickerSet> sticker_set);
|
object_ptr<td_api::stickerSet> sticker_set);
|
||||||
|
|
||||||
void on_get_sticker_set_name(int64 set_id, const td::string &name);
|
void on_get_sticker_set_name(int64 set_id, const td::string &name);
|
||||||
@ -968,6 +969,12 @@ class Client final : public WebhookActor::Callback {
|
|||||||
|
|
||||||
void process_new_message_queue(int64 chat_id, int state);
|
void process_new_message_queue(int64 chat_id, int state);
|
||||||
|
|
||||||
|
void add_new_business_message(object_ptr<td_api::updateNewBusinessMessage> &&update);
|
||||||
|
|
||||||
|
void add_business_message_edited(object_ptr<td_api::updateBusinessMessageEdited> &&update);
|
||||||
|
|
||||||
|
void process_new_business_message_queue(const td::string &connection_id);
|
||||||
|
|
||||||
struct FullMessageId {
|
struct FullMessageId {
|
||||||
int64 chat_id;
|
int64 chat_id;
|
||||||
int64 message_id;
|
int64 message_id;
|
||||||
@ -1073,6 +1080,8 @@ class Client final : public WebhookActor::Callback {
|
|||||||
MessageReaction,
|
MessageReaction,
|
||||||
MessageReactionCount,
|
MessageReactionCount,
|
||||||
BusinessConnection,
|
BusinessConnection,
|
||||||
|
BusinessMessage,
|
||||||
|
EditedBusinessMessage,
|
||||||
Size
|
Size
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1180,6 +1189,20 @@ class Client final : public WebhookActor::Callback {
|
|||||||
};
|
};
|
||||||
td::FlatHashMap<int64, NewMessageQueue> new_message_queues_; // chat_id -> queue
|
td::FlatHashMap<int64, NewMessageQueue> new_message_queues_; // chat_id -> queue
|
||||||
|
|
||||||
|
struct NewBusinessMessage {
|
||||||
|
object_ptr<td_api::businessMessage> message_;
|
||||||
|
bool is_edited_ = false;
|
||||||
|
|
||||||
|
NewBusinessMessage(object_ptr<td_api::businessMessage> &&message, bool is_edited)
|
||||||
|
: message_(std::move(message)), is_edited_(is_edited) {
|
||||||
|
}
|
||||||
|
};
|
||||||
|
struct NewBusinessMessageQueue {
|
||||||
|
std::queue<NewBusinessMessage> queue_;
|
||||||
|
bool has_active_request_ = false;
|
||||||
|
};
|
||||||
|
td::FlatHashMap<td::string, NewBusinessMessageQueue> new_business_message_queues_; // connection_id -> queue
|
||||||
|
|
||||||
struct NewCallbackQueryQueue {
|
struct NewCallbackQueryQueue {
|
||||||
std::queue<object_ptr<td_api::updateNewCallbackQuery>> queue_;
|
std::queue<object_ptr<td_api::updateNewCallbackQuery>> queue_;
|
||||||
bool has_active_request_ = false;
|
bool has_active_request_ = false;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user