summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--modules/pseudoclients/nickserv.cpp12
-rw-r--r--src/users.cpp2
2 files changed, 10 insertions, 4 deletions
diff --git a/modules/pseudoclients/nickserv.cpp b/modules/pseudoclients/nickserv.cpp
index 6700dce48..c57039bee 100644
--- a/modules/pseudoclients/nickserv.cpp
+++ b/modules/pseudoclients/nickserv.cpp
@@ -378,8 +378,14 @@ class NickServCore : public Module, public NickServService
for (user_map::const_iterator it = UserListByNick.begin(); it != UserListByNick.end(); ++it)
{
User *u = it->second;
- if (u->server == s && !u->IsIdentified())
- this->Validate(u);
+
+ if (u->server == s)
+ {
+ if (u->HasMode("REGISTERED") && !u->IsIdentified(true))
+ u->RemoveMode(NickServ, "REGISTERED");
+ if (!u->IsIdentified())
+ this->Validate(u);
+ }
}
}
@@ -409,7 +415,7 @@ class NickServCore : public Module, public NickServService
void OnUserModeSet(const MessageSource &setter, User *u, const Anope::string &mname) anope_override
{
- if (mname == "REGISTERED" && !u->IsIdentified())
+ if (u->server->IsSynced() && mname == "REGISTERED" && !u->IsIdentified(true))
u->RemoveMode(NickServ, mname);
}
diff --git a/src/users.cpp b/src/users.cpp
index f44a6f62d..3c99b46e6 100644
--- a/src/users.cpp
+++ b/src/users.cpp
@@ -367,7 +367,7 @@ bool User::IsIdentified(bool check_nick) const
{
if (check_nick && this->nc)
{
- NickAlias *na = NickAlias::Find(this->nc->display);
+ NickAlias *na = NickAlias::Find(this->nick);
return na && *na->nc == *this->nc;
}