mirror of
https://github.com/NoFxAiOS/nofx.git
synced 2026-07-04 03:21:04 +08:00
## 🔴 修復關鍵錯誤:Spot 餘額不應加入可用餘額 ### 問題分析 之前的修復錯誤地將 Spot 餘額加入 `availableBalance`: ```go // ❌ 錯誤:把 Spot 加到可用餘額 totalAvailableBalance := spotUSDCBalance + availableBalance result["availableBalance"] = totalAvailableBalance ``` **問題**: - Hyperliquid 的 Spot 和 Perpetuals 是**兩個獨立帳戶** - Spot 的錢**不能直接用於開倉** - 需要手動調用 `ClassTransfer` API 才能轉帳 - 如果包含 Spot,`auto_trader` 會誤以為有錢可以開倉 → 實際開倉失敗 ### SDK 確認 經查詢 `github.com/sonirico/go-hyperliquid` v0.17.0: - ✅ SDK 支援 `ClassTransfer` 方法(Perpetuals ↔ Spot 轉帳) - ❌ 我們的系統**沒有實現自動轉帳** - 結論:Spot 餘額不能算入可用餘額 ### 修復方案 ```go // ✅ 正確:Spot 只加到總資產,不加到可用餘額 totalWalletBalance := walletBalanceWithoutUnrealized + spotUSDCBalance result["totalWalletBalance"] = totalWalletBalance // 總資產(Perp + Spot) result["availableBalance"] = availableBalance // 可用餘額(僅 Perpetuals) result["totalUnrealizedProfit"] = totalUnrealizedPnl result["spotBalance"] = spotUSDCBalance // 單獨返回 Spot 餘額 ``` ### 修復前後對比 | 場景 | 修復前 | 修復後 | 影響 | |------|--------|--------|------| | Spot 100, Perp 0 | availableBalance=100 | availableBalance=0 | ✅ 避免開倉失敗 | | Spot 100, Perp 50 | availableBalance=150 | availableBalance=50 | ✅ 避免誤判 | | totalWalletBalance | 僅 Perp | Perp + Spot | ✅ 正確顯示總資產 | ### 日誌改善 ``` ✓ Hyperliquid 账户总览: • Spot 现货余额: 100.00 USDC (需手动转账到 Perpetuals 才能开仓) • Perpetuals 可用余额: 50.00 USDC (可直接用於開倉) • 總資產 (Perp+Spot): 150.00 USDC ⭐ 总资产: 150.00 USDC | Perp 可用: 50.00 USDC | Spot 余额: 100.00 USDC ``` ## 相關 - 修復了fe8ba6a引入的錯誤邏輯 - 與2f9a7b0(動態保證金摘要) 獨立 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>