mirror of
https://github.com/OpenAPITools/openapi-generator.git
synced 2025-10-23 21:03:41 +00:00
299 lines
36 KiB
HTML
299 lines
36 KiB
HTML
<!DOCTYPE html><html lang="en"><head><meta charSet="utf-8"/><meta http-equiv="X-UA-Compatible" content="IE=edge"/><title>Customization · OpenAPI Generator</title><meta name="viewport" content="width=device-width"/><meta name="generator" content="Docusaurus"/><meta name="description" content="<a id="creating-a-new-template"></a><!-- maintain old link ref name.-->"/><meta name="docsearch:language" content="en"/><meta property="og:title" content="Customization · OpenAPI Generator"/><meta property="og:type" content="website"/><meta property="og:url" content="https://openapi-generator.tech/"/><meta property="og:description" content="<a id="creating-a-new-template"></a><!-- maintain old link ref name.-->"/><meta property="og:image" content="https://openapi-generator.tech/img/docusaurus.png"/><meta name="twitter:card" content="summary"/><meta name="twitter:image" content="https://openapi-generator.tech/img/icons/twitter.svg"/><link rel="shortcut icon" href="/img/favicon.png"/><link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/default.min.css"/><link rel="alternate" type="application/atom+xml" href="https://openapi-generator.tech/blog/atom.xml" title="OpenAPI Generator Blog ATOM Feed"/><link rel="alternate" type="application/rss+xml" href="https://openapi-generator.tech/blog/feed.xml" title="OpenAPI Generator Blog RSS Feed"/><script>
|
||
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
|
||
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
|
||
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
|
||
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
|
||
|
||
ga('create', 'UA-132927057-1', 'auto');
|
||
ga('send', 'pageview');
|
||
</script><script type="text/javascript" src="https://buttons.github.io/buttons.js"></script><script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.0/clipboard.min.js"></script><script type="text/javascript" src="/js/code-block-buttons.js"></script><script src="https://unpkg.com/vanilla-back-to-top@7.1.14/dist/vanilla-back-to-top.min.js"></script><script>
|
||
document.addEventListener('DOMContentLoaded', function() {
|
||
addBackToTop(
|
||
{"zIndex":100}
|
||
)
|
||
});
|
||
</script><script src="/js/scrollSpy.js"></script><link rel="stylesheet" href="/css/main.css"/><script src="/js/codetabs.js"></script></head><body class="sideNavVisible separateOnPageNav"><div class="fixedHeaderContainer"><div class="headerWrapper wrapper"><header><a href="/"><img class="logo" src="/img/mono-logo.svg" alt="OpenAPI Generator"/><h2 class="headerTitleWithLogo">OpenAPI Generator</h2></a><div class="navigationWrapper navigationSlider"><nav class="slidingNav"><ul class="nav-site nav-site-internal"><li class="siteNavGroupActive"><a href="/docs/installation" target="_self">Get Started</a></li><li class="siteNavGroupActive"><a href="/docs/generators" target="_self">Generators</a></li><li class="siteNavGroupActive"><a href="/docs/roadmap" target="_self">Roadmap</a></li><li class=""><a href="/team" target="_self">Team</a></li><li class=""><a href="/docs/faq" target="_self">FAQ</a></li><li class=""><a href="/blog/" target="_self">Blog</a></li></ul></nav></div></header></div></div><div class="navPusher"><div class="docMainWrapper wrapper"><div class="docsNavContainer" id="docsNav"><nav class="toc"><div class="toggleNav"><section class="navWrapper wrapper"><div class="navBreadcrumb wrapper"><div class="navToggle" id="navToggler"><div class="hamburger-menu"><div class="line1"></div><div class="line2"></div><div class="line3"></div></div></div><h2><i>›</i><span>Extending</span></h2><div class="tocToggler" id="tocToggler"><i class="icon-toc"></i></div></div><div class="navGroups"><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">Getting Started<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/installation">CLI Installation</a></li><li class="navListItem"><a class="navItem" href="/docs/plugins">Plugins</a></li><li class="navListItem"><a class="navItem" href="/docs/online">Online</a></li><li class="navListItem"><a class="navItem" href="/docs/usage">Usage</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">Extending<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/templating">Using Templates</a></li><li class="navListItem navListItemActive"><a class="navItem" href="/docs/customization">Customization</a></li><li class="navListItem"><a class="navItem" href="/docs/debugging">Debugging</a></li><li class="navListItem"><a class="navItem" href="/docs/integrations">Workflow Integrations</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">Contributing<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/contributing">Guidelines</a></li><li class="navListItem"><a class="navItem" href="/docs/code-of-conduct">Code of Conduct</a></li><li class="navListItem"><a class="navItem" href="/docs/contribute-building">Building the code</a></li><li class="navListItem"><a class="navItem" href="/docs/new-generator">Create a New Generator</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">About<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/roadmap">Roadmap</a></li><li class="navListItem"><a class="navItem" href="/docs/swagger-codegen-migration">Migrating from Swagger Codegen</a></li><li class="navListItem"><a class="navItem" href="/docs/fork-qna">Swagger Codegen Fork: Q&A</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">Releases<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/release-summary">Release Summary</a></li><li class="navListItem"><a class="navItem" href="/docs/release-3-0-0">Release Notes: 3.0.0</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">API<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/generators">Generators List</a></li></ul></div></div></section></div><script>
|
||
var coll = document.getElementsByClassName('collapsible');
|
||
var checkActiveCategory = true;
|
||
for (var i = 0; i < coll.length; i++) {
|
||
var links = coll[i].nextElementSibling.getElementsByTagName('*');
|
||
if (checkActiveCategory){
|
||
for (var j = 0; j < links.length; j++) {
|
||
if (links[j].classList.contains('navListItemActive')){
|
||
coll[i].nextElementSibling.classList.toggle('hide');
|
||
coll[i].childNodes[1].classList.toggle('rotate');
|
||
checkActiveCategory = false;
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
|
||
coll[i].addEventListener('click', function() {
|
||
var arrow = this.childNodes[1];
|
||
arrow.classList.toggle('rotate');
|
||
var content = this.nextElementSibling;
|
||
content.classList.toggle('hide');
|
||
});
|
||
}
|
||
|
||
document.addEventListener('DOMContentLoaded', function() {
|
||
createToggler('#navToggler', '#docsNav', 'docsSliderActive');
|
||
createToggler('#tocToggler', 'body', 'tocActive');
|
||
|
||
var headings = document.querySelector('.toc-headings');
|
||
headings && headings.addEventListener('click', function(event) {
|
||
var el = event.target;
|
||
while(el !== headings){
|
||
if (el.tagName === 'A') {
|
||
document.body.classList.remove('tocActive');
|
||
break;
|
||
} else{
|
||
el = el.parentNode;
|
||
}
|
||
}
|
||
}, false);
|
||
|
||
function createToggler(togglerSelector, targetSelector, className) {
|
||
var toggler = document.querySelector(togglerSelector);
|
||
var target = document.querySelector(targetSelector);
|
||
|
||
if (!toggler) {
|
||
return;
|
||
}
|
||
|
||
toggler.onclick = function(event) {
|
||
event.preventDefault();
|
||
|
||
target.classList.toggle(className);
|
||
};
|
||
}
|
||
});
|
||
</script></nav></div><div class="container mainContainer docsContainer"><div class="wrapper"><div class="post"><header class="postHeader"><h1 id="__docusaurus" class="postHeaderTitle">Customization</h1></header><article><div><span><p><a id="creating-a-new-template"></a><!-- maintain old link ref name.--></p>
|
||
<h2><a class="anchor" aria-hidden="true" id="custom-generator-and-template"></a><a href="#custom-generator-and-template" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Custom Generator (and Template)</h2>
|
||
<p>If none of the built-in generators suit your needs and you need to do more than just modify the mustache templates to tweak generated code, you can create a brand new generator and its associated templates. OpenAPI Generator can help with this, using the <code>meta</code> command:</p>
|
||
<pre><code class="hljs css language-sh">java -jar modules/openapi-generator-cli/target/openapi-generator-cli.jar meta \
|
||
-o out/generators/my-codegen -n my-codegen -p com.my.company.codegen
|
||
</code></pre>
|
||
<p>This will create a new directory <code>out/generators/my-codegen</code>, with all the files you need to get started - including a <code>README.md</code>. Once modified and compiled, you can use your new codegen just like any other, with your own custom-rolled logic.</p>
|
||
<p>These names can be anything you like. If you are building a client for the whitespace language, maybe you'd use the options <code>-o out/generators/whitespace -n whitespace</code>. They can be the same, or different, it doesn't matter. The <code>-n</code> value will be become the template name.</p>
|
||
<p><strong>NOTE</strong> Convention is to use kebab casing for names passed to <code>-n</code>. Example, <code>scala-finatra</code> would become <code>ScalaFinatraGenerator</code>.</p>
|
||
<h3><a class="anchor" aria-hidden="true" id="use-your-new-generator-with-the-cli"></a><a href="#use-your-new-generator-with-the-cli" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Use your new generator with the CLI</h3>
|
||
<p>To compile your library, enter the <code>out/generators/my-codegen</code> directory, run <code>mvn package</code> and execute the generator:</p>
|
||
<pre><code class="hljs css language-sh">java -cp out/generators/my-codegen/target/my-codegen-openapi-generator-1.0.0.jar:modules/openapi-generator-cli/target/openapi-generator-cli.jar org.openapitools.codegen.OpenAPIGenerator
|
||
</code></pre>
|
||
<p>For Windows users, you will need to use <code>;</code> instead of <code>:</code> in the classpath, e.g.</p>
|
||
<pre><code class="hljs">java -cp <span class="hljs-keyword">out</span>/generators/my-codegen/target/my-codegen-openapi-generator<span class="hljs-number">-1.0</span><span class="hljs-number">.0</span>.jar;modules/openapi-generator-cli/target/openapi-generator-cli.jar org.openapitools.codegen.OpenAPIGenerator
|
||
</code></pre>
|
||
<p>Note the <code>my-codegen</code> is an option for <code>-g</code> now, and you can use the usual arguments for generating your code:</p>
|
||
<pre><code class="hljs css language-sh">java -cp out/codegens/customCodegen/target/my-codegen-openapi-generator-1.0.0.jar:modules/openapi-generator-cli/target/openapi-generator-cli.jar \
|
||
org.openapitools.codegen.OpenAPIGenerator generate -g my-codegen \
|
||
-i https://raw.githubusercontent.com/openapitools/openapi-generator/master/modules/openapi-generator/src/<span class="hljs-built_in">test</span>/resources/2_0/petstore.yaml \
|
||
-o ./out/myClient
|
||
</code></pre>
|
||
<p>For Windows users:</p>
|
||
<pre><code class="hljs">java -cp out<span class="hljs-regexp">/codegens/</span>customCodegen<span class="hljs-regexp">/target/</span>my-codegen-openapi-generator<span class="hljs-number">-1.0</span><span class="hljs-number">.0</span>.jar;modules<span class="hljs-regexp">/openapi-generator-cli/</span>target/openapi-generator-cli.jar \
|
||
org.openapitools.codegen.OpenAPIGenerator generate -g my-codegen \
|
||
-i <span class="hljs-string">https:</span><span class="hljs-comment">//raw.githubusercontent.com/openapitools/openapi-generator/master/modules/openapi-generator/src/test/resources/2_0/petstore.yaml \</span>
|
||
-o .<span class="hljs-regexp">/out/</span>myClient
|
||
</code></pre>
|
||
<h3><a class="anchor" aria-hidden="true" id="use-your-new-generator-with-the-maven-plugin"></a><a href="#use-your-new-generator-with-the-maven-plugin" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Use your new generator with the maven plugin</h3>
|
||
<p>Install your library to your local maven repository by running:</p>
|
||
<pre><code class="hljs">mvn clean <span class="hljs-keyword">install</span> -f <span class="hljs-keyword">out</span>/generators/my-codegen
|
||
</code></pre>
|
||
<p>This will install <code>org.openapitools:my-codegen-openapi-generator:1.0.0</code> to your local maven repository.</p>
|
||
<p>You can use this as additional dependency of the <code>openapi-generator-maven-plugin</code> plugin and use <code>my-codegen</code> as <code>generatorName</code> value:</p>
|
||
<pre><code class="hljs css language-xml"><span class="hljs-tag"><<span class="hljs-name">plugin</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">groupId</span>></span>org.openapitools<span class="hljs-tag"></<span class="hljs-name">groupId</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">artifactId</span>></span>openapi-generator-maven-plugin<span class="hljs-tag"></<span class="hljs-name">artifactId</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">version</span>></span>${openapi-generator-version}<span class="hljs-tag"></<span class="hljs-name">version</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">executions</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">execution</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">id</span>></span>generate-client-code<span class="hljs-tag"></<span class="hljs-name">id</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">goals</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">goal</span>></span>generate<span class="hljs-tag"></<span class="hljs-name">goal</span>></span>
|
||
<span class="hljs-tag"></<span class="hljs-name">goals</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">configuration</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">generatorName</span>></span>my-codegen<span class="hljs-tag"></<span class="hljs-name">generatorName</span>></span>
|
||
<span class="hljs-comment"><!-- other configuration ... --></span>
|
||
<span class="hljs-tag"></<span class="hljs-name">configuration</span>></span>
|
||
<span class="hljs-tag"></<span class="hljs-name">execution</span>></span>
|
||
<span class="hljs-tag"></<span class="hljs-name">executions</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">dependencies</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">dependency</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">groupId</span>></span>org.openapitools<span class="hljs-tag"></<span class="hljs-name">groupId</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">artifactId</span>></span>my-codegen-openapi-generator<span class="hljs-tag"></<span class="hljs-name">artifactId</span>></span>
|
||
<span class="hljs-tag"><<span class="hljs-name">version</span>></span>1.0.0<span class="hljs-tag"></<span class="hljs-name">version</span>></span>
|
||
<span class="hljs-tag"></<span class="hljs-name">dependency</span>></span>
|
||
<span class="hljs-tag"></<span class="hljs-name">dependencies</span>></span>
|
||
<span class="hljs-tag"></<span class="hljs-name">plugin</span>></span>
|
||
</code></pre>
|
||
<p>If you publish your artifact to a distant maven repository, do not forget to add this repository as <code>pluginRepository</code> for your project.</p>
|
||
<h2><a class="anchor" aria-hidden="true" id="selective-generation"></a><a href="#selective-generation" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Selective generation</h2>
|
||
<p>You may not want to generate <em>all</em> models in your project. Likewise you may want just one or two apis to be written. If that's the case, you can use system properties to control the output:</p>
|
||
<p>The default is generate <em>everything</em> supported by the specific library. Once you enable a feature, it will restrict the contents generated:</p>
|
||
<pre><code class="hljs css language-sh"><span class="hljs-comment"># generate only models</span>
|
||
java -Dmodels {opts}
|
||
|
||
<span class="hljs-comment"># generate only apis</span>
|
||
java -Dapis {opts}
|
||
|
||
<span class="hljs-comment"># generate only supporting files</span>
|
||
java -DsupportingFiles
|
||
|
||
<span class="hljs-comment"># generate models and supporting files</span>
|
||
java -Dmodels -DsupportingFiles
|
||
</code></pre>
|
||
<p>To control the specific files being generated, you can pass a CSV list of what you want:</p>
|
||
<pre><code class="hljs css language-sh"><span class="hljs-comment"># generate the User and Pet models only</span>
|
||
-Dmodels=User,Pet
|
||
|
||
<span class="hljs-comment"># generate the User model and the supportingFile `StringUtil.java`:</span>
|
||
-Dmodels=User -DsupportingFiles=StringUtil.java
|
||
</code></pre>
|
||
<p>To control generation of docs and tests for api and models, pass false to the option. For api, these options are <code>-DapiTests=false</code> and <code>-DapiDocs=false</code>. For models, <code>-DmodelTests=false</code> and <code>-DmodelDocs=false</code>.
|
||
These options default to true and don't limit the generation of the feature options listed above (like <code>-Dapi</code>):</p>
|
||
<pre><code class="hljs css language-sh"><span class="hljs-comment"># generate only models (with tests and documentation)</span>
|
||
java -Dmodels {opts}
|
||
|
||
<span class="hljs-comment"># generate only models (with tests but no documentation)</span>
|
||
java -Dmodels -DmodelDocs=<span class="hljs-literal">false</span> {opts}
|
||
|
||
<span class="hljs-comment"># generate only User and Pet models (no tests and no documentation)</span>
|
||
java -Dmodels=User,Pet -DmodelTests=<span class="hljs-literal">false</span> {opts}
|
||
|
||
<span class="hljs-comment"># generate only apis (without tests)</span>
|
||
java -Dapis -DapiTests=<span class="hljs-literal">false</span> {opts}
|
||
|
||
<span class="hljs-comment"># generate only apis (modelTests option is ignored)</span>
|
||
java -Dapis -DmodelTests=<span class="hljs-literal">false</span> {opts}
|
||
</code></pre>
|
||
<p>When using selective generation, <em>only</em> the templates needed for the specific generation will be used.</p>
|
||
<p>To skip models defined as the form parameters in "requestBody", please use <code>skipFormModel</code> (default to false) (this option is introduced at v3.2.2)</p>
|
||
<pre><code class="hljs css language-sh">java -DskipFormModel=<span class="hljs-literal">true</span>
|
||
</code></pre>
|
||
<p>This option will be helpful to skip model generation due to the form parameter, which is defined differently in OAS3 as there's no form parameter in OAS3</p>
|
||
<h2><a class="anchor" aria-hidden="true" id="ignore-file-format"></a><a href="#ignore-file-format" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Ignore file format</h2>
|
||
<p>OpenAPI Generator supports a <code>.openapi-generator-ignore</code> file, similar to <code>.gitignore</code> or <code>.dockerignore</code> you're probably already familiar with.</p>
|
||
<p>The ignore file allows for better control over overwriting existing files than the <code>--skip-overwrite</code> flag. With the ignore file, you can specify individual files or directories can be ignored. This can be useful, for example if you only want a subset of the generated code.</p>
|
||
<p>Examples:</p>
|
||
<pre><code class="hljs css language-sh"><span class="hljs-comment"># OpenAPI Generator Ignore</span>
|
||
<span class="hljs-comment"># Lines beginning with a # are comments</span>
|
||
|
||
<span class="hljs-comment"># This should match build.sh located anywhere.</span>
|
||
build.sh
|
||
|
||
<span class="hljs-comment"># Matches build.sh in the root</span>
|
||
/build.sh
|
||
|
||
<span class="hljs-comment"># Exclude all recursively</span>
|
||
docs/**
|
||
|
||
<span class="hljs-comment"># Explicitly allow files excluded by other rules</span>
|
||
!docs/UserApi.md
|
||
|
||
<span class="hljs-comment"># Recursively exclude directories named Api</span>
|
||
<span class="hljs-comment"># You can't negate files below this directory.</span>
|
||
src/**/Api/
|
||
|
||
<span class="hljs-comment"># When this file is nested under /Api (excluded above),</span>
|
||
<span class="hljs-comment"># this rule is ignored because parent directory is excluded by previous rule.</span>
|
||
!src/**/PetApiTests.cs
|
||
|
||
<span class="hljs-comment"># Exclude a single, nested file explicitly</span>
|
||
src/Org.OpenAPITools.Test/Model/AnimalFarmTests.cs
|
||
</code></pre>
|
||
<p>The <code>.openapi-generator-ignore</code> file must exist in the root of the output directory.</p>
|
||
<p>Upon first code generation, you may also pass the CLI option <code>--ignore-file-override=/path/to/ignore_file</code> for greater control over generated outputs. Note that this is a complete override, and will override the <code>.openapi-generator-ignore</code> file in an output directory when regenerating code.</p>
|
||
<p>Editor support for <code>.openapi-generator-ignore</code> files is available in IntelliJ via the <a href="https://plugins.jetbrains.com/plugin/7495--ignore">.ignore plugin</a>.</p>
|
||
<h2><a class="anchor" aria-hidden="true" id="customizing-the-generator"></a><a href="#customizing-the-generator" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Customizing the generator</h2>
|
||
<p>There are different aspects of customizing the code generator beyond just creating or modifying templates. Each language has a supporting configuration file to handle different type mappings, etc:</p>
|
||
<pre><code class="hljs css language-sh">$ ls -1 modules/openapi-generator/src/main/java/org/openapitools/codegen/languages/
|
||
AbstractJavaJAXRSServerCodegen.java
|
||
AbstractTypeScriptClientCodegen.java
|
||
... (results omitted)
|
||
TypeScriptAngularClientCodegen.java
|
||
TypeScriptNodeClientCodegen.java
|
||
</code></pre>
|
||
<p>Each of these files creates reasonable defaults so you can get running quickly. But if you want to configure package names, prefixes, model folders, etc. you can use a json config file to pass the values.</p>
|
||
<pre><code class="hljs css language-sh">java -jar modules/openapi-generator-cli/target/openapi-generator-cli.jar generate \
|
||
-i https://raw.githubusercontent.com/openapitools/openapi-generator/master/modules/openapi-generator/src/<span class="hljs-built_in">test</span>/resources/2_0/petstore.yaml \
|
||
-g java \
|
||
-o samples/client/petstore/java \
|
||
-c path/to/config.json
|
||
</code></pre>
|
||
<p>and <code>config.json</code> contains the following as an example:</p>
|
||
<pre><code class="hljs css language-json">{
|
||
<span class="hljs-attr">"apiPackage"</span> : <span class="hljs-string">"petstore"</span>
|
||
}
|
||
</code></pre>
|
||
<p>You can use also <code>config.yml</code> with following equivalent example:</p>
|
||
<pre><code class="hljs css language-yaml"><span class="hljs-attr">apiPackage:</span> <span class="hljs-string">"petstore"</span>
|
||
</code></pre>
|
||
<p>Supported config options can be different per language. Running <code>config-help -g {lang}</code> will show available options.
|
||
<strong>These options are applied via configuration file (e.g. config.json or config.yml) or by passing them with <code>-D{optionName}={optionValue}</code></strong>. (If <code>-D{optionName}</code> does not work, please open a <a href="https://github.com/openapitools/openapi-generator/issues/new">ticket</a> and we'll look into it)</p>
|
||
<pre><code class="hljs css language-sh">java -jar modules/openapi-generator-cli/target/openapi-generator-cli.jar config-help -g java
|
||
</code></pre>
|
||
<p>Output</p>
|
||
<pre><code class="hljs">CONFIG OPTIONS
|
||
modelPackage
|
||
package <span class="hljs-keyword">for</span> generated models
|
||
|
||
apiPackage
|
||
package <span class="hljs-keyword">for</span> generated api classes
|
||
...... (results omitted)
|
||
library
|
||
library template (sub-template) to use:
|
||
jersey1 - HTTP client: Jersey client <span class="hljs-number">1.18</span>. JSON processing: Jackson <span class="hljs-number">2.4</span><span class="hljs-number">.2</span>
|
||
jersey2 - HTTP client: Jersey client <span class="hljs-number">2.6</span>
|
||
feign - HTTP client: Netflix Feign <span class="hljs-number">8.1</span><span class="hljs-number">.1</span>. JSON processing: Jackson <span class="hljs-number">2.6</span><span class="hljs-number">.3</span>
|
||
okhttp-gson (<span class="hljs-keyword">default</span>) - HTTP client: OkHttp <span class="hljs-number">2.4</span><span class="hljs-number">.0</span>. JSON processing: Gson <span class="hljs-number">2.3</span><span class="hljs-number">.1</span>
|
||
retrofit - HTTP client: OkHttp <span class="hljs-number">2.4</span><span class="hljs-number">.0</span>. JSON processing: Gson <span class="hljs-number">2.3</span><span class="hljs-number">.1</span> (Retrofit <span class="hljs-number">1.9</span><span class="hljs-number">.0</span>)
|
||
retrofit2 - HTTP client: OkHttp <span class="hljs-number">2.5</span><span class="hljs-number">.0</span>. JSON processing: Gson <span class="hljs-number">2.4</span> (Retrofit <span class="hljs-number">2.0</span><span class="hljs-number">.0</span>-beta2)
|
||
google-api-client - HTTP client: google-api-client <span class="hljs-number">1.23</span><span class="hljs-number">.0</span>. JSON processing: Jackson <span class="hljs-number">2.8</span><span class="hljs-number">.9</span>
|
||
rest-assured - HTTP client: rest-assured : <span class="hljs-number">4.0</span><span class="hljs-number">.0</span>. JSON processing: Gson <span class="hljs-number">2.8</span><span class="hljs-number">.5</span>. Only <span class="hljs-keyword">for</span> Java8
|
||
</code></pre>
|
||
<p>Your config file for Java can look like</p>
|
||
<pre><code class="hljs css language-json">{
|
||
<span class="hljs-attr">"groupId"</span>:<span class="hljs-string">"com.my.company"</span>,
|
||
<span class="hljs-attr">"artifactId"</span>:<span class="hljs-string">"MyClient"</span>,
|
||
<span class="hljs-attr">"artifactVersion"</span>:<span class="hljs-string">"1.2.0"</span>,
|
||
<span class="hljs-attr">"library"</span>:<span class="hljs-string">"feign"</span>
|
||
}
|
||
</code></pre>
|
||
<p>Or if you preffer yaml format it can look like</p>
|
||
<pre><code class="hljs css language-yaml"><span class="hljs-attr">groupId:</span> <span class="hljs-string">"com.my.company"</span>
|
||
<span class="hljs-attr">artifactId:</span> <span class="hljs-string">"MyClient"</span>
|
||
<span class="hljs-attr">artifactVersion:</span> <span class="hljs-string">"1.2.0"</span>
|
||
<span class="hljs-attr">library:</span> <span class="hljs-string">"feign"</span>
|
||
</code></pre>
|
||
<p>For all the unspecified options default values will be used.</p>
|
||
<p>Another way to override default options is to extend the config class for the specific language.
|
||
To change, for example, the prefix for the Objective-C generated files, simply subclass the <code>ObjcClientCodegen.java</code>:</p>
|
||
<pre><code class="hljs css language-java"><span class="hljs-keyword">package</span> com.mycompany.openapitools.codegen;
|
||
|
||
<span class="hljs-keyword">import</span> org.openapitools.codegen.languages.*;
|
||
|
||
<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MyObjcCodegen</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">ObjcClientCodegen</span> </span>{
|
||
<span class="hljs-keyword">static</span> {
|
||
PREFIX = <span class="hljs-string">"HELO"</span>;
|
||
}
|
||
}
|
||
</code></pre>
|
||
<p>and specify the <code>classname</code> when running the generator:</p>
|
||
<pre><code class="hljs"><span class="hljs-selector-tag">-g</span> <span class="hljs-selector-tag">com</span><span class="hljs-selector-class">.mycompany</span><span class="hljs-selector-class">.openapitools</span><span class="hljs-selector-class">.codegen</span><span class="hljs-selector-class">.MyObjcCodegen</span>
|
||
</code></pre>
|
||
<p>Your subclass will now be loaded and overrides the <code>PREFIX</code> value in the superclass.</p>
|
||
<h2><a class="anchor" aria-hidden="true" id="bringing-your-own-models"></a><a href="#bringing-your-own-models" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Bringing your own models</h2>
|
||
<p>Sometimes you don't want a model generated. In this case, you can simply specify an import mapping to tell
|
||
the codegen what <em>not</em> to create. When doing this, every location that references a specific model will
|
||
refer back to your classes. Note, this may not apply to all languages...</p>
|
||
<p>To specify an import mapping, use the <code>--import-mappings</code> argument and specify the model-to-import logic as such:</p>
|
||
<pre><code class="hljs">--<span class="hljs-built_in">import</span>-mappings <span class="hljs-attr">Pet=my.models.MyPet</span>
|
||
</code></pre>
|
||
<p>Or for multiple mappings:</p>
|
||
<pre><code class="hljs">--import-mappings Pet=my<span class="hljs-selector-class">.models</span><span class="hljs-selector-class">.MyPet</span>,Order=my<span class="hljs-selector-class">.models</span><span class="hljs-selector-class">.MyOrder</span>
|
||
</code></pre>
|
||
<p>or</p>
|
||
<pre><code class="hljs">--<span class="hljs-built_in">import</span>-mappings <span class="hljs-attr">Pet=my.models.MyPet</span> --<span class="hljs-built_in">import</span>-mappings <span class="hljs-attr">Order=my.models.MyOrder</span>
|
||
</code></pre>
|
||
</span></div></article></div><div class="docLastUpdate"><em>Last updated on 10/30/2019</em></div><div class="docs-prevnext"><a class="docs-prev button" href="/docs/templating"><span class="arrow-prev">← </span><span>Using Templates</span></a><a class="docs-next button" href="/docs/debugging"><span>Debugging</span><span class="arrow-next"> →</span></a></div></div></div><nav class="onPageNav"><ul class="toc-headings"><li><a href="#custom-generator-and-template">Custom Generator (and Template)</a><ul class="toc-headings"><li><a href="#use-your-new-generator-with-the-cli">Use your new generator with the CLI</a></li><li><a href="#use-your-new-generator-with-the-maven-plugin">Use your new generator with the maven plugin</a></li></ul></li><li><a href="#selective-generation">Selective generation</a></li><li><a href="#ignore-file-format">Ignore file format</a></li><li><a href="#customizing-the-generator">Customizing the generator</a></li><li><a href="#bringing-your-own-models">Bringing your own models</a></li></ul></nav></div><footer class="nav-footer" id="footer"><section class="sitemap"><a href="/" class="nav-home"><img src="/img/mono-logo.svg" alt="OpenAPI Generator" width="66" height="58"/></a><div><h5>Docs</h5><a href="/docs/en/customization.html">Customizing Generators</a><a href="/docs/en/integrations.html">Workflow Integrations</a></div><div><h5>Community</h5><a href="/en/users.html">User Showcase</a><a href="http://stackoverflow.com/questions/tagged/openapi-generator" target="_blank" rel="noreferrer noopener">Stack Overflow</a><a href="https://join.slack.com/t/openapi-generator/shared_invite/enQtNzAyNDMyOTU0OTE1LTY5ZDBiNDI5NzI5ZjQ1Y2E5OWVjMjZkYzY1ZGM2MWQ4YWFjMzcyNDY5MGI4NjQxNDBiMTlmZTc5NjY2ZTQ5MGM">Chat Room</a><a href="https://twitter.com/oas_generator" target="_blank" rel="noreferrer noopener">Twitter</a></div><div><h5>More</h5><a href="/blog">Blog</a><a href="https://github.com/OpenAPITools/openapi-generator">GitHub Repo</a><a class="github-button" href="https://github.com/OpenAPITools/openapi-generator" data-icon="octicon-star" data-count-href="/OpenAPITools/openapi-generator/stargazers" data-show-count="true" data-count-aria-label="# stargazers on GitHub" aria-label="Star this project on GitHub">Star</a></div></section><section class="copyright">Copyright © 2020 OpenAPI-Generator Contributors (https://openapi-generator.tech). (Both "OpenAPI Tools" (https://OpenAPITools.org) and "OpenAPI Generator" are not affiliated with OpenAPI Initiative (OAI))</section></footer></div></body></html> |