From ed5065b35911a6d7d3dff30bd80600cc593901a3 Mon Sep 17 00:00:00 2001 From: llnulldisk <48621230+llnulldisk@users.noreply.github.com> Date: Mon, 29 Aug 2022 21:30:37 +0200 Subject: Update to API 4.6 --- src/Api.cpp | 28 ++++++++++++++++++---- src/TgTypeParser.cpp | 68 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 91 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/Api.cpp b/src/Api.cpp index b1a2f69..f1a1065 100644 --- a/src/Api.cpp +++ b/src/Api.cpp @@ -1155,24 +1155,42 @@ void Api::deleteMessage(std::int64_t chatId, std::int32_t messageId) const { sendRequest("deleteMessage", { HttpReqArg("chat_id", chatId), HttpReqArg("message_id", messageId) }); } -Message::Ptr Api::sendPoll(std::int64_t chatId, const std::string& question, const std::vector& options, bool disableNotification, std::int32_t replyToMessageId, const GenericReply::Ptr replyMarkup) const { +Message::Ptr Api::sendPoll(std::int64_t chatId, const std::string& question, const std::vector& options, bool disableNotification, std::int32_t replyToMessageId, + const GenericReply::Ptr replyMarkup, bool isAnonymous, const std::string& type, bool allowsMultipleAnswers, + std::int32_t correctOptionId, bool isClosed) const { vector args; - args.reserve(6); + args.reserve(11); args.emplace_back("chat_id", chatId); args.emplace_back("question", question); args.emplace_back("options", _tgTypeParser.parseArray([] (const std::string& option) -> std::string { return StringTools::urlEncode(option); }, options)); - if (disableNotification){ + if (!isAnonymous) { + args.emplace_back("is_anonymous", isAnonymous); + } + if (!type.empty()) { + args.emplace_back("type", type); + } + if (allowsMultipleAnswers) { + args.emplace_back("allows_multiple_answers", allowsMultipleAnswers); + } + if (correctOptionId != 0) { + args.emplace_back("correct_option_id", correctOptionId); + } + if (isClosed) { + args.emplace_back("is_closed", isClosed); + } + if (disableNotification) { args.emplace_back("disable_notification", disableNotification); } - if (replyToMessageId != 0){ + if (replyToMessageId != 0) { args.emplace_back("reply_to_message_id", replyToMessageId); } - if (replyMarkup){ + if (replyMarkup) { args.emplace_back("reply_markup", _tgTypeParser.parseGenericReply(replyMarkup)); } + return _tgTypeParser.parseJsonAndGetMessage(sendRequest("sendPoll", args)); } diff --git a/src/TgTypeParser.cpp b/src/TgTypeParser.cpp index db2e750..4528d62 100644 --- a/src/TgTypeParser.cpp +++ b/src/TgTypeParser.cpp @@ -80,6 +80,9 @@ User::Ptr TgTypeParser::parseJsonAndGetUser(const ptree& data) const { result->lastName = data.get("last_name", ""); result->username = data.get("username", ""); result->languageCode = data.get("language_code", ""); + result->canJoinGroups = data.get("can_join_groups", false); + result->canReadAllGroupMessages = data.get("can_read_all_group_messages", false); + result->supportsInlineQueries = data.get("supports_inline_queries", false); return result; } @@ -95,6 +98,9 @@ string TgTypeParser::parseUser(const User::Ptr& object) const { appendToJson(result, "last_name", object->lastName); appendToJson(result, "username", object->username); appendToJson(result, "language_code", object->languageCode); + appendToJson(result, "can_join_groups", object->canJoinGroups); + appendToJson(result, "can_read_all_group_messages", object->canReadAllGroupMessages); + appendToJson(result, "supports_inline_queries", object->supportsInlineQueries); removeLastComma(result); result += '}'; return result; @@ -107,6 +113,7 @@ MessageEntity::Ptr TgTypeParser::parseJsonAndGetMessageEntity(const ptree& data) result->length = data.get("length"); result->url = data.get("url", ""); result->user = tryParseJson(&TgTypeParser::parseJsonAndGetUser, data, "user"); + result->language = data.get("language", ""); return result; } @@ -121,6 +128,7 @@ string TgTypeParser::parseMessageEntity(const MessageEntity::Ptr& object) const appendToJson(result, "length", object->length); appendToJson(result, "url", object->url); appendToJson(result, "user", parseUser(object->user)); + appendToJson(result, "language", object->url); removeLastComma(result); result += '}'; return result; @@ -405,7 +413,12 @@ Poll::Ptr TgTypeParser::parseJsonAndGetPoll(const ptree& data) const { result->id = data.get("id", 0); result->question = data.get("question", ""); result->options = parseJsonAndGetArray(&TgTypeParser::parseJsonAndGetPollOption, data, "options"); + result->totalVoterCount = data.get("total_voter_count", 0); result->isClosed = data.get("is_closed"); + result->isAnonymous = data.get("is_anonymous"); + result->type = data.get("type", ""); + result->allowsMultipleAnswers = data.get("allows_multiple_answers"); + result->correctOptionId = data.get("correct_option_id", 0); return result; } @@ -418,7 +431,39 @@ string TgTypeParser::parsePoll(const Poll::Ptr& object) const { appendToJson(result, "id", object->id); appendToJson(result, "question", object->question); appendToJson(result, "options", parseArray(&TgTypeParser::parsePollOption, object->options)); + appendToJson(result, "total_voter_count", object->totalVoterCount); appendToJson(result, "is_closed", object->isClosed); + appendToJson(result, "is_anonymous", object->isAnonymous); + appendToJson(result, "type", object->type); + appendToJson(result, "allows_multiple_answers", object->allowsMultipleAnswers); + appendToJson(result, "correct_option_id", object->correctOptionId); + removeLastComma(result); + result += '}'; + return result; +} + +PollAnswer::Ptr TgTypeParser::parseJsonAndGetPollAnswer(const ptree& data) const { + auto result(make_shared()); + result->pollId = data.get("poll_id", ""); + result->user = tryParseJson(&TgTypeParser::parseJsonAndGetUser, data, "user"); + result->optionIds = parseJsonAndGetArray([] (const ptree& innerData)->std::int32_t { + return innerData.get(0); + }, data, "option_ids"); + + return result; +} + +string TgTypeParser::parsePollAnswer(const PollAnswer::Ptr& object) const { + if (!object) { + return ""; + } + string result; + result += '{'; + appendToJson(result, "poll_id", object->pollId); + appendToJson(result, "user", parseUser(object->user)); + appendToJson(result, "option_ids", parseArray([] (std::int32_t i)->std::int32_t { + return i; + }, object->optionIds)); removeLastComma(result); result += '}'; return result; @@ -705,6 +750,7 @@ Update::Ptr TgTypeParser::parseJsonAndGetUpdate(const ptree& data) const { result->shippingQuery = tryParseJson(&TgTypeParser::parseJsonAndGetShippingQuery, data, "shipping_query"); result->preCheckoutQuery = tryParseJson(&TgTypeParser::parseJsonAndGetPreCheckoutQuery, data, "pre_checkout_query"); result->poll = tryParseJson(&TgTypeParser::parseJsonAndGetPoll, data, "poll"); + result->pollAnswer = tryParseJson(&TgTypeParser::parseJsonAndGetPollAnswer, data, "poll_answer"); return result; } @@ -725,6 +771,7 @@ string TgTypeParser::parseUpdate(const Update::Ptr& object) const { appendToJson(result, "shipping_query", parseShippingQuery(object->shippingQuery)); appendToJson(result, "pre_checkout_query", parsePreCheckoutQuery(object->preCheckoutQuery)); appendToJson(result, "poll", parsePoll(object->poll)); + appendToJson(result, "poll_answer", parsePollAnswer(object->pollAnswer)); removeLastComma(result); result += '}'; return result; @@ -920,6 +967,8 @@ KeyboardButton::Ptr TgTypeParser::parseJsonAndGetKeyboardButton(const boost::pro result->text = data.get("text"); result->requestContact = data.get("request_contact", false); result->requestLocation = data.get("request_location", false); + result->requestPoll = tryParseJson(&TgTypeParser::parseJsonAndGetKeyboardButtonPollType, data, "request_poll"); + return result; } @@ -932,6 +981,25 @@ std::string TgTypeParser::parseKeyboardButton(const KeyboardButton::Ptr& object) appendToJson(result, "text", object->text); appendToJson(result, "request_contact", object->requestContact); appendToJson(result, "request_location", object->requestLocation); + appendToJson(result, "request_poll", parseKeyboardButtonPollType(object->requestPoll)); + removeLastComma(result); + result += '}'; + return result; +} + +KeyboardButtonPollType::Ptr TgTypeParser::parseJsonAndGetKeyboardButtonPollType(const ptree& data) const { + auto result(make_shared()); + result->type = data.get("type"); + return result; +} + +string TgTypeParser::parseKeyboardButtonPollType(const KeyboardButtonPollType::Ptr& object) const { + if (!object) { + return ""; + } + string result; + result += '{'; + appendToJson(result, "type", object->type); removeLastComma(result); result += '}'; return result; -- cgit v1.2.3