diff options
author | Oleg Morozenkov <m@oleg.rocks> | 2020-08-21 01:41:36 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-08-21 01:41:36 +0300 |
commit | 4009b7ea603dcd7f21c6e852497daba7b0a1a6b3 (patch) | |
tree | 6dd10e3c92accb9aa250bc30862a59f6f7d9067b /samples/echobot-setmycommands/src/main.cpp | |
parent | 3230b1b5d84a7a948324949eb607082dc40fe01e (diff) | |
parent | ffc3c38882d669ea6b2abeea5c0f7c7b322fa6e7 (diff) |
Merge pull request #143 from sebest06/master
* add SetMyCommand to the api
Diffstat (limited to 'samples/echobot-setmycommands/src/main.cpp')
-rw-r--r-- | samples/echobot-setmycommands/src/main.cpp | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/samples/echobot-setmycommands/src/main.cpp b/samples/echobot-setmycommands/src/main.cpp new file mode 100644 index 0000000..afb9e35 --- /dev/null +++ b/samples/echobot-setmycommands/src/main.cpp @@ -0,0 +1,75 @@ +#include <csignal> +#include <cstdio> +#include <cstdlib> +#include <exception> +#include <string> + +#include <tgbot/tgbot.h> + +using namespace std; +using namespace TgBot; + +int main() { + string token(getenv("TOKEN")); + printf("Token: %s\n", token.c_str()); + + Bot bot(token); + + + vector<BotCommand::Ptr> commands; + BotCommand::Ptr cmdArray(new BotCommand); + cmdArray->command = "ccuno"; + cmdArray->description = "es el comando uno"; + + commands.push_back(cmdArray); + + cmdArray = BotCommand::Ptr(new BotCommand); + cmdArray->command = "dossendo"; + cmdArray->description = "es el comando dos"; + commands.push_back(cmdArray); + + cmdArray = BotCommand::Ptr(new BotCommand); + cmdArray->command = "tressss"; + cmdArray->description = "es el comando tres"; + commands.push_back(cmdArray); + + bot.getApi().setMyCommands(commands); + + vector<BotCommand::Ptr> vectCmd; + vectCmd = bot.getApi().getMyCommands(); + + for(std::vector<BotCommand::Ptr>::iterator it = vectCmd.begin(); it != vectCmd.end(); ++it) { + printf("cmd: %s -> %s\r",(*it)->command.c_str(),(*it)->description.c_str()); + } + + bot.getEvents().onCommand("start", [&bot](Message::Ptr message) { + bot.getApi().sendMessage(message->chat->id, "Hi!"); + }); + bot.getEvents().onAnyMessage([&bot](Message::Ptr message) { + printf("User wrote %s\n", message->text.c_str()); + if (StringTools::startsWith(message->text, "/start")) { + return; + } + bot.getApi().sendMessage(message->chat->id, "Your message is: " + message->text); + }); + + signal(SIGINT, [](int s) { + printf("SIGINT got\n"); + exit(0); + }); + + try { + printf("Bot username: %s\n", bot.getApi().getMe()->username.c_str()); + bot.getApi().deleteWebhook(); + + TgLongPoll longPoll(bot); + while (true) { + printf("Long poll started\n"); + longPoll.start(); + } + } catch (exception& e) { + printf("error: %s\n", e.what()); + } + + return 0; +} |