This maven plugin allows you to generate the OpenAPI Schema on build.
Add this to your pom.xml:
<plugin>
<artifactId>smallrye-open-api-maven-plugin</artifactId>
<groupId>io.smallrye</groupId>
<executions>
<execution>
<goals>
<goal>generate-schema</goal>
</goals>
</execution>
</executions>
<!-- Uncomment the dependency overrides for JDK 1.8 compatibility: -->
<!--
<dependencies>
<dependency>
<groupId>io.smallrye.config</groupId>
<artifactId>smallrye-config</artifactId>
<version>2.13.3</version>
</dependency>
<dependency>
<groupId>org.jboss.logging</groupId>
<artifactId>jboss-logging</artifactId>
<version>3.4.3.Final</version>
</dependency>
</dependencies>
-->
</plugin>
The schema will appear as target/generated/openapi.yaml
and target/generated/openapi.json
by default.
Any option of type List<String>
has to be specified as follows. The child elements name is the same as the parents, without the s
.
E.g. for includeDependenciesScopes could be configured as:
<includeDependenciesScopes> <includeDependenciesScope>compile</includeDependenciesScope> <includeDependenciesScope>system</includeDependenciesScope> </includeDependenciesScopes>
-
outputDirectory
(String) - To override the defaulttarget/generated/
outputDirectory where the json and yaml files will be created. -
schemaFilename
(String) - To override the defaultopenapi
filename. This will be the name without the extension. -
scanDependenciesDisable
(boolean, default: false) - Disable scanning the project’s dependencies for OpenAPI model classes too -
includeDependenciesScopes
(List<String>, default: compile, system) - If the abovescanDependenciesDisable
is true, you can control what scopes should be included. -
includeDependenciesTypes
(List<String>, default: jar) - If the abovescanDependenciesDisable
is true, you can control what types should be included. -
configProperties
(String) - Load any properties from a file. Example${basedir}/src/main/resources/application.properties
. -
attachArtifacts
(boolean, default: false) - Attach the built OpenAPI schema as build artifact. -
skip
(boolean, default: false) - Skip execution of the plugin. -
encoding
(String) - Encoding of output OpenAPI files. -
outputFileTypeFilter
(String, default: ALL) - Set this toYAML
in order to let the generation process produce just *.yaml output,JSON
to obtain *.json files only. The default isALL
, which will generate both file types.
All properties from the MicroProfile OpenAPI Spec is supported. Properties set here will override the properties from configProperties
.
-
modelReader
(String) - Configuration property to specify the fully qualified name of the OASModelReader implementation. -
filter
(String) - Configuration property to specify the fully qualified name of the OASFilter implementation. -
scanDisabled
(boolean) - Configuration property to disable annotation scanning. -
scanPackages
(regex) - Configuration property to specify the list of packages to scan. -
scanClasses
(regex) - Configuration property to specify the list of classes to scan. -
scanExcludePackages
(regex) - Configuration property to specify the list of packages to exclude from scans. -
scanExcludeClasses
(regex) - Configuration property to specify the list of classes to exclude from scans. -
servers
(List<String>) - Configuration property to specify the list of global servers that provide connectivity information. -
pathServers
(List<String>) - Prefix of the configuration property to specify an alternative list of servers to service all operations in a path -
operationServers
(List<String>) - Prefix of the configuration property to specify an alternative list of servers to service an operation.
All properties from the SmallRye OpenAPI Implementation is supported. Properties set here will override the properties from configProperties
.
-
customSchemaRegistryClass
(String) - Fully qualified name of a CustomSchemaRegistry, which can be used to specify a custom schema for a type. -
applicationPathDisable
(boolean, default: false) - Disable scanning of the javax.ws.rs.Path (and jakarta.ws.rs.Path) for the application path. -
openApiVersion
(String, default: 3.0.3) - To specify a custom OpenAPI version. -
infoTitle
(String) -
infoVersion
(String) -
infoDescription
(String) -
infoTermsOfService
(String) -
infoContactEmail
(String) -
infoContactName
(String) -
infoContactUrl
(String) -
infoLicenseName
(String) -
infoLicenseUrl
(String) -
operationIdStrategy
(METHOD/CLASS_METHOD/PACKAGE_CLASS_METHOD) - Configuration property to specify how the operationid is generated. Can be used to minimize risk of collisions between operations. -
METHOD
- The method name is used as operationId. -
CLASS_METHOD
- The class name and method name is used as operationId. -
PACKAGE_CLASS_METHOD
- The fully qualified class name and method name is used as operationId. -
scanProfiles
(List<String>) - Profiles which explicitly include operations. Any operation without a matching profile is excluded. -
scanExcludeProfiles
(List<String>) - Profiles which explicitly exclude operations. Any operation without a matching profile is included.