All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.security.ldap.LdapEncoder Maven / Gradle / Ivy

There is a newer version: 6.3.4
Show newest version
/*
 * Copyright 2005-2010 the original author or authors.
 *
 * Licensed 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
 *
 *      https://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.springframework.security.ldap;

import org.springframework.ldap.BadLdapGrammarException;

/**
 * Helper class to encode and decode ldap names and values.
 *
 * 

* NOTE: This is a copy from Spring LDAP so that both Spring LDAP 1.x and 2.x can be * supported without reflection. *

* * @author Adam Skogman * @author Mattias Hellborg Arthursson */ final class LdapEncoder { private static final int HEX = 16; private static String[] NAME_ESCAPE_TABLE = new String[96]; static { // all below 0x20 (control chars) for (char c = 0; c < ' '; c++) { NAME_ESCAPE_TABLE[c] = "\\" + toTwoCharHex(c); } NAME_ESCAPE_TABLE['#'] = "\\#"; NAME_ESCAPE_TABLE[','] = "\\,"; NAME_ESCAPE_TABLE[';'] = "\\;"; NAME_ESCAPE_TABLE['='] = "\\="; NAME_ESCAPE_TABLE['+'] = "\\+"; NAME_ESCAPE_TABLE['<'] = "\\<"; NAME_ESCAPE_TABLE['>'] = "\\>"; NAME_ESCAPE_TABLE['\"'] = "\\\""; NAME_ESCAPE_TABLE['\\'] = "\\\\"; } private static String[] FILTER_ESCAPE_TABLE = new String['\\' + 1]; static { // fill with char itself for (char c = 0; c < FILTER_ESCAPE_TABLE.length; c++) { FILTER_ESCAPE_TABLE[c] = String.valueOf(c); } // escapes (RFC2254) FILTER_ESCAPE_TABLE['*'] = "\\2a"; FILTER_ESCAPE_TABLE['('] = "\\28"; FILTER_ESCAPE_TABLE[')'] = "\\29"; FILTER_ESCAPE_TABLE['\\'] = "\\5c"; FILTER_ESCAPE_TABLE[0] = "\\00"; } /** * All static methods - not to be instantiated. */ private LdapEncoder() { } protected static String toTwoCharHex(char c) { String raw = Integer.toHexString(c).toUpperCase(); return (raw.length() > 1) ? raw : "0" + raw; } /** * Escape a value for use in a filter. * @param value the value to escape. * @return a properly escaped representation of the supplied value. */ static String filterEncode(String value) { if (value == null) { return null; } StringBuilder encodedValue = new StringBuilder(value.length() * 2); int length = value.length(); for (int i = 0; i < length; i++) { char ch = value.charAt(i); encodedValue.append((ch < FILTER_ESCAPE_TABLE.length) ? FILTER_ESCAPE_TABLE[ch] : ch); } return encodedValue.toString(); } /** * LDAP Encodes a value for use with a DN. Escapes for LDAP, not JNDI! * *
* Escapes:
* ' ' [space] - "\ " [if first or last]
* '#' [hash] - "\#"
* ',' [comma] - "\,"
* ';' [semicolon] - "\;"
* '= [equals] - "\="
* '+' [plus] - "\+"
* '<' [less than] - "\<"
* '>' [greater than] - "\>"
* '"' [double quote] - "\""
* '\' [backslash] - "\\"
* @param value the value to escape. * @return The escaped value. */ static String nameEncode(String value) { if (value == null) { return null; } StringBuilder encodedValue = new StringBuilder(value.length() * 2); int length = value.length(); int last = length - 1; for (int i = 0; i < length; i++) { char c = value.charAt(i); // space first or last if (c == ' ' && (i == 0 || i == last)) { encodedValue.append("\\ "); continue; } // check in table for escapes if (c < NAME_ESCAPE_TABLE.length) { String esc = NAME_ESCAPE_TABLE[c]; if (esc != null) { encodedValue.append(esc); continue; } } // default: add the char encodedValue.append(c); } return encodedValue.toString(); } /** * Decodes a value. Converts escaped chars to ordinary chars. * @param value Trimmed value, so no leading an trailing blanks, except an escaped * space last. * @return The decoded value as a string. * @throws BadLdapGrammarException */ static String nameDecode(String value) throws BadLdapGrammarException { if (value == null) { return null; } StringBuilder decoded = new StringBuilder(value.length()); int i = 0; while (i < value.length()) { char currentChar = value.charAt(i); if (currentChar == '\\') { // Ending with a single backslash is not allowed if (value.length() <= i + 1) { throw new BadLdapGrammarException("Unexpected end of value " + "unterminated '\\'"); } char nextChar = value.charAt(i + 1); if (isNormalBackslashEscape(nextChar)) { decoded.append(nextChar); i += 2; } else { if (value.length() <= i + 2) { throw new BadLdapGrammarException( "Unexpected end of value " + "expected special or hex, found '" + nextChar + "'"); } // This should be a hex value String hexString = "" + nextChar + value.charAt(i + 2); decoded.append((char) Integer.parseInt(hexString, HEX)); i += 3; } } else { // This character wasn't escaped - just append it decoded.append(currentChar); i++; } } return decoded.toString(); } private static boolean isNormalBackslashEscape(char nextChar) { return nextChar == ',' || nextChar == '=' || nextChar == '+' || nextChar == '<' || nextChar == '>' || nextChar == '#' || nextChar == ';' || nextChar == '\\' || nextChar == '\"' || nextChar == ' '; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy