Compare commits

..

2 Commits

Author SHA1 Message Date
Brett 25ec286d05 i went to a park today 2024-02-26 12:43:31 -05:00
Brett e9cd4345f5 lovely 2024-02-26 12:17:59 -05:00
2 changed files with 61 additions and 22 deletions

View File

@ -1,4 +1,4 @@
cmake_minimum_required(VERSION 3.27) cmake_minimum_required(VERSION 3.25)
project(discord_bot) project(discord_bot)
option(ENABLE_ADDRSAN "Enable the address sanitizer" OFF) option(ENABLE_ADDRSAN "Enable the address sanitizer" OFF)

View File

@ -15,10 +15,16 @@ struct message_t
std::string content; std::string content;
}; };
struct attachment_t
{
blt::u64 messageID;
blt::u64 channelID;
std::string url;
};
struct user_info_t struct user_info_t
{ {
blt::u64 userID; blt::u64 userID;
blt::u64 changeTime;
std::string username; std::string username;
std::string global_nickname; std::string global_nickname;
std::string server_name; std::string server_name;
@ -39,15 +45,37 @@ struct message_edits_t
std::string new_content; std::string new_content;
}; };
struct message_deletes_t
{
blt::u64 messageID;
blt::u64 channelID;
};
struct db_obj struct db_obj
{ {
private: private:
blt::u64 guildID; blt::u64 guildID;
std::string path;
public: public:
db_obj(blt::u64 guildID, std::string_view path): guildID(guildID), path(path) std::vector<message_t> messages;
std::vector<user_info_t> user_data;
std::vector<channel_info_t> channel_data;
std::vector<message_edits_t> message_edits;
std::vector<message_deletes_t> message_deletes;
std::vector<attachment_t> attachments;
public:
explicit db_obj(blt::u64 guildID): guildID(guildID)
{} {}
void dump()
{
}
void check_for_updates(dpp::cluster& bot)
{
}
}; };
namespace db namespace db
@ -62,6 +90,13 @@ namespace db
blt::hashmap_t<blt::u64, db_obj> databases; blt::hashmap_t<blt::u64, db_obj> databases;
db_obj& get(blt::u64 id)
{
if (databases.find(id) == databases.end())
databases.insert({id, db_obj{id}});
return databases.at(id);
}
int main(int argc, const char** argv) int main(int argc, const char** argv)
{ {
using namespace sqlite_orm; using namespace sqlite_orm;
@ -74,8 +109,16 @@ 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::cluster bot(args.get<std::string>("token"), dpp::i_default_intents | dpp::i_message_content | dpp::i_all_intents);
bot.on_message_delete([&bot](const dpp::message_delete_t& event) { bot.on_user_update([&bot](const dpp::user_update_t& event) {
BLT_INFO("User '%s' updated in some way; global name: '%s'", event.updated.username.c_str(), event.updated.global_name.c_str());
});
bot.on_guild_member_update([&bot](const dpp::guild_member_update_t& event) {
});
bot.on_message_delete([&bot](const dpp::message_delete_t& event) {
BLT_DEBUG("Message %ld deleted content in %ld", event.id, event.channel_id);
}); });
bot.on_message_delete_bulk([&bot](const dpp::message_delete_bulk_t& event) { bot.on_message_delete_bulk([&bot](const dpp::message_delete_bulk_t& event) {
@ -90,25 +133,21 @@ int main(int argc, const char** argv)
bot.on_message_create([&bot](const dpp::message_create_t& event) { bot.on_message_create([&bot](const dpp::message_create_t& event) {
if (event.msg.id == bot.me.id) if (event.msg.id == bot.me.id)
return; return;
bot.guild_get(event.msg.guild_id, [](const dpp::confirmation_callback_t& con) { if (blt::string::contains(event.msg.content, "/dump"))
BLT_INFO("Guild name: %s", con.get<dpp::guild>().name.c_str()); {
}); for (auto g : databases)
g.second.dump();
}
auto& storage = get(event.msg.guild_id);
storage.messages.push_back({
event.msg.id,
event.msg.channel_id,
event.msg.author.id,
event.msg.content
});
BLT_TRACE("(%s '%s' aka '%s' with mention '%s')> %s", event.msg.author.username.c_str(), event.msg.author.global_name.c_str(),
event.msg.member.get_nickname().c_str(), event.msg.member.get_mention().c_str(), event.msg.content.c_str());
for (const dpp::attachment& attach : event.msg.attachments) for (const dpp::attachment& attach : event.msg.attachments)
{ storage.attachments.push_back({event.msg.id, event.msg.channel_id, attach.url});
BLT_INFO("\tAttachment: %s", attach.url.c_str());
}
for (const dpp::embed& embed : event.msg.embeds)
{
BLT_INFO("\tEmbedding: %s", embed.url.c_str());
}
//BLT_TRACE_STREAM << event.msg.channel_id.str() << " " << event.msg.channel_id.str() << " " << "\n";
// if (blt::string::toLowerCase(event.msg.author.username) != "autismbot" && blt::string::toLowerCase(event.msg.author.username) != "jewhack")
// {
// //event.reply("Test response " + event.msg.author.global_name);
// }
}); });
bot.start(dpp::st_wait); bot.start(dpp::st_wait);