-
Notifications
You must be signed in to change notification settings - Fork 2.3k
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
Integration with other languages is partially broken #298
Comments
For what it's worth, it could have been as simple as adding a directory with the If inside the definitions if was something like this instead:
then importing would have been trivial enough. I could see, however, this being a problem for the Golang ecosystem. Also, switching to the new layout would be a breaking change. |
@doubleyou, Thanks so much for showing interest in the gRPC Gateway project. It's nice to know there are people out there playing with these ideas. Unfortunately, I have almost no knowledge of the intricacies of the python import system and don't have any ideas on how to address your specific problem. Sorry. It sounds like this is a problem that would be better addressed by the Protobuf project. Maybe you could open a bug over there and add a reference to this one? I'm going to close this issue since it is related to the actual protobuf compiler's python code generation strategy. Good luck out there and if you find a great solution, please come back and leave a note explaining how you solved the problem. |
So, there's one way to make it work specifically for Python. If we generate the Python code from
Then it will import both the native google package and the local one. I'm still trying to search for any related discussions in the Protobuf community, but this may be at least a decent solution specifically for Python. Also, easy to automate. |
Hi @doubleyou . Could you, if it is not so much a trouble, give me some example project that you could successfully run with grpc-gateway on Python? I have been trying to make this happen and tried all of your advices above but not getting anything working. Thanks a ton in advance. |
I'm unsure why this was closed. I'm facing this exact issue with Python. The only GRPC example I can find doesn't work. Opened issue here GoogleCloudPlatform/python-docs-samples#1103 |
Installing 'googleapis-common-protos' package from pypi will solve the problem. |
Hi @doubleyou could you give me a guide about how to use grpc-gateway in python? Thanks |
Looks like some (if not all) non-Go languages don't really work by default with protobuf files annotated with
grpc-gateway
bindings.Consider the following gist: https://gist.github.com/doubleyou/41f0828e4b9b50a38f7db815feed0a6c
It basically implements HTTP bindings for protobuf's helloworld example. I also added the Makefile to give a bit better idea of what paths are being included, etc.
The problem arises when we try to run
python server.py
. Specifically, the code fails at the following line that gets generated insidehelloworld_pb2.py
:The problem here is that we have never generated Python code from
annotations.proto
andhttp.proto
and put them in the right place. I bet the same problem would arise with a lot of other languages, if not all of them.This is an example of how people work around it right now: https://github.com/kasey/grpc-example/blob/master/installers/python-grpc-hack.sh. My guess is that in Ruby, C++ or Java world one has to do a very similar hack.
Seems like this is more of a Protocol Buffers problem: whenever you include an intermediate
.proto
file, you have to also generate code from it and put it to the appropriate include path. I'm not aware of any methods to make Protocol Buffers behave differently about it (for example, merge all the imported files into the main file and compile them as one?). Been trying to find any related issues raised in their repository or Google Groups, but no luck so far.Another alternative is writing some helper scripts that compile
annotations.proto
andhttp.proto
into a specified language and put them into the right place (just like ininstallers/python-grpc-hack.sh
) and including them into the main repository. Can be a bit tricky, given that there are various ways of installing and running the same compiler/interpreter.Finally, this can be at least documented for the time being, so that people know at least approximately where to look for a solution.
Thoughts, suggestions?
The text was updated successfully, but these errors were encountered: