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

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

2024-09-12 18:48:17作者:宣海椒Queenly
ogent
Ent Extension to integrate ogen

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开发流程。

ogent
Ent Extension to integrate ogen
热门项目推荐
相关项目推荐

项目优选

收起
CangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
671
0
RuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
136
18
openHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
12
8
redis-sdk
仓颉语言实现的Redis客户端SDK。已适配仓颉0.53.4 Beta版本。接口设计兼容jedis接口语义,支持RESP2和RESP3协议,支持发布订阅模式,支持哨兵模式和集群模式。
Cangjie
322
26
advanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
75.83 K
19.04 K
qwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
15.56 K
1.44 K
Jpom
🚀简而轻的低侵入式在线构建、自动部署、日常运维、项目监控软件
Java
1.41 K
292
Yi-Coder
Yi Coder 编程模型,小而强大的编程助手
HTML
30
5
easy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
1.42 K
231
taro
开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/
TypeScript
35.34 K
4.77 K