From d7157f39dfa767e517828ba9ac9f2fa3111210b6 Mon Sep 17 00:00:00 2001 From: Frits Jan van Kempen Date: Tue, 28 Jul 2020 15:48:28 +0200 Subject: [PATCH 1/9] initial bugfixes - issue 186 --- src/UniversalTelegramBot.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/UniversalTelegramBot.cpp b/src/UniversalTelegramBot.cpp index e6de1f7..4ded853 100644 --- a/src/UniversalTelegramBot.cpp +++ b/src/UniversalTelegramBot.cpp @@ -64,7 +64,7 @@ String UniversalTelegramBot::buildCommand(const String& cmd) { String UniversalTelegramBot::sendGetToTelegram(const String& command) { String body, headers; - bool avail; + //bool avail; // bugfix FJvK // Connect with api.telegram.org if not already connected if (!client->connected()) { @@ -236,7 +236,7 @@ String UniversalTelegramBot::sendMultipartFormDataToTelegram( client->print(buildCommand(command)); client->println(F(" HTTP/1.1")); // Host header - client->print(F("Host: " TELEGRAM_HOST)); + client->println(F("Host: " TELEGRAM_HOST)); // bugfix - https://github.com/witnessmenow/Universal-Arduino-Telegram-Bot/issues/186 client->println(F("User-Agent: arduino/1.0")); client->println(F("Accept: */*")); @@ -268,7 +268,7 @@ String UniversalTelegramBot::sendMultipartFormDataToTelegram( #endif byte buffer[512]; int count = 0; - char ch; + //char ch; // bugfix FJvK while (moreDataAvailableCallback()) { buffer[count] = getNextByteCallback(); count++; From b8ba7b01a8253b5e317387531e340b30504e05e7 Mon Sep 17 00:00:00 2001 From: Frits Jan van Kempen Date: Tue, 28 Jul 2020 16:10:58 +0200 Subject: [PATCH 2/9] added retreiving message_id to processResult() --- src/UniversalTelegramBot.cpp | 8 +++++++- src/UniversalTelegramBot.h | 1 + 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/src/UniversalTelegramBot.cpp b/src/UniversalTelegramBot.cpp index 4ded853..00287d1 100644 --- a/src/UniversalTelegramBot.cpp +++ b/src/UniversalTelegramBot.cpp @@ -461,6 +461,7 @@ bool UniversalTelegramBot::processResult(JsonObject result, int messageIndex) { messages[messageIndex].chat_id = message["chat"]["id"].as(); messages[messageIndex].chat_title = message["chat"]["title"].as(); messages[messageIndex].hasDocument = false; + messages[messageIndex].message_id = message["message_id"].as(); // added message id if (message.containsKey("text")) { messages[messageIndex].text = message["text"].as(); @@ -480,7 +481,8 @@ bool UniversalTelegramBot::processResult(JsonObject result, int messageIndex) { messages[messageIndex].reply_to_message_id = message["reply_to_message"]["message_id"]; // no need to check if containsKey["text"]. If it doesn't, it default to null messages[messageIndex].reply_to_text = message["reply_to_message"]["text"].as(); - } + } + } else if (result.containsKey("channel_post")) { JsonObject message = result["channel_post"]; messages[messageIndex].type = F("channel_post"); @@ -488,6 +490,7 @@ bool UniversalTelegramBot::processResult(JsonObject result, int messageIndex) { messages[messageIndex].date = message["date"].as(); messages[messageIndex].chat_id = message["chat"]["id"].as(); messages[messageIndex].chat_title = message["chat"]["title"].as(); + messages[messageIndex].message_id = message["message_id"].as(); // added message id } else if (result.containsKey("callback_query")) { JsonObject message = result["callback_query"]; @@ -500,6 +503,8 @@ bool UniversalTelegramBot::processResult(JsonObject result, int messageIndex) { messages[messageIndex].reply_to_text = message["message"]["text"].as(); messages[messageIndex].chat_title = F(""); messages[messageIndex].query_id = message["id"].as(); + messages[messageIndex].message_id = message["message"]["message_id"].as(); // added message id + } else if (result.containsKey("edited_message")) { JsonObject message = result["edited_message"]; messages[messageIndex].type = F("edited_message"); @@ -508,6 +513,7 @@ bool UniversalTelegramBot::processResult(JsonObject result, int messageIndex) { messages[messageIndex].date = message["date"].as(); messages[messageIndex].chat_id = message["chat"]["id"].as(); messages[messageIndex].chat_title = message["chat"]["title"].as(); + messages[messageIndex].message_id = message["message_id"].as(); // added message id if (message.containsKey("text")) { messages[messageIndex].text = message["text"].as(); diff --git a/src/UniversalTelegramBot.h b/src/UniversalTelegramBot.h index 3db855b..795224e 100644 --- a/src/UniversalTelegramBot.h +++ b/src/UniversalTelegramBot.h @@ -57,6 +57,7 @@ struct telegramMessage { float longitude; float latitude; int update_id; + int message_id; // added message id int reply_to_message_id; String reply_to_text; From 1eda34de1ebb7c4ebc095abcb58364ff3e6b3cf4 Mon Sep 17 00:00:00 2001 From: Frits Jan van Kempen Date: Tue, 28 Jul 2020 16:50:37 +0200 Subject: [PATCH 3/9] Added option to send editMessageText --- src/UniversalTelegramBot.cpp | 16 ++++++++++------ src/UniversalTelegramBot.h | 4 ++-- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/src/UniversalTelegramBot.cpp b/src/UniversalTelegramBot.cpp index 00287d1..02279dd 100644 --- a/src/UniversalTelegramBot.cpp +++ b/src/UniversalTelegramBot.cpp @@ -606,25 +606,29 @@ bool UniversalTelegramBot::sendMessageWithReplyKeyboard( bool UniversalTelegramBot::sendMessageWithInlineKeyboard(const String& chat_id, const String& text, const String& parse_mode, - const String& keyboard) { + const String& keyboard, + const int& message_id) { // added message_id DynamicJsonDocument payload(maxMessageLength); payload["chat_id"] = chat_id; payload["text"] = text; + if (message_id != 0) + payload["message_id"] = message_id; // added message_id + if (parse_mode != "") payload["parse_mode"] = parse_mode; JsonObject replyMarkup = payload.createNestedObject("reply_markup"); replyMarkup["inline_keyboard"] = serialized(keyboard); - return sendPostMessage(payload.as()); + return sendPostMessage(payload.as(), message_id); // if message id == 0 then edit is false, else edit is true } /*********************************************************************** - * SendPostMessage - function to send message to telegram * + * SendPostMessage - function to send message to telegram * * (Arguments to pass: chat_id, text to transmit and markup(optional)) * ***********************************************************************/ -bool UniversalTelegramBot::sendPostMessage(JsonObject payload) { +bool UniversalTelegramBot::sendPostMessage(JsonObject payload, bool edit = false) { // added message_id bool sent = false; #ifdef TELEGRAM_DEBUG @@ -636,8 +640,8 @@ bool UniversalTelegramBot::sendPostMessage(JsonObject payload) { if (payload.containsKey("text")) { while (millis() < sttime + 8000) { // loop for a while to send the message - String response = sendPostToTelegram(BOT_CMD("sendMessage"), payload); - #ifdef TELEGRAM_DEBUG + String response = sendPostToTelegram((edit ? BOT_CMD("editMessageText") : BOT_CMD("sendMessage")), payload); // if edit is true we send a editMessageText CMD + #ifdef TELEGRAM_DEBUG Serial.println(response); #endif sent = checkForOkResponse(response); diff --git a/src/UniversalTelegramBot.h b/src/UniversalTelegramBot.h index 795224e..71f38f1 100644 --- a/src/UniversalTelegramBot.h +++ b/src/UniversalTelegramBot.h @@ -90,11 +90,11 @@ class UniversalTelegramBot { bool resize = false, bool oneTime = false, bool selective = false); bool sendMessageWithInlineKeyboard(const String& chat_id, const String& text, - const String& parse_mode, const String& keyboard); + const String& parse_mode, const String& keyboard, const int& message_id = 0); // added message id bool sendChatAction(const String& chat_id, const String& text); - bool sendPostMessage(JsonObject payload); + bool sendPostMessage(JsonObject payload, bool edit = false); // added message id option to send an editMessageText command String sendPostPhoto(JsonObject payload); String sendPhotoByBinary(const String& chat_id, const String& contentType, int fileSize, MoreDataAvailable moreDataAvailableCallback, From 726c112217821f5ef327b7b799e37bdcb65e3b32 Mon Sep 17 00:00:00 2001 From: Frits Jan van Kempen Date: Tue, 28 Jul 2020 16:59:23 +0200 Subject: [PATCH 4/9] Correctly declared values --- src/UniversalTelegramBot.cpp | 4 ++-- src/UniversalTelegramBot.h | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/UniversalTelegramBot.cpp b/src/UniversalTelegramBot.cpp index 02279dd..0edbac8 100644 --- a/src/UniversalTelegramBot.cpp +++ b/src/UniversalTelegramBot.cpp @@ -607,7 +607,7 @@ bool UniversalTelegramBot::sendMessageWithInlineKeyboard(const String& chat_id, const String& text, const String& parse_mode, const String& keyboard, - const int& message_id) { // added message_id + int message_id) { // added message_id DynamicJsonDocument payload(maxMessageLength); payload["chat_id"] = chat_id; @@ -628,7 +628,7 @@ bool UniversalTelegramBot::sendMessageWithInlineKeyboard(const String& chat_id, * SendPostMessage - function to send message to telegram * * (Arguments to pass: chat_id, text to transmit and markup(optional)) * ***********************************************************************/ -bool UniversalTelegramBot::sendPostMessage(JsonObject payload, bool edit = false) { // added message_id +bool UniversalTelegramBot::sendPostMessage(JsonObject payload, bool edit) { // added message_id bool sent = false; #ifdef TELEGRAM_DEBUG diff --git a/src/UniversalTelegramBot.h b/src/UniversalTelegramBot.h index 71f38f1..ab70093 100644 --- a/src/UniversalTelegramBot.h +++ b/src/UniversalTelegramBot.h @@ -90,7 +90,7 @@ class UniversalTelegramBot { bool resize = false, bool oneTime = false, bool selective = false); bool sendMessageWithInlineKeyboard(const String& chat_id, const String& text, - const String& parse_mode, const String& keyboard, const int& message_id = 0); // added message id + const String& parse_mode, const String& keyboard, int message_id = 0); // added message id bool sendChatAction(const String& chat_id, const String& text); From 762d6e8d38377bcc32da9e6940f12787633223d9 Mon Sep 17 00:00:00 2001 From: Frits Jan van Kempen Date: Tue, 28 Jul 2020 21:44:37 +0200 Subject: [PATCH 5/9] added a working example for update (toggle a LED) --- .../ESP32/LEDButtonUpdate/LEDButtonUpdate.ino | 176 ++++++++++++++++++ examples/ESP32/LEDButtonUpdate/README.md | 20 ++ 2 files changed, 196 insertions(+) create mode 100644 examples/ESP32/LEDButtonUpdate/LEDButtonUpdate.ino create mode 100644 examples/ESP32/LEDButtonUpdate/README.md diff --git a/examples/ESP32/LEDButtonUpdate/LEDButtonUpdate.ino b/examples/ESP32/LEDButtonUpdate/LEDButtonUpdate.ino new file mode 100644 index 0000000..a04bc8d --- /dev/null +++ b/examples/ESP32/LEDButtonUpdate/LEDButtonUpdate.ino @@ -0,0 +1,176 @@ +/******************************************************************* + An example of how to use message_id to update an inline keyboard + message and buttons to toggle a LED + + written by Frits Jan van Kempen + *******************************************************************/ +#include +#include +#include +#include + +// Initialize Wifi connection to the router +const char *ssid = "mySSID"; +const char *password = "myPASSWORD"; + +// Initialize Telegram BOT +#define BOTtoken "xxxxxxxxxx:xxxxxxxxxxxxxxxxxxxxxxxxxx" // your Bot Token (Get from Botfather) +WiFiClientSecure client; +UniversalTelegramBot bot(BOTtoken2, client); + +int Bot_mtbs = 1000; //mean time between scan messages +long Bot_lasttime; //last time messages' scan has been done +int last_message_id = 0; + +// LED parameters +const int ledPin = 2; // Internal LED on DevKit ESP32-WROOM (GPIO2) +int ledState = LOW; + +void handleNewMessages(int numNewMessages) +{ + + for (int i = 0; i < numNewMessages; i++) + { + + // Get all the important data from the message + int message_id = bot.messages[i].message_id; + String chat_id = String(bot.messages[i].chat_id); + String text = bot.messages[i].text; + String from_name = bot.messages[i].from_name; + if (from_name == "") + from_name = "Guest"; + String msg = ""; // init a message string to use + + // Output the message_id to give you feeling on how this example works + Serial.print("Message id: "); + Serial.println(message_id); + + // Inline buttons with callbacks when pressed will raise a callback_query message + if (bot.messages[i].type == "callback_query") + { + Serial.print("Call back button pressed by: "); + Serial.println(bot.messages[i].from_id); + Serial.print("Data on the button: "); + Serial.println(bot.messages[i].text); + + if (text == "/toggleLED") + { + + // Toggle the ledState and update the LED itself + ledState = !ledState; + digitalWrite(ledPin, ledState); + + // Now we can UPDATE the message, lets prepare it for sending: + msg = "Hi " + from_name + "!\n"; + msg += "Notice how the LED state has changed!\n\n"; + msg += "Try it again, see the button has updated as well:\n\n"; + + // Prepare the buttons + String keyboardJson = "["; // start Json + keyboardJson += "[{ \"text\" : \"The LED is "; + if (ledState) + { + keyboardJson += "ON"; + } + else + { + keyboardJson += "OFF"; + } + keyboardJson += "\", \"callback_data\" : \"/toggleLED\" }]"; + keyboardJson += ", [{ \"text\" : \"Send text\", \"callback_data\" : \"This text was sent by inline button\" }]"; // add another button + //keyboardJson += ", [{ \"text\" : \"Go to Google\", \"url\" : \"https://www.google.com\" }]"; // add another button, this one appears after first Update + keyboardJson += "]"; // end Json + + // Now send this message including the current message_id as the 5th input to UPDATE that message + bot.sendMessageWithInlineKeyboard(chat_id, msg, "Markdown", keyboardJson, message_id); + } + + else + { + // echo back callback_query which is not handled above + bot.sendMessage(chat_id, text, "Markdown"); + } + } + + // 'Normal' messages are handled here + else + { + if (text == "/start") + { + // lets create a friendly welcome message + msg = "Hi " + from_name + "!\n"; + msg += "I am your Telegram Bot running on ESP32.\n\n"; + msg += "Lets test this updating LED button below:\n\n"; + + // lets create a button depending on the current ledState + String keyboardJson = "["; // start of keyboard json + keyboardJson += "[{ \"text\" : \"The LED is "; + if (ledState) + { + keyboardJson += "ON"; + } + else + { + keyboardJson += "OFF"; + } + keyboardJson += "\", \"callback_data\" : \"/toggleLED\" }]"; //callback is /toggleLED + keyboardJson += ", [{ \"text\" : \"Send text\", \"callback_data\" : \"This text was sent by inline button\" }]"; // add another button + keyboardJson += "]"; // end of keyboard json + + //first time, send this message as a normal inline keyboard message: + bot.sendMessageWithInlineKeyboard(chat_id, msg, "Markdown", keyboardJson); + } + if (text == "/options") + { + String keyboardJson = "[[{ \"text\" : \"Go to Google\", \"url\" : \"https://www.google.com\" }], [{ \"text\" : \"Send\", \"callback_data\" : \"This was sent by inline\" }]]"; + bot.sendMessageWithInlineKeyboard(chat_id, "Choose from one of the following options", "", keyboardJson); + } + } + } +} + +void setup() +{ + Serial.begin(115200); + + // Attempt to connect to Wifi network: + Serial.print("Connecting Wifi: "); + Serial.println(ssid); + + // Set WiFi to station mode and disconnect from an AP if it was Previously + // connected + WiFi.mode(WIFI_STA); + WiFi.begin(ssid, password); + + while (WiFi.status() != WL_CONNECTED) + { + Serial.print("."); + delay(500); + } + + Serial.println(""); + Serial.println("WiFi connected"); + Serial.print("IP address: "); + Serial.println(WiFi.localIP()); + + pinMode(ledPin, OUTPUT); // initialize ledPin as an output. + digitalWrite(ledPin, ledState); // initialize pin as low (LED Off) +} + +void loop() +{ + // run this in loop to poll new messages + if (millis() > Bot_lasttime + Bot_mtbs) + { + int numNewMessages = bot.getUpdates(bot.last_message_received + 1); + + while (numNewMessages) + { + Serial.println("got response"); + handleNewMessages(numNewMessages); + numNewMessages = bot.getUpdates(bot.last_message_received + 1); + } + + Bot_lasttime = millis(); + } +} \ No newline at end of file diff --git a/examples/ESP32/LEDButtonUpdate/README.md b/examples/ESP32/LEDButtonUpdate/README.md new file mode 100644 index 0000000..a4045e6 --- /dev/null +++ b/examples/ESP32/LEDButtonUpdate/README.md @@ -0,0 +1,20 @@ +#ESP32 - LED button update + +This is an example of how one can update inline keyboard messages (buttons). +The message_id of the specific message is sent when a message is received. +This message_id can be used to UPDATE that message. +One can update text inside a message, but also buttons can be updated. +This way one can build menu's, like the menu the botfather uses. + +In this simple example we use a inlinekeyboard button to toggle (and update) the state of a LED. + +NOTE: You will need to enter your SSID, password and bot Token for the example to work. + +Example and update to Universal-Arduino-Telegram-Bot originally written by +[Frits Jan van Kempen] (https://github.com/fritsjan) with inspiration from [RomeHein] (https://github.com/RomeHein) + +Adapted by [Brian Lough](https://github.com/witnessmenow) + +## License + +You may copy, distribute and modify the software provided that modifications are described and licensed for free under [LGPL-3](http://www.gnu.org/licenses/lgpl-3.0.html). Derivatives works (including modifications or anything statically linked to the library) can only be redistributed under [LGPL-3](http://www.gnu.org/licenses/lgpl-3.0.html), but applications that use the library don't have to be. From 8c7bdba6786524e611cfa3990c52131c3e8a380e Mon Sep 17 00:00:00 2001 From: Frits Jan van Kempen Date: Tue, 28 Jul 2020 21:51:01 +0200 Subject: [PATCH 6/9] also added message_id to sendMessage() function --- src/UniversalTelegramBot.cpp | 7 +++++-- src/UniversalTelegramBot.h | 2 +- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/UniversalTelegramBot.cpp b/src/UniversalTelegramBot.cpp index 0edbac8..c140ba1 100644 --- a/src/UniversalTelegramBot.cpp +++ b/src/UniversalTelegramBot.cpp @@ -562,16 +562,19 @@ bool UniversalTelegramBot::sendSimpleMessage(const String& chat_id, const String } bool UniversalTelegramBot::sendMessage(const String& chat_id, const String& text, - const String& parse_mode) { + const String& parse_mode, int message_id) { // added message_id DynamicJsonDocument payload(maxMessageLength); payload["chat_id"] = chat_id; payload["text"] = text; + if (message_id != 0) + payload["message_id"] = message_id; // added message_id + if (parse_mode != "") payload["parse_mode"] = parse_mode; - return sendPostMessage(payload.as()); + return sendPostMessage(payload.as(), message_id); // if message id == 0 then edit is false, else edit is true } bool UniversalTelegramBot::sendMessageWithReplyKeyboard( diff --git a/src/UniversalTelegramBot.h b/src/UniversalTelegramBot.h index ab70093..63e00ab 100644 --- a/src/UniversalTelegramBot.h +++ b/src/UniversalTelegramBot.h @@ -84,7 +84,7 @@ class UniversalTelegramBot { bool getMe(); bool sendSimpleMessage(const String& chat_id, const String& text, const String& parse_mode); - bool sendMessage(const String& chat_id, const String& text, const String& parse_mode = ""); + bool sendMessage(const String& chat_id, const String& text, const String& parse_mode = "", int message_id = 0); // added message id bool sendMessageWithReplyKeyboard(const String& chat_id, const String& text, const String& parse_mode, const String& keyboard, bool resize = false, bool oneTime = false, From f2fb98773bd56c784477d9a9515a06d1e36fb132 Mon Sep 17 00:00:00 2001 From: witnessmenow Date: Wed, 30 Sep 2020 23:14:51 +0100 Subject: [PATCH 7/9] Updating License and adding example to travis Also updated the example name to make it more generic --- .travis.yml | 1 + .../UpdateInlineKeyboard}/README.md | 3 ++- .../UpdateInlineKeyboard/UpdateInlineKeyboard.ino} | 6 ++++-- 3 files changed, 7 insertions(+), 3 deletions(-) rename examples/ESP32/{LEDButtonUpdate => CustomKeyboard/UpdateInlineKeyboard}/README.md (59%) rename examples/ESP32/{LEDButtonUpdate/LEDButtonUpdate.ino => CustomKeyboard/UpdateInlineKeyboard/UpdateInlineKeyboard.ino} (97%) diff --git a/.travis.yml b/.travis.yml index f33973b..8a9496a 100644 --- a/.travis.yml +++ b/.travis.yml @@ -31,6 +31,7 @@ env: - SCRIPT=platformioSingle EXAMPLE_NAME=ChatAction EXAMPLE_FOLDER=/ BOARDTYPE=ESP32 BOARD=esp32dev - SCRIPT=platformioSingle EXAMPLE_NAME=InlineKeyboardMarkup EXAMPLE_FOLDER=/CustomKeyboard/ BOARDTYPE=ESP32 BOARD=esp32dev - SCRIPT=platformioSingle EXAMPLE_NAME=ReplyKeyboardMarkup EXAMPLE_FOLDER=/CustomKeyboard/ BOARDTYPE=ESP32 BOARD=esp32doit-devkit-v1 + - SCRIPT=platformioSingle EXAMPLE_NAME=UpdateInlineKeyboard EXAMPLE_FOLDER=/CustomKeyboard/ BOARDTYPE=ESP32 BOARD=esp32dev - SCRIPT=platformioSingle EXAMPLE_NAME=EchoBot EXAMPLE_FOLDER=/ BOARDTYPE=ESP32 BOARD=esp32dev - SCRIPT=platformioSingle EXAMPLE_NAME=FlashLED EXAMPLE_FOLDER=/ BOARDTYPE=ESP32 BOARD=esp32doit-devkit-v1 - SCRIPT=platformioSingle EXAMPLE_NAME=Location EXAMPLE_FOLDER=/ BOARDTYPE=ESP32 BOARD=esp32dev diff --git a/examples/ESP32/LEDButtonUpdate/README.md b/examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/README.md similarity index 59% rename from examples/ESP32/LEDButtonUpdate/README.md rename to examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/README.md index a4045e6..54cff4a 100644 --- a/examples/ESP32/LEDButtonUpdate/README.md +++ b/examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/README.md @@ -17,4 +17,5 @@ Adapted by [Brian Lough](https://github.com/witnessmenow) ## License -You may copy, distribute and modify the software provided that modifications are described and licensed for free under [LGPL-3](http://www.gnu.org/licenses/lgpl-3.0.html). Derivatives works (including modifications or anything statically linked to the library) can only be redistributed under [LGPL-3](http://www.gnu.org/licenses/lgpl-3.0.html), but applications that use the library don't have to be. +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. diff --git a/examples/ESP32/LEDButtonUpdate/LEDButtonUpdate.ino b/examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/UpdateInlineKeyboard.ino similarity index 97% rename from examples/ESP32/LEDButtonUpdate/LEDButtonUpdate.ino rename to examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/UpdateInlineKeyboard.ino index a04bc8d..84ef339 100644 --- a/examples/ESP32/LEDButtonUpdate/LEDButtonUpdate.ino +++ b/examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/UpdateInlineKeyboard.ino @@ -1,6 +1,8 @@ /******************************************************************* - An example of how to use message_id to update an inline keyboard - message and buttons to toggle a LED + An example to show how to edit an existing inline keyboard. + + In this example the keyboard is updated with the state of + the LED. written by Frits Jan van Kempen *******************************************************************/ From e04bacde584fafc0998ac0bdea83079b9b5ab38c Mon Sep 17 00:00:00 2001 From: witnessmenow Date: Wed, 30 Sep 2020 23:31:09 +0100 Subject: [PATCH 8/9] Removed uneeded comments --- src/UniversalTelegramBot.h | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/UniversalTelegramBot.h b/src/UniversalTelegramBot.h index 6c3b208..5fc97ee 100644 --- a/src/UniversalTelegramBot.h +++ b/src/UniversalTelegramBot.h @@ -58,7 +58,7 @@ struct telegramMessage { float longitude; float latitude; int update_id; - int message_id; // added message id + int message_id; int reply_to_message_id; String reply_to_text; @@ -85,17 +85,17 @@ class UniversalTelegramBot { bool getMe(); bool sendSimpleMessage(const String& chat_id, const String& text, const String& parse_mode); - bool sendMessage(const String& chat_id, const String& text, const String& parse_mode = "", int message_id = 0); // added message id + bool sendMessage(const String& chat_id, const String& text, const String& parse_mode = "", int message_id = 0); bool sendMessageWithReplyKeyboard(const String& chat_id, const String& text, const String& parse_mode, const String& keyboard, bool resize = false, bool oneTime = false, bool selective = false); bool sendMessageWithInlineKeyboard(const String& chat_id, const String& text, - const String& parse_mode, const String& keyboard, int message_id = 0); // added message id + const String& parse_mode, const String& keyboard, int message_id = 0); bool sendChatAction(const String& chat_id, const String& text); - bool sendPostMessage(JsonObject payload, bool edit = false); // added message id option to send an editMessageText command + bool sendPostMessage(JsonObject payload, bool edit = false); String sendPostPhoto(JsonObject payload); String sendPhotoByBinary(const String& chat_id, const String& contentType, int fileSize, MoreDataAvailable moreDataAvailableCallback, From 1307102dfe94314aabdfb970c5633a64cbcafdf0 Mon Sep 17 00:00:00 2001 From: witnessmenow Date: Thu, 1 Oct 2020 00:19:55 +0100 Subject: [PATCH 9/9] Typo, Travis doing its job! --- .../UpdateInlineKeyboard/UpdateInlineKeyboard.ino | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/UpdateInlineKeyboard.ino b/examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/UpdateInlineKeyboard.ino index 84ef339..80ba5ca 100644 --- a/examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/UpdateInlineKeyboard.ino +++ b/examples/ESP32/CustomKeyboard/UpdateInlineKeyboard/UpdateInlineKeyboard.ino @@ -18,7 +18,7 @@ const char *password = "myPASSWORD"; // Initialize Telegram BOT #define BOTtoken "xxxxxxxxxx:xxxxxxxxxxxxxxxxxxxxxxxxxx" // your Bot Token (Get from Botfather) WiFiClientSecure client; -UniversalTelegramBot bot(BOTtoken2, client); +UniversalTelegramBot bot(BOTtoken, client); int Bot_mtbs = 1000; //mean time between scan messages long Bot_lasttime; //last time messages' scan has been done