commiting

main
Brett 2024-02-28 22:32:09 -05:00
parent c641fbfc1b
commit e207ca9b5d
3 changed files with 92 additions and 19 deletions

View File

@ -55,6 +55,7 @@ namespace db
struct channel_info_t struct channel_info_t
{ {
blt::u64 channelID; blt::u64 channelID;
std::string channel_topic;
std::string channel_name; std::string channel_name;
}; };
@ -76,6 +77,9 @@ namespace db
struct attachment_t struct attachment_t
{ {
blt::u64 messageID; blt::u64 messageID;
blt::u64 attachmentID;
std::string filename;
std::string description;
std::string url; std::string url;
}; };
@ -125,6 +129,7 @@ namespace db
using namespace sqlite_orm; using namespace sqlite_orm;
return make_table("channels", return make_table("channels",
make_column("channelID", &channel_info_t::channelID, primary_key()), make_column("channelID", &channel_info_t::channelID, primary_key()),
make_column("channel_topic", &channel_info_t::channel_topic),
make_column("channel_name", &channel_info_t::channel_name)); make_column("channel_name", &channel_info_t::channel_name));
} }
@ -162,9 +167,12 @@ namespace db
using namespace sqlite_orm; using namespace sqlite_orm;
return make_table("attachments", return make_table("attachments",
make_column("messageID", &attachment_t::messageID), make_column("messageID", &attachment_t::messageID),
make_column("attachmentID", &attachment_t::attachmentID),
make_column("filename", &attachment_t::filename),
make_column("description", &attachment_t::description),
make_column("url", &attachment_t::url), make_column("url", &attachment_t::url),
foreign_key(&attachment_t::messageID).references(&message_t::messageID), foreign_key(&attachment_t::messageID).references(&message_t::messageID),
primary_key(&attachment_t::messageID, &attachment_t::url)); primary_key(&attachment_t::messageID, &attachment_t::attachmentID));
} }
using attachment_table_t = decltype(make_attachment_table()); using attachment_table_t = decltype(make_attachment_table());

@ -1 +1 @@
Subproject commit 9b4d0cc9a8493c608ab0075ab2c6a2b66061f3be Subproject commit 9ad652195b0a69f9977d313eff4dd01a7890f1df

View File

@ -65,6 +65,7 @@ struct db_obj
BLT_DEBUG("\tFetched channel id %ld with name '%s'", channel.first, channel.second.name.c_str()); BLT_DEBUG("\tFetched channel id %ld with name '%s'", channel.first, channel.second.name.c_str());
channel_info_t channels; channel_info_t channels;
channels.channel_name = channel.second.name; channels.channel_name = channel.second.name;
channels.channel_topic = channel.second.topic;
channels.channelID = channel.first; channels.channelID = channel.first;
commit(channels); commit(channels);
} }
@ -147,7 +148,8 @@ struct db_obj
void process_queue(dpp::cluster& bot) void process_queue(dpp::cluster& bot)
{ {
thread = new std::thread([this, &bot]() { thread = new std::thread([this, &bot]() {
while (user_count != loaded_users.load()) // while (user_count != loaded_users.load())
while (true)
{ {
std::this_thread::sleep_for(std::chrono::milliseconds(50)); std::this_thread::sleep_for(std::chrono::milliseconds(50));
blt::u64 member = 0; blt::u64 member = 0;
@ -197,6 +199,12 @@ struct db_obj
}); });
} }
inline void queue_user(blt::u64 userID)
{
std::scoped_lock lock(user_load_queue_mutex);
user_load_queue.push(userID);
}
bool loading_complete() bool loading_complete()
{ {
return loaded_channels.load() && loaded_members.load() && user_count != -1ul && user_count == loaded_users.load(); return loaded_channels.load() && loaded_members.load() && user_count != -1ul && user_count == loaded_users.load();
@ -303,7 +311,18 @@ int main(int argc, const char** argv)
user_info_t info; user_info_t info;
info.userID = event.updated.user_id; info.userID = event.updated.user_id;
info.server_name = event.updated.get_nickname(); info.server_name = event.updated.get_nickname();
get(event.updated.guild_id).commit(info); auto& storage = get(event.updated.guild_id);
storage.commit(info);
storage.queue_user(event.updated.user_id);
}));
bot.on_guild_member_add(wait_wrapper<dpp::guild_member_add_t>([](const dpp::guild_member_add_t& event) {
user_info_t info;
info.userID = event.added.user_id;
info.server_name = event.added.get_nickname();
auto& storage = get(event.added.guild_id);
storage.commit(info);
storage.queue_user(event.added.user_id);
})); }));
bot.on_message_delete(wait_wrapper<dpp::message_delete_t>([&bot](const dpp::message_delete_t& event) { bot.on_message_delete(wait_wrapper<dpp::message_delete_t>([&bot](const dpp::message_delete_t& event) {
@ -316,16 +335,28 @@ int main(int argc, const char** argv)
bot.on_message_delete_bulk(wait_wrapper<dpp::message_delete_bulk_t>([&bot](const dpp::message_delete_bulk_t& event) { bot.on_message_delete_bulk(wait_wrapper<dpp::message_delete_bulk_t>([&bot](const dpp::message_delete_bulk_t& event) {
BLT_INFO("Bulk delete!"); BLT_INFO("Bulk delete!");
if (event.deleting_channel == nullptr || event.deleting_guild == nullptr)
{
BLT_WARN("Unable to handle bulk delete, guild or channel is not in cache!");
BLT_WARN("Raw String:");
BLT_WARN("\t%s", event.raw_event.c_str());
return;
}
for (auto v : event.deleted) for (auto v : event.deleted)
{
BLT_TRACE("\tBulk Delete: %ld", v); BLT_TRACE("\tBulk Delete: %ld", v);
message_deletes_t deleted;
deleted.messageID = v;
deleted.channelID = event.deleting_channel->id;
get(event.deleting_guild->id).commit(deleted);
}
})); }));
bot.on_message_update(wait_wrapper<dpp::message_update_t>([&bot](const dpp::message_update_t& event) { bot.on_message_update(wait_wrapper<dpp::message_update_t>([&bot](const dpp::message_update_t& event) {
auto& storage = get(event.msg.guild_id);
message_edits_t edited; message_edits_t edited;
edited.messageID = event.msg.id; edited.messageID = event.msg.id;
edited.new_content = event.msg.content; edited.new_content = event.msg.content;
get(event.msg.guild_id).commit(edited);
BLT_INFO("%ld (from user %ld in channel %ld ['%s']) -> '%s'", event.msg.id, event.msg.author.id, event.msg.channel_id, BLT_INFO("%ld (from user %ld in channel %ld ['%s']) -> '%s'", event.msg.id, event.msg.author.id, event.msg.channel_id,
event.msg.author.username.c_str(), event.msg.content.c_str()); event.msg.author.username.c_str(), event.msg.content.c_str());
})); }));
@ -334,21 +365,55 @@ int main(int argc, const char** argv)
if (event.msg.id == bot.me.id) if (event.msg.id == bot.me.id)
return; return;
if (blt::string::starts_with(event.msg.content, "!dump")) if (blt::string::starts_with(event.msg.content, "!dump"))
{}
auto& storage = get(event.msg.guild_id);
message_t message;
message.messageID = event.msg.id;
message.channelID = event.msg.channel_id;
message.userID = event.msg.author.id;
message.content = event.msg.content;
storage.commit(message);
for (const dpp::attachment& attach : event.msg.attachments)
{ {
attachment_t attachment;
attachment.messageID = event.msg.id;
attachment.attachmentID = attach.id;
attachment.url = attach.url;
attachment.filename = attach.filename;
attachment.description = attach.description;
storage.commit(attachment);
} }
// auto& storage = get(event.msg.guild_id); }));
// storage.messages.push_back({
// event.msg.id, bot.on_channel_create(wait_wrapper<dpp::channel_create_t>([](const dpp::channel_create_t& event) {
// event.msg.channel_id, if (event.created == nullptr)
// event.msg.author.id, {
// event.msg.content BLT_WARN("Unable to handle channel creation, channel is not in cache!");
// }); BLT_WARN("Raw String:");
// BLT_WARN("\t%s", event.raw_event.c_str());
// for (const dpp::attachment& attach : event.msg.attachments) return;
// { }
// storage.attachments.push_back({event.msg.id, attach.url}); channel_info_t channel;
// } channel.channelID = event.created->id;
channel.channel_topic = event.created->topic;
channel.channel_name = event.created->name;
get(event.created->guild_id).commit(channel);
}));
bot.on_channel_delete(wait_wrapper<dpp::channel_delete_t>([](const dpp::channel_delete_t& event) {
channel_info_t channel;
channel.channelID = event.deleted.id;
channel.channel_name = event.deleted.name;
channel.channel_topic = event.deleted.topic;
get(event.deleted.guild_id).commit(channel);
}));
bot.on_channel_update(wait_wrapper<dpp::channel_update_t>([](const dpp::channel_update_t& event) {
channel_info_t channel;
channel.channelID = event.updated->guild_id;
channel.channel_name = event.updated->name;
channel.channel_topic = event.updated->topic;
get(event.updated->guild_id).commit(channel);
})); }));
bot.start(dpp::st_wait); bot.start(dpp::st_wait);