-
Notifications
You must be signed in to change notification settings - Fork 48
/
c02-auth.rs
54 lines (42 loc) · 1.79 KB
/
c02-auth.rs
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
//! This example demonstrates how to use a custom authentication function to override the default AuthData resolution
//! for any specific adapter (which is based on environment variables).
use genai::chat::printer::print_chat_stream;
use genai::chat::{ChatMessage, ChatRequest};
use genai::resolver::{AuthData, AuthResolver};
use genai::{Client, ModelIden};
const MODEL: &str = "gpt-4o-mini";
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let questions = &[
// Follow-up questions
"Why is the sky blue?",
"Why is it red sometimes?",
];
// -- Build an auth_resolver and the AdapterConfig
let auth_resolver = AuthResolver::from_resolver_fn(
|model_iden: ModelIden| -> Result<Option<AuthData>, genai::resolver::Error> {
let ModelIden {
adapter_kind,
model_name,
} = model_iden;
println!("\n>> Custom auth provider for {adapter_kind} (model: {model_name}) <<");
// This will cause it to fail if any model is not an OPEN_API_KEY
let key = std::env::var("OPENAI_API_KEY").map_err(|_| genai::resolver::Error::ApiKeyEnvNotFound {
env_name: "OPENAI_API_KEY".to_string(),
})?;
Ok(Some(AuthData::from_single(key)))
},
);
// -- Build the new client with this adapter_config
let client = Client::builder().with_auth_resolver(auth_resolver).build();
let mut chat_req = ChatRequest::default().with_system("Answer in one sentence");
for &question in questions {
chat_req = chat_req.append_message(ChatMessage::user(question));
println!("\n--- Question:\n{question}");
let chat_res = client.exec_chat_stream(MODEL, chat_req.clone(), None).await?;
println!("\n--- Answer: (streaming)");
let assistant_answer = print_chat_stream(chat_res, None).await?;
chat_req = chat_req.append_message(ChatMessage::assistant(assistant_answer));
}
Ok(())
}