首页
/ 使用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开发流程。

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

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
373
72
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
276
72
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
200
47
xzs-mysqlxzs-mysql
学之思开源考试系统是一款 java + vue 的前后端分离的考试系统。主要优点是开发、部署简单快捷、界面设计友好、代码结构清晰。支持web端和微信小程序,能覆盖到pc机和手机等设备。 支持多种部署方式:集成部署、前后端分离部署、docker部署
HTML
5
1
LangChatLangChat
LangChat: Java LLMs/AI Project, Supports Multi AI Providers( Gitee AI/ 智谱清言 / 阿里通义 / 百度千帆 / DeepSeek / 抖音豆包 / 零一万物 / 讯飞星火 / OpenAI / Gemini / Ollama / Azure / Claude 等大模型), Java生态下AI大模型产品解决方案,快速构建企业级AI知识库、AI机器人应用
Java
11
3
gin-vue-admingin-vue-admin
🚀Vite+Vue3+Gin的开发基础平台,支持TS和JS混用。它集成了JWT鉴权、权限管理、动态路由、显隐可控组件、分页封装、多点登录拦截、资源权限、上传下载、代码生成器【可AI辅助】、表单生成器和可配置的导入导出等开发必备功能。
Go
16
3
source-vuesource-vue
🔥 一直想做一款追求极致用户体验的快速开发平台,看了很多优秀的开源项目但是发现没有合适的。于是利用空闲休息时间对若依框架进行扩展写了一套快速开发系统。如此有了开源字节快速开发平台。该平台基于 Spring Boot + MyBatis + Vue & Element ,包含微信小程序 & Uniapp, Web 报表、可视化大屏、三方登录、支付、短信、邮件、OSS...
Java
24
2
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
898
0
madongmadong
基于Webman的权限管理系统
PHP
4
0
cool-admin-javacool-admin-java
🔥 cool-admin(java版)一个很酷的后台权限管理框架,Ai编码、流程编排、模块化、插件化、CRUD极速开发,永久开源免费,基于springboot3、typescript、vue3、vite、element-ui等构建
Java
18
2