Commit c339f0b9 authored by akrherz's avatar akrherz Committed by Guus der Kinderen

OF-1331 Warn user during setup when a session failure occurs

This is a complex problem.  During setup, fetching xmppSettings from the session may fail due to an invalid session state maintained between the client browser and the server.  This is likely caused by a previous HTTPS session to the same server hostname setting a `JSESSIONID` that subsequently can not be overwritten by the current HTTP openfire-setup session.

This introduces i18n string `setup.invalid_session`
parent d7ea5359
...@@ -1846,6 +1846,7 @@ component.session.details.info=Below are details about the session with the exte ...@@ -1846,6 +1846,7 @@ component.session.details.info=Below are details about the session with the exte
# General Setup # General Setup
setup.title=Setup setup.title=Setup
setup.invalid_session=A failure occurred while fetching your session from the server. This is typically a cookie issue. Please either clear all cookies for this domain or try this URL again from an incognito browser session.
# Setup environment check # Setup environment check
......
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
boolean scramOnly = JiveGlobals.getBooleanProperty("user.scramHashedPasswordOnly"); boolean scramOnly = JiveGlobals.getBooleanProperty("user.scramHashedPasswordOnly");
boolean requestedScramOnly = (request.getParameter("scramOnly") != null); boolean requestedScramOnly = (request.getParameter("scramOnly") != null);
boolean next = request.getParameter("continue") != null; boolean next = request.getParameter("continue") != null;
boolean sessionFailure = false;
if (next) { if (next) {
// Figure out where to send the user. // Figure out where to send the user.
String mode = request.getParameter("mode"); String mode = request.getParameter("mode");
...@@ -34,28 +35,31 @@ ...@@ -34,28 +35,31 @@
// Set to default providers by deleting any existing values. // Set to default providers by deleting any existing values.
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
Map<String,String> xmppSettings = (Map<String,String>)session.getAttribute("xmppSettings"); Map<String,String> xmppSettings = (Map<String,String>)session.getAttribute("xmppSettings");
if (xmppSettings == null){
xmppSettings.put("provider.auth.className", JiveGlobals.getXMLProperty("provider.auth.className", sessionFailure = true;
} else {
xmppSettings.put("provider.auth.className", JiveGlobals.getXMLProperty("provider.auth.className",
org.jivesoftware.openfire.auth.DefaultAuthProvider.class.getName())); org.jivesoftware.openfire.auth.DefaultAuthProvider.class.getName()));
xmppSettings.put("provider.user.className", JiveGlobals.getXMLProperty("provider.user.className", xmppSettings.put("provider.user.className", JiveGlobals.getXMLProperty("provider.user.className",
org.jivesoftware.openfire.user.DefaultUserProvider.class.getName())); org.jivesoftware.openfire.user.DefaultUserProvider.class.getName()));
xmppSettings.put("provider.group.className", JiveGlobals.getXMLProperty("provider.group.className", xmppSettings.put("provider.group.className", JiveGlobals.getXMLProperty("provider.group.className",
org.jivesoftware.openfire.group.DefaultGroupProvider.class.getName())); org.jivesoftware.openfire.group.DefaultGroupProvider.class.getName()));
xmppSettings.put("provider.vcard.className", JiveGlobals.getXMLProperty("provider.vcard.className", xmppSettings.put("provider.vcard.className", JiveGlobals.getXMLProperty("provider.vcard.className",
org.jivesoftware.openfire.vcard.DefaultVCardProvider.class.getName())); org.jivesoftware.openfire.vcard.DefaultVCardProvider.class.getName()));
xmppSettings.put("provider.lockout.className", JiveGlobals.getXMLProperty("provider.lockout.className", xmppSettings.put("provider.lockout.className", JiveGlobals.getXMLProperty("provider.lockout.className",
org.jivesoftware.openfire.lockout.DefaultLockOutProvider.class.getName())); org.jivesoftware.openfire.lockout.DefaultLockOutProvider.class.getName()));
xmppSettings.put("provider.securityAudit.className", JiveGlobals.getXMLProperty("provider.securityAudit.className", xmppSettings.put("provider.securityAudit.className", JiveGlobals.getXMLProperty("provider.securityAudit.className",
org.jivesoftware.openfire.security.DefaultSecurityAuditProvider.class.getName())); org.jivesoftware.openfire.security.DefaultSecurityAuditProvider.class.getName()));
xmppSettings.put("provider.admin.className", JiveGlobals.getXMLProperty("provider.admin.className", xmppSettings.put("provider.admin.className", JiveGlobals.getXMLProperty("provider.admin.className",
org.jivesoftware.openfire.admin.DefaultAdminProvider.class.getName())); org.jivesoftware.openfire.admin.DefaultAdminProvider.class.getName()));
if (requestedScramOnly) { if (requestedScramOnly) {
JiveGlobals.setProperty("user.scramHashedPasswordOnly", "true"); JiveGlobals.setProperty("user.scramHashedPasswordOnly", "true");
} }
// Redirect // Redirect
response.sendRedirect("setup-admin-settings.jsp"); response.sendRedirect("setup-admin-settings.jsp");
return; return;
}
} }
else if ("ldap".equals(mode)) { else if ("ldap".equals(mode)) {
response.sendRedirect("setup-ldap-server.jsp"); response.sendRedirect("setup-ldap-server.jsp");
...@@ -78,6 +82,12 @@ ...@@ -78,6 +82,12 @@
<fmt:message key="setup.profile.description" /> <fmt:message key="setup.profile.description" />
</p> </p>
<% if (sessionFailure) { %>
<span class="jive-error-text">
<fmt:message key="setup.invalid_session" />
</span>
<% } %>
<!-- BEGIN jive-contentBox --> <!-- BEGIN jive-contentBox -->
<div class="jive-contentBox"> <div class="jive-contentBox">
<form action="setup-profile-settings.jsp" name="profileform" method="post"> <form action="setup-profile-settings.jsp" name="profileform" method="post">
...@@ -122,4 +132,4 @@ ...@@ -122,4 +132,4 @@
<!-- END jive-contentBox --> <!-- END jive-contentBox -->
</body> </body>
</html> </html>
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment