[kotlin-client][jackson] Add support for unknown default enum value (#17404)

* [kotlin-client][jackson] Enable @JsonEnumDefaultValue

* Update samples
This commit is contained in:
ken_tunc 2023-12-27 01:36:44 +09:00 committed by GitHub
parent e20466bffe
commit 1105759a6f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
45 changed files with 74 additions and 16 deletions

View File

@ -6,3 +6,4 @@ additionalProperties:
serializationLibrary: jackson serializationLibrary: jackson
artifactId: kotlin-petstore-jackson artifactId: kotlin-petstore-jackson
enumPropertyNaming: UPPERCASE enumPropertyNaming: UPPERCASE
enumUnknownDefaultCase: "true"

View File

@ -7,6 +7,9 @@ import com.squareup.moshi.Json
import com.squareup.moshi.JsonClass import com.squareup.moshi.JsonClass
{{/moshi}} {{/moshi}}
{{#jackson}} {{#jackson}}
{{#enumUnknownDefaultCase}}
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
{{/enumUnknownDefaultCase}}
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
{{#discriminator}} {{#discriminator}}
import com.fasterxml.jackson.annotation.JsonSubTypes import com.fasterxml.jackson.annotation.JsonSubTypes
@ -114,7 +117,7 @@ import {{packageName}}.infrastructure.ITransformForStorage
@SerializedName(value = {{#lambda.doublequote}}{{{value}}}{{/lambda.doublequote}}) {{&name}}({{{value}}}){{^-last}},{{/-last}}{{#-last}};{{/-last}} @SerializedName(value = {{#lambda.doublequote}}{{{value}}}{{/lambda.doublequote}}) {{&name}}({{{value}}}){{^-last}},{{/-last}}{{#-last}};{{/-last}}
{{/gson}} {{/gson}}
{{#jackson}} {{#jackson}}
@JsonProperty(value = {{#lambda.doublequote}}{{{value}}}{{/lambda.doublequote}}) {{&name}}({{{value}}}){{^-last}},{{/-last}}{{#-last}};{{/-last}} @JsonProperty(value = {{#lambda.doublequote}}{{{value}}}{{/lambda.doublequote}}) {{#enumUnknownDefaultCase}}{{#-last}}@JsonEnumDefaultValue {{/-last}}{{/enumUnknownDefaultCase}}{{&name}}({{{value}}}){{^-last}},{{/-last}}{{#-last}};{{/-last}}
{{/jackson}} {{/jackson}}
{{#kotlinx_serialization}} {{#kotlinx_serialization}}
@SerialName(value = {{#lambda.doublequote}}{{{value}}}{{/lambda.doublequote}}) {{&name}}({{{value}}}){{^-last}},{{/-last}}{{#-last}};{{/-last}} @SerialName(value = {{#lambda.doublequote}}{{{value}}}{{/lambda.doublequote}}) {{&name}}({{{value}}}){{^-last}},{{/-last}}{{#-last}};{{/-last}}

View File

@ -28,6 +28,9 @@ import kotlinx.datetime.Instant
import java.util.UUID import java.util.UUID
{{/gson}} {{/gson}}
{{#jackson}} {{#jackson}}
{{#enumUnknownDefaultCase}}
import com.fasterxml.jackson.databind.DeserializationFeature
{{/enumUnknownDefaultCase}}
import com.fasterxml.jackson.databind.ObjectMapper import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.databind.SerializationFeature import com.fasterxml.jackson.databind.SerializationFeature
import com.fasterxml.jackson.annotation.JsonInclude import com.fasterxml.jackson.annotation.JsonInclude
@ -104,6 +107,9 @@ import java.util.concurrent.atomic.AtomicLong
val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper() val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper()
.findAndRegisterModules() .findAndRegisterModules()
.setSerializationInclusion(JsonInclude.Include.NON_ABSENT) .setSerializationInclusion(JsonInclude.Include.NON_ABSENT)
{{#enumUnknownDefaultCase}}
.configure(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_USING_DEFAULT_VALUE, true)
{{/enumUnknownDefaultCase}}
.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false) .configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false)
{{/jackson}} {{/jackson}}
{{#kotlinx_serialization}} {{#kotlinx_serialization}}

View File

@ -193,7 +193,7 @@ class PetApi(basePath: kotlin.String = defaultBasePath, client: OkHttpClient = A
enum class StatusFindPetsByStatus(val value: kotlin.String) { enum class StatusFindPetsByStatus(val value: kotlin.String) {
@JsonProperty(value = "available") AVAILABLE("available"), @JsonProperty(value = "available") AVAILABLE("available"),
@JsonProperty(value = "pending") PENDING("pending"), @JsonProperty(value = "pending") PENDING("pending"),
@JsonProperty(value = "sold") SOLD("sold") @JsonProperty(value = "sold") SOLD("sold"),
} }
/** /**

View File

@ -1,5 +1,6 @@
package org.openapitools.client.infrastructure package org.openapitools.client.infrastructure
import com.fasterxml.jackson.databind.DeserializationFeature
import com.fasterxml.jackson.databind.ObjectMapper import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.databind.SerializationFeature import com.fasterxml.jackson.databind.SerializationFeature
import com.fasterxml.jackson.annotation.JsonInclude import com.fasterxml.jackson.annotation.JsonInclude
@ -10,5 +11,6 @@ object Serializer {
val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper() val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper()
.findAndRegisterModules() .findAndRegisterModules()
.setSerializationInclusion(JsonInclude.Include.NON_ABSENT) .setSerializationInclusion(JsonInclude.Include.NON_ABSENT)
.configure(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_USING_DEFAULT_VALUE, true)
.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false) .configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false)
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -56,12 +57,13 @@ data class Order (
/** /**
* Order Status * Order Status
* *
* Values: PLACED,APPROVED,DELIVERED * Values: PLACED,APPROVED,DELIVERED,UNKNOWN_DEFAULT_OPEN_API
*/ */
enum class Status(val value: kotlin.String) { enum class Status(val value: kotlin.String) {
@JsonProperty(value = "placed") PLACED("placed"), @JsonProperty(value = "placed") PLACED("placed"),
@JsonProperty(value = "approved") APPROVED("approved"), @JsonProperty(value = "approved") APPROVED("approved"),
@JsonProperty(value = "delivered") DELIVERED("delivered"); @JsonProperty(value = "delivered") DELIVERED("delivered"),
@JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue UNKNOWN_DEFAULT_OPEN_API("unknown_default_open_api");
} }
} }

View File

@ -18,6 +18,7 @@ package org.openapitools.client.models
import org.openapitools.client.models.Category import org.openapitools.client.models.Category
import org.openapitools.client.models.Tag import org.openapitools.client.models.Tag
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -58,12 +59,13 @@ data class Pet (
/** /**
* pet status in the store * pet status in the store
* *
* Values: AVAILABLE,PENDING,SOLD * Values: AVAILABLE,PENDING,SOLD,UNKNOWN_DEFAULT_OPEN_API
*/ */
enum class Status(val value: kotlin.String) { enum class Status(val value: kotlin.String) {
@JsonProperty(value = "available") AVAILABLE("available"), @JsonProperty(value = "available") AVAILABLE("available"),
@JsonProperty(value = "pending") PENDING("pending"), @JsonProperty(value = "pending") PENDING("pending"),
@JsonProperty(value = "sold") SOLD("sold"); @JsonProperty(value = "sold") SOLD("sold"),
@JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue UNKNOWN_DEFAULT_OPEN_API("unknown_default_open_api");
} }
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -1,5 +1,6 @@
package org.openapitools.client.infrastructure package org.openapitools.client.infrastructure
import com.fasterxml.jackson.databind.DeserializationFeature
import com.fasterxml.jackson.databind.ObjectMapper import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.databind.SerializationFeature import com.fasterxml.jackson.databind.SerializationFeature
import com.fasterxml.jackson.annotation.JsonInclude import com.fasterxml.jackson.annotation.JsonInclude
@ -10,5 +11,6 @@ object Serializer {
val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper() val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper()
.findAndRegisterModules() .findAndRegisterModules()
.setSerializationInclusion(JsonInclude.Include.NON_ABSENT) .setSerializationInclusion(JsonInclude.Include.NON_ABSENT)
.configure(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_USING_DEFAULT_VALUE, true)
.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false) .configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false)
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -62,7 +63,7 @@ data class Order (
@JsonProperty(value = "placed") placed("placed"), @JsonProperty(value = "placed") placed("placed"),
@JsonProperty(value = "approved") approved("approved"), @JsonProperty(value = "approved") approved("approved"),
@JsonProperty(value = "delivered") delivered("delivered"), @JsonProperty(value = "delivered") delivered("delivered"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -18,6 +18,7 @@ package org.openapitools.client.models
import org.openapitools.client.models.Category import org.openapitools.client.models.Category
import org.openapitools.client.models.Tag import org.openapitools.client.models.Tag
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -65,7 +66,7 @@ data class Pet (
@JsonProperty(value = "available") available("available"), @JsonProperty(value = "available") available("available"),
@JsonProperty(value = "pending") pending("pending"), @JsonProperty(value = "pending") pending("pending"),
@JsonProperty(value = "sold") sold("sold"), @JsonProperty(value = "sold") sold("sold"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -62,7 +63,7 @@ data class Order (
@JsonProperty(value = "placed") placed("placed"), @JsonProperty(value = "placed") placed("placed"),
@JsonProperty(value = "approved") approved("approved"), @JsonProperty(value = "approved") approved("approved"),
@JsonProperty(value = "delivered") delivered("delivered"), @JsonProperty(value = "delivered") delivered("delivered"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -18,6 +18,7 @@ package org.openapitools.client.models
import org.openapitools.client.models.Category import org.openapitools.client.models.Category
import org.openapitools.client.models.Tag import org.openapitools.client.models.Tag
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -64,7 +65,7 @@ data class Pet (
@JsonProperty(value = "available") available("available"), @JsonProperty(value = "available") available("available"),
@JsonProperty(value = "pending") pending("pending"), @JsonProperty(value = "pending") pending("pending"),
@JsonProperty(value = "sold") sold("sold"), @JsonProperty(value = "sold") sold("sold"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -1,5 +1,6 @@
package org.openapitools.client.infrastructure package org.openapitools.client.infrastructure
import com.fasterxml.jackson.databind.DeserializationFeature
import com.fasterxml.jackson.databind.ObjectMapper import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.databind.SerializationFeature import com.fasterxml.jackson.databind.SerializationFeature
import com.fasterxml.jackson.annotation.JsonInclude import com.fasterxml.jackson.annotation.JsonInclude
@ -10,5 +11,6 @@ object Serializer {
val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper() val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper()
.findAndRegisterModules() .findAndRegisterModules()
.setSerializationInclusion(JsonInclude.Include.NON_ABSENT) .setSerializationInclusion(JsonInclude.Include.NON_ABSENT)
.configure(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_USING_DEFAULT_VALUE, true)
.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false) .configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false)
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -62,7 +63,7 @@ data class Order (
@JsonProperty(value = "placed") placed("placed"), @JsonProperty(value = "placed") placed("placed"),
@JsonProperty(value = "approved") approved("approved"), @JsonProperty(value = "approved") approved("approved"),
@JsonProperty(value = "delivered") delivered("delivered"), @JsonProperty(value = "delivered") delivered("delivered"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -18,6 +18,7 @@ package org.openapitools.client.models
import org.openapitools.client.models.Category import org.openapitools.client.models.Category
import org.openapitools.client.models.Tag import org.openapitools.client.models.Tag
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -65,7 +66,7 @@ data class Pet (
@JsonProperty(value = "available") available("available"), @JsonProperty(value = "available") available("available"),
@JsonProperty(value = "pending") pending("pending"), @JsonProperty(value = "pending") pending("pending"),
@JsonProperty(value = "sold") sold("sold"), @JsonProperty(value = "sold") sold("sold"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -1,5 +1,6 @@
package org.openapitools.client.infrastructure package org.openapitools.client.infrastructure
import com.fasterxml.jackson.databind.DeserializationFeature
import com.fasterxml.jackson.databind.ObjectMapper import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.databind.SerializationFeature import com.fasterxml.jackson.databind.SerializationFeature
import com.fasterxml.jackson.annotation.JsonInclude import com.fasterxml.jackson.annotation.JsonInclude
@ -10,5 +11,6 @@ object Serializer {
val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper() val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper()
.findAndRegisterModules() .findAndRegisterModules()
.setSerializationInclusion(JsonInclude.Include.NON_ABSENT) .setSerializationInclusion(JsonInclude.Include.NON_ABSENT)
.configure(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_USING_DEFAULT_VALUE, true)
.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false) .configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false)
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -62,7 +63,7 @@ data class Order (
@JsonProperty(value = "placed") placed("placed"), @JsonProperty(value = "placed") placed("placed"),
@JsonProperty(value = "approved") approved("approved"), @JsonProperty(value = "approved") approved("approved"),
@JsonProperty(value = "delivered") delivered("delivered"), @JsonProperty(value = "delivered") delivered("delivered"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -18,6 +18,7 @@ package org.openapitools.client.models
import org.openapitools.client.models.Category import org.openapitools.client.models.Category
import org.openapitools.client.models.Tag import org.openapitools.client.models.Tag
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -65,7 +66,7 @@ data class Pet (
@JsonProperty(value = "available") available("available"), @JsonProperty(value = "available") available("available"),
@JsonProperty(value = "pending") pending("pending"), @JsonProperty(value = "pending") pending("pending"),
@JsonProperty(value = "sold") sold("sold"), @JsonProperty(value = "sold") sold("sold"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -1,5 +1,6 @@
package org.openapitools.client.infrastructure package org.openapitools.client.infrastructure
import com.fasterxml.jackson.databind.DeserializationFeature
import com.fasterxml.jackson.databind.ObjectMapper import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.databind.SerializationFeature import com.fasterxml.jackson.databind.SerializationFeature
import com.fasterxml.jackson.annotation.JsonInclude import com.fasterxml.jackson.annotation.JsonInclude
@ -10,5 +11,6 @@ object Serializer {
val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper() val jacksonObjectMapper: ObjectMapper = jacksonObjectMapper()
.findAndRegisterModules() .findAndRegisterModules()
.setSerializationInclusion(JsonInclude.Include.NON_ABSENT) .setSerializationInclusion(JsonInclude.Include.NON_ABSENT)
.configure(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_USING_DEFAULT_VALUE, true)
.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false) .configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false)
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -62,7 +63,7 @@ data class Order (
@JsonProperty(value = "placed") placed("placed"), @JsonProperty(value = "placed") placed("placed"),
@JsonProperty(value = "approved") approved("approved"), @JsonProperty(value = "approved") approved("approved"),
@JsonProperty(value = "delivered") delivered("delivered"), @JsonProperty(value = "delivered") delivered("delivered"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -18,6 +18,7 @@ package org.openapitools.client.models
import org.openapitools.client.models.Category import org.openapitools.client.models.Category
import org.openapitools.client.models.Tag import org.openapitools.client.models.Tag
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**
@ -65,7 +66,7 @@ data class Pet (
@JsonProperty(value = "available") available("available"), @JsonProperty(value = "available") available("available"),
@JsonProperty(value = "pending") pending("pending"), @JsonProperty(value = "pending") pending("pending"),
@JsonProperty(value = "sold") sold("sold"), @JsonProperty(value = "sold") sold("sold"),
@JsonProperty(value = "unknown_default_open_api") unknownDefaultOpenApi("unknown_default_open_api"); @JsonProperty(value = "unknown_default_open_api") @JsonEnumDefaultValue unknownDefaultOpenApi("unknown_default_open_api");
} }
} }

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**

View File

@ -16,6 +16,7 @@
package org.openapitools.client.models package org.openapitools.client.models
import com.fasterxml.jackson.annotation.JsonEnumDefaultValue
import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.annotation.JsonProperty
/** /**