Class InstantDeserializer<T extends Temporal>
- All Implemented Interfaces:
NullValueProvider, ValueInstantiator.Gettable
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classstatic classNested classes/interfaces inherited from class ValueDeserializer
ValueDeserializer.None -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final BooleanFlag forJsonFormat.Feature.ADJUST_DATES_TO_CONTEXT_TIME_ZONEprotected final BooleanFlag forJsonFormat.Feature.READ_DATE_TIMESTAMPS_AS_NANOSECONDSprotected final BiFunction<T, ZoneId, T> private static final booleanprivate static final booleanprotected final Function<InstantDeserializer.FromIntegerArguments, T> protected final Function<InstantDeserializer.FromDecimalArguments, T> static final InstantDeserializer<Instant> protected static final PatternConstants used to check if ISO 8601 time string is colon-less.static final InstantDeserializer<OffsetDateTime> protected final Function<TemporalAccessor, T> protected final booleanIn case of vanilla `Instant` we seem to need to translate "+0000 | +00:00 | +00" timezone designator into plain "Z" for some reason; see [jackson-modules-java8#18] for more infostatic final InstantDeserializer<ZonedDateTime> Fields inherited from class JSR310DateTimeDeserializerBase
_formatter, _shapeFields inherited from class JSR310DeserializerBase
_isLenientFields inherited from class StdDeserializer
_valueClass, _valueType, F_MASK_INT_COERCIONS -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedInstantDeserializer(Class<T> supportedType, DateTimeFormatter formatter, Function<TemporalAccessor, T> parsedToValue, Function<InstantDeserializer.FromIntegerArguments, T> fromMilliseconds, Function<InstantDeserializer.FromDecimalArguments, T> fromNanoseconds, BiFunction<T, ZoneId, T> adjust, boolean replaceZeroOffsetAsZ, boolean normalizeZoneId, boolean readNumericStringsAsTimestamp) protectedInstantDeserializer(InstantDeserializer<T> base, Boolean leniency, DateTimeFormatter formatter, com.fasterxml.jackson.annotation.JsonFormat.Shape shape, Boolean adjustToContextTimezoneOverride, Boolean readTimestampsAsNanosOverride) protectedprotectedInstantDeserializer(InstantDeserializer<T> base, DateTimeFormatter f, Boolean leniency) -
Method Summary
Modifier and TypeMethodDescriptionprotected int_countPeriods(String str) protected T_fromDecimal(DeserializationContext context, BigDecimal value) protected T_fromLong(DeserializationContext context, long timestamp) protected T_fromString(tools.jackson.core.JsonParser p, DeserializationContext ctxt, String string0) protected T_truncateToMillis(T value) protected JSR310DateTimeDeserializerBase<?> _withFormatOverrides(DeserializationContext ctxt, BeanProperty property, com.fasterxml.jackson.annotation.JsonFormat.Value formatOverrides) private static Stringprivate static OffsetDateTimedeserialize(tools.jackson.core.JsonParser p, DeserializationContext ctxt) Method that can be called to ask implementation to deserialize JSON content into the value type this serializer handles.private ZoneIdgetZone(DeserializationContext context) private static StringreplaceZeroOffsetAsZ(String text) private Stringprotected booleanprotected booleanNOTE:publicsince 2.21 / 3.1withLeniency(Boolean leniency) NOTE:publicsince 2.21 / 3.1Methods inherited from class JSR310DateTimeDeserializerBase
_throwNoNumericTimestampNeedTimeZone, createContextual, withShapeMethods inherited from class JSR310DeserializerBase
_failForNotLenient, _fromEmptyString, _handleDateTimeException, _handleDateTimeFormatException, _handleUnexpectedToken, _handleUnexpectedToken, _isValidTimestampString, _peelDTE, _reportWrongToken, _reportWrongToken, deserializeWithType, isLenient, logicalTypeMethods inherited from class StdScalarDeserializer
deserialize, getEmptyAccessPattern, getNullAccessPattern, supportsUpdateMethods inherited from class StdDeserializer
_byteOverflow, _checkBooleanToStringCoercion, _checkCoercionFail, _checkDoubleSpecialValue, _checkFloatSpecialValue, _checkFloatToIntCoercion, _checkFloatToStringCoercion, _checkFromStringCoercion, _checkFromStringCoercion, _checkIntToFloatCoercion, _checkIntToStringCoercion, _checkTextualNull, _checkToStringCoercion, _coerceBooleanFromInt, _coercedTypeDesc, _coercedTypeDesc, _coerceIntegral, _deserializeFromArray, _deserializeFromEmptyString, _deserializeFromString, _deserializeFromStringForContainer, _deserializeWrappedValue, _findCoercionFromBlankString, _findCoercionFromEmptyArray, _findCoercionFromEmptyString, _findNullProvider, _hasTextualNull, _intOverflow, _isBlank, _isFalse, _isIntNumber, _isNaN, _isNegInf, _isPosInf, _isTrue, _neitherNull, _nonNullNumber, _parseBoolean, _parseBooleanPrimitive, _parseBytePrimitive, _parseDate, _parseDate, _parseDateFromArray, _parseDouble, _parseDoublePrimitive, _parseDoublePrimitive, _parseFloatPrimitive, _parseFloatPrimitive, _parseInteger, _parseInteger, _parseIntPrimitive, _parseIntPrimitive, _parseLong, _parseLong, _parseLongPrimitive, _parseLongPrimitive, _parseShortPrimitive, _parseString, _reportFailedNullCoerce, _shortOverflow, _verifyEndArrayForSingle, _verifyNullForPrimitive, _verifyNullForPrimitive, _verifyNullForPrimitiveCoercion, _wrapIOFailure, findContentNullProvider, findContentNullStyle, findConvertingContentDeserializer, findDeserializer, findFormatFeature, findFormatFeature, findFormatOverrides, findFormatOverrides, findValueNullProvider, getValueInstantiator, getValueType, getValueType, handledType, handleMissingEndArrayForSingle, handleNestedArrayForSingle, handleUnknownProperty, isDefaultDeserializer, isDefaultKeyDeserializerMethods inherited from class ValueDeserializer
deserializeWithType, findBackReference, getAbsentValue, getDelegatee, getEmptyValue, getKnownPropertyNames, getNullValue, getObjectIdReader, isCachable, replaceDelegatee, resolve, unwrappingDeserializer
-
Field Details
-
DEFAULT_NORMALIZE_ZONE_ID
private static final boolean DEFAULT_NORMALIZE_ZONE_ID -
DEFAULT_ALWAYS_ALLOW_STRINGIFIED_DATE_TIMESTAMPS
private static final boolean DEFAULT_ALWAYS_ALLOW_STRINGIFIED_DATE_TIMESTAMPS -
ISO8601_COLONLESS_OFFSET_REGEX
Constants used to check if ISO 8601 time string is colon-less. See [jackson-modules-java8#131] -
INSTANT
-
OFFSET_DATE_TIME
-
ZONED_DATE_TIME
-
fromMilliseconds
protected final Function<InstantDeserializer.FromIntegerArguments, T extends Temporal> fromMilliseconds -
fromNanoseconds
protected final Function<InstantDeserializer.FromDecimalArguments, T extends Temporal> fromNanoseconds -
parsedToValue
-
adjust
-
replaceZeroOffsetAsZ
protected final boolean replaceZeroOffsetAsZIn case of vanilla `Instant` we seem to need to translate "+0000 | +00:00 | +00" timezone designator into plain "Z" for some reason; see [jackson-modules-java8#18] for more info -
_adjustToContextTZOverride
Flag forJsonFormat.Feature.ADJUST_DATES_TO_CONTEXT_TIME_ZONE -
_readTimestampsAsNanosOverride
Flag forJsonFormat.Feature.READ_DATE_TIMESTAMPS_AS_NANOSECONDS
-
-
Constructor Details
-
InstantDeserializer
protected InstantDeserializer(Class<T> supportedType, DateTimeFormatter formatter, Function<TemporalAccessor, T> parsedToValue, Function<InstantDeserializer.FromIntegerArguments, T> fromMilliseconds, Function<InstantDeserializer.FromDecimalArguments, T> fromNanoseconds, BiFunction<T, ZoneId, T> adjust, boolean replaceZeroOffsetAsZ, boolean normalizeZoneId, boolean readNumericStringsAsTimestamp) - Since:
- 2.16
-
InstantDeserializer
-
InstantDeserializer
-
InstantDeserializer
protected InstantDeserializer(InstantDeserializer<T> base, Boolean leniency, DateTimeFormatter formatter, com.fasterxml.jackson.annotation.JsonFormat.Shape shape, Boolean adjustToContextTimezoneOverride, Boolean readTimestampsAsNanosOverride)
-
-
Method Details
-
decimalToOffsetDateTime
private static OffsetDateTime decimalToOffsetDateTime(InstantDeserializer.FromDecimalArguments args) -
withDateFormat
NOTE:publicsince 2.21 / 3.1- Specified by:
withDateFormatin classJSR310DateTimeDeserializerBase<T extends Temporal>
-
withLeniency
NOTE:publicsince 2.21 / 3.1- Specified by:
withLeniencyin classJSR310DateTimeDeserializerBase<T extends Temporal>
-
_withFormatOverrides
protected JSR310DateTimeDeserializerBase<?> _withFormatOverrides(DeserializationContext ctxt, BeanProperty property, com.fasterxml.jackson.annotation.JsonFormat.Value formatOverrides) - Overrides:
_withFormatOverridesin classJSR310DateTimeDeserializerBase<T extends Temporal>- Parameters:
ctxt- Active deserialization contextproperty- (optional) Property on which this deserializer is used, ornullfor root valueformatOverrides- Format overrides to use (non-null)- Returns:
- Either this deserializer as is, or newly constructed variant if created for different configuration
-
deserialize
public T deserialize(tools.jackson.core.JsonParser p, DeserializationContext ctxt) throws tools.jackson.core.JacksonException Description copied from class:ValueDeserializerMethod that can be called to ask implementation to deserialize JSON content into the value type this serializer handles. Returned instance is to be constructed by method itself.Pre-condition for this method is that the parser points to the first event that is part of value to deserializer (and which is never JSON 'null' literal, more on this below): for simple types it may be the only value; and for structured types the Object start marker or a FIELD_NAME.
The two possible input conditions for structured types result from polymorphism via fields. In the ordinary case, Jackson calls this method when it has encountered an OBJECT_START, and the method implementation must advance to the next token to see the first field name. If the application configures polymorphism via a field, then the object looks like the following.
{ "@class": "class name", ... }Jackson consumes the two tokens (the@classfield name and its value) in order to learn the class and select the deserializer. Thus, the stream is pointing to the FIELD_NAME for the first field after the @class. Thus, if you want your method to work correctly both with and without polymorphism, you must begin your method with:if (p.currentToken() == JsonToken.START_OBJECT) { p.nextToken(); }This results in the stream pointing to the field name, so that the two conditions align.Post-condition is that the parser will point to the last event that is part of deserialized value (or in case deserialization fails, event that was not recognized or usable, which may be the same event as the one it pointed to upon call).
Handling null values (JsonToken.VALUE_NULL)
: Note that this method is never called for the JSONnullliteral to avoid every deserializer from having to handle null values. Instead, theValueDeserializer.getNullValue(DeserializationContext)method is called to produce a null value. To influence null handling, custom deserializers should overrideValueDeserializer.getNullValue(DeserializationContext)and usually alsoValueDeserializer.getNullAccessPattern().- Specified by:
deserializein classValueDeserializer<T extends Temporal>- Parameters:
p- Parser used for reading JSON contentctxt- Context that can be used to access information about this deserialization activity.- Returns:
- Deserialized value
- Throws:
tools.jackson.core.JacksonException
-
_truncateToMillis
-
shouldAdjustToContextTimezone
-
shouldReadTimestampsAsNanoseconds
-
_countPeriods
-
_fromString
protected T _fromString(tools.jackson.core.JsonParser p, DeserializationContext ctxt, String string0) throws tools.jackson.core.JacksonException - Throws:
tools.jackson.core.JacksonException
-
_fromLong
-
_fromDecimal
-
getZone
-
replaceZeroOffsetAsZIfNecessary
-
replaceZeroOffsetAsZ
-
addInColonToOffsetIfMissing
-