Skip to content

Latest commit

 

History

History
144 lines (99 loc) · 5.68 KB

README.md

File metadata and controls

144 lines (99 loc) · 5.68 KB

Maven Central

yaml-combine-maven-plugin

This project provides a source pre-processor which can be used to combine one or more YAML files before swagger code generation.

Overview

This plugin exists mainly because $ref references are only allowed in one or two places in the swagger spec, and you may want to import objects in other locations.

It does this by adding a new reference type called $xref which is identical to $ref except

  • you can use them anywhere in the yaml file
  • you can add or override keys in the referenced objects
  • the syntax allows forward slashes in path keys to appear as forward slashes

The maven documentation for the plugin is here

And there's a blog article here.

Syntax

This plugin recognises a new $xref reference which is backwards-compatible with $refs, but can be located anywhere in the source swagger file. The pre-processor will replace $xrefs with the content of those references.

$xrefs use the same JSON-Pointer syntax as swagger ( which performs URL-escaping and ~1 substitution ), so you could have references that look like

paths:
  /thing:
    $xref: 'paths.yaml#/paths/~1thing

or

paths:
  /thing:
    $xref: 'paths.yaml#/paths/%2Fthing

To make references more readable, you can add '#' characters inside the reference. Each '#' character toggles how '/' characters are interpretted, either '/' as JSON-Pointer separators, or '/' as characters within a YAML key.

e.g.

paths:
  /thing:
    $xref: 'paths.yaml#/paths/#/thing

Modifying imported objects

Unlike $refs, $xrefs let you modify the imported object.

An object defined via an $xref can provide additional keys which are merged in with the $xrefed object.

e.g.

paths:
  /thing:
    get:
      $xref: 'paths.yaml#/paths/#/thing#/get'
      parameters:
        old-parameter:
          description: some old parameter whose description has changed
        new-parameter: 
          description: a new parameter in v2 of the API that isn't in v1
          type: string

Combining input files

As an alternative (or in addition) to using $xref to reference external files, you can also merge YAML files together by supplying multiple YAML files as inputs to the plugin.

Handling of $ref

Files can continue to use $ref references, and these references will survive the yaml-combine-maven-plugin process.

Examples

There's a handful of examples in the site documentation for the plugin

Here's you how might use this plugin in your pom.xml file:

<project>
  <build>
    <plugins>
    
      <plugin>
        <groupId>com.randomnoun.maven.plugins</groupId>
        <artifactId>yaml-combine-maven-plugin</artifactId>
        <version>2.0.0</version>
        <executions>
          <execution>
            <id>yaml-combine</id>
            <phase>generate-sources</phase>
            <goals>
                <goal>yaml-combine</goal>
            </goals>
            <configuration>
              <fileset>
                <includes>

                  <!-- can supply multiple files here or filespecs; e.g. *.yaml -->
                  <include>my-swagger-file-with-xrefs-in-it.yaml</include>
                </includes>
                <directory>${project.basedir}/src/main/swagger</directory>
              </fileset>
              <outputDirectory>${project.basedir}/target/swagger-combine</outputDirectory>

              <!-- use this file as the input to the codegen goal -->
              <finalName>my-swagger-file-with-resolved-xrefs.yaml</finalName>
            </configuration>
          </execution>
        </executions>
      </plugin>
            
    <plugins>
  <build>
<project>

Is there a blog article about this project ?

Why yes there is: http://www.randomnoun.com/wp/2021/06/29/swagger-combine/

Alternatives

Did a bit of googling and found:

but these didn't really work for me.

Licensing

yaml-combine-maven-plugin is licensed under the BSD 2-clause license.