# OpenLark Client
现代化的 Rust 客户端库,为飞书开放平台提供类型安全的 API 访问。
> 普通用户请优先使用根 crate `openlark`。
>
> `openlark-client` 适合已经明确需要统一 `Client` 实现细节、或只想直接复用客户端层的高级用户。
## 🚀 特性
### ✨ **架构优势**
- **模块化设计**: 通过 feature 标志实现服务解耦
- **条件编译**: 只编译需要的服务,优化二进制大小
- **类型安全**: 编译时类型检查,避免运行时错误
- **向后兼容**: 提供兼容现有代码的迁移路径
- **服务元信息**: 编译期注册服务元信息用于可观测性
### 🎯 **核心功能**
- **1,000+ API 支持**: 覆盖飞书开放平台主要功能
- **服务元信息**: 启动时注册已编译服务元信息(用于可观测/依赖展示)
- **错误处理**: 企业级错误处理和恢复机制
- **性能优化**: 共享配置和内存优化
- **构建器模式**: 流畅的 API 配置体验
## 📦 安装
在 `Cargo.toml` 中添加:
```toml
[dependencies]
openlark-client = { version = "0.15.0", features = ["docs"] }
```
### 功能标志
```toml
# 默认启用:auth + communication(如需关闭:default-features = false)
# 文档服务(会启用 openlark-docs)
features = ["docs"]
# 通信服务(会启用 openlark-communication;默认已启用)
features = ["communication"]
# 认证服务(默认已启用)
features = ["auth"]
# CardKit(卡片能力,meta 调用链)
features = ["cardkit"]
# 会议服务
features = ["meeting"]
# WebSocket 支持
features = ["websocket"]
# 组合功能(P0 推荐)
features = ["p0-services"]
```
如果你只是要接入 SDK,而不是直接依赖客户端实现层,推荐改用:
```toml
[dependencies]
openlark = { version = "0.15.0", features = ["essential"] }
```
## 🧩 meta 调用链(按 CSV 映射)
本仓库提供一种"调用路径与 `api_list_export.csv` 的 `meta.*` 字段一一对应"的访问方式:
`client.{meta.Project}.{meta.Version}.{meta.Resource}.{meta.Name}(...)`
规范与示例见:`crates/openlark-client/docs/meta-api-style.md:1`
## 🔧 快速开始
### 基础用法
```rust
use openlark_client::prelude::*;
use std::time::Duration;
fn main() -> Result<()> {
// 使用构建器创建客户端
let _client = Client::builder()
.app_id("your_app_id")
.app_secret("your_app_secret")
.base_url("https://open.feishu.cn")
.timeout(Duration::from_secs(30))
.build()?;
Ok(())
}
```
### 从环境变量创建
```rust
use openlark_client::prelude::*;
fn main() -> Result<()> {
// 需要配置 OPENLARK_APP_ID / OPENLARK_APP_SECRET
let _client = Client::from_env()?;
Ok(())
}
```
## 🎪 服务访问
### meta 单入口(推荐)
```rust
use openlark_client::prelude::*;
fn main() -> Result<()> {
let client = Client::from_env()?;
// 文档入口(需启用 docs feature)
#[cfg(feature = "docs")]
let _docs_config = client.docs.config();
// 通讯入口(需启用 communication feature,默认启用)
#[cfg(feature = "communication")]
let _comm = &client.communication;
Ok(())
}
```
### 服务发现
```rust
use openlark_client::prelude::*;
fn main() -> Result<()> {
let client = Client::from_env()?;
// 列出已注册的服务元数据
for entry in client.registry().list_services() {
println!("可用服务: {}", entry.metadata.name);
}
// 检查特定服务是否已启用(元信息层面)
if client.registry().has_service("docs") {
println!("文档服务已启用");
}
Ok(())
}
```
## 🔄 迁移指南
### 从现有 LarkClient 迁移
1. **新代码**(推荐):
```rust
use openlark_client::prelude::*;
let client = Client::builder()
.app_id("app_id")
.app_secret("app_secret")
.build()?;
```
2. **服务访问更新**:
```rust
```
## 🏗️ 架构设计
### 服务注册表模式
```mermaid
graph TD
A[Client] --> B[DefaultServiceRegistry]
A --> C[meta clients<br/>docs/communication/auth/...]
D[registry::bootstrap] --> B
E[Cargo features] --> D
```
**说明**:
- **编译期**: Cargo features 决定哪些 meta client 字段被编译进 Client
- **启动期**: `registry::bootstrap` 注册已编译服务的元信息到 DefaultServiceRegistry
- **运行期**: Registry 仅提供元信息查询(服务名、依赖关系等),不管理服务实例生命周期
### 核心 Trait
- **`LarkClient`** (`src/traits/client.rs`): 客户端统一接口
- **`ServiceTrait`** (`src/traits/service.rs`): 服务基础约定
- **`ServiceLifecycle`** (`src/traits/service.rs`): 服务生命周期约定
## 🧪 测试
```bash
# 运行所有测试
cargo test -p openlark-client
# 测试特定功能
cargo test -p openlark-client --features docs
# 无功能测试
cargo test -p openlark-client --no-default-features
# 全功能测试
cargo test -p openlark-client --all-features
```
## 📚 文档
- **API 文档**: `cargo doc -p openlark-client --open`
- **Meta API 规范**: `crates/openlark-client/docs/meta-api-style.md`
- **核心概念**: 参见飞书开放平台官方文档
## 🤝 贡献
欢迎提交 Issue 和 Pull Request!
## 📄 许可证
Apache License 2.0