This example contains two simple workflow services containing the annotation
and description
attributes. The services are described using both JSON and YAML formats as defined in the CNCF Serverless Workflow specification.
These workflow definitions will generate an Open API document like the following (note the tags “Cogito”, “ergo”, “sum”, “jsonannotations”, and “yamlannotations”):
--- openapi: 3.0.3 info: title: serverless-workflow-annotations API tags: - name: Cogito - name: ergo - name: jsonannotations description: This is an amazing workflow - name: sum - name: yamlannotations description: This is an amazing workflow paths: /: post: requestBody: content: '*/*': schema: $ref: '#/components/schemas/CloudEvent' responses: "200": description: OK content: application/json: schema: $ref: '#/components/schemas/Response' # more paths here
You will need:
When using native image compilation, you will also need:
mvn clean package quarkus:dev
mvn clean package java -jar target/quarkus-app/quarkus-run.jar
or on windows
mvn clean package java -jar target\quarkus-app\quarkus-run.jar
Note that this requires GRAALVM_HOME to point to a valid GraalVM installation
mvn clean package -Pnative
To run the generated native executable, generated in target/
, execute
./target/sw-quarkus-greeting-{version}-runner
http://localhost:8080/q/openapi