From 9bc8a89b860aad3f3a59b550d5eae47d9ea89c2d Mon Sep 17 00:00:00 2001
From: Carsten Wickner <11309681+CarstenWickner@users.noreply.github.com>
Date: Fri, 21 Jun 2024 22:18:40 +0200
Subject: [PATCH] chore: add example for target type override (#452)
---
.../examples/TargetTypeOverrideExample.java | 85 +++++++++++++++++++
.../jsonschema/examples/ExampleTest.java | 1 +
.../TargetTypeOverrideExample-result.json | 17 ++++
3 files changed, 103 insertions(+)
create mode 100644 jsonschema-examples/src/main/java/com/github/victools/jsonschema/examples/TargetTypeOverrideExample.java
create mode 100644 jsonschema-examples/src/test/resources/com/github/victools/jsonschema/examples/TargetTypeOverrideExample-result.json
diff --git a/jsonschema-examples/src/main/java/com/github/victools/jsonschema/examples/TargetTypeOverrideExample.java b/jsonschema-examples/src/main/java/com/github/victools/jsonschema/examples/TargetTypeOverrideExample.java
new file mode 100644
index 00000000..f21f20bb
--- /dev/null
+++ b/jsonschema-examples/src/main/java/com/github/victools/jsonschema/examples/TargetTypeOverrideExample.java
@@ -0,0 +1,85 @@
+/*
+ * Copyright 2024 VicTools.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package com.github.victools.jsonschema.examples;
+
+import com.fasterxml.classmate.ResolvedType;
+import com.fasterxml.jackson.databind.node.ObjectNode;
+import com.github.victools.jsonschema.generator.FieldScope;
+import com.github.victools.jsonschema.generator.MemberScope;
+import com.github.victools.jsonschema.generator.Option;
+import com.github.victools.jsonschema.generator.OptionPreset;
+import com.github.victools.jsonschema.generator.SchemaGenerationContext;
+import com.github.victools.jsonschema.generator.SchemaGenerator;
+import com.github.victools.jsonschema.generator.SchemaGeneratorConfig;
+import com.github.victools.jsonschema.generator.SchemaGeneratorConfigBuilder;
+import com.github.victools.jsonschema.generator.SchemaVersion;
+import com.github.victools.jsonschema.generator.SubtypeResolver;
+import com.github.victools.jsonschema.generator.TypeContext;
+import com.github.victools.jsonschema.module.jakarta.validation.JakartaValidationModule;
+import io.github.classgraph.ClassGraph;
+import io.github.classgraph.ClassInfoList;
+import io.github.classgraph.ScanResult;
+import jakarta.validation.constraints.NotNull;
+import jakarta.validation.constraints.Size;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.List;
+import java.util.stream.Collectors;
+
+/**
+ * Example created in response to #451.
+ *
+ * Demonstrating target type overrides to represent a {@code byte[]} as {@code string} with particular content encoding.
+ */
+public class TargetTypeOverrideExample implements SchemaGenerationExampleInterface {
+
+ @Override
+ public ObjectNode generateSchema() {
+ SchemaGeneratorConfigBuilder configBuilder = new SchemaGeneratorConfigBuilder(SchemaVersion.DRAFT_2020_12, OptionPreset.PLAIN_JSON);
+ configBuilder.with(new JakartaValidationModule());
+ configBuilder.forFields()
+ .withTargetTypeOverridesResolver(this::treatByteArrayAsString)
+ .withInstanceAttributeOverride(this::addContentEncodingForByteArray);
+ SchemaGeneratorConfig config = configBuilder.build();
+ SchemaGenerator generator = new SchemaGenerator(config);
+ return generator.generateSchema(Example.class);
+ }
+
+ private List treatByteArrayAsString(MemberScope, ?> scope) {
+ ResolvedType type = scope.getType();
+ if (type != null && type.getErasedType().equals(byte[].class)) {
+ return Collections.singletonList(scope.getContext().resolve(String.class));
+ }
+ return null;
+ }
+
+ private void addContentEncodingForByteArray(ObjectNode schema, MemberScope, ?> scope, SchemaGenerationContext context) {
+ ResolvedType declaredType = scope.getDeclaredType();
+ if (declaredType != null && declaredType.getErasedType().equals(byte[].class)) {
+ schema.put("contentEncoding", "base64");
+ }
+ }
+
+ static class Example {
+ @NotNull
+ @Size(min = 1, max = 100)
+ public String someText;
+ @NotNull
+ @Size(min = 1, max = 10485760)
+ public byte[] byteArray;
+ }
+}
diff --git a/jsonschema-examples/src/test/java/com/github/victools/jsonschema/examples/ExampleTest.java b/jsonschema-examples/src/test/java/com/github/victools/jsonschema/examples/ExampleTest.java
index ea49a003..c93bb35a 100644
--- a/jsonschema-examples/src/test/java/com/github/victools/jsonschema/examples/ExampleTest.java
+++ b/jsonschema-examples/src/test/java/com/github/victools/jsonschema/examples/ExampleTest.java
@@ -41,6 +41,7 @@ public class ExampleTest {
JacksonSubtypeDefinitionExample.class,
StrictTypeInfoExample.class,
SubtypeLookUpExample.class,
+ TargetTypeOverrideExample.class,
ValidationErrorMessageExample.class
})
public void testExample(Class extends SchemaGenerationExampleInterface> exampleType) throws Exception {
diff --git a/jsonschema-examples/src/test/resources/com/github/victools/jsonschema/examples/TargetTypeOverrideExample-result.json b/jsonschema-examples/src/test/resources/com/github/victools/jsonschema/examples/TargetTypeOverrideExample-result.json
new file mode 100644
index 00000000..6f669e36
--- /dev/null
+++ b/jsonschema-examples/src/test/resources/com/github/victools/jsonschema/examples/TargetTypeOverrideExample-result.json
@@ -0,0 +1,17 @@
+{
+ "$schema" : "https://json-schema.org/draft/2020-12/schema",
+ "type" : "object",
+ "properties" : {
+ "byteArray" : {
+ "type" : "string",
+ "minLength" : 1,
+ "maxLength" : 10485760,
+ "contentEncoding" : "base64"
+ },
+ "someText" : {
+ "type" : "string",
+ "minLength" : 1,
+ "maxLength" : 100
+ }
+ }
+}