Usage
Options for OpenAPI Generator are the same whether you're using the CLI, Maven/Gradle Plugins, or Online generation options. This page demonstrates navigating the options via CLI. Commands are presented here in a logical progression as a tutorial, but you're welcome to skip directly to the generate command.
help
The help option lists all commands available to the CLI.
openapi-generator helpusage: openapi-generator-cli <command> [<args>]The most commonly used openapi-generator-cli commands are:config-help Config help for chosen langgenerate Generate code with the specified generator.help Display help informationlist Lists the available generatorsmeta MetaGenerator. Generator for creating a new template set and configuration for Codegen. The output will be based on the language you specify, and includes default templates to include.validate Validate specificationversion Show version informationSee 'openapi-generator-cli help <command>' for more information on a specificcommand.
list
The list command outputs a formatted list of every available generator. Pass the -s/--short option if you would like a CSV output for easy parsing.
openapi-generator help listNAMEopenapi-generator-cli list - Lists the available generatorsSYNOPSISopenapi-generator-cli list [(-i <include> | --include <include>)][(-s | --short)]OPTIONS-i <include>, --include <include>comma-separated list of stability indexes to include (value:all,beta,stable,experimental,deprecated). Excludes deprecated bydefault.-s, --shortshortened output (suitable for scripting)
Example:
openapi-generator list -s | tr ',' '\n'
For the full list of generators, refer to the Generators List.
config-help
The config-help option provides details about 
openapi-generator help config-helpNAMEopenapi-generator-cli config-help - Config help for chosen langSYNOPSISopenapi-generator-cli config-help[(-f <output format> | --format <output format>)][(-g <generator name> | --generator-name <generator name>)][--markdown-header] [--named-header][(-o <output location> | --output <output location>)]OPTIONS-f <output format>, --format <output format>Write output files in the desired format. Options are 'text','markdown' or 'yamlsample'. Default is 'text'.-g <generator name>, --generator-name <generator name>generator to get config help for--markdown-headerWhen format=markdown, include this option to write out markdownheaders (e.g. for docusaurus).--named-headerHeader includes the generator name, for clarity in output-o <output location>, --output <output location>Optionally write help to this location, otherwise default isstandard output
The option of note is -g/--generator-name (other options are exposed for tooling).
You may pass any generator name (see list command) to -g, and options specific to that generator will be displayed. Some generators have many options, while others may have only a few.
Example:
openapi-generator config-help -g go
Outputs:
CONFIG OPTIONSpackageNameGo package name (convention: lowercase). (Default: openapi)hideGenerationTimestampHides the generation timestamp when files are generated. (Default: true)packageVersionGo package version. (Default: 1.0.0)withGoCodegenCommentwhether to include Go codegen comment to disable Go Lint and collapse by default in GitHub PRs and diffs (Default: false)withXmlwhether to include support for application/xml content type and include XML annotations in the model (works with libraries that provide support for JSON and XML) (Default: false)prependFormOrBodyParametersAdd form or body parameters to the beginning of the parameter list. (Default: false)
To pass these go client generator-specific options to the generate command for a go client, use the --additional-properties option. See the generate command section for an example.
meta
The meta command creates a new Java class and template files, used for creating your own custom templates.
openapi-generator help metaNAMEopenapi-generator-cli meta - MetaGenerator. Generator for creating a newtemplate set and configuration for Codegen. The output will be based onthe language you specify, and includes default templates to include.SYNOPSISopenapi-generator-cli meta [(-n <name> | --name <name>)][(-o <output directory> | --output <output directory>)][(-p <package> | --package <package>)] [(-t <type> | --type <type>)]OPTIONS-n <name>, --name <name>the human-readable name of the generator-o <output directory>, --output <output directory>where to write the generated files (current dir by default)-p <package>, --package <package>the package to put the main class into (defaults toorg.openapitools.codegen)-t <type>, --type <type>the type of generator that is created
For an in-depth example of using the meta command, see Customization.
validate
The validate command allows you to validate an input specification, optionally providing recommendations for error fixes or other improvements (if available).
openapi-generator help validateNAMEopenapi-generator-cli validate - Validate specificationSYNOPSISopenapi-generator-cli validate(-i <spec file> | --input-spec <spec file>) [--recommend]OPTIONS-i <spec file>, --input-spec <spec file>location of the OpenAPI spec, as URL or file (required)--recommend
Valid Spec Example (using petstore-v3.0.yaml)
openapi-generator validate -i petstore-v3.0.yaml
Validating spec (petstore-v3.0.yaml)No validation issues detected.
Invalid Spec Example (using petstore-v3.0-invalid.yaml):
openapi-generator validate -i petstore-v3.0-invalid.yaml
Validating spec (petstore-v3.0-invalid.yaml)Errors:-attribute info is missing[error] Spec has 1 errors.
completion
Although not documented in the help output, the CLI offers a completion command, which can be used for auto-completion.
This command takes one or more parameters representing the args list you would otherwise pass to openapi-generator. For example:
openapi-generator completion config-help-o--output--named-header-g--generator-name-f--format--markdown-header
An example bash completion script can be found in the repo at scripts/openapi-generator-cli-completion.bash.
generate
The generate command is the workhorse of the generator toolset. As such, it has many more options and the previous commands. The abbreviated options are below, but you may expand the full descriptions.
openapi-generator help generateNAMEopenapi-generator-cli generate - Generate code with the specifiedgenerator.SYNOPSISopenapi-generator-cli generate[(-a <authorization> | --auth <authorization>)][--api-name-suffix <api name suffix>] [--api-package <api package>][--artifact-id <artifact id>] [--artifact-version <artifact version>][(-c <configuration file> | --config <configuration file>)][-D <system properties>...] [--dry-run][(-e <templating engine> | --engine <templating engine>)][--enable-post-process-file][(-g <generator name> | --generator-name <generator name>)][--generate-alias-as-model] [--git-host <git host>][--git-repo-id <git repo id>] [--git-user-id <git user id>][--group-id <group id>] [--http-user-agent <http user agent>](-i <spec file> | --input-spec <spec file>)[--ignore-file-override <ignore file override location>][--import-mappings <import mappings>...][--instantiation-types <instantiation types>...][--invoker-package <invoker package>][--language-specific-primitives <language specific primitives>...][--library <library>] [--log-to-stderr] [--minimal-update][--model-name-prefix <model name prefix>][--model-name-suffix <model name suffix>][--model-package <model package>][(-o <output directory> | --output <output directory>)][(-p <additional properties> | --additional-properties <additional properties>)...][--package-name <package name>] [--release-note <release note>][--remove-operation-id-prefix][--reserved-words-mappings <reserved word mappings>...][(-s | --skip-overwrite)] [--server-variables <server variables>...][--skip-validate-spec] [--strict-spec <true/false strict behavior>][(-t <template directory> | --template-dir <template directory>)][--type-mappings <type mappings>...] [(-v | --verbose)]
generate OPTIONS
OPTIONS-a <authorization>, --auth <authorization>adds authorization headers when fetching the OpenAPI definitionsremotely. Pass in a URL-encoded string of name:header with a commaseparating multiple values--api-name-suffix <api name suffix>Suffix that will be appended to all API names ('tags'). Default:Api. e.g. Pet => PetApi. Note: Only ruby, python, jaxrs generatorssuppport this feature at the moment.--api-package <api package>package for generated api classes--artifact-id <artifact id>artifactId in generated pom.xml. This also becomes part of thegenerated library's filename--artifact-version <artifact version>artifact version in generated pom.xml. This also becomes part of thegenerated library's filename-c <configuration file>, --config <configuration file>Path to configuration file. It can be JSON or YAML. If file is JSON,the content should have the format {"optionKey":"optionValue","optionKey1":"optionValue1"...}. If file is YAML, the content shouldhave the format optionKey: optionValue. Supported options can bedifferent for each language. Run config-help -g {generator name}command for language-specific config options.-D <system properties>sets specified system properties in the format ofname=value,name=value (or multiple options, each with name=value)--dry-runTry things out and report on potential changes (without actuallymaking changes).-e <templating engine>, --engine <templating engine>templating engine: "mustache" (default) or "handlebars" (beta)--enable-post-process-fileEnable post-processing file using environment variables.-g <generator name>, --generator-name <generator name>generator to use (see list command for list)--generate-alias-as-modelGenerate model implementation for aliases to map and array schemas.An 'alias' is an array, map, or list which is defined inline in aOpenAPI document and becomes a model in the generated code.A 'map' schema is an object that can have undeclared properties,i.e. the 'additionalproperties' attribute is set on that object.An 'array' schema is a list of sub schemas in a OAS document.--git-host <git host>Git host, e.g. gitlab.com.--git-repo-id <git repo id>Git repo ID, e.g. openapi-generator.--git-user-id <git user id>Git user ID, e.g. openapitools.--group-id <group id>groupId in generated pom.xml--http-user-agent <http user agent>HTTP user agent, e.g. codegen_csharp_api_client, default to'OpenAPI-Generator/{packageVersion}}/{language}'-i <spec file>, --input-spec <spec file>location of the OpenAPI spec, as URL or file (required)--ignore-file-override <ignore file override location>Specifies an override location for the .openapi-generator-ignorefile. Most useful on initial generation.--import-mappings <import mappings>specifies mappings between a given class and the import that shouldbe used for that class in the format of type=import,type=import. Youcan also have multiple occurrences of this option.--instantiation-types <instantiation types>sets instantiation type mappings in the format oftype=instantiatedType,type=instantiatedType.For example (in Java):array=ArrayList,map=HashMap. In other words array types will getinstantiated as ArrayList in generated code. You can also havemultiple occurrences of this option.--invoker-package <invoker package>root package for generated code--language-specific-primitives <language specific primitives>specifies additional language specific primitive types in the formatof type1,type2,type3,type3. For example:String,boolean,Boolean,Double. You can also have multipleoccurrences of this option.--library <library>library template (sub-template)--log-to-stderrwrite all log messages (not just errors) to STDOUT. Useful forpiping the JSON output of debug options (e.g. `-DdebugOperations`)to an external parser directly while testing a generator.--minimal-updateOnly write output files that have changed.--model-name-prefix <model name prefix>Prefix that will be prepended to all model names.--model-name-suffix <model name suffix>Suffix that will be appended to all model names.--model-package <model package>package for generated models-o <output directory>, --output <output directory>where to write the generated files (current dir by default)-p <additional properties>, --additional-properties <additionalproperties>sets additional properties that can be referenced by the mustachetemplates in the format of name=value,name=value. You can also havemultiple occurrences of this option.--package-name <package name>package for generated classes (where supported)--release-note <release note>Release note, default to 'Minor update'.--remove-operation-id-prefixRemove prefix of operationId, e.g. config_getId => getId--reserved-words-mappings <reserved word mappings>specifies how a reserved name should be escaped to. Otherwise, thedefault _<name> is used. For example id=identifier. You can alsohave multiple occurrences of this option.-s, --skip-overwritespecifies if the existing files should be overwritten during thegeneration.--server-variables <server variables>sets server variables overrides for spec documents which supportvariable templating of servers.--skip-validate-specSkips the default behavior of validating an input specification.--strict-spec <true/false strict behavior>'MUST' and 'SHALL' wording in OpenAPI spec is strictly adhered to.e.g. when false, no fixes will be applied to documents which passvalidation but don't follow the spec.-t <template directory>, --template-dir <template directory>folder containing the template files--type-mappings <type mappings>sets mappings between OpenAPI spec types and generated code types inthe format of OpenAPIType=generatedType,OpenAPIType=generatedType.For example: array=List,map=Map,string=String. You can also havemultiple occurrences of this option.-v, --verboseverbose mode
At a minimum, generate requires:
- -gto specify the generator
- -oto specify a meaningful output directory (defaults to the current directory!)
- -ito specify the input OpenAPI document
NOTE You may also pass
-Dcoloras a system property to colorize terminal outputs.
Examples
The following examples use petstore.yaml.
Additional Properties
Generator-specific options should be passed as --additional-properties:
openapi-generator generate -g go --additional-properties=prependFormOrBodyParameters=true \-o out -i petstore.yaml
To pass more than one generator property, these can be combined via comma:
--additional-properties=key1=value1,key2=value2
For the full list of generator-specified parameters, refer to generators docs.
Type Mappings and Import Mappings
Most generators allow for types bound to the OpenAPI Specification's types to be remapped to a user's desired types. Not all type mappings can be reassigned, as some generators define mappings which are tightly coupled to the built-in templates.
If you're not using your own templates with star/glob package imports, you will most likely need to combine --type-mappings and --import-mappings together.
- --type-mappingsDefines the user's target type
- --import-mappingsInforms the template of the type to be imported
Here's how one might change the kotlin-spring server generator's default of OffsetDateTime to LocalDateTime:
openapi-generator generate \-i petstore.yaml \-g kotlin-spring \-o out \--additional-properties=library=spring-boot,beanValidations=true,swaggerAnnotations=true,serviceImplementation=true \--import-mappings=DateTime=java.time.LocalDateTime \--type-mappings=DateTime=java.time.LocalDateTime
NOTE: mappings are applied to
DateTime, as this is the representation of the primitive type. See DefaultCodegen.
Target External Models
Sometimes you don't want the codegen to make a model for you--you might want to just include one that already exists in your codebase.  Say you already have a User object and want to reuse that, which has a different model package from the other generated files:
First, indicate that the class is already included by default. This will keep the codegen from trying to generate the class.
--language-specific-primitives=Pet
This command line option will tell the generator to consider Pet a "primitive" type.
Next, if the Pet class is a different package, add an --import-mapping to tell the generator to include that import wherever Pet is used:
--import-mappings=Pet=com.yourpackage.models.Pet
Now the codegen will know what to import from that specific package.
NOTE: import-mappings is assigned a key-value pair in this example, but multiple values can be comma-separate. For instance:
--import-mappings=Pet=com.yourpackage.models.Pet,User=com.yourpackage.models.User
Configuration File
Rather than passing generator options in a CSV of --additional-properties, you may also provide the settings via JSON file or YAML file.
For example, one of our typescript samples has the following configuration file:
{"npmName": "@swagger/typescript-fetch-petstore","npmVersion": "1.0.0","npmRepository" : "https://skimdb.npmjs.com/registry","snapshot" : false,"supportsES6": true}
These settings can be passed via -c filename. Here, we've saved the above as config.json:
openapi-generator generate -i petstore.yaml -g typescript-fetch -o out \-c config.json
Same configuration file can be passed into YAML format having following equivalent content:
npmName: "@swagger/typescript-fetch-petstore"npmVersion: "1.0.0"npmRepository: "https://skimdb.npmjs.com/registry"snapshot: falsesupportsES6: true
The settings are passed exactly the same as for config.json. The most important part is the file extension. Supported values are yml or yaml.
The name of the file should be config.yml or config.yaml (in our example it will be config.yaml.
openapi-generator generate -i petstore.yaml -g typescript-fetch -o out \-c config.yaml
batch
The batch command allows you to move all CLI arguments supported by the generate command into a YAML or JSON file.
NOTE: This command supports an additional !include property which may point to another "shared" file, the base path to which can be
modified by --includes-base-dir.
openapi-generator help batchNAMEopenapi-generator-cli batch - Generate code in batch via externalconfigs.SYNOPSISopenapi-generator-cli batch [--fail-fast][--includes-base-dir <includes>] [(-r <threads> | --threads <threads>)][--root-dir <root>] [--timeout <timeout>] [(-v | --verbose)] [--]<configs>...OPTIONS--fail-fastfail fast on any errors--includes-base-dir <includes>base directory used for includes-r <threads>, --threads <threads>thread count--root-dir <root>root directory used output/includes (includes can be overridden)--timeout <timeout>execution timeout (minutes)-v, --verboseverbose mode--This option can be used to separate command-line options from thelist of argument, (useful when arguments might be mistaken forcommand-line options<configs>Generator configuration files.
Example:
# create "shared" configmkdir shared && cat > shared/common.yaml <<EOFinputSpec: https://raw.githubusercontent.com/OpenAPITools/openapi-generator/master/modules/openapi-generator/src/test/resources/2_0/petstore.yamladditionalProperties:x-ext-name: "Your Name"EOF# create "standard" configscat > kotlin.yaml <<EOF'!include': 'shared/common.yaml'outputDir: out/kotlingeneratorName: kotlinartifactId: kotlin-petstore-stringadditionalProperties:dateLibrary: stringserializableModel: "true"EOFcat > csharp.yaml <<EOF'!include': 'shared/common.yaml'outputDir: out/csharp-netcoregeneratorName: csharp-netcoreadditionalProperties:packageGuid: "{321C8C3F-0156-40C1-AE42-D59761FB9B6C}"useCompareNetObjects: "true"EOF# Generate themopenapi-generator batch *.yaml