Compare commits
No commits in common. "3d8abc3f0c20b8df3e2fb4db3f5b70056bd354d2" and "ea29fa79f005884f63241742ebbd391268d03f57" have entirely different histories.
3d8abc3f0c
...
ea29fa79f0
7 changed files with 45 additions and 94 deletions
3
modules/bot/front/.gitignore
vendored
3
modules/bot/front/.gitignore
vendored
|
|
@ -1,4 +1 @@
|
|||
build/
|
||||
out/
|
||||
.vscode
|
||||
api/generated-client
|
||||
|
|
@ -27,6 +27,5 @@ namespace BotConstants {
|
|||
}
|
||||
namespace Text {
|
||||
const std::string MAIN_MENU = "Вас приветствует nyanimedb бот:)\nЧего будем делать?";
|
||||
const std::string SAD_ERROR = "У нас что-то случилось:(\nМы обязательно скоро исправимся";
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -5,12 +5,11 @@
|
|||
#include <string>
|
||||
|
||||
#include <tgbot/tgbot.h>
|
||||
#include "handlers.hpp"
|
||||
|
||||
class AnimeBot {
|
||||
private:
|
||||
std::string token;
|
||||
TgBot::Bot bot;
|
||||
BotHandlers handler;
|
||||
|
||||
public:
|
||||
/// Init Bot
|
||||
|
|
|
|||
|
|
@ -1,4 +1,3 @@
|
|||
#pragma once
|
||||
#include <tgbot/tgbot.h>
|
||||
#include <string>
|
||||
#include <structs.hpp>
|
||||
|
|
@ -11,27 +10,12 @@ struct HandlerResult {
|
|||
|
||||
class BotHandlers {
|
||||
public:
|
||||
BotHandlers(TgBot::Api api) : botApi(api) {;}
|
||||
|
||||
/// @brief Обработка callback'ов из кнопок интерфейса
|
||||
/// @param query запрос callback
|
||||
void handleCallback(TgBot::CallbackQuery::Ptr query);
|
||||
|
||||
/// @brief Обработка сообщений боту
|
||||
/// @details
|
||||
/// Функция для обработки сообщений, которые юзер отправляет
|
||||
/// боту. Необходима для обработки ревью и названий искомого
|
||||
/// аниме. Внутри себя проверяет текущий state пользователя
|
||||
/// в боте.
|
||||
/// @param message обрабатываемое сообщение
|
||||
void handleMessage(TgBot::Message::Ptr message);
|
||||
void handleCallback(const TgBot::CallbackQuery::Ptr query);
|
||||
|
||||
private:
|
||||
TgBot::Api botApi;
|
||||
|
||||
void handleNavigation(TgBot::CallbackQuery::Ptr query);
|
||||
|
||||
void processCallbackImpl(TgBot::CallbackQuery::Ptr query);
|
||||
void handleNavigation(const TgBot::CallbackQuery::Ptr query);
|
||||
|
||||
/// @brief Получить очередную страницу тайтлов из списка пользователя
|
||||
/// @param userId Идентификатор пользователя
|
||||
|
|
|
|||
|
|
@ -39,16 +39,16 @@ TgBot::InlineKeyboardMarkup::Ptr KeyboardFactory::createMyTitles(std::vector<Tit
|
|||
if(counter % 2 == 1) {
|
||||
auto button = std::make_shared<TgBot::InlineKeyboardButton>();
|
||||
button->text = BotConstants::Button::PREV;
|
||||
button->callbackData = BotConstants::Callback::LIST_PREV + ':' + std::to_string(titles[0].num);
|
||||
button->callbackData = BotConstants::Callback::LIST_PREV + std::to_string(titles[0].num);
|
||||
layout[counter / 2].push_back(button);
|
||||
}
|
||||
else {
|
||||
auto button_prev = std::make_shared<TgBot::InlineKeyboardButton>();
|
||||
button_prev->text = BotConstants::Button::PREV;
|
||||
button_prev->callbackData = BotConstants::Callback::LIST_PREV + ':' + std::to_string(titles[0].num);
|
||||
button_prev->callbackData = BotConstants::Callback::LIST_PREV + std::to_string(titles[0].num);
|
||||
auto button_next = std::make_shared<TgBot::InlineKeyboardButton>();
|
||||
button_next->text = BotConstants::Button::NEXT;
|
||||
button_next->callbackData = BotConstants::Callback::LIST_NEXT + ':' + std::to_string(titles[5].num);
|
||||
button_next->callbackData = BotConstants::Callback::LIST_NEXT + std::to_string(titles[5].num);
|
||||
layout.push_back({button_prev, button_next});
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -3,9 +3,7 @@
|
|||
#include "constants.hpp"
|
||||
#include "handlers.hpp"
|
||||
|
||||
AnimeBot::AnimeBot(const std::string& token)
|
||||
: bot(token)
|
||||
, handler(bot.getApi()) {
|
||||
AnimeBot::AnimeBot(const std::string& token) : bot(token) {
|
||||
setupHandlers();
|
||||
}
|
||||
|
||||
|
|
@ -14,12 +12,19 @@ void AnimeBot::setupHandlers() {
|
|||
sendMainMenu(message->chat->id);
|
||||
});
|
||||
|
||||
bot.getEvents().onCallbackQuery([this](TgBot::CallbackQuery::Ptr query) {
|
||||
handler.handleCallback(query);
|
||||
});
|
||||
auto [text, kb] = BotHandlers::returnMyTitles(321);
|
||||
|
||||
bot.getEvents().onAnyMessage([this](TgBot::Message::Ptr message) {
|
||||
handler.handleMessage(message);
|
||||
auto cp_api = bot.getApi();
|
||||
bot.getEvents().onCallbackQuery([text, kb, cp_api](TgBot::CallbackQuery::Ptr query) {
|
||||
cp_api.editMessageText(
|
||||
text,
|
||||
query->message->chat->id,
|
||||
query->message->messageId,
|
||||
"",
|
||||
"",
|
||||
nullptr,
|
||||
kb
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
|
|
@ -31,3 +36,9 @@ void AnimeBot::sendMainMenu(int64_t chatId) {
|
|||
TgBot::Bot& AnimeBot::getBot() {
|
||||
return bot;
|
||||
}
|
||||
|
||||
/*
|
||||
void AnimeBot::showMyTitles() {
|
||||
|
||||
}
|
||||
*/
|
||||
|
|
|
|||
|
|
@ -3,23 +3,15 @@
|
|||
#include "structs.hpp"
|
||||
#include "constants.hpp"
|
||||
|
||||
void BotHandlers::handleCallback(TgBot::CallbackQuery::Ptr query) {
|
||||
if (!query) {
|
||||
// TODO: log
|
||||
return;
|
||||
}
|
||||
void BotHandlers::handleCallback(const TgBot::CallbackQuery::Ptr query) {
|
||||
std::string data = query -> data;
|
||||
|
||||
try {
|
||||
// TODO: Тут mutex на многопоточке
|
||||
botApi.answerCallbackQuery(query->id);
|
||||
} catch (const std::exception& e) {
|
||||
std::cerr << "answerCallbackQuery error";
|
||||
//TODO: обработка ошибки
|
||||
if (data.starts_with(BotConstants::Callback::NAVIGATION)) {
|
||||
handleNavigation(query);
|
||||
}
|
||||
|
||||
processCallbackImpl(query);
|
||||
}
|
||||
|
||||
/// В угоду потокобезопасности создаем новый экземпляр TgBot::Api
|
||||
HandlerResult BotHandlers::returnMyTitles(int64_t userId) {
|
||||
// Здесь должен происходить запрос на сервер
|
||||
std::vector<Title> titles = {{123, "Школа мертвяков", "", 1}, {321, "KissXsis", "", 2}};
|
||||
|
|
@ -31,37 +23,6 @@ HandlerResult BotHandlers::returnMyTitles(int64_t userId) {
|
|||
return result;
|
||||
}
|
||||
|
||||
void BotHandlers::handleNavigation(TgBot::CallbackQuery::Ptr query) {
|
||||
const std::string& data = query->data;
|
||||
if (data == BotConstants::Callback::MY_TITLES) {
|
||||
auto [text, kb] = BotHandlers::returnMyTitles(321);
|
||||
botApi.editMessageText(
|
||||
text,
|
||||
query->message->chat->id,
|
||||
query->message->messageId,
|
||||
"",
|
||||
"",
|
||||
nullptr,
|
||||
kb
|
||||
);
|
||||
}
|
||||
else {
|
||||
botApi.sendMessage(query->message->chat->id, BotConstants::Text::SAD_ERROR, nullptr, nullptr);
|
||||
}
|
||||
}
|
||||
|
||||
void BotHandlers::handleMessage(TgBot::Message::Ptr message) {
|
||||
//TODO: просмотр состояния пользователя
|
||||
void BotHandlers::handleNavigation(const TgBot::CallbackQuery::Ptr query) {
|
||||
return;
|
||||
}
|
||||
|
||||
void BotHandlers::processCallbackImpl(TgBot::CallbackQuery::Ptr query) {
|
||||
const std::string& data = query->data;
|
||||
|
||||
if (data.starts_with(BotConstants::Callback::NAVIGATION)) {
|
||||
handleNavigation(query);
|
||||
}
|
||||
else {
|
||||
botApi.sendMessage(query->message->chat->id, BotConstants::Text::SAD_ERROR, nullptr, nullptr);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue