flare-core 0.1.2

A high-performance, reliable long-connection communication toolkit for Rust, supporting WebSocket and QUIC protocols with features like authentication, device management, serialization negotiation, and protocol racing.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
# Flare Core

[![Crates.io](https://img.shields.io/crates/v/flare-core.svg)](https://crates.io/crates/flare-core)
[![Documentation](https://docs.rs/flare-core/badge.svg)](https://docs.rs/flare-core)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Rust](https://img.shields.io/badge/rust-1.70%2B-blue.svg)](https://www.rust-lang.org/)

**Flare Core** 是一个高性能、可靠的即时通讯长连接工具包,专为 Rust 设计。它提供了简洁的 API 和强大的功能,让开发者能够轻松构建实时通信应用。

> **注意**: 本文档使用中文编写。For English documentation, please refer to [docs.rs/flare-core]https://docs.rs/flare-core.

## ✨ 核心特性

### 🚀 多协议支持
- **WebSocket** - 基于标准 WebSocket 协议,支持 Web 和移动端
- **QUIC** - 基于 UDP 的现代传输协议,提供更低的延迟和更好的性能
- **协议竞速** - 客户端可以同时尝试多个协议,自动选择最快的连接

### 🔐 认证与安全
- **Token 认证** - 支持可配置的 token 验证机制
- **自定义认证器** - 实现 `Authenticator` trait 提供自定义验证逻辑
- **认证超时** - 可配置的认证超时时间
- **连接状态管理** - 只有已验证的连接才能收发业务消息

### 📱 多设备管理
- **设备冲突策略** - 支持多种设备管理策略:
  - 平台互斥:同一用户同一平台只能有一个设备在线
  - 移动端互斥:同一用户只能有一个移动端设备在线
  - 完全互斥:同一用户只能有一个设备在线
  - 移动端和PC共存:移动端之间互斥,PC端之间互斥,但移动端和PC端可以同时在线
  - 完全开放:允许所有设备同时在线
- **设备信息** - 支持设备ID、平台、型号、版本等信息

### 🔄 序列化协商
- **多格式支持** - 支持 Protobuf 和 JSON 序列化格式
- **压缩算法** - 支持 None、Gzip、Zstd 压缩算法
- **协商机制** - 客户端和服务端自动协商最优的序列化格式和压缩算法
- **强制模式** - 客户端可以强制指定格式(适用于不支持某些格式的平台)

### 💓 心跳检测
- **自动心跳** - 服务端自动检测连接超时
- **客户端心跳** - 客户端自动发送心跳保持连接
- **可配置** - 心跳间隔和超时时间可配置

### 🏗️ 灵活的构建模式
- **观察者模式** - 实现 `ConnectionHandler`/`ConnectionObserver` trait 处理消息
- **简单模式** - 使用闭包定义消息处理逻辑
- **事件处理器** - 支持细化的命令处理和事件观察

### 📦 模块化设计
- **清晰的架构** - 协议层、核心层、业务层分离
- **易于扩展** - 支持自定义认证器、事件处理器、设备管理器等
- **类型安全** - 充分利用 Rust 的类型系统保证安全性

## 📦 安装

### 使用 Cargo

```toml
[dependencies]
flare-core = "0.1.0"
```

### 功能特性

当前版本包含以下特性(可通过 `features` 启用,未来版本):

- `default` - 默认功能集(当前包含所有功能)

## 🚀 快速开始

### 服务端示例

#### 观察者模式(推荐)

```rust
use flare_core::server::*;
use flare_core::common::*;
use std::sync::Arc;

// 实现 ConnectionHandler
struct MyHandler;

#[async_trait::async_trait]
impl ConnectionHandler for MyHandler {
    async fn handle_frame(&self, frame: &Frame, connection_id: &str) -> Result<Option<Frame>> {
        // 处理消息
        Ok(None)
    }

    async fn on_connect(&self, connection_id: &str) -> Result<()> {
        println!("新连接: {}", connection_id);
        Ok(())
    }

    async fn on_disconnect(&self, connection_id: &str) -> Result<()> {
        println!("连接断开: {}", connection_id);
        Ok(())
    }
}

#[tokio::main]
async fn main() -> Result<()> {
    let handler = Arc::new(MyHandler);
    
    let mut server = ObserverServerBuilder::new("0.0.0.0:8080")
        .with_handler(handler)
        .build()?;
    
    server.start().await?;
    tokio::signal::ctrl_c().await?;
    server.stop().await?;
    Ok(())
}
```

#### 简单模式

```rust
use flare_core::server::*;
use flare_core::common::*;

#[tokio::main]
async fn main() -> Result<()> {
    let mut server = ServerBuilder::new("0.0.0.0:8080")
        .on_message(|frame, ctx| async move {
            // 处理消息
            Ok(None)
        })
        .on_connect(|conn_id, ctx| async move {
            println!("新连接: {}", conn_id);
            Ok(())
        })
        .build()?;
    
    server.start().await?;
    tokio::signal::ctrl_c().await?;
    server.stop().await?;
    Ok(())
}
```

### 客户端示例

#### 观察者模式(推荐)

```rust
use flare_core::client::*;
use flare_core::transport::events::*;
use std::sync::Arc;

// 实现 ConnectionObserver
struct MyObserver;

impl ConnectionObserver for MyObserver {
    fn on_event(&self, event: &ConnectionEvent) {
        match event {
            ConnectionEvent::Connected => println!("已连接"),
            ConnectionEvent::Disconnected(reason) => println!("断开: {}", reason),
            ConnectionEvent::Message(data) => {
                // 处理消息
            }
            ConnectionEvent::Error(e) => eprintln!("错误: {:?}", e),
        }
    }
}

#[tokio::main]
async fn main() -> Result<()> {
    let observer = Arc::new(MyObserver);
    
    let mut client = ObserverClientBuilder::new("ws://127.0.0.1:8080")
        .with_observer(observer)
        .build_with_race()
        .await?;
    
    // 发送消息
    let frame = /* ... */;
    client.send_frame(&frame).await?;
    
    tokio::signal::ctrl_c().await?;
    client.disconnect().await?;
    Ok(())
}
```

#### 简单模式

```rust
use flare_core::client::*;

#[tokio::main]
async fn main() -> Result<()> {
    let mut client = ClientBuilder::new("ws://127.0.0.1:8080")
        .on_message(|frame| {
            println!("收到消息: {:?}", frame);
            Ok(())
        })
        .on_event(|event| {
            println!("事件: {:?}", event);
        })
        .build_with_race()
        .await?;
    
    // 使用客户端...
    Ok(())
}
```

## 📚 核心模块

### 服务端模块 (`server`)

- **`HybridServer`** - 混合服务端,支持多协议监听
- **`ServerBuilder`** / **`ObserverServerBuilder`** - 服务端构建器
- **`ConnectionManager`** - 连接管理器
- **`ServerCore`** - 服务端核心功能(连接管理、心跳检测、协商处理)
- **`Authenticator`** - 认证器接口
- **`DeviceManager`** - 设备管理器
- **`ServerEventHandler`** - 事件处理器接口

### 客户端模块 (`client`)

- **`HybridClient`** - 混合客户端,支持协议竞速
- **`ClientBuilder`** / **`ObserverClientBuilder`** - 客户端构建器
- **`ClientCore`** - 客户端核心功能(状态管理、心跳管理、消息路由)
- **`ConnectionObserver`** - 连接观察者接口
- **`ClientEventHandler`** - 事件处理器接口

### 公共模块 (`common`)

- **`MessageParser`** - 消息解析器(支持 Protobuf 和 JSON)
- **`CompressionAlgorithm`** - 压缩算法(None、Gzip、Zstd)
- **`SerializationFormat`** - 序列化格式(Protobuf、JSON)
- **`DeviceInfo`** - 设备信息
- **`DeviceConflictStrategy`** - 设备冲突策略
- **`FlareError`** - 统一错误类型

### 传输模块 (`transport`)

- **`Connection`** - 连接接口
- **`ConnectionEvent`** - 连接事件
- **`WebSocketTransport`** - WebSocket 传输实现
- **`QUICTransport`** - QUIC 传输实现

## 🔧 高级功能

### 认证配置

```rust
use flare_core::server::*;

// 自定义认证器
struct MyAuthenticator;

#[async_trait::async_trait]
impl Authenticator for MyAuthenticator {
    async fn authenticate(
        &self,
        token: &str,
        connection_id: &str,
        device_info: Option<&DeviceInfo>,
        metadata: Option<&HashMap<String, Vec<u8>>>,
    ) -> Result<AuthResult> {
        // 验证 token
        if token == "valid_token" {
            Ok(AuthResult::success(Some("user123".to_string())))
        } else {
            Ok(AuthResult::failure("Token 无效".to_string()))
        }
    }
}

let authenticator = Arc::new(MyAuthenticator);
let server = ObserverServerBuilder::new("0.0.0.0:8080")
    .enable_auth()
    .with_authenticator(authenticator)
    .with_auth_timeout(Duration::from_secs(30))
    .build()?;
```

### 设备管理

```rust
use flare_core::server::*;
use flare_core::common::device::*;

let device_manager = Arc::new(DeviceManager::new(
    DeviceConflictStrategyBuilder::new()
        .platform_exclusive() // 平台互斥
        .build()
));

let server = ObserverServerBuilder::new("0.0.0.0:8080")
    .with_device_manager(device_manager)
    .build()?;
```

### 序列化协商

```rust
// 服务端:设置默认格式
let server = ObserverServerBuilder::new("0.0.0.0:8080")
    .with_default_format(SerializationFormat::Protobuf)
    .with_default_compression(CompressionAlgorithm::Gzip)
    .build()?;

// 客户端:设置首选格式(协商模式)
let client = ObserverClientBuilder::new("ws://127.0.0.1:8080")
    .with_format(SerializationFormat::Protobuf)
    .with_compression(CompressionAlgorithm::Gzip)
    .build_with_race()
    .await?;

// 客户端:强制指定格式(不协商)
let client = ObserverClientBuilder::new("ws://127.0.0.1:8080")
    .force_format(SerializationFormat::Json) // 强制使用 JSON
    .build_with_race()
    .await?;
```

### 协议竞速

```rust
use flare_core::common::config_types::TransportProtocol;

let client = ObserverClientBuilder::new("127.0.0.1:8080")
    .with_protocol_race(vec![
        TransportProtocol::QUIC,      // 优先级 0(最高)
        TransportProtocol::WebSocket,  // 优先级 1
    ])
    .with_protocol_url(TransportProtocol::WebSocket, "ws://127.0.0.1:8080".to_string())
    .with_protocol_url(TransportProtocol::QUIC, "quic://127.0.0.1:8081".to_string())
    .build_with_race()
    .await?;
```

## 📖 文档

### API 文档

完整的 API 文档请查看 [docs.rs/flare-core](https://docs.rs/flare-core)

### 示例

项目包含丰富的示例,位于 `examples/` 目录:

- **基础示例**
  - `websocket_server.rs` / `websocket_client.rs` - WebSocket 基础示例
  - `quic_server.rs` / `quic_client.rs` - QUIC 基础示例
  - `hybrid_server.rs` / `hybrid_client.rs` - 混合协议示例

- **高级示例**
  - `negotiation_server.rs` / `negotiation_client.rs` - 序列化协商和设备管理示例
  - `auth_server.rs` / `auth_client.rs` - 认证示例
  - `simple_server.rs` / `simple_client.rs` - 简单模式示例

运行示例:

```bash
# 查看所有示例
cargo run --example <example_name>

# 查看示例说明
cat examples/README.md
```

## 🏗️ 架构设计

### 模块分层

```
┌─────────────────────────────────────────┐
│          应用层 (Application)            │
│  - ConnectionHandler / ConnectionObserver │
│  - EventHandler                          │
│  - Authenticator                         │
└─────────────────────────────────────────┘
┌─────────────────────────────────────────┐
│          核心层 (Core)                    │
│  - ServerCore / ClientCore               │
│  - ConnectionManager                     │
│  - HeartbeatDetector / HeartbeatManager  │
│  - DeviceManager                         │
└─────────────────────────────────────────┘
┌─────────────────────────────────────────┐
│          协议层 (Protocol)                │
│  - WebSocketServer / WebSocketClient     │
│  - QUICServer / QUICClient               │
│  - HybridServer / HybridClient           │
└─────────────────────────────────────────┘
┌─────────────────────────────────────────┐
│          传输层 (Transport)                │
│  - WebSocketTransport                    │
│  - QUICTransport                         │
│  - Connection trait                      │
└─────────────────────────────────────────┘
```

### 核心组件

1. **ServerCore** / **ClientCore**
   - 统一管理连接状态、心跳、消息路由
   - 处理协商、设备冲突、认证等核心逻辑

2. **ConnectionManager**
   - 管理所有活跃连接
   - 支持按连接ID、用户ID查询
   - 维护连接状态和元数据

3. **MessageParser**
   - 支持 Protobuf 和 JSON 自动检测
   - 支持压缩/解压缩
   - 协商后动态更新解析器

4. **DeviceManager**
   - 管理用户设备
   - 实现设备冲突策略
   - 处理设备踢出逻辑

## 🔒 安全性

- **认证机制** - 支持可配置的 token 验证
- **连接状态** - 只有已验证的连接才能收发业务消息
- **TLS 支持** - 支持 TLS/SSL 加密(WebSocket 和 QUIC)
- **错误处理** - 完善的错误处理和日志记录

## 📊 性能特性

- **异步架构** - 基于 Tokio 的高性能异步运行时
- **零拷贝** - 尽可能减少数据拷贝
- **连接复用** - 高效的连接管理
- **协议竞速** - 自动选择最快的协议

## 📦 发布到 crates.io

### 安装

```bash
cargo add flare-core
```

### 发布准备

发布前请确保:

1. ✅ 所有代码已通过测试和 lint 检查
2. ✅ 文档已更新
3. ✅ 版本号已更新
4. ✅ README.md 和 Cargo.toml 已完善

详细发布指南请查看 [PUBLISH.md](PUBLISH.md)。

### 发布命令

```bash
# 1. 登录 crates.io(首次发布需要)
cargo login <your-token>

# 2. 检查打包
cargo package

# 3. 发布
cargo publish
```

## 🤝 贡献

欢迎贡献!请查看 [CONTRIBUTING.md](CONTRIBUTING.md) 了解详细信息。

## 📄 许可证

本项目采用 MIT 许可证。详见 [LICENSE](LICENSE) 文件。

## 🔗 相关链接

- [文档]https://docs.rs/flare-core
- [GitHub 仓库]https://github.com/flare-team/flare-core
- [问题反馈]https://github.com/flare-team/flare-core/issues
- [crates.io]https://crates.io/crates/flare-core

## 📝 版本历史

### 0.1.0 (当前版本)

- ✨ 初始发布
- 支持 WebSocket 和 QUIC 协议
- 支持协议竞速
- 支持序列化协商(Protobuf/JSON)
- 支持压缩算法(None/Gzip/Zstd)
- 支持多设备管理
- 支持 Token 认证
- 提供观察者模式和简单模式两种构建方式
- 完善的事件处理机制

---

**Flare Core** - 让实时通信变得简单 🚀