From 321878464adb427fbc58daa70ff07cfd1614d4da Mon Sep 17 00:00:00 2001 From: Simon Chemouil Date: Mon, 16 Oct 2017 17:50:20 +0200 Subject: [PATCH] Issue #3: Allow automatic deserialization of immutable classes using parameter names --- .../jackson/internal/JacksonMapperImpl.java | 27 ++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/src/main/java/io/primeval/json/jackson/internal/JacksonMapperImpl.java b/src/main/java/io/primeval/json/jackson/internal/JacksonMapperImpl.java index bbede32..5ab8817 100644 --- a/src/main/java/io/primeval/json/jackson/internal/JacksonMapperImpl.java +++ b/src/main/java/io/primeval/json/jackson/internal/JacksonMapperImpl.java @@ -22,12 +22,18 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import com.fasterxml.jackson.annotation.JsonCreator; +import com.fasterxml.jackson.annotation.JsonCreator.Mode; import com.fasterxml.jackson.core.JsonParser; import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.DeserializationFeature; +import com.fasterxml.jackson.databind.MapperFeature; import com.fasterxml.jackson.databind.Module; import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.SerializationFeature; +import com.fasterxml.jackson.databind.cfg.MapperConfig; +import com.fasterxml.jackson.databind.introspect.Annotated; +import com.fasterxml.jackson.databind.introspect.JacksonAnnotationIntrospector; import com.fasterxml.jackson.datatype.jdk8.Jdk8Module; import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; import com.fasterxml.jackson.module.paramnames.ParameterNamesModule; @@ -45,10 +51,11 @@ @Component(immediate = true, service = { JacksonMapper.class, JsonSerDes.class, JsonSerializer.class, JsonDeserializer.class }) public final class JacksonMapperImpl implements JacksonMapper { + private static final Logger LOGGER = LoggerFactory.getLogger(JacksonMapperImpl.class); - private final List BASE_MODULES = Arrays.asList(new Jdk8Module(), new JavaTimeModule(), - new ParameterNamesModule()); + private static final List BASE_MODULES = Arrays.asList(new Jdk8Module(), new JavaTimeModule(), + new ParameterNamesModule(Mode.PROPERTIES)); private final Object lock = new Object(); private ObjectMapper mapper; @@ -79,7 +86,21 @@ public void ensureMapperConfig() { this.mapper.enable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES); this.mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false); this.mapper.configure(JsonParser.Feature.ALLOW_NON_NUMERIC_NUMBERS, true); - + this.mapper.enable(MapperFeature.INFER_CREATOR_FROM_CONSTRUCTOR_PROPERTIES); + this.mapper.setAnnotationIntrospector(new JacksonAnnotationIntrospector() { + public JsonCreator.Mode findCreatorAnnotation(MapperConfig config, Annotated a) { + JsonCreator ann = _findAnnotation(a, JsonCreator.class); + if (ann != null) { + JsonCreator.Mode mode = ann.mode(); + // but keep in mind that there may be explicit default for this module + if (mode == JsonCreator.Mode.DEFAULT) { + mode = Mode.PROPERTIES; + } + return mode; + } + return Mode.PROPERTIES; + } + }); // TODO Make Filters & AnnotationIntrospecter settable with service }