aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/network/address.cpp16
-rw-r--r--src/network/address.h1
-rw-r--r--src/network/clientpackethandler.cpp7
3 files changed, 21 insertions, 3 deletions
diff --git a/src/network/address.cpp b/src/network/address.cpp
index f698a2e91..0ecface37 100644
--- a/src/network/address.cpp
+++ b/src/network/address.cpp
@@ -271,3 +271,19 @@ void Address::print(std::ostream *s) const
else
*s << serializeString() << ":" << m_port;
}
+
+bool Address::isLocalhost() const {
+ if (isIPv6()) {
+ static const unsigned char localhost_bytes[] = {
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1};
+ static const unsigned char mapped_ipv4_localhost[] = {
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xff, 0xff, 0x7f, 0, 0, 1};
+
+ auto addr = m_address.ipv6.sin6_addr.s6_addr;
+
+ return memcmp(addr, localhost_bytes, 16) == 0 ||
+ memcmp(addr, mapped_ipv4_localhost, 16) == 0;
+ } else {
+ return m_address.ipv4.sin_addr.s_addr == 0x0100007F;
+ }
+}
diff --git a/src/network/address.h b/src/network/address.h
index fb25b3565..4329c84a8 100644
--- a/src/network/address.h
+++ b/src/network/address.h
@@ -66,6 +66,7 @@ public:
void setPort(unsigned short port);
void print(std::ostream *s) const;
std::string serializeString() const;
+ bool isLocalhost() const;
private:
unsigned int m_addr_family = 0;
diff --git a/src/network/clientpackethandler.cpp b/src/network/clientpackethandler.cpp
index 909d336ae..2d02d0755 100644
--- a/src/network/clientpackethandler.cpp
+++ b/src/network/clientpackethandler.cpp
@@ -97,9 +97,10 @@ void Client::handleCommand_Hello(NetworkPacket* pkt)
// Authenticate using that method, or abort if there wasn't any method found
if (chosen_auth_mechanism != AUTH_MECHANISM_NONE) {
- if (chosen_auth_mechanism == AUTH_MECHANISM_FIRST_SRP
- && !m_simple_singleplayer_mode
- && g_settings->getBool("enable_register_confirmation")) {
+ if (chosen_auth_mechanism == AUTH_MECHANISM_FIRST_SRP &&
+ !m_simple_singleplayer_mode &&
+ !getServerAddress().isLocalhost() &&
+ g_settings->getBool("enable_register_confirmation")) {
promptConfirmRegistration(chosen_auth_mechanism);
} else {
startAuth(chosen_auth_mechanism);