-
-
Notifications
You must be signed in to change notification settings - Fork 579
Add Swagger Support to API #220
Comments
That definitely seems a bit heavy handed, but I'm open to the idea of figuring out a good way to work with swagger. I've thought about it in the past. I would love to be able to do several things with swagger:
those are my initial thoughts. |
maybe a go start is to just generate just the routes and stub handlers with go-swagger? the work would be to create a new generation template for buffalo routes & stub handlers. I'm interested to hear thoughts |
I've been thinking about this and ran into this Github issue discussion. Just posting my thoughts as @arschles asked for. 😄 I think having api doc and generation harmonizes with the rapid nature of buffalo. Of course everyone wants to just "build their app" and work faster. I guess this isn't a revelation ... but instead it seems to come up when you start another JSON API and are wondering why am I doing this again. The problem of the tool though is in the details. (spooky dramatic comment music) You likely already know this but I think the idea behind these tools is to create docs that are executable (like specs) but also have wiring between the client and the server. And initial generation is all fine and well but you'd really want continuing enforcement in CI or something to ensure that API docs don't just bit-rot. Using swagger or RAML isn't super rapid in initial spec generation imho, I think the real win is when your API exists for a long time and you constantly have to manage a README of curl commands or resort to giving up and say "just read the source luke" which is essentially saying "there are no docs for our API". Buffalo has it's own Go source generation. So you couldn't like just generate a swagger server off a yaml file and then move that code into a buffalo project. It wouldn't sync up with the migrations anyway. So there's not a direct integration point even for the generators. But since buffalo doesn't want to be like goa where generation and commands are continually updating code, you wouldn't want that. What if you did sort of spec first development?
Ok, what if you generated the client, watched it fail against a non-existent server?
No, I think the real value of swagger (as a concept, including RAML etc) is its ability to be an executable link between the client / server and documentation. If you have a generated client and server passing tests of any kind and being used within an app, you are very confident in the API docs because they are "bit fresh". 🎈 But how do you reconcile regeneration (swagger) and no regeneration (buffalo)? Seems like it's a dead idea unless there's a proxy / handoff / option / pass-through or something where the router goes to a set of code that is not hand written by a Buffalo app dev. The two projects have an impasse on code (re)generation. Some more details:
Anyway, sorry to ramble without implementation work. I guess in summary, I wonder if the router is the best glue spot? |
@squarism I've been following this thread pretty loosely, so some really late comments:
💯% agree!
Can you expand on this? Do you mean a router that sits in front of the buffalo app? |
@arschles Yeah, I'm just not sure on where the glue points would sit. What I mean is, swagger server (the thing that serves the docs so a client could play with the API) is just a What I mean is:
This also doesn't know the difference between HTML requests and JSON for example. You'd need a separate path for the Swagger UI or inspect the request and route based on MIME type. It'd be neat if there was an assumption or option to route HTML requests to Swagger and JSON requests to Buffalo. |
Opening this for tracking. I don't yet have a proposed solution or data architecture yet.
When I've used the grpc-gateway project in the past, on of my favorite features was the auto-swagger generator. With strongly-typed requests and responses coming from Protocol Buffers, the gateway had all the information it needed to generate the API definition.
I think that an auto-documentation tool built into Buffalo would make it more developer friendly.
The most radical way we could do this would be to use grpc-gateway, use protocol buffers to generate the API definitions, and simultaneously support gRPC with REST. However, I think this seems heavy-handed.
@markbates Do you have any thoughts or opinions on this?
The text was updated successfully, but these errors were encountered: