首页
/ 使用ogent:Ent ORM与ogen的无缝整合指南

使用ogent:Ent ORM与ogen的无缝整合指南

2024-09-12 18:48:17作者:宣海椒Queenly

1. 项目介绍

ogent 是一个专为Ent ORM设计的扩展包,它通过集成ogen这个强大的OpenAPI Specification文档代码生成器,提供了一种类型安全、无需反射的方式来实现RESTful API服务。此工具利用Ent ORM的能力来处理数据访问层,而ogen负责基于定义的OpenAPI文档生成服务器端逻辑。ogent作为二者之间的桥梁,自动完成ogen所需的手动实现部分,使得开发者可以轻松创建并维护符合OpenAPI v3规范的CRUD操作。

2. 项目快速启动

要快速开始使用ogent,首先确保你的开发环境中已安装了Go语言,并设置好了GOPATH或使用Go Modules。

安装ogent

执行以下命令将ogent添加到你的项目中。

go get ariga.io/ogent@main

配置Ent与ogent

接下来,在Ent项目中设置必要的配置文件,首先是创建ent/entc.go,用于集成ogent与entoas(另一个Ent扩展,用于生成OpenAPI Spec):

//go:build ignore
package main

import (
    "log"
    "ariga.io/ogent"
    "entgo.io/contrib/entoas"
    "entgo.io/ent/entc"
    "entgo.io/ent/entc/gen"
    "github.com/ogen-go/ogen"
)

func main() {
    spec := new(ogen.Spec)
    oas, err := entoas.NewExtension(entoas.Spec(spec))
    if err != nil {
        log.Fatalf("creating entoas extension: %v", err)
    }
    ogent, err := ogent.NewExtension(spec)
    if err != nil {
        log.Fatalf("creating ogent extension: %v", err)
    }
    err = entc.Generate("./schema", &gen.Config{}, entc.Extensions(oent, oas))
    if err != nil {
        log.Fatalf("running ent codegen: %v", err)
    }
}

确保在你的项目中编辑或创建ent/generate.go,使其调用上述entc.go文件来进行代码生成步骤:

//go:generate go run ./ent/entc.go

最后,运行代码生成器:

go generate

这将会自动生成一系列处理REST API所需的Go代码。

3. 应用案例和最佳实践

在你的应用程序中加入自定义逻辑和健康检查功能是个不错的实践。例如,你可以扩展ogent生成的接口来实现数据库健康检查路由:

首先,更新ent/entc.go以添加新的API路径:

spec.AddPathItem("/db-health", ogen.NewPathItem().
    SetDescription("Check the servers DB status").
    SetGet(ogen.NewOperation().
        SetOperationID("DBHealth").
        SetSummary("Ping the database and report").
        AddResponse("204", ogen.NewResponse().SetDescription("DB is reachable")).
        AddResponse("503", ogen.NewResponse().SetDescription("DB is not reachable"))))

然后,在你的主要应用程序逻辑中实现该接口:

type handler struct {
    ogent.OgentHandler
    db *sql.DB
}

func (h handler) DBHealth(ctx context.Context) (*ogent.DBHealthRes, error) {
    if err := h.db.Ping(); err != nil {
        return &ogent.DBHealthServiceUnavailable{}, nil
    }
    return &ogent.DBHealthNoContent{}, nil
}

记得调整数据库连接和其他必要的上下文配置。

4. 典型生态项目

ogent与Ent ORM结合使用的场景广泛存在于需要快速构建RESTful API服务的Go应用中,特别是在那些重视代码质量和生产效率的项目中。虽然ogent本身是一个较为专业的工具,但其在微服务架构、云原生应用、以及需要标准化API文档的服务开发中显示出极高的价值。此外,结合Ent ORM的强大数据建模能力,ogent使得在Go生态系统中实现高度可维护且规范化的API成为可能。


以上就是ogent的快速入门及基本使用方法。随着对ogent深入探索,你可以发现更多高级特性和定制化选项,进一步优化你的API开发流程。

热门项目推荐
相关项目推荐

项目优选

收起
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
33
24
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
828
0
redis-sdkredis-sdk
仓颉语言实现的Redis客户端SDK。已适配仓颉0.53.4 Beta版本。接口设计兼容jedis接口语义,支持RESP2和RESP3协议,支持发布订阅模式,支持哨兵模式和集群模式。
Cangjie
376
32
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
75.92 K
19.09 K
qwerty-learnerqwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
15.62 K
1.45 K
easy-eseasy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
19
2
杨帆测试平台杨帆测试平台
扬帆测试平台是一款高效、可靠的自动化测试平台,旨在帮助团队提升测试效率、降低测试成本。该平台包括用例管理、定时任务、执行记录等功能模块,支持多种类型的测试用例,目前支持API(http和grpc协议)、性能、CI调用等功能,并且可定制化,灵活满足不同场景的需求。 其中,支持批量执行、并发执行等高级功能。通过用例设置,可以设置用例的基本信息、运行配置、环境变量等,灵活控制用例的执行。
JavaScript
9
1
Yi-CoderYi-Coder
Yi Coder 编程模型,小而强大的编程助手
HTML
57
7
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
147
26
markdown4cjmarkdown4cj
一个markdown解析和展示的库
Cangjie
10
1