-
Notifications
You must be signed in to change notification settings - Fork 541
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
Use generator with nitro openapi #2912
Comments
@maximersetec Can you provide a simple repo with |
Actually what he has used (I mean that Zod or something) is not important. The important thing is, we need dynamic variables work in DefineRouteMeta. Now in DefineRouteMeta, it only accept static string. For example:
This will work. Because is doesn't contains any variables. However if:
Or even:
In both situation, they won't work because of variables. |
For your information, I have copied an example that I use in another issue. Acutally, with this issue, there are 5 issues that are requiring for dynamic DefineRouteMeta function. That's why I said this function is very necessary. |
@AkarinServer I will try to dive into it :) |
Ok, @AkarinServer @maximersetec, I found the root cause of this issue. Unfortunately, this can't be resolved without core changes 😢 Let me explain why. The This code takes the export default {"openAPI":{"summary":"Login","requestBody":{"content":{"application/json":{"schema":{"type":"object"}}}}}}; This code is then injected into the The AST could export these variables as additional exports from the file, but this would require significantly more changes than I initially anticipated. I have some ideas for how to approach this, but @pi0 should take a look and decide if it's worth pursuing. |
I found a solution in my case: I create a new api route that fetches me _openapi.json and modifies or adds elements from my generator.
I can show you this in a future post if you're interested, but the idea was to be able to modify directly without going through a wrapper that fetches
Envoyé à partir de Outlook pour Android<https://aka.ms/AAb9ysg>
…________________________________
From: Oskar Lebuda ***@***.***>
Sent: Thursday, December 5, 2024 7:46:48 PM
To: nitrojs/nitro ***@***.***>
Cc: RAMOS Maxime ***@***.***>; Mention ***@***.***>
Subject: Re: [nitrojs/nitro] Use generator with nitro openapi (Issue #2912)
Ok @AkarinServer<https://github.com/AkarinServer> @maximersetec<https://github.com/maximersetec> I found the reason of that. Without core changes this couldn't be done unfortunately 😢 Let me tell you why. defineRouteMeta is transformed using AST as a rollup plugin for nitro. There is the transform:
https://github.com/nitrojs/nitro/blob/v2/src/rollup/plugins/handlers-meta.ts#L58
This code takes defineRouteMeta expression statement and creates an object from that. The output code is injected into bundled code and looks like this:
export default {"openAPI":{"summary":"Login","requestBody":{"content":{"application/json":{"schema":{"type":"object"}}}}}};
Then this code is injected into index.mjs file right here: https://github.com/nitrojs/nitro/blob/v2/src/rollup/plugins/handlers.ts#L102
The AST could export that variables as additional export from file, but this is way to much changes then I thought before. I have some ideas for that but @pi0<https://github.com/pi0> should looks at that and told if it's worth.
—
Reply to this email directly, view it on GitHub<#2912 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/BNEYQNQCSKMWWCY3LIKW3P32ECNRRAVCNFSM6AAAAABS23E3VCVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDKMRRGE2TQMBXGI>.
You are receiving this because you were mentioned.Message ID: ***@***.***>
|
Hello, could you show me how you did this? |
Moving to #2974 |
Describe the feature
Question
Is it possible to configure Nitro OpenAPI to use a generator from
@asteasolutions/zod-to-openapi
to automatically add OpenAPI objects to one or more routes?Example Code
The text was updated successfully, but these errors were encountered: