From 6ab61f2fed3a46c69d29100a18831c34e7b28584 Mon Sep 17 00:00:00 2001 From: levlam Date: Thu, 25 Feb 2021 22:32:23 +0300 Subject: [PATCH] Add revokeChatInviteLink method. --- telegram-bot-api/Client.cpp | 36 +++++++++++++++++++++++++++--------- telegram-bot-api/Client.h | 1 + 2 files changed, 28 insertions(+), 9 deletions(-) diff --git a/telegram-bot-api/Client.cpp b/telegram-bot-api/Client.cpp index 0743b7a..5a0d210 100644 --- a/telegram-bot-api/Client.cpp +++ b/telegram-bot-api/Client.cpp @@ -214,6 +214,7 @@ bool Client::init_methods() { methods_.emplace("exportchatinvitelink", &Client::process_export_chat_invite_link_query); methods_.emplace("createchatinvitelink", &Client::process_create_chat_invite_link_query); methods_.emplace("editchatinvitelink", &Client::process_edit_chat_invite_link_query); + methods_.emplace("revokechatinvitelink", &Client::process_revoke_chat_invite_link_query); methods_.emplace("getchat", &Client::process_get_chat_query); methods_.emplace("setchatphoto", &Client::process_set_chat_photo_query); methods_.emplace("deletechatphoto", &Client::process_delete_chat_photo_query); @@ -3209,9 +3210,15 @@ class Client::TdOnGetChatInviteLinkCallback : public TdQueryCallback { return fail_query_with_error(std::move(query_), move_object_as(result)); } - CHECK(result->get_id() == td_api::chatInviteLink::ID); - auto invite_link = move_object_as(result); - return answer_query(JsonChatInviteLink(invite_link.get(), client_), std::move(query_)); + if (result->get_id() == td_api::chatInviteLink::ID) { + auto invite_link = move_object_as(result); + return answer_query(JsonChatInviteLink(invite_link.get(), client_), std::move(query_)); + } else { + CHECK(result->get_id() == td_api::chatInviteLinks::ID); + auto invite_links = move_object_as(result); + CHECK(!invite_links->invite_links_.empty()); + return answer_query(JsonChatInviteLink(invite_links->invite_links_[0].get(), client_), std::move(query_)); + } } private: @@ -6835,12 +6842,23 @@ td::Status Client::process_edit_chat_invite_link_query(PromisedQueryPtr &query) auto expire_date = get_integer_arg(query.get(), "expire_date", 0, 0); auto member_limit = get_integer_arg(query.get(), "member_limit", 0, 0, 100000); - check_chat( - chat_id, AccessRights::Write, std::move(query), - [this, invite_link = invite_link.str(), expire_date, member_limit](int64 chat_id, PromisedQueryPtr query) { - send_request(make_object(chat_id, invite_link, expire_date, member_limit), - std::make_unique(this, std::move(query))); - }); + check_chat(chat_id, AccessRights::Write, std::move(query), + [this, invite_link = invite_link.str(), expire_date, member_limit](int64 chat_id, PromisedQueryPtr query) { + send_request(make_object(chat_id, invite_link, expire_date, member_limit), + std::make_unique(this, std::move(query))); + }); + return Status::OK(); +} + +td::Status Client::process_revoke_chat_invite_link_query(PromisedQueryPtr &query) { + auto chat_id = query->arg("chat_id"); + auto invite_link = query->arg("invite_link"); + + check_chat(chat_id, AccessRights::Write, std::move(query), + [this, invite_link = invite_link.str()](int64 chat_id, PromisedQueryPtr query) { + send_request(make_object(chat_id, invite_link), + std::make_unique(this, std::move(query))); + }); return Status::OK(); } diff --git a/telegram-bot-api/Client.h b/telegram-bot-api/Client.h index 135bfd7..7025b42 100644 --- a/telegram-bot-api/Client.h +++ b/telegram-bot-api/Client.h @@ -447,6 +447,7 @@ class Client : public WebhookActor::Callback { Status process_export_chat_invite_link_query(PromisedQueryPtr &query); Status process_create_chat_invite_link_query(PromisedQueryPtr &query); Status process_edit_chat_invite_link_query(PromisedQueryPtr &query); + Status process_revoke_chat_invite_link_query(PromisedQueryPtr &query); Status process_get_chat_query(PromisedQueryPtr &query); Status process_set_chat_photo_query(PromisedQueryPtr &query); Status process_delete_chat_photo_query(PromisedQueryPtr &query);