com.fasterxml.jackson.jakarta.rs.cfg.JakartaRSFeature Maven / Gradle / Ivy
Show all versions of jackson-jakarta-rs-base Show documentation
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; }
}