summaryrefslogtreecommitdiff
path: root/include/modules/os_ignore.h
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2013-05-05 03:30:08 -0400
committerAdam <Adam@anope.org>2013-05-05 03:30:08 -0400
commit57c2b65f08c9c0658003a74a32c6506829e12b0b (patch)
tree49883b790ed9f7cd395e0c6f2f62cc946d743635 /include/modules/os_ignore.h
parenta118946e657b8a137502ff60c1f21c608cb44495 (diff)
Move module header files to include/modules to fix naming conflicts with system headers
Diffstat (limited to 'include/modules/os_ignore.h')
-rw-r--r--include/modules/os_ignore.h79
1 files changed, 79 insertions, 0 deletions
diff --git a/include/modules/os_ignore.h b/include/modules/os_ignore.h
new file mode 100644
index 000000000..6c3e237ab
--- /dev/null
+++ b/include/modules/os_ignore.h
@@ -0,0 +1,79 @@
+/* OperServ ignore interface
+ *
+ * (C) 2003-2013 Anope Team
+ * Contact us at team@anope.org
+ *
+ * Please read COPYING and README for further details.
+ *
+ * Based on the original code of Epona by Lara.
+ * Based on the original code of Services by Andy Church.
+ */
+
+
+struct IgnoreData : Serializable
+{
+ Anope::string mask;
+ Anope::string creator;
+ Anope::string reason;
+ time_t time; /* When do we stop ignoring them? */
+
+ IgnoreData() : Serializable("IgnoreData") { }
+ void Serialize(Serialize::Data &data) const anope_override;
+ static Serializable* Unserialize(Serializable *obj, Serialize::Data &data);
+};
+
+class IgnoreService : public Service
+{
+ protected:
+ std::list<IgnoreData> ignores;
+
+ IgnoreService(Module *c) : Service(c, "IgnoreService", "ignore") { }
+
+ public:
+ virtual IgnoreData* AddIgnore(const Anope::string &mask, const Anope::string &creator, const Anope::string &reason, time_t delta = Anope::CurTime) = 0;
+
+ virtual bool DelIgnore(const Anope::string &mask) = 0;
+
+ inline void ClearIgnores() { this->ignores.clear(); }
+
+ virtual IgnoreData *Find(const Anope::string &mask) = 0;
+
+ inline std::list<IgnoreData> &GetIgnores() { return this->ignores; }
+};
+
+static ServiceReference<IgnoreService> ignore_service("IgnoreService", "ignore");
+
+void IgnoreData::Serialize(Serialize::Data &data) const
+{
+ data["mask"] << this->mask;
+ data["creator"] << this->creator;
+ data["reason"] << this->reason;
+ data["time"] << this->time;
+}
+
+Serializable* IgnoreData::Unserialize(Serializable *obj, Serialize::Data &data)
+{
+ if (!ignore_service)
+ return NULL;
+
+ if (obj)
+ {
+ IgnoreData *ign = anope_dynamic_static_cast<IgnoreData *>(obj);
+ data["mask"] >> ign->mask;
+ data["creator"] >> ign->creator;
+ data["reason"] >> ign->reason;
+ data["time"] >> ign->time;
+ return ign;
+ }
+
+ Anope::string smask, screator, sreason;
+ time_t t;
+
+ data["mask"] >> smask;
+ data["creator"] >> screator;
+ data["reason"] >> sreason;
+ data["time"] >> t;
+
+ return ignore_service->AddIgnore(smask, screator, sreason, t);
+}
+