summaryrefslogtreecommitdiff
path: root/src/Api.cpp
diff options
context:
space:
mode:
authorOleg Morozenkov <m@oleg.rocks>2021-07-14 01:05:41 +0300
committerGitHub <noreply@github.com>2021-07-14 01:05:41 +0300
commit143de34d699a6edf09ed9cc42931e932e0c914ef (patch)
tree2fb33dd85c237b824e29b08057f94feaeda89ebe /src/Api.cpp
parenta0d31e277f0b62d24b5ee1777c07c7c942b92e1b (diff)
parentff11276c9a3f58b7d1fbcbbae0892b438d193bb6 (diff)
Merge pull request #172 from demidko/patch-1
Channels support
Diffstat (limited to 'src/Api.cpp')
-rw-r--r--src/Api.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/Api.cpp b/src/Api.cpp
index 9acf1bb..08b102a 100644
--- a/src/Api.cpp
+++ b/src/Api.cpp
@@ -45,6 +45,29 @@ Message::Ptr Api::sendMessage(std::int64_t chatId, const string& text, bool disa
}
return _tgTypeParser.parseJsonAndGetMessage(sendRequest("sendMessage", args));
}
+
+Message::Ptr Api::sendMessage(const std::string &chatId, const string& text, bool disableWebPagePreview, std::int32_t replyToMessageId, const GenericReply::Ptr replyMarkup, const string& parseMode, bool disableNotification) const {
+ vector<HttpReqArg> args;
+ args.reserve(7);
+ args.emplace_back("chat_id", chatId);
+ args.emplace_back("text", text);
+ if (disableWebPagePreview) {
+ args.emplace_back("disable_web_page_preview", disableWebPagePreview);
+ }
+ if (disableNotification){
+ args.emplace_back("disable_notification", disableNotification);
+ }
+ if (replyToMessageId) {
+ args.emplace_back("reply_to_message_id", replyToMessageId);
+ }
+ if (replyMarkup) {
+ args.emplace_back("reply_markup", _tgTypeParser.parseGenericReply(replyMarkup));
+ }
+ if (!parseMode.empty()) {
+ args.emplace_back("parse_mode", parseMode);
+ }
+ return _tgTypeParser.parseJsonAndGetMessage(sendRequest("sendMessage", args));
+}
Message::Ptr Api::forwardMessage(std::int64_t chatId, std::int64_t fromChatId, std::int32_t messageId, bool disableNotification) const {
vector<HttpReqArg> args;