-
Notifications
You must be signed in to change notification settings - Fork 310
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
Type string byte in swagger file implies Base64 not Base16/Hex #2298
Comments
Indeed, this is one of the early implementation choices we made, which breaks compatibility with JSONPB, i.e. what grpc-gateways interprets based on the protos from which the Swagger file is generated. LoRaWAN specific types are indeed hex encoded in our API. We should somehow instruct the Swagger generator to reflect that. PS please follow the issue template for future issues. |
When you browse the code on github, click on a line number, and then choose "Reference in new issue", the issue template is not filled in, so it's very difficult to keep to it using this workflow. |
@htdvisser can you give @neoaggelos some pointers to fix the Swagger file generation? |
That's all done by https://github.com/grpc-ecosystem/grpc-gateway |
Right, so are we forking this to adapt for proto fields indicating non-standard types? |
Hey @jpmeijers May I ask what command you are using to generate code from the API swagger file? |
@neoaggelos you can try pasting our Swagger file here and use Generate Client in the top menu |
Okay, so this is an issue with https://github.com/go-swagger/go-swagger, as the original Java And this is where the issue originates from https://github.com/go-swagger/go-swagger/blob/468a61360689c96f4e1a7350feeadf8eebb44b50/generator/formats.go#L142 |
How should we proceed with this? cc @htdvisser @johanstokking |
Fork and fix, I'm afraid. Alternatively, run a script to "fix" the generated Swagger files. That might be cleaner until we remove our custom sauce in V4. |
I'm running into this same issue, as well as other related field type mismatch issues, when generating Kotlin client code from the Swagger file. I also tried using the proto files to generate Kotlin classes, but after a long struggle the generated code is unusable. Currently it seems like I'll have to make do with the code generated from the swagger file, and then manually go through them all and fix the types.
|
Yep, the generated Swagger is plain wrong. We should either pick this up or remove Swagger for the time being, because currently this is useless. |
References also #2798 |
Oh wow a mess this gogo situation is causing (oops, clicked close by accident) |
As a side note, I find the swagger file still very helpful. The reason is that swagger can by compiled into simple POJO or other simple classes with which can then parse the TTI json objects - with some slight manual changes to them. Up until now I have not been able to build clean (no grpc/protocol buffers) classes for unmarshalling json from the proto files. |
Blocked on #2798. We're going to do some more refactoring to our protos and generated code. |
TL;DR
This issue is with Swagger, not with TTN. Swagger seems to only support Base64 for bytes, and no other formats like Base16.
Perhaps one should define it as just strings in the Swagger file, and not specifically as bytes.
Description
When one generate code according to the swagger file, the code will parse received DevAddr and DevEUI from TTN as Base64, while they are in fact Base16.
v3EndDeviceIdentifiers in the swagger file
lorawan-stack/api/api.swagger.json
Lines 9945 to 9949 in 0478dd4
Compiles to the following go, which assumes Base64
But the JSON I receive from the webhook looks like this, which is Base16/HEX
Some references
go-swagger/go-swagger#2170
OAI/OpenAPI-Specification#50
The proto definition where I assume the swagger definition is generated from
lorawan-stack/api/identifiers.proto
Lines 37 to 48 in 0478dd4
Which refers to the DevAddr type, which uses Hex/Base16 to marshal to json
lorawan-stack/pkg/types/devaddr.go
Lines 60 to 61 in 0478dd4
The same is true for the EUI type - it is also marshalled to HEX.
The text was updated successfully, but these errors were encountered: