2026-01-23 16:11:20 +08:00
|
|
|
|
## 更新记录
|
|
|
|
|
|
|
|
|
|
|
|
> 说明:本文件用于记录每次客户端代码层面的更新内容,按时间倒序排列。
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
2026-01-29 16:51:06 +08:00
|
|
|
|
### 2026-01-29
|
|
|
|
|
|
|
|
|
|
|
|
- **挖矿任务持久化重构(替换 SQLite 为本地日志文件)**
|
|
|
|
|
|
- 移除 `sqflite_common_ffi` 及 SQLite 依赖,避免在 Windows / Linux 环境下对系统 `libsqlite3` 的安装要求。
|
|
|
|
|
|
- `DatabaseService` 改为基于 `bin/mining_tasks.log` 的 JSON 行存储:
|
|
|
|
|
|
- 新挖矿任务创建时追加写入 `.log`;
|
|
|
|
|
|
- 挖矿任务完成后,从 `.log` 中删除对应记录;
|
|
|
|
|
|
- 客户端启动时读取 `.log`,仅保留未过期任务,并自动恢复最新一条未完成的挖矿任务。
|
|
|
|
|
|
|
|
|
|
|
|
- **退出流程优化**
|
|
|
|
|
|
- 新增 `ClientProvider.shutdown()`,在点击“退出程序”时:
|
|
|
|
|
|
- 停止与服务器的连接和心跳;
|
|
|
|
|
|
- 停止当前挖矿进程和持续挖矿任务;
|
|
|
|
|
|
- 关闭自动刷新定时器,确保退出后不会残留后台矿工进程。
|
|
|
|
|
|
|
|
|
|
|
|
- **文档与多平台说明**
|
|
|
|
|
|
- README 中补充了“持续挖矿中”状态标识(蓝色指示灯)及 `bin/mining_tasks.log` 的作用说明。
|
|
|
|
|
|
- 增加 Linux 构建脚本(`build_linux.sh`)和运行脚本(`start_linux_app.sh`)的使用说明,支持在 Linux 环境下一键安装依赖并运行客户端。
|
|
|
|
|
|
|
2026-01-23 16:11:20 +08:00
|
|
|
|
### 2026-01-23
|
|
|
|
|
|
|
|
|
|
|
|
- **网络与构建相关**
|
|
|
|
|
|
- 配置 Flutter 使用国内镜像源(`PUB_HOSTED_URL` / `FLUTTER_STORAGE_BASE_URL`),解决 `pub.dev` 访问失败问题。
|
|
|
|
|
|
- 清理并修复 Windows 构建缓存(CMake 路径不一致导致的构建失败)。
|
|
|
|
|
|
- 排查 `sqlite3` 原生资产构建失败的原因(无法访问 GitHub 下载预编译库),为后续在有外网环境下构建做准备。
|
|
|
|
|
|
|
|
|
|
|
|
- **数据库与路径**
|
|
|
|
|
|
- 移除未使用的 `package:path/path.dart` 导入,database 层统一通过 `PathUtils.binFile` 处理路径。
|
|
|
|
|
|
|
|
|
|
|
|
- **重连与认证逻辑**
|
|
|
|
|
|
- `ClientCore`:
|
|
|
|
|
|
- 为 TCP 连接新增**指数退避重连策略**:10s、20s、40s、80s、160s,最多重试 5 次,并在连接成功后重置重试次数。
|
|
|
|
|
|
- 在连接错误、连接关闭和心跳超时(超过 60 分钟未收到 ping)时触发重连。
|
|
|
|
|
|
- **重连成功后自动发送 `auth.machineCode` 认证消息**(在已成功获取机器码和身份信息的前提下)。
|
|
|
|
|
|
|
|
|
|
|
|
- **持续挖矿(SustainMiner)**
|
|
|
|
|
|
- 从 `mining.windows.conf` 的 `[sustain]` 段读取配置,校验必填字段与矿工程序路径。
|
|
|
|
|
|
- 当没有租约任务时自动启动持续挖矿,有租约任务到来时暂停,租约结束后自动恢复持续挖矿。
|
|
|
|
|
|
- 新增持续挖矿进程监控:
|
|
|
|
|
|
- 监听矿工进程退出事件,如果在持续挖矿运行且未暂停的情况下进程意外退出,5 秒后自动重启持续挖矿。
|
|
|
|
|
|
|
|
|
|
|
|
- **状态与 UI 展示**
|
|
|
|
|
|
- `ClientStatus`:
|
|
|
|
|
|
- 新增 `sustainingMining` 状态,用于表示“持续挖矿中”,在界面上显示为**蓝色圆点 + 文案「持续挖矿中」**。
|
|
|
|
|
|
- `ClientProvider`:
|
|
|
|
|
|
- 根据是否有租约任务 / 持续挖矿任务,区分显示:
|
|
|
|
|
|
- `mining`:租约挖矿中。
|
|
|
|
|
|
- `sustainingMining`:持续挖矿中。
|
|
|
|
|
|
- 统一通过 `_getMiningInfo()` 构造当前挖矿信息(支持租约挖矿和持续挖矿),供界面展示。
|
|
|
|
|
|
- `MainScreen`:
|
|
|
|
|
|
- “挖矿信息”按钮在以下状态下可用:`ClientStatus.mining` 或 `ClientStatus.sustainingMining`,并且存在 `miningInfo`。
|
|
|
|
|
|
- 点击后进入同一套挖矿信息界面。
|
|
|
|
|
|
- `MiningInfoScreen`:
|
|
|
|
|
|
- 复用同一界面展示日志和当前任务信息。
|
|
|
|
|
|
- 当为**持续挖矿**时,不再显示“结束时间”和“剩余时间”区域,仅展示基本任务信息和日志。
|
|
|
|
|
|
|