async_translate/
lib.rs

1//! # async-translate
2//!
3//! 一个支持并发的翻译库,目前支持 OpenAI 和微软翻译服务。
4//!
5//! ## 功能特性
6//!
7//! - 支持 OpenAI 翻译接口
8//!   - 支持自定义 base URL、模型、API Key
9//!   - 支持多 API Key 配置,每个 Key 单独计算并发数和 RPM
10//!   - RPM 和并发数可选配置,具备默认数值
11//! - 支持微软翻译接口
12//!   - 自动获取临时认证token,无需配置API密钥
13//!   - 支持并发操作
14//! - 统一的翻译接口,易于扩展
15//! - 类型安全的语言标识符支持
16//! - 可配置的超时和重试机制
17//!
18//! ## 使用方法
19//!
20//! ```rust,no_run
21//! use async_translate::{TranslationManager, OpenAITranslator, OpenAIConfig, MicrosoftTranslator, MicrosoftConfig, LanguageIdentifier, TranslateOptions};
22//! use std::time::Duration;
23//!
24//! #[tokio::main]
25//! async fn main() -> Result<(), Box<dyn std::error::Error>> {
26//!     // 创建翻译管理器
27//!     let mut manager = TranslationManager::new();
28//!
29//!     // 配置 OpenAI 翻译器
30//!     let openai_config = OpenAIConfig {
31//!         base_url: "https://api.openai.com/v1".to_string(),
32//!         model: "gpt-3.5-turbo".to_string(),
33//!         api_keys: vec!["your-openai-api-key".to_string()],
34//!         rpm_limit: 60,
35//!         concurrent_limit: 10,
36//!         system_prompt: None,
37//!     };
38//!     let openai_translator = Box::new(OpenAITranslator::new(openai_config));
39//!     manager.add_translator("openai", openai_translator);
40//!
41//!     // 配置微软翻译器(自动获取认证token)
42//!     let microsoft_config = MicrosoftConfig {
43//!         endpoint: None,  // 使用默认端点
44//!         api_key: None,   // 使用自动认证
45//!         concurrent_limit: 10,
46//!     };
47//!     let microsoft_translator = Box::new(MicrosoftTranslator::new(microsoft_config));
48//!     manager.add_translator("microsoft", microsoft_translator);
49//!
50//!     // 执行翻译
51//!     let text = "Hello, world!";
52//!     let target_lang: LanguageIdentifier = "zh".parse().unwrap();
53//!
54//!     // 基本翻译(使用默认配置)
55//!     let result = manager.translate("openai", text, &target_lang, None).await?;
56//!     println!("OpenAI Translation: {}", result);
57//!
58//!     // 带配置的翻译
59//!     let options = TranslateOptions::default()
60//!         .timeout(Duration::from_secs(60))
61//!         .max_retries(5);
62//!     let result = manager.translate_with_options("microsoft", text, &target_lang, None, &options).await?;
63//!     println!("Microsoft Translation: {}", result);
64//!
65//!     Ok(())
66//! }
67//! ```
68
69pub mod error;
70pub mod manager;
71pub mod microsoft;
72pub mod openai;
73pub mod options;
74pub mod translator;
75
76pub use error::TranslationError;
77pub use manager::TranslationManager;
78pub use microsoft::{MicrosoftConfig, MicrosoftTranslator};
79pub use openai::{OpenAIConfig, OpenAITranslator};
80pub use options::TranslateOptions;
81pub use translator::Translator;
82
83// 导出语言标识符类型
84pub use unic_langid::LanguageIdentifier;