-
Notifications
You must be signed in to change notification settings - Fork 27
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
Grpc transcoding #95
Comments
@zZHorizonZz we would be pleased to have this feature, perhaps we can discuss how the implementation should be crafted for the vertx-grpc project ? |
In my Quarkus PR, I needed to create custom During debugging, I noticed that the code attempted to read a grpc prefix from the buffer, which doesn't exist in JSON requests. To fix this, I reimplemented several classes, including However, there might still be problems in determining the correct request marshallers, unmarshallers based on its path and merging path and query parameters into the body. |
we are planning to backport grpc-web to vertx 4, so we can assume developing your PR against master can be done and then we can backport everything to vertx 4. |
Before I start implementing it, I will need to go through the code of grpc-web so that I understand it better, as I reckon the transcoding implementation will be using some elements from grpc-web. |
sure @zZHorizonZz , there might be some decoupling / refactoring necessary because the current grpc-web integration uses inheritance with calls to super to override the behaviour for grpc-web sometimes |
we can also schedule a call to discuss the plans if you are inclined |
I wouldn't mind getting into a call, although I will be busy until the end of the month, so it would be in 2-3 weeks. |
I think I should have more time this year, as last year I didn't have as much free time as I would have liked to work on this. I still think it will take some time (even more because I need to remember how the actual thing I wrote half a year ago works... 😅) Anyway, my initial thought process on how this could be implemented is that since gRPC transcoding supports annotations like this:
I think we should start implementing support for this in the generator, if it isn't already supported or if there aren't other protoc plugins available. |
Describe the feature
This feature request proposes gRPC transcoding capabilities for the server. This would allow the server to accept json formatted grpc requests and transcode them according to the specifications defined in google.api.http.
Use cases
While grpc web is already implemented, it utilizes a unique format that differs from the transcoding of REST requests into grpc requests. Implementing this feature would be particularly useful when publicly exposing a grpc service, where supporting web based requests or providing users with a REST api option is desired.
Contribution
I am willing to contribute to the implementation of this feature. I have already implemented this in quarkus repository. After discussion in this PR, the maintainers concluded that this should be implemented directly in grpc server implementation.
The text was updated successfully, but these errors were encountered: