1 /* +------------------------------------+
2 * | Inspire Internet Relay Chat Daemon |
3 * +------------------------------------+
5 * InspIRCd: (C) 2002-2007 InspIRCd Development Team
6 * See: http://www.inspircd.org/wiki/index.php/Credits
8 * This program is free but copyrighted software; see
9 * the file COPYING for details.
11 * ---------------------------------------------------
15 #include "cull_list.h"
17 CullItem::CullItem(User* u, std::string &r, const char* o_reason)
22 /* Seperate oper reason not set, use the user reason */
24 this->oper_reason = o_reason;
26 this->oper_reason = r;
29 CullItem::CullItem(User* u, const char* r, const char* o_reason)
34 /* Seperate oper reason not set, use the user reason */
36 this->oper_reason = o_reason;
38 this->oper_reason = r;
41 void CullItem::MakeSilent()
46 bool CullItem::IsSilent()
55 User* CullItem::GetUser()
60 std::string& CullItem::GetReason()
65 std::string& CullItem::GetOperReason()
67 return this->oper_reason;
70 CullList::CullList(InspIRCd* Instance) : ServerInstance(Instance)
76 void CullList::AddItem(User* user, std::string &reason, const char* o_reason)
78 AddItem(user, reason.c_str(), o_reason);
82 void CullList::AddItem(User* user, const char* reason, const char* o_reason)
84 if (exempt.find(user) == exempt.end())
86 CullItem item(user, reason, o_reason);
92 void CullList::MakeSilent(User* user)
94 for (std::vector<CullItem>::iterator a = list.begin(); a != list.end(); ++a)
96 if (a->GetUser() == user)
105 int CullList::Apply()
110 std::vector<CullItem>::iterator a = list.begin();
112 User *u = a->GetUser();
113 user_hash::iterator iter = ServerInstance->clientlist->find(u->nick);
114 std::map<User*, User*>::iterator exemptiter = exempt.find(u);
115 const char* preset_reason = u->GetOperQuit();
116 std::string reason = a->GetReason();
117 std::string oper_reason = *preset_reason ? preset_reason : a->GetOperReason();
119 if (reason.length() > MAXQUIT - 1)
120 reason.resize(MAXQUIT - 1);
121 if (oper_reason.length() > MAXQUIT - 1)
122 oper_reason.resize(MAXQUIT - 1);
124 if (u->registered != REG_ALL)
125 if (ServerInstance->unregistered_count)
126 ServerInstance->unregistered_count--;
130 if ((!u->sendq.empty()) && (!(*u->GetWriteError())))
134 if (u->registered == REG_ALL)
136 FOREACH_MOD_I(ServerInstance,I_OnUserQuit,OnUserQuit(u, reason, oper_reason));
137 u->PurgeEmptyChannels();
138 u->WriteCommonQuit(reason, oper_reason);
141 FOREACH_MOD_I(ServerInstance,I_OnUserDisconnect,OnUserDisconnect(u));
145 if (ServerInstance->Config->GetIOHook(u->GetPort()))
149 ServerInstance->Config->GetIOHook(u->GetPort())->OnRawSocketClose(u->GetFd());
151 catch (CoreException& modexcept)
153 ServerInstance->Log(DEBUG, "%s threw an exception: %s", modexcept.GetSource(), modexcept.GetReason());
157 ServerInstance->SE->DelFd(u);
162 * this must come before the ServerInstance->SNO->WriteToSnoMaskso that it doesnt try to fill their buffer with anything
163 * if they were an oper with +sn +qQ.
165 if (u->registered == REG_ALL)
171 ServerInstance->SNO->WriteToSnoMask('q',"Client exiting: %s!%s@%s [%s]",u->nick,u->ident,u->host,oper_reason.c_str());
176 if ((!ServerInstance->SilentULine(u->server)) && (!a->IsSilent()))
178 ServerInstance->SNO->WriteToSnoMask('Q',"Client exiting on server %s: %s!%s@%s [%s]",u->server,u->nick,u->ident,u->host,oper_reason.c_str());
184 if (iter != ServerInstance->clientlist->end())
188 std::vector<User*>::iterator x = find(ServerInstance->local_users.begin(),ServerInstance->local_users.end(),u);
189 if (x != ServerInstance->local_users.end())
190 ServerInstance->local_users.erase(x);
192 ServerInstance->clientlist->erase(iter);
196 list.erase(list.begin());
197 exempt.erase(exemptiter);