1
0
Fork 0
mirror of https://gitlab.com/niansa/dpplogger.git synced 2025-03-06 20:48:29 +01:00

Minor fixes to previous commit

This commit is contained in:
niansa 2023-01-08 23:53:27 +01:00
parent 108853c190
commit 13b372714d
2 changed files with 26 additions and 9 deletions

@ -1 +1 @@
Subproject commit 9c225be66bdec7a509efb32f40b3d45ec592709b
Subproject commit 15489b816b4d70a927e920fb9327c7ba122644ee

View file

@ -11,6 +11,8 @@
#include <dcboost/discord.hpp>
#include <dcboost/snowflake.hpp>
#include <fstream>
using namespace ChatFuse;
using namespace QLog;
@ -223,7 +225,7 @@ protected:
// since it's safe to assume it's already been cached
// Make sure data is actually incomplete
if (incomplete_data["name"].isString() && incomplete_data["channels"].isArray()) {
if ((incomplete_data["name"].isString() && incomplete_data["channels"].isArray()) || incomplete_data["properties"].isObject()) {
// It's not, so we'll just use it as-is
processGuild(std::move(incomplete_data));
continue;
@ -236,7 +238,20 @@ protected:
co_await asyncSleep(rng.getUInt(6000, 15000));
}
}
void fixGuild(Json::Value& data) {
if (!settings.is_bot) {
auto& props = data["properties"];
for (const auto& prop_name : props.getMemberNames()) {
data[prop_name] = std::move(props[prop_name]);
}
data.removeMember("properties");
}
}
Cache::StoreResult processGuild(Json::Value&& data) {
// Fix guild
fixGuild(data);
// Get guild ID
const auto& id = data["id"];
// Insert into database
@ -407,18 +422,20 @@ protected:
* Intent handler
*/
virtual boost::asio::awaitable<void> intentHandler(std::string intent, Json::Value data) override {
std::ofstream(intent+".json") << data;
if (intent == "READY") [[unlikely]] {
const auto& user = cache.store(std::move(data["user"])).data;
logger.log(Loglevel::info, "Connected to Discord as: "+user["username"].asString()+'#'+user["discriminator"].asString());
settings.is_bot = GetJSONAsOptionalInt(user["bot"]).value_or(false);
co_await fetchAllGuilds(std::move(data["guilds"]));
}
else if (intent == "GUILD_CREATE") [[unlikely]] {
fixGuild(data);
processGuild(std::move(data));
} else if (intent == "GUILD_UPDATE") [[unlikely]] {
insertGuildUpdate(data, false);
cache.store(std::move(data));
fixGuild(data);
if (cache.store(data).changed) insertGuildUpdate(data, false);
} else if (intent == "GUILD_DELETE") [[unlikely]] {
fixGuild(data);
insertGuildDelete(data["id"]);
}
else if (intent == "MESSAGE_CREATE") [[likely]] {
@ -436,8 +453,7 @@ protected:
insertChannelUpdate(data, true);
cache.store(std::move(data));
} else if (intent == "CHANNEL_UPDATE") [[unlikely]] {
insertChannelUpdate(data, false);
cache.store(std::move(data));
if (cache.store(data).changed) cache.store(std::move(data));
} else if (intent == "CHANNEL_DELETE") [[unlikely]] {
insertChannelDelete(data["id"]);
}
@ -464,9 +480,10 @@ int main(int argc, char **argv) {
boost::asio::io_service io;
// Set up client
auto client = std::make_shared<MyClient>(io, ChatFuse::Discord::Settings{
auto client = std::make_shared<MyClient>(io, Discord::Settings{
.bot_token = argv[1],
.intents = ChatFuse::Discord::intents::all
.intents = Discord::intents::all,
.is_bot = false
});
client->detach();