Initial commit

This commit is contained in:
zs
2026-02-28 20:05:15 +08:00
commit c66f5f9be4
185 changed files with 18356 additions and 0 deletions

View File

@@ -0,0 +1,59 @@
---
description: InsightReply 后端 Go/API 编码规范与架构设计
globs: *.go, *.sql
---
# InsightReply 后端 Go 编码与 API 设计规范
本文档定义了 InsightReply 后端服务Golang的架构风格、代码组织模式及统一的 API 响应标准。
## 一、 整体架构模式
后端服务采用 **清晰架构 (Clean Architecture / Domain-Driven Design 简化版)** 进行分层,严禁跨层调用:
* **`cmd/server/`**: 应用入口,加载配置、初始化路由与数据库连接。
* **`internal/handler/`** (或 `controller/`): 负责接收 HTTP 请求,解析参数,并将其转化为业务层需要的结构。
* **`internal/service/`**: 存放核心业务逻辑(如调用 LLM 生成评论的策略代码、热度计算公式的落地)。
* **`internal/repository/`** (或 `model/`): 负责与 PostgreSQL 数据库交互(封装所有的 SQL / ORM 逻辑)。
## 二、 统一接口标准 (RESTful)
所有对外部浏览器和前端暴露的 HTTP JSON 接口,必须严格遵守统一的包装格式。
### 1. 成功响应
```json
{
"code": 200,
"message": "success",
"data": {
"replies": [...] // 具体的业务数据
}
}
```
### 2. 失败响应(业务报错)
* `code`: > 200 的自定义业务状态码(例如 `4001` 表示参数错误,`4003` 表示权限不足)。
* `message`: 面向前端的友好提示。
```json
{
"code": 4001,
"message": "推文链接解析失败",
"data": null
}
```
*HTTP Status Code 应依然使用 `400 Bad Request` 或 `500 Internal Server Error` 匹配网络层的状态语义。*
## 三、 Go 代码风格与规范
* **错误处理 (Error Handling)**:
* 坚决避免到处写 `err != nil` 却只做透明抛出的行为,当错误发生时,使用 `fmt.Errorf("doSomething failed: %w", err)` 包装上游错误信息,以便追踪。
* **命名规范**:
* 包名 (`package`): 保持简短、全部小写、无下划线,不使用复数形式(如用 `user` 而非 `users`)。
* 接口类型名 (`interface`): 通常以 `-er` 结尾(如 `Reader`, `TweetFetcher`)。
* **日志打印**:
* 关键的业务路径(如调用第三方 LLM API 失败)、恐慌恢复 (Panic Recovery)、定时任务失败必须有结构化的日志记录。
## 四、 数据库 (PostgreSQL) 规范
* 对于本项目的初步开发,推荐使用如 **`gorm`** 或 **`sqlx`** 进行快速的数据交互操作。
* 所有表名、字段名在 Go 结构体 (`struct`) 的 tag 中必须显式定义为下划线 (snake_case)。
* UUID 作为主键,禁止前端或外部服务自行生成传入,一律由 PostgreSQL `gen_random_uuid()` 或者服务端生成。