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

com.fasterxml.jackson.jakarta.rs.cfg.JakartaRSFeature Maven / Gradle / Ivy

There is a newer version: 2.18.2
Show newest version
package com.fasterxml.jackson.jakarta.rs.cfg;

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

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

    /**
     * Feature to define 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 Jakarta-RS 2.0, specific exception will be {@code jakarta.ws.rs.core.NoContentException}, */ ALLOW_EMPTY_INPUT(true), /** * For HTTP keep-alive or multipart content to work correctly, Jackson must read the entire HTTP input * stream up until reading EOF (-1). * Issue #108 * If set to true, always consume all input content. This has a side-effect of failing on trailing content. *

* Feature is enabled by default. * Note that this means that behavior in earlier versions * (2.14 and before) differs from 2.15 and later. * * @since 2.15 */ READ_FULL_STREAM(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 Jakarta-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 JakartaRSFeature#CACHE_ENDPOINT_READERS} and {@link JakartaRSFeature#CACHE_ENDPOINT_WRITERS} * since caching would prevent lookups. *

* Feature is disabled by default. */ DYNAMIC_OBJECT_MAPPER_LOOKUP(false), /** * 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 instance of ObjectMapper is needed. *

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

* Feature is enabled by default. */ CACHE_ENDPOINT_READERS(true), /** * 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 instance of ObjectMapper is needed. *

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

* Feature is enabled by default. */ CACHE_ENDPOINT_WRITERS(true), /* /********************************************************************** /* Other /********************************************************************** */ ; private final boolean _defaultState; private JakartaRSFeature(boolean defaultState) { _defaultState = defaultState; } public static int collectDefaults() { int flags = 0; for (JakartaRSFeature 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; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy