From a86c1730db0a2567ca4b78c6e4a9968ddcb89e91 Mon Sep 17 00:00:00 2001 From: danieldg Date: Tue, 1 Sep 2009 15:04:25 +0000 Subject: Show metadata keys and values in /CHECK output git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11554 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_check.cpp | 41 ++++++++++++++++++++++++++++++++++++----- 1 file changed, 36 insertions(+), 5 deletions(-) (limited to 'src/modules/m_check.cpp') diff --git a/src/modules/m_check.cpp b/src/modules/m_check.cpp index 86b035522..acde4ad30 100644 --- a/src/modules/m_check.cpp +++ b/src/modules/m_check.cpp @@ -19,8 +19,10 @@ */ class CommandCheck : public Command { + Module* Parent; public: - CommandCheck (InspIRCd* Instance) : Command(Instance,"CHECK", "o", 1) + bool md_sent; + CommandCheck (InspIRCd* Instance, Module* parent) : Command(Instance,"CHECK", "o", 1), Parent(parent) { this->source = "m_check.so"; syntax = "|||"; @@ -96,6 +98,19 @@ class CommandCheck : public Command std::stringstream dump(chliststr); ServerInstance->DumpText(user,checkstr + " onchans ", dump); + + std::deque extlist; + targuser->GetExtList(extlist); + std::stringstream dumpkeys; + for(std::deque::iterator i = extlist.begin(); i != extlist.end(); i++) + { + md_sent = false; + FOREACH_MOD_I(ServerInstance,I_OnSyncUserMetaData,OnSyncUserMetaData(targuser,Parent,(void*)user,*i, true)); + if (!md_sent) + dumpkeys << " " << *i; + } + if (!dumpkeys.str().empty()) + ServerInstance->DumpText(user,checkstr + " metadata ", dumpkeys); } else if (targchan) { @@ -127,6 +142,19 @@ class CommandCheck : public Command snprintf(tmpbuf, MAXBUF, "%-3lu %s%s (%s@%s) %s ", ServerInstance->Users->GlobalCloneCount(i->first), targchan->GetAllPrefixChars(i->first), i->first->nick.c_str(), i->first->ident.c_str(), i->first->dhost.c_str(), i->first->fullname.c_str()); user->WriteServ(checkstr + " member " + tmpbuf); } + + std::deque extlist; + targchan->GetExtList(extlist); + std::stringstream dumpkeys; + for(std::deque::iterator i = extlist.begin(); i != extlist.end(); i++) + { + md_sent = false; + FOREACH_MOD_I(ServerInstance,I_OnSyncChannelMetaData,OnSyncChannelMetaData(targchan,Parent,(void*)user,*i, true)); + if (!md_sent) + dumpkeys << " " << *i; + } + if (!dumpkeys.str().empty()) + ServerInstance->DumpText(user,checkstr + " metadata ", dumpkeys); } else { @@ -166,10 +194,8 @@ class ModuleCheck : public Module public: ModuleCheck(InspIRCd* Me) : Module(Me) { - - mycommand = new CommandCheck(ServerInstance); + mycommand = new CommandCheck(ServerInstance, this); ServerInstance->AddCommand(mycommand); - } virtual ~ModuleCheck() @@ -181,7 +207,12 @@ class ModuleCheck : public Module return Version("$Id$", VF_VENDOR, API_VERSION); } - + virtual void ProtoSendMetaData(void* opaque, TargetTypeFlags type, void* target, const std::string& name, const std::string& value) + { + User* user = static_cast(opaque); + user->WriteServ("304 " + std::string(user->nick) + " :CHECK meta:" + name + " " + value); + mycommand->md_sent = true; + } }; MODULE_INIT(ModuleCheck) -- cgit v1.2.3