From 5b1877bc1f4b5121ecd5befdc9ebb5e36da5c847 Mon Sep 17 00:00:00 2001 From: sowgro Date: Fri, 14 Nov 2025 17:05:51 -0500 Subject: more robust map serializer should be working --- src/main/java/design/persistence/Serializers.java | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) (limited to 'src/main/java/design/persistence/Serializers.java') diff --git a/src/main/java/design/persistence/Serializers.java b/src/main/java/design/persistence/Serializers.java index 3940b44..d00dcbf 100644 --- a/src/main/java/design/persistence/Serializers.java +++ b/src/main/java/design/persistence/Serializers.java @@ -13,6 +13,7 @@ import design.model.Golfer; import design.model.League; import java.io.IOException; +import java.util.Map; public class Serializers { public static class CustomPrettyPrinter extends DefaultPrettyPrinter { @@ -76,4 +77,22 @@ public class Serializers { return personalDB.getGolfer(username); } } + + @SuppressWarnings("rawtypes") + public static class MapListSerializer extends JsonSerializer { + + @Override + public void serialize(Map value, JsonGenerator gen, SerializerProvider serializers) throws IOException { + gen.writeObject(value.entrySet()); + } + } + + @SuppressWarnings("rawtypes") + public static class MapListDeserializer extends JsonDeserializer { + + @Override + public Map deserialize(JsonParser p, DeserializationContext ctxt) throws IOException { + return Map.ofEntries(p.readValueAs(Map.Entry[].class)); + } + } } -- cgit v1.2.3