summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/tgbot/Api.h94
-rw-r--r--include/tgbot/TgTypeParser.h3
-rw-r--r--include/tgbot/types/Chat.h41
-rw-r--r--include/tgbot/types/ChatMember.h73
-rw-r--r--include/tgbot/types/ChatPhoto.h52
-rw-r--r--src/Api.cpp116
-rw-r--r--src/EventHandler.cpp6
-rw-r--r--src/TgTypeParser.cpp37
8 files changed, 404 insertions, 18 deletions
diff --git a/include/tgbot/Api.h b/include/tgbot/Api.h
index 10cc91e..5750a83 100644
--- a/include/tgbot/Api.h
+++ b/include/tgbot/Api.h
@@ -493,15 +493,16 @@ public:
* @return True on success
*/
bool answerInlineQuery(const std::string& inlineQueryId, const std::vector<InlineQueryResult::Ptr>& results,
- int32_t cacheTime=300, bool isPersonal=false, const std::string& nextOffset="", const std::string& switchPmText="", const std::string& switchPmParameter="") const;
+ int32_t cacheTime = 300, bool isPersonal = false, const std::string& nextOffset = "", const std::string& switchPmText = "", const std::string& switchPmParameter = "") const;
/**
* 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
*/
- bool kickChatMember(int64_t chatId, int32_t userId) const;
+ bool kickChatMember(int64_t chatId, int32_t userId, uint64_t untilDate = 0) const;
/**
* Use this method to unban a previously kicked user in a supergroup.
@@ -512,6 +513,95 @@ public:
bool unbanChatMember(int64_t chatId, int32_t userId) const;
/**
+ * Use this method to restrict a user in a supergroup.
+ * @param chatId Unique identifier for the target chat of the target supergroup.
+ * @param userId Unique identifier of the target user.
+ * @param untilDate Optional. Date when restrictions will be lifted for the user, unix time. If user is restricted for more than 366 days or less than 30 seconds from the current time, they are considered to be restricted forever.
+ * @param canSendMessages Optional. Pass True, if the user can send text messages, contacts, locations and venues.
+ * @param canSendMediaMessages Optional. Pass True, if the user can send audios, documents, photos, videos, video notes and voice notes, implies can_send_messages.
+ * @param canSendOtherMessages Optional. Pass True, if the user can send animations, games, stickers and use inline bots, implies can_send_media_messages.
+ * @param canAddWebPagePreviews Optional. Pass True, if the user may add web page previews to their messages, implies can_send_media_messages.
+ * @return True on success
+ */
+ bool restrictChatMember(int64_t chatId, int32_t userId, uint64_t untilDate = 0, bool canSendMessages = false,
+ bool canSendMediaMessages = false, bool canSendOtherMessages = false, bool canAddWebPagePreviews = false) const;
+
+ /**
+ * Use this method to promote or demote a user in a supergroup or a channel.
+ * @param chatId Unique identifier for the target chat of the target supergroup or channal.
+ * @param userId Unique identifier of the target user.
+ * @param canChangeInfo Optional. Pass True, if the administrator can change chat title, photo and other settings.
+ * @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 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 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 his own privileges or demote administrators that he has promoted, directly or indirectly (promoted by administrators that were appointed by him).
+ * @return True on success
+ */
+ bool promoteChatMember(int64_t chatId, int32_t userId, bool canChangeInfo = false, bool canPostMessages = false,
+ bool canEditMessages = false, bool canDeleteMessages = false, bool canInviteUsers = false, bool canPinMessages = false, bool canPromoteMembers = false) const;
+
+ /**
+ * Use this method to generate a new invite link for a chat; any previously generated link is revoked.
+ * @param chatId Unique identifier for the target chat.
+ * @return The new invite link as String on success.
+ */
+ std::string exportChatInviteLink(int64_t chatId) const;
+
+ /**
+ * Use this method to set a new profile photo for the chat.
+ * Photos can't be changed for private chats.
+ * @param chatId Unique identifier for the target chat.
+ * @param photo New chat photo.
+ * @return True on success
+ */
+ bool setChatPhoto(int64_t chatId, InputFile::Ptr photo) const;
+
+ /**
+ * Use this method to delete a chat photo.
+ * Photos can't be changed for private chats.
+ * @param chatId Unique identifier for the target chat.
+ * @return True on success
+ */
+ bool deleteChatPhoto(int64_t chatId) const;
+
+ /**
+ * Use this method to change the title of a chat.
+ * Titles can't be changed for private chats.
+ * @param chatId Unique identifier for the target chat.
+ * @param title New chat title, 1-255 characters.
+ * @return True on success
+ */
+ bool setChatTitle(int64_t chatId, std::string title) const;
+
+ /**
+ * Use this method to change the description of a supergroup or a channel.
+ * @param chatId Unique identifier for the target chat.
+ * @param description New chat description, 1-255 characters.
+ * @return True on success
+ */
+ bool setChatDescription(int64_t chatId, std::string description) const;
+
+ /**
+ * Use this method to pin a message in a supergroup or a channel.
+ * @param chatId Unique identifier for the target chat.
+ * @param messageId Identifier of a message to pin.
+ * @param disableNotification Optional. Pass True, if it is not necessary to send a notification to all chat members about the new pinned message. Notifications are always disabled in channels.
+ * @return True on success
+ */
+ bool pinChatMessage(int64_t chatId, int32_t messageId, bool disableNotification = false) const;
+
+ /**
+ * Use this method to unpin a message in a supergroup or a channel.
+ * @param chatId Unique identifier for the target chat.
+ * @return True on success
+ */
+ bool unpinChatMessage(int64_t chatId) const;
+
+
+ /**
* Downloads file from Telegram and saves it in memory.
* @param filePath Telegram file path.
* @param args Additional api parameters.
diff --git a/include/tgbot/TgTypeParser.h b/include/tgbot/TgTypeParser.h
index bfae9aa..0aea80b 100644
--- a/include/tgbot/TgTypeParser.h
+++ b/include/tgbot/TgTypeParser.h
@@ -47,6 +47,7 @@
#include "tgbot/types/ReplyKeyboardRemove.h"
#include "tgbot/types/ForceReply.h"
#include "tgbot/types/ChatMember.h"
+#include "tgbot/types/ChatPhoto.h"
#include "tgbot/types/ResponseParameters.h"
#include "tgbot/types/GenericReply.h"
#include "tgbot/types/InlineQuery.h"
@@ -149,6 +150,8 @@ public:
ChatMember::Ptr parseJsonAndGetChatMember(const boost::property_tree::ptree& data) const;
std::string parseChatMember(const ChatMember::Ptr& object) const;
+ ChatPhoto::Ptr parseJsonAndGetChatPhoto(const boost::property_tree::ptree& data) const; // returned only in getChat
+
ResponseParameters::Ptr parseJsonAndGetResponseParameters(const boost::property_tree::ptree& data) const;
std::string parseResponseParameters(const ResponseParameters::Ptr& object) const;
diff --git a/include/tgbot/types/Chat.h b/include/tgbot/types/Chat.h
index 698b95f..d286a63 100644
--- a/include/tgbot/types/Chat.h
+++ b/include/tgbot/types/Chat.h
@@ -26,6 +26,9 @@
#include <string>
#include <memory>
+#include "tgbot/types/ChatPhoto.h"
+#include "tgbot/types/Message.h"
+
namespace TgBot {
/**
@@ -79,9 +82,45 @@ public:
/**
* Optional. True if a group
- * has �All Members Are Admins� enabled.
+ * has ‘All Members Are Admins’ enabled.
*/
bool allMembersAreAdministrators;
+
+ /**
+ * Optional. Chat photo.
+ * Returned only in getChat.
+ */
+ ChatPhoto::Ptr photo;
+
+ /**
+ * Optional. Description, for supergroups and channel chats.
+ * Returned only in getChat.
+ */
+ std::string description;
+
+ /**
+ * Optional. Chat invite link, for supergroups and channel chats.
+ * Returned only in getChat.
+ */
+ std::string inviteLink;
+
+ /**
+ * Optional. Pinned message, for supergroups and channel chats.
+ * Returned only in getChat.
+ */
+ Message::Ptr pinnedMessage;
+
+ /**
+ * Optional. For supergroups, name of group sticker set.
+ * Returned only in getChat.
+ */
+ std::string stickerSetName;
+
+ /**
+ * Optional. True, if the bot can change the group sticker set.
+ * Returned only in getChat.
+ */
+ bool canSetStickerSet;
};
}
diff --git a/include/tgbot/types/ChatMember.h b/include/tgbot/types/ChatMember.h
index 7f4b139..a77e23a 100644
--- a/include/tgbot/types/ChatMember.h
+++ b/include/tgbot/types/ChatMember.h
@@ -1,5 +1,6 @@
//
// Created by Konstantin Kukin on 26/12/16.
+// Edit by JellyBrick on 27/05/18.
//
#ifndef TGBOT_CHATMEMBER_H
@@ -26,9 +27,79 @@ public:
User::Ptr user;
/**
- * The member's status in the chat. Can be creator, administrator, member, left or kicked
+ * The member's status in the chat. Can be “creator”, “administrator”, “member”, “restricted”, “left” or “kicked”
*/
std::string status;
+
+ /**
+ * Optional. Restricted and kicked only. Date when restrictions will be lifted for this user, unix time.
+ */
+ uint64_t untilDate;
+
+ /**
+ * Optional. Administrators only. True, if the bot is allowed to edit administrator privileges of that user.
+ */
+ bool canBeEdited = false;
+
+ /**
+ * Optional. Administrators only. True, if the administrator can change the chat title, photo and other settings.
+ */
+ bool canChangeInfo = false;
+
+ /**
+ * Optional. Administrators only. True, if the administrator can post in the channel, channels only.
+ */
+ bool canPostMessages = false;
+
+ /**
+ * Optional. Administrators only. True, if the administrator can edit messages of other users and can pin messages, channels only.
+ */
+ bool canEditMessages = false;
+
+ /**
+ * Optional. Administrators only. True, if the administrator can delete messages of other users.
+ */
+ bool canDeleteMessages = false;
+
+ /**
+ * Optional. Administrators only. True, if the administrator can invite new users to the chat.
+ */
+ bool canInviteUsers = false;
+
+ /**
+ * Optional. Administrators only. True, if the administrator can restrict, ban or unban chat members.
+ */
+ bool canRestrictMembers = false;
+
+ /**
+ * Optional. Administrators only. True, if the administrator can pin messages, supergroups only.
+ */
+ bool canPinMessages = false;
+
+ /**
+ * Optional. Administrators only. True, if the administrator can add new administrators with a subset of his own privileges or demote administrators that he has promoted, directly or indirectly (promoted by administrators that were appointed by the user).
+ */
+ bool canPromoteMembers = false;
+
+ /**
+ * Optional. Restricted only. True, if the user can send text messages, contacts, locations and venues.
+ */
+ bool canSendMessages = false;
+
+ /**
+ * Optional. Restricted only. True, if the user can send audios, documents, photos, videos, video notes and voice notes, implies can_send_messages.
+ */
+ bool canSendMediaMessages = false;
+
+ /**
+ * Optional. Restricted only. True, if the user can send animations, games, stickers and use inline bots, implies can_send_media_messages.
+ */
+ bool canSendOtherMessages = false;
+
+ /**
+ * Optional. Restricted only. True, if user may add web page previews to his messages, implies can_send_media_messages.
+ */
+ bool canAddWebPagePreviews = false;
};
}
diff --git a/include/tgbot/types/ChatPhoto.h b/include/tgbot/types/ChatPhoto.h
new file mode 100644
index 0000000..9469d2e
--- /dev/null
+++ b/include/tgbot/types/ChatPhoto.h
@@ -0,0 +1,52 @@
+/*
+ * Copyright (c) 2015 Oleg Morozenkov
+ * Copyright (c) 2018 JellyBrick
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ */
+
+#ifndef TGBOT_CHATPHOTO_H
+#define TGBOT_CHATPHOTO_H
+
+#include <memory>
+#include <string>
+
+namespace TgBot {
+
+/**
+ * This object represents a chat photo.
+ * @ingroup types
+ */
+class ChatPhoto {
+public:
+ typedef std::shared_ptr<ChatPhoto> Ptr;
+
+ /**
+ * Unique file identifier of small (160x160) chat photo. This file_id can be used only for photo download.
+ */
+ std::string smallFileId;
+
+ /**
+ * Unique file identifier of big (640x640) chat photo. This file_id can be used only for photo download.
+ */
+ std::string bigFileId;
+};
+}
+
+#endif //TGBOT_CHATPHOTO_H \ No newline at end of file
diff --git a/src/Api.cpp b/src/Api.cpp
index 5e39a9a..568ca71 100644
--- a/src/Api.cpp
+++ b/src/Api.cpp
@@ -609,7 +609,7 @@ vector<Update::Ptr> Api::getUpdates(int32_t offset, int32_t limit, int32_t timeo
if (timeout) {
args.push_back(HttpReqArg("timeout", timeout));
}
- if (allowedUpdates!=nullptr) {
+ if (allowedUpdates != nullptr) {
string allowedUpdatesJson = TgTypeParser::getInstance().parseArray<std::string>(
[](const std::string &s)->std::string {
return s;
@@ -625,10 +625,10 @@ void Api::setWebhook(const string& url, const InputFile::Ptr certificate, int32_
args.push_back(HttpReqArg("url", url));
if (certificate != nullptr)
args.push_back(HttpReqArg("certificate", certificate->data, true, certificate->mimeType, certificate->fileName));
- if (maxConnection!=40)
+ if (maxConnection != 40)
args.push_back(HttpReqArg("max_connections", maxConnection));
- if (allowedUpdates!=nullptr)
+ if (allowedUpdates != nullptr)
{
string allowedUpdatesJson = TgTypeParser::getInstance().parseArray<std::string>(
[](const std::string &s)->std::string {
@@ -653,7 +653,7 @@ WebhookInfo::Ptr Api::getWebhookInfo() const
if (!p.get_child_optional("url"))
return nullptr;
- if (p.get<string>("url","")!=string(""))
+ if (p.get<string>("url","") != string(""))
{
return TgTypeParser::getInstance().parseJsonAndGetWebhookInfo(p);
}
@@ -664,7 +664,7 @@ WebhookInfo::Ptr Api::getWebhookInfo() const
}
bool Api::answerInlineQuery(const std::string& inlineQueryId, const std::vector<InlineQueryResult::Ptr>& results,
- int32_t cacheTime, bool isPersonal, const std::string& nextOffset, const std::string& switchPmText, const std::string& switchPmParameter) const {
+ int32_t cacheTime, bool isPersonal, const std::string& nextOffset, const std::string& switchPmText, const std::string& switchPmParameter) const {
vector<HttpReqArg> args;
args.push_back(HttpReqArg("inline_query_id", inlineQueryId));
string resultsJson = TgTypeParser::getInstance().parseArray<InlineQueryResult>(&TgTypeParser::parseInlineQueryResult, results);
@@ -687,10 +687,13 @@ bool Api::answerInlineQuery(const std::string& inlineQueryId, const std::vector<
return sendRequest("answerInlineQuery", args).get<bool>("", false);
}
-bool Api::kickChatMember(int64_t chatId, int32_t userId) const {
+bool Api::kickChatMember(int64_t chatId, int32_t userId, uint64_t untilDate) const {
vector<HttpReqArg> args;
args.push_back(HttpReqArg("chat_id", chatId));
args.push_back(HttpReqArg("user_id", userId));
+ if (untilDate) {
+ args.push_back(HttpReqArg("until_date", untilDate));
+ }
return sendRequest("kickChatMember", args).get<bool>("", false);
}
@@ -701,6 +704,107 @@ bool Api::unbanChatMember(int64_t chatId, int32_t userId) const {
return sendRequest("unbanChatMember", args).get<bool>("", false);
}
+bool Api::restrictChatMember(int64_t chatId, int32_t userId, uint64_t untilDate, bool canSendMessages,
+ bool canSendMediaMessages, bool canSendOtherMessages, bool canAddWebPagePreviews) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ args.push_back(HttpReqArg("user_id", userId));
+ if (untilDate) {
+ args.push_back(HttpReqArg("until_date", untilDate));
+ }
+ if (canSendMessages) {
+ args.push_back(HttpReqArg("can_send_messages", canSendMessages));
+ }
+ if (canSendMediaMessages) {
+ args.push_back(HttpReqArg("can_send_media_messages", canSendMediaMessages));
+ }
+ if (canSendOtherMessages) {
+ args.push_back(HttpReqArg("can_send_other_messages", canSendOtherMessages));
+ }
+ if (canAddWebPagePreviews) {
+ args.push_back(HttpReqArg("can_add_web_page_previews", canAddWebPagePreviews));
+ }
+ return sendRequest("restrictChatMember", args).get<bool>("", false);
+}
+
+bool Api::promoteChatMember(int64_t chatId, int32_t userId, bool canChangeInfo, bool canPostMessages,
+ bool canEditMessages, bool canDeleteMessages, bool canInviteUsers, bool canPinMessages, bool canPromoteMembers) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ args.push_back(HttpReqArg("user_id", userId));
+ if (canChangeInfo) {
+ args.push_back(HttpReqArg("can_change_info", canChangeInfo));
+ }
+ if (canPostMessages) {
+ args.push_back(HttpReqArg("can_post_messages", canPostMessages));
+ }
+ if (canEditMessages) {
+ args.push_back(HttpReqArg("can_edit_messages", canEditMessages));
+ }
+ if (canDeleteMessages) {
+ args.push_back(HttpReqArg("can_delete_messages", canDeleteMessages));
+ }
+ if (canInviteUsers) {
+ args.push_back(HttpReqArg("can_invite_users", canInviteUsers));
+ }
+ if (canPinMessages) {
+ args.push_back(HttpReqArg("can_pin_messages", canPinMessages));
+ }
+ if (canPromoteMembers) {
+ args.push_back(HttpReqArg("can_promote_members", canPromoteMembers));
+ }
+ return sendRequest("promoteChatMember", args).get<bool>("", false);
+}
+
+std::string Api::exportChatInviteLink(int64_t chatId) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ return sendRequest("exportChatInviteLink", args).get("", "");
+}
+
+bool Api::setChatPhoto(int64_t chatId, InputFile::Ptr photo) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ args.push_back(HttpReqArg("photo", photo->data, true, photo->mimeType, photo->fileName));
+ return sendRequest("setChatPhoto", args).get<bool>("", false);
+}
+
+bool Api::deleteChatPhoto(int64_t chatId) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ return sendRequest("deleteChatPhoto", args).get<bool>("", false);
+}
+
+bool Api::setChatTitle(int64_t chatId, std::string title) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ args.push_back(HttpReqArg("title", title));
+ return sendRequest("setChatTitle", args).get<bool>("", false);
+}
+
+bool Api::setChatDescription(int64_t chatId, std::string description) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ args.push_back(HttpReqArg("description", description));
+ return sendRequest("setChatDescription", args).get<bool>("", false);
+}
+
+bool Api::pinChatMessage(int64_t chatId, int32_t messageId, bool disableNotification) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ args.push_back(HttpReqArg("description", description));
+ if (disableNotification) {
+ args.push_back(HttpReqArg("disable_notification", disableNotification));
+ }
+ return sendRequest("pinChatMessage", args).get<bool>("", false);
+}
+
+bool Api::unpinChatMessage(int64_t chatId) const {
+ vector<HttpReqArg> args;
+ args.push_back(HttpReqArg("chat_id", chatId));
+ return sendRequest("unpinChatMessage", args).get<bool>("", false);
+}
+
void Api::deleteMessage(int64_t chatId, int32_t messageId) const {
sendRequest("deleteMessage", { HttpReqArg("chat_id", chatId), HttpReqArg("message_id", messageId) });
}
diff --git a/src/EventHandler.cpp b/src/EventHandler.cpp
index 32efe3e..ba0ce54 100644
--- a/src/EventHandler.cpp
+++ b/src/EventHandler.cpp
@@ -26,9 +26,9 @@ void EventHandler::handleMessage(const Message::Ptr message) const {
_broadcaster->broadcastAnyMessage(message);
if (StringTools::startsWith(message->text, "/")) {
- uint32_t splitPosition;
- uint32_t spacePosition = message->text.find(' ');
- uint32_t atSymbolPosition = message->text.find('@');
+ uint16_t splitPosition;
+ uint16_t spacePosition = message->text.find(' ');
+ uint16_t atSymbolPosition = message->text.find('@');
if (spacePosition == message->text.npos) {
if (atSymbolPosition == message->text.npos) {
splitPosition = message->text.size();
diff --git a/src/TgTypeParser.cpp b/src/TgTypeParser.cpp
index c442600..9a48de5 100644
--- a/src/TgTypeParser.cpp
+++ b/src/TgTypeParser.cpp
@@ -50,6 +50,12 @@ Chat::Ptr TgTypeParser::parseJsonAndGetChat(const ptree& data) const {
result->firstName = data.get<string>("first_name", "");
result->lastName = data.get("last_name", "");
result->allMembersAreAdministrators = data.get<bool>("all_members_are_administrators", false);
+ result->photo = tryParseJson<ChatPhoto>(&TgTypeParser::parseJsonAndGetChatPhoto, data, "photo");
+ result->description = data.get("description", "");
+ result->inviteLink = data.get("invite_link", "");
+ result->pinnedMessage = tryParseJson<ChatPhoto>(&TgTypeParser::parseJsonAndGetMessage, data, "pinned_message");
+ result->stickerSetName = data.get("sticker_set_name", "");
+ result->canSetStickerSet = data.get<bool>("can_set_sticker_set", false);
return result;
}
@@ -107,10 +113,10 @@ string TgTypeParser::parseUser(const User::Ptr& object) const {
MessageEntity::Ptr TgTypeParser::parseJsonAndGetEntity(const ptree& data) const{
auto result(make_shared<MessageEntity>());
- result->type=data.get<string>("type");
- result->offset=data.get<int32_t>("offset");
- result->length=data.get<int32_t>("length");
- result->url=data.get<string>("url", "");
+ result->type = data.get<string>("type");
+ result->offset = data.get<int32_t>("offset");
+ result->length = data.get<int32_t>("length");
+ result->url = data.get<string>("url", "");
result->user = tryParseJson<User>(&TgTypeParser::parseJsonAndGetUser, data, "user");
return result;
}
@@ -571,7 +577,21 @@ std::string TgTypeParser::parseForceReply(const ForceReply::Ptr& object) const {
ChatMember::Ptr TgTypeParser::parseJsonAndGetChatMember(const boost::property_tree::ptree& data) const {
auto result(make_shared<ChatMember>());
result->user = tryParseJson<User>(&TgTypeParser::parseJsonAndGetUser, data, "user");
- result->status = data.get<string>("status");
+ result->status = data.get("status", "");
+ result->untilDate = data.get<uint64_t>("until_date", 0);
+ result->canBeEdited = data.get<bool>("can_be_edited", false);
+ result->canChangeInfo = data.get<bool>("can_change_info", false);
+ result->canPostMessages = data.get<bool>("can_post_messages", false);
+ result->canEditMessages = data.get<bool>("can_edit_messages", false);
+ result->canDeleteMessages = data.get<bool>("can_delete_messages", false);
+ result->canInviteUsers = data.get<bool>("can_invite_users", false);
+ result->canRestrictMembers = data.get<bool>("can_restrict_members", false);
+ result->canPinMessages = data.get<bool>("can_pin_messages", false);
+ result->canPromoteMembers = data.get<bool>("can_promote_messages", false);
+ result->canSendMessages = data.get<bool>("can_send_messages", false);
+ result->canSendMediaMessages = data.get<bool>("can_send_media_messages", false);
+ result->canSendOtherMessages = data.get<bool>("can_send_other_messages", false);
+ result->canAddWebPagePreviews = data.get<bool>("can_add_web_page_previews", false);
return result;
}
@@ -588,6 +608,13 @@ std::string TgTypeParser::parseChatMember(const ChatMember::Ptr& object) const {
return result;
}
+ChatPhoto::Ptr TgTypeParser::parseJsonAndGetChatPhoto(const boost::property_tree::ptree& data) const {
+ auto result(make_shared<ChatPhoto>());
+ result->smallFileId = data.get("small_file_id", "");
+ result->bigFileId = data.get("big_file_id", "");
+ return result;
+}
+
ResponseParameters::Ptr TgTypeParser::parseJsonAndGetResponseParameters(const boost::property_tree::ptree& data) const {
auto result(make_shared<ResponseParameters>());
result->migrateToChatId = data.get<int32_t>("migrate_to_chat_id", 0);