diff --git a/src/main/java/ch/ethz/seb/sebserver/gbl/model/sebconfig/ConfigurationAttribute.java b/src/main/java/ch/ethz/seb/sebserver/gbl/model/sebconfig/ConfigurationAttribute.java index a9d584f4..4cbaaee2 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gbl/model/sebconfig/ConfigurationAttribute.java +++ b/src/main/java/ch/ethz/seb/sebserver/gbl/model/sebconfig/ConfigurationAttribute.java @@ -40,7 +40,7 @@ public final class ConfigurationAttribute implements Entity, Comparable configurationValue); + if (j < columns.length - 1) { + out.write(Utils.toByteArray(Constants.LIST_SEPARATOR)); + } } } out.write((xml) ? XML_DICT_END : JSON_DICT_END); + if (!xml && i < rows.length - 1) { + out.write(Utils.toByteArray(Constants.LIST_SEPARATOR)); + } } out.write((xml) ? XML_ARRAY_END : JSON_ARRAY_END); } + private String[] getSortedColumns(final String resources) { + final String[] columns = StringUtils.split(resources, Constants.EMBEDDED_LIST_SEPARATOR); + final List list = Arrays.asList(columns); + Collections.sort(list, (s1, s2) -> { + final String name1 = StringUtils.split(s1, Constants.COMPLEX_VALUE_SEPARATOR)[1]; + final String name2 = StringUtils.split(s2, Constants.COMPLEX_VALUE_SEPARATOR)[1]; + return ConfigurationAttribute.CULTURE_INVARIANT_COLLATOR.compare( + name1, + name2); + }); + + return list.toArray(new String[columns.length]); + } + } diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/sebconfig/impl/converter/StringConverter.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/sebconfig/impl/converter/StringConverter.java index 3957a9bb..e372d66b 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/sebconfig/impl/converter/StringConverter.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/sebconfig/impl/converter/StringConverter.java @@ -67,10 +67,15 @@ public class StringConverter implements AttributeValueConverter { final ConfigurationAttribute attribute, final Function valueSupplier) throws IOException { + final ConfigurationValue cValue = valueSupplier.apply(attribute); + final String val = StringEscapeUtils.escapeXml10((cValue != null && cValue.value != null) + ? cValue.value + : attribute.getDefaultValue()); + convert( out, attribute, - valueSupplier.apply(attribute), + val, XML_TEMPLATE, XML_TEMPLATE_EMPTY); } @@ -80,29 +85,33 @@ public class StringConverter implements AttributeValueConverter { final ConfigurationAttribute attribute, final Function valueSupplier) throws IOException { + // NOTE: Don't escape JSON characters on the value strings here, + // otherwise the Config-Key will be different then in SEB and SEB Config Tool + final ConfigurationValue cValue = valueSupplier.apply(attribute); + final String val = (cValue != null && cValue.value != null) + ? cValue.value + : attribute.getDefaultValue(); + convert( out, attribute, - valueSupplier.apply(attribute), + val, JSON_TEMPLATE, JSON_TEMPLATE_EMPTY); } private void convert( final OutputStream out, final ConfigurationAttribute attribute, - final ConfigurationValue value, + final String value, final String template, final String emptyTemplate) throws IOException { - final String val = StringEscapeUtils.escapeXml10((value != null && value.value != null) - ? value.value - : attribute.getDefaultValue()); final String realName = AttributeValueConverter.extractName(attribute); - if (StringUtils.isNotBlank(val)) { + if (StringUtils.isNotBlank(value)) { out.write(Utils.toByteArray(String.format( template, realName, - convertPassword(realName, val)))); + convertPassword(realName, value)))); } else { out.write(Utils.toByteArray(String.format( emptyTemplate,