如何使用 Swagger 生成的 Golang 模型制作 DTO

我在 Go 中实现 REST API 时遇到了一些问题。


我使用 go-swagger 来记录我的 API。它基于结构生成模型。


我的第一个问题是我不知道在我的招摇 yaml 文件中如何定义一个简单的 hasMany 关系。


如果我需要一辆有很多轮子的车。在我的数据库中,我将有一个vehicle表和一个wheel包含id车辆的表。


由于 Vehicle 没有wheel_id,所以我大摇大摆地得到一个简单的type: object. 对于轮子,我有一个属性:


  vehicle:

    $ref: '#/definitions/Vehicle'

这会生成一个模型:


type Wheel struct {

  ...

  Vehicle *Vehicle

}

当我要求轮子列表时,这不是我希望我的 API 返回的内容。


所以我需要一个 DTO 或某种映射器在客户端和数据库之间工作。


阅读https://www.reddit.com/r/golang/comments/6xgzmp/model_to_dto_mapper_my_first_experience_with_go/ 看起来这不是在 Go 中做事的方式。


我是否需要删除我的 swagger 文件中的所有参考,以便它更好地匹配模型?(将 $ref 替换为属性 id:类型:字符串)


在这种情况下,最佳做法是什么?


慕容3067478
浏览 123回答 1
1回答

呼唤远方

我找到的解决方案是大摇大摆地制作一个自定义响应模型:/vehicle/{id}:  get:    ...    responses:      '200':        schema:          $ref: '#definitions/VehicleCustomeResponse'我想我可以使用招摇anyOf来减少重复的数量。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go