From 3373169a00148cee9216034d91c67b6b3301ced8 Mon Sep 17 00:00:00 2001 From: mightymop Date: Fri, 24 Sep 2021 00:00:03 +0200 Subject: [PATCH] fallback: try to connect to parent xmpp domain if no dns entry for subdomain (service) was found... add configuration property to enable/disable the fallback --- .../main/resources/openfire_i18n.properties | 2 ++ .../jivesoftware/openfire/net/SocketUtil.java | 24 ++++++++++++++++++- 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/i18n/src/main/resources/openfire_i18n.properties b/i18n/src/main/resources/openfire_i18n.properties index 937d74de24..7549c8e194 100644 --- a/i18n/src/main/resources/openfire_i18n.properties +++ b/i18n/src/main/resources/openfire_i18n.properties @@ -1746,6 +1746,8 @@ system_property.xmpp.taskengine.threadpool.size.core=The number of threads to ke system_property.xmpp.taskengine.threadpool.size.max=The maximum number of threads to allow in the thread pool that is used to execute tasks of Openfire's TaskEngine. system_property.xmpp.taskengine.threadpool.keepalive=The number of threads in the thread pool that is used to execute tasks of Openfire's TaskEngine is greater than the core, this is the maximum time that excess idle threads will wait for new tasks before terminating. +system_property.xmpp.dns.usefallback=Use XMPP Domain host for service subdomains as fallback, if no dns entrys for subdomains were set. + # Server properties Page server.properties.title=System Properties diff --git a/xmppserver/src/main/java/org/jivesoftware/openfire/net/SocketUtil.java b/xmppserver/src/main/java/org/jivesoftware/openfire/net/SocketUtil.java index 324feb13d1..061d1f42e5 100644 --- a/xmppserver/src/main/java/org/jivesoftware/openfire/net/SocketUtil.java +++ b/xmppserver/src/main/java/org/jivesoftware/openfire/net/SocketUtil.java @@ -1,6 +1,7 @@ package org.jivesoftware.openfire.net; import org.jivesoftware.openfire.server.RemoteServerManager; +import org.jivesoftware.util.SystemProperty; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -20,6 +21,11 @@ public class SocketUtil { private final static Logger Log = LoggerFactory.getLogger( SocketUtil.class ); + public static final SystemProperty USE_FALLBACK = SystemProperty.Builder.ofType(Boolean.class) + .setKey("xmpp.dns.usefallback") + .setDefaultValue(false) + .setDynamic(true) + .build(); /** * Creates a socket connection to an XMPP domain. * @@ -34,10 +40,11 @@ public class SocketUtil * * @param xmppDomain The XMPP domain to connect to. * @param port The port to connect to when DNS resolution fails. + * @param tryparent try parent domain, if no connection could be established and fallback is enabled. * @return a Socket instance that is connected, or null. * @see DNSUtil#resolveXMPPDomain(String, int) */ - public static Map.Entry createSocketToXmppDomain( String xmppDomain, int port ) + public static Map.Entry createSocketToXmppDomain( String xmppDomain, int port, boolean tryparent) { Log.debug( "Creating a socket connection to XMPP domain '{}' ...", xmppDomain ); @@ -80,10 +87,25 @@ public static Map.Entry createSocketToXmppDomain( String xmppDo { Log.debug( "An additional exception occurred while trying to close a socket when creating a connection to {}:{} failed.", realHostname, realPort, ex ); } + + /* + * Fallback: If no dns entry was found for xmpp service subdomain, try the xmpp (parent) domain itself. + * */ + if (USE_FALLBACK.getValue()&&tryparent&&xmppDomain.contains(".")) + { + String xmppDomainWithoutSubdomain = xmppDomain.substring(xmppDomain.indexOf(".")+1); + Log.info("Try to connect to parent domain {}:{}",xmppDomainWithoutSubdomain,port); + return createSocketToXmppDomain(xmppDomainWithoutSubdomain,port,false); + } } } Log.warn( "Unable to create a socket connection to XMPP domain '{}': Unable to connect to any of its remote hosts.", xmppDomain ); return null; } + + public static Map.Entry createSocketToXmppDomain( String xmppDomain, int port ) + { + return createSocketToXmppDomain(xmppDomain,port,true); + } }