From bfa7b0c67a3df3848eb7f9bccdf7c158ce4c9d07 Mon Sep 17 00:00:00 2001 From: llnulldisk <48621230+llnulldisk@users.noreply.github.com> Date: Sun, 4 Sep 2022 13:45:21 +0200 Subject: Update to API 5.1 --- README.md | 2 +- include/tgbot/Api.h | 93 +++++++++++--- include/tgbot/TgTypeParser.h | 23 ++++ include/tgbot/types/ChatInviteLink.h | 55 ++++++++ include/tgbot/types/ChatMember.h | 11 ++ include/tgbot/types/ChatMemberUpdated.h | 55 ++++++++ include/tgbot/types/Dice.h | 2 +- include/tgbot/types/Message.h | 54 ++++++-- .../tgbot/types/MessageAutoDeleteTimerChanged.h | 26 ++++ include/tgbot/types/Update.h | 15 ++- include/tgbot/types/VoiceChatEnded.h | 26 ++++ include/tgbot/types/VoiceChatParticipantsInvited.h | 28 +++++ include/tgbot/types/VoiceChatStarted.h | 21 ++++ src/Api.cpp | 108 ++++++++++++---- src/TgTypeParser.cpp | 140 ++++++++++++++++++++- 15 files changed, 606 insertions(+), 53 deletions(-) create mode 100644 include/tgbot/types/ChatInviteLink.h create mode 100644 include/tgbot/types/ChatMemberUpdated.h create mode 100644 include/tgbot/types/MessageAutoDeleteTimerChanged.h create mode 100644 include/tgbot/types/VoiceChatEnded.h create mode 100644 include/tgbot/types/VoiceChatParticipantsInvited.h create mode 100644 include/tgbot/types/VoiceChatStarted.h diff --git a/README.md b/README.md index 0b77f0b..f83854b 100644 --- a/README.md +++ b/README.md @@ -13,7 +13,7 @@ Documentation is located [here](http://reo7sp.github.io/tgbot-cpp). - [x] Bot API 3.0 ~ 3.6 - [x] Bot API 4.0 ~ 4.9 -- [x] Bot API 5.0 (Implemented all APIs except 'Run Your Own Bot API Server') +- [x] Bot API 5.0 ~ 5.1 (Implemented all APIs except 'Run Your Own Bot API Server') ## Sample diff --git a/include/tgbot/Api.h b/include/tgbot/Api.h index 2241e1d..cf4cd31 100644 --- a/include/tgbot/Api.h +++ b/include/tgbot/Api.h @@ -560,7 +560,7 @@ public: * @brief Use this method to send an animated emoji that will display a random value. * * @param chatId Unique identifier for the target chat or username of the target channel (in the format @channelusername) - * @param emoji Optional. Emoji on which the dice throw animation is based. Currently, must be one of β€œπŸŽ²β€, β€œπŸŽ―β€, β€œπŸ€β€, β€œβš½β€, or β€œπŸŽ°β€. Dice can have values 1-6 for β€œπŸŽ²β€ and β€œπŸŽ―β€, values 1-5 for β€œπŸ€β€ and β€œβš½β€, and values 1-64 for β€œπŸŽ°β€. Defaults to β€œπŸŽ²β€ + * @param emoji Optional. Emoji on which the dice throw animation is based. Currently, must be one of β€œπŸŽ²β€, β€œπŸŽ―β€, β€œπŸ€β€, β€œβš½β€, β€œπŸŽ³β€, or β€œπŸŽ°β€. Dice can have values 1-6 for β€œπŸŽ²β€, β€œπŸŽ―β€ and β€œπŸŽ³β€, values 1-5 for β€œπŸ€β€ and β€œβš½β€, and values 1-64 for β€œπŸŽ°β€. Defaults to β€œπŸŽ²β€ * @param disableNotification Optional. Sends the message silently. Users will receive a notification with no sound. * @param replyToMessageId Optional. If the message is a reply, ID of the original message * @param allowSendingWithoutReply Optional. Pass True, if the message should be sent even if the specified replied-to message is not found @@ -611,13 +611,21 @@ public: std::string downloadFile(const std::string& filePath, const std::vector& args = std::vector()) const; /** - * @brief Use this method to kick a user from a group or a supergroup. - * @param chatId Unique identifier for the target group. - * @param userId Unique identifier of the target user. - * @param untilDate Optional. Date when the user will be unbanned, unix time. If user is banned for more than 366 days or less than 30 seconds from the current time they are considered to be banned forever. - * @return True on success + * @brief Use this method to kick a user from a group, a supergroup or a channel. + * In the case of supergroups and channels, the user will not be able to return to the chat on their own using invite links, etc., unless unbanned first. + * The bot must be an administrator in the chat for this to work and must have the appropriate admin rights. + * + * @param chatId Unique identifier for the target group or username of the target supergroup or channel (in the format @channelusername) + * @param userId Unique identifier of the target user + * @param untilDate Optional. Date when the user will be unbanned, unix time. If user is banned for more than 366 days or less than 30 seconds from the current time they are considered to be banned forever. Applied for supergroups and channels only. + * @param revokeMessages Optional. Pass True to delete all messages from the chat for the user that is being removed. If False, the user will be able to see messages in the group that were sent before the user was removed. Always True for supergroups and channels. + * + * @return True on success. */ - bool kickChatMember(std::int64_t chatId, std::int64_t userId, std::uint64_t untilDate = 0) const; + bool kickChatMember(std::int64_t chatId, + std::int64_t userId, + std::uint64_t untilDate = 0, + bool revokeMessages = true) const; /** * @brief Use this method to unban a previously kicked user in a supergroup or channel. @@ -657,21 +665,32 @@ public: * @param chatId Unique identifier for the target chat or username of the target channel (in the format @channelusername) * @param userId Unique identifier of the target user * @param isAnonymous Optional. Pass True, if the administrator's presence in the chat is hidden - * @param canChangeInfo Optional. Pass True, if the administrator can change chat title, photo and other settings + * @param canManageChat Optional. Pass True, if the administrator can access the chat event log, chat statistics, message statistics in channels, see channel members, see anonymous administrators in supergroups and ignore slow mode. Implied by any other administrator privilege * @param canPostMessages Optional. Pass True, if the administrator can create channel posts, channels only - * @param canEditMessages Optional. Pass True, if the administrator can edit messages of other users and can pin messages, channels only + * @param canEditMessages Optional. Pass True, if the administrator can edit messages of other users and can pin messages, channels only * @param canDeleteMessages Optional. Pass True, if the administrator can delete messages of other users - * @param canInviteUsers Optional. Pass True, if the administrator can invite new users to the chat + * @param canManageVoiceChats Optional. Pass True, if the administrator can manage voice chats, supergroups only * @param canRestrictMembers Optional. Pass True, if the administrator can restrict, ban or unban chat members - * @param canPinMessages Optional. Pass True, if the administrator can pin messages, supergroups only * @param canPromoteMembers Optional. Pass True, if the administrator can add new administrators with a subset of their own privileges or demote administrators that he has promoted, directly or indirectly (promoted by administrators that were appointed by him) + * @param canChangeInfo Optional. Pass True, if the administrator can change chat title, photo and other settings + * @param canInviteUsers Optional. Pass True, if the administrator can invite new users to the chat + * @param canPinMessages Optional. Pass True, if the administrator can pin messages, supergroups only * * @return True on success. */ - bool promoteChatMember(std::int64_t chatId, std::int64_t userId, bool isAnonymous = false, - bool canChangeInfo = false, bool canPostMessages = false, bool canEditMessages = false, - bool canDeleteMessages = false, bool canInviteUsers = false, bool canRestrictMembers = false, - bool canPinMessages = false, bool canPromoteMembers = false) const; + bool promoteChatMember(std::int64_t chatId, + std::int64_t userId, + bool isAnonymous = false, + bool canManageChat = false, + bool canPostMessages = false, + bool canEditMessages = false, + bool canDeleteMessages = false, + bool canManageVoiceChats = false, + bool canRestrictMembers = false, + bool canPromoteMembers = false, + bool canChangeInfo = false, + bool canInviteUsers = false, + bool canPinMessages = false) const; /** * @brief Use this method to set a custom title for an administrator in a supergroup promoted by the bot. @@ -699,6 +718,50 @@ public: */ std::string exportChatInviteLink(std::int64_t chatId) const; + /** + * @brief Use this method to create an additional invite link for a chat. + * The bot must be an administrator in the chat for this to work and must have the appropriate admin rights. + * The link can be revoked using the method Api::revokeChatInviteLink. + * + * @param chatId Unique identifier for the target chat or username of the target channel (in the format @channelusername) + * @param expireDate Optional. Point in time (Unix timestamp) when the link will expire + * @param memberLimit Optional. Maximum number of users that can be members of the chat simultaneously after joining the chat via this invite link; 1-99999 + * + * @return the new invite link as ChatInviteLink object. + */ + ChatInviteLink::Ptr createChatInviteLink(std::int64_t chatId, + std::int32_t expireDate = 0, + std::int32_t memberLimit = 0) const; + + /** + * @brief Use this method to edit a non-primary invite link created by the bot. + * The bot must be an administrator in the chat for this to work and must have the appropriate admin rights. + * + * @param chatId Unique identifier for the target chat or username of the target channel (in the format @channelusername) + * @param inviteLink The invite link to edit + * @param expireDate Optional. Point in time (Unix timestamp) when the link will expire + * @param memberLimit Optional. Maximum number of users that can be members of the chat simultaneously after joining the chat via this invite link; 1-99999 + * + * @return the edited invite link as a ChatInviteLink object. + */ + ChatInviteLink::Ptr editChatInviteLink(std::int64_t chatId, + std::string inviteLink, + std::int32_t expireDate = 0, + std::int32_t memberLimit = 0) const; + + /** + * @brief Use this method to revoke an invite link created by the bot. + * If the primary link is revoked, a new link is automatically generated. + * The bot must be an administrator in the chat for this to work and must have the appropriate admin rights. + * + * @param chatId Unique identifier for the target chat or username of the target channel (in the format @channelusername) + * @param inviteLink The invite link to revoke + * + * @return the revoked invite link as ChatInviteLink object. + */ + ChatInviteLink::Ptr revokeChatInviteLink(std::int64_t chatId, + std::string inviteLink) const; + /** * @brief Use this method to set a new profile photo for the chat. * diff --git a/include/tgbot/TgTypeParser.h b/include/tgbot/TgTypeParser.h index 7009f6e..86f3b31 100644 --- a/include/tgbot/TgTypeParser.h +++ b/include/tgbot/TgTypeParser.h @@ -24,6 +24,10 @@ #include "tgbot/types/Contact.h" #include "tgbot/types/Location.h" #include "tgbot/types/ProximityAlertTriggered.h" +#include "tgbot/types/MessageAutoDeleteTimerChanged.h" +#include "tgbot/types/VoiceChatStarted.h" +#include "tgbot/types/VoiceChatEnded.h" +#include "tgbot/types/VoiceChatParticipantsInvited.h" #include "tgbot/types/Update.h" #include "tgbot/types/UserProfilePhotos.h" #include "tgbot/types/File.h" @@ -33,6 +37,7 @@ #include "tgbot/types/ReplyKeyboardRemove.h" #include "tgbot/types/ForceReply.h" #include "tgbot/types/ChatMember.h" +#include "tgbot/types/ChatMemberUpdated.h" #include "tgbot/types/ChatPhoto.h" #include "tgbot/types/ResponseParameters.h" #include "tgbot/types/GenericReply.h" @@ -201,6 +206,18 @@ public: ProximityAlertTriggered::Ptr parseJsonAndGetProximityAlertTriggered(const boost::property_tree::ptree& data) const; std::string parseProximityAlertTriggered(const ProximityAlertTriggered::Ptr& object) const; + MessageAutoDeleteTimerChanged::Ptr parseJsonAndGetMessageAutoDeleteTimerChanged(const boost::property_tree::ptree& data) const; + std::string parseMessageAutoDeleteTimerChanged(const MessageAutoDeleteTimerChanged::Ptr& object) const; + + VoiceChatStarted::Ptr parseJsonAndGetVoiceChatStarted(const boost::property_tree::ptree& data) const; + std::string parseVoiceChatStarted(const VoiceChatStarted::Ptr& object) const; + + VoiceChatEnded::Ptr parseJsonAndGetVoiceChatEnded(const boost::property_tree::ptree& data) const; + std::string parseVoiceChatEnded(const VoiceChatEnded::Ptr& object) const; + + VoiceChatParticipantsInvited::Ptr parseJsonAndGetVoiceChatParticipantsInvited(const boost::property_tree::ptree& data) const; + std::string parseVoiceChatParticipantsInvited(const VoiceChatParticipantsInvited::Ptr& object) const; + Update::Ptr parseJsonAndGetUpdate(const boost::property_tree::ptree& data) const; std::string parseUpdate(const Update::Ptr& object) const; @@ -246,9 +263,15 @@ public: ChatMember::Ptr parseJsonAndGetChatMember(const boost::property_tree::ptree& data) const; std::string parseChatMember(const ChatMember::Ptr& object) const; + ChatMemberUpdated::Ptr parseJsonAndGetChatMemberUpdated(const boost::property_tree::ptree& data) const; + std::string parseChatMemberUpdated(const ChatMemberUpdated::Ptr& object) const; + ChatPhoto::Ptr parseJsonAndGetChatPhoto(const boost::property_tree::ptree& data) const; std::string parseChatPhoto(const ChatPhoto::Ptr& object) const; + ChatInviteLink::Ptr parseJsonAndGetChatInviteLink(const boost::property_tree::ptree& data) const; + std::string parseChatInviteLink(const ChatInviteLink::Ptr& object) const; + ResponseParameters::Ptr parseJsonAndGetResponseParameters(const boost::property_tree::ptree& data) const; std::string parseResponseParameters(const ResponseParameters::Ptr& object) const; diff --git a/include/tgbot/types/ChatInviteLink.h b/include/tgbot/types/ChatInviteLink.h new file mode 100644 index 0000000..22de714 --- /dev/null +++ b/include/tgbot/types/ChatInviteLink.h @@ -0,0 +1,55 @@ +#ifndef TGBOT_CPP_CHATINVITELINK_H +#define TGBOT_CPP_CHATINVITELINK_H + +#include "tgbot/types/User.h" + +#include +#include +#include + +namespace TgBot { + +/** + * @brief Represents an invite link for a chat. + * + * @ingroup types + */ +class ChatInviteLink { + +public: + typedef std::shared_ptr Ptr; + + /** + * @brief The invite link. + * If the link was created by another chat administrator, then the second part of the link will be replaced with β€œβ€¦β€. + */ + std::string inviteLink; + + /** + * @brief Creator of the link + */ + User::Ptr creator; + + /** + * @brief True, if the link is primary + */ + bool isPrimary; + + /** + * @brief True, if the link is revoked + */ + bool isRevoked; + + /** + * @brief Optional. Point in time (Unix timestamp) when the link will expire or has been expired + */ + std::uint32_t expireDate; + + /** + * @brief Optional. Maximum number of users that can be members of the chat simultaneously after joining the chat via this invite link; 1-99999 + */ + std::uint32_t memberLimit; +}; +} + +#endif //TGBOT_CPP_CHATINVITELINK_H diff --git a/include/tgbot/types/ChatMember.h b/include/tgbot/types/ChatMember.h index dd033fd..a7ef856 100644 --- a/include/tgbot/types/ChatMember.h +++ b/include/tgbot/types/ChatMember.h @@ -45,6 +45,12 @@ public: */ bool canBeEdited; + /** + * @brief Optional. Administrators only. True, if the administrator can access the chat event log, chat statistics, message statistics in channels, see channel members, see anonymous administrators in supergroups and ignore slow mode. + * Implied by any other administrator privilege + */ + bool canManageChat; + /** * @brief Optional. Administrators only. True, if the administrator can post in the channel; channels only */ @@ -60,6 +66,11 @@ public: */ bool canDeleteMessages; + /** + * @brief Optional. Administrators only. True, if the administrator can manage voice chats + */ + bool canManageVoiceChats; + /** * @brief Optional. Administrators only. True, if the administrator can restrict, ban or unban chat members */ diff --git a/include/tgbot/types/ChatMemberUpdated.h b/include/tgbot/types/ChatMemberUpdated.h new file mode 100644 index 0000000..9d8ce2b --- /dev/null +++ b/include/tgbot/types/ChatMemberUpdated.h @@ -0,0 +1,55 @@ +#ifndef TGBOT_CPP_CHATMEMBERUPDATED_H +#define TGBOT_CPP_CHATMEMBERUPDATED_H + +#include "tgbot/types/Chat.h" +#include "tgbot/types/User.h" +#include "tgbot/types/ChatMember.h" +#include "tgbot/types/ChatInviteLink.h" + +#include + +namespace TgBot { + +/** + * @brief This object represents changes in the status of a chat member. + * + * @ingroup types + */ +class ChatMemberUpdated { + +public: + typedef std::shared_ptr Ptr; + + /** + * @brief Chat the user belongs to + */ + Chat::Ptr chat; + + /** + * @brief Performer of the action, which resulted in the change + */ + User::Ptr from; + + /** + * @brief Date the change was done in Unix time + */ + std::uint32_t date; + + /** + * @brief Previous information about the chat member + */ + ChatMember::Ptr oldChatMember; + + /** + * @brief New information about the chat member + */ + ChatMember::Ptr newChatMember; + + /** + * @brief Optional. Chat invite link, which was used by the user to join the chat; for joining by invite link events only. + */ + ChatInviteLink::Ptr inviteLink; +}; +} + +#endif //TGBOT_CPP_CHATMEMBERUPDATED_H diff --git a/include/tgbot/types/Dice.h b/include/tgbot/types/Dice.h index 55ded96..58a97f5 100644 --- a/include/tgbot/types/Dice.h +++ b/include/tgbot/types/Dice.h @@ -21,7 +21,7 @@ public: std::string emoji; /** - * @brief Value of the dice, 1-6 for β€œπŸŽ²β€ and β€œπŸŽ―β€ base emoji, 1-5 for β€œπŸ€β€ and β€œβš½β€ base emoji, 1-64 for β€œπŸŽ°β€ base emoji + * @brief Value of the dice, 1-6 for β€œπŸŽ²β€, β€œπŸŽ―β€ and β€œπŸŽ³β€ base emoji, 1-5 for β€œπŸ€β€ and β€œβš½β€ base emoji, 1-64 for β€œπŸŽ°β€ base emoji */ std::int32_t value; }; diff --git a/include/tgbot/types/Message.h b/include/tgbot/types/Message.h index 7eb28d7..fc99873 100644 --- a/include/tgbot/types/Message.h +++ b/include/tgbot/types/Message.h @@ -19,10 +19,14 @@ #include "tgbot/types/Venue.h" #include "tgbot/types/Voice.h" #include "tgbot/types/VideoNote.h" +#include "tgbot/types/MessageAutoDeleteTimerChanged.h" #include "tgbot/types/Invoice.h" #include "tgbot/types/SuccessfulPayment.h" #include "tgbot/types/PassportData.h" #include "tgbot/types/ProximityAlertTriggered.h" +#include "tgbot/types/VoiceChatStarted.h" +#include "tgbot/types/VoiceChatEnded.h" +#include "tgbot/types/VoiceChatParticipantsInvited.h" #include "tgbot/types/InlineKeyboardMarkup.h" #include @@ -75,7 +79,7 @@ public: User::Ptr forwardFrom; /** - * @brief Optional. For messages forwarded from channels, information about the original channel + * @brief Optional. For messages forwarded from channels or from anonymous administrators, information about the original sender chat */ Chat::Ptr forwardFromChat; @@ -101,7 +105,7 @@ public: /** * @brief Optional. For replies, the original message. - * Note that the Message object in this field will not contain further @ref Message::replyToMessage fields even if it itself is a reply. + * Note that the Message object in this field will not contain further replyToMessage fields even if it itself is a reply. */ Message::Ptr replyToMessage; @@ -192,7 +196,7 @@ public: Contact::Ptr contact; /** - * @brief Optional. Message is a dice with random value from 1 to 6 + * @brief Optional. Message is a dice with random value */ Dice::Ptr dice; @@ -207,7 +211,8 @@ public: Poll::Ptr poll; /** - * @brief Optional. Message is a venue, information about the venue + * @brief Optional. Message is a venue, information about the venue. + * For backward compatibility, when this field is set, the location field will also be set */ Venue::Ptr venue; @@ -217,7 +222,7 @@ public: Location::Ptr location; /** - * @brief Optional. New members that were added to the group or supergroup and information about them (the bot itself may be one of these members) + * @brief Optional. Optional. New members that were added to the group or supergroup and information about them (the bot itself may be one of these members) */ std::vector newChatMembers; @@ -247,15 +252,24 @@ public: bool groupChatCreated; /** - * @brief Optional. Service message: the supergroup has been created + * @brief Optional. Service message: the supergroup has been created. + * This field can't be received in a message coming through updates, because bot can't be a member of a supergroup when it is created. + * It can only be found in replyToMessage if someone replies to a very first message in a directly created supergroup. */ bool supergroupChatCreated; /** - * @brief Optional. Service message: the channel has been created + * @brief Optional. Service message: the channel has been created. + * This field can't be received in a message coming through updates, because bot can't be a member of a channel when it is created. + * It can only be found in replyToMessage if someone replies to a very first message in a channel. */ bool channelChatCreated; + /** + * @brief Optional. Service message: auto-delete timer settings changed in the chat + */ + MessageAutoDeleteTimerChanged::Ptr messageAutoDeleteTimerChanged; + /** * @brief Optional. The group has been migrated to a supergroup with the specified identifier. * @@ -274,22 +288,25 @@ public: /** * @brief Optional. Specified message was pinned. - * Note that the Message object in this field will not contain further @ref Message::replyToMessage fields even if it is itself a reply. + * Note that the Message object in this field will not contain further replyToMessage fields even if it is itself a reply. */ Message::Ptr pinnedMessage; /** - * @brief Optional. Message is an invoice for a payment, information about the invoice + * @brief Optional. Message is an invoice for a payment, information about the invoice. + * https://core.telegram.org/bots/api#payments */ Invoice::Ptr invoice; /** * @brief Optional. Message is a service message about a successful payment, information about the payment + * https://core.telegram.org/bots/api#payments */ SuccessfulPayment::Ptr successfulPayment; /** - * @brief Optional. The domain name of the website on which the user has logged in + * @brief Optional. The domain name of the website on which the user has logged in. + * https://core.telegram.org/widgets/login */ std::string connectedWebsite; @@ -304,9 +321,24 @@ public: */ ProximityAlertTriggered::Ptr proximityAlertTriggered; + /** + * @brief Optional. Service message: voice chat started + */ + VoiceChatStarted::Ptr voiceChatStarted; + + /** + * @brief Optional. Service message: voice chat ended + */ + VoiceChatEnded::Ptr voiceChatEnded; + + /** + * @brief Optional. Service message: new participants invited to a voice chat + */ + VoiceChatParticipantsInvited::Ptr voiceChatParticipantsInvited; + /** * @brief Optional. Inline keyboard attached to the message. - * @ref InlineKeyboardButton::loginUrl buttons are represented as ordinary @ref InlineKeyboardButton::url buttons. + * loginUrl buttons are represented as ordinary url buttons. */ InlineKeyboardMarkup::Ptr replyMarkup; diff --git a/include/tgbot/types/MessageAutoDeleteTimerChanged.h b/include/tgbot/types/MessageAutoDeleteTimerChanged.h new file mode 100644 index 0000000..87adcd5 --- /dev/null +++ b/include/tgbot/types/MessageAutoDeleteTimerChanged.h @@ -0,0 +1,26 @@ +#ifndef TGBOT_CPP_MESSAGEAUTODELETETIMERCHANGED_H +#define TGBOT_CPP_MESSAGEAUTODELETETIMERCHANGED_H + +#include +#include + +namespace TgBot { + +/** + * @brief This object represents a service message about a change in auto-delete timer settings. + * + * @ingroup types + */ +class MessageAutoDeleteTimerChanged { + +public: + typedef std::shared_ptr Ptr; + + /** + * @brief New auto-delete time for messages in the chat + */ + std::int32_t messageAutoDeleteTime; +}; +} + +#endif //TGBOT_CPP_MESSAGEAUTODELETETIMERCHANGED_H diff --git a/include/tgbot/types/Update.h b/include/tgbot/types/Update.h index f5b0237..3f15c46 100644 --- a/include/tgbot/types/Update.h +++ b/include/tgbot/types/Update.h @@ -9,6 +9,7 @@ #include "tgbot/types/PreCheckoutQuery.h" #include "tgbot/types/Poll.h" #include "tgbot/types/PollAnswer.h" +#include "tgbot/types/ChatMemberUpdated.h" #include #include @@ -61,7 +62,7 @@ public: /** * @brief Optional. The result of an inline query that was chosen by a user and sent to their chat partner. - * Please see the documentation on the feedback collecting for details on how to enable these updates for your bot. (https://core.telegram.org/bots/inline#collecting-feedback) + * Please see https://core.telegram.org/bots/inline#collecting-feedback for details on how to enable these updates for your bot. (https://core.telegram.org/bots/inline#collecting-feedback) */ ChosenInlineResult::Ptr chosenInlineResult; @@ -93,6 +94,18 @@ public: * Bots receive new votes only in polls that were sent by the bot itself. */ PollAnswer::Ptr pollAnswer; + + /** + * @brief Optional. The bot's chat member status was updated in a chat. + * For private chats, this update is received only when the bot is blocked or unblocked by the user. + */ + ChatMemberUpdated::Ptr myChatMember; + + /** + * @brief Optional. A chat member's status was updated in a chat. + * The bot must be an administrator in the chat and must explicitly specify β€œchatMember” in the list of allowedUpdates to receive these updates. + */ + ChatMemberUpdated::Ptr chatMember; }; } diff --git a/include/tgbot/types/VoiceChatEnded.h b/include/tgbot/types/VoiceChatEnded.h new file mode 100644 index 0000000..883f6a2 --- /dev/null +++ b/include/tgbot/types/VoiceChatEnded.h @@ -0,0 +1,26 @@ +#ifndef TGBOT_CPP_VOICECHATENDED_H +#define TGBOT_CPP_VOICECHATENDED_H + +#include +#include + +namespace TgBot { + +/** + * @brief This object represents a service message about a voice chat ended in the chat. + * + * @ingroup types + */ +class VoiceChatEnded { + +public: + typedef std::shared_ptr Ptr; + + /** + * @brief This object represents a service message about a voice chat ended in the chat. + */ + std::int32_t duration; +}; +} + +#endif //TGBOT_CPP_VOICECHATENDED_H diff --git a/include/tgbot/types/VoiceChatParticipantsInvited.h b/include/tgbot/types/VoiceChatParticipantsInvited.h new file mode 100644 index 0000000..f96c800 --- /dev/null +++ b/include/tgbot/types/VoiceChatParticipantsInvited.h @@ -0,0 +1,28 @@ +#ifndef TGBOT_CPP_VOICECHATPARTICIPANTSINVITED_H +#define TGBOT_CPP_VOICECHATPARTICIPANTSINVITED_H + +#include "tgbot/types/User.h" + +#include +#include + +namespace TgBot { + +/** + * @brief This object represents a service message about new members invited to a voice chat. + * + * @ingroup types + */ +class VoiceChatParticipantsInvited { + +public: + typedef std::shared_ptr Ptr; + + /** + * @brief Optional. New members that were invited to the voice chat + */ + std::vector users; +}; +} + +#endif //TGBOT_CPP_VOICECHATPARTICIPANTSINVITED_H diff --git a/include/tgbot/types/VoiceChatStarted.h b/include/tgbot/types/VoiceChatStarted.h new file mode 100644 index 0000000..3d4b2e6 --- /dev/null +++ b/include/tgbot/types/VoiceChatStarted.h @@ -0,0 +1,21 @@ +#ifndef TGBOT_CPP_VOICECHATSTARTED_H +#define TGBOT_CPP_VOICECHATSTARTED_H + +#include + +namespace TgBot { + +/** + * @brief This object represents a service message about a voice chat started in the chat. + * Currently holds no information. + * + * @ingroup types + */ +class VoiceChatStarted { + +public: + typedef std::shared_ptr Ptr; +}; +} + +#endif //TGBOT_CPP_VOICECHATSTARTED_H diff --git a/src/Api.cpp b/src/Api.cpp index 86d573b..a67aafb 100644 --- a/src/Api.cpp +++ b/src/Api.cpp @@ -852,15 +852,11 @@ Message::Ptr Api::sendDice(std::int64_t chatId, if (!emoji.empty()) { args.emplace_back("emoji", emoji); } - if (disableNotification) { - args.emplace_back("disable_notification", disableNotification); - } + args.emplace_back("disable_notification", disableNotification); if (replyToMessageId != 0) { args.emplace_back("reply_to_message_id", replyToMessageId); } - if (allowSendingWithoutReply) { - args.emplace_back("allow_sending_without_reply", allowSendingWithoutReply); - } + args.emplace_back("allow_sending_without_reply", allowSendingWithoutReply); if (replyMarkup) { args.emplace_back("reply_markup", _tgTypeParser.parseGenericReply(replyMarkup)); } @@ -907,14 +903,18 @@ string Api::downloadFile(const string& filePath, const std::vector& return serverResponse; } -bool Api::kickChatMember(std::int64_t chatId, std::int64_t userId, std::uint64_t untilDate) const { +bool Api::kickChatMember(std::int64_t chatId, + std::int64_t userId, + std::uint64_t untilDate, + bool revokeMessages) const { vector args; - args.reserve(3); + args.reserve(4); + args.emplace_back("chat_id", chatId); args.emplace_back("user_id", userId); - if (untilDate) { - args.emplace_back("until_date", untilDate); - } + args.emplace_back("until_date", untilDate); + args.emplace_back("revoke_messages", revokeMessages); + return sendRequest("kickChatMember", args).get("", false); } @@ -943,20 +943,29 @@ bool Api::restrictChatMember(std::int64_t chatId, std::int64_t userId, TgBot::Ch return sendRequest("restrictChatMember", args).get("", false); } -bool Api::promoteChatMember(std::int64_t chatId, std::int64_t userId, bool isAnonymous, - bool canChangeInfo, bool canPostMessages, bool canEditMessages, - bool canDeleteMessages, bool canInviteUsers, bool canRestrictMembers, - bool canPinMessages, bool canPromoteMembers) const { +bool Api::promoteChatMember(std::int64_t chatId, + std::int64_t userId, + bool isAnonymous, + bool canManageChat, + bool canPostMessages, + bool canEditMessages, + bool canDeleteMessages, + bool canManageVoiceChats, + bool canRestrictMembers, + bool canPromoteMembers, + bool canChangeInfo, + bool canInviteUsers, + bool canPinMessages) const { vector args; - args.reserve(11); + args.reserve(13); args.emplace_back("chat_id", chatId); args.emplace_back("user_id", userId); if (isAnonymous) { args.emplace_back("is_anonymous", isAnonymous); } - if (canChangeInfo) { - args.emplace_back("can_change_info", canChangeInfo); + if (canManageChat) { + args.emplace_back("can_manage_chat", canManageChat); } if (canPostMessages) { args.emplace_back("can_post_messages", canPostMessages); @@ -967,18 +976,24 @@ bool Api::promoteChatMember(std::int64_t chatId, std::int64_t userId, bool isAno if (canDeleteMessages) { args.emplace_back("can_delete_messages", canDeleteMessages); } - if (canInviteUsers) { - args.emplace_back("can_invite_users", canInviteUsers); + if (canManageVoiceChats) { + args.emplace_back("can_manage_voice_chats", canManageVoiceChats); } if (canRestrictMembers) { args.emplace_back("can_restrict_members", canRestrictMembers); } - if (canPinMessages) { - args.emplace_back("can_pin_messages", canPinMessages); - } if (canPromoteMembers) { args.emplace_back("can_promote_members", canPromoteMembers); } + if (canChangeInfo) { + args.emplace_back("can_change_info", canChangeInfo); + } + if (canInviteUsers) { + args.emplace_back("can_invite_users", canInviteUsers); + } + if (canPinMessages) { + args.emplace_back("can_pin_messages", canPinMessages); + } return sendRequest("promoteChatMember", args).get("", false); } @@ -1009,6 +1024,53 @@ string Api::exportChatInviteLink(std::int64_t chatId) const { return sendRequest("exportChatInviteLink", args).get("", ""); } +ChatInviteLink::Ptr Api::createChatInviteLink(std::int64_t chatId, + std::int32_t expireDate, + std::int32_t memberLimit) const { + vector args; + args.reserve(3); + + args.emplace_back("chat_id", chatId); + if (expireDate != 0) { + args.emplace_back("expire_date", expireDate); + } + if (memberLimit != 0) { + args.emplace_back("member_limit", memberLimit); + } + + return _tgTypeParser.parseJsonAndGetChatInviteLink(sendRequest("createChatInviteLink", args)); +} + +ChatInviteLink::Ptr Api::editChatInviteLink(std::int64_t chatId, + std::string inviteLink, + std::int32_t expireDate, + std::int32_t memberLimit) const { + vector args; + args.reserve(4); + + args.emplace_back("chat_id", chatId); + args.emplace_back("invite_link", inviteLink); + if (expireDate != 0) { + args.emplace_back("expire_date", expireDate); + } + if (memberLimit != 0) { + args.emplace_back("member_limit", memberLimit); + } + + return _tgTypeParser.parseJsonAndGetChatInviteLink(sendRequest("editChatInviteLink", args)); +} + +ChatInviteLink::Ptr Api::revokeChatInviteLink(std::int64_t chatId, + std::string inviteLink) const { + vector args; + args.reserve(2); + + args.emplace_back("chat_id", chatId); + args.emplace_back("invite_link", inviteLink); + + return _tgTypeParser.parseJsonAndGetChatInviteLink(sendRequest("revokeChatInviteLink", args)); +} + bool Api::setChatPhoto(std::int64_t chatId, const InputFile::Ptr photo) const { vector args; args.reserve(2); diff --git a/src/TgTypeParser.cpp b/src/TgTypeParser.cpp index 60a2c54..0491360 100644 --- a/src/TgTypeParser.cpp +++ b/src/TgTypeParser.cpp @@ -178,6 +178,7 @@ Message::Ptr TgTypeParser::parseJsonAndGetMessage(const boost::property_tree::pt result->groupChatCreated = data.get("group_chat_created", false); result->supergroupChatCreated = data.get("supergroup_chat_created", false); result->channelChatCreated = data.get("channel_chat_created", false); + result->messageAutoDeleteTimerChanged = tryParseJson(&TgTypeParser::parseJsonAndGetMessageAutoDeleteTimerChanged, data, "message_auto_delete_timer_changed"); result->migrateToChatId = data.get("migrate_to_chat_id", 0); result->migrateFromChatId = data.get("migrate_from_chat_id", 0); result->pinnedMessage = tryParseJson(&TgTypeParser::parseJsonAndGetMessage, data, "pinned_message"); @@ -186,7 +187,10 @@ Message::Ptr TgTypeParser::parseJsonAndGetMessage(const boost::property_tree::pt result->connectedWebsite = data.get("connected_website", ""); result->passportData = tryParseJson(&TgTypeParser::parseJsonAndGetPassportData, data, "passport_data"); result->passportData = tryParseJson(&TgTypeParser::parseJsonAndGetPassportData, data, "passport_data"); - result->proximityAlertTriggered = tryParseJson(&TgTypeParser::parseJsonAndGetProximityAlertTriggered, data, "proximity_alert_triggered"); + result->proximityAlertTriggered = tryParseJson(&TgTypeParser::parseJsonAndGetProximityAlertTriggered, data, "proximity_alert_triggered"); + result->voiceChatStarted = tryParseJson(&TgTypeParser::parseJsonAndGetVoiceChatStarted, data, "voice_chat_started"); + result->voiceChatEnded = tryParseJson(&TgTypeParser::parseJsonAndGetVoiceChatEnded, data, "voice_chat_ended"); + result->voiceChatParticipantsInvited = tryParseJson(&TgTypeParser::parseJsonAndGetVoiceChatParticipantsInvited, data, "voice_chat_participants_invited"); result->replyMarkup = tryParseJson(&TgTypeParser::parseJsonAndGetInlineKeyboardMarkup, data, "reply_markup"); result->automaticForward = data.get("is_automatic_forward", false); return result; @@ -240,6 +244,7 @@ std::string TgTypeParser::parseMessage(const Message::Ptr& object) const { appendToJson(result, "group_chat_created", object->groupChatCreated); appendToJson(result, "supergroup_chat_created", object->supergroupChatCreated); appendToJson(result, "channel_chat_created", object->channelChatCreated); + appendToJson(result, "message_auto_delete_timer_changed", parseMessageAutoDeleteTimerChanged(object->messageAutoDeleteTimerChanged)); appendToJson(result, "migrate_to_chat_id", object->migrateToChatId); appendToJson(result, "migrate_from_chat_id", object->migrateFromChatId); appendToJson(result, "pinned_message", parseMessage(object->pinnedMessage)); @@ -248,6 +253,9 @@ std::string TgTypeParser::parseMessage(const Message::Ptr& object) const { appendToJson(result, "connected_website", object->connectedWebsite); appendToJson(result, "passport_data", parsePassportData(object->passportData)); appendToJson(result, "proximity_alert_triggered", parseProximityAlertTriggered(object->proximityAlertTriggered)); + appendToJson(result, "voice_chat_started", parseVoiceChatStarted(object->voiceChatStarted)); + appendToJson(result, "voice_chat_ended", parseVoiceChatEnded(object->voiceChatEnded)); + appendToJson(result, "voice_chat_participants_invited", parseVoiceChatParticipantsInvited(object->voiceChatParticipantsInvited)); appendToJson(result, "reply_markup", parseInlineKeyboardMarkup(object->replyMarkup)); appendToJson(result, "is_automatic_forward", object->automaticForward); removeLastComma(result); @@ -887,6 +895,72 @@ std::string TgTypeParser::parseProximityAlertTriggered(const ProximityAlertTrigg return result; } +MessageAutoDeleteTimerChanged::Ptr TgTypeParser::parseJsonAndGetMessageAutoDeleteTimerChanged(const boost::property_tree::ptree& data) const { + auto result(std::make_shared()); + result->messageAutoDeleteTime = data.get("message_auto_delete_time", 0); + return result; +} + +std::string TgTypeParser::parseMessageAutoDeleteTimerChanged(const MessageAutoDeleteTimerChanged::Ptr& object) const { + if (!object) { + return ""; + } + std::string result; + result += '{'; + appendToJson(result, "message_auto_delete_time", object->messageAutoDeleteTime); + removeLastComma(result); + result += '}'; + return result; +} + +VoiceChatStarted::Ptr TgTypeParser::parseJsonAndGetVoiceChatStarted(const boost::property_tree::ptree& data) const { + auto result(std::make_shared()); + return result; +} + +std::string TgTypeParser::parseVoiceChatStarted(const VoiceChatStarted::Ptr& object) const { + if (!object) { + return ""; + } + return "{}"; +} + +VoiceChatEnded::Ptr TgTypeParser::parseJsonAndGetVoiceChatEnded(const boost::property_tree::ptree& data) const { + auto result(std::make_shared()); + result->duration = data.get("duration", 0); + return result; +} + +std::string TgTypeParser::parseVoiceChatEnded(const VoiceChatEnded::Ptr& object) const { + if (!object) { + return ""; + } + std::string result; + result += '{'; + appendToJson(result, "duration", object->duration); + removeLastComma(result); + result += '}'; + return result; +} + +VoiceChatParticipantsInvited::Ptr TgTypeParser::parseJsonAndGetVoiceChatParticipantsInvited(const boost::property_tree::ptree& data) const { + auto result(std::make_shared()); + result->users = parseJsonAndGetArray(&TgTypeParser::parseJsonAndGetUser, data, "users"); + return result; +} + +std::string TgTypeParser::parseVoiceChatParticipantsInvited(const VoiceChatParticipantsInvited::Ptr& object) const { + if (!object) { + return ""; + } + std::string result; + result += '{'; + appendToJson(result, "users", parseArray(&TgTypeParser::parseUser, object->users)); + removeLastComma(result); + result += '}'; + return result; +} + Update::Ptr TgTypeParser::parseJsonAndGetUpdate(const boost::property_tree::ptree& data) const { auto result(std::make_shared()); result->updateId = data.get("update_id", 0); @@ -901,6 +975,8 @@ Update::Ptr TgTypeParser::parseJsonAndGetUpdate(const boost::property_tree::ptre result->preCheckoutQuery = tryParseJson(&TgTypeParser::parseJsonAndGetPreCheckoutQuery, data, "pre_checkout_query"); result->poll = tryParseJson(&TgTypeParser::parseJsonAndGetPoll, data, "poll"); result->pollAnswer = tryParseJson(&TgTypeParser::parseJsonAndGetPollAnswer, data, "poll_answer"); + result->myChatMember = tryParseJson(&TgTypeParser::parseJsonAndGetChatMemberUpdated, data, "my_chat_member"); + result->chatMember = tryParseJson(&TgTypeParser::parseJsonAndGetChatMemberUpdated, data, "chat_member"); return result; } @@ -922,6 +998,8 @@ std::string TgTypeParser::parseUpdate(const Update::Ptr& object) const { appendToJson(result, "pre_checkout_query", parsePreCheckoutQuery(object->preCheckoutQuery)); appendToJson(result, "poll", parsePoll(object->poll)); appendToJson(result, "poll_answer", parsePollAnswer(object->pollAnswer)); + appendToJson(result, "my_chat_member", parseChatMemberUpdated(object->myChatMember)); + appendToJson(result, "chat_member", parseChatMemberUpdated(object->chatMember)); removeLastComma(result); result += '}'; return result; @@ -1267,9 +1345,11 @@ ChatMember::Ptr TgTypeParser::parseJsonAndGetChatMember(const boost::property_tr result->customTitle = data.get("custom_title", ""); result->isAnonymous = data.get("is_anonymous", false); result->canBeEdited = data.get("can_be_edited", false); + result->canManageChat = data.get("can_manage_chat", false); result->canPostMessages = data.get("can_post_messages", false); result->canEditMessages = data.get("can_edit_messages", false); result->canDeleteMessages = data.get("can_delete_messages", false); + result->canManageVoiceChats = data.get("can_manage_voice_chats", false); result->canRestrictMembers = data.get("can_restrict_members", false); result->canPromoteMembers = data.get("can_promote_members", false); result->canChangeInfo = data.get("can_change_info", false); @@ -1296,9 +1376,11 @@ std::string TgTypeParser::parseChatMember(const ChatMember::Ptr& object) const { appendToJson(result, "custom_title", object->customTitle); appendToJson(result, "is_anonymous", object->isAnonymous); appendToJson(result, "can_be_edited", object->canBeEdited); + appendToJson(result, "can_manage_chat", object->canManageChat); appendToJson(result, "can_post_messages", object->canPostMessages); appendToJson(result, "can_edit_messages", object->canEditMessages); appendToJson(result, "can_delete_messages", object->canDeleteMessages); + appendToJson(result, "can_manage_voice_chats", object->canManageVoiceChats); appendToJson(result, "can_restrict_members", object->canRestrictMembers); appendToJson(result, "can_promote_members", object->canPromoteMembers); appendToJson(result, "can_change_info", object->canChangeInfo); @@ -1316,6 +1398,34 @@ std::string TgTypeParser::parseChatMember(const ChatMember::Ptr& object) const { return result; } +ChatMemberUpdated::Ptr TgTypeParser::parseJsonAndGetChatMemberUpdated(const boost::property_tree::ptree& data) const { + auto result(std::make_shared()); + result->chat = tryParseJson(&TgTypeParser::parseJsonAndGetChat, data, "chat"); + result->from = tryParseJson(&TgTypeParser::parseJsonAndGetUser, data, "from"); + result->date = data.get("date", 0); + result->oldChatMember = tryParseJson(&TgTypeParser::parseJsonAndGetChatMember, data, "old_chat_member"); + result->newChatMember = tryParseJson(&TgTypeParser::parseJsonAndGetChatMember, data, "new_chat_member"); + result->inviteLink = tryParseJson(&TgTypeParser::parseJsonAndGetChatInviteLink, data, "invite_link"); + return result; +} + +std::string TgTypeParser::parseChatMemberUpdated(const ChatMemberUpdated::Ptr& object) const { + if (!object) { + return ""; + } + std::string result; + result += '{'; + appendToJson(result, "chat", parseChat(object->chat)); + appendToJson(result, "from", parseUser(object->from)); + appendToJson(result, "date", object->date); + appendToJson(result, "old_chat_member", parseChatMember(object->oldChatMember)); + appendToJson(result, "new_chat_member", parseChatMember(object->newChatMember)); + appendToJson(result, "invite_link", parseChatInviteLink(object->inviteLink)); + removeLastComma(result); + result += '}'; + return result; +} + ChatPhoto::Ptr TgTypeParser::parseJsonAndGetChatPhoto(const boost::property_tree::ptree& data) const { auto result(std::make_shared()); result->smallFileId = data.get("small_file_id", ""); @@ -1340,6 +1450,34 @@ std::string TgTypeParser::parseChatPhoto(const ChatPhoto::Ptr& object) const { return result; } +ChatInviteLink::Ptr TgTypeParser::parseJsonAndGetChatInviteLink(const boost::property_tree::ptree& data) const { + auto result(std::make_shared()); + result->inviteLink = data.get("invite_link", ""); + result->creator = tryParseJson(&TgTypeParser::parseJsonAndGetUser, data, "creator"); + result->isPrimary = data.get("is_primary", false); + result->isRevoked = data.get("is_revoked", false); + result->expireDate = data.get("expire_date", 0); + result->memberLimit = data.get("member_limit", 0); + return result; +} + +std::string TgTypeParser::parseChatInviteLink(const ChatInviteLink::Ptr& object) const { + if (!object) { + return ""; + } + std::string result; + result += '{'; + appendToJson(result, "invite_link", object->inviteLink); + appendToJson(result, "creator", parseUser(object->creator)); + appendToJson(result, "is_primary", object->isPrimary); + appendToJson(result, "is_revoked", object->isRevoked); + appendToJson(result, "expire_date", object->expireDate); + appendToJson(result, "member_limit", object->memberLimit); + removeLastComma(result); + result += '}'; + return result; +} + ResponseParameters::Ptr TgTypeParser::parseJsonAndGetResponseParameters(const boost::property_tree::ptree& data) const { auto result(std::make_shared()); result->migrateToChatId = data.get("migrate_to_chat_id", 0); -- cgit v1.2.3