mirror of https://github.com/OpenIdentityPlatform/OpenDJ.git

Matthew Swift
25.33.2012 263d085885df024dca9250cc03c807912b0a7662
opendj3/opendj-ldap-sdk/src/main/java/org/forgerock/opendj/ldap/schema/RegexSyntaxImpl.java
@@ -6,17 +6,16 @@
 * (the "License").  You may not use this file except in compliance
 * with the License.
 *
 * You can obtain a copy of the license at
 * trunk/opendj3/legal-notices/CDDLv1_0.txt
 * You can obtain a copy of the license at legal-notices/CDDLv1_0.txt
 * or http://forgerock.org/license/CDDLv1.0.html.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at
 * trunk/opendj3/legal-notices/CDDLv1_0.txt.  If applicable,
 * add the following below this CDDL HEADER, with the fields enclosed
 * by brackets "[]" replaced with your own identifying information:
 * file and include the License file at legal-notices/CDDLv1_0.txt.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information:
 *      Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
@@ -27,10 +26,11 @@
package org.forgerock.opendj.ldap.schema;
import static org.forgerock.opendj.ldap.CoreMessages.*;
import static org.forgerock.opendj.ldap.schema.SchemaConstants.*;
import static org.forgerock.opendj.ldap.CoreMessages.WARN_ATTR_SYNTAX_LDAPSYNTAX_REGEX_INVALID_VALUE;
import static org.forgerock.opendj.ldap.schema.SchemaConstants.AMR_DOUBLE_METAPHONE_OID;
import static org.forgerock.opendj.ldap.schema.SchemaConstants.EMR_CASE_IGNORE_OID;
import static org.forgerock.opendj.ldap.schema.SchemaConstants.OMR_CASE_IGNORE_OID;
import static org.forgerock.opendj.ldap.schema.SchemaConstants.SMR_CASE_IGNORE_OID;
import java.util.regex.Pattern;
@@ -40,85 +40,58 @@
import com.forgerock.opendj.util.Validator;
/**
 * This class provides a regex mechanism where a new syntax and its
 * corresponding matching rules can be created on-the-fly. A regex syntax is an
 * LDAPSyntaxDescriptionSyntax with X-PATTERN extension.
 */
final class RegexSyntaxImpl extends AbstractSyntaxImpl
{
  // The Pattern associated with the regex.
  private final Pattern pattern;
final class RegexSyntaxImpl extends AbstractSyntaxImpl {
    // The Pattern associated with the regex.
    private final Pattern pattern;
  RegexSyntaxImpl(final Pattern pattern)
  {
    Validator.ensureNotNull(pattern);
    this.pattern = pattern;
  }
  @Override
  public String getApproximateMatchingRule()
  {
    return AMR_DOUBLE_METAPHONE_OID;
  }
  @Override
  public String getEqualityMatchingRule()
  {
    return EMR_CASE_IGNORE_OID;
  }
  public String getName()
  {
    return "Regex(" + pattern.toString() + ")";
  }
  @Override
  public String getOrderingMatchingRule()
  {
    return OMR_CASE_IGNORE_OID;
  }
  @Override
  public String getSubstringMatchingRule()
  {
    return SMR_CASE_IGNORE_OID;
  }
  public boolean isHumanReadable()
  {
    return true;
  }
  public boolean valueIsAcceptable(final Schema schema,
      final ByteSequence value, final LocalizableMessageBuilder invalidReason)
  {
    final String strValue = value.toString();
    final boolean matches = pattern.matcher(strValue).matches();
    if (!matches)
    {
      final LocalizableMessage message = WARN_ATTR_SYNTAX_LDAPSYNTAX_REGEX_INVALID_VALUE
          .get(strValue, pattern.pattern());
      invalidReason.append(message);
    RegexSyntaxImpl(final Pattern pattern) {
        Validator.ensureNotNull(pattern);
        this.pattern = pattern;
    }
    return matches;
  }
    @Override
    public String getApproximateMatchingRule() {
        return AMR_DOUBLE_METAPHONE_OID;
    }
    @Override
    public String getEqualityMatchingRule() {
        return EMR_CASE_IGNORE_OID;
    }
    public String getName() {
        return "Regex(" + pattern.toString() + ")";
    }
    @Override
    public String getOrderingMatchingRule() {
        return OMR_CASE_IGNORE_OID;
    }
    @Override
    public String getSubstringMatchingRule() {
        return SMR_CASE_IGNORE_OID;
    }
    public boolean isHumanReadable() {
        return true;
    }
    public boolean valueIsAcceptable(final Schema schema, final ByteSequence value,
            final LocalizableMessageBuilder invalidReason) {
        final String strValue = value.toString();
        final boolean matches = pattern.matcher(strValue).matches();
        if (!matches) {
            final LocalizableMessage message =
                    WARN_ATTR_SYNTAX_LDAPSYNTAX_REGEX_INVALID_VALUE
                            .get(strValue, pattern.pattern());
            invalidReason.append(message);
        }
        return matches;
    }
}