mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 13:17:41 +00:00
GUACAMOLE-524: Consistently generate token names from LDAP attributes with arbitrary naming conventions.
This commit is contained in:
@@ -153,6 +153,14 @@
|
|||||||
<version>3.0</version>
|
<version>3.0</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<!-- JUnit -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>junit</groupId>
|
||||||
|
<artifactId>junit</artifactId>
|
||||||
|
<version>4.12</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
|
@@ -53,12 +53,6 @@ public class AuthenticationProviderService {
|
|||||||
*/
|
*/
|
||||||
private final Logger logger = LoggerFactory.getLogger(AuthenticationProviderService.class);
|
private final Logger logger = LoggerFactory.getLogger(AuthenticationProviderService.class);
|
||||||
|
|
||||||
/**
|
|
||||||
* The prefix string to add to each parameter token generated from an LDAP
|
|
||||||
* attribute name.
|
|
||||||
*/
|
|
||||||
private static final String LDAP_ATTRIBUTE_TOKEN_PREFIX = "LDAP_ATTR_";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Service for creating and managing connections to LDAP servers.
|
* Service for creating and managing connections to LDAP servers.
|
||||||
*/
|
*/
|
||||||
@@ -302,7 +296,7 @@ public class AuthenticationProviderService {
|
|||||||
// Convert each retrieved attribute into a corresponding token
|
// Convert each retrieved attribute into a corresponding token
|
||||||
for (Object attrObj : attrSet) {
|
for (Object attrObj : attrSet) {
|
||||||
LDAPAttribute attr = (LDAPAttribute)attrObj;
|
LDAPAttribute attr = (LDAPAttribute)attrObj;
|
||||||
tokens.put(LDAP_ATTRIBUTE_TOKEN_PREFIX + attr.getName(), attr.getStringValue());
|
tokens.put(TokenName.fromAttribute(attr.getName()), attr.getStringValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +1,106 @@
|
|||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.guacamole.auth.ldap;
|
||||||
|
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Utility class for generating parameter token names.
|
||||||
|
*/
|
||||||
|
public class TokenName {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The prefix string to add to each parameter token generated from an LDAP
|
||||||
|
* attribute name.
|
||||||
|
*/
|
||||||
|
private static final String LDAP_ATTRIBUTE_TOKEN_PREFIX = "LDAP_ATTR_";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pattern which matches logical groupings of words within an LDAP
|
||||||
|
* attribute name. This pattern is intended to match logical groupings
|
||||||
|
* regardless of the naming convention used: "CamelCase",
|
||||||
|
* "headlessCamelCase", "lowercase_with_underscores",
|
||||||
|
* "lowercase-with-dashes" or even "aVery-INCONSISTENTMix_ofAllStyles".
|
||||||
|
*/
|
||||||
|
private static final Pattern LDAP_ATTRIBUTE_NAME_GROUPING = Pattern.compile(
|
||||||
|
|
||||||
|
// "Camel" word groups
|
||||||
|
"\\p{javaUpperCase}\\p{javaLowerCase}+"
|
||||||
|
|
||||||
|
// Groups of digits
|
||||||
|
+ "|[0-9]+"
|
||||||
|
|
||||||
|
// Groups of uppercase letters, excluding the uppercase letter
|
||||||
|
// which begins a following "Camel" group
|
||||||
|
+ "|\\p{javaUpperCase}+(?!\\p{javaLowerCase})"
|
||||||
|
|
||||||
|
// Groups of lowercase letters which match no other pattern
|
||||||
|
+ "|\\p{javaLowerCase}+"
|
||||||
|
|
||||||
|
// Groups of word characters letters which match no other pattern
|
||||||
|
+ "|\\b\\w+\\b"
|
||||||
|
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This utility class should not be instantiated.
|
||||||
|
*/
|
||||||
|
private TokenName() {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates the name of the parameter token that should be populated with
|
||||||
|
* the value of the given LDAP attribute. The name of the LDAP attribute
|
||||||
|
* will automatically be transformed from "CamelCase", "headlessCamelCase",
|
||||||
|
* "lowercase_with_underscores", and "mixes_ofBoth_Styles" to consistent
|
||||||
|
* "UPPERCASE_WITH_UNDERSCORES". Each returned attribute will be prefixed
|
||||||
|
* with "LDAP_ATTR_".
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* The name of the LDAP attribute to use to generate the token name.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* The name of the parameter token that should be populated with the
|
||||||
|
* value of the LDAP attribute having the given name.
|
||||||
|
*/
|
||||||
|
public static String fromAttribute(String name) {
|
||||||
|
|
||||||
|
// If even one logical word grouping cannot be found, default to
|
||||||
|
// simply converting the attribute to uppercase and adding the
|
||||||
|
// prefix
|
||||||
|
Matcher groupMatcher = LDAP_ATTRIBUTE_NAME_GROUPING.matcher(name);
|
||||||
|
if (!groupMatcher.find())
|
||||||
|
return LDAP_ATTRIBUTE_TOKEN_PREFIX + name.toUpperCase();
|
||||||
|
|
||||||
|
// Split the given name into logical word groups, separated by
|
||||||
|
// underscores and converted to uppercase
|
||||||
|
StringBuilder builder = new StringBuilder(LDAP_ATTRIBUTE_TOKEN_PREFIX);
|
||||||
|
builder.append(groupMatcher.group(0).toUpperCase());
|
||||||
|
|
||||||
|
while (groupMatcher.find()) {
|
||||||
|
builder.append("_");
|
||||||
|
builder.append(groupMatcher.group(0).toUpperCase());
|
||||||
|
}
|
||||||
|
|
||||||
|
return builder.toString();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.guacamole.auth.ldap;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test which verifies automatic generation of LDAP-specific connection
|
||||||
|
* parameter token names.
|
||||||
|
*/
|
||||||
|
public class TokenNameTest {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Verifies that TokenName.fromAttribute() generates token names as
|
||||||
|
* specified, regardless of the naming convention of the attribute.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testFromAttribute() {
|
||||||
|
assertEquals("LDAP_ATTR_A", TokenName.fromAttribute("a"));
|
||||||
|
assertEquals("LDAP_ATTR_B", TokenName.fromAttribute("b"));
|
||||||
|
assertEquals("LDAP_ATTR_1", TokenName.fromAttribute("1"));
|
||||||
|
assertEquals("LDAP_ATTR_SOME_URL", TokenName.fromAttribute("someURL"));
|
||||||
|
assertEquals("LDAP_ATTR_LOWERCASE_WITH_DASHES", TokenName.fromAttribute("lowercase-with-dashes"));
|
||||||
|
assertEquals("LDAP_ATTR_HEADLESS_CAMEL_CASE", TokenName.fromAttribute("headlessCamelCase"));
|
||||||
|
assertEquals("LDAP_ATTR_CAMEL_CASE", TokenName.fromAttribute("CamelCase"));
|
||||||
|
assertEquals("LDAP_ATTR_CAMEL_CASE", TokenName.fromAttribute("CamelCase"));
|
||||||
|
assertEquals("LDAP_ATTR_LOWERCASE_WITH_UNDERSCORES", TokenName.fromAttribute("lowercase_with_underscores"));
|
||||||
|
assertEquals("LDAP_ATTR_UPPERCASE_WITH_UNDERSCORES", TokenName.fromAttribute("UPPERCASE_WITH_UNDERSCORES"));
|
||||||
|
assertEquals("LDAP_ATTR_A_VERY_INCONSISTENT_MIX_OF_ALL_STYLES", TokenName.fromAttribute("aVery-INCONSISTENTMix_ofAllStyles"));
|
||||||
|
assertEquals("LDAP_ATTR_ABC_123_DEF_456", TokenName.fromAttribute("abc123def456"));
|
||||||
|
assertEquals("LDAP_ATTR_ABC_123_DEF_456", TokenName.fromAttribute("ABC123DEF456"));
|
||||||
|
assertEquals("LDAP_ATTR_WORD_A_WORD_AB_WORD_ABC_WORD", TokenName.fromAttribute("WordAWordABWordABCWord"));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Reference in New Issue
Block a user