rwadurian/backend/mpc-system/services/service-party-android/app
hailin 7b95711406 feat(android): 实现可靠的 gRPC 连接和流管理机制
基于 gRPC 官方最佳实践完整重构流管理系统

核心改进:
1. Keep-Alive 配置优化 (20s PING, 5s 超时, 永不超时空闲连接)
2. 创建 StreamManager 统一管理双向流生命周期
3. 实现自动重连机制 (Flow.retryWhen + 指数退避)
4. 添加 Android 网络状态监听 (立即 resetConnectBackoff)

技术细节:
- gRPC 流无法"恢复",必须重新发起 RPC 调用
- StreamManager 保存流配置,失败后自动重新发起
- 监听 GrpcConnectionEvent.Reconnected 触发流重启
- 删除旧的 callback 机制,使用 Flow 事件驱动

修复的关键问题:
- 网络断开后 eventStreamSubscribed flag 被清除导致 callback 不触发
- reSubscribeStreams 尝试"恢复"已关闭的 Flow (设计错误)
- 缺少 Keep-Alive 导致连接被中间设备清理
- 缺少网络监听导致 60 秒 DNS 解析延迟

参考资料:
- https://github.com/grpc/grpc-java/issues/8177
- https://grpc.io/docs/guides/keepalive/
- https://github.com/grpc/grpc-java/issues/4011

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-01-27 00:56:55 -08:00
..
libs feat(android): add Android TSS Party app with full API implementation 2025-12-31 23:27:29 -08:00
src/main feat(android): 实现可靠的 gRPC 连接和流管理机制 2026-01-27 00:56:55 -08:00
build.gradle.kts fix(tss): 修复备份恢复后签名失败的问题 2026-01-20 00:39:05 -08:00
proguard-rules.pro feat(android): add Android TSS Party app with full API implementation 2025-12-31 23:27:29 -08:00