X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_xline_db.cpp;h=6928e43d75a330ffe79dc18a87f1fe01a2888537;hb=581d1d8fa0ef62e20409543570390613c78e6f5b;hp=a64dc7071185162bd52df98002d2d196defdf0e2;hpb=9b25df31096f889e3653ab100493133014d4fe73;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_xline_db.cpp b/src/modules/m_xline_db.cpp index a64dc7071..6928e43d7 100644 --- a/src/modules/m_xline_db.cpp +++ b/src/modules/m_xline_db.cpp @@ -1,7 +1,15 @@ /* * InspIRCd -- Internet Relay Chat Daemon * - * Copyright (C) 2008 Thomas Stagner + * Copyright (C) 2019 Matt Schatz + * Copyright (C) 2014 Justin Crawford + * Copyright (C) 2013, 2015, 2018-2020 Sadie Powell + * Copyright (C) 2012-2013 Attila Molnar + * Copyright (C) 2012, 2019 Robby + * Copyright (C) 2012, 2014 Adam + * Copyright (C) 2012 ChrisTX + * Copyright (C) 2010 Craig Edwards + * Copyright (C) 2009 Daniel De Graaf * Copyright (C) 2008 Robin Burchell * * This file is part of InspIRCd. InspIRCd is free software: you can @@ -22,11 +30,20 @@ #include "xline.h" #include -class ModuleXLineDB : public Module +class ModuleXLineDB + : public Module + , public Timer { + private: bool dirty; std::string xlinedbpath; + public: + ModuleXLineDB() + : Timer(0, true) + { + } + void init() CXX11_OVERRIDE { /* Load the configuration @@ -36,7 +53,8 @@ class ModuleXLineDB : public Module * ...and so is discarding all current in-memory XLines for the ones in the database. */ ConfigTag* Conf = ServerInstance->Config->ConfValue("xlinedb"); - xlinedbpath = ServerInstance->Config->Paths.PrependData(Conf->getString("filename", "xline.db")); + xlinedbpath = ServerInstance->Config->Paths.PrependData(Conf->getString("filename", "xline.db", 1)); + SetInterval(Conf->getDuration("saveperiod", 5)); // Read xlines before attaching to events ReadDatabase(); @@ -66,13 +84,14 @@ class ModuleXLineDB : public Module dirty = true; } - void OnBackgroundTimer(time_t now) CXX11_OVERRIDE + bool Tick(time_t) CXX11_OVERRIDE { if (dirty) { if (WriteDatabase()) dirty = false; } + return true; } bool WriteDatabase() @@ -137,7 +156,7 @@ class ModuleXLineDB : public Module #ifdef _WIN32 remove(xlinedbpath.c_str()); #endif - // Use rename to move temporary to new db - this is guarenteed not to fuck up, even in case of a crash. + // Use rename to move temporary to new db - this is guaranteed not to fuck up, even in case of a crash. if (rename(xlinenewdbpath.c_str(), xlinedbpath.c_str()) < 0) { ServerInstance->Logs->Log(MODNAME, LOG_DEBUG, "Cannot replace old database \"%s\" with new database \"%s\"! %s (%d)", xlinedbpath.c_str(), xlinenewdbpath.c_str(), strerror(errno), errno); @@ -200,8 +219,8 @@ class ModuleXLineDB : public Module continue; } - XLine* xl = xlf->Generate(ServerInstance->Time(), atoi(command_p[5].c_str()), command_p[3], command_p[6], command_p[2]); - xl->SetCreateTime(atoi(command_p[4].c_str())); + XLine* xl = xlf->Generate(ServerInstance->Time(), ConvToNum(command_p[5]), command_p[3], command_p[6], command_p[2]); + xl->SetCreateTime(ConvToNum(command_p[4])); if (ServerInstance->XLines->AddLine(xl, NULL)) { @@ -217,7 +236,7 @@ class ModuleXLineDB : public Module Version GetVersion() CXX11_OVERRIDE { - return Version("Keeps a dynamic log of all XLines created, and stores them in a separate conf file (xline.db).", VF_VENDOR); + return Version("Allows X-lines to be saved and reloaded on restart.", VF_VENDOR); } };