From 45f46c60f6253a4b7c0cebf047983dd7cfce1683 Mon Sep 17 00:00:00 2001 From: Andrea Giove Date: Wed, 6 Apr 2016 18:26:16 +0200 Subject: Added certificate to setWebhook method --- include/tgbot/Api.h | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) (limited to 'include') diff --git a/include/tgbot/Api.h b/include/tgbot/Api.h index 66f41b5..68b8462 100644 --- a/include/tgbot/Api.h +++ b/include/tgbot/Api.h @@ -230,8 +230,7 @@ public: * Ports currently supported for Webhooks: 443, 80, 88, 8443. * @param url Optional. HTTPS url to send updates to. Use an empty string to remove webhook integration. */ - // TODO Add support to self-signed certificate - void setWebhook(const std::string& url = "") const; + void setWebhook(const std::string& url = "", const InputFile::Ptr& certificate = nullptr) const; /** * Use this method to send answers to an inline query. -- cgit v1.2.3 From abbd611b34ccb5f77c1c28160294f1481c9479c2 Mon Sep 17 00:00:00 2001 From: Andrea Giove Date: Sat, 16 Apr 2016 22:23:38 +0200 Subject: Added the disable_method parameter to all methods --- include/tgbot/Api.h | 51 ++++++++++++++++++++++++++++++++++++++------------- 1 file changed, 38 insertions(+), 13 deletions(-) (limited to 'include') diff --git a/include/tgbot/Api.h b/include/tgbot/Api.h index 68b8462..0670ea0 100644 --- a/include/tgbot/Api.h +++ b/include/tgbot/Api.h @@ -65,18 +65,21 @@ public: * @param disableWebPagePreview Optional. Disables link previews for links in this message. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendMessage(int64_t chatId, const std::string& text, bool disableWebPagePreview = false, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendMessage(int64_t chatId, const std::string& text, bool disableWebPagePreview = false, + int32_t replyToMessageId = 0,const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to forward messages of any kind. * @param chatId Unique identifier for the target chat. * @param fromChatId Unique identifier for the chat where the original message was sent — User or GroupChat id. * @param messageId Unique message identifier. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr forwardMessage(int64_t chatId, int64_t fromChatId, int32_t messageId) const; + Message::Ptr forwardMessage(int64_t chatId, int64_t fromChatId, int32_t messageId, bool disableNotification = false) const; /** * Use this method to send photos. @@ -85,9 +88,11 @@ public: * @param caption Optional. Photo caption. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendPhoto(int64_t chatId, const InputFile::Ptr& photo, const std::string& caption = "", int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendPhoto(int64_t chatId, const InputFile::Ptr& photo, const std::string& caption = "", int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send photos. @@ -96,9 +101,11 @@ public: * @param caption Optional. Photo caption. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendPhoto(int64_t chatId, const std::string& photoId, const std::string& caption = "", int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendPhoto(int64_t chatId, const std::string& photoId, const std::string& caption = "", int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. For this to work, your audio must be in an .ogg file encoded with OPUS (other formats may be sent as Document). @@ -107,9 +114,11 @@ public: * @param duration Duration of sent audio in seconds. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendAudio(int64_t chatId, const InputFile::Ptr& audio, int32_t duration = 0, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendAudio(int64_t chatId, const InputFile::Ptr& audio, int32_t duration = 0, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. For this to work, your audio must be in an .ogg file encoded with OPUS (other formats may be sent as Document). @@ -118,9 +127,11 @@ public: * @param duration Duration of sent audio in seconds. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendAudio(int64_t chatId, const std::string& audioId, int32_t duration = 0, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendAudio(int64_t chatId, const std::string& audioId, int32_t duration = 0, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send general files. @@ -128,9 +139,11 @@ public: * @param document Document to send. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendDocument(int64_t chatId, const InputFile::Ptr& document, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendDocument(int64_t chatId, const InputFile::Ptr& document, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send general files. @@ -138,9 +151,11 @@ public: * @param document Id of the document that is already on the Telegram servers. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendDocument(int64_t chatId, const std::string& documentId, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendDocument(int64_t chatId, const std::string& documentId, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send .webp stickers. @@ -148,9 +163,11 @@ public: * @param sticker Sticker to send. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendSticker(int64_t chatId, const InputFile::Ptr& sticker, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendSticker(int64_t chatId, const InputFile::Ptr& sticker, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send .webp stickers. @@ -158,9 +175,11 @@ public: * @param sticker Id of the sticker that is already on the Telegram servers. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendSticker(int64_t chatId, const std::string& stickerId, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendSticker(int64_t chatId, const std::string& stickerId, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send video files, Telegram clients support mp4 videos (other formats may be sent as Document). @@ -168,9 +187,11 @@ public: * @param video Video to send. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendVideo(int64_t chatId, const InputFile::Ptr& video, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendVideo(int64_t chatId, const InputFile::Ptr& video, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send video files, Telegram clients support mp4 videos (other formats may be sent as Document). @@ -178,9 +199,11 @@ public: * @param video Id of the video that is already on the Telegram servers. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendVideo(int64_t chatId, const std::string& videoId, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendVideo(int64_t chatId, const std::string& videoId, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method to send point on the map. @@ -189,9 +212,11 @@ public: * @param longitude Longitude of location. * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendLocation(int64_t chatId, float latitude, float longitude, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + Message::Ptr sendLocation(int64_t chatId, float latitude, float longitude, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** * Use this method when you need to tell the user that something is happening on the bot's side. The status is set for 5 seconds or less (when a message arrives from your bot, Telegram clients clear its typing status). -- cgit v1.2.3 From 730407e8df5031d19a097be4e3e597f2f3b868fd Mon Sep 17 00:00:00 2001 From: Andrea Giove Date: Sat, 16 Apr 2016 22:38:00 +0200 Subject: Added sendVoice method and update sendAudio method --- include/tgbot/Api.h | 36 ++++++++++++++++++++++++++++++++++-- 1 file changed, 34 insertions(+), 2 deletions(-) (limited to 'include') diff --git a/include/tgbot/Api.h b/include/tgbot/Api.h index 0670ea0..d7cfc0e 100644 --- a/include/tgbot/Api.h +++ b/include/tgbot/Api.h @@ -112,12 +112,15 @@ public: * @param chatId Unique identifier for the target chat. * @param audio Audio to send. * @param duration Duration of sent audio in seconds. + * @param performer Performer + * @param title Track name * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendAudio(int64_t chatId, const InputFile::Ptr& audio, int32_t duration = 0, int32_t replyToMessageId = 0, + Message::Ptr sendAudio(int64_t chatId, const InputFile::Ptr& audio, int32_t duration = 0, + const std::string& performer = "", const std::string& title = "", int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** @@ -125,12 +128,15 @@ public: * @param chatId Unique identifier for the target chat. * @param audio Id of the audio that is already on the Telegram servers. * @param duration Duration of sent audio in seconds. + * @param performer Performer + * @param title Track name * @param replyToMessageId Optional. If the message is a reply, ID of the original message. * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendAudio(int64_t chatId, const std::string& audioId, int32_t duration = 0, int32_t replyToMessageId = 0, + Message::Ptr sendAudio(int64_t chatId, const std::string& audioId, int32_t duration = 0, + const std::string& performer = "", const std::string& title = "", int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; /** @@ -205,6 +211,32 @@ public: Message::Ptr sendVideo(int64_t chatId, const std::string& videoId, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + /** + * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. + * @param chatId Unique identifier for the target chat. + * @param voice Audio file to send. + * @param duration Duration of send audio in seconds. + * @param replyToMessageId Optional. If the message is a reply, ID of the original message. + * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. + * @return On success, the sent message is returned. + */ + Message::Ptr sendVoice(int64_t chatId, const InputFile::Ptr& voice, int duration = 0, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + + /** + * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. + * @param chatId Unique identifier for the target chat. + * @param voiceId Id of the voice that is already on the Telegram servers. + * @param duration Duration of send audio in seconds. + * @param replyToMessageId Optional. If the message is a reply, ID of the original message. + * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. + * @return On success, the sent message is returned. + */ + Message::Ptr sendVoice(int64_t chatId, const std::string& voiceId, int duration = 0, int32_t replyToMessageId = 0, + const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + /** * Use this method to send point on the map. * @param chatId Unique identifier for the target chat. -- cgit v1.2.3 From d134bf795a293a641655630bdd8ad44b5b70c1ae Mon Sep 17 00:00:00 2001 From: Andrea Giove Date: Sun, 17 Apr 2016 21:10:23 +0200 Subject: Added implementation to Inline Keyboard and added a new event broadcaster --- include/tgbot/EventBroadcaster.h | 19 +++++++++++ include/tgbot/EventHandler.h | 2 ++ include/tgbot/TgTypeParser.h | 9 ++++++ include/tgbot/types/CallbackQuery.h | 52 ++++++++++++++++++++++++++++++ include/tgbot/types/InlineKeyboardButton.h | 43 ++++++++++++++++++++++++ include/tgbot/types/InlineKeyboardMarkup.h | 32 ++++++++++++++++++ include/tgbot/types/Update.h | 6 ++++ 7 files changed, 163 insertions(+) create mode 100644 include/tgbot/types/CallbackQuery.h create mode 100644 include/tgbot/types/InlineKeyboardButton.h create mode 100644 include/tgbot/types/InlineKeyboardMarkup.h (limited to 'include') diff --git a/include/tgbot/EventBroadcaster.h b/include/tgbot/EventBroadcaster.h index d97dbbb..12daef3 100644 --- a/include/tgbot/EventBroadcaster.h +++ b/include/tgbot/EventBroadcaster.h @@ -31,6 +31,7 @@ #include "tgbot/types/Message.h" #include "tgbot/types/InlineQuery.h" #include "tgbot/types/ChosenInlineResult.h" +#include "tgbot/types/CallbackQuery.h" namespace TgBot { @@ -48,6 +49,7 @@ public: typedef std::function MessageListener; typedef std::function InlineQueryListener; typedef std::function ChosenInlineResultListener; + typedef std::function CallbackQueryListener; /** * Registers listener which receives all messages which the bot can ever receive. @@ -82,14 +84,26 @@ public: _onNonCommandMessageListeners.push_back(listener); } + /** + * Registers listener which receives all the inline query. + * @param listener Listener. + */ inline void onInlineQuery(const InlineQueryListener& listener) { _onInlineQueryListeners.push_back(listener); } + /** + * Registers listener which receives all the chosen inline result. + * @param listener Listener. + */ inline void onChosenInlineResult(const ChosenInlineResultListener& listener){ _onChosenInlineResultListeners.push_back(listener); } + inline void onCallbackQuery(const CallbackQueryListener& listener){ + _onCallbackQueryListeners.push_back(listener); + } + private: template inline void broadcast(const std::vector& listeners, const ObjectType& object) const { @@ -130,12 +144,17 @@ private: broadcast(_onChosenInlineResultListeners, result); } + inline void broadcastCallbackQuery(const CallbackQuery::Ptr& result) const { + broadcast(_onCallbackQueryListeners, result); + } + std::vector _onAnyMessageListeners; std::map _onCommandListeners; std::vector _onUnknownCommandListeners; std::vector _onNonCommandMessageListeners; std::vector _onInlineQueryListeners; std::vector _onChosenInlineResultListeners; + std::vector _onCallbackQueryListeners; }; } diff --git a/include/tgbot/EventHandler.h b/include/tgbot/EventHandler.h index 64f74cd..63ecde3 100644 --- a/include/tgbot/EventHandler.h +++ b/include/tgbot/EventHandler.h @@ -67,6 +67,8 @@ public: _broadcaster->broadcastInlineQuery(update->inlineQuery); if (update->chosenInlineResult != NULL) _broadcaster->broadcastChosenInlineResult(update->chosenInlineResult); + if (update->callbackQuery != NULL) + _broadcaster->broadcastCallbackQuery(update->callbackQuery); if (update->message != NULL) handleMessage(update->message); } diff --git a/include/tgbot/TgTypeParser.h b/include/tgbot/TgTypeParser.h index f52d106..17e9553 100644 --- a/include/tgbot/TgTypeParser.h +++ b/include/tgbot/TgTypeParser.h @@ -52,6 +52,9 @@ #include "tgbot/types/InlineQueryResultMpeg4Gif.h" #include "tgbot/types/InlineQueryResultVideo.h" #include "tgbot/types/ChosenInlineResult.h" +#include "tgbot/types/CallbackQuery.h" +#include "tgbot/types/InlineKeyboardMarkup.h" +#include "tgbot/types/InlineKeyboardButton.h" namespace TgBot { @@ -114,6 +117,12 @@ public: std::string parseInlineQueryResultVideo(const InlineQueryResultVideo::Ptr& object) const; ChosenInlineResult::Ptr parseJsonAndGetChosenInlineResult(const boost::property_tree::ptree& data) const; std::string parseChosenInlineResult(const ChosenInlineResult::Ptr& object) const; + CallbackQuery::Ptr parseJsonAndGetCallbackQuery(const boost::property_tree::ptree& data) const; + std::string parseCallbackQuery(const CallbackQuery::Ptr& object) const; + InlineKeyboardMarkup::Ptr parseJsonAndGetInlineKeyboardMarkup(const boost::property_tree::ptree& data) const; + std::string parseInlineKeyboardMarkup(const InlineKeyboardMarkup::Ptr& object) const; + InlineKeyboardButton::Ptr parseJsonAndGetInlineKeyboardButton(const boost::property_tree::ptree& data) const; + std::string parseInlineKeyboardButton(const InlineKeyboardButton::Ptr& object) const; inline boost::property_tree::ptree parseJson(const std::string& json) const { boost::property_tree::ptree tree; diff --git a/include/tgbot/types/CallbackQuery.h b/include/tgbot/types/CallbackQuery.h new file mode 100644 index 0000000..5f6871d --- /dev/null +++ b/include/tgbot/types/CallbackQuery.h @@ -0,0 +1,52 @@ +// +// Created by Andrea Giove on 17/04/16. +// + +#ifndef TGBOT_CALLBACKQUERY_H +#define TGBOT_CALLBACKQUERY_H + +#include +#include + +#include "tgbot/types/User.h" +#include "tgbot/types/Message.h" + +namespace TgBot { + +/** + * This object represents an incoming callback query from a callback button in an inline keyboard. + * @ingroup types + */ +class CallbackQuery { +public: + typedef std::shared_ptr Ptr; + + /** + * Unique identifier for this query. + */ + std::string id; + + /** + * Sender. + */ + User::Ptr from; + + /** + * Optional. Message with the callback button that originated the query. Note that message content and message date will not be available if the message is too old. + */ + Message::Ptr message; + + /** + * Optional. Identifier of the message sent via the bot in inline mode, that originated the query. + */ + std::string inlineMessageId; + + /** + * Data associated with the callback button. Be aware that a bad client can send arbitrary data in this field. + */ + std::string data; + +}; +} + +#endif //TGBOT_CALLBACKQUERY_H diff --git a/include/tgbot/types/InlineKeyboardButton.h b/include/tgbot/types/InlineKeyboardButton.h new file mode 100644 index 0000000..1a71341 --- /dev/null +++ b/include/tgbot/types/InlineKeyboardButton.h @@ -0,0 +1,43 @@ +// +// Created by Andrea Giove on 17/04/16. +// + +#ifndef TGBOT_INLINEKEYBOARDBUTTON_H +#define TGBOT_INLINEKEYBOARDBUTTON_H + +#include +#include + +namespace TgBot { + +/** + * This object represents one button of an inline keyboard. You must use exactly one of the optional fields. + * @ingroup types + */ +class InlineKeyboardButton { +public: + typedef std::shared_ptr Ptr; + + /** + * Label text on the button + */ + std::string text; + + /** + * Optional. HTTP url to be opened when button is pressed. + */ + std::string url; + + /** + * Optional. Data to be sent in a callback query to the bot when button is pressed. + */ + std::string callbackData; + + /** + * Optional. If set, pressing the button will prompt the user to select one of their chats, open that chat and insert the bot‘s username and the specified inline query in the input field. Can be empty, in which case just the bot’s username will be inserted. + */ + std::string switchInlineQuery; +}; +} + +#endif //TGBOT_INLINEKEYBOARDBUTTON_H diff --git a/include/tgbot/types/InlineKeyboardMarkup.h b/include/tgbot/types/InlineKeyboardMarkup.h new file mode 100644 index 0000000..9097fa5 --- /dev/null +++ b/include/tgbot/types/InlineKeyboardMarkup.h @@ -0,0 +1,32 @@ +// +// Created by Andrea Giove on 17/04/16. +// + +#ifndef TGBOT_INLINEKEYBOARDMARKUP_H +#define TGBOT_INLINEKEYBOARDMARKUP_H + +#include +#include + +#include "tgbot/types/GenericReply.h" +#include "tgbot/types/InlineKeyboardButton.h" + +namespace TgBot { + +/** + * This object represents an inline keyboard that appears right next to the message it belongs to. + * @ingroup types + */ +class InlineKeyboardMarkup : public GenericReply { +public: + typedef std::shared_ptr Ptr; + + /** + * Array of button rows, each represented by an Array of InlineKeyboardButton objects. + */ + std::vector> inlineKeyboard; + +}; +} + +#endif //TGBOT_INLINEKEYBOARDMARKUP_H diff --git a/include/tgbot/types/Update.h b/include/tgbot/types/Update.h index 9ae8d73..7a3c106 100644 --- a/include/tgbot/types/Update.h +++ b/include/tgbot/types/Update.h @@ -28,6 +28,7 @@ #include "tgbot/types/Message.h" #include "tgbot/types/InlineQuery.h" #include "tgbot/types/ChosenInlineResult.h" +#include "tgbot/types/CallbackQuery.h" namespace TgBot { @@ -59,6 +60,11 @@ public: * Optional. The result of an inline query that was chosen by a user and sent to their chat partner. */ ChosenInlineResult::Ptr chosenInlineResult; + + /** + * Optional. New incoming callback query. + */ + CallbackQuery::Ptr callbackQuery; }; } -- cgit v1.2.3 From 9ba69d7e87c9b8ff9997294b68550852ef0274b8 Mon Sep 17 00:00:00 2001 From: Andrea Giove Date: Sun, 17 Apr 2016 22:09:52 +0200 Subject: Added new type: Venue, MessageEntity Update Message type Added new method: sendVenue, sendContact, kickChatMember, unbanChatMember --- include/tgbot/Api.h | 45 +++++++++++++++++++++++++++++++++++ include/tgbot/types/Message.h | 47 ++++++++++++++++++++++++++++++------- include/tgbot/types/MessageEntity.h | 43 +++++++++++++++++++++++++++++++++ include/tgbot/types/Venue.h | 45 +++++++++++++++++++++++++++++++++++ include/tgbot/types/Voice.h | 43 +++++++++++++++++++++++++++++++++ 5 files changed, 214 insertions(+), 9 deletions(-) create mode 100644 include/tgbot/types/MessageEntity.h create mode 100644 include/tgbot/types/Venue.h create mode 100644 include/tgbot/types/Voice.h (limited to 'include') diff --git a/include/tgbot/Api.h b/include/tgbot/Api.h index d7cfc0e..b6be878 100644 --- a/include/tgbot/Api.h +++ b/include/tgbot/Api.h @@ -36,6 +36,7 @@ #include "tgbot/types/UserProfilePhotos.h" #include "tgbot/types/Update.h" #include "tgbot/types/InlineQueryResult.h" +#include "tgbot/types/Venue.h" namespace TgBot { @@ -250,6 +251,36 @@ public: Message::Ptr sendLocation(int64_t chatId, float latitude, float longitude, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + /** + * Use this method to send information about a venue. On success, the sent Message is returned. + * @param chatId Unique identifier for the target chat. + * @param latitude Latitude of location. + * @param longitude Longitude of location. + * @param title Name of the venue. + * @param address Address of the venue. + * @param foursquare_id Foursquare identifier of the venue. + * @param replyToMessageId Optional. If the message is a reply, ID of the original message. + * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @param disableNotification Optional. Sends the message silenty. + * @return On success, the sent message is returned. + */ + Message::Ptr sendVenue(int64_t chatId, float latitude, float longitude, std::string title, std::string address, std::string foursquareId = "", + bool disableNotification = false, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + + /** + * Use this method to send phone contacts. On success, the sent Message is returned. + * @param chatId Unique identifier for the target chat. + * @param phoneNumber Contact's phone number. + * @param firstName Contact's first name. + * @param lastName Contact's last name. + * @param disableNotification Optional. Sends the message silenty. + * @param replyToMessageId Optional. If the message is a reply, ID of the original message. + * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user. + * @return On success, the sent message is returned. + */ + Message::Ptr sendContact(int64_t chatId, std::string phoneNumber, std::string firstName, std::string lastName = "", bool disableNotification = false, + int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const; + /** * Use this method when you need to tell the user that something is happening on the bot's side. The status is set for 5 seconds or less (when a message arrives from your bot, Telegram clients clear its typing status). * Example: The ImageBot needs some time to process a request and upload the image. Instead of sending a text message along the lines of “Retrieving image, please wait…”, the bot may use sendChatAction with action = upload_photo. The user will see a “sending photo” status for the bot. @@ -301,6 +332,20 @@ public: void answerInlineQuery(const std::string& inlineQueryId, const std::vector& results, int32_t cacheTime=300, bool isPersonal=false, const std::string& nextOffset="") const; + /** + * Use this method to kick a user from a group or a supergroup. + * @param chatId Unique identifier for the target group. + * @param userId Unique identifier of the target user. + */ + void kickChatMember(int64_t chatId, int32_t userId) const; + + /** + * Use this method to unban a previously kicked user in a supergroup. + * @param chatId Unique identifier for the target group. + * @param userId Unique identifier of the target user. + */ + void unbanChatMember(int64_t chatId, int32_t userId) const; + private: boost::property_tree::ptree sendRequest(const std::string& method, const std::vector& args = std::vector()) const; diff --git a/include/tgbot/types/Message.h b/include/tgbot/types/Message.h index ea53cf3..be1d313 100644 --- a/include/tgbot/types/Message.h +++ b/include/tgbot/types/Message.h @@ -37,6 +37,9 @@ #include "tgbot/types/Contact.h" #include "tgbot/types/Location.h" #include "tgbot/types/PhotoSize.h" +#include "tgbot/types/MessageEntity.h" +#include "tgbot/types/Venue.h" +#include "tgbot/types/Voice.h" namespace TgBot { @@ -45,10 +48,18 @@ namespace TgBot { * @ingroup types */ class Message { - public: typedef std::shared_ptr Ptr; + Message(){ + deleteChatPhoto = false; + groupChatCreated = false; + supergroupChatCreated = false; + channelChatCreated = false; + migrateToChatId = 0; + migrateFromChatId = 0; + } + /** * Unique message identifier. */ @@ -89,6 +100,11 @@ public: */ std::string text; + /** + * Optional. For text messages, special entities like usernames, URLs, bot commands, etc. that appear in the text. + */ + std::vector entities; + /** * Optional. Message is an audio file, information about the file. */ @@ -114,7 +130,15 @@ public: */ Video::Ptr video; - // TODO voice + /** + * Optional. Message is a voice message, information about the file. + */ + Voice::Ptr voice; + + /** + * Optional. Caption for the document, photo or video, 0-200 characters. + */ + std::string caption; /** * Optional. Message is a shared contact, information about the contact. @@ -126,15 +150,20 @@ public: */ Location::Ptr location; + /** + * Optional. Message is a venue, information about the venue. + */ + Venue::Ptr venue; + /** * Optional. A new member was added to the group, information about them (this member may be bot itself). */ - User::Ptr newChatParticipant; + User::Ptr newChatMember; /** * Optional. A member was removed from the group, information about them (this member may be bot itself). */ - User::Ptr leftChatParticipant; + User::Ptr leftChatMember; /** * Optional. A group title was changed to this value. @@ -156,11 +185,6 @@ public: */ bool groupChatCreated; - /** - * Optional. Text description of the photo or the video. - */ - std::string caption; - /** * Optional. Service message: the supergroup has been created. */ @@ -181,6 +205,11 @@ public: */ int64_t migrateFromChatId; + /** + * Optional. Specified message was pinned. Note that the Message object in this field will not contain further reply_to_message fields even if it is itself a reply. + */ + Message::Ptr pinnedMessage; + }; } diff --git a/include/tgbot/types/MessageEntity.h b/include/tgbot/types/MessageEntity.h new file mode 100644 index 0000000..befcb3e --- /dev/null +++ b/include/tgbot/types/MessageEntity.h @@ -0,0 +1,43 @@ +// +// Created by Andrea Giove on 17/04/16. +// + +#ifndef TGBOT_MESSAGEENTITY_H +#define TGBOT_MESSAGEENTITY_H + +#include +#include + +namespace TgBot { + +/** + * This object represents one special entity in a text message. For example, hashtags, usernames, URLs, etc. + * @ingroup types + */ +class MessageEntity { +public: + std::shared_ptr Ptr; + + /** + * Type of the entity. One of mention (@username), hashtag, bot_command, url, email, bold (bold text), italic (italic text), code (monowidth string), pre (monowidth block), text_link (for clickable text URLs). + */ + std::string type; + + /** + * Offset in UTF-16 code units to the start of the entity. + */ + int32_t offset; + + /** + * Length of the entity in UTF-16 code units + */ + int32_t length; + + /** + * Optional. For “text_link” only, url that will be opened after user taps on the text + */ + std::string url; +}; +} + +#endif //TGBOT_MESSAGEENTITY_H diff --git a/include/tgbot/types/Venue.h b/include/tgbot/types/Venue.h new file mode 100644 index 0000000..5040cce --- /dev/null +++ b/include/tgbot/types/Venue.h @@ -0,0 +1,45 @@ +// +// Created by Andrea Giove on 17/04/16. +// + +#ifndef TGBOT_VENUE_H +#define TGBOT_VENUE_H + +#include +#include + +#include "tgbot/types/Location.h" + +namespace TgBot { + +/** + * This object represents a venue. + * @ingroup types + */ +class Venue { +public: + typedef std::shared_ptr Ptr; + + /** + * Venue location. + */ + Location::Ptr location; + + /** + * Name of the venue. + */ + std::string title; + + /** + * Address of the venue. + */ + std::string address; + + /** + * Optional. Foursquare identifier of the venue. + */ + std::string foursquare_id; +}; +} + +#endif //TGBOT_VENUE_H diff --git a/include/tgbot/types/Voice.h b/include/tgbot/types/Voice.h new file mode 100644 index 0000000..385257d --- /dev/null +++ b/include/tgbot/types/Voice.h @@ -0,0 +1,43 @@ +// +// Created by Andrea Giove on 17/04/16. +// + +#ifndef TGBOT_VOICE_H +#define TGBOT_VOICE_H + +#include +#include + +namespace TgBot { + +/** + * This object represents a voice note. + * @ingroup types + */ +class Voice { +public: + std::shared_ptr Ptr; + + /** + * Unique identifier for this file. + */ + std::string file_id; + + /** + * Duration of the audio in seconds as defined by sender. + */ + int32_t duration; + + /** + * Optional. MIME type of the file as defined by sender; + */ + std::string mime_type; + + /** + * Optional. File size. + */ + int32_t file_size; +}; +} + +#endif //TGBOT_VOICE_H -- cgit v1.2.3