xbot/main.cpp

110 lines
2.9 KiB
C++
Raw Normal View History

2023-11-22 19:59:34 -08:00
#include <boost/asio.hpp>
2023-11-25 09:22:55 -08:00
#include "connection.hpp"
2023-11-27 14:12:20 -08:00
#include "event.hpp"
2023-11-22 19:59:34 -08:00
#include "ircmsg.hpp"
2023-11-25 09:22:55 -08:00
#include "linebuffer.hpp"
2023-11-22 19:59:34 -08:00
#include "settings.hpp"
2023-11-25 20:09:20 -08:00
#include "write_irc.hpp"
2023-11-25 09:22:55 -08:00
2023-11-27 14:12:20 -08:00
#include "command_thread.hpp"
2023-11-25 09:22:55 -08:00
#include "irc_parse_thread.hpp"
2023-11-25 20:09:20 -08:00
#include "ping_thread.hpp"
2023-11-27 14:12:20 -08:00
#include "registration_thread.hpp"
2023-11-26 16:48:21 -08:00
#include "self_thread.hpp"
2023-11-27 14:12:20 -08:00
#include "snote_thread.hpp"
#include "watchdog_thread.hpp"
2023-11-29 08:56:58 -08:00
#include "priv_thread.hpp"
2023-11-22 19:59:34 -08:00
#include <algorithm>
#include <chrono>
#include <fstream>
#include <coroutine>
#include <iostream>
#include <limits>
#include <list>
#include <memory>
#include <string>
#include <string_view>
#include <tuple>
#include <utility>
#include <variant>
#include <vector>
#include <unordered_map>
#include <unordered_set>
using namespace std::chrono_literals;
2023-11-29 08:56:58 -08:00
auto echo_thread(
Connection& connection,
std::shared_ptr<PrivThread> priv_thread) -> void
2023-11-26 16:48:21 -08:00
{
2023-11-29 08:56:58 -08:00
connection.add_listener<CommandEvent>([&connection, priv_thread](CommandEvent& event)
2023-11-26 16:48:21 -08:00
{
2023-11-29 09:44:36 -08:00
if ("raw" == event.command && priv_thread->check_command(event, PrivThread::owner_priv))
2023-11-26 16:48:21 -08:00
{
2023-11-27 14:12:20 -08:00
connection.write_line(std::string{event.arg});
2023-11-26 19:59:12 -08:00
event.handled_ = true;
send_notice(connection, event.nick, "ack");
2023-11-26 16:48:21 -08:00
}
});
}
2023-11-22 19:59:34 -08:00
auto start(boost::asio::io_context & io, Settings const& settings) -> void
{
2023-11-29 09:44:36 -08:00
auto const connection = std::make_shared<Connection>(io);
2023-11-22 19:59:34 -08:00
2023-11-27 14:12:20 -08:00
WatchdogThread::start(*connection);
IrcParseThread::start(*connection);
PingThread::start(*connection);
SelfThread::start(*connection);
RegistrationThread::start(*connection, settings.password, settings.username, settings.realname, settings.nickname);
2023-11-26 21:16:56 -08:00
SnoteThread::start(*connection);
2023-11-26 19:59:12 -08:00
CommandThread::start(*connection);
2023-11-29 09:44:36 -08:00
auto const priv_thread = PrivThread::start(*connection, "privs.toml");
2023-11-29 08:56:58 -08:00
echo_thread(*connection, priv_thread);
2023-11-26 21:16:56 -08:00
2023-11-29 09:44:36 -08:00
/*
2023-11-28 11:34:27 -08:00
connection->add_listener<SnoteEvent>([](SnoteEvent& event) {
std::cout << "SNOTE " << static_cast<int>(event.get_tag()) << std::endl;
for (auto c : event.get_results())
{
std::cout << " " << std::string_view{c.first, c.second} << std::endl;
}
});
2023-11-29 09:44:36 -08:00
*/
2023-11-28 11:34:27 -08:00
2023-11-22 19:59:34 -08:00
boost::asio::co_spawn(
io,
2023-11-25 09:22:55 -08:00
connection->connect(io, settings.host, settings.service),
2023-11-22 19:59:34 -08:00
[&io, &settings](std::exception_ptr e)
{
2023-11-25 09:22:55 -08:00
auto timer = std::make_shared<boost::asio::steady_timer>(io);
timer->expires_from_now(5s);
timer->async_wait([&io, &settings, timer](auto) {
2023-11-22 19:59:34 -08:00
start(io, settings);
});
});
}
auto get_settings() -> Settings
{
if (auto config_stream = std::ifstream {"config.toml"})
{
return Settings::from_stream(config_stream);
}
else
{
std::cerr << "Unable to open config.toml\n";
std::exit(1);
}
}
auto main() -> int
{
auto const settings = get_settings();
auto io = boost::asio::io_context{};
start(io, settings);
io.run();
}