2023-11-25 09:22:55 -08:00
|
|
|
#include "connection.hpp"
|
2023-11-22 19:59:34 -08:00
|
|
|
#include "settings.hpp"
|
2023-11-25 09:22:55 -08:00
|
|
|
|
2023-11-29 13:13:48 -08:00
|
|
|
#include <boost/asio.hpp>
|
2025-01-26 14:38:13 -08:00
|
|
|
#include <boost/log/trivial.hpp>
|
2023-11-29 13:13:48 -08:00
|
|
|
|
2023-11-22 19:59:34 -08:00
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
|
|
|
#include <memory>
|
|
|
|
#include <string>
|
|
|
|
|
2025-01-26 14:38:13 -08:00
|
|
|
#include "bot.hpp"
|
2025-01-26 19:35:56 -08:00
|
|
|
#include "client.hpp"
|
|
|
|
#include "registration.hpp"
|
2023-11-22 19:59:34 -08:00
|
|
|
|
2025-01-26 19:35:56 -08:00
|
|
|
using namespace std::literals;
|
2025-01-23 00:47:05 -08:00
|
|
|
|
2025-01-25 15:45:31 -08:00
|
|
|
auto start(boost::asio::io_context &io, const Settings &settings) -> void
|
2023-11-22 19:59:34 -08:00
|
|
|
{
|
2025-01-25 15:45:31 -08:00
|
|
|
const auto connection = std::make_shared<Connection>(io);
|
2025-01-26 19:35:56 -08:00
|
|
|
const auto client = Client::start(*connection);
|
|
|
|
Registration::start(*connection, settings, client);
|
2023-11-22 19:59:34 -08:00
|
|
|
|
2025-01-26 19:35:56 -08:00
|
|
|
const auto bot = Bot::start(client);
|
2025-01-22 23:49:48 -08:00
|
|
|
|
2025-01-24 14:48:15 -08:00
|
|
|
connection->sig_snote.connect([](auto &match) {
|
|
|
|
std::cout << "SNOTE " << static_cast<int>(match.get_tag()) << std::endl;
|
2025-01-22 23:49:48 -08:00
|
|
|
for (auto c : match.get_results())
|
2023-11-28 11:34:27 -08:00
|
|
|
{
|
|
|
|
std::cout << " " << std::string_view{c.first, c.second} << std::endl;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2025-01-26 19:44:35 -08:00
|
|
|
client->sig_registered.connect([connection]() {
|
2025-01-26 19:35:56 -08:00
|
|
|
connection->send_join("##glguy"sv);
|
|
|
|
});
|
|
|
|
|
|
|
|
connection->sig_disconnect.connect(
|
|
|
|
[&io, &settings, client, bot]() {
|
|
|
|
client->shutdown();
|
|
|
|
bot->shutdown();
|
|
|
|
|
2023-11-25 09:22:55 -08:00
|
|
|
auto timer = std::make_shared<boost::asio::steady_timer>(io);
|
2025-01-22 20:33:17 -08:00
|
|
|
timer->expires_after(5s);
|
2025-01-26 14:51:44 -08:00
|
|
|
timer->async_wait([&io, &settings, timer](auto) { start(io, settings); });
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2025-01-26 19:35:56 -08:00
|
|
|
bot->sig_command.connect([connection](const Command &cmd) {
|
|
|
|
std::cout << "COMMAND " << cmd.command << " from " << cmd.account << std::endl;
|
|
|
|
});
|
|
|
|
|
|
|
|
connection->start({
|
2025-01-26 14:51:44 -08:00
|
|
|
.tls = settings.use_tls,
|
|
|
|
.host = settings.host,
|
|
|
|
.port = settings.service,
|
|
|
|
.verify = settings.tls_hostname,
|
|
|
|
});
|
2023-11-22 19:59:34 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
auto get_settings() -> Settings
|
|
|
|
{
|
2025-01-25 15:45:31 -08:00
|
|
|
if (auto config_stream = std::ifstream{"config.toml"})
|
2023-11-22 19:59:34 -08:00
|
|
|
{
|
|
|
|
return Settings::from_stream(config_stream);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2025-01-26 14:38:13 -08:00
|
|
|
BOOST_LOG_TRIVIAL(error) << "Unable to open config.toml";
|
2023-11-22 19:59:34 -08:00
|
|
|
std::exit(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
auto main() -> int
|
|
|
|
{
|
2025-01-25 15:45:31 -08:00
|
|
|
const auto settings = get_settings();
|
2023-11-22 19:59:34 -08:00
|
|
|
auto io = boost::asio::io_context{};
|
|
|
|
start(io, settings);
|
|
|
|
io.run();
|
|
|
|
}
|