From f3aba5cb3cca0f99f2a39d61acd960a836295593 Mon Sep 17 00:00:00 2001 From: kukin-konstantin Date: Tue, 10 Jan 2017 17:07:34 +0300 Subject: fix ReplyKeyboardMarkup --- include/tgbot/types/KeyboardButton.h | 4 ++-- include/tgbot/types/ReplyKeyboardMarkup.h | 11 ++++++----- src/TgTypeParser.cpp | 23 +++++++++-------------- 3 files changed, 17 insertions(+), 21 deletions(-) diff --git a/include/tgbot/types/KeyboardButton.h b/include/tgbot/types/KeyboardButton.h index 637aced..204c579 100644 --- a/include/tgbot/types/KeyboardButton.h +++ b/include/tgbot/types/KeyboardButton.h @@ -31,12 +31,12 @@ public: * Optional. If True, the user's phone number will be sent as a contact * when the button is pressed. Available in private chats only */ - bool requestContact; + bool requestContact = false; /** * Optional. If True, the user's current location will be sent when the button is pressed. Available in private chats only. */ - bool requestLocation; + bool requestLocation = false; }; } diff --git a/include/tgbot/types/ReplyKeyboardMarkup.h b/include/tgbot/types/ReplyKeyboardMarkup.h index 92d850e..f6e50db 100644 --- a/include/tgbot/types/ReplyKeyboardMarkup.h +++ b/include/tgbot/types/ReplyKeyboardMarkup.h @@ -28,6 +28,7 @@ #include #include "tgbot/types/GenericReply.h" +#include "tgbot/types/KeyboardButton.h" namespace TgBot { @@ -41,25 +42,25 @@ public: typedef std::shared_ptr Ptr; /** - * Array of button rows, each represented by an Array of Strings. + * Array of button rows, each represented by an Array of KeyboardButton. */ - std::vector> keyboard; + std::vector> keyboard; /** * Optional. Requests clients to resize the keyboard vertically for optimal fit (e.g., make the keyboard smaller if there are just two rows of buttons). Defaults to false, in which case the custom keyboard is always of the same height as the app's standard keyboard. */ - bool resizeKeyboard; + bool resizeKeyboard = false; /** * Optional. Requests clients to hide the keyboard as soon as it's been used. Defaults to false. */ - bool oneTimeKeyboard; + bool oneTimeKeyboard = false; /** * Optional. Use this parameter if you want to show the keyboard to specific users only. Targets: 1) users that are @mentioned in the text of the Message object; 2) if the bot's message is a reply (has reply_to_message_id), sender of the original message. * Example: A user requests to change the bot‘s language, bot replies to the request with a keyboard to select the new language. Other users in the group don’t see the keyboard. */ - bool selective; + bool selective = false; }; } diff --git a/src/TgTypeParser.cpp b/src/TgTypeParser.cpp index 45124e2..0952d75 100644 --- a/src/TgTypeParser.cpp +++ b/src/TgTypeParser.cpp @@ -442,16 +442,12 @@ string TgTypeParser::parseFile(const File::Ptr& object) const { ReplyKeyboardMarkup::Ptr TgTypeParser::parseJsonAndGetReplyKeyboardMarkup(const boost::property_tree::ptree& data) const { ReplyKeyboardMarkup::Ptr result(new ReplyKeyboardMarkup); - for (const pair& item : data.find("keyboard")->second) { - vector array; - for (const pair& innerItem : item.second) { - array.push_back(innerItem.second.data()); - } - result->keyboard.push_back(array); + for (const boost::property_tree::ptree::value_type& item : data.find("keyboard")->second){ + result->keyboard.push_back(parseJsonAndGetArray(&TgTypeParser::parseJsonAndGetKeyboardButton, item.second)); } - result->resizeKeyboard = data.get("resize_keyboard"); - result->oneTimeKeyboard = data.get("one_time_keyboard"); - result->selective = data.get("selective"); + result->resizeKeyboard = data.get("resize_keyboard", false); + result->oneTimeKeyboard = data.get("one_time_keyboard", false); + result->selective = data.get("selective", false); return result; } @@ -462,12 +458,11 @@ std::string TgTypeParser::parseReplyKeyboardMarkup(const ReplyKeyboardMarkup::Pt string result; result += '{'; result += "\"keyboard\":["; - for (vector& item : object->keyboard) { + for (vector& item : object->keyboard) { result += '['; - for (string& innerItem : item) { - result += '"'; - result += innerItem; - result += "\","; + for (KeyboardButton::Ptr& innerItem : item) { + result += parseKeyboardButton(innerItem); + result += ','; } result.erase(result.length() - 1); result += "],"; -- cgit v1.2.3 From 54a50a7c8a7e9d15c03bdb64babe54e5c123e5c7 Mon Sep 17 00:00:00 2001 From: kukin-konstantin Date: Wed, 11 Jan 2017 20:33:18 +0300 Subject: fix encodeUrl function --- src/tools/StringTools.cpp | 20 +++++++++++--------- test/tgbot/tools/StringTools.cpp | 2 +- 2 files changed, 12 insertions(+), 10 deletions(-) diff --git a/src/tools/StringTools.cpp b/src/tools/StringTools.cpp index c682b35..d5270db 100644 --- a/src/tools/StringTools.cpp +++ b/src/tools/StringTools.cpp @@ -84,20 +84,22 @@ string generateRandomString(size_t length) { return result; } + string urlEncode(const string& value, const std::string& additionalLegitChars) { - static const string legitPunctuation = "-_.~"; - ostringstream result; - result.fill('0'); - result << hex; - for (const char& c : value) { - if (isalnum(c) || legitPunctuation.find(c) != legitPunctuation.npos || additionalLegitChars.find(c) != additionalLegitChars.npos) { - result << c; + static const string legitPunctuation = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.-~:"; + std::stringstream ss; + std::string t; + for (auto const &c : value) { + if ((legitPunctuation.find(c) == std::string::npos) + && (additionalLegitChars.find(c)==std::string::npos)) { + ss << '%' << std::uppercase << std::setfill('0') << std::setw(2) << std::hex << (unsigned int)(unsigned char)c; + t = ss.str(); } else { - result << '%' << setw(2) << int((unsigned char) c); + ss << c; } } - return result.str(); + return ss.str(); } string urlDecode(const string& value) { diff --git a/test/tgbot/tools/StringTools.cpp b/test/tgbot/tools/StringTools.cpp index 86eb147..453919c 100644 --- a/test/tgbot/tools/StringTools.cpp +++ b/test/tgbot/tools/StringTools.cpp @@ -50,7 +50,7 @@ BOOST_AUTO_TEST_CASE(split) { BOOST_AUTO_TEST_CASE(urlEncode) { string t = StringTools::urlEncode("`1234567890-qwertyuiop[]\\asdfghjkl;'zxcvbnm,./~!@#$%^&*()_+QWERTYUIOP{}|ASDFGHJKL:ZXCVBNM<>? "); - string e = "%601234567890-qwertyuiop%5b%5d%5casdfghjkl%3b%27zxcvbnm%2c.%2f~%21%40%23%24%25%5e%26%2a%28%29_%2bQWERTYUIOP%7b%7d%7cASDFGHJKL%3aZXCVBNM%3c%3e%3f%20"; + string e = "%601234567890-qwertyuiop%5B%5D%5Casdfghjkl%3B%27zxcvbnm%2C.%2F~%21%40%23%24%25%5E%26%2A%28%29_%2BQWERTYUIOP%7B%7D%7CASDFGHJKL:ZXCVBNM%3C%3E%3F%20"; BOOST_CHECK_MESSAGE(t == e, diffS(t, e)); } -- cgit v1.2.3 From 19a83123e908e8d80b404d47ec843fa6f0d4a5a6 Mon Sep 17 00:00:00 2001 From: kukin-konstantin Date: Thu, 12 Jan 2017 18:01:49 +0300 Subject: fix parse Array error --- src/TgTypeParser.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/TgTypeParser.cpp b/src/TgTypeParser.cpp index 0952d75..f22a868 100644 --- a/src/TgTypeParser.cpp +++ b/src/TgTypeParser.cpp @@ -467,7 +467,8 @@ std::string TgTypeParser::parseReplyKeyboardMarkup(const ReplyKeyboardMarkup::Pt result.erase(result.length() - 1); result += "],"; } - result.erase(result.length() - 1); + if (!object->keyboard.empty()) + result.erase(result.length() - 1); result += "],"; appendToJson(result, "resize_keyboard", object->resizeKeyboard); appendToJson(result, "one_time_keyboard", object->oneTimeKeyboard); @@ -1329,7 +1330,8 @@ std::string TgTypeParser::parseInlineKeyboardMarkup(const InlineKeyboardMarkup:: result.erase(result.length() - 1); result += "],"; } - result.erase(result.length() - 1); + if (!object->inlineKeyboard.empty()) + result.erase(result.length() - 1); result += "]}"; return result; } -- cgit v1.2.3