partial working

main
Brett 2024-03-04 23:33:21 -05:00
parent d6e9a878f6
commit cb2acae98b
2 changed files with 104 additions and 20 deletions

View File

@ -87,6 +87,7 @@ namespace db
struct message_edits_t struct message_edits_t
{ {
blt::u64 messageID; blt::u64 messageID;
blt::u64 time_changed;
std::string old_content; std::string old_content;
std::string new_content; std::string new_content;
}; };
@ -202,10 +203,12 @@ namespace db
using namespace sqlite_orm; using namespace sqlite_orm;
return make_table("message_edits", return make_table("message_edits",
make_column("messageID", &message_edits_t::messageID), make_column("messageID", &message_edits_t::messageID),
make_column("time_changed", &message_edits_t::time_changed),
make_column("old_content", &message_edits_t::old_content), make_column("old_content", &message_edits_t::old_content),
make_column("new_content", &message_edits_t::new_content), make_column("new_content", &message_edits_t::new_content),
foreign_key(&message_edits_t::messageID).references(&message_t::messageID), foreign_key(&message_edits_t::messageID).references(&message_t::messageID),
primary_key(&message_edits_t::messageID, &message_edits_t::old_content, &message_edits_t::new_content)); primary_key(&message_edits_t::messageID, &message_edits_t::time_changed, &message_edits_t::old_content,
&message_edits_t::new_content));
} }
using message_edits_table_t = decltype(make_message_edits_table()); using message_edits_table_t = decltype(make_message_edits_table());

View File

@ -26,11 +26,26 @@ struct discord_message
discord_message& operator+=(T&& t) discord_message& operator+=(T&& t)
{ {
message += std::forward<T>(t); message += std::forward<T>(t);
return *this;
} }
void send() [[nodiscard]] std::string_view get() const
{ {
return message;
}
template<typename... Args, typename T, typename... UArgs>
void send(const T& event, void (T::*func)(Args...) const, UArgs&& ... args)
{
std::string message_copy = message;
while (message_copy.length() > 2000)
{
auto message_view = std::string_view(message_copy).substr(0, 2000);
auto pos = message_view.find_last_of('\n');
(event.*func)(message_copy.substr(0, pos), std::forward<UArgs>(args)...);
message_copy = message_copy.substr(pos);
}
(event.*func)(message_copy, std::forward<UArgs>(args)...);
} }
}; };
@ -75,8 +90,8 @@ struct db_obj
inline void printMessages() inline void printMessages()
{ {
using namespace sql; //using namespace sql;
auto data = db.select(object<message_t>); //auto data = db.select(object<message_t>);
} }
@ -181,7 +196,18 @@ struct db_obj
void commit(const user_history_t& edited) void commit(const user_history_t& edited)
{ {
db.insert(edited); using namespace sql;
auto existing_data = db.select(columns(&user_history_t::userID), from<user_history_t>(),
where(c(&user_history_t::userID) == edited.userID &&
c(&user_history_t::time_changed) == edited.time_changed));
if (!existing_data.empty())
{
BLT_WARN("Trying to insert user history data yet already exists!");
return;
}
db.replace(edited);
} }
void commit(const channel_info_t& channel) void commit(const channel_info_t& channel)
@ -211,22 +237,78 @@ struct db_obj
void commit(const channel_history_t& channel) void commit(const channel_history_t& channel)
{ {
db.insert(channel); using namespace sql;
auto existing_data = db.select(columns(&channel_history_t::channelID), from<channel_history_t>(),
where(c(&channel_history_t::channelID) == channel.channelID &&
c(&channel_history_t::time_changed) == channel.time_changed));
if (!existing_data.empty())
{
BLT_WARN("Trying to insert channel history data yet already exists!");
return;
}
db.replace(channel);
} }
void commit(const message_t& message) void commit(const message_t& message)
{ {
db.insert(message); using namespace sql;
auto existing_data = db.select(columns(&message_t::messageID), from<message_t>(),
where(c(&message_t::messageID) == message.messageID));
if (!existing_data.empty())
{
BLT_WARN("Trying to insert message data yet message already exists!");
return;
}
db.replace(message);
} }
void commit(const attachment_t& attachment) void commit(const attachment_t& attachment)
{ {
db.insert(attachment); using namespace sql;
auto existing_data = db.select(columns(&attachment_t::messageID), from<attachment_t>(),
where(c(&attachment_t::messageID) == attachment.messageID &&
c(&attachment_t::attachmentID) == attachment.attachmentID));
if (!existing_data.empty())
{
BLT_WARN("Trying to insert attachment data yet attachment already exists!");
return;
} }
void commit(const message_edits_t& edited) db.replace(attachment);
}
void commit(message_edits_t edited)
{ {
db.insert(edited); using namespace sql;
try
{
auto message_data = db.get<message_t>(edited.messageID);
edited.old_content = message_data.content;
message_data.content = edited.new_content;
db.update(message_data);
} catch (const std::system_error& ignored)
{
BLT_WARN("Failed to fetch message ID, user is trying to edit message which does not exist!");
}
auto existing_data = db.select(columns(&message_edits_t::messageID), from<message_edits_t>(),
where(c(&message_edits_t::messageID) == edited.messageID &&
c(&message_edits_t::time_changed) == edited.time_changed &&
c(&message_edits_t::old_content) == edited.old_content &&
c(&message_edits_t::new_content) == edited.new_content));
if (!existing_data.empty())
{
BLT_WARN("Trying to insert message edits history data yet already exists!");
return;
}
db.replace(edited);
} }
void commit(message_deletes_t& deleted) void commit(message_deletes_t& deleted)
@ -244,7 +326,7 @@ struct db_obj
deleted.content = std::get<0>(message_content[0]); deleted.content = std::get<0>(message_content[0]);
deleted.userID = std::get<1>(message_content[0]); deleted.userID = std::get<1>(message_content[0]);
db.insert(deleted); db.replace(deleted);
} }
void commit(const server_info_t& server) void commit(const server_info_t& server)
@ -387,7 +469,7 @@ int main(int argc, const char** argv)
dpp::cluster bot(args.get<std::string>("token"), dpp::i_default_intents | dpp::i_message_content | dpp::i_all_intents | dpp::i_guild_members); dpp::cluster bot(args.get<std::string>("token"), dpp::i_default_intents | dpp::i_message_content | dpp::i_all_intents | dpp::i_guild_members);
bot.start_timer([](const auto& v) { bot.start_timer([](const auto&) {
for (auto& db : databases) for (auto& db : databases)
db.second->flush(); db.second->flush();
}, 60); }, 60);
@ -477,6 +559,7 @@ int main(int argc, const char** argv)
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) {
message_edits_t edited; message_edits_t edited;
edited.messageID = event.msg.id; edited.messageID = event.msg.id;
edited.time_changed = blt::system::getCurrentTimeMilliseconds();
edited.new_content = event.msg.content; edited.new_content = event.msg.content;
get(event.msg.guild_id).commit(edited); 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,
@ -488,7 +571,8 @@ int main(int argc, const char** argv)
return; return;
if (blt::string::starts_with(event.msg.content, "!dump")) if (blt::string::starts_with(event.msg.content, "!dump"))
{ {
std::string message = "Server Count: "; discord_message message;
message += "Server Count: ";
message += std::to_string(databases.size()); message += std::to_string(databases.size());
message += '\n'; message += '\n';
for (auto& db : databases) for (auto& db : databases)
@ -504,13 +588,10 @@ int main(int argc, const char** argv)
message += std::to_string(db.second->messages()); message += std::to_string(db.second->messages());
message += '\n'; message += '\n';
} }
while (message.length() > 2000) BLT_TRACE(message.get());
{ message.send<const std::string&, dpp::command_completion_event_t>(event,
auto message_view = std::string_view(message).substr(0, 2000); &dpp::message_create_t::send,
auto pos = message_view.find_last_of('\n'); dpp::utility::log_error());
event.send(message.substr(0, pos));
message = message.substr(pos);
}
} }
if (blt::string::starts_with(event.msg.content, "!messages")) if (blt::string::starts_with(event.msg.content, "!messages"))
{ {