summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
authorSadie Powell <sadie@witchery.services>2025-03-14 23:58:25 +0000
committerSadie Powell <sadie@witchery.services>2025-03-15 00:17:18 +0000
commit5ac5e1068ea5365dc8e670a3836dc3d9dea322a5 (patch)
treeeefc9904b0e9c6174ff294ca53849d6ceaf162cc /modules
parent0ebc43f0dc277b307f671757005e218a502cc8a4 (diff)
Use custom-cloak when setting the SASL hostname too.
Diffstat (limited to 'modules')
-rw-r--r--modules/protocol/inspircd.cpp44
1 files changed, 22 insertions, 22 deletions
diff --git a/modules/protocol/inspircd.cpp b/modules/protocol/inspircd.cpp
index 56f6e193e..e65f3098c 100644
--- a/modules/protocol/inspircd.cpp
+++ b/modules/protocol/inspircd.cpp
@@ -153,6 +153,24 @@ private:
Uplink::Send("METADATA", uid, "accountnicks", GetAccountNicks(na));
}
+ static void SendVHostInternal(const Anope::string &uid, const Anope::string &vident, const Anope::string &vhost)
+ {
+ if (Servers::Capab.count("CLOAK"))
+ {
+ Anope::string cloak;
+ if (!vident.empty())
+ cloak.append(vident).push_back('@');
+ cloak.append(vhost);
+
+ Uplink::Send("METADATA", uid, "custom-cloak", cloak);
+ return;
+ }
+
+ if (!vident.empty())
+ SendChgIdentInternal(uid, vident);
+ SendChgHostInternal(uid, vhost);
+ }
+
public:
PrimitiveExtensibleItem<ListLimits> maxlist;
@@ -510,22 +528,7 @@ public:
void SendVHost(User *u, const Anope::string &vident, const Anope::string &vhost) override
{
- if (Servers::Capab.count("CLOAK"))
- {
- Anope::string cloak;
- if (!vident.empty())
- cloak.append(vident).push_back('@');
- cloak.append(vhost);
-
- Uplink::Send("METADATA", u->GetUID(), "custom-cloak", cloak);
- return;
- }
-
- if (!vident.empty())
- this->SendChgIdentInternal(u->GetUID(), vident);
-
- if (!vhost.empty())
- this->SendChgHostInternal(u->GetUID(), vhost);
+ SendVHostInternal(u->GetUID(), vident, vhost);
}
void SendSVSHold(const Anope::string &nick, time_t t) override
@@ -650,11 +653,8 @@ public:
if (na)
{
- if (!na->GetVHostIdent().empty())
- SendChgHostInternal(uid, na->GetVHostIdent());
-
if (!na->GetVHostHost().empty())
- SendChgHostInternal(uid, na->GetVHostHost());
+ SendVHostInternal(uid, na->GetVHostIdent(), na->GetVHostHost());
// Mark this SASL session as pending user introduction.
SASLUser su;
@@ -1897,7 +1897,7 @@ private:
const auto idx = token.find('=');
if (token.compare(0, idx, "custom", 6) == 0)
{
- if (!Servers::Capab.count("TOPICLOCK"))
+ if (!Servers::Capab.count("CLOAK"))
{
Log() << "The remote server has the custom cloak method; this will be used for setting vhosts.";
Servers::Capab.insert("CLOAK");
@@ -1906,7 +1906,7 @@ private:
}
}
- if (Servers::Capab.count("TOPICLOCK"))
+ if (Servers::Capab.count("CLOAK"))
{
Log() << "The remote server does not have the custom cloak method; CHGIDENT and CHGHOST will be used until the module is loaded.";
Servers::Capab.erase("CLOAK");