diff options
| author | sowgro <tpoke.ferrari@gmail.com> | 2025-11-13 20:05:25 -0500 |
|---|---|---|
| committer | sowgro <tpoke.ferrari@gmail.com> | 2025-11-13 20:05:25 -0500 |
| commit | 9adc51f8d74577b5c4ae9c1f88341252f2c22939 (patch) | |
| tree | b4523e012299dae275a684c5ca46f2631db3621b /src/main/java/design/persistence/importexport/XMLHandler.java | |
| parent | 38aacc304d5bc55a8e5705f9eb378ca18fc5a4a7 (diff) | |
| download | designproject-design-6-9adc51f8d74577b5c4ae9c1f88341252f2c22939.tar.gz designproject-design-6-9adc51f8d74577b5c4ae9c1f88341252f2c22939.tar.bz2 designproject-design-6-9adc51f8d74577b5c4ae9c1f88341252f2c22939.zip | |
export almost working
Diffstat (limited to 'src/main/java/design/persistence/importexport/XMLHandler.java')
| -rw-r--r-- | src/main/java/design/persistence/importexport/XMLHandler.java | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/main/java/design/persistence/importexport/XMLHandler.java b/src/main/java/design/persistence/importexport/XMLHandler.java new file mode 100644 index 0000000..1a16b90 --- /dev/null +++ b/src/main/java/design/persistence/importexport/XMLHandler.java @@ -0,0 +1,34 @@ +package design.persistence.importexport; +import java.io.File; +import java.io.IOException; + +import com.fasterxml.jackson.databind.JsonNode; +import com.fasterxml.jackson.databind.node.ObjectNode; +import com.fasterxml.jackson.dataformat.xml.XmlMapper; + +public class XMLHandler implements DataHandler { + + private final DataSource dataSource; + private final XmlMapper xmlMapper = new XmlMapper(); + + public XMLHandler(DataSource dataSource) { + this.dataSource = dataSource; + } + + @Override + public void importData(File file) throws IOException { + JsonNode tree = xmlMapper.readTree(file); + JsonNode unwrapped = tree.get("items"); + dataSource.importData(unwrapped); + } + + @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); + } +} + + |
