-
-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(schemaFormat): support AsyncAPI, OpenAPI and Json Schemas
- Loading branch information
Showing
200 changed files
with
9,564 additions
and
488 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
2 changes: 1 addition & 1 deletion
2
...n/java/com/asyncapi/v3/_0_0/jackson/model/channel/message/MessagePayloadDeserializer.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
2 changes: 1 addition & 1 deletion
2
...main/java/com/asyncapi/v3/_0_0/jackson/model/component/ComponentsSchemasDeserializer.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
66 changes: 0 additions & 66 deletions
66
asyncapi-core/src/main/java/com/asyncapi/v3/schema/MultiFormatSchema.java
This file was deleted.
Oops, something went wrong.
53 changes: 53 additions & 0 deletions
53
asyncapi-core/src/main/java/com/asyncapi/v3/schema/multiformat/AsyncAPIFormatSchema.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
package com.asyncapi.v3.schema.multiformat; | ||
|
||
import com.asyncapi.v3.schema.AsyncAPISchema; | ||
import com.fasterxml.jackson.annotation.JsonCreator; | ||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import lombok.EqualsAndHashCode; | ||
import org.jetbrains.annotations.NotNull; | ||
import org.jetbrains.annotations.Nullable; | ||
|
||
/** | ||
* The Multi Format Schema Object represents a schema definition. It differs from the {@link AsyncAPISchema} in that it supports | ||
* multiple schema formats or languages (e.g., JSON Schema, Avro, etc.). | ||
* | ||
* @see <a href="https://www.asyncapi.com/docs/reference/specification/v3.0.0#multiFormatSchemaObject">Multi Format Schema</a> | ||
* @see <a href="https://www.asyncapi.com/docs/reference/specification/v3.0.0#schemaObject">Schema</a> | ||
* @author Pavel Bodiachevskii | ||
* @version 3.0.0 | ||
*/ | ||
@EqualsAndHashCode(callSuper = true) | ||
public class AsyncAPIFormatSchema extends MultiFormatSchema<AsyncAPISchema> { | ||
|
||
public AsyncAPIFormatSchema(@NotNull AsyncAPISchema schema) { | ||
super(schema); | ||
} | ||
|
||
@JsonCreator(mode = JsonCreator.Mode.PROPERTIES) | ||
public AsyncAPIFormatSchema( | ||
@JsonProperty("schemaFormat") @Nullable String schemaFormat, | ||
@JsonProperty("schema") @NotNull AsyncAPISchema schema | ||
) { | ||
super(schemaFormat(schemaFormat), schema); | ||
} | ||
|
||
@Override | ||
public void setSchema(@NotNull AsyncAPISchema schema) { | ||
super.setSchema(schema); | ||
} | ||
|
||
@NotNull | ||
public AsyncAPISchema getSchema() { | ||
return super.getSchema(); | ||
} | ||
|
||
@NotNull | ||
private static String schemaFormat(@Nullable String schemaFormat) { | ||
if (schemaFormat == null || schemaFormat.isEmpty()) { | ||
return "application/vnd.aai.asyncapi+json;version=3.0.0"; | ||
} | ||
|
||
return schemaFormat; | ||
} | ||
|
||
} |
44 changes: 44 additions & 0 deletions
44
asyncapi-core/src/main/java/com/asyncapi/v3/schema/multiformat/JsonFormatSchema.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
package com.asyncapi.v3.schema.multiformat; | ||
|
||
import com.asyncapi.v3.schema.AsyncAPISchema; | ||
import com.asyncapi.v3.schema.JsonSchema; | ||
import com.fasterxml.jackson.annotation.JsonCreator; | ||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import lombok.EqualsAndHashCode; | ||
import org.jetbrains.annotations.NotNull; | ||
|
||
/** | ||
* The Multi Format Schema Object represents a schema definition. It differs from the {@link AsyncAPISchema} in that it supports | ||
* multiple schema formats or languages (e.g., JSON Schema, Avro, etc.). | ||
* | ||
* @see <a href="https://www.asyncapi.com/docs/reference/specification/v3.0.0#multiFormatSchemaObject">Multi Format Schema</a> | ||
* @see <a href="https://www.asyncapi.com/docs/reference/specification/v3.0.0#schemaObject">Schema</a> | ||
* @author Pavel Bodiachevskii | ||
* @version 3.0.0 | ||
*/ | ||
@EqualsAndHashCode(callSuper = true) | ||
public class JsonFormatSchema extends MultiFormatSchema<JsonSchema> { | ||
|
||
public JsonFormatSchema(@NotNull JsonSchema schema) { | ||
super("application/schema+json;version=draft-07", schema); | ||
} | ||
|
||
@JsonCreator(mode = JsonCreator.Mode.PROPERTIES) | ||
public JsonFormatSchema( | ||
@JsonProperty("schemaFormat") @NotNull String schemaFormat, | ||
@JsonProperty("schema") @NotNull JsonSchema schema | ||
) { | ||
super(schemaFormat, schema); | ||
} | ||
|
||
@Override | ||
public void setSchema(@NotNull JsonSchema schema) { | ||
super.setSchema(schema); | ||
} | ||
|
||
@NotNull | ||
public JsonSchema getSchema() { | ||
return super.getSchema(); | ||
} | ||
|
||
} |
145 changes: 145 additions & 0 deletions
145
asyncapi-core/src/main/java/com/asyncapi/v3/schema/multiformat/MultiFormatSchema.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
package com.asyncapi.v3.schema.multiformat; | ||
|
||
import com.asyncapi.v3.ExtendableObject; | ||
import com.asyncapi.v3.schema.AsyncAPISchema; | ||
import com.fasterxml.jackson.annotation.JsonCreator; | ||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
import com.fasterxml.jackson.annotation.JsonSubTypes; | ||
import com.fasterxml.jackson.annotation.JsonTypeInfo; | ||
import lombok.EqualsAndHashCode; | ||
import org.jetbrains.annotations.NotNull; | ||
|
||
/** | ||
* The Multi Format Schema Object represents a schema definition. It differs from the {@link AsyncAPISchema} in that it supports | ||
* multiple schema formats or languages (e.g., JSON Schema, Avro, etc.). | ||
* | ||
* @see <a href="https://www.asyncapi.com/docs/reference/specification/v3.0.0#multiFormatSchemaObject">Multi Format Schema</a> | ||
* @see <a href="https://www.asyncapi.com/docs/reference/specification/v3.0.0#schemaObject">Schema</a> | ||
* @author Pavel Bodiachevskii | ||
* @version 3.0.0 | ||
*/ | ||
@JsonTypeInfo( | ||
use = JsonTypeInfo.Id.NAME, | ||
include = JsonTypeInfo.As.EXISTING_PROPERTY, | ||
defaultImpl = AsyncAPIFormatSchema.class, | ||
property = "schemaFormat", | ||
visible = true | ||
) | ||
@JsonSubTypes({ | ||
@JsonSubTypes.Type(value = JsonFormatSchema.class, names = { | ||
"application/schema+json;version=draft-07", | ||
"application/schema+yaml;version=draft-07" | ||
}), | ||
@JsonSubTypes.Type(value = OpenAPIFormatSchema.class, names = { | ||
"application/vnd.oai.openapi;version=3.0.0", | ||
"application/vnd.oai.openapi+json;version=3.0.0", | ||
"application/vnd.oai.openapi+yaml;version=3.0.0" | ||
}), | ||
@JsonSubTypes.Type(value = AsyncAPIFormatSchema.class, names = { | ||
"application/vnd.aai.asyncapi;version=2.0.0", | ||
"application/vnd.aai.asyncapi+json;version=2.0.0", | ||
"application/vnd.aai.asyncapi+yaml;version=2.0.0", | ||
"application/vnd.aai.asyncapi;version=2.1.0", | ||
"application/vnd.aai.asyncapi+json;version=2.1.0", | ||
"application/vnd.aai.asyncapi+yaml;version=2.1.0", | ||
"application/vnd.aai.asyncapi;version=2.2.0", | ||
"application/vnd.aai.asyncapi+json;version=2.2.0", | ||
"application/vnd.aai.asyncapi+yaml;version=2.2.0", | ||
"application/vnd.aai.asyncapi;version=2.3.0", | ||
"application/vnd.aai.asyncapi+json;version=2.3.0", | ||
"application/vnd.aai.asyncapi+yaml;version=2.3.0", | ||
"application/vnd.aai.asyncapi;version=2.4.0", | ||
"application/vnd.aai.asyncapi+json;version=2.4.0", | ||
"application/vnd.aai.asyncapi+yaml;version=2.4.0", | ||
"application/vnd.aai.asyncapi;version=2.5.0", | ||
"application/vnd.aai.asyncapi+json;version=2.5.0", | ||
"application/vnd.aai.asyncapi+yaml;version=2.5.0", | ||
"application/vnd.aai.asyncapi;version=2.6.0", | ||
"application/vnd.aai.asyncapi+json;version=2.6.0", | ||
"application/vnd.aai.asyncapi+yaml;version=2.6.0", | ||
"application/vnd.aai.asyncapi;version=3.0.0", | ||
"application/vnd.aai.asyncapi+json;version=3.0.0", | ||
"application/vnd.aai.asyncapi+yaml;version=3.0.0" | ||
}) | ||
}) | ||
@EqualsAndHashCode(callSuper = true) | ||
public class MultiFormatSchema<Schema> extends ExtendableObject { | ||
|
||
public MultiFormatSchema(@NotNull Schema schema) { | ||
this.schemaFormat = "application/vnd.aai.asyncapi+json;version=3.0.0"; | ||
this.schema = schema; | ||
} | ||
|
||
@JsonCreator(mode = JsonCreator.Mode.PROPERTIES) | ||
public MultiFormatSchema( | ||
@JsonProperty("schemaFormat") @NotNull String schemaFormat, | ||
@JsonProperty("schema") @NotNull Schema schema | ||
) { | ||
this.schemaFormat = schemaFormat; | ||
this.schema = schema; | ||
} | ||
|
||
/** | ||
* <b>Required</b>. | ||
* <p> | ||
* A string containing the name of the schema format that is used to define the information. | ||
* <p> | ||
* If schemaFormat is missing, it MUST default to application/vnd.aai.asyncapi+json;version={{asyncapi}} | ||
* where {{asyncapi}} matches the {@link com.asyncapi.v3._0_0.model.AsyncAPI#getAsyncapi()} version string. | ||
* <p> | ||
* In such a case, this would make the Multi Format Schema Object equivalent to the {@link AsyncAPISchema}. | ||
* <p> | ||
* When using {@link com.asyncapi.v3.Reference} within the {@link #getSchema()}, the schemaFormat of the resource being referenced MUST match | ||
* the schemaFormat of the {@link #getSchema()} that contains the initial reference. | ||
* <p> | ||
* For example, if you reference Avro schema, then schemaFormat of referencing resource and the resource being reference MUST match. | ||
* <p> | ||
* <p> | ||
* Check out the supported schema formats table for more information. | ||
* Custom values are allowed but their implementation is OPTIONAL. | ||
* A custom value MUST NOT refer to one of the schema formats listed in the table. | ||
* <p> | ||
* <p> | ||
* When using {@link com.asyncapi.v3.Reference} within the {@link #getSchema()}, the schemaFormat of the referenced resource MUST | ||
* match the schemaFormat of the schema containing the reference. | ||
* | ||
* @see <a href="https://www.asyncapi.com/docs/reference/specification/v3.0.0#multiFormatSchemaFormatTable">Schema formats table</a> | ||
*/ | ||
@NotNull | ||
@JsonProperty("schemaFormat") | ||
private String schemaFormat; | ||
|
||
public void setSchemaFormat(@NotNull String schemaFormat) { | ||
this.schemaFormat = schemaFormat; | ||
} | ||
|
||
@NotNull | ||
public String getSchemaFormat() { | ||
return schemaFormat; | ||
} | ||
|
||
/** | ||
* <b>Required</b>. | ||
* <p> | ||
* Definition of the message payload. | ||
* <p> | ||
* It can be of any type but defaults to {@link AsyncAPISchema}. | ||
* <p> | ||
* It MUST match the schema format defined in {@link #getSchemaFormat()}, including the encoding type. E.g., Avro should be | ||
* inlined as either a YAML or JSON object instead of as a string to be parsed as YAML or JSON. Non-JSON-based | ||
* schemas (e.g., Protobuf or XSD) MUST be inlined as a string. | ||
*/ | ||
@NotNull | ||
@JsonProperty("schema") | ||
private Schema schema; | ||
|
||
public void setSchema(@NotNull Schema schema) { | ||
this.schema = schema; | ||
} | ||
|
||
@NotNull | ||
public Schema getSchema() { | ||
return schema; | ||
} | ||
|
||
} |
Oops, something went wrong.