gpt4 book ai didi

go - 混淆从 proto 文件创建 swagger.json 文件

转载 作者:IT王子 更新时间:2023-10-29 00:58:28 24 4
gpt4 key购买 nike

我已经为我打算生成的 REST 网络服务创建了一个包含所有必要消息和 rpc 函数的原型(prototype)文件。使用 protoc-gen-swagger 插件,我设法将该 proto 文件编译成 swagger.json 文件,一切看起来都很好,除了两件事,我似乎无法解决。

  1. swagger.json 文件中的所有定义都以我的原型(prototype)文件包的名称为前缀。有办法摆脱这个吗?

  2. 我消息的所有字段都是“可选的”。它们没有明确指定,但也没有指定为“必需”,根据定义,它们是可选的。 Proto3 不再支持必需/可选/重复,但即使我使用 Proto2 并添加这些关键字,它似乎也不会影响 swagger.json 输出。我如何在我的 proto 文件中指定一个字段是必需的,以便 protoc-gen-swagger 将所需的部分添加到 json 输出?

这是一个非常基本的原型(prototype)文件的示例:

webservice.proto

syntax = "proto3";
package mypackage;
import "google/api/annotations.proto";

service MyAPIWebService {
rpc MyFunc (MyMessage) returns (MyResponse) {
option (google.api.http) = {
post: "/message"
body: "*"
};
}
}

message MyMessage {
string MyString = 1;
int64 MyInt = 2;
}

message MyResponse {
string MyString = 1;
}

然后使用以下命令将其编译成 swagger.json 文件:

protoc -I. -I"%GOPATH%/src/github.com/grpc-ecosystem/grpc-gateway/third_party/googleapis" --swagger_out=logtostderr=true:. webservice.proto

产生以下输出:webservice.swagger.json

{
"swagger": "2.0",
"info": {
"title": "webservice.proto",
"version": "version not set"
},
"schemes": [
"http",
"https"
],
"consumes": [
"application/json"
],
"produces": [
"application/json"
],
"paths": {
"/message": {
"post": {
"operationId": "MyFunc",
"responses": {
"200": {
"description": "",
"schema": {
"$ref": "#/definitions/mypackageMyResponse"
}
}
},
"parameters": [
{
"name": "body",
"in": "body",
"required": true,
"schema": {
"$ref": "#/definitions/mypackageMyMessage"
}
}
],
"tags": [
"MyAPIWebService"
]
}
}
},
"definitions": {
"mypackageMyMessage": {
"type": "object",
"properties": {
"MyString": {
"type": "string"
},
"MyInt": {
"type": "string",
"format": "int64"
}
}
},
"mypackageMyResponse": {
"type": "object",
"properties": {
"MyString": {
"type": "string"
}
}
}
}
}
  1. 注意 proto 文件中的 MyMessageMyResponse 如何转换为 mypackageMyMessagemypackageMyResponse json 文件。

  2. 例如,如果我想要 MyMessage:MyString 是必需的,我必须向“定义”中的“mypackageMyMessage”部分添加一个部分,如下所示:

    “必需”:[ “我的弦”]

如果有一种方法我可以在 proto 文件中指定它,这样我就不必在每次编译时都手动编辑 json 文件,我肯定会更喜欢。

最佳答案

在此处发布以供遇到此问题并寻找相同信息的任何其他人使用。


更新这是代码定义如何创建定义的地方。

https://github.com/grpc-ecosystem/grpc-gateway/blob/master/protoc-gen-swagger/genswagger/template.go#L859


这是您可以根据需要表示字段的方式——向您的消息定义添加自定义选项:

message MyMessage {
option (grpc.gateway.protoc_gen_swagger.options.openapiv2_schema) = {
json_schema: {
title: "MyMessage"
description: "Does something neat"
required: ["MyString"]
}
};

string MyString = 1;
int64 MyInt = 2;
}

关于go - 混淆从 proto 文件创建 swagger.json 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42368221/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com