com.github.fge.jackson.JacksonUtils Maven / Gradle / Ivy
/*
* Copyright (c) 2014, Francis Galiegue ([email protected])
*
* This software is dual-licensed under:
*
* - the Lesser General Public License (LGPL) version 3.0 or, at your option, any
* later version;
* - the Apache Software License (ASL) version 2.0.
*
* The text of this file and of both licenses is available at the root of this
* project or, if you have the jar distribution, in directory META-INF/, under
* the names LGPL-3.0.txt and ASL-2.0.txt respectively.
*
* Direct link to the sources:
*
* - LGPL 3.0: https://www.gnu.org/licenses/lgpl-3.0.txt
* - ASL 2.0: http://www.apache.org/licenses/LICENSE-2.0.txt
*/
package com.github.fge.jackson;
import com.fasterxml.jackson.core.JsonGenerationException;
import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectReader;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.databind.node.JsonNodeFactory;
import com.google.common.collect.Maps;
import java.io.IOException;
import java.io.StringWriter;
import java.util.Collections;
import java.util.Iterator;
import java.util.Map;
/**
* Utility class for Jackson
*
* This class provides utility methods to get a {@link JsonNodeFactory} and
* a preconfigured {@link ObjectReader}. It can also be used to return
* preconfigured instances of {@link ObjectMapper} (see {@link #newMapper()}.
*
*/
public final class JacksonUtils
{
private static final JsonNodeFactory FACTORY = JsonNodeFactory.instance;
private static final ObjectReader READER;
private static final ObjectWriter WRITER;
static {
final ObjectMapper mapper = newMapper();
READER = mapper.reader();
WRITER = mapper.writer();
}
private JacksonUtils()
{
}
/**
* Return a preconfigured {@link ObjectReader} to read JSON inputs
*
* @return the reader
* @see #newMapper()
*/
public static ObjectReader getReader()
{
return READER;
}
/**
* Return a preconfigured {@link JsonNodeFactory} to generate JSON data as
* {@link JsonNode}s
*
* @return the factory
*/
public static JsonNodeFactory nodeFactory()
{
return FACTORY;
}
/**
* Return a map out of an object's members
*
* If the node given as an argument is not a map, an empty map is
* returned.
*
* @param node the node
* @return a map
*/
public static Map asMap(final JsonNode node)
{
if (!node.isObject())
return Collections.emptyMap();
final Iterator> iterator = node.fields();
final Map ret = Maps.newHashMap();
Map.Entry entry;
while (iterator.hasNext()) {
entry = iterator.next();
ret.put(entry.getKey(), entry.getValue());
}
return ret;
}
/**
* Pretty print a JSON value
*
* @param node the JSON value to print
* @return the pretty printed value as a string
* @see #newMapper()
*/
public static String prettyPrint(final JsonNode node)
{
final StringWriter writer = new StringWriter();
try {
WRITER.writeValue(writer, node);
writer.flush();
} catch (JsonGenerationException e) {
throw new RuntimeException("How did I get there??", e);
} catch (JsonMappingException e) {
throw new RuntimeException("How did I get there??", e);
} catch (IOException ignored) {
// cannot happen
}
return writer.toString();
}
/**
* Return a preconfigured {@link ObjectMapper}
*
* The returned mapper will have the following features enabled:
*
*
* - {@link DeserializationFeature#USE_BIG_DECIMAL_FOR_FLOATS};
* - {@link SerializationFeature#WRITE_BIGDECIMAL_AS_PLAIN};
* - {@link SerializationFeature#INDENT_OUTPUT}.
*
*
* This returns a new instance each time.
*
* @return an {@link ObjectMapper}
*/
public static ObjectMapper newMapper()
{
return new ObjectMapper().setNodeFactory(FACTORY)
.enable(DeserializationFeature.USE_BIG_DECIMAL_FOR_FLOATS)
.enable(SerializationFeature.WRITE_BIGDECIMAL_AS_PLAIN)
.enable(SerializationFeature.INDENT_OUTPUT);
}
}