diff --git a/authentication/source/java/ch/systemsx/cisd/authentication/crowd/CrowdAuthenticationService.java b/authentication/source/java/ch/systemsx/cisd/authentication/crowd/CrowdAuthenticationService.java index 6f0b2f7995656bbe5af904f2916f055156d4f29e..ff398c3e2f7d5aef81ff96021ffd34492241a081 100644 --- a/authentication/source/java/ch/systemsx/cisd/authentication/crowd/CrowdAuthenticationService.java +++ b/authentication/source/java/ch/systemsx/cisd/authentication/crowd/CrowdAuthenticationService.java @@ -48,7 +48,8 @@ import ch.systemsx.cisd.common.logging.LogFactory; * <i>Crowd</i> server, then authenticates the user. * <p> * The modus operandi is based on information found at <a - * href="http://confluence.atlassian.com/display/CROWD/SOAP+API">http://confluence.atlassian.com/display/CROWD/SOAP+API</a> + * href="http://confluence.atlassian.com/display/CROWD/SOAP+API" + * >http://confluence.atlassian.com/display/CROWD/SOAP+API</a> * </p> * * @author Franz-Josef Elmer @@ -167,14 +168,14 @@ public class CrowdAuthenticationService implements IAuthenticationService private final IRequestExecutor requestExecutor; - public CrowdAuthenticationService(final String host, final int port, final String application, - final String applicationPassword) + public CrowdAuthenticationService(final String host, final String port, + final String application, final String applicationPassword) { - this("https://" + host + ":" + port + "/crowd/services/SecurityServer", application, - applicationPassword, createExecutor()); + this("https://" + host + ":" + checkPort(port) + "/crowd/services/SecurityServer", + application, applicationPassword, createExecutor()); } - public CrowdAuthenticationService(final String url, final String application, + CrowdAuthenticationService(final String url, final String application, final String applicationPassword, final IRequestExecutor requestExecutor) { this.url = url; @@ -190,6 +191,25 @@ public class CrowdAuthenticationService implements IAuthenticationService } } + private static String checkPort(String portStr) throws ConfigurationFailureException + { + try + { + // '${' means we have an unresolved Spring variable + if (portStr != null && portStr.startsWith("${") == false) + { + if (Integer.parseInt(portStr) <= 0) + { + throw ConfigurationFailureException.fromTemplate("Illegal port '%s'", portStr); + } + } + } catch (NumberFormatException ex) + { + throw ConfigurationFailureException.fromTemplate("Illegal port '%s'", portStr); + } + return portStr; + } + // // ISelfTestable // @@ -299,7 +319,8 @@ public class CrowdAuthenticationService implements IAuthenticationService } /** - * Parses given <i>Crowd</i> XML response and returns a map of found <code>SOAPAttribute</code>s. + * Parses given <i>Crowd</i> XML response and returns a map of found <code>SOAPAttribute</code> + * s. * <p> * Never returns <code>null</code> but could returns an empty <code>Map</code>. * </p> diff --git a/authentication/sourceTest/java/ch/systemsx/cisd/authentication/crowd/RealCrowdAuthenticationTest.java b/authentication/sourceTest/java/ch/systemsx/cisd/authentication/crowd/RealCrowdAuthenticationTest.java index 08f58532496a917c5522c793c15c482042b9b89b..679db42db66fb9f0941704783faaa57dcc41cbc6 100644 --- a/authentication/sourceTest/java/ch/systemsx/cisd/authentication/crowd/RealCrowdAuthenticationTest.java +++ b/authentication/sourceTest/java/ch/systemsx/cisd/authentication/crowd/RealCrowdAuthenticationTest.java @@ -45,7 +45,7 @@ import ch.systemsx.cisd.authentication.Principal; public class RealCrowdAuthenticationTest { - private static final int PORT_OF_AUTHENTICATION_SERVICE = 0; // FIX! + private static final String PORT_OF_AUTHENTICATION_SERVICE = null; // FIX! private static final String HOST_NAME_OF_AUTHENTICATION_SERVICE = null; // FIX!