Skip to content
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

Client code generation #63

Open
thibauult opened this issue Feb 5, 2024 · 2 comments
Open

Client code generation #63

thibauult opened this issue Feb 5, 2024 · 2 comments

Comments

@thibauult
Copy link

Hi @ZeroOne3010,

I'm Thibault, the maintainer of OpenHue. I've been actively working on the openhue-api project, an OpenAPI spec for the Philips Hue REST API (v2).

Recently, I've been thinking about how beneficial it could be for your project to leverage this OpenAPI specification. By automatically generating the client code, it could alleviate the burden of writing and maintaining this aspect of the code in your project.

I'm more than willing to help with the integration of the OpenHue OpenAPI specification into your project!

Best,
@thibauult

@ZeroOne3010
Copy link
Owner

Hey, thanks for reaching out and sharing about the project, Thibault! 😃 I can definitely see how that would be complementary to Yet Another Hue API. I'm not sure, however, if it's a bit late at this point, now that the most important parts of the new Hue API have already been implemented... Also, in the past I've had bad experiences trying to generate good code from any non-trivial OpenAPI spec, but I attribute that to the generators.

I would, one day, should I find to much extra time in my hands, love to have a go at creating a code generator myself, though: I'd like a generator that would just make me the DTOs as clean, Jackson-annotated classes. Like, leave the network traffic part out of it, allowing people to use Spring or plain Jackson or some other compatible framework. Possibly even leaving out the Jackson annotations so one could use other deserialization libraries too... 🤔

But at least the openhue-api will become really useful when debugging and trying to understand the API! I can see myself loading it to Postman, for example -- I admit so far I've only used the rather dreadful /clip/v2/ service that the Bridge providers via a browser form... 🙈

So anyway thank you again for reaching out and let me know if you have any further ideas or comments!

@thibauult
Copy link
Author

thibauult commented Feb 5, 2024

now that the most important parts of the new Hue API have already been implemented

Absolutely no worries! I understand that you are almost ready to release the v3 version of your library that now relies on the Hue Clip V2 API, very well done for that 👏

I'd like a generator that would just make me the DTOs as clean, Jackson-annotated classes.

This would be definitely possible using the OpenAPI Generator Maven Plugin, that has an option to generate the models only (cf. generateModels). Then it would also be possible to override the default code generation templates so that they don't generate code with Jackson dependencies.

I actually started the spec to develop the openhue-cli project, where I generate the Go client-side code. This actually helps me verify if the spec is valid or not.

But at least the openhue-api will become really useful when debugging and trying to understand the API!

That's indeed one the main goal of the openhue-api! I made a short YouTube video explaining how to load the spec inside Postman. You can also easily browse the spec from the Swagger Editor.

Each new release of the spec is automatically deployed and accessible via this URL.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants