Skip to content

Commit 205514c

Browse files
author
Slavek Kabrda
authored
[Java][jersey2] Make (de)serialization work for oneOf models, add convenience and comparison methods (#6323)
1 parent 202d184 commit 205514c

File tree

4 files changed

+179
-0
lines changed

4 files changed

+179
-0
lines changed

modules/openapi-generator/src/main/resources/Java/libraries/jersey2/AbstractOpenApiSchema.mustache

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3,10 +3,13 @@
33
package {{invokerPackage}}.model;
44

55
import {{invokerPackage}}.ApiException;
6+
import java.util.Objects;
67
import java.lang.reflect.Type;
78
import java.util.Map;
89
import javax.ws.rs.core.GenericType;
910

11+
import com.fasterxml.jackson.annotation.JsonValue;
12+
1013
/**
1114
* Abstract class for oneOf,anyOf schemas defined in OpenAPI spec
1215
*/
@@ -39,6 +42,7 @@ public abstract class AbstractOpenApiSchema {
3942
*
4043
* @return an instance of the actual schema/object
4144
*/
45+
@JsonValue
4246
public Object getActualInstance() {return instance;}
4347

4448
/***
@@ -57,6 +61,46 @@ public abstract class AbstractOpenApiSchema {
5761
return schemaType;
5862
}
5963

64+
@Override
65+
public String toString() {
66+
StringBuilder sb = new StringBuilder();
67+
sb.append("class ").append(getClass()).append(" {\n");
68+
sb.append(" instance: ").append(toIndentedString(instance)).append("\n");
69+
sb.append(" isNullable: ").append(toIndentedString(isNullable)).append("\n");
70+
sb.append(" schemaType: ").append(toIndentedString(schemaType)).append("\n");
71+
sb.append("}");
72+
return sb.toString();
73+
}
74+
75+
/**
76+
* Convert the given object to string with each line indented by 4 spaces
77+
* (except the first line).
78+
*/
79+
private String toIndentedString(java.lang.Object o) {
80+
if (o == null) {
81+
return "null";
82+
}
83+
return o.toString().replace("\n", "\n ");
84+
}
85+
86+
public boolean equals(Object o) {
87+
if (this == o) {
88+
return true;
89+
}
90+
if (o == null || getClass() != o.getClass()) {
91+
return false;
92+
}
93+
AbstractOpenApiSchema a = (AbstractOpenApiSchema) o;
94+
return Objects.equals(this.instance, a.instance) &&
95+
Objects.equals(this.isNullable, a.isNullable) &&
96+
Objects.equals(this.schemaType, a.schemaType);
97+
}
98+
99+
@Override
100+
public int hashCode() {
101+
return Objects.hash(instance, isNullable, schemaType);
102+
}
103+
60104
/***
61105
* Is nullalble
62106
*

modules/openapi-generator/src/main/resources/Java/libraries/jersey2/oneof_model.mustache

Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,51 @@
11
import javax.ws.rs.core.GenericType;
22
import javax.ws.rs.core.Response;
3+
import java.io.IOException;
34
import java.util.ArrayList;
45
import java.util.HashMap;
56
import java.util.Map;
67

8+
import com.fasterxml.jackson.core.JsonParser;
9+
import com.fasterxml.jackson.core.JsonProcessingException;
10+
import com.fasterxml.jackson.databind.DeserializationContext;
11+
import com.fasterxml.jackson.databind.JsonNode;
12+
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
13+
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
14+
715
{{>additionalModelTypeAnnotations}}{{>generatedAnnotation}}{{>xmlAnnotation}}
16+
@JsonDeserialize(using={{classname}}.{{classname}}Deserializer.class)
817
public class {{classname}} extends AbstractOpenApiSchema{{#vendorExtensions.x-implements}}, {{{.}}}{{/vendorExtensions.x-implements}} {
18+
public static class {{classname}}Deserializer extends StdDeserializer<{{classname}}> {
19+
public {{classname}}Deserializer() {
20+
this({{classname}}.class);
21+
}
22+
23+
public {{classname}}Deserializer(Class<?> vc) {
24+
super(vc);
25+
}
26+
27+
@Override
28+
public {{classname}} deserialize(JsonParser jp, DeserializationContext ctxt) throws IOException, JsonProcessingException {
29+
JsonNode tree = jp.readValueAsTree();
30+
31+
int match = 0;
32+
Object deserialized = null;
33+
{{#oneOf}}
34+
try {
35+
deserialized = tree.traverse(jp.getCodec()).readValueAs({{{.}}}.class);
36+
match++;
37+
} catch (Exception e) {
38+
// deserialization failed, continue
39+
}
40+
{{/oneOf}}
41+
if (match == 1) {
42+
{{classname}} ret = new {{classname}}();
43+
ret.setActualInstance(deserialized);
44+
return ret;
45+
}
46+
throw new IOException(String.format("Failed deserialization for {{classname}}: %d classes match result, expected 1", match));
47+
}
48+
}
949

1050
// store a list of schema names defined in oneOf
1151
public final static Map<String, GenericType> schemas = new HashMap<String, GenericType>();
@@ -14,6 +54,13 @@ public class {{classname}} extends AbstractOpenApiSchema{{#vendorExtensions.x-im
1454
super("oneOf", {{#isNullable}}Boolean.TRUE{{/isNullable}}{{^isNullable}}Boolean.FALSE{{/isNullable}});
1555
}
1656

57+
{{#oneOf}}
58+
public {{classname}}({{{.}}} o) {
59+
super("oneOf", {{#isNullable}}Boolean.TRUE{{/isNullable}}{{^isNullable}}Boolean.FALSE{{/isNullable}});
60+
setActualInstance(o);
61+
}
62+
{{/oneOf}}
63+
1764
static {
1865
{{#oneOf}}
1966
schemas.put("{{{.}}}", new GenericType<{{{.}}}>() {

samples/client/petstore/java/jersey2-java7/src/main/java/org/openapitools/client/model/AbstractOpenApiSchema.java

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -14,10 +14,13 @@
1414
package org.openapitools.client.model;
1515

1616
import org.openapitools.client.ApiException;
17+
import java.util.Objects;
1718
import java.lang.reflect.Type;
1819
import java.util.Map;
1920
import javax.ws.rs.core.GenericType;
2021

22+
import com.fasterxml.jackson.annotation.JsonValue;
23+
2124
/**
2225
* Abstract class for oneOf,anyOf schemas defined in OpenAPI spec
2326
*/
@@ -50,6 +53,7 @@ public AbstractOpenApiSchema(String schemaType, Boolean isNullable) {
5053
*
5154
* @return an instance of the actual schema/object
5255
*/
56+
@JsonValue
5357
public Object getActualInstance() {return instance;}
5458

5559
/***
@@ -68,6 +72,46 @@ public String getSchemaType() {
6872
return schemaType;
6973
}
7074

75+
@Override
76+
public String toString() {
77+
StringBuilder sb = new StringBuilder();
78+
sb.append("class ").append(getClass()).append(" {\n");
79+
sb.append(" instance: ").append(toIndentedString(instance)).append("\n");
80+
sb.append(" isNullable: ").append(toIndentedString(isNullable)).append("\n");
81+
sb.append(" schemaType: ").append(toIndentedString(schemaType)).append("\n");
82+
sb.append("}");
83+
return sb.toString();
84+
}
85+
86+
/**
87+
* Convert the given object to string with each line indented by 4 spaces
88+
* (except the first line).
89+
*/
90+
private String toIndentedString(java.lang.Object o) {
91+
if (o == null) {
92+
return "null";
93+
}
94+
return o.toString().replace("\n", "\n ");
95+
}
96+
97+
public boolean equals(Object o) {
98+
if (this == o) {
99+
return true;
100+
}
101+
if (o == null || getClass() != o.getClass()) {
102+
return false;
103+
}
104+
AbstractOpenApiSchema a = (AbstractOpenApiSchema) o;
105+
return Objects.equals(this.instance, a.instance) &&
106+
Objects.equals(this.isNullable, a.isNullable) &&
107+
Objects.equals(this.schemaType, a.schemaType);
108+
}
109+
110+
@Override
111+
public int hashCode() {
112+
return Objects.hash(instance, isNullable, schemaType);
113+
}
114+
71115
/***
72116
* Is nullalble
73117
*

samples/client/petstore/java/jersey2-java8/src/main/java/org/openapitools/client/model/AbstractOpenApiSchema.java

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -14,10 +14,13 @@
1414
package org.openapitools.client.model;
1515

1616
import org.openapitools.client.ApiException;
17+
import java.util.Objects;
1718
import java.lang.reflect.Type;
1819
import java.util.Map;
1920
import javax.ws.rs.core.GenericType;
2021

22+
import com.fasterxml.jackson.annotation.JsonValue;
23+
2124
/**
2225
* Abstract class for oneOf,anyOf schemas defined in OpenAPI spec
2326
*/
@@ -50,6 +53,7 @@ public AbstractOpenApiSchema(String schemaType, Boolean isNullable) {
5053
*
5154
* @return an instance of the actual schema/object
5255
*/
56+
@JsonValue
5357
public Object getActualInstance() {return instance;}
5458

5559
/***
@@ -68,6 +72,46 @@ public String getSchemaType() {
6872
return schemaType;
6973
}
7074

75+
@Override
76+
public String toString() {
77+
StringBuilder sb = new StringBuilder();
78+
sb.append("class ").append(getClass()).append(" {\n");
79+
sb.append(" instance: ").append(toIndentedString(instance)).append("\n");
80+
sb.append(" isNullable: ").append(toIndentedString(isNullable)).append("\n");
81+
sb.append(" schemaType: ").append(toIndentedString(schemaType)).append("\n");
82+
sb.append("}");
83+
return sb.toString();
84+
}
85+
86+
/**
87+
* Convert the given object to string with each line indented by 4 spaces
88+
* (except the first line).
89+
*/
90+
private String toIndentedString(java.lang.Object o) {
91+
if (o == null) {
92+
return "null";
93+
}
94+
return o.toString().replace("\n", "\n ");
95+
}
96+
97+
public boolean equals(Object o) {
98+
if (this == o) {
99+
return true;
100+
}
101+
if (o == null || getClass() != o.getClass()) {
102+
return false;
103+
}
104+
AbstractOpenApiSchema a = (AbstractOpenApiSchema) o;
105+
return Objects.equals(this.instance, a.instance) &&
106+
Objects.equals(this.isNullable, a.isNullable) &&
107+
Objects.equals(this.schemaType, a.schemaType);
108+
}
109+
110+
@Override
111+
public int hashCode() {
112+
return Objects.hash(instance, isNullable, schemaType);
113+
}
114+
71115
/***
72116
* Is nullalble
73117
*

0 commit comments

Comments
 (0)