Files
NyaHome/README.md
T

66 lines
2.3 KiB
Markdown

# NyaHome - 在线 AI 聊天室 基础设施
NyaHome 是由 FastAPI 后端、Vue WebUI 实现的在线 AI 文学创作平台的基础设施。
## 特色功能
* AI 创作聊天室
* 接入 OpenAI 兼容模型提供商,自携带 API 凭据
* 用户系统
* 由用户自行管理自己的聊天室
* 安全的密码管理与 JWT 令牌签发和验证
* 邮箱绑定、邮件验证码发送和验证
* 用户安全事件记录、修改密码时自动登出所有设备
* NyaHome 系统功能
* 在线后台管理面板
* 邮件 SMTP 发件
* 基于 mjml -> Jinja2 -> HTML 邮件的全链路渲染和发件流程
* 异步邮件发送队列
## 未来功能计划
| 功能 | 阶段 | 优先级 |
|---------------------------|-----|-----|
| **剧本市场** - 剧本分享、聊天室导出为剧本 | 规划中 | 低 |
| **用户功能** - 绑定手机号、接收收集验证码 | 规划中 | 低 |
| **用户功能** - 第三方账户 Oauth 登录 | 规划中 | 低 |
## 代码规范
NyaHome 的项目代码可以分为 Python 后端部分和 TypeScript 前端部分。
### Python 部分
NyaHome 使用 uv 作为项目管理工具,使用 ruff 和 mypy 进行代码检查。在新的代码提交之前,应使用以下命令进行代码检查:
```bash
uv run ruff check --fix
uv run ruff format
uv run mypy
```
以上检查也被写入了 git 的 pre-push 钩子中,会在推送前自动进行检查。
### TypeScript 部分
NyaHome 的 Vue 前端使用 TS。同时,使用 Oxc 的 linter 和 formatter。你可以在 webui 目录下使用以下命令进行代码检查:
```bash
pnpm run lint
pnpm run format
```
## 更新日志 CHANGELOD.md
NyaHome 尝试编写遵循 [Keep a changelog](https://keepachangelog.com/zh-CN/1.1.0/) 规范的更新日志。这意味着:
| 变动类型 | 变动含义 |
|------------|------------------|
| Added | 新添加的功能。 |
| Changed | 对现有功能的变更。 |
| Deprecated | 已经不建议使用,即将移除的功能。 |
| Removed | 已经移除的功能。 |
| Fixed | 对 bug 的修复。 |
| Security | 对安全性的改进。 |
虽然 NyaHome 同时尝试维护规范的 git 日志,但是 git 日志毕竟是给开发者看的,而 CHANGELOG 是给所有人看的,包括你。