From e252f0aa25bb7087698ed94698a91f9309e61460 Mon Sep 17 00:00:00 2001 From: JellyBrick Date: Fri, 22 Jun 2018 20:51:07 +0900 Subject: Resolved #48, Bot API 3.0 implementation done. --- src/Api.cpp | 142 +++++++++++++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 121 insertions(+), 21 deletions(-) (limited to 'src/Api.cpp') diff --git a/src/Api.cpp b/src/Api.cpp index e6c7c4b..cd9fac8 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 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& 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 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(&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 answerShippingQuery(const std::string& shippingQueryId, bool ok, const std::vector& shippingOptions, const std::string& errorMessage) const { + vector args; + args.reserve(4); + args.emplace_back("shipping_query_id", shippingQueryId); + args.emplace_back("ok", ok); + if (ShippingOptions != nullptr) { + args.emplace_back("shipping_options", TgTypeParser::getInstance().parseArray(&TgTypeParser::parseShippingOption, shippingOptions)); + } + if (!errorMessage.empty()) { + args.emplace_back("error_message", errorMessage); + } + return sendRequest("answerShippingQuery", args).get("", false); +} + +bool answerPreCheckoutQuery(const std::string& preCheckoutQueryId, bool ok, const std::string& errorMessage) const { + vector args; + args.reserve(3); + args.emplace_back("shipping_query_id", shippingQueryId); + args.emplace_back("ok", ok); + if (!errorMessage.empty()) { + args.emplace_back("error_message", errorMessage); + } + return sendRequest("answerPreCheckoutQuery", args).get("", false); +} + Message::Ptr Api::sendSticker(int64_t chatId, const InputFile::Ptr sticker, int32_t replyToMessageId, const GenericReply::Ptr replyMarkup, bool disableNotification) const { vector 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("", 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("", 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("", 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("", false); } @@ -848,16 +950,17 @@ vector 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 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( + } + if (allowedUpdates != nullptr) { + auto allowedUpdatesJson = TgTypeParser::getInstance().parseArray( [](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("", false); + return sendRequest("deleteWebhook").get("", 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("url","") != string("")) - { + } + if (p.get("url","") != string("")) { return TgTypeParser::getInstance().parseJsonAndGetWebhookInfo(p); } - else - { + else { return nullptr; } } -- cgit v1.2.3 From 531b376681830f57634a69c22df841f5ee5e2e23 Mon Sep 17 00:00:00 2001 From: JellyBrick Date: Fri, 22 Jun 2018 21:32:41 +0900 Subject: Fix typo --- src/Api.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) (limited to 'src/Api.cpp') diff --git a/src/Api.cpp b/src/Api.cpp index cd9fac8..de697df 100644 --- a/src/Api.cpp +++ b/src/Api.cpp @@ -229,7 +229,7 @@ Message::Ptr Api::sendDocument(int64_t chatId, const string& document, const str return TgTypeParser::getInstance().parseJsonAndGetMessage(sendRequest("sendDocument", args)); } -Message::Ptr sendInvoice(int64_t chatId, const std::string& title, const std::string& description, const std::string& payload, +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& prices, const std::string& providerData, const std::string& photoUrl, int32_t photoSize, int32_t photoWidth, int32_t photoHeight, bool needName, @@ -294,12 +294,12 @@ Message::Ptr sendInvoice(int64_t chatId, const std::string& title, const std::st return TgTypeParser::getInstance().parseJsonAndGetMessage(sendRequest("sendInvoice", args)); } -bool answerShippingQuery(const std::string& shippingQueryId, bool ok, const std::vector& shippingOptions, const std::string& errorMessage) const { +bool Api::answerShippingQuery(const std::string& shippingQueryId, bool ok, const std::vector& shippingOptions, const std::string& errorMessage) const { vector args; args.reserve(4); args.emplace_back("shipping_query_id", shippingQueryId); args.emplace_back("ok", ok); - if (ShippingOptions != nullptr) { + if (!shippingOptions.empty()) { args.emplace_back("shipping_options", TgTypeParser::getInstance().parseArray(&TgTypeParser::parseShippingOption, shippingOptions)); } if (!errorMessage.empty()) { @@ -308,10 +308,10 @@ bool answerShippingQuery(const std::string& shippingQueryId, bool ok, const std: return sendRequest("answerShippingQuery", args).get("", false); } -bool answerPreCheckoutQuery(const std::string& preCheckoutQueryId, bool ok, const std::string& errorMessage) const { +bool Api::answerPreCheckoutQuery(const std::string& preCheckoutQueryId, bool ok, const std::string& errorMessage) const { vector args; args.reserve(3); - args.emplace_back("shipping_query_id", shippingQueryId); + args.emplace_back("pre_checkout_query_id", preCheckoutQueryId); args.emplace_back("ok", ok); if (!errorMessage.empty()) { args.emplace_back("error_message", errorMessage); -- cgit v1.2.3 From fea0c2ffb669923959df17ba904448e159d22489 Mon Sep 17 00:00:00 2001 From: JellyBrick Date: Fri, 22 Jun 2018 21:44:52 +0900 Subject: Fix typo (std::vector contains Object::Ptr) Thanks VSCode --- src/Api.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'src/Api.cpp') diff --git a/src/Api.cpp b/src/Api.cpp index de697df..e6a39d7 100644 --- a/src/Api.cpp +++ b/src/Api.cpp @@ -230,7 +230,7 @@ Message::Ptr Api::sendDocument(int64_t chatId, const string& document, const str } 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& prices, + const std::string& providerToken, const std::string& startParameter, const std::string& currency, const std::vector& 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, @@ -294,7 +294,7 @@ Message::Ptr Api::sendInvoice(int64_t chatId, const std::string& title, const st return TgTypeParser::getInstance().parseJsonAndGetMessage(sendRequest("sendInvoice", args)); } -bool Api::answerShippingQuery(const std::string& shippingQueryId, bool ok, const std::vector& shippingOptions, const std::string& errorMessage) const { +bool Api::answerShippingQuery(const std::string& shippingQueryId, bool ok, const std::vector& shippingOptions, const std::string& errorMessage) const { vector args; args.reserve(4); args.emplace_back("shipping_query_id", shippingQueryId); -- cgit v1.2.3 From 8cdd0f4551e6d3d22c4fc753fb20e82918a43090 Mon Sep 17 00:00:00 2001 From: JellyBrick Date: Fri, 22 Jun 2018 22:02:23 +0900 Subject: Resolved #42 --- src/Api.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'src/Api.cpp') diff --git a/src/Api.cpp b/src/Api.cpp index e6a39d7..3d8d3f6 100644 --- a/src/Api.cpp +++ b/src/Api.cpp @@ -245,7 +245,7 @@ Message::Ptr Api::sendInvoice(int64_t chatId, const std::string& title, const st args.emplace_back("provider_token", providerToken); args.emplace_back("start_parameter", startParameter); args.emplace_back("currency", currency); - args.emplace_back("prices", TgTypeParser::getInstance().parseArray(&TgTypeParser::parseLabeledPrice, prices); + args.emplace_back("prices", TgTypeParser::getInstance().parseArray(&TgTypeParser::parseLabeledPrice, prices)); if (!providerData.empty()) { args.emplace_back("provider_data", providerData); } -- cgit v1.2.3