All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
4.22.0 - 2022-01-10
- Introduce support for
SchemaVersion.DRAFT_2020_12
- Replace
log4j
test dependency withlogback
(still only test dependency)
- Enable usage under JDK11 (by adjusting usage of
reflections
, in order to allow finding classes in dependencies/jar)
- Update
reflections
runtime dependency from 0.9.12 to 0.10.2
4.21.0 - 2021-12-03
- prevent mixing of
type: null
withconst
/enum
in order to avoid validation error whenconst
/enum
does not includenull
- default
ObjectMapper
when none is given inSchemaGeneratorConfigBuilder
constructor now enablesJsonWriteFeature.WRITE_NUMBERS_AS_STRINGS
- Consider
@JsonProperty.value
override for methods - Look-up
"description"
for methods (if included) based on@JsonPropertyDescription
- Consider
@JsonProperty(access = Access.READ_ONLY)
when determining whether a field/method should be marked asreadOnly
- Consider
@JsonProperty(access = Access.WRITE_ONLY)
when determining whether a field/method should be marked aswriteOnly
- Introduce
JacksonOption.INCLUDE_ONLY_JSONPROPERTY_ANNOTATED_METHODS
to enable easy inclusion of annotated non-getter methods (typically in combination with the generalOption.FIELDS_DERIVED_FROM_ARGUMENTFREE_METHODS
andOption.NONSTATIC_NONVOID_NONGETTER_METHODS
)
- Ignore getter methods when their associated field is being ignored (according to various Jackson annotations)
- Ignore methods when they or their associated field are marked as
@JsonBackReference
4.20.0 - 2021-09-04
- Support for
null
values in collections/containers/arrays - New opt-in
Option.NULLABLE_ARRAY_ITEMS_ALLOWED
for enabling the respective "NullableCheck" to be considered for items in a field's array value or a method' array return value
- Consider
@ArraySchema(schema = @Schema(nullable = true))
if the newOption.NULLABLE_ARRAY_ITEMS_ALLOWED
is enabled
4.19.0 - 2021-09-02
- Support
readOnly
andwriteOnly
keywords
- subtype resolution now also respects
@JsonTypeInfo
annotation on common interface (and not just common super class)
- Mark a subschema as
readOnly
orwriteOnly
based on a field or method's@Schema.accessMode
4.18.0 - 2021-03-21
- Increase of Jackson dependency version to 2.12.1
- Include
java.net.URI
in handling ofOption.ADDITIONAL_FIXED_TYPES
.
- New
JacksonOption.RESPECT_JSONPROPERTY_REQUIRED
to set a field as "required" based on@JsonProperty
annotations
- Replace deprecated Jackson API usage, resulting in MINIMUM Jackson version 2.12.0
4.17.0 - 2020-12-24
- Initial implementation (initial features are equivalent to
jsonschema-module-javax-validation
)
- Support for new
jakarta.validation
module
4.16.0 - 2020-09-25
- New
Option.ENUM_KEYWORD_FOR_SINGLE_VALUES
to produce"enum": ["A"]
instead of"const": "A"
if there is only one allowed value.
4.15.1 - 2020-09-15
- Missing parentheses on void argument-free methods that don't start with "get" or "is" when enabling
Option.FIELDS_DERIVED_FROM_ARGUMENTFREE_METHODS
4.15.0 - 2020-09-15
- New
Option.EXTRA_OPEN_API_FORMAT_VALUES
to support automatic inclusion of"format"
values for certain simple/fixed types
- Support picking up annotations on a (top-level) generic
Optional
parameter (e.g.Optional<@Size(min=2) String>
)
4.14.0 - 2020-08-02
- Entries in
SchemaKeyword
enum for"not"
,"minProperties"
,"maxProperties"
(without further handling)
- Make use of new
SchemaKeyword
enum entries instead of hard-coded strings (no change in behaviour)
- Support for including classes via glob patterns in
<classNames>
and<packageNames>
(in addition to absolute paths) - Support for excluding classes via absolute paths or glob patterns in new
<excludeClassNames>
- Explicitly include dependencies of supported generator modules that they expect to be provided
- Avoid generating the same schema multiple times if there are overlaps between entries in
<classNames>
and/or<packageNames>
4.13.0 - 2020-06-27
- Possibility to configure
SchemaDefinitionNamingStrategy
viaconfigBuilder.forTypesInGeneral().withDefinitionNamingStrategy()
- Explicit
DefaultSchemaDefinitionNamingStrategy
that is being applied if no otherSchemaDefinitionNamingStrategy
is being configured - New
Option.FIELDS_DERIVED_FROM_ARGUMENTFREE_METHODS
to allow deriving fields from getter methods
- Determine names/keys of subschemas in
definitions
/$defs
through configurableSchemaDefinitionNamingStrategy
- Default property sort order to consider property name when differentiating fields and methods (now that methods may have field-like names)
- For multiple definitions for the same type, they might be unnecessarily treated as having conflicting definition names requiring resolution
- Obsolete
TypeContext.getSchemaDefinitionName()
- Initial implementation of
Swagger2Module
for deriving schema attributes from OpenAPI@Schema
annotations.
- Support for new
jsonschema-module-swagger-2
4.12.2 - 2020-06-10
- Performance: Cache looked-up getter in
FieldScope.findGetter()
- Performance: Cache looked-up field in
MethodScope.findGetterField()
- Collecting all classes from a given
<packageName>
even if it contains classes whose super types are not included
4.12.1 - 2020-05-28
- Setting correct contextual classpath for class/package look-up via reflections
4.12.0 - 2020-05-10
- New
SchemaGeneratorGeneralConfigPart.withPropertySorter()
exposing the sorting logic of an object schema's properties
- New
JacksonOption.RESPECT_JSONPROPERTY_ORDER
to sort properties in an object's schema based on@JsonPropertyOrder
annotations - New
JacksonOption.IGNORE_PROPERTY_NAMING_STRATEGY
to skip the adjustment of property names based on@JsonNaming
annotations
- Consider
@JsonNaming
annotations to alter the names of contained fields according to the specifiedPropertyNamingStrategy
4.11.1 - 2020-04-30
- Maven plugin is unable to resolve runtime dependencies (#95)
4.11.0 - 2020-04-28
- New
Option.MAP_VALUES_AS_ADDITIONAL_PROPERTIES
to includeadditionalProperties
with a schema for eachMap<K, V>
's value typeV
- New
Option.DEFINITION_FOR_MAIN_SCHEMA
to allow moving main/target schema intodefinitions
/$defs
- New
Option.PLAIN_DEFINITION_KEYS
to ensure keys indefinitions
/$defs
adhere to the reduced set of allowed characters expected by OpenAPI - New
SchemaGenerator.buildMultipleSchemaDefinitions()
allowing to generate JSON Schema elements (e.g. for building an OpenAPI description)
- Skip fields for which
isFakeContainerItemScope()
returnstrue
, when fulfilling value collection forOption.VALUES_FROM_CONSTANT_FIELDS
- Treat
Byte
/byte
as"type": "string"
and not as"type": "integer"
by default
- Initial implementation
- Support schema generation from one or multiple classes
- Support schema generation for all classes in one or multiple packages
- Allow configuration of target schema version
- Allow configuration of
OptionPreset
(also allowing forNONE
) - Allow configuration of individual
Option
s to be enabled/disabled - Allow configuration of standard modules by name, with possible list of module options
- Allow configuration of custom modules by class name
4.10.0 - 2020-04-12
- Official support for Draft 6 (via new
SchemaVersion.DRAFT_6
) - New
Option.INLINE_ALL_SCHEMAS
to enforce nodefinitions
/$defs
to be produced (throwing exception if there is at least one circular reference) - Offering also
SchemaGenerationContext.createStandardDefinition(FieldScope, CustomPropertyDefinitionProvider)
- Offering also
SchemaGenerationContext.createStandardDefinition(MethodScope, CustomPropertyDefinitionProvider)
- Alternative
SchemaGenerationConfigPart.withInstanceAttributeOverride(InstanceAttributeOverrideV2)
with access toSchemaGenerationContext
- Enhance
Option.ALLOF_CLEANUP_AT_THE_END
to also reduceallOf
if multiple parts have the same attributes but with equal values (except forif
tags) - Providing access to the
SchemaGenerationContext
when invokingTypeAttributeOverrideV2
(potentially BREAKING change in case of lambda usage)
SchemaGenerationConfigPart.withInstanceAttributeOverride(InstanceAttributeOverride)
without access toSchemaGenerationContext
InstanceAttributeOverride
interface without access toSchemaGenerationContext
TypeAttributeOverride
interface with only access toSchemaGenerationConfig
and notSchemaGenerationContext
- Ambiguous
SchemaGeneratorConfigBuilder.with(CustomDefinitionProviderV2)
- Ambiguous and outdated
SchemaGeneratorConfigBuilder.with(TypeAttributeOverride)
- New
JacksonOption.FLATTENED_ENUMS_FROM_JSONPROPERTY
to allow enum serialization based on each constant's@JsonProperty
value
4.9.0 - 2020-04-02
- Convenience constructors on
SchemaGeneratorConfigBuilder
without explicitObjectMapper
instance being expected - Convenience methods on
FieldScope
/MethodScope
for accessing (first level) container item annotations:getContainerItemAnnotation()
andgetContainerItemAnnotationConsideringFieldAndGetter()
MethodScope.getAnnotation()
now also considers annotations directly on return type (when no matching annotation was found on the method itself)
- Attributes set in custom property definitions should not be overridden by other configurations (except for explicit attribute overrides)
- Consider (first level) container item annotations (e.g.
List<@Size(min = 3) String>
)
4.8.1 - 2020-03-31
- Include parent
pom.xml
when publishing release
- Error when encountering container/collection property
4.8.0 - 2020-03-30
- Support for custom definitions in the scope of a particular field/method via
SchemaGeneratorConfigPart.withCustomDefinitionProvider()
- Ability to opt-out of normal "attribute collection" for custom definitions through new
CustomDefinition
constructor parameters
- Consolidate
anyOf
entries that only contain ananyOf
themselves into the outeranyOf
(mostly relevant for nullable entries with subtypes) - If a field/method is of a container type: apply the per-property configurations on its items; with
MemberScope.isFakeContainerItemScope()
flag
- Should consider per-type attributes even on inline custom definitions
- Use less strict
anyOf
instead ofoneOf
when indicating that a sub-schema may be of"type": "null"
com.fasterxml.jackson.core
:jackson-core
/jackson-databind
from2.10.2
to2.10.3
- Remove dependencies to
log4j
implementation (onlyslf4j-api
remains)
- Look-up subtypes according to
@JsonTypeInfo
and@JsonSubTypes
annotations per-type or overridden per-property:- Considering
@JsonTypeInfo.include
with valuesAs.PROPERTY
,As.EXISTING_PROPERTY
,As.WRAPPER_ARRAY
,As.WRAPPER_OBJECT
- Considering
@JsonTypeInfo.use
with valuesId.NAME
(from@JsonTypeName
) andId.CLASS
- Considering
- New
JacksonOption.SKIP_SUBTYPE_LOOKUP
for disabling the new look-up of subtypes (i.e. to regain previous behaviour) if required - New
JacksonOption.IGNORE_TYPE_INFO_TRANSFORM
for disabling addition of extra property or wrapping in an array/object according to@JsonTypeInfo
4.7.0 - 2020-03-20
- Support for multiple target type overrides at once per field/method
- Support for "$id" property via
SchemaGeneratorGeneralConfigPart.withIdResolver()
- Support for "$anchor" property via
SchemaGeneratorGeneralConfigPart.withAnchorResolver()
- Allow for multiple types with the same name (but different package) instead of picking one at random
- Allow for multiple definitions for the same type (e.g. in case of a custom definition wrapping the standard definition)
- Configuration option for single target type override
- Look-up of single target type override from configuration
- Ignore/exclude properties marked with
@JsonBackReference
4.6.0 - 2020-03-15
- Explicit indication of targeted JSON Schema version (for now: Draft 7 or 2019-09)
- Support for renamed keywords between Draft versions through new
SchemaKeyword
enum (replacing staticSchemaConstants
interface) - Support for
$ref
alongside other attributes (from Draft 2019-09 onwards) thereby reducing number ofallOf
elements - Introduce
Option.ALLOF_CLEANUP_AT_THE_END
(also included in all standardOptionPreset
s) for toggling-off this improvement if not desired
- Reduce number of
allOf
elements in generated schema when contained schema parts are distinct (and in case of Draft 7: don't contain$ref
)
SchemaConstants
interface containing staticString
constants for tag names/values (in favour of version-awareSchemaKeyword
enum)- Internal
AttributeCollector
API without generation context as parameter SchemaGeneratorConfigBuilder
constructors without explicit JSON Schema version indication
com.fasterxml.jackson.core
:jackson-core
/jackson-databind
from2.10.0
to2.10.2
com.fasterxml
:classmate
from1.5.0
to1.5.2
- Optional:
org.slf4j
:slf4j-api
from1.7.26
to1.7.30
- Optional:
org.apache.logging.log4j
:log4j-api
/log4j-core
/log4j-slf4j-impl
from2.11.2
to2.13.0
4.5.0 - 2020-03-05
- Expose
SchemaGenerationContext.createDefinitionReference()
to custom definitions to enable circular references within - Expose
SchemaGenerationContext.createStandardDefinitionReference()
to custom definitions to enable circular references within
- New
JacksonOption.FLATTENED_ENUMS_FROM_JSONVALUE
for considering@JsonValue
annotations on enums, similar toOption.FLATTENED_ENUMS
4.4.0 - 2020-03-02
- Enable declaration of subtypes through
withSubtypeResolver(SubtypeResolver)
onforTypesInGeneral()
(#24)
- Move custom definitions and type attribute overrides into
forTypesInGeneral()
(while preserving delegate setters on config builder)
4.3.0 - 2020-02-28
- Limit collected type attributes by declared "type" (prior to any
TypeAttributeOverride
!)
- Not declare any "type" for
Object.class
by default
4.2.0 - 2020-02-27
- Support for "additionalProperties" property via
SchemaGeneratorTypeConfigPart.withAdditionalPropertiesResolver()
- Support for "patternProperties" property via
SchemaGeneratorTypeConfigPart.withPatternPropertiesResolver()
- Introduce new
Option.FORBIDDEN_ADDITIONAL_PROPERTIES_BY_DEFAULT
for more convenient usage - Offer
TypeScope.getTypeParameterFor()
andTypeContext.getTypeParameterFor()
convenience methods
- Possible exceptions in case of encountered collections without specific type parameters
4.1.0 - 2020-02-18
- New
Option.FLATTENED_ENUMS_FROM_TOSTRING
, usingtoString()
instead ofname()
as perOption.FLATTENED_ENUMS
4.0.2 - 2020-01-30
- Avoid further characters in definition keys that are not URI-compatible (#19)
4.0.1 - 2020-01-29
- Avoid white-spaces in definition keys
4.0.0 - 2020-01-03
- Extended API for defining context independent collection of schema attributes (for array/collection items that are not directly under a member)
- BREAKING CHANGE:
TypeAttributeOverride
's second parameter is now the newTypeScope
wrapper instead of just aResolvedType
- Look-up descriptions from
@JsonClassDescription
via newforTypesInGeneral()
API
- Look-up titles and descriptions from
@ApiModel
via newforTypesInGeneral()
API
3.5.0 - 2020-01-01
CustomDefinitionProviderV2
with access toSchemaGenerationContext
, e.g. to allow continuing normal schema generation for nested properties
CustomDefinitionProvider
receiving only theTypeContext
as parameter
- Possible
IllegalAccess
when loading constant values should just be ignored
3.4.1 - 2019-12-30
- Collected attributes should also be applied to container types (Issue #15)
3.4.0 - 2019-11-29
- Introduce convenience function
MemberScope.getAnnotationConsideringFieldAndGetter(Class)
- Optionally provide a field/method's "title" as per
@ApiModel(value = ...)
- Allow to ignore the general
@ApiModel(description = ...)
when populating a field/method's "description"
3.3.0 - 2019-10-25
- Increase dependency version for jackson-databind (and jackson-core) to resolve security alerts.
- Avoid unnecessary quotes when representing constant string values (due to changed behaviour in jackson >=2.10.0)
3.2.0 – 2019-09-01
- In
SchemaGenerator.generateSchema(Type)
also allow passing type parameters viaSchemaGenerator.generateSchema(Type, Type...)
. - Support for "required" property via
SchemaGeneratorConfigPart.withRequiredCheck()
(PR #5). - Support for "default" property via
SchemaGeneratorConfigPart.withDefaultResolver()
(PR #5). - Support for "pattern" property via
SchemaGeneratorConfigPart.withStringPatternResolver()
(Issue #9).
- Option for treating not-nullable fields as "required" in their parent type
- Option for treating not-nullable methods as "required" in their parent type
- Indicate a string's "format" to be "email" if
@Email
is present - Option for returning "idn-email" instead of "email" as "format" if
@Email
is present - Indicate a string's "pattern" according to regular expressions on
@Pattern
or@Email
(ignoring specified flags) - Option for enabling the inclusion of "pattern" expressions (they are excluded by default)
- Allow filtering applicable annotations by their declared validation
groups
viaJavaxValidationModule.forValidationGroups()
3.1.0 – 2019-06-18
- Use
Class.getTypeName()
instead ofClass.getName()
inTypeContext.getFullTypeDescription()
.
- In
TypeContext.resolve(Type)
also allow passing type parameters viaTypeContext.resolve(Type, Type...)
.
NullPointerException
onMemberScope
representingvoid
methods.IndexOutOfBoundsException
when determining container item type of rawCollection
.
3.0.0 – 2019-06-10
- Simplify configuration API to be based on
FieldScope
/MethodScope
respectively. - Consolidate some utility functions into
FieldScope
/MethodScope
. - Consolidate logic for determining whether a type is a container into
TypeContext
. - Consolidate naming logic for schema "definitions" into
TypeContext
. - Add
TypeContext
argument toCustomDefinitionProvider
interface. - Remove
SchemaGeneratorConfig
argument fromInstanceAttributeOverride
interface.
- Allow for sub-typing of
FieldScope
/MethodScope
andTypeContext
(in case offered configuration options are insufficient).
- Remove support for
Option.GETTER_ATTRIBUTES_FOR_FIELDS
andOption.FIELD_ATTRIBUTES_FOR_GETTERS
, rather let configurations/modules decide individually and avoid potential endless loop.
- Populate "description" as per
@JsonPropertyDescription
(falling-back on@JsonClassDescription
). - Apply alternative field names defined in
@JsonProperty
annotations. - Ignore fields that are deemed to be ignored according to various
jackson-annotations
(e.g.@JsonIgnore
,@JsonIgnoreType
,@JsonIgnoreProperties
) or are otherwise supposed to be excluded.
- Consider the same validation annotations on a getter method also for its field
- Consider the same validation annotations on a field also for its getter method
- Optionally override a field's property name with
@ApiModelProperty(name = ...)
- Optionally ignore a field/method if
@ApiModelProperty(hidden = true)
- Provide a field/method's "description" as per
@ApiModelProperty(value = ...)
or@ApiModel(description = ...)
- Indicate a number's (field/method) "minimum" (inclusive) according to
@ApiModelProperty(allowableValues = "range[...")
- Indicate a number's (field/method) "exclusiveMinimum" according to
@ApiModelProperty(allowableValues = "range(...")
- Indicate a number's (field/method) "maximum" (inclusive) according to
@ApiModelProperty(allowableValues = "range...]")
- Indicate a number's (field/method) "exclusiveMaximum" according to
@ApiModelProperty(allowableValues = "range...)")
- Indicate a field/method's "const"/"enum" as
@ApiModelProperty(allowableValues = ...)
(if it is not a numeric range declaration) - Consider the
@ApiModelProperty
annotation on a getter method also for its field - Consider the
@ApiModelProperty
annotation on a field also for its getter method
2.0.0 – 2019-06-07
- Removed type resolution and replaced it with
org.fasterxml:classmate
dependency. - Adjusting configuration API to use
classmate
references for types/fields/methods.
- Ignore complex constant values that may not be properly representable as JSON.
1.0.2 - 2019-05-30
- Increase dependency version for jackson-databind to resolve security alert.
1.0.1 - 2019-05-19
- Specified "test" scope for dependency on jsonassert.
1.0.0 - 2019-05-18
- Reflection-based JSON Schema Generator.
- Support of generics and the resolution of their type boundaries in the respective scope.
- Inclusion of any fields and public methods in a generated JSON Schema.
- Ability to define a fixed JSON Schema per type (e.g. for determining how to represent primitive types).
- Ability to customise various aspects of schema generation and assigned attributes.
- Concept of modules (e.g. for sub-libraries) to define a single entry-point for applying individual configurations.
- Standard enum of common configuration options.
- Specific handling of enums (two alternatives via standard options).
- Specific handling of optionals (two alternatives via standard options).
- Pre-defined sets of standard options to cover different use-cases and simplify library usage.
- Indicate a field/method to be nullable if
@Null
is present - Indicate a field/method to be not nullable if
@NotNull
,@NotEmpty
or@NotBlank
is present - Indicate an array's "minItems" according to
@Size
or@NotEmpty
- Indicate an array's "maxItems" according to
@Size
- Indicate a string's "minLength" according to
@Size
,@NotEmpty
or@NotBlank
- Indicate a string's "maxLength" according to
@Size
- Indicate a number's "minimum" (inclusive) according to
@Min
,@DecimalMin
or@PositiveOrZero
- Indicate a number's "exclusiveMinimum" according to
@DecimalMin
or@Positive
- Indicate a number's "maximum" (inclusive) according to
@Max
,@DecimalMax
or@NegativeOrZero
- Indicate a number's "exclusiveMaximum" according to
@DecimalMax
or@Negative