Commit 7e2db426 authored by julian.moschuering's avatar julian.moschuering

fixed encrypted properties containing xml escaped data not saved correctly

Encrypted properties containing data that needs xml escaping (eg a database password containing '&') are encryped in escaped form but decryption uses them directly. Encrypted properties do not need xml escaping.

Eg:
1. Install an mysql connection with the password 'pass&word'; password is saved as pass&word in properties.xml
2. Launch openfire
-> mysql connection is established correctly and password is now stored in encrypted form.
4. Restart openfire
5. Openfire startup fails due to incorrect database password (pass&word) is used.
parent fe052913
...@@ -481,7 +481,7 @@ public class XMLProperties { ...@@ -481,7 +481,7 @@ public class XMLProperties {
String propValue = StringEscapeUtils.escapeXml(value); String propValue = StringEscapeUtils.escapeXml(value);
// check to see if the property is marked as encrypted // check to see if the property is marked as encrypted
if (JiveGlobals.isPropertyEncrypted(name)) { if (JiveGlobals.isPropertyEncrypted(name)) {
propValue = JiveGlobals.getPropertyEncryptor().encrypt(propValue); propValue = JiveGlobals.getPropertyEncryptor().encrypt(value);
childElement.addAttribute(ENCRYPTED_ATTRIBUTE, "true"); childElement.addAttribute(ENCRYPTED_ATTRIBUTE, "true");
} }
childElement.setText(propValue); childElement.setText(propValue);
...@@ -642,7 +642,7 @@ public class XMLProperties { ...@@ -642,7 +642,7 @@ public class XMLProperties {
String propValue = StringEscapeUtils.escapeXml(value); String propValue = StringEscapeUtils.escapeXml(value);
// check to see if the property is marked as encrypted // check to see if the property is marked as encrypted
if (JiveGlobals.isPropertyEncrypted(name)) { if (JiveGlobals.isPropertyEncrypted(name)) {
propValue = JiveGlobals.getPropertyEncryptor().encrypt(propValue); propValue = JiveGlobals.getPropertyEncryptor().encrypt(value);
element.addAttribute(ENCRYPTED_ATTRIBUTE, "true"); element.addAttribute(ENCRYPTED_ATTRIBUTE, "true");
} }
element.setText(propValue); element.setText(propValue);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment