登录
首页 >  Golang >  Go问答

封装第三方配置结构体

来源:stackoverflow

时间:2024-03-05 11:30:27 226浏览 收藏

大家好,我们又见面了啊~本文《封装第三方配置结构体》的内容中将会涉及到等等。如果你正在学习Golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们能一起进步!下面就开始本文的正式内容~

问题内容

我正在开发一个 go 项目,其中我利用一些相当大的第三方客户端库来与一些第三方 rest api 进行通信。我的目的是将我的内部代码 api 与这些特定依赖项解耦。

在我的代码中将特定方法与这些库解耦非常简单,因为我只需要功能的子集,并且能够抽象用例。因此,我在代码中引入了一种新类型,它实现了我的特定用例;然后底层实现依赖于第三方依赖项。

我无法理解如何找到良好的解耦的地方是 configuration structs。通常,我使用的客户端库提供这种形式的一些功能

createresourcea(options *resourceaoptions) (*resourcea, error)
createresourceb(options *resourceboptions) (*resourceb, error)

其中*resourcea*resourceb是相应资源创建后的服务器端配置。

不同的 options 是相当大的配置结构,适用于具有大量字段、嵌套结构等的资源。一般来说,这些配置包含比我的应用程序所需的更多选项,但总体重叠最终相当大。

因为我想避免我的内部代码必须导入特定的依赖项才能访问我想要封装它们的配置结构。

我当前的封装方法是定义我自己的配置结构,然后用它来配置第三方依赖项。举个简单的例子:

import a "github.com/client-a"

// MyClient implements my use case functions
type MyClient struct{}

// MyConfiguration wraps more or less the configuration options
// provided by the client-a dependency
type MyConfiguration struct{
  Strategy StrategyType
  StrategyAOptions *StrategyAOptions
  StrategyBOptions *StrategyBOptions
}

type StrategyType int
const (
  StrategyA StrategyType = iota
  StrategyB
)

type StrategyAOptions struct{}
type StrategyBOptions struct{}


func (c *MyClient) UseCaseA(options *MyConfiguration) error {
  cfg := &a.Config{}
  if (options.Strategy = StrategyA) {
    cfg.TypeStrategy = a.TypeStrategyXY
  }
  ...
  a.CreateResourceA(cfg)
}

正如示例所示,使用此方法我可以封装第三方配置结构,但我认为此解决方案的扩展性不是很好。我已经遇到过一些示例,在这些示例中,我基本上是从代码中的依赖项重新实现类型,只是为了抽象出依赖项。

如果我的方法通常是错误的,我在这里寻找可能更复杂的解决方案和/或一些见解。

我的进一步研究:

我研究了 struct embedding ,这是否可以帮助我。但是,由于配置包含重要的成员,我最终也在调用代码中导入依赖项来填充字段。

由于通常的准则似乎是 accept 接口返回 structs 我试图用这种方法找到一个好的解决方案。但在这里我最终也可以得到一个相当大的接口,并且在 go 标准库中配置结构似乎不通过接口使用。如果在 go 中将配置隐藏在接口后面是一个很好的实践,我无法找到明确的声明。

总结一下:

我想知道如何从第三方库中抽象配置结构,而无需在代码中重新定义相同的数据类型。


解决方案


一个非常简单的事情怎么样 - 重新定义包装器包中所需的结构类型?

我是个新手,所以这可能不是最好的继续方式。

package myconfig

import a "github.com/client-a"

type aconfig a.config

那么你只需要导入你的myconfig包

import "myConfig"
// myConfig.aConfig is actually a.Config
myConfig.aConfig

不太确定这是否有很大帮助,因为这不是真正的解耦,但至少你不需要在每个地方导入“github.com/client-a”

好了,本文到此结束,带大家了解了《封装第三方配置结构体》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>