我正在努力根据开放 api 格式的 api 规范生成 http 客户端库。
我用来生成它的命令与此类似
openapi-generator生成-g go -i spec.yaml -o code-gen-go -p packagename=mypackage
这会在生成的代码中创建一个类似于下面的结构
type Configuration struct { Host string `json:"host,omitempty"` Scheme string `json:"scheme,omitempty"` DefaultHeader map[string]string `json:"defaultHeader,omitempty"` UserAgent string `json:"userAgent,omitempty"` Debug bool `json:"debug,omitempty"` Servers ServerConfigurations OperationServers map[string]ServerConfigurations HTTPClient *http.Client }
其中 httpclient
字段将用于发出请求。理想情况下,应该导入此包,将客户端分配给 httpclient
字段,并且他们应该能够通过此发出 http 请求。
但就我而言,我必须使用自定义库来发出请求。假设我的库是 customhttp
。我必须使用这个库来创建 *customhttp.client
类型的客户端(这只是 *http.client
类型的客户端,但带有一些附加插件)。我怎样才能做到这一点?是否可以在不手动更新自动生成的代码的情况下执行此操作?
我想如果我能让它生成代码,httpclient
的类型是一个实现 do
方法的接口,我将能够用它分配我的客户端?但我也不知道该怎么做。
可以通过修改 go 客户端
从存储库中获取模板:
openapi-generator-cli author template -g go -o tmp/mygotemplates
您现在已经有了本地副本:修改您想要自定义的模板,在本例中为 configuration.mustache
。
您可以在此处导入所需的代码和模块,必要时也可以重命名现有代码。添加您的自定义客户端库。
继续使用您自己的模板生成代码:
openapi-generator-cli generate \ -i openapi.yaml \ -t tmp/mygotemplates \ -g go \ -p packageName=myPackage \ -o src
生成的代码现在包括您的自定义代码和库。该方法提供了您所需的灵活性,但代价是维护模板的自定义版本(例如,您将来可能需要更新)。
这是一篇关于文章代码生成作为参考。
以上是如何将自定义 go http 客户端与从 openapi 规范生成的客户端 go 代码结合使用的详细内容。更多信息请关注PHP中文网其他相关文章!