-
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
add support for resource name in swagger plugin (#702) #704
add support for resource name in swagger plugin (#702) #704
Conversation
Thanks for your pull request. It looks like this may be your first contribution to a Google open source project (if not, look below for help). Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA). 📝 Please visit https://cla.developers.google.com/ to sign. Once you've signed (or fixed any issues), please reply here (e.g. What to do if you already signed the CLAIndividual signers
Corporate signers
|
I signed it! |
We found a Contributor License Agreement for you (the sender of this pull request), but were unable to find agreements for all the commit author(s) or Co-authors. If you authored these, maybe you used a different email address in the git commits than was used to sign the CLA (login here to double check)? If these were authored by someone else, then they will need to sign a CLA as well, and confirm that they're okay with these being contributed to Google. |
CLAs look good, thanks! |
Reopening on the request of @ch3rub1m |
@ch3rub1m could you push your changes again please? |
@johanbrandhorst @achew22 I already pushed. But it built failed again. |
Yeah, the problem is that some library we depend on for serializing changed their default for serializing enums from the numeric representation to the string representation. A reasonable change to make, but we need to explicitly set that in whatever library that is. Sorry I just haven't had time to dig into it |
@achew22 Ok, I got it, thanks. |
Could you rebase off of master? We have since fixed the CI issue |
Also, I was thinking about this. Would you be willing to (feel free to push back) add some new usage in the everything example? I would love it if we could do an e2e too |
@achew22 It still not work with GO: 1.10.x. Could you help to check it please? |
@achew22 Hi, I would like to add more usage, but it seems like it's not so suitable to add them directly to the everything example. May I create a new example? By the way, please take a look at the CI issue when you are not that busy. |
Yes, please. Feel free to add as many examples as you think are necessary |
What's the status on this PR? I think I have the same need? Correct me if I am wrong please :) I have a field in a protobuf message called "parent". It looks like this:
The parent can take the form "organizations/<org_id>" or "tenants/<tenant_id>" or it can be empty. I'd like the swagger to match all three. For example: GET How can I achieve this? |
@jon-whit I am writing the examples for this PR. I think it's different with your need. But you could do this to reach your demand:
|
@ch3rub1m Are you saying I can already achieve what I'm looking for? If so, what would the protobuf HTTP options look like for that? That's what I'm struggling with. If not, are you saying that once this PR is merged the example above will be supported? Sorry for the confusion. |
@jon-whit Yes, you could already achieve what you are looking for in current version! But there are some bug in generated swagger doc. And I am trying to fix it. But the bug just affect the doc so the service is still work. You should write as follow to achieve what you want:
|
@ch3rub1m That doesn't match the three mentioned above though.. It will only match
I'd like a match that matches all three of the following:
Is this a scenario where the additional bindings are meant to be used? |
Codecov Report
@@ Coverage Diff @@
## master #704 +/- ##
==========================================
+ Coverage 56.16% 56.29% +0.12%
==========================================
Files 30 30
Lines 3112 3121 +9
==========================================
+ Hits 1748 1757 +9
Misses 1193 1193
Partials 171 171
Continue to review full report at Codecov.
|
We found a Contributor License Agreement for you (the sender of this pull request), but were unable to find agreements for all the commit author(s) or Co-authors. If you authored these, maybe you used a different email address in the git commits than was used to sign the CLA (login here to double check)? If these were authored by someone else, then they will need to sign a CLA as well, and confirm that they're okay with these being contributed to Google. |
CLAs look good, thanks! |
Hi, @achew22. I tried to write some usage in everything example but it failed in travis CI. The bazel really confused me and I don't know how to generate *.pb.go and swagger file by bazel. So I roll back the example commit and it works again. Could you approve this PR first please? I have done many tests in my own project and it seems the PR is ready to be merged. If you wants more usage in example I will open another PR. |
This LGTM, thanks for your contribution! |
I'm unable to generate valid swagger output after this merge. I've tried two validators / parsers and they both complain about the same thing.
Take this example protobuf specification: syntax = "proto3";
import "google/api/annotations.proto";
import "google/protobuf/empty.proto";
service LibraryService {
// Shelf management
rpc GetShelf(GetShelfRequest) returns (Shelf) {
option (google.api.http) = {
get: "/pai/v1/{name=shelves/*}"
};
};
rpc CreateShelf(CreateShelfRequest) returns (Shelf) {
option (google.api.http) = {
post: "/api/v1/shelves"
body: "shelf"
};
};
rpc DeleteShelf(DeleteShelfRequest) returns (google.protobuf.Empty) {
option (google.api.http) = {
delete: "/api/v1/{name=shelves/*}"
};
};
rpc ListShelfs(ListShelfRequest) returns (ListShelfResponse) {
option (google.api.http) = {
get: "/api/v1/shelves"
};
};
// Book management
rpc GetBook(GetBookRequest) returns (Book) {
option (google.api.http) = {
get: "/api/v1/{name=shelves/*/books/*}"
};
};
rpc CreateBook(CreateBookRequest) returns (Book) {
option (google.api.http) = {
post: "/api/v1/{parent=shelves/*}/books"
body: "book"
};
};
rpc DeleteBook(DeleteBookRequest) returns (google.protobuf.Empty) {
option (google.api.http) = {
delete: "/api/v1/{name=shelves/*/books/*}"
};
};
rpc ListBooks(ListBookRequest) returns (ListBookResponse) {
option (google.api.http) = {
get: "/api/v1/{parent=shelves/*}/books"
};
};
}
message Shelf {
// Resource name of the shelf. It must have the format of "shelves/*".
// For example: "shelves/shelf1"
string name = 1;
}
message Book {
// Resource name of the book. It must have the format of "shelves/*/books/*".
// For example: "shelves/shelf1/books/book2"
string name = 1;
string isbn = 2;
string author = 3;
}
message GetShelfRequest {
// Resource name of the shelf.
// For example: "shelves/shelf1"
string name = 1;
}
message CreateShelfRequest {
// Resource name of the shelf.
// For example: "shelves/shelf1"
Shelf shelf = 1;
}
message ListShelfRequest {
}
message ListShelfResponse {
repeated Shelf shelves = 1;
}
message DeleteShelfRequest {
// Resource name of the shelf.
// For example: "shelves/shelf1".
string name = 1;
}
message GetBookRequest {
// Resource name of the book.
// For example: "shelves/shelf1/books/book1"
string name = 1;
}
message CreateBookRequest {
// Resource name of the parent resource where to create the book.
// For example: "shelves/shelf1".
string parent = 1;
Book book = 2;
}
message DeleteBookRequest {
// Resource name of the book to be deleted.
// For example: "shelves/shelf1/books/book1"
string name = 1;
}
message ListBookRequest {
// Resource name of the parent resource.
// For example: "shelves/shelf1"
string parent = 1;
}
message ListBookResponse {
repeated Book books = 1;
}
when generating the swagger output for this the result contain the following problematic statements:
|
@ch3rub1m Any ideas for this error? I was looking through our examples but couldn't find one with a name definition like this. I'm tempted to revert this MR as it has broken some users. |
I'll give @ch3rub1m a week to respond, there might be a workaround. |
@johanbrandhorst I just knew this problem. I'll try to find a trade-off to solve it. |
Great, thanks for your response. Since this breaks existing users I will roll back this change and reopen the original issue. |
@tlyng Hi, I ran your examples in my environment, and I found that there are some errors was complained by validator but it works well for doc generation (by https://github.com/Redocly/redoc). Could you tell me your real use case? Actually in your use case, if this PR was reverted, you couldn't both get apis @johanbrandhorst For the above reasons, I think this PR shouldn't be reverted, because it might fix the warnings of validator and generate a valid swagger but more logical errors back. We should consider another workaround to mitigate the problems of validator instead of reverting this PR. |
As I understand it, it's not just a matter of "warnings in the validator", but not being able to use generators or web UIs that rely on valid swagger files. I think that is a bigger problem right now, although of course I would like to see both issues fixed. I am proposing reverting this PR until we can get a new solution to the duplicate resource generation that still produces valid swagger files. |
@johanbrandhorst Understood, how about using encoded slash
It's a valid swagger and solve the duplicate resource generation even if it doesn't look good. |
I am working on it. Thank you. |
Sounds good enough for me! I'm not personally using swagger documentation for consuming API's, it's a request I've gotten from other developers. Personally I use protobuf , grpc and grpc-web. Providing swagger/openapi reduces the brainwork required by people already used to operate in such environments. |
Fix this issue: The swagger plugin couldn’t distinguish two rpcs if we use the resource name design style. (#702)