com.graphql_java_generator.client.response.AbstractCustomJacksonDeserializer Maven / Gradle / Ivy
/**
*
*/
package com.graphql_java_generator.client.response;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.JsonToken;
import com.fasterxml.jackson.databind.DeserializationContext;
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
import graphql.language.BooleanValue;
import graphql.language.FloatValue;
import graphql.language.IntValue;
import graphql.language.StringValue;
import graphql.language.Value;
import graphql.schema.GraphQLScalarType;
/**
* Jackson Deserializer for Custom Scalar.
*
* @author etienne-sf
*/
public abstract class AbstractCustomJacksonDeserializer extends StdDeserializer {
private static final long serialVersionUID = 1L;
/** Logger for this class */
private Logger logger = LoggerFactory.getLogger(getClass());
/**
* The class that can deserialize the items in the list. This recursion allows to deserialize list of lists.
* This field must be null to deserialize non list objects. And it's mandatory, to deserialize lists.
*/
AbstractCustomJacksonDeserializer> itemDeserializer;
// final int nbListLevels;
/**
* The {@link GraphQLScalarType} instance that manages this Custom Scalar. It's used to deserialize the value read
* on the Jackson response from the server It is mandatory for custom scalars, and must null for other data types.
*/
final GraphQLScalarType graphQLScalarType;
/**
* This indicates if this deserializer manages list of GraphQL values, or a GraphQL scalar. We can't just read the
* kind of JSON token, as it would be possible (very unlikely, but not impossible) that a custom scalar stores its
* content as a JSON list. So we need our particular way of knowing of this deserialize expects a list or final
* value (from a GraphQL or java view point).
*/
final boolean list;
/**
* The java type that contains the value of the final items, in the list. For instance for a GraphQL type
* [[Boolean]], the handle type is {@link Boolean}. It is sent to the jackson {@link StdDeserializer}. It is also
* used when the recursion of the nested list is at the deepest level, and the read token is the "real" value.
*/
final Class> handledType;
/**
* The constructor, for non list field. This constructor builds a custom jackson deserialize, for field that can't
* be deserialize by jackson alone. Typically: GraphQL custom scalars.
*
* @param handledType
* The java type that contains the value of the final items, in the list. For instance for a GraphQL type
* [[Boolean]], the handle type is {@link Boolean}. It is sent to the jackson {@link StdDeserializer}. It
* is also used when the recursion of the nested list is at the deepest level, and the read token is the
* "real" value.
* @param graphQLScalarType
* The {@link GraphQLScalarType} instance that manages this Custom Scalar. It's used to deserialize the
* value read on the Jackson response from the server It is mandatory for custom scalars, and must null
* for other data types.
*/
protected AbstractCustomJacksonDeserializer(Class> handledType, GraphQLScalarType graphQLScalarType) {
this(null, false, handledType, graphQLScalarType);
}
/**
* @param itemDeserializer
* The class that can deserialize the items in the list. This recursion allows to deserialize list of
* lists.
* This field must be null to deserialize non list objects. And it's mandatory, to deserialize lists.
* @param handledType
* The java type that contains the value of the final items, in the list. For instance for a GraphQL type
* [[Boolean]], the handle type is {@link Boolean}. It is sent to the jackson {@link StdDeserializer}. It
* is also used when the recursion of the nested list is at the deepest level, and the read token is the
* "real" value.
* @param graphQLScalarType
* The {@link GraphQLScalarType} instance that manages this Custom Scalar. It's used to deserialize the
* value read on the Jackson response from the server It is mandatory for custom scalars, and must null
* for other data types.
*/
protected AbstractCustomJacksonDeserializer(AbstractCustomJacksonDeserializer> itemDeserializer, boolean list,
Class> handledType, GraphQLScalarType graphQLScalarType) {
super(handledType);
this.itemDeserializer = itemDeserializer;
this.list = list;
this.handledType = handledType;
this.graphQLScalarType = graphQLScalarType;
}
@SuppressWarnings("unchecked")
@Override
public T deserialize(JsonParser p, DeserializationContext ctxt) throws IOException, JsonProcessingException {
JsonToken currentToken = p.currentToken();
logger.trace("Reading a {} token", currentToken);
if (p.currentToken().equals(JsonToken.VALUE_NULL)) {
return null;
} else if (list) {
if (!p.currentToken().equals(JsonToken.START_ARRAY)) {
// Oups
throw new JsonParseException(p, "Found a " + p.currentToken().asString()
+ " token, but the current deserializer expects a list");
}
// We're at the beginning of a list. Let's read it
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy