com.fasterxml.jackson.databind

Class BeanDescription

  • Direct Known Subclasses:
    BasicBeanDescription


    public abstract class BeanDescription
    extends Object
    Basic container for information gathered by ClassIntrospector to help in constructing serializers and deserializers. Note that the one implementation type is BasicBeanDescription, meaning that it is safe to upcast to that type.
    • Field Detail

      • _type

        protected final JavaType _type
        Bean type information, including raw class and possible generics information
    • Constructor Detail

      • BeanDescription

        protected BeanDescription(JavaType type)
    • Method Detail

      • getType

        public JavaType getType()
        Method for accessing declared type of bean being introspected, including full generic type information (from declaration)
      • getBeanClass

        public Class<?> getBeanClass()
      • isRecordType

        public boolean isRecordType()
        Since:
        2.15
      • isNonStaticInnerClass

        public boolean isNonStaticInnerClass()
        Since:
        2.9
      • getClassInfo

        public abstract AnnotatedClass getClassInfo()
        Method for accessing low-level information about Class this item describes.
      • getObjectIdInfo

        public abstract ObjectIdInfo getObjectIdInfo()
        Accessor for getting information about Object Id expected to be used for this POJO type, if any.
      • hasKnownClassAnnotations

        public abstract boolean hasKnownClassAnnotations()
        Method for checking whether class being described has any annotations recognized by registered annotation introspector.
      • getClassAnnotations

        public abstract Annotations getClassAnnotations()
        Method for accessing collection of annotations the bean class has.
      • findProperties

        public abstract List<BeanPropertyDefinition> findProperties()
        Returns:
        Ordered Map with logical property name as key, and matching getter method as value.
      • getIgnoredPropertyNames

        public abstract Set<String> getIgnoredPropertyNames()
      • findBackReferences

        public abstract List<BeanPropertyDefinition> findBackReferences()
        Method for locating all back-reference properties (setters, fields) bean has
        Since:
        2.9
      • getConstructors

        public abstract List<AnnotatedConstructor> getConstructors()
        Helper method that will return all non-default constructors (that is, constructors that take one or more arguments) this class has.
      • getConstructorsWithMode

        public abstract List<AnnotatedAndMetadata<AnnotatedConstructor,com.fasterxml.jackson.annotation.JsonCreator.Mode>> getConstructorsWithMode()
        Method similar to getConstructors() except will also introspect JsonCreator.Mode and filter out ones marked as not applicable and include mode (or lack thereof) for remaining constructors.

        Note that no other filtering (regarding visibility or other annotations) is performed

        Since:
        2.13
      • getFactoryMethods

        public abstract List<AnnotatedMethod> getFactoryMethods()
        Helper method that will check all static methods of the bean class that seem like factory methods eligible to be used as Creators. This requires that the static method:
        1. Returns type compatible with bean type (same or subtype)
        2. Is recognized from either explicit annotation (usually @JsonCreator OR naming: names valueOf() and fromString() are recognized but only for 1-argument factory methods, and in case of fromString() argument type must further be either String or CharSequence.
        Note that caller typically applies further checks for things like visibility.
        Returns:
        List of static methods considered as possible Factory methods
      • getFactoryMethodsWithMode

        public abstract List<AnnotatedAndMetadata<AnnotatedMethod,com.fasterxml.jackson.annotation.JsonCreator.Mode>> getFactoryMethodsWithMode()
        Method similar to getFactoryMethods() but will return JsonCreator.Mode metadata along with qualifying factory method candidates.
        Since:
        2.13
      • findDefaultConstructor

        public abstract AnnotatedConstructor findDefaultConstructor()
        Method that will locate the no-arg constructor for this class, if it has one, and that constructor has not been marked as ignorable.
      • getPotentialCreators

        public abstract PotentialCreators getPotentialCreators()
        Method that is replacing earlier Creator introspection access methods.
        Returns:
        Container for introspected Creator candidates, if any
        Since:
        2.18
      • findJsonKeyAccessor

        public AnnotatedMember findJsonKeyAccessor()
        Method for locating accessor (readable field, or "getter" method) that has JsonKey annotation, if any. If multiple ones are found, an error is reported by throwing IllegalArgumentException
        Since:
        2.12
      • findJsonValueAccessor

        public abstract AnnotatedMember findJsonValueAccessor()
        Method for locating accessor (readable field, or "getter" method) that has JsonValue annotation, if any. If multiple ones are found, an error is reported by throwing IllegalArgumentException
        Since:
        2.9
      • findAnySetterAccessor

        public abstract AnnotatedMember findAnySetterAccessor()
        Method used to locate a mutator (settable field, or 2-argument set method) of introspected class that implements JsonAnySetter. If no such mutator exists null is returned. If more than one are found, an exception is thrown. Additional checks are also made to see that method signature is acceptable: needs to take 2 arguments, first one String or Object; second any can be any type.
        Since:
        2.9
      • findPropertyInclusion

        public abstract com.fasterxml.jackson.annotation.JsonInclude.Value findPropertyInclusion(com.fasterxml.jackson.annotation.JsonInclude.Value defValue)
        Method for finding annotation-indicated inclusion definition (if any); possibly overriding given default value.

        NOTE: does NOT use global inclusion default settings as the base, unless passed as `defValue`.

        Since:
        2.7
      • findExpectedFormat

        public abstract com.fasterxml.jackson.annotation.JsonFormat.Value findExpectedFormat()
        Method for checking what is the expected format for POJO, as defined by defaults and possible annotations. Note that this may be further refined by per-property annotations.
        Since:
        2.17
      • findExpectedFormat

        @Deprecated
        public com.fasterxml.jackson.annotation.JsonFormat.Value findExpectedFormat(com.fasterxml.jackson.annotation.JsonFormat.Value defValue)
        Deprecated. Since 2.17 use findExpectedFormat()
        Since:
        2.1
      • findSerializationConverter

        public abstract Converter<Object,Object> findSerializationConverter()
        Method for finding Converter used for serializing instances of this class.
        Since:
        2.2
      • findDeserializationConverter

        public abstract Converter<Object,Object> findDeserializationConverter()
        Method for finding Converter used for serializing instances of this class.
        Since:
        2.2
      • findClassDescription

        public String findClassDescription()
        Accessor for possible description for the bean type, used for constructing documentation.
        Since:
        2.7
      • findPOJOBuilder

        public abstract Class<?> findPOJOBuilder()
        Method for checking if the POJO type has annotations to indicate that a builder is to be used for instantiating instances and handling data binding, instead of standard bean deserializer.
      • findPOJOBuilderConfig

        public abstract JsonPOJOBuilder.Value findPOJOBuilderConfig()
        Method for finding configuration for POJO Builder class.
      • instantiateBean

        public abstract Object instantiateBean(boolean fixAccess)
        Method called to create a "default instance" of the bean, currently only needed for obtaining default field values which may be used for suppressing serialization of fields that have "not changed".
        Parameters:
        fixAccess - If true, method is allowed to fix access to the default constructor (to be able to call non-public constructor); if false, has to use constructor as is.
        Returns:
        Instance of class represented by this descriptor, if suitable default constructor was found; null otherwise.
      • findDefaultViews

        public abstract Class<?>[] findDefaultViews()
        Method for finding out if the POJO specifies default view(s) to use for properties, considering both per-type annotations and global default settings.
        Since:
        2.9

Copyright © 2008–2024 FasterXML. All rights reserved.