Compare commits

..

No commits in common. "3d8abc3f0c20b8df3e2fb4db3f5b70056bd354d2" and "ea29fa79f005884f63241742ebbd391268d03f57" have entirely different histories.

7 changed files with 45 additions and 94 deletions

View file

@ -1,4 +1 @@
build/
out/
.vscode
api/generated-client

View file

@ -27,6 +27,5 @@ namespace BotConstants {
}
namespace Text {
const std::string MAIN_MENU = "Вас приветствует nyanimedb бот:)\nЧего будем делать?";
const std::string SAD_ERROR = "У нас что-то случилось:(\nМы обязательно скоро исправимся";
}
}

View file

@ -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

View file

@ -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 Идентификатор пользователя

View file

@ -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});
}

View file

@ -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() {
}
*/

View file

@ -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);
}
}