summaryrefslogtreecommitdiff
path: root/src/main/java/design/persistence/importexport/XMLHandler.java
diff options
context:
space:
mode:
authorTyler Ferrari <69283684+Sowgro@users.noreply.github.com>2025-11-16 02:16:38 -0500
committerGitHub <noreply@github.com>2025-11-16 02:16:38 -0500
commit73dfd2dd419483c7d1060ef2fb40e328a0209e02 (patch)
tree456ed56e629a6324e5993b7ce094705c72e0b922 /src/main/java/design/persistence/importexport/XMLHandler.java
parentb5d46c7701716bcb2dd6127aeb97f8fcdb7774fc (diff)
parent6ffc6b4cbd9e0c5ce2dc82a7c77f39b3adf849b6 (diff)
downloaddesignproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.tar.gz
designproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.tar.bz2
designproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.zip
Merge pull request #21 from RIT-SWEN-262/league-model
League model
Diffstat (limited to 'src/main/java/design/persistence/importexport/XMLHandler.java')
-rw-r--r--src/main/java/design/persistence/importexport/XMLHandler.java38
1 files changed, 38 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..0a07d6e
--- /dev/null
+++ b/src/main/java/design/persistence/importexport/XMLHandler.java
@@ -0,0 +1,38 @@
+package design.persistence.importexport;
+import java.io.File;
+import java.io.IOException;
+import java.time.LocalDateTime;
+
+import com.fasterxml.jackson.databind.module.SimpleModule;
+import com.fasterxml.jackson.dataformat.xml.XmlMapper;
+import design.persistence.Serializers;
+
+public class XMLHandler implements DataHandler {
+
+ private final DataSource dataSource;
+ private final XmlMapper xmlMapper = new XmlMapper();
+
+ 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 {
+ Object data = xmlMapper.readValue(file, dataSource.getTargetClass());
+ dataSource.importData(data);
+ }
+
+ @Override
+ public void exportData(File file) throws IOException {
+ Object data = dataSource.exportData();
+ xmlMapper.writerWithDefaultPrettyPrinter()
+ .writeValue(file, data);
+ }
+}
+
+