Skip to content

Latest commit

 

History

History
104 lines (92 loc) · 9.86 KB

File metadata and controls

104 lines (92 loc) · 9.86 KB

OpenAPI: REST Controllers Generator

👉 ZenWave360 Helps You Create Software Easy to Understand

Generates implementations based on JDL models and OpenAPI definitions SpringMVC generated OpenAPI interfaces.

After you have generated SpringMVC interfaces and DTOs with OpenAPI generator, you can use this command to generate implementations (skeletons) and mappers for those interfaces and dtos:

jbang zw -p io.zenwave360.sdk.plugins.OpenAPIControllersPlugin    
    openapiFile=src/main/resources/model/openapi.yml \
    zdlFile=src/main/resources/model/orders-model.jdl \
    basePackage=io.zenwave360.example \
    openApiApiPackage=io.zenwave360.example.adapters.web \
    openApiModelPackage=io.zenwave360.example.adapters.web.model \
    openApiModelNameSuffix=DTO \
    targetFolder=.

Configuring OpenAPI Generator for Compatibility

Default options for https://openapi-generator.tech/docs/generators/spring/ have changes over time and different versions. Here is a sample configuration that works with this version of ZenWave360 SDK.

<plugin>
    <groupId>org.openapitools</groupId>
    <artifactId>openapi-generator-maven-plugin</artifactId>
    <version>7.8.0</version>
    <executions>
        <execution>
            <goals>
                <goal>generate</goal>
            </goals>
            <phase>generate-sources</phase>
            <configuration>
                <inputSpec>${project.basedir}/src/main/resources/public/apis/openapi.yml</inputSpec>
                <skipIfSpecIsUnchanged>true</skipIfSpecIsUnchanged>
                <generatorName>spring</generatorName>
                <apiPackage>${openApiApiPackage}</apiPackage>
                <modelPackage>${openApiModelPackage}</modelPackage>
                <modelNameSuffix>DTO</modelNameSuffix>
                <addCompileSourceRoot>true</addCompileSourceRoot>
                <generateSupportingFiles>false</generateSupportingFiles>
                <typeMappings>
                    <typeMapping>Double=java.math.BigDecimal</typeMapping>
                </typeMappings>
                <configOptions>
                    <useSpringBoot3>true</useSpringBoot3>
                    <documentationProvider>none</documentationProvider>
                    <openApiNullable>false</openApiNullable>
                    <useOptional>false</useOptional>
                    <useTags>true</useTags>
                    <interfaceOnly>true</interfaceOnly>
                    <skipDefaultInterface>true</skipDefaultInterface>
                    <delegatePattern>false</delegatePattern>
                    <sortParamsByRequiredFlag>false</sortParamsByRequiredFlag><!-- this is important -->
                </configOptions>
            </configuration>
        </execution>
    </executions>
</plugin>

Also, make sure you set required: true for requestBody in your OpenAPI definition for post, put, patch...

requestBody:
  required: true # this is important
  content:
    application/json:
      schema:
        $ref: "#/components/schemas/Customer"

Plugin Options

Option Description Type Default Values
openapiFile OpenAPI Specification File String
zdlFile ZDL file to parse String
targetFolder Target folder to generate code to. If left empty, it will print to stdout. File
style Programming Style ProgrammingStyle imperative imperative, reactive
operationIds OpenAPI operationIds to generate code for List []
statusCodes Status codes to generate code for List [200, 201, 202, 400]
openApiApiPackage The package to used by OpenAPI-Generator for generated api objects/classes String
openApiModelPackage The package to used by OpenAPI-Generator for generated model objects/classes String {{openApiApiPackage}}
openApiModelNamePrefix Sets the prefix for model enums and classes used by OpenAPI-Generator String
openApiModelNameSuffix Sets the suffix for model enums and classes used by OpenAPI-Generator String
basePackage Applications base package String
controllersPackage The package to generate REST Controllers String {{basePackage}}.adapters.web
entitiesPackage Package where your domain entities are String {{basePackage}}.core.domain
inboundDtosPackage Package where your inbound dtos are String {{basePackage}}.core.inbound.dtos
servicesPackage Package where your domain services/usecases interfaces are String {{basePackage}}.core.inbound
inputDTOSuffix Should use same value configured in BackendApplicationDefaultPlugin. Whether to use an input DTO for entities used as command parameter. String
paginatedDtoItemsJsonPath JSONPath list to search for response DTO schemas for list or paginated results. User '$.items' for lists or '$.properties..items' for paginated results. List [$.items, $.properties.content.items]
formatter Code formatter implementation Formatters spring google, palantir, spring, eclipse
skipFormatting Skip java sources output formatting boolean false
haltOnFailFormatting Halt on formatting errors boolean true
continueOnZdlError Continue even when ZDL contains fatal errors boolean true

Getting Help

jbang zw -p io.zenwave360.sdk.plugins.OpenAPIControllersPlugin --help