/*
|
* CDDL HEADER START
|
*
|
* The contents of this file are subject to the terms of the
|
* Common Development and Distribution License, Version 1.0 only
|
* (the "License"). You may not use this file except in compliance
|
* with the License.
|
*
|
* You can obtain a copy of the license at
|
* trunk/opends/resource/legal-notices/OpenDS.LICENSE
|
* or https://OpenDS.dev.java.net/OpenDS.LICENSE.
|
* 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/opends/resource/legal-notices/OpenDS.LICENSE. 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
|
*
|
*
|
* Portions Copyright 2007 Sun Microsystems, Inc.
|
*/
|
|
package org.opends.server.admin.client;
|
|
|
|
import org.opends.server.admin.IllegalPropertyValueStringException;
|
import org.opends.server.admin.OperationsException;
|
import org.opends.server.admin.PropertyDefinition;
|
import org.opends.server.admin.PropertyDefinitionUsageBuilder;
|
|
|
|
/**
|
* Thrown when an attempt is made to create a new managed object with
|
* an illegal name.
|
* <p>
|
* This exception can occur when a new managed object is given a name
|
* which is either an empty string, a string containing just
|
* white-spaces, or a string which is invalid according to the managed
|
* object's naming property (if it has one).
|
*/
|
public class IllegalManagedObjectNameException extends OperationsException {
|
|
/**
|
* Serialization ID.
|
*/
|
private static final long serialVersionUID = 7491748228684293291L;
|
|
// The illegal name.
|
private final String illegalName;
|
|
// The naming property definition if applicable.
|
private final PropertyDefinition<?> namingPropertyDefinition;
|
|
|
|
/**
|
* Create a new illegal name exception and no naming property
|
* definition.
|
*
|
* @param illegalName
|
* The illegal managed object name.
|
*/
|
public IllegalManagedObjectNameException(String illegalName) {
|
this(illegalName, null);
|
}
|
|
|
|
/**
|
* Create a new illegal name exception and a naming property
|
* definition.
|
*
|
* @param illegalName
|
* The illegal managed object name.
|
* @param namingPropertyDefinition
|
* The naming property definition.
|
*/
|
public IllegalManagedObjectNameException(String illegalName,
|
PropertyDefinition<?> namingPropertyDefinition) {
|
this.illegalName = illegalName;
|
this.namingPropertyDefinition = namingPropertyDefinition;
|
}
|
|
|
|
/**
|
* Get the illegal managed object name.
|
*
|
* @return Returns the illegal managed object name.
|
*/
|
public String getIllegalName() {
|
return illegalName;
|
}
|
|
|
|
/**
|
* Get the naming property definition if applicable.
|
*
|
* @return Returns naming property definition, or <code>null</code>
|
* if none was specified.
|
*/
|
public PropertyDefinition<?> getNamingPropertyDefinition() {
|
return namingPropertyDefinition;
|
}
|
|
|
|
/**
|
* {@inheritDoc}
|
*/
|
@Override
|
public String getMessage() {
|
if (illegalName.length() == 0) {
|
return "Empty managed object names are not permitted";
|
} else if (illegalName.trim().length() == 0) {
|
return "Blank managed object names are not permitted";
|
} else if (namingPropertyDefinition != null) {
|
try {
|
namingPropertyDefinition.decodeValue(illegalName);
|
} catch (IllegalPropertyValueStringException e) {
|
String msg = "The managed object name \"%s\" is not a valid value "
|
+ "for the naming property \"%s\", which must have the following "
|
+ "syntax: %s";
|
PropertyDefinitionUsageBuilder builder =
|
new PropertyDefinitionUsageBuilder(true);
|
return String.format(msg, illegalName, namingPropertyDefinition
|
.getName(), builder.getUsage(namingPropertyDefinition));
|
}
|
}
|
|
return "The managed object name \"" + illegalName + "\" is not permitted";
|
}
|
|
}
|