summaryrefslogtreecommitdiff
path: root/src/modules/m_ojoin.cpp
diff options
context:
space:
mode:
authordanieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7>2009-09-09 19:28:34 +0000
committerdanieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7>2009-09-09 19:28:34 +0000
commitd5411d06255ea264791631538642619d13e129aa (patch)
tree61b373b1a96aa96bffdd5be2f3ac8f2a307e4551 /src/modules/m_ojoin.cpp
parentc40ce687100f9db5be42a135673f00dd2ba65338 (diff)
Allow OJOIN to be used when already in the target channel
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11686 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules/m_ojoin.cpp')
-rw-r--r--src/modules/m_ojoin.cpp25
1 files changed, 11 insertions, 14 deletions
diff --git a/src/modules/m_ojoin.cpp b/src/modules/m_ojoin.cpp
index 906d0d1f8..6d036d96a 100644
--- a/src/modules/m_ojoin.cpp
+++ b/src/modules/m_ojoin.cpp
@@ -84,32 +84,29 @@ class CommandOjoin : public Command
parameters[0].c_str(), user->nick.c_str());
ServerInstance->PI->SendChannelNotice(channel, 0, std::string(user->nick) + " joined on official network business.");
}
-
- return CMD_SUCCESS;
}
else
{
- user->WriteServ("NOTICE "+std::string(user->nick)+" :*** Could not join "+parameters[0]);
- return CMD_FAILURE;
+ ServerInstance->SNO->WriteGlobalSno('a', std::string(user->nick)+" used OJOIN in "+channel->name);
+ // they're already in the channel
+ std::vector<std::string> modes;
+ modes.push_back(parameters[0]);
+ modes.push_back("+Y");
+ modes.push_back(user->nick);
+ ServerInstance->SendMode(modes, ServerInstance->FakeClient);
+ ServerInstance->PI->SendMode(channel->name, ServerInstance->Modes->GetLastParseParams(), ServerInstance->Modes->GetLastParseTranslate());
}
- }
-
- RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters)
- {
- return ROUTE_BROADCAST;
+ return CMD_SUCCESS;
}
};
-/** Abstraction of NetworkPrefixBase for channel mode +Y
+/** channel mode +Y
*/
class NetworkPrefix : public ModeHandler
{
public:
NetworkPrefix(InspIRCd* Instance, Module* parent)
: ModeHandler(Instance, parent, 'Y', 1, 1, true, MODETYPE_CHANNEL, false, NPrefix, 0, TR_NICK)
-// NetworkPrefixBase(Instance,"cm_network_","official user", 388, 389) { }
-// NetworkPrefixBase(InspIRCd* Instance, const std::string &ext, const std::string &mtype, int l, int e) :
-// extend(ext), type(mtype), list(l), end(e)
{
}
@@ -256,7 +253,7 @@ class ModuleOjoin : public Module
OnRehash(NULL);
/* Initialise module variables */
- np = new NetworkPrefix(ServerInstance, this);
+ np = new NetworkPrefix(Me, this);
if (!ServerInstance->Modes->AddMode(np))
{