summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/modules/m_filter.cpp2
-rw-r--r--src/modules/m_saquit.cpp86
2 files changed, 87 insertions, 1 deletions
diff --git a/src/modules/m_filter.cpp b/src/modules/m_filter.cpp
index eaa07c7c3..d975e13c1 100644
--- a/src/modules/m_filter.cpp
+++ b/src/modules/m_filter.cpp
@@ -44,7 +44,7 @@ class ModuleFilter : public Module
delete Conf;
}
- // format of a config entry is <keyword pattern="*glob*" reason="Some reason here">
+ // format of a config entry is <keyword pattern="*glob*" reason="Some reason here" action="kill/block">
virtual int OnUserPreMessage(userrec* user,void* dest,int target_type, std::string text)
{
diff --git a/src/modules/m_saquit.cpp b/src/modules/m_saquit.cpp
new file mode 100644
index 000000000..d7151e5ec
--- /dev/null
+++ b/src/modules/m_saquit.cpp
@@ -0,0 +1,86 @@
+/*
+ * SAQUIT module for InspIRCd
+ * Author: w00t
+ * Version: 1.0.0.0
+ *
+ * Syntax: /SAQUIT <user> [reason]
+ * Makes it appear as though <user> has /quit with [reason]
+ *
+ */
+
+#include <stdio.h>
+#include <string>
+#include "users.h"
+#include "channels.h"
+#include "modules.h"
+
+/* $ModDesc: Provides support for an SAQUIT command, exits user with a reason */
+
+Server *Srv;
+
+void handle_saquit(char **parameters, int pcnt, userrec *user)
+{
+ userrec* dest = Srv->FindNick(std::string(parameters[0]));
+ if (dest)
+ {
+
+ std::string line = "";
+ for (int i = 1; i < pcnt - 1; i++)
+ {
+ line = line + std::string(parameters[i]) + " ";
+ }
+ line = line + std::string(parameters[pcnt-1])
+
+ Srv->SendOpers(std::string(user->nick)+" used SAQUIT to make "+std::string(dest->nick)+" quit with a reason of "+line);
+ Srv->QuitUser(dest, line);
+ }
+}
+
+
+class ModuleSaquit : public Module
+{
+ public:
+ ModuleSaquit()
+ {
+ Srv = new Server;
+ Srv->AddCommand("SAQUIT",handle_saquit,'o',2);
+ }
+
+ virtual ~ModuleSaquit()
+ {
+ delete Srv;
+ }
+
+ virtual Version GetVersion()
+ {
+ return Version(1,0,0,0);
+ }
+
+};
+
+// stuff down here is the module-factory stuff. For basic modules you can ignore this.
+
+class ModuleSaquitFactory : public ModuleFactory
+{
+ public:
+ ModuleSaquitFactory()
+ {
+ }
+
+ ~ModuleSaquitFactory()
+ {
+ }
+
+ virtual Module * CreateModule()
+ {
+ return new ModuleSaquit;
+ }
+
+};
+
+
+extern "C" void * init_module( void )
+{
+ return new ModuleSaquitFactory;
+}
+