From cf9a67abae7058ffcb44348e2e69ee54584d4640 Mon Sep 17 00:00:00 2001 From: Jonas Lagoni Date: Mon, 16 Oct 2023 10:33:59 +0200 Subject: [PATCH] chore: update migration guide (#1560) --- docs/migrations/version-1-to-2.md | 109 +++++++++++++++++++++++++----- 1 file changed, 92 insertions(+), 17 deletions(-) diff --git a/docs/migrations/version-1-to-2.md b/docs/migrations/version-1-to-2.md index a3d59b53dc..fba429ffd0 100644 --- a/docs/migrations/version-1-to-2.md +++ b/docs/migrations/version-1-to-2.md @@ -1,10 +1,10 @@ # Migration from v1 to v2 -This document contains all the breaking changes and migrations guidelines for adapting your code to the new version. +This document contains all the breaking changes and migration guidelines for adapting your code to the new version. -## Using preferred ids over anonymous ids +## Using preferred IDs over anonymous IDs -If you use _allOf_, and properties need to be merged, Modelina is now using preferred ids over anonymous ids. That means if a property has an id/title other than _anonymous_schema_ in one of the schemas in a _allOf_, it will use the non-anonymous id/title. +If you use _allOf_, and properties need to be merged, Modelina is now using preferred IDs over anonymous IDs. That means if a property has an id/title other than _anonymous_schema_ in one of the schemas in a _allOf_, it will use the non-anonymous id/title. Example: @@ -138,7 +138,7 @@ This example will generate a model for `Cat` and `Dog` where `PetType` is a shar ## Optional properties in Kotlin -In Kotlin, if property is not `required` in JSON Schema, it will be nullable in Kotlin with default value `null`. +In Kotlin, if the property is not `required` in JSON Schema, it will be nullable with the default value `null`. ```yaml Response: @@ -153,7 +153,7 @@ Response: additionalProperties: false ``` -will generate +will generate: ```kotlin data class Response( @@ -162,6 +162,38 @@ data class Response( ) ``` +## Optional properties in Java +In Java, if the property is not `required` in JSON Schema, it should use nullable types instead of primitive. + +```yaml +Response: + type: object + properties: + result: + type: number + message: + type: number + required: + - result + additionalProperties: false + +``` + +Will now generate: + +```java +public class Response { + private double result; + private Double message; + + public double getResult() { return this.result; } + public void setResult(double result) { this.result = result; } + + public Double getMessage() { return this.message; } + public void setMessage(Double message) { this.message = message; } +} +``` + ## Interface for objects in oneOf for Java In Java, if a oneOf includes objects, there will be created an interface. All the classes that are part of the oneOf, implements the interface. The Jackson preset includes support for unions by setting @JsonTypeInfo and @JsonSubTypes annotations. @@ -265,38 +297,81 @@ public class Truck implements Vehicle { public void setAdditionalProperties(Map additionalProperties) { this.additionalProperties = additionalProperties; } } ``` +# OpenAPI inputs now generate parameters as models +For a given OpenAPI input, it now generates [parameter models on top of the payload models](https://github.com/asyncapi/modelina/pull/1498) as the default behavior. + +# `renderCompleteModel` and `render` now use object arguments +As parameters grow, regular arguments become cumbersome, so we are starting to [switch over to using object arguments](https://github.com/asyncapi/modelina/pull/1505). + +This means that the following functions are going to change from: + +```ts +generator.renderCompleteModel( + constrainedModel, + inputModel, + completeOptions, + options +); + +generator.render( + constrainedModel, + inputModel, + options +); +``` + +To +```ts +generator.renderCompleteModel({ + constrainedModel, + inputModel, + completeOptions, + options +}); + +generator.render({ + constrainedModel, + inputModel, + options +}); +``` # Nullable models -Each [meta model](../internal-model.md) up until now where not able to be marked as nullable, but now they can be through `isNullable`. Here are the different outputs and how they now apply nullable types. +Each [meta model](../internal-model.md) up until now was not able to be marked as nullable, but now they can be through `isNullable`. Here are the different outputs and how they now apply nullable types. -### TypeScript +## TypeScript Across all models, if they are nullable they will get the union `x | null`. -### JavaScript +## JavaScript Is not affected by this change. -### C# +## C# Is not affected by this change. -### Java -With this update, Float, Integer and Boolean meta models are rendered between their primitive types (for example `float`) and wrapper classes (for example `Float`) for nullable. +## Java +With this update, Float, Integer, and Boolean meta models are rendered between their primitive types (for example `float`) and wrapper classes (for example `Float`) for nullable. + +[`Double` now also respects being nullable](https://github.com/asyncapi/modelina/pull/1439). -### Kotlin +## Kotlin Is not affected by this change. -### Rust +## Rust Is not affected by this change. -### Python +## Python Is not affected by this change. -### Go +## Go Is not affected by this change. -### Dart +## Dart Is not affected by this change. -### C++ +## C++ Is not affected by this change. + +# Upgrading to Node v18 +[As Node v14 is unmaintained we have upgraded to use Node v18.](https://github.com/asyncapi/modelina/pull/1422)