org.codehaus.jackson.jaxrs.JacksonJaxbJsonProvider Maven / Gradle / Ivy
package org.codehaus.jackson.jaxrs;
import javax.ws.rs.Consumes;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.ext.Provider;
import org.codehaus.jackson.map.ObjectMapper;
/**
* JSON content type provider automatically configured to use both Jackson
* and JAXB annotations (in that order of priority). Otherwise functionally
* same as {@link JacksonJsonProvider}.
*
* Typical usage pattern is to just instantiate instance of this
* provider for JAX-RS and use as is: this will use both Jackson and
* JAXB annotations (with Jackson annotations having priority).
*
* Note: class annotations are duplicated from super class, since it
* is not clear whether JAX-RS implementations are required to
* check settings of super-classes. It is important to keep annotations
* in sync if changed.
*
* @since 1.3
*/
@Provider
@Consumes({MediaType.APPLICATION_JSON, "text/json"})
@Produces({MediaType.APPLICATION_JSON, "text/json"})
public class JacksonJaxbJsonProvider extends JacksonJsonProvider {
/**
* Default annotation sets to use, if not explicitly defined during
* construction: use Jackson annotations if found; if not, use
* JAXB annotations as fallback.
*/
public final static Annotations[] DEFAULT_ANNOTATIONS = {
Annotations.JACKSON, Annotations.JAXB
};
/**
* Default constructor, usually used when provider is automatically
* configured to be used with JAX-RS implementation.
*/
public JacksonJaxbJsonProvider()
{
this(null, DEFAULT_ANNOTATIONS);
}
/**
* @param annotationsToUse Annotation set(s) to use for configuring
* data binding
*/
public JacksonJaxbJsonProvider(Annotations... annotationsToUse)
{
this(null, annotationsToUse);
}
/**
* Constructor to use when a custom mapper (usually components
* like serializer/deserializer factories that have been configured)
* is to be used.
*/
public JacksonJaxbJsonProvider(ObjectMapper mapper, Annotations[] annotationsToUse)
{
super(mapper, annotationsToUse);
}
}