-
-
Notifications
You must be signed in to change notification settings - Fork 6.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make RestApplication class generation configurable #20408
Comments
to skip a particular file from being generated, what about using |
It's a nice idea for a workaround, but it doesn't appear to work.
in the openapi-generator-maven-plugin pom.xml configuration, with I'll play about some more. Edit: Ah, I see https://github.com/openapitools/openapi-generator/blob/master/docs/customization.md#ignore-file-format notes "The .openapi-generator-ignore file must exist in the root of the output directory." |
you can also pre-populate the ignore file using the option |
Well I have tried the CLI with I have also tried using using the openapi-generator-maven-plugin and nothing I have tired works. Does "doNotOverwrite" also apply to 'ignore'? |
you need to provide the full path to the file e..g |
Despite the docs saying different?
Anyway, I have tried multiple combinations, and nothing seems to achieve the desired result. Maybe I should create a reproducible test case. |
the following works for me
as confirmed by the output log
can you please give it a try
I always specify the full path so not even aware of this (i wasn't the one who add the ignore file support). will review and update the documentation accordingly. my guess is that someone filed a change before which may have changed this documented behavior. |
Okay, I have some success with the CLI, but it's a relative path, not a full path, and is relative to the output root. If fixing the docs I would be explicit about that. So yes, using the CLI with something like:
does yield:
I thought I had tried all manner of paths including that, but maybe not. Thanks for your patience. However, our build uses the openapi-generator-maven-plugin, and even given that I could properly specify ignore list in a .openapi-generator-ignore file, the plugin still insists on writing (and presumably using) target/generated-sources/openapi/.openapi-generator-ignore and ignores entirely the value of which according to
Am I misinterpreting what that means? How else might I tell the plugin to similarly ignore the generation of RestApplication.java? |
can you share your pom.xml? did you use the (another workaround is simply delete the file via command for example after the code generation process completes) |
Again, thanks for your patience. I had
as a configOptions. In case anyone else stumbles across this, the correct structure is:
Obviously, in our case that would mean adding such a line to all the openapi definitions, and as you say we could also have added, say, an ant task to delete the generated file before further compilation, but these are workarounds. There are a number of comments on #17646 indicating the same issue. Is it possible to make the generation configurable? |
technically we can but still you need to set it (another line in pom.xml) so not much difference than using openapiGeneratorIgnoreList (we want to avoid adding an option to skip a file or 2 as that would result in too many options per generator) |
I understand your point, but any workaround needs to be applied to all openapi-defined endpoint pom.xml files as the package and therefore relative paths would be different in each case. A generation configuration could be set in a parent pom.xml. As it is, the generation assumes that the currently-being-generated endpoint is the sole arbiter of the entire application's path, which is, I would suggest, an unrealistic prospect. |
#17646
made the generation of a RestApplication class mandatory. This causes an issue when an application has more than one OpenAPI defined endpoint.
For example, with multiple OpenAPI defined endpoints and an existing @ApplicationPath annotated class intended to group those endpoints under a common '/rest' path prefix, using openapi-generator-maven-plugin 7.3.0 or greater will fail to deploy because there will be multiple generated RestApplication class conflicting with the existing @ApplicationPath annotated class:
6-Aug-2024 21:09:58.596 SEVERE [http-nio-8080-exec-4] org.apache.openejb.observer.ObserverManager$MethodInvocation.invoke error invoking org.apache.tomee.webservices.TomeeJaxRsService@2fb68ec6
org.apache.cxf.service.factory.ServiceConstructionException
...
Caused by: org.apache.cxf.service.factory.ServiceConstructionException: There is an endpoint already running on http://localhost:8080/rest.
The mandatory generation of a RestApplication implies a single OpenAPI defined endpoint, and this solipsistic approach means to continue to use an endpoint common path prefix requires one and only one of the defined endpoints to be nominated as the 'chosen one' to define the path prefix;
This is clumsy and non-obvious.
It would be cleaner and more flexible to simply provide a configuration option to disable the RestApplication generation.
The text was updated successfully, but these errors were encountered: