From 76a362631705d9adcc2709e6d8f9b327112ae306 Mon Sep 17 00:00:00 2001 From: llnulldisk <48621230+llnulldisk@users.noreply.github.com> Date: Tue, 30 Aug 2022 00:25:15 +0200 Subject: Update to API 4.7 --- src/Api.cpp | 64 +++++++++++++++++++++++++++++++++++++++------ src/TgTypeParser.cpp | 73 +++++++++++++++++++++++++++++++++++++++++++++++----- 2 files changed, 123 insertions(+), 14 deletions(-) (limited to 'src') diff --git a/src/Api.cpp b/src/Api.cpp index f1a1065..22115c2 100644 --- a/src/Api.cpp +++ b/src/Api.cpp @@ -320,19 +320,28 @@ File::Ptr Api::uploadStickerFile(std::int64_t userId, const InputFile::Ptr pngSt return _tgTypeParser.parseJsonAndGetFile(sendRequest("uploadStickerFile", args)); } -bool Api::createNewStickerSet(std::int64_t userId, const string& name, const string& title, boost::variant pngSticker, const string& emojis, bool containsMasks, MaskPosition::Ptr maskPosition) const { +bool Api::createNewStickerSet(std::int64_t userId, const std::string& name, const std::string& title, const std::string& emojis, + boost::variant pngSticker, boost::variant tgsSticker, + bool containsMasks, MaskPosition::Ptr maskPosition) const { vector args; - args.reserve(7); + args.reserve(8); args.emplace_back("user_id", userId); args.emplace_back("name", name); args.emplace_back("title", title); + args.emplace_back("emojis", emojis); + if (pngSticker.which() == 0 /* InputFile::Ptr */) { auto file = boost::get(pngSticker); args.emplace_back("png_sticker", file->data, true, file->mimeType, file->fileName); } else /* std::string */ { args.emplace_back("png_sticker", boost::get(pngSticker)); } - args.emplace_back("emojis", emojis); + if (tgsSticker.which() == 0 /* InputFile::Ptr */) { + auto file = boost::get(tgsSticker); + args.emplace_back("tgs_sticker", file->data, true, file->mimeType, file->fileName); + } else /* std::string */ { + args.emplace_back("tgs_sticker", boost::get(tgsSticker)); + } if (containsMasks) { args.emplace_back("contains_mask", containsMasks); } @@ -342,18 +351,27 @@ bool Api::createNewStickerSet(std::int64_t userId, const string& name, const str return sendRequest("createNewStickerSet", args).get("", false); } -bool Api::addStickerToSet(std::int64_t userId, const string& name, boost::variant pngSticker, const string& emojis, MaskPosition::Ptr maskPosition) const { +bool Api::addStickerToSet(std::int64_t userId, const std::string& name, const std::string& emojis, + boost::variant pngSticker, boost::variant tgsSticker, + MaskPosition::Ptr maskPosition) const { vector args; args.reserve(6); args.emplace_back("user_id", userId); args.emplace_back("name", name); + args.emplace_back("emojis", emojis); + if (pngSticker.which() == 0 /* InputFile::Ptr */) { auto file = boost::get(pngSticker); args.emplace_back("png_sticker", file->data, true, file->mimeType, file->fileName); } else /* std::string */ { args.emplace_back("png_sticker", boost::get(pngSticker)); } - args.emplace_back("emojis", emojis); + if (tgsSticker.which() == 0 /* InputFile::Ptr */) { + auto file = boost::get(tgsSticker); + args.emplace_back("tgs_sticker", file->data, true, file->mimeType, file->fileName); + } else /* std::string */ { + args.emplace_back("tgs_sticker", boost::get(tgsSticker)); + } if (maskPosition != nullptr) { args.emplace_back("mask_position", _tgTypeParser.parseMaskPosition(maskPosition)); } @@ -375,6 +393,20 @@ bool Api::deleteStickerFromSet(const string& sticker) const { return sendRequest("deleteStickerFromSet", args).get("", false); } +bool Api::setStickerSetThumb(const std::string& name, std::int64_t userId, boost::variant thumb) const { + vector args; + args.reserve(3); + args.emplace_back("name", name); + args.emplace_back("user_id", userId); + if (thumb.which() == 0 /* InputFile::Ptr */) { + auto file = boost::get(thumb); + args.emplace_back("thumb", file->data, true, file->mimeType, file->fileName); + } else /* std::string */ { + args.emplace_back("thumb", boost::get(thumb)); + } + return sendRequest("setStickerSetThumb", args).get("", false); +} + Message::Ptr Api::sendVideo(std::int64_t chatId, boost::variant video, bool supportsStreaming, std::int32_t duration, std::int32_t width, std::int32_t height, boost::variant thumb, const string &caption, std::int32_t replyToMessageId, const GenericReply::Ptr replyMarkup, const string& parseMode, bool disableNotification) const { vector args; args.reserve(12); @@ -1194,6 +1226,24 @@ Message::Ptr Api::sendPoll(std::int64_t chatId, const std::string& question, con return _tgTypeParser.parseJsonAndGetMessage(sendRequest("sendPoll", args)); } +Message::Ptr Api::sendDice(std::int64_t chatId, bool disableNotification, std::int32_t replyToMessageId, GenericReply::Ptr replyMarkup) const { + vector args; + args.reserve(4); + args.emplace_back("chat_id", chatId); + + if (disableNotification) { + args.emplace_back("disable_notification", disableNotification); + } + if (replyToMessageId != 0) { + args.emplace_back("reply_to_message_id", replyToMessageId); + } + if (replyMarkup) { + args.emplace_back("reply_markup", _tgTypeParser.parseGenericReply(replyMarkup)); + } + + return _tgTypeParser.parseJsonAndGetMessage(sendRequest("sendDice", args)); +} + Poll::Ptr Api::stopPoll(std::int64_t chatId, std::int64_t messageId, const InlineKeyboardMarkup::Ptr replyMarkup) const { vector args; args.reserve(3); @@ -1206,7 +1256,6 @@ Poll::Ptr Api::stopPoll(std::int64_t chatId, std::int64_t messageId, const Inlin } bool Api::setMyCommands(const std::vector& commands) const { - vector args; args.reserve(5); @@ -1216,8 +1265,7 @@ bool Api::setMyCommands(const std::vector& commands) const { return sendRequest("setMyCommands",args).get("",false); } -std::vector Api::getMyCommands() const -{ +std::vector Api::getMyCommands() const { return _tgTypeParser.parseJsonAndGetArray(&TgTypeParser::parseJsonAndGetBotCommand, sendRequest("getMyCommands")); } diff --git a/src/TgTypeParser.cpp b/src/TgTypeParser.cpp index 4528d62..37dafb6 100644 --- a/src/TgTypeParser.cpp +++ b/src/TgTypeParser.cpp @@ -148,6 +148,7 @@ Message::Ptr TgTypeParser::parseJsonAndGetMessage(const ptree& data) const { result->forwardDate = data.get("forward_date", 0); result->replyToMessage = tryParseJson(&TgTypeParser::parseJsonAndGetMessage, data, "reply_to_message"); result->editDate = data.get("edit_date", 0); + result->mediaGroupId = data.get("media_group_id", ""); result->authorSignature = data.get("author_signature", ""); result->text = data.get("text", ""); result->entities = parseJsonAndGetArray(&TgTypeParser::parseJsonAndGetMessageEntity, data, "entities"); @@ -160,17 +161,20 @@ Message::Ptr TgTypeParser::parseJsonAndGetMessage(const ptree& data) const { result->sticker = tryParseJson(&TgTypeParser::parseJsonAndGetSticker, data, "sticker"); result->video = tryParseJson