2
0
mirror of https://github.com/acepanel/panel.git synced 2026-02-04 04:22:33 +08:00
Files
panel/.github/copilot-instructions.md
2026-01-15 06:10:11 +08:00

5.3 KiB
Raw Blame History

项目概述

AcePanel 是基于 Go 语言开发的新一代 Linux 服务器运维管理面板。项目采用前后端分离架构:

  • 后端Go 1.25 + go-chi 路由 + GORM + Wire 依赖注入
  • 前端Vue 3 + Vite + Naive UI + pnpm

语言和编码规范

所有代码注释、文档和回复必须使用简体中文。

构建和测试

后端构建

构建主程序:

go build -o ace ./cmd/ace

构建 CLI 工具:

go build -o cli ./cmd/cli

前端开发

进入前端目录:

cd web

安装依赖:

pnpm install

开发模式(带热重载):

pnpm dev

构建生产版本:

pnpm build

代码架构

项目采用类 DDD 分层架构依赖关系为route -> service -> biz <- data

核心目录结构

  • cmd/: 程序入口

    • ace/: 面板主程序
    • cli/: 命令行工具
  • internal/app/: 应用入口和配置

  • internal/route/: HTTP 路由定义

    • 定义路由规则
    • 注入所需的 service 依赖
  • internal/service/: 服务层(类似 DDD 的 application 层)

    • 处理 HTTP 请求/响应
    • DTO 到 DO 的转换
    • 协调多个 biz 接口完成业务流程
    • 不应处理复杂业务逻辑
  • internal/biz/: 业务逻辑层(类似 DDD 的 domain 层)

    • 定义业务接口Repository 模式)
    • 定义领域模型和数据结构
    • 使用依赖倒置原则biz 定义接口data 实现接口
  • internal/data/: 数据访问层(类似 DDD 的 repository 层)

    • 实现 biz 中定义的业务接口
    • 封装数据库、缓存等操作
    • 处理数据持久化逻辑
  • internal/http/: HTTP 相关

    • middleware/: 自定义中间件
    • request/: 请求结构体定义
    • rule/: 自定义验证规则
  • internal/apps/: 面板子应用实现

  • internal/bootstrap/: 各模块启动引导

  • internal/migration/: 数据库迁移

  • internal/job/: 后台任务

  • internal/queuejob/: 任务队列

  • pkg/: 工具函数和通用包

    • 包含各种独立的工具模块
    • 可被项目任何部分引用
  • web/: Vue 3 前端项目

开发新功能的标准流程

  1. internal/route/ 中添加路由

    • 参考已有路由文件(如 http.go
    • 注入需要的 service 依赖
    • 定义路由规则和 handler 映射
  2. internal/service/ 中实现服务方法

    • 先阅读已有的类似服务以了解代码风格
    • 处理请求验证和响应格式化
    • 使用 Success() 返回成功响应
    • 使用 Error() 返回错误响应
    • 使用 ErrorSystem() 返回系统严重错误
    • 调用 biz 层接口完成业务逻辑
  3. internal/biz/ 中定义业务接口

    • 先阅读已有的类似接口定义
    • 定义 Repository 接口(如 WebsiteRepo
    • 定义领域模型结构体(如 Website
    • 保持接口简洁明确
  4. internal/data/ 中实现 biz 接口

    • 先阅读已有的类似实现
    • 创建 repo 结构体(如 websiteRepo
    • 实现构造函数(如 NewWebsiteRepo
    • 实现所有接口方法
    • 处理数据库操作和缓存逻辑
  5. 使用 Wire 进行依赖注入

    • 在对应的 wire.go 文件中添加 provider
    • 运行 go generate 生成依赖注入代码

技术栈特定注意事项

Go 语言规范

  • 使用 Go 1.25 稳定版本
  • 遵循 Go 标准库和习惯用法
  • 日志使用标准库的 slog
  • 使用 github.com/samber/lo 进行函数式编程辅助

当前框架

  • 路由:github.com/go-chi/chi/v5
  • ORMgorm.io/gorm
  • 依赖注入:github.com/google/wire
  • 验证:github.com/gookit/validate

助手函数service 层)

在 service 层使用以下助手函数:

  • Success(w, data): 返回成功响应
  • Error(w, statusCode, format, args...): 返回错误响应
  • ErrorSystem(w, format, args...): 返回系统严重错误500
  • Bind[T](r): 绑定请求参数到泛型类型 T
  • Paginate[T](...): 构建分页响应

数据库

  • 使用 SQLitegithub.com/ncruces/go-sqlite3
  • 使用 GORM 进行数据库迁移和操作

安全性

  • 不需要实现命令注入过滤,文件名过滤等,因为这是服务器面板,所有登录的用户都被视为管理员

代码风格

  • 所有代码注释必须使用简体中文
  • 遵循 Go 官方代码风格
  • 使用 gofmt 格式化代码
  • 复杂逻辑添加注释说明
  • 导出的函数和类型必须有注释

Wire 依赖注入

项目使用 Wire 进行依赖注入。当添加新的依赖时:

  1. cmd/ace/wire.gocmd/cli/wire.go 中添加 provider
  2. 运行生成命令:
go generate ./...

前端开发注意事项

  • 使用 Vue 3 Composition API
  • UI 框架Naive UI
  • 状态管理Pinia
  • HTTP 请求Alova.js使用 useRequest 等助手函数进行数据获取,无需处理 onError 错误。
  • 图标:@iconify/vue
  • 终端xterm.js
  • 遵循项目已有的组件结构和编码风格

配置文件

开发时需要准备配置文件:

cp config.example.yml config.yml

前端开发配置:

cd web
cp .env.production .env
cp settings/proxy-config.example.ts settings/proxy-config.ts