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

com.fasterxml.jackson.jaxrs.cfg.JaxRSFeature Maven / Gradle / Ivy

package com.fasterxml.jackson.jaxrs.cfg;

import com.fasterxml.jackson.databind.cfg.ConfigFeature;

/**
 * Enumeration that defines simple on/off features that can be
 * used on all Jackson JAX-RS providers, regardless of
 * underlying data format.
 */
public enum JaxRSFeature implements ConfigFeature
{
    /*
    /**********************************************************
    /* Input handling
    /**********************************************************
     */

    /**
     * Feature related to
     * Issue #49:
     * whether empty input is considered legal or not.
     * If set to true, empty content is allowed and will be read as Java 'null': if false,
     * an {@link java.io.IOException} will be thrown.
     *

* NOTE: in case of JAX-RS 2.0, specific exception will be javax.ws.rs.core.NoContentException; * but this is not defined in JAX-RS 1.x. */ ALLOW_EMPTY_INPUT(true), /* /********************************************************** /* HTTP headers /********************************************************** */ /** * Feature that can be enabled to make provider automatically * add "nosniff" (see * this entry * for details *

* Feature is disabled by default. */ ADD_NO_SNIFF_HEADER(false), /* /********************************************************** /* Caching, related /********************************************************** */ /** * Feature that may be enabled to force dynamic lookup of ObjectMapper * via JAX-RS Provider interface, regardless of whether MapperConfigurator * has explicitly configured mapper or not; if disabled, static configuration will * take precedence. * Note that if this feature is enabled, it typically makes sense to also disable * {@link JaxRSFeature#CACHE_ENDPOINT_READERS} and {@link JaxRSFeature#CACHE_ENDPOINT_WRITERS} * since caching would prevent lookups. *

* Feature is disabled by default. * * @since 2.8 */ DYNAMIC_OBJECT_MAPPER_LOOKUP(false), /** * [jaxrs-providers#86]: Feature that determines whether provider will cache endpoint * definitions for reading or not (including caching of actual ObjectReader to use). * Feature may be disabled if reconfiguration or alternate isntance of ObjectMapper is needed. *

* Note that disabling of the feature may add significant amount of overhead for processing. *

* Feature is enabled by default. * * @since 2.8 */ CACHE_ENDPOINT_READERS(true), /** * [jaxrs-providers#86]: Feature that determines whether provider will cache endpoint * definitions for writing or not (including caching of actual ObjectWriter to use). * Feature may be disabled if reconfiguration or alternate isntance of ObjectMapper is needed. *

* Note that disabling of the feature may add significant amount of overhead for processing. *

* Feature is enabled by default. * * @since 2.8 */ CACHE_ENDPOINT_WRITERS(true), /* /********************************************************** /* Other /********************************************************** */ ; private final boolean _defaultState; private JaxRSFeature(boolean defaultState) { _defaultState = defaultState; } public static int collectDefaults() { int flags = 0; for (JaxRSFeature f : values()) { if (f.enabledByDefault()) { flags |= f.getMask(); } } return flags; } @Override public boolean enabledByDefault() { return _defaultState; } @Override public int getMask() { return (1 << ordinal()); } @Override public boolean enabledIn(int flags) { return (flags & getMask()) != 0; } }