summaryrefslogtreecommitdiff
path: root/src/modules
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2007-07-07 21:13:12 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2007-07-07 21:13:12 +0000
commit89712710a87638e226d834b62ea89ed308d1b3a8 (patch)
tree6ae959e77a053700b5984165c217e067bc3a7cba /src/modules
parent297c720daecb7622f5eee80359987f416fa82227 (diff)
Implement /dalinfo, as a joke. Consider this an easter egg.
More debug logging in m_ssl_openssl, still not fixed git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@7430 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules')
-rw-r--r--src/modules/extra/m_ssl_openssl.cpp3
-rw-r--r--src/modules/m_testcommand.cpp56
2 files changed, 12 insertions, 47 deletions
diff --git a/src/modules/extra/m_ssl_openssl.cpp b/src/modules/extra/m_ssl_openssl.cpp
index 3db495c8b..ffd9d4032 100644
--- a/src/modules/extra/m_ssl_openssl.cpp
+++ b/src/modules/extra/m_ssl_openssl.cpp
@@ -376,6 +376,7 @@ class ModuleSSLOpenSSL : public Module
}
else if (strcmp("IS_HSDONE", request->GetId()) == 0)
{
+ ServerInstance->Log(DEBUG,"Module checking if handshake is done");
if (ISR->Sock->GetFd() < 0)
return (char*)"OK";
@@ -487,6 +488,7 @@ class ModuleSSLOpenSSL : public Module
}
else
{
+ errno = EAGAIN;
return -1;
}
}
@@ -775,6 +777,7 @@ class ModuleSSLOpenSSL : public Module
{
int ssl_err = SSL_get_error(session->sess, ret);
char buf[1024];
+ ERR_print_errors_fp(stderr);
ServerInstance->Log(DEBUG,"Handshake fail 2: %d: %s", ssl_err, ERR_error_string(ssl_err,buf));
CloseSession(session);
return true;
diff --git a/src/modules/m_testcommand.cpp b/src/modules/m_testcommand.cpp
index 6df2db1dd..6ec197eb6 100644
--- a/src/modules/m_testcommand.cpp
+++ b/src/modules/m_testcommand.cpp
@@ -15,75 +15,36 @@
#include "users.h"
#include "channels.h"
#include "modules.h"
-#include "dns.h"
-/* $ModDesc: Povides a proof-of-concept test /WOOT command */
+/* $ModDesc: Provides a pointless /dalinfo command, demo module */
-/** A test resolver class for IPV6
+/** Handle /DALINFO
*/
-class MyV6Resolver : public Resolver
+class cmd_dalinfo : public command_t
{
- bool fw;
public:
- MyV6Resolver(InspIRCd* Instance, Module* me, const std::string &source, bool forward, bool &cached) : Resolver(Instance, source, forward ? DNS_QUERY_AAAA : DNS_QUERY_PTR6, cached, me)
- {
- fw = forward;
- }
-
- virtual void OnLookupComplete(const std::string &result, unsigned int ttl, bool cached)
- {
- ServerInstance->Log(DEBUG,"*** RESOLVER COMPLETED %s LOOKUP, IP IS: '%s' TTL=%lu CACHED=%d",fw ? "FORWARD" : "REVERSE", result.c_str(), ttl, cached);
- }
-
- virtual void OnError(ResolverError e, const std::string &errormessage)
- {
- ServerInstance->Log(DEBUG,"*** RESOLVER GOT ERROR: %d: %s",e,errormessage.c_str());
- }
-};
-
-/** Handle /WOOT
- */
-class cmd_woot : public command_t
-{
- Module* Creator;
- public:
- /* Command 'woot', takes no parameters and needs no special modes */
- cmd_woot (InspIRCd* Instance, Module* maker) : command_t(Instance,"WOOT", 0, 0), Creator(maker)
+ /* Command 'dalinfo', takes no parameters and needs no special modes */
+ cmd_dalinfo (InspIRCd* Instance) : command_t(Instance,"DALINFO", 0, 0)
{
this->source = "m_testcommand.so";
}
CmdResult Handle (const char** parameters, int pcnt, userrec *user)
{
- /* We dont have to worry about deleting 'r', the core will
- * do it for us as required.*/
- try
- {
- bool cached;
- MyV6Resolver* r = new MyV6Resolver(ServerInstance, Creator, "shake.stacken.kth.se", true, cached);
- ServerInstance->AddResolver(r, cached);
- r = new MyV6Resolver(ServerInstance, Creator, "2001:6b0:1:ea:202:a5ff:fecd:13a6", false, cached);
- ServerInstance->AddResolver(r, cached);
- }
- catch (ModuleException& e)
- {
- ServerInstance->Log(DEBUG,"Danger, will robinson! There was an exception: %s",e.GetReason());
- }
-
+ user->WriteServ("NOTICE %s :*** DALNet had nothing to do with it.", user->nick);
return CMD_FAILURE;
}
};
class ModuleTestCommand : public Module
{
- cmd_woot* newcommand;
+ cmd_dalinfo* newcommand;
public:
ModuleTestCommand(InspIRCd* Me)
: Module(Me)
{
-
// Create a new command
- newcommand = new cmd_woot(ServerInstance, this);
+ newcommand = new cmd_dalinfo(ServerInstance);
ServerInstance->AddCommand(newcommand);
}
@@ -103,3 +64,4 @@ class ModuleTestCommand : public Module
};
MODULE_INIT(ModuleTestCommand)
+