All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.kiwiproject.json.FlexibleJsonModel Maven / Gradle / Ivy

Go to download

Kiwi is a utility library. We really like Google's Guava, and also use Apache Commons. But if they don't have something we need, and we think it is useful, this is where we put it.

There is a newer version: 4.5.2
Show newest version
package org.kiwiproject.json;

import com.fasterxml.jackson.annotation.JsonAnyGetter;
import com.fasterxml.jackson.annotation.JsonAnySetter;
import lombok.ToString;

import java.util.HashMap;
import java.util.Map;

/**
 * This class can be used as a base class for situations where there may be additional/unknown properties in
 * a JSON string that don't have a corresponding property in the class being deserialized into. It uses Jackson's
 * {@link JsonAnyGetter} and {@link JsonAnySetter} feature to get and set these "extra fields" in a property
 * named {@code extraFields}.
 * 

* The general use case for this "extra fields" is when some service or application proxies data from a canonical source * where we don't want or need to know about every field, but where we still want to capture those fields, * so we can store, display, etc. them. For example, a remote service that has a large number of properties, and * we only care about a few of them, but we might want to store all of them for analytics, debugging, etc. *

* This implementation intentionally does not define {@code equals} or {@code hashCode} methods, which means the * extra fields will not be included in equality checks unless subclasses choose to include them. It does, however, * include a default {@code toString} method that will print out the extra fields. Whether to include extra fields * in equality checks depends heavily on the use case, so subclasses must decide for themselves. In addition, many * times simple data holder objects don't need to be compared so don't need {@code equals} or {@code hashCode}. */ @ToString public abstract class FlexibleJsonModel { protected final Map extraFields = new HashMap<>(); /** * Returns the "extra" fields not explicitly defined as properties when this object was deserialized * from JSON. * * @return the extra fields */ @JsonAnyGetter public Map getExtraFields() { return extraFields; } /** * Add an "extra" field when deserializing from JSON. * * @param key the extra field name * @param value the value of the extra field */ @JsonAnySetter public void setExtraFields(String key, Object value) { extraFields.put(key, value); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy