summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/Api.cpp142
-rw-r--r--src/TgTypeParser.cpp124
2 files changed, 188 insertions, 78 deletions
diff --git a/src/Api.cpp b/src/Api.cpp
index e6c7c4b..3d8d3f6 100644
--- a/src/Api.cpp
+++ b/src/Api.cpp
@@ -229,6 +229,96 @@ Message::Ptr Api::sendDocument(int64_t chatId, const string& document, const str
return TgTypeParser::getInstance().parseJsonAndGetMessage(sendRequest("sendDocument", args));
}
+Message::Ptr Api::sendInvoice(int64_t chatId, const std::string& title, const std::string& description, const std::string& payload,
+ const std::string& providerToken, const std::string& startParameter, const std::string& currency, const std::vector<LabeledPrice::Ptr>& prices,
+ const std::string& providerData, const std::string& photoUrl, int32_t photoSize,
+ int32_t photoWidth, int32_t photoHeight, bool needName,
+ bool needPhoneNumber, bool needEmail, bool needShippingAddress,
+ bool sendPhoneNumberToProvider, bool sendEmailToProvider, bool isFlexible,
+ int32_t replyToMessageId, const GenericReply::Ptr replyMarkup, bool disableNotification) const {
+ vector<HttpReqArg> args;
+ args.reserve(23);
+ args.emplace_back("chat_id", chatId);
+ args.emplace_back("title", title);
+ args.emplace_back("description", description);
+ args.emplace_back("payload", payload);
+ args.emplace_back("provider_token", providerToken);
+ args.emplace_back("start_parameter", startParameter);
+ args.emplace_back("currency", currency);
+ args.emplace_back("prices", TgTypeParser::getInstance().parseArray<LabeledPrice>(&TgTypeParser::parseLabeledPrice, prices));
+ if (!providerData.empty()) {
+ args.emplace_back("provider_data", providerData);
+ }
+ if (!photoUrl.empty()) {
+ args.emplace_back("photo_url", photoUrl);
+ }
+ if (photoSize) {
+ args.emplace_back("photo_size", photoSize);
+ }
+ if (photoWidth) {
+ args.emplace_back("photo_width", photoWidth);
+ }
+ if (photoHeight) {
+ args.emplace_back("photo_height", photoHeight);
+ }
+ if (needName) {
+ args.emplace_back("need_name", needName);
+ }
+ if (needPhoneNumber) {
+ args.emplace_back("need_phone_number", needPhoneNumber);
+ }
+ if (needEmail) {
+ args.emplace_back("need_email", needEmail);
+ }
+ if (needShippingAddress) {
+ args.emplace_back("need_shipping_address", needShippingAddress);
+ }
+ if (sendPhoneNumberToProvider) {
+ args.emplace_back("send_phone_number_to_provider", sendPhoneNumberToProvider);
+ }
+ if (sendEmailToProvider) {
+ args.emplace_back("send_email_to_provider", sendEmailToProvider);
+ }
+ if (isFlexible) {
+ args.emplace_back("is_flexible", isFlexible);
+ }
+ if (replyToMessageId) {
+ args.emplace_back("reply_to_message_id", replyToMessageId);
+ }
+ if (replyMarkup) {
+ args.emplace_back("reply_markup", TgTypeParser::getInstance().parseGenericReply(replyMarkup));
+ }
+ if (disableNotification){
+ args.emplace_back("disable_notification", disableNotification);
+ }
+ return TgTypeParser::getInstance().parseJsonAndGetMessage(sendRequest("sendInvoice", args));
+}
+
+bool Api::answerShippingQuery(const std::string& shippingQueryId, bool ok, const std::vector<ShippingOption::Ptr>& shippingOptions, const std::string& errorMessage) const {
+ vector<HttpReqArg> args;
+ args.reserve(4);
+ args.emplace_back("shipping_query_id", shippingQueryId);
+ args.emplace_back("ok", ok);
+ if (!shippingOptions.empty()) {
+ args.emplace_back("shipping_options", TgTypeParser::getInstance().parseArray<ShippingOption>(&TgTypeParser::parseShippingOption, shippingOptions));
+ }
+ if (!errorMessage.empty()) {
+ args.emplace_back("error_message", errorMessage);
+ }
+ return sendRequest("answerShippingQuery", args).get<bool>("", false);
+}
+
+bool Api::answerPreCheckoutQuery(const std::string& preCheckoutQueryId, bool ok, const std::string& errorMessage) const {
+ vector<HttpReqArg> args;
+ args.reserve(3);
+ args.emplace_back("pre_checkout_query_id", preCheckoutQueryId);
+ args.emplace_back("ok", ok);
+ if (!errorMessage.empty()) {
+ args.emplace_back("error_message", errorMessage);
+ }
+ return sendRequest("answerPreCheckoutQuery", args).get<bool>("", false);
+}
+
Message::Ptr Api::sendSticker(int64_t chatId, const InputFile::Ptr sticker, int32_t replyToMessageId, const GenericReply::Ptr replyMarkup, bool disableNotification) const {
vector<HttpReqArg> args;
args.reserve(5);
@@ -286,8 +376,12 @@ bool Api::createNewStickerSet(int32_t userId, const string& name, const string&
args.emplace_back("title", title);
args.emplace_back("png_sticker", pngSticker->data, true, pngSticker->mimeType, pngSticker->fileName);
args.emplace_back("emojis", emojis);
- args.emplace_back("contains_mask", containsMasks);
- args.emplace_back("mask_position", TgTypeParser::getInstance().parseMaskPosition(maskPosition));
+ if (containsMasks) {
+ args.emplace_back("contains_mask", containsMasks);
+ }
+ if (maskPosition != nullptr) {
+ args.emplace_back("mask_position", TgTypeParser::getInstance().parseMaskPosition(maskPosition));
+ }
return sendRequest("createNewStickerSet", args).get<bool>("", false);
}
@@ -299,8 +393,12 @@ bool Api::createNewStickerSet(int32_t userId, const string& name, const string&
args.emplace_back("title", title);
args.emplace_back("png_sticker", pngSticker);
args.emplace_back("emojis", emojis);
- args.emplace_back("contains_mask", containsMasks);
- args.emplace_back("mask_position", TgTypeParser::getInstance().parseMaskPosition(maskPosition));
+ if (containsMasks) {
+ args.emplace_back("contains_mask", containsMasks);
+ }
+ if (maskPosition != nullptr) {
+ args.emplace_back("mask_position", TgTypeParser::getInstance().parseMaskPosition(maskPosition));
+ }
return sendRequest("createNewStickerSet", args).get<bool>("", false);
}
@@ -312,7 +410,9 @@ bool Api::addStickerToSet(int32_t userId, const string& name, const string& titl
args.emplace_back("title", title);
args.emplace_back("png_sticker", pngSticker->data, true, pngSticker->mimeType, pngSticker->fileName);
args.emplace_back("emojis", emojis);
- args.emplace_back("mask_position", TgTypeParser::getInstance().parseMaskPosition(maskPosition));
+ if (maskPosition != nullptr) {
+ args.emplace_back("mask_position", TgTypeParser::getInstance().parseMaskPosition(maskPosition));
+ }
return sendRequest("addStickerToSet", args).get<bool>("", false);
}
@@ -324,7 +424,9 @@ bool Api::addStickerToSet(int32_t userId, const string& name, const string& titl
args.emplace_back("title", title);
args.emplace_back("png_sticker", pngSticker);
args.emplace_back("emojis", emojis);
- args.emplace_back("mask_position", TgTypeParser::getInstance().parseMaskPosition(maskPosition));
+ if (maskPosition != nullptr) {
+ args.emplace_back("mask_position", TgTypeParser::getInstance().parseMaskPosition(maskPosition));
+ }
return sendRequest("addStickerToSet", args).get<bool>("", false);
}
@@ -848,16 +950,17 @@ vector<Update::Ptr> Api::getUpdates(int32_t offset, int32_t limit, int32_t timeo
void Api::setWebhook(const string& url, const InputFile::Ptr certificate, int32_t maxConnection, const StringArrayPtr &allowedUpdates) const {
vector<HttpReqArg> args;
args.reserve(4);
- if (!url.empty())
+ if (!url.empty()) {
args.emplace_back("url", url);
- if (certificate != nullptr)
+ }
+ if (certificate != nullptr) {
args.emplace_back("certificate", certificate->data, true, certificate->mimeType, certificate->fileName);
- if (maxConnection != 40)
+ }
+ if (maxConnection != 40) {
args.emplace_back("max_connections", maxConnection);
-
- if (allowedUpdates != nullptr)
- {
- string allowedUpdatesJson = TgTypeParser::getInstance().parseArray<string>(
+ }
+ if (allowedUpdates != nullptr) {
+ auto allowedUpdatesJson = TgTypeParser::getInstance().parseArray<string>(
[](const string &s)->string {
return s;
}, *allowedUpdates);
@@ -868,22 +971,19 @@ void Api::setWebhook(const string& url, const InputFile::Ptr certificate, int32_
}
bool Api::deleteWebhook() const {
- ptree p = sendRequest("deleteWebhook");
- return p.get<bool>("", false);
+ return sendRequest("deleteWebhook").get<bool>("", false);
}
WebhookInfo::Ptr Api::getWebhookInfo() const {
ptree p = sendRequest("getWebhookInfo");
- if (!p.get_child_optional("url"))
+ 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);
}
- else
- {
+ else {
return nullptr;
}
}
diff --git a/src/TgTypeParser.cpp b/src/TgTypeParser.cpp
index ca7547d..4eaeaea 100644
--- a/src/TgTypeParser.cpp
+++ b/src/TgTypeParser.cpp
@@ -80,7 +80,7 @@ string TgTypeParser::parseChat(const Chat::Ptr& object) const {
appendToJson(result, "username", object->username);
appendToJson(result, "first_name", object->firstName);
appendToJson(result, "last_name", object->lastName);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -108,7 +108,7 @@ 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);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -134,7 +134,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));
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -177,6 +177,8 @@ Message::Ptr TgTypeParser::parseJsonAndGetMessage(const ptree& data) const {
result->migrateToChatId = data.get<int64_t>("migrate_to_chat_id", 0);
result->migrateFromChatId = data.get<int64_t>("migrate_from_chat_id", 0);
result->pinnedMessage = tryParseJson<Message>(&TgTypeParser::parseJsonAndGetMessage, data, "pinned_message");
+ result->invoice = tryParseJson<Invoice>(&TgTypeParser::parseJsonAndGetInvoice, data, "invoice");
+ result->successfulPayment = tryParseJson<SuccessfulPayment>(&TgTypeParser::parseJsonAndGetSuccessfulPayment, data, "successful_payment");
result->connectedWebsite = data.get("connected_website", "");
return result;
}
@@ -221,7 +223,9 @@ string TgTypeParser::parseMessage(const Message::Ptr& object) const {
appendToJson(result, "migrate_from_chat_id", object->migrateFromChatId);
appendToJson(result, "pinned_message", parseMessage(object->pinnedMessage));
appendToJson(result, "connected_website", object->connectedWebsite);
- result.erase(result.length() - 1);
+ appendToJson(result, "invoice", parseInvoice(object->invoice));
+ appendToJson(result, "successful_payment", parseSuccessfulPayment(object->successfulPayment));
+ removeLastComma(result);
result += '}';
return result;
}
@@ -245,7 +249,7 @@ string TgTypeParser::parsePhotoSize(const PhotoSize::Ptr& object) const {
appendToJson(result, "width", object->width);
appendToJson(result, "height", object->height);
appendToJson(result, "file_size", object->fileSize);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -271,7 +275,7 @@ string TgTypeParser::parseAudio(const Audio::Ptr& object) const {
appendToJson(result, "duration", object->duration);
appendToJson(result, "mime_type", object->mimeType);
appendToJson(result, "file_size", object->fileSize);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -297,7 +301,7 @@ string TgTypeParser::parseDocument(const Document::Ptr& object) const {
appendToJson(result, "file_name", object->fileName);
appendToJson(result, "mime_type", object->mimeType);
appendToJson(result, "file_size", object->fileSize);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -327,7 +331,7 @@ string TgTypeParser::parseSticker(const Sticker::Ptr& object) const {
appendToJson(result, "thumb", parsePhotoSize(object->thumb));
appendToJson(result, "emoji", object->emoji);
appendToJson(result, "file_size", object->fileSize);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -351,7 +355,7 @@ string TgTypeParser::parseStickerSet(const StickerSet::Ptr& object) const {
appendToJson(result, "title", object->title);
appendToJson(result, "contains_masks", object->containsMasks);
appendToJson(result, "stickers", parseArray(&TgTypeParser::parseSticker, object->stickers));
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -375,7 +379,7 @@ string TgTypeParser::parseMaskPosition(const MaskPosition::Ptr& object) const {
appendToJson(result, "x_shift", object->xShift);
appendToJson(result, "y_shift", object->yShift);
appendToJson(result, "scale", object->scale);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -405,7 +409,7 @@ string TgTypeParser::parseVideo(const Video::Ptr& object) const {
appendToJson(result, "thumb", parsePhotoSize(object->thumb));
appendToJson(result, "mime_type", object->mimeType);
appendToJson(result, "file_size", object->fileSize);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -459,7 +463,7 @@ string TgTypeParser::parseGame(const Game::Ptr& object) const {
appendToJson(result, "text", object->text);
appendToJson(result, "text_entities", parseArray(&TgTypeParser::parseMessageEntity, object->textEntities));
appendToJson(result, "animation", parseAnimation(object->animation));
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -481,7 +485,7 @@ string TgTypeParser::parseGameHighScore(const GameHighScore::Ptr& object) const
appendToJson(result, "position", object->position);
appendToJson(result, "user", parseUser(object->user));
appendToJson(result, "score", object->score);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -507,7 +511,7 @@ string TgTypeParser::parseAnimation(const Animation::Ptr& object) const {
appendToJson(result, "file_name", object->fileName);
appendToJson(result, "mime_type", object->mimeType);
appendToJson(result, "file_size", object->fileSize);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -531,7 +535,7 @@ string TgTypeParser::parseContact(const Contact::Ptr& object) const {
appendToJson(result, "first_name", object->firstName);
appendToJson(result, "last_name", object->lastName);
appendToJson(result, "user_id", object->userId);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -551,7 +555,7 @@ string TgTypeParser::parseLocation(const Location::Ptr& object) const {
result += '{';
appendToJson(result, "longitude", object->longitude);
appendToJson(result, "latitude", object->latitude);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -566,6 +570,8 @@ Update::Ptr TgTypeParser::parseJsonAndGetUpdate(const ptree& data) const {
result->inlineQuery = tryParseJson<InlineQuery>(&TgTypeParser::parseJsonAndGetInlineQuery, data, "inline_query");
result->chosenInlineResult = tryParseJson<ChosenInlineResult>(&TgTypeParser::parseJsonAndGetChosenInlineResult, data, "chosen_inline_result");
result->callbackQuery = tryParseJson<CallbackQuery>(&TgTypeParser::parseJsonAndGetCallbackQuery, data, "callback_query");
+ result->shippingQuery = tryParseJson<ShippingQuery>(&TgTypeParser::parseJsonAndGetShippingQuery, data, "shipping_query");
+ result->preCheckoutQuery = tryParseJson<PreCheckoutQuery>(&TgTypeParser::parseJsonAndGetPreCheckoutQuery, data, "pre_checkout_query");
return result;
}
@@ -583,7 +589,9 @@ string TgTypeParser::parseUpdate(const Update::Ptr& object) const {
appendToJson(result, "inline_query", parseInlineQuery(object->inlineQuery));
appendToJson(result, "chosen_inline_result", parseChosenInlineResult(object->chosenInlineResult));
appendToJson(result, "callback_query", parseCallbackQuery(object->callbackQuery));
- result.erase(result.length() - 1);
+ appendToJson(result, "shipping_query", parseShippingQuery(object->shippingQuery));
+ appendToJson(result, "pre_checkout_query", parsePreCheckoutQuery(object->preCheckoutQuery));
+ removeLastComma(result);
result += '}';
return result;
}
@@ -603,7 +611,7 @@ string TgTypeParser::parseUserProfilePhotos(const UserProfilePhotos::Ptr& object
result += '{';
appendToJson(result, "total_count", object->totalCount);
appendToJson(result, "photos", parse2DArray(&TgTypeParser::parsePhotoSize, object->photos));
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -660,7 +668,7 @@ string TgTypeParser::parseInputMedia(const InputMedia::Ptr& object) const {
if (object->supportsStreaming) {
appendToJson(result, "supports_streaming", object->supportsStreaming);
}
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -682,14 +690,14 @@ string TgTypeParser::parseFile(const File::Ptr& object) const {
appendToJson(result, "file_id", object->fileId);
appendToJson(result, "file_size", object->fileSize);
appendToJson(result, "file_path", object->filePath);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
ReplyKeyboardMarkup::Ptr TgTypeParser::parseJsonAndGetReplyKeyboardMarkup(const boost::property_tree::ptree& data) const {
auto result(make_shared<ReplyKeyboardMarkup>());
- for (const boost::property_tree::ptree::value_type& item : data.find("keyboard")->second){
+ for (const auto& item : data.find("keyboard")->second){
result->keyboard.push_back(parseJsonAndGetArray<KeyboardButton>(&TgTypeParser::parseJsonAndGetKeyboardButton, item.second));
}
result->resizeKeyboard = data.get<bool>("resize_keyboard", false);
@@ -704,23 +712,23 @@ std::string TgTypeParser::parseReplyKeyboardMarkup(const ReplyKeyboardMarkup::Pt
}
string result;
result += '{';
- result += "\"keyboard\":[";
- for (vector<KeyboardButton::Ptr>& item : object->keyboard) {
+ result += R"("keyboard":[)";
+ for (const auto& item : object->keyboard) {
result += '[';
- for (KeyboardButton::Ptr& innerItem : item) {
+ for (const auto& innerItem : item) {
result += parseKeyboardButton(innerItem);
result += ',';
}
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += "],";
}
if (!object->keyboard.empty())
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += "],";
appendToJson(result, "resize_keyboard", object->resizeKeyboard);
appendToJson(result, "one_time_keyboard", object->oneTimeKeyboard);
appendToJson(result, "selective", object->selective);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -742,7 +750,7 @@ 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);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -761,7 +769,7 @@ std::string TgTypeParser::parseReplyKeyboardRemove(const ReplyKeyboardRemove::Pt
result += '{';
appendToJson(result, "remove_keyboard", object->removeKeyboard);
appendToJson(result, "selective", object->selective);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -780,7 +788,7 @@ std::string TgTypeParser::parseForceReply(const ForceReply::Ptr& object) const {
result += '{';
appendToJson(result, "force_reply", object->forceReply);
appendToJson(result, "selective", object->selective);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -814,7 +822,7 @@ std::string TgTypeParser::parseChatMember(const ChatMember::Ptr& object) const {
result += '{';
appendToJson(result, "user", parseUser(object->user));
appendToJson(result, "status", object->status);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -834,7 +842,7 @@ std::string TgTypeParser::parseChatPhoto(const ChatPhoto::Ptr& object) const {
result += '{';
appendToJson(result, "small_file_id", object->smallFileId);
appendToJson(result, "big_file_id", object->bigFileId);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -854,7 +862,7 @@ std::string TgTypeParser::parseResponseParameters(const ResponseParameters::Ptr&
result += '{';
appendToJson(result, "migrate_to_chat_id", object->migrateToChatId);
appendToJson(result, "retry_after", object->retryAfter);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -910,7 +918,7 @@ std::string TgTypeParser::parseInlineQuery(const InlineQuery::Ptr& object) const
appendToJson(result, "location", parseLocation(object->location));
appendToJson(result, "query", object->query);
appendToJson(result, "offset", object->offset);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1047,7 +1055,7 @@ std::string TgTypeParser::parseInlineQueryResult(const InlineQueryResult::Ptr& o
result += parseInlineQueryResultVideo(static_pointer_cast<InlineQueryResultVideo>(object));
}
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1557,7 +1565,7 @@ std::string TgTypeParser::parseChosenInlineResult(const ChosenInlineResult::Ptr&
appendToJson(result, "result_id", object->resultId);
appendToJson(result, "from", parseUser(object->from));
appendToJson(result, "query", object->query);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1588,14 +1596,14 @@ std::string TgTypeParser::parseCallbackQuery(const CallbackQuery::Ptr& object) c
appendToJson(result, "chat_instance", object->chatInstance);
appendToJson(result, "game_short_name", object->gameShortName);
appendToJson(result, "data", object->data);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
InlineKeyboardMarkup::Ptr TgTypeParser::parseJsonAndGetInlineKeyboardMarkup(const boost::property_tree::ptree& data) const {
auto result(make_shared<InlineKeyboardMarkup>());
- for (const boost::property_tree::ptree::value_type& item : data.find("inline_keyboard")->second){
+ for (const auto& item : data.find("inline_keyboard")->second){
result->inlineKeyboard.push_back(parseJsonAndGetArray<InlineKeyboardButton>(&TgTypeParser::parseJsonAndGetInlineKeyboardButton, item.second));
}
return result;
@@ -1607,18 +1615,18 @@ std::string TgTypeParser::parseInlineKeyboardMarkup(const InlineKeyboardMarkup::
}
string result;
result += '{';
- result += "\"inline_keyboard\":[";
- for (vector<InlineKeyboardButton::Ptr>& item : object->inlineKeyboard){
+ result += R"("inline_keyboard":[)";
+ for (const auto& item : object->inlineKeyboard){
result += '[';
- for (InlineKeyboardButton::Ptr& innerItem : item){
+ for (const auto& innerItem : item){
result += parseInlineKeyboardButton(innerItem);
result += ',';
}
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += "],";
}
if (!object->inlineKeyboard.empty())
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += "]}";
return result;
}
@@ -1631,6 +1639,7 @@ InlineKeyboardButton::Ptr TgTypeParser::parseJsonAndGetInlineKeyboardButton(cons
result->switchInlineQuery = data.get<string>("switch_inline_query", "");
result->switchInlineQueryCurrentChat = data.get<string>("switch_inline_query_current_chat", "");
result->callbackGame = make_shared<CallbackGame>();
+ result->pay = data.get<bool>("pay", false);
return result;
}
std::string TgTypeParser::parseInlineKeyboardButton(const InlineKeyboardButton::Ptr& object) const {
@@ -1644,7 +1653,8 @@ std::string TgTypeParser::parseInlineKeyboardButton(const InlineKeyboardButton::
appendToJson(result, "callback_data", object->callbackData);
appendToJson(result, "switch_inline_query", object->switchInlineQuery);
appendToJson(result, "switch_inline_query_current_chat", object->switchInlineQueryCurrentChat);
- result.erase(result.length() - 1);
+ appendToJson(result, "pay", object->pay);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1682,7 +1692,7 @@ std::string TgTypeParser::parseWebhookInfo(const WebhookInfo::Ptr& object) const
return s;
}
, object->allowedUpdates));
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1730,7 +1740,7 @@ std::string TgTypeParser::parseInputMessageContent(const InputMessageContent::Pt
result += parseInputContactMessageContent(static_pointer_cast<InputContactMessageContent>(object));
}
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1846,7 +1856,7 @@ std::string TgTypeParser::parseInvoice(const Invoice::Ptr& object) const {
appendToJson(result, "start_parameter", object->startParameter);
appendToJson(result, "currency", object->currency);
appendToJson(result, "total_amount", object->totalAmount);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1863,7 +1873,7 @@ string TgTypeParser::parseLabeledPrice(const LabeledPrice::Ptr& object) const {
result += '{';
appendToJson(result, "label", object->label);
appendToJson(result, "amount", object->amount);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1897,7 +1907,7 @@ string TgTypeParser::parseOrderInfo(const OrderInfo::Ptr& object) const {
result += parseShippingAddress(object->shippingAddress);
result += ",";
}
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1920,7 +1930,7 @@ string TgTypeParser::parsePreCheckoutQuery(const PreCheckoutQuery::Ptr& object)
result += ",";
appendToJson(result, "currency", object->currency);
appendToJson(result, "total_amount", object->totalAmount);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1947,7 +1957,7 @@ string TgTypeParser::parseShippingAddress(const ShippingAddress::Ptr& object) co
appendToJson(result, "street_line1", object->streetLine1);
appendToJson(result, "street_line2", object->streetLine2);
appendToJson(result, "post_code", object->postCode);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -1965,7 +1975,7 @@ string TgTypeParser::parseShippingOption(const ShippingOption::Ptr& object) cons
result += '{';
appendToJson(result, "id", object->id);
appendToJson(result, "title", object->title);
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += R"("prices":)";
result += parseArray(&TgTypeParser::parseLabeledPrice, object->prices);
result += '}';
@@ -1992,12 +2002,12 @@ string TgTypeParser::parseShippingQuery(const ShippingQuery::Ptr& object) const
result += R"("shipping_address":)";
result += parseShippingAddress(object->shippingAddress);
result += ",";
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
-SuccessfulPayment::Ptr TgTypeParser::parseJsonAndGetSucessfulPayment(const boost::property_tree::ptree& data) const {
+SuccessfulPayment::Ptr TgTypeParser::parseJsonAndGetSuccessfulPayment(const boost::property_tree::ptree& data) const {
auto result(make_shared<SuccessfulPayment>());
result->currency = data.get<string>("currency");
result->totalAmount = data.get<int32_t>("total_amount");
@@ -2007,7 +2017,7 @@ SuccessfulPayment::Ptr TgTypeParser::parseJsonAndGetSucessfulPayment(const boost
return result;
}
-std::string TgTypeParser::parseSucessfulPayment(const SuccessfulPayment::Ptr& object) const {
+std::string TgTypeParser::parseSuccessfulPayment(const SuccessfulPayment::Ptr& object) const {
string result;
result += '{';
appendToJson(result, "currency", object->currency);
@@ -2017,7 +2027,7 @@ std::string TgTypeParser::parseSucessfulPayment(const SuccessfulPayment::Ptr& ob
result += R"("order_info":)";
result += parseOrderInfo(object->orderInfo);
result += ",";
- result.erase(result.length() - 1);
+ removeLastComma(result);
result += '}';
return result;
}
@@ -2029,7 +2039,7 @@ void TgTypeParser::appendToJson(string& json, const string& varName, const strin
}
json += '"';
json += varName;
- json += "\":";
+ json += R"(":)";
if (value.front() != '{') {
json += '"';
}