diff options
| author | sowgro <tpoke.ferrari@gmail.com> | 2025-11-16 01:56:27 -0500 |
|---|---|---|
| committer | sowgro <tpoke.ferrari@gmail.com> | 2025-11-16 01:56:27 -0500 |
| commit | cf59d52cba70742f1d4098c38b4c7a798b3d89fa (patch) | |
| tree | 3d939229fe72a9298aa5fce98812dfffb6c41fba /src/main/java/design/persistence/importexport/XMLHandler.java | |
| parent | 4ac38e80c2442e085c53986f5717d44f9d2d821a (diff) | |
| download | designproject-design-6-cf59d52cba70742f1d4098c38b4c7a798b3d89fa.tar.gz designproject-design-6-cf59d52cba70742f1d4098c38b4c7a798b3d89fa.tar.bz2 designproject-design-6-cf59d52cba70742f1d4098c38b4c7a798b3d89fa.zip | |
IMPORT-EXPORT WORKING!!!!!!!!!!!!!!!!!!!!!!!!!!import-export-exp
Diffstat (limited to 'src/main/java/design/persistence/importexport/XMLHandler.java')
| -rw-r--r-- | src/main/java/design/persistence/importexport/XMLHandler.java | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/src/main/java/design/persistence/importexport/XMLHandler.java b/src/main/java/design/persistence/importexport/XMLHandler.java index 1a16b90..0a07d6e 100644 --- a/src/main/java/design/persistence/importexport/XMLHandler.java +++ b/src/main/java/design/persistence/importexport/XMLHandler.java @@ -1,10 +1,11 @@ package design.persistence.importexport; import java.io.File; import java.io.IOException; +import java.time.LocalDateTime; -import com.fasterxml.jackson.databind.JsonNode; -import com.fasterxml.jackson.databind.node.ObjectNode; +import com.fasterxml.jackson.databind.module.SimpleModule; import com.fasterxml.jackson.dataformat.xml.XmlMapper; +import design.persistence.Serializers; public class XMLHandler implements DataHandler { @@ -13,21 +14,24 @@ public class XMLHandler implements DataHandler { public XMLHandler(DataSource dataSource) { this.dataSource = dataSource; + + Serializers.configureMapper(xmlMapper); + SimpleModule module = dataSource.getJacksonModule(); + module.addSerializer(LocalDateTime.class, new Serializers.DateTimeStringSerializer()); + xmlMapper.registerModule(module); } @Override public void importData(File file) throws IOException { - JsonNode tree = xmlMapper.readTree(file); - JsonNode unwrapped = tree.get("items"); - dataSource.importData(unwrapped); + Object data = xmlMapper.readValue(file, dataSource.getTargetClass()); + dataSource.importData(data); } @Override public void exportData(File file) throws IOException { - JsonNode tree = dataSource.exportData(); - ObjectNode wrapper = xmlMapper.createObjectNode(); - wrapper.set("items", tree); - xmlMapper.writerWithDefaultPrettyPrinter().withRootName("export").writeValue(file, wrapper); + Object data = dataSource.exportData(); + xmlMapper.writerWithDefaultPrettyPrinter() + .writeValue(file, data); } } |
