a4e78b864a
延长 SendEmailJob 超时并改为超时直接失败,补充重试退避、 失败日志与收件人脱敏,避免 send_email 队列批量超时重试。 新增 MAIL_TIMEOUT 与 QUEUE_RETRY_AFTER 配置,并抽出邮件运行时 配置与 HTML 内容服务,确保 Horizon 常驻进程使用最新邮件配置。 为 Docker、supervisor 与 compose 样例补齐 scheduler 进程,并在 节点管理端开启墙检测托管时立即触发一次检测,保证定时任务持续生效。
128 lines
6.9 KiB
Markdown
128 lines
6.9 KiB
Markdown
# 项目上下文
|
||
|
||
## 基本信息
|
||
|
||
- 项目: Xboard-new
|
||
- 当前工作目录: `E:\code\php\Xboard-new`
|
||
- 主要栈: Laravel(PHP) + Vue3/TypeScript/Vite/Element Plus (`admin-frontend`)
|
||
|
||
## 技术上下文
|
||
|
||
- 管理端前端位于 `admin-frontend/`
|
||
- `admin-frontend` 现支持通过 `ADMIN_BUILD_OUT_DIR` 覆写构建输出目录:仓内默认仍写到 `../public/assets/admin`,容器构建可切到独立 `dist`
|
||
- 前端容器化运行采用 `admin-frontend/Dockerfile`(`Node 20 + Caddy` 多阶段构建),静态站点入口重定向到 `/assets/admin/`
|
||
- 前端容器会通过 `XBOARD_BACKEND_UPSTREAM` 把 `/api` 反向代理到后端 `web` 服务;compose 分支当前默认值为 `http://web:7001`
|
||
- 前端容器会通过 `XBOARD_UPLOAD_UPSTREAM` 把 `/upload/*` 去掉 `/upload` 前缀后反向代理到图片上传服务,默认值为 `https://pic.535888.xyz`
|
||
- GHCR 前端镜像发布工作流位于 `.github/workflows/admin-frontend-docker-publish.yml`,镜像名为 `ghcr.io/<owner>/xboard-admin-frontend`
|
||
- 管理端 API 通过 `window.settings.secure_path` 或 `VITE_ADMIN_PATH` 解析 `/api/v2/{secure_path}` 前缀
|
||
- 登录接口复用 `/api/v2/passport/auth/login`
|
||
- 工单回复链路当前以 `TicketService::reply()` 为统一真相源:管理员或用户再次回复已关闭工单时都会自动把工单状态改回开启,同时继续维护 `reply_status` 与 `last_reply_user_id`
|
||
- 邮件发送链路当前以 `SendEmailJob` + `MailService` 为统一入口:`send_email` 队列的单个 job 超时为 60 秒,SMTP 传输超时默认由 `MAIL_TIMEOUT=30` 控制,Redis `retry_after` 默认由 `QUEUE_RETRY_AFTER=90` 控制。
|
||
- 管理端仪表盘现已接入:
|
||
- `stat/getStats`
|
||
- `stat/getOrder`
|
||
- `stat/getTrafficRank`
|
||
- `system/getSystemStatus`
|
||
- `system/getQueueStats`
|
||
- 管理端用户管理现已接入:
|
||
- `user/fetch`
|
||
- `user/generate`
|
||
- `user/update`
|
||
- `user/dumpCSV`
|
||
- `user/sendMail`
|
||
- `user/ban`
|
||
- `user/resetSecret`
|
||
- `user/destroy`
|
||
- `plan/fetch`
|
||
- `traffic-reset/reset-user`
|
||
- 管理端节点管理现已接入:
|
||
- `server/manage/getNodes`
|
||
- `server/manage/save`
|
||
- `server/manage/sort`
|
||
- `server/manage/batchUpdate`
|
||
- `server/group/fetch`
|
||
- `server/group/save`
|
||
- `server/group/drop`
|
||
- `server/route/fetch`
|
||
- `server/route/save`
|
||
- `server/route/drop`
|
||
- `server/manage/update`
|
||
- `server/manage/copy`
|
||
- `server/manage/drop`
|
||
- `server/manage/batchDelete`
|
||
- `server/manage/checkGfw`
|
||
- `server/manage/resetTraffic`
|
||
- `server/manage/batchResetTraffic`
|
||
- 管理端套餐管理现已接入:
|
||
- `plan/fetch`
|
||
- `plan/save`
|
||
- `plan/update`
|
||
- `plan/drop`
|
||
- `plan/sort`
|
||
- `server/group/fetch`
|
||
- 管理端订单管理现已接入:
|
||
- `order/fetch`
|
||
- `order/detail`
|
||
- `order/assign`
|
||
- `order/paid`
|
||
- `order/cancel`
|
||
- `order/update`
|
||
- 管理端礼品卡管理现已接入:
|
||
- `gift-card/templates`
|
||
- `gift-card/create-template`
|
||
- `gift-card/update-template`
|
||
- `gift-card/delete-template`
|
||
- `gift-card/generate-codes`
|
||
- `gift-card/codes`
|
||
- `gift-card/toggle-code`
|
||
- `gift-card/export-codes`
|
||
- `gift-card/update-code`
|
||
- `gift-card/delete-code`
|
||
- `gift-card/usages`
|
||
- `gift-card/statistics`
|
||
- `gift-card/types`
|
||
- 管理端公告管理现已接入:
|
||
- `notice/fetch`
|
||
- `notice/save`
|
||
- `notice/show`
|
||
- `notice/drop`
|
||
- `notice/sort`
|
||
- 管理端支付配置现已接入:
|
||
- `payment/fetch`
|
||
- `payment/getPaymentMethods`
|
||
- `payment/getPaymentForm`
|
||
- `payment/save`
|
||
- `payment/show`
|
||
- `payment/drop`
|
||
- `payment/sort`
|
||
- 订单支付成功后会额外快照保存 `payment_channel / payment_method / payment_amount / payment_ip`,管理端订单详情优先展示真实支付成功信息,再回退当前支付配置
|
||
- 客户端订阅导出入口位于 `app/Http/Controllers/V1/Client/ClientController.php`,会根据 `flag` / `User-Agent` 匹配 `app/Protocols/*` 导出器
|
||
- `Stash` 订阅导出位于 `app/Protocols/Stash.php`,当前对 `AnyTLS` 采用保守兼容:仅客户端版本 `>= 3.3.0` 时导出
|
||
- 用户主题源代码当前不在仓内,仅保留 `theme/Xboard/assets/umi.js` 编译产物;涉及用户侧工单交互时,优先通过后端语义修复保证前后台一致
|
||
|
||
## 项目概述
|
||
|
||
- 主仓仍以 Laravel 为后端真相源
|
||
- `admin-frontend` 负责独立管理后台 UI 与交互逻辑
|
||
- `admin-frontend` 现在同时支持两种交付路径:仓内构建产物写回 `public/assets/admin`,或独立构建为 GHCR 静态镜像供 compose 分支部署
|
||
- `deploy/xboard-server/` 是可复制到服务器的一键部署模板,包含 `web / horizon / scheduler / admin / ws-server / redis` Compose 拓扑、`.env.example`、初始化/部署/更新/状态检查脚本和部署说明
|
||
- 订阅协议导出由 Laravel 主仓内的 `app/Protocols/*` 提供,客户端兼容问题需以对应导出器实现为准
|
||
- `public/assets/admin` 为构建产物输出位置
|
||
|
||
## 开发约定
|
||
|
||
- 管理端路由使用 Hash 模式
|
||
- 管理端当前业务路由包含 `/dashboard`、`/users`、`/tickets`、`/nodes`、`/node-groups`、`/node-routes`、`/subscriptions/plans`、`/subscriptions/orders`、`/subscriptions/coupons`、`/subscriptions/gift-cards`、`/system/config`、`/system/notices`、`/system/payments`、`/system/plugins`、`/system/themes` 与 `/system/knowledge`
|
||
- `#/nodes` 当前已升级为真实节点工作台:支持搜索、在线 / 离线筛选、父/子节点筛选、墙状态筛选、分页浏览、显隐切换、自动上线托管开关、墙检测托管开关、刷新数据、复制、单节点置顶、仅对已勾选节点生效的批量修改 / 批量删除,以及 11 种协议的新增 / 编辑弹窗和排序对话框
|
||
- 节点自动上线由后端 `sync:server-auto-online` 定时命令执行,只处理 `auto_online=1` 的节点:在线 / 待同步时自动 `show=1`,离线时自动 `show=0`;未开启自动上线的节点继续保持手动显隐控制;墙状态为 `blocked` 或仍处于 `gfw_auto_hidden` 且未恢复正常时会否决自动显示
|
||
- 节点自动墙检测由后端 `sync:server-gfw-checks` 定时命令执行,只为开启 `gfw_check_enabled` 的父节点创建检测任务;子节点不独立检测,但可控制是否随父节点自动隐藏 / 恢复
|
||
- Compose 部署必须确保 Laravel Scheduler 持续运行;`deploy/xboard-server/compose.yaml` 通过独立 `scheduler` 服务执行 `php artisan schedule:work`,否则自动墙检测只会在手动触发时创建任务
|
||
- Bearer Token 存储于 `sessionStorage/localStorage`
|
||
- `admin-frontend` 的视觉方向当前以 Apple 风格为基线,优先纯色分区、系统字体栈和低装饰成本
|
||
|
||
## 当前约束
|
||
|
||
- 本地静态 preview 环境默认缺少 Laravel 注入的 `window.settings` 与真实管理 API,受保护页面只能验证结构与跳转,不能替代完整联调
|
||
- 当前主工作树存在多组未提交业务改动;`compose` 分支变更需在独立 worktree 中处理,避免污染 `master`
|
||
- 后端接口契约以仓库内 Controller/Route 为准,不在前端推断字段
|