Package org.jivesoftware.util
Class XMLProperties
java.lang.Object
org.jivesoftware.util.XMLProperties
Provides the the ability to use simple XML property files. Each property is
in the form X.Y.Z, which would map to an XML snippet of:
<X>
<Y>
<Z>someValue</Z>
</Y>
</X>
The XML file is passed in to the constructor and must be readable and
writtable. Setting property values will automatically persist those value
to disk. The file encoding used is UTF-8.- Author:
- Derek DeMoro, Iain Shigeoka
-
Constructor Summary
ConstructorsConstructorDescriptionXMLProperties(File file) Creates a new XMLPropertiesTest object.Loads XML properties from a stream.XMLProperties(String fileName) Creates a new XMLPropertiesTest object. -
Method Summary
Modifier and TypeMethodDescriptionvoiddeleteProperty(String name) Deletes the specified property.getAttribute(String name, String attribute) Returns the value of the attribute of the given property name or null if it doesn't exist.getChildProperties(String name) Return all values who's path matches the given property name as a String array, or an empty array if the if there are no children.String[]getChildrenProperties(String parent) Return all children property names of a parent property as a String array, or an empty array if the if there are no children.String[]getProperties(String name) Return all values who's path matches the given property name as a String array, or an empty array if the if there are no children.getProperty(String name) Returns the value of the specified property.voidsetProperties(String name, List<String> values) Sets a property to an array of values.voidsetProperties(Map<String, String> propertyMap) voidsetProperty(String name, String value) Sets the value of the specified property.
-
Constructor Details
-
XMLProperties
Creates a new XMLPropertiesTest object.- Parameters:
fileName- the full path the file that properties should be read from and written to.- Throws:
IOException- if an error occurs loading the properties.
-
XMLProperties
Loads XML properties from a stream.- Parameters:
in- the input stream of XML.- Throws:
IOException- if an exception occurs when reading the stream.
-
XMLProperties
Creates a new XMLPropertiesTest object.- Parameters:
file- the file that properties should be read from and written to.- Throws:
IOException- if an error occurs loading the properties.
-
-
Method Details
-
getProperty
Returns the value of the specified property.- Parameters:
name- the name of the property to get.- Returns:
- the value of the specified property.
-
getProperties
Return all values who's path matches the given property name as a String array, or an empty array if the if there are no children. This allows you to retrieve several values with the same property name. For example, consider the XML file entry:<foo> <bar> <prop>some value</prop> <prop>other value</prop> <prop>last value</prop> </bar> </foo>If you call getProperties("foo.bar.prop") will return a string array containing {"some value", "other value", "last value"}.- Parameters:
name- the name of the property to retrieve- Returns:
- all child property values for the given node name.
-
getChildProperties
Return all values who's path matches the given property name as a String array, or an empty array if the if there are no children. This allows you to retrieve several values with the same property name. For example, consider the XML file entry:<foo> <bar> <prop>some value</prop> <prop>other value</prop> <prop>last value</prop> </bar> </foo>If you call getProperties("foo.bar.prop") will return a string array containing {"some value", "other value", "last value"}.- Parameters:
name- the name of the property to retrieve- Returns:
- all child property values for the given node name.
-
getAttribute
Returns the value of the attribute of the given property name or null if it doesn't exist. Note, this- Parameters:
name- the property name to lookup - ie, "foo.bar"attribute- the name of the attribute, ie "id"- Returns:
- the value of the attribute of the given property or null if it doesn't exist.
-
setProperties
Sets a property to an array of values. Multiple values matching the same property is mapped to an XML file as multiple elements containing each value. For example, using the name "foo.bar.prop", and the value string array containing {"some value", "other value", "last value"} would produce the following XML:<foo> <bar> <prop>some value</prop> <prop>other value</prop> <prop>last value</prop> </bar> </foo>- Parameters:
name- the name of the property.values- the values for the property (can be empty but not null).
-
getChildrenProperties
Return all children property names of a parent property as a String array, or an empty array if the if there are no children. For example, given the properties X.Y.A, X.Y.B, and X.Y.C, then the child properties of X.Y are A, B, and C.- Parameters:
parent- the name of the parent property.- Returns:
- all child property values for the given parent.
-
setProperty
Sets the value of the specified property. If the property doesn't currently exist, it will be automatically created.- Parameters:
name- the name of the property to set.value- the new value for the property.
-
deleteProperty
Deletes the specified property.- Parameters:
name- the property to delete.
-
setProperties
-