| | |
| | | * CDDL HEADER END |
| | | * |
| | | * |
| | | * Portions Copyright 2006 Sun Microsystems, Inc. |
| | | * Portions Copyright 2006-2007 Sun Microsystems, Inc. |
| | | */ |
| | | package org.opends.server.config; |
| | | |
| | |
| | | import org.opends.server.types.AttributeValue; |
| | | import org.opends.server.types.ErrorLogCategory; |
| | | import org.opends.server.types.ErrorLogSeverity; |
| | | import org.opends.server.types.DebugLogLevel; |
| | | |
| | | import static org.opends.server.config.ConfigConstants.*; |
| | | import static org.opends.server.loggers.Debug.*; |
| | | import static org.opends.server.loggers.Error.*; |
| | | import static org.opends.server.loggers.debug.DebugLogger.debugCought; |
| | | import static org.opends.server.loggers.debug.DebugLogger.debugEnabled; |
| | | import static org.opends.server.messages.ConfigMessages.*; |
| | | import static org.opends.server.messages.MessageHandler.*; |
| | | import static org.opends.server.util.ServerConstants.*; |
| | |
| | | public class IntegerConfigAttribute |
| | | extends ConfigAttribute |
| | | { |
| | | /** |
| | | * The fully-qualified name of this class for debugging purposes. |
| | | */ |
| | | private static final String CLASS_NAME = |
| | | "org.opends.server.config.IntegerConfigAttribute"; |
| | | |
| | | |
| | | |
| | |
| | | { |
| | | super(name, description, isRequired, isMultiValued, requiresAdminAction); |
| | | |
| | | assert debugConstructor(CLASS_NAME, |
| | | new String[] |
| | | { |
| | | String.valueOf(name), |
| | | String.valueOf(isRequired), |
| | | String.valueOf(isMultiValued), |
| | | String.valueOf(description), |
| | | String.valueOf(requiresAdminAction), |
| | | String.valueOf(hasLowerBound), |
| | | String.valueOf(lowerBound), |
| | | String.valueOf(hasUpperBound), |
| | | String.valueOf(upperBound) |
| | | }); |
| | | |
| | | this.hasLowerBound = hasLowerBound; |
| | | this.lowerBound = lowerBound; |
| | |
| | | super(name, description, isRequired, isMultiValued, requiresAdminAction, |
| | | getValueSet(value)); |
| | | |
| | | assert debugConstructor(CLASS_NAME, |
| | | new String[] |
| | | { |
| | | String.valueOf(name), |
| | | String.valueOf(isRequired), |
| | | String.valueOf(isMultiValued), |
| | | String.valueOf(description), |
| | | String.valueOf(requiresAdminAction), |
| | | String.valueOf(hasLowerBound), |
| | | String.valueOf(lowerBound), |
| | | String.valueOf(hasUpperBound), |
| | | String.valueOf(upperBound), |
| | | String.valueOf(value) |
| | | }); |
| | | |
| | | this.hasLowerBound = hasLowerBound; |
| | | this.lowerBound = lowerBound; |
| | |
| | | super(name, description, isRequired, isMultiValued, requiresAdminAction, |
| | | getValueSet(values)); |
| | | |
| | | assert debugConstructor(CLASS_NAME, |
| | | new String[] |
| | | { |
| | | String.valueOf(name), |
| | | String.valueOf(isRequired), |
| | | String.valueOf(isMultiValued), |
| | | String.valueOf(description), |
| | | String.valueOf(requiresAdminAction), |
| | | String.valueOf(hasLowerBound), |
| | | String.valueOf(lowerBound), |
| | | String.valueOf(hasUpperBound), |
| | | String.valueOf(upperBound), |
| | | String.valueOf(values) |
| | | }); |
| | | |
| | | this.hasLowerBound = hasLowerBound; |
| | | this.lowerBound = lowerBound; |
| | |
| | | getValueSet(activeValues), (pendingValues != null), |
| | | getValueSet(pendingValues)); |
| | | |
| | | assert debugConstructor(CLASS_NAME, |
| | | new String[] |
| | | { |
| | | String.valueOf(name), |
| | | String.valueOf(isRequired), |
| | | String.valueOf(isMultiValued), |
| | | String.valueOf(description), |
| | | String.valueOf(requiresAdminAction), |
| | | String.valueOf(hasLowerBound), |
| | | String.valueOf(lowerBound), |
| | | String.valueOf(hasUpperBound), |
| | | String.valueOf(upperBound), |
| | | String.valueOf(activeValues), |
| | | String.valueOf(pendingValues) |
| | | }); |
| | | |
| | | this.hasLowerBound = hasLowerBound; |
| | | this.lowerBound = lowerBound; |
| | |
| | | */ |
| | | public String getDataType() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getDataType"); |
| | | |
| | | return "Integer"; |
| | | } |
| | |
| | | */ |
| | | public AttributeSyntax getSyntax() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getSyntax"); |
| | | |
| | | return DirectoryServer.getDefaultIntegerSyntax(); |
| | | } |
| | |
| | | public long activeValue() |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "activeValue"); |
| | | |
| | | if ((activeValues == null) || activeValues.isEmpty()) |
| | | { |
| | |
| | | public int activeIntValue() |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "activeIntValue"); |
| | | |
| | | if ((activeValues == null) || activeValues.isEmpty()) |
| | | { |
| | |
| | | */ |
| | | public List<Long> activeValues() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "activeValues"); |
| | | |
| | | return activeValues; |
| | | } |
| | |
| | | public long pendingValue() |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "pendingValue"); |
| | | |
| | | if (! hasPendingValues()) |
| | | { |
| | |
| | | public int pendingIntValue() |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "pendingIntValue"); |
| | | |
| | | if (! hasPendingValues()) |
| | | { |
| | |
| | | */ |
| | | public List<Long> pendingValues() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "pendingValues"); |
| | | |
| | | if (! hasPendingValues()) |
| | | { |
| | |
| | | */ |
| | | public boolean hasLowerBound() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "hasLowerBound"); |
| | | |
| | | return hasLowerBound; |
| | | } |
| | |
| | | */ |
| | | public long getLowerBound() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getLowerBound"); |
| | | |
| | | return lowerBound; |
| | | } |
| | |
| | | */ |
| | | public boolean hasUpperBound() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "hasUpperBound"); |
| | | |
| | | return hasUpperBound; |
| | | } |
| | |
| | | */ |
| | | public long getUpperBound() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getUpperBound"); |
| | | |
| | | return upperBound; |
| | | } |
| | |
| | | public void setValue(long value) |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "setValue", String.valueOf(value)); |
| | | |
| | | if (hasLowerBound && (value < lowerBound)) |
| | | { |
| | |
| | | public void setValues(List<Long> values) |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "setValues", String.valueOf(values)); |
| | | |
| | | |
| | | // First check if the set is empty and if that is allowed. |
| | |
| | | */ |
| | | private static LinkedHashSet<AttributeValue> getValueSet(long value) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getValueSet", String.valueOf(value)); |
| | | |
| | | LinkedHashSet<AttributeValue> valueSet = |
| | | new LinkedHashSet<AttributeValue>(1); |
| | |
| | | */ |
| | | private static LinkedHashSet<AttributeValue> getValueSet(List<Long> values) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getValueSet", String.valueOf(values)); |
| | | |
| | | if (values == null) |
| | | { |
| | |
| | | */ |
| | | public void applyPendingValues() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "applyPendingValues"); |
| | | |
| | | if (! hasPendingValues()) |
| | | { |
| | |
| | | public boolean valueIsAcceptable(AttributeValue value, |
| | | StringBuilder rejectReason) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "valueIsAcceptable", String.valueOf(value), |
| | | "java.lang.StringBuilder"); |
| | | |
| | | |
| | | // First, make sure we can represent it as a long. |
| | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "valueIsAcceptable", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | rejectReason.append(getMessage(MSGID_CONFIG_ATTR_INVALID_INT_VALUE, |
| | | stringValue, String.valueOf(e))); |
| | |
| | | boolean allowFailures) |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "stringsToValues", |
| | | String.valueOf(valueStrings), |
| | | String.valueOf(allowFailures)); |
| | | |
| | | if ((valueStrings == null) || valueStrings.isEmpty()) |
| | | { |
| | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "stringsToValues", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | int msgID = MSGID_CONFIG_ATTR_INT_COULD_NOT_PARSE; |
| | | String message = getMessage(msgID, valueString, getName(), |
| | |
| | | */ |
| | | public List<String> activeValuesToStrings() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "activeValuesToStrings"); |
| | | |
| | | ArrayList<String> valueStrings = |
| | | new ArrayList<String>(activeValues.size()); |
| | |
| | | */ |
| | | public List<String> pendingValuesToStrings() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "pendingValuesToStrings"); |
| | | |
| | | if (hasPendingValues()) |
| | | { |
| | |
| | | public ConfigAttribute getConfigAttribute(List<Attribute> attributeList) |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "getConfigAttribute", |
| | | String.valueOf(attributeList)); |
| | | |
| | | |
| | | ArrayList<Long> activeValues = null; |
| | |
| | | */ |
| | | private javax.management.Attribute _toJMXAttribute(boolean pending) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "_toJMXAttribute"); |
| | | List<Long> requestedValues ; |
| | | String name ; |
| | | if (pending) |
| | |
| | | */ |
| | | public javax.management.Attribute toJMXAttribute() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "toJMXAttribute"); |
| | | |
| | | return _toJMXAttribute(false); |
| | | } |
| | |
| | | */ |
| | | public javax.management.Attribute toJMXAttributePending() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "toJMXAttributePending"); |
| | | |
| | | return _toJMXAttribute(true); |
| | | } |
| | |
| | | */ |
| | | public void toJMXAttribute(AttributeList attributeList) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "toJMXAttribute", |
| | | String.valueOf(attributeList)); |
| | | |
| | | if (activeValues.size() > 0) |
| | | { |
| | |
| | | */ |
| | | public void toJMXAttributeInfo(List<MBeanAttributeInfo> attributeInfoList) |
| | | { |
| | | assert debugEnter(CLASS_NAME, "toJMXAttributeInfo", |
| | | String.valueOf(attributeInfoList)); |
| | | |
| | | |
| | | if (isMultiValued()) |
| | |
| | | */ |
| | | public MBeanParameterInfo toJMXParameterInfo() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "toJMXParameterInfo"); |
| | | |
| | | if (isMultiValued()) |
| | | { |
| | |
| | | public void setValue(javax.management.Attribute jmxAttribute) |
| | | throws ConfigException |
| | | { |
| | | assert debugEnter(CLASS_NAME, "setValue", String.valueOf(jmxAttribute)); |
| | | |
| | | Object value = jmxAttribute.getValue(); |
| | | if (value instanceof Long) |
| | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "setValue", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | int msgID = MSGID_CONFIG_ATTR_INT_COULD_NOT_PARSE; |
| | | String message = getMessage(msgID, String.valueOf(value), getName(), |
| | |
| | | } |
| | | catch (ConfigException ce) |
| | | { |
| | | assert debugException(CLASS_NAME, "setValue", ce); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, ce); |
| | | } |
| | | |
| | | throw ce; |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | assert debugException(CLASS_NAME, "setValue", e); |
| | | if (debugEnabled()) |
| | | { |
| | | debugCought(DebugLogLevel.ERROR, e); |
| | | } |
| | | |
| | | int msgID = MSGID_CONFIG_ATTR_INT_COULD_NOT_PARSE; |
| | | String message = getMessage(msgID, componentType + "[" + length + "]", |
| | |
| | | */ |
| | | public ConfigAttribute duplicate() |
| | | { |
| | | assert debugEnter(CLASS_NAME, "duplicate"); |
| | | |
| | | return new IntegerConfigAttribute(getName(), getDescription(), isRequired(), |
| | | isMultiValued(), requiresAdminAction(), |