Package org.forgerock.opendj.config
Class DurationPropertyDefinition
- java.lang.Object
-
- org.forgerock.opendj.config.PropertyDefinition<Long>
-
- org.forgerock.opendj.config.DurationPropertyDefinition
-
- All Implemented Interfaces:
Comparable<PropertyDefinition<?>>,Comparator<Long>
public final class DurationPropertyDefinition extends PropertyDefinition<Long>
Duration property definition.A duration property definition comprises of:
- a base unit - specifies the minimum granularity which can be used to specify duration property values. For example, if the base unit is in seconds then values represented in milliseconds will not be permitted. The default base unit is seconds
- an optional maximum unit - specifies the biggest duration unit which can be used to specify duration property values. Values presented in units greater than this unit will not be permitted. There is no default maximum unit
- lower limit - specifies the smallest duration permitted by the property. The default lower limit is 0 and can never be less than 0
- an optional upper limit - specifies the biggest duration permitted by the property. By default, there is no upper limit
- support for unlimited durations - when permitted users can specify "unlimited" durations. These are represented using the decoded value, -1, or the encoded string value "unlimited". By default, unlimited durations are not permitted. In addition, it is not possible to define an upper limit and support unlimited values.
longvalues in the base unit defined for the duration property definition.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classDurationPropertyDefinition.BuilderAn interface for incrementally constructing duration property definitions.-
Nested classes/interfaces inherited from class org.forgerock.opendj.config.PropertyDefinition
PropertyDefinition.AbstractBuilder<T,D extends PropertyDefinition<T>>
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description <R,P>
Raccept(PropertyDefinitionVisitor<R,P> v, P p)Apply a visitor to this property definition.<R,P>
Raccept(PropertyValueVisitor<R,P> v, Long value, P p)Apply a visitor to a property value associated with this property definition.intcompare(Long o1, Long o2)Compares two property values for order.static DurationPropertyDefinition.BuildercreateBuilder(AbstractManagedObjectDefinition<?,?> d, String propertyName)Create a duration property definition builder.LongdecodeValue(String value)Parse and validate a string representation of a property value.StringencodeValue(Long value)Encode the provided property value into its string representation.DurationUnitgetBaseUnit()Get the base unit for this property definition (values including limits are specified in this unit).longgetLowerLimit()Get the lower limit in milli-seconds.DurationUnitgetMaximumUnit()Get the maximum unit for this property definition if specified.LonggetUpperLimit()Get the upper limit in milli-seconds.booleanisAllowUnlimited()Determine whether this property allows unlimited durations.voidtoString(StringBuilder builder)Append a string representation of the property definition to the provided string builder.voidvalidateValue(Long value)Determine if the provided property value is valid according to this property definition.-
Methods inherited from class org.forgerock.opendj.config.PropertyDefinition
castValue, compareTo, equals, getAdministratorAction, getDefaultBehaviorProvider, getDescription, getDescription, getManagedObjectDefinition, getName, getSynopsis, getSynopsis, hashCode, hasOption, initialize, normalizeValue, toString
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.Comparator
reversed, thenComparing, thenComparing, thenComparing, thenComparingDouble, thenComparingInt, thenComparingLong
-
-
-
-
Method Detail
-
createBuilder
public static DurationPropertyDefinition.Builder createBuilder(AbstractManagedObjectDefinition<?,?> d, String propertyName)
Create a duration property definition builder.- Parameters:
d- The managed object definition associated with this property definition.propertyName- The property name.- Returns:
- Returns the new integer property definition builder.
-
getBaseUnit
public DurationUnit getBaseUnit()
Get the base unit for this property definition (values including limits are specified in this unit).- Returns:
- Returns the base unit for this property definition (values including limits are specified in this unit).
-
getMaximumUnit
public DurationUnit getMaximumUnit()
Get the maximum unit for this property definition if specified.- Returns:
- Returns the maximum unit for this property definition, or
nullif there is no maximum unit.
-
getLowerLimit
public long getLowerLimit()
Get the lower limit in milli-seconds.- Returns:
- Returns the lower limit in milli-seconds.
-
getUpperLimit
public Long getUpperLimit()
Get the upper limit in milli-seconds.- Returns:
- Returns the upper limit in milli-seconds, or
nullif there is no upper limit.
-
isAllowUnlimited
public boolean isAllowUnlimited()
Determine whether this property allows unlimited durations.- Returns:
- Returns
trueif this this property allows unlimited durations.
-
validateValue
public void validateValue(Long value)
Description copied from class:PropertyDefinitionDetermine if the provided property value is valid according to this property definition.- Specified by:
validateValuein classPropertyDefinition<Long>- Parameters:
value- The property value (must not benull).
-
encodeValue
public String encodeValue(Long value)
Description copied from class:PropertyDefinitionEncode the provided property value into its string representation.This default implementation simply returns invokes the
Object.toString()method on the provided value.- Overrides:
encodeValuein classPropertyDefinition<Long>- Parameters:
value- The property value (must not benull).- Returns:
- Returns the encoded property string value.
-
decodeValue
public Long decodeValue(String value)
Description copied from class:PropertyDefinitionParse and validate a string representation of a property value.- Specified by:
decodeValuein classPropertyDefinition<Long>- Parameters:
value- The property string value (must not benull).- Returns:
- Returns the decoded property value.
-
accept
public <R,P> R accept(PropertyDefinitionVisitor<R,P> v, P p)
Description copied from class:PropertyDefinitionApply a visitor to this property definition.- Specified by:
acceptin classPropertyDefinition<Long>- Type Parameters:
R- The return type of the visitor's methods.P- The type of the additional parameters to the visitor's methods.- Parameters:
v- The property definition visitor.p- Optional additional visitor parameter.- Returns:
- Returns a result as specified by the visitor.
-
accept
public <R,P> R accept(PropertyValueVisitor<R,P> v, Long value, P p)
Description copied from class:PropertyDefinitionApply a visitor to a property value associated with this property definition.- Specified by:
acceptin classPropertyDefinition<Long>- Type Parameters:
R- The return type of the visitor's methods.P- The type of the additional parameters to the visitor's methods.- Parameters:
v- The property value visitor.value- The property value.p- Optional additional visitor parameter.- Returns:
- Returns a result as specified by the visitor.
-
toString
public void toString(StringBuilder builder)
Description copied from class:PropertyDefinitionAppend a string representation of the property definition to the provided string builder.This simple implementation just outputs the propertyName of the property definition. Sub-classes should override this method to provide more complete string representations.
- Overrides:
toStringin classPropertyDefinition<Long>- Parameters:
builder- The string builder where the string representation should be appended.
-
compare
public int compare(Long o1, Long o2)
Description copied from class:PropertyDefinitionCompares two property values for order. Returns a negative integer, zero, or a positive integer as the first argument is less than, equal to, or greater than the second.This default implementation normalizes both values using
PropertyDefinition.normalizeValue(Object)and then performs a case-sensitive string comparison.- Specified by:
comparein interfaceComparator<Long>- Overrides:
comparein classPropertyDefinition<Long>- Parameters:
o1- the first object to be compared.o2- the second object to be compared.- Returns:
- a negative integer, zero, or a positive integer as the first argument is less than, equal to, or greater than the second.
-
-