An open API service indexing awesome lists of open source software.

https://github.com/uozi-tech/cosy

a Comfortable Object-oriented Simplified framework for You
https://github.com/uozi-tech/cosy

curd gin go

Last synced: 3 months ago
JSON representation

a Comfortable Object-oriented Simplified framework for You

Awesome Lists containing this project

README

          

# Cosy - Golang Web API 框架助手

a **C**omfortable **O**bject-oriented **S**implified framework for **Y**ou

Designed by @0xJacky 2024-2025

Cosy 是一个方便的工具,基于泛型,面相对象,旨在简化基于 Gin 框架并使用 Gorm 作为 ORM 的 Web API 的创建、更新和列出数据库记录的过程。

目标是简化繁琐重复的 CURD 过程,并且对 ChatGPT 友好。

## 特点

1. **链式方法:** 为 CRUD 操作轻松设置各种查询条件和配置
2. **基本生命周期:** BeforeDecode, BeforeExecute, GormAction, Executed
3. **钩子系统:** 提供在主要 CRUD 操作之前和之后执行函数的能力
- map 转换为 struct 前的钩子 `BeforeDecodeHook`
- 数据库操作执行前的钩子 `BeforeExecuteHook`
- 数据库执行时的钩子 `GormScope`
- 数据库执行后的钩子 `ExecutedHook`
- 钩子的设置函数可以被多次调用,将会按照调用顺序执行
4. **接口级性能**:只涉及到泛型,Cosy 层面上没有使用 reflect
5. **路由级性能**:几乎仅在程序初始化阶段使用 reflect,并对模型的反射结果缓存到 map 中
6. **强大的标签系统**:通过 `cosy` 标签控制字段在不同操作中的行为
7. **自定义筛选器**:支持自定义列表筛选器,满足复杂查询需求
8. **批量操作**:支持批量创建、更新、删除和恢复操作
9. **事务支持**:内置事务支持,确保数据一致性
10. **配置文件支持**:支持 INI 和 TOML 两种配置文件格式
11. **队列系统**:基于 Redis 的简单队列,支持生产者-消费者模式
12. **定时任务**:集成 gocron 定时任务调度器
13. **错误处理**:完善的错误处理机制,支持错误文档和代码生成
14. **日志系统**:基于 zap 的高性能日志系统
15. **热重载**:支持 HTTPS 证书热重载

## 数据库驱动支持

- [MySQL](https://github.com/uozi-tech/cosy-driver-mysql)
- [Postgres](https://github.com/uozi-tech/cosy-driver-postgres)
- [Sqlite](https://github.com/uozi-tech/cosy-driver-sqlite)

## 文档
https://cosy.uozi.org/

## 在项目中使用
```shell
go get -u github.com/uozi-tech/cosy
```

## 版权
Copyright © 2024-2025 UoziTech

Cosy 版权属于柚子星云科技(深圳)有限公司,并已取得软件著作权。