diff --git a/modules/database/db_atheme.cpp b/modules/database/db_atheme.cpp index 4599a7469..b97aa2984 100644 --- a/modules/database/db_atheme.cpp +++ b/modules/database/db_atheme.cpp @@ -20,6 +20,7 @@ #include "modules/info.h" #include "modules/ns_cert.h" #include "modules/os_forbid.h" +#include "modules/os_news.h" #include "modules/os_oper.h" #include "modules/os_session.h" #include "modules/suspend.h" @@ -199,6 +200,8 @@ private: { "JM", &DBAtheme::HandleIgnore }, { "KID", &DBAtheme::HandleIgnore }, { "KL", &DBAtheme::HandleKL }, + { "LI", &DBAtheme::HandleLI }, + { "LIO", &DBAtheme::HandleLIO }, { "LUID", &DBAtheme::HandleIgnore }, { "MC", &DBAtheme::HandleMC }, { "MCFP", &DBAtheme::HandleMCFP }, @@ -787,6 +790,58 @@ private: return true; } + bool HandleLI(AthemeRow &row) + { + // LI + auto setter = row.Get(); + auto subject = row.Get(); + auto ts = row.GetNum(); + auto body = row.GetRemaining(); + + if (!row) + return row.LogError(this); + + if (!news_service) + { + Log(this) << "Unable to convert logon news as os_news is not loaded"; + return true; + } + + auto *ni = news_service->CreateNewsItem(); + ni->type = NEWS_LOGON; + ni->text = Anope::printf("[%s] %s", subject.c_str(), body.c_str()); + ni->who = setter; + ni->time = ts; + news_service->AddNewsItem(ni); + return true; + } + + bool HandleLIO(AthemeRow &row) + { + // LIO + auto setter = row.Get(); + auto subject = row.Get(); + auto ts = row.GetNum(); + auto body = row.GetRemaining(); + + if (!row) + return row.LogError(this); + + if (!news_service) + { + Log(this) << "Unable to convert oper news as os_news is not loaded"; + return true; + } + + auto *ni = news_service->CreateNewsItem(); + ni->type = NEWS_OPER; + ni->text = Anope::printf("[%s] %s", subject.c_str(), body.c_str()); + ni->who = setter; + ni->time = ts; + news_service->AddNewsItem(ni); + return true; + } + bool HandleIgnore(AthemeRow &row) { Log(LOG_DEBUG_3) << "Intentionally ignoring Atheme database row: " << row.GetRow();