Skip to content

Commit

Permalink
Merge pull request #43 from dongri/assistant
Browse files Browse the repository at this point in the history
Add assistant api
  • Loading branch information
Dongri Jin committed Nov 11, 2023
2 parents 6e07047 + cfca665 commit 075acf5
Show file tree
Hide file tree
Showing 19 changed files with 966 additions and 48 deletions.
64 changes: 64 additions & 0 deletions examples/assistant.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
use openai_api_rs::v1::api::Client;
use openai_api_rs::v1::assistant::AssistantRequest;
use openai_api_rs::v1::common::GPT4_1106_PREVIEW;
use openai_api_rs::v1::message::{CreateMessageRequest, MessageRole};
use openai_api_rs::v1::run::CreateRunRequest;
use openai_api_rs::v1::thread::CreateThreadRequest;
use std::collections::HashMap;
use std::env;

fn main() -> Result<(), Box<dyn std::error::Error>> {
let client = Client::new(env::var("OPENAI_API_KEY").unwrap().to_string());

let mut tools = HashMap::new();
tools.insert("type".to_string(), "code_interpreter".to_string());

let req = AssistantRequest::new(GPT4_1106_PREVIEW.to_string());
req.clone()
.description("this is a test assistant".to_string());
req.clone().instructions("You are a personal math tutor. When asked a question, write and run Python code to answer the question.".to_string());
req.clone().tools(vec![tools]);
let result = client.create_assistant(req)?;
println!("{:?}", result.id);

let thread_req = CreateThreadRequest::new();
let thread_result = client.create_thread(thread_req)?;
println!("{:?}", thread_result.id.clone());

let message_req = CreateMessageRequest::new(
MessageRole::user,
"`I need to solve the equation 3x + 11 = 14. Can you help me?".to_string(),
);

let message_result = client.create_message(thread_result.id.clone(), message_req)?;
println!("{:?}", message_result.id.clone());

let run_req = CreateRunRequest::new(result.id);
let run_result = client.create_run(thread_result.id.clone(), run_req)?;

loop {
let run_result = client
.retrieve_run(thread_result.id.clone(), run_result.id.clone())
.unwrap();
if run_result.status == "completed" {
break;
} else {
println!("waiting...");
std::thread::sleep(std::time::Duration::from_secs(1));
}
}

let list_message_result = client.list_messages(thread_result.id.clone()).unwrap();
for data in list_message_result.data {
for content in data.content {
println!(
"{:?}: {:?} {:?}",
data.role, content.text.value, content.text.annotations
);
}
}

Ok(())
}

// OPENAI_API_KEY=xxxx cargo run --package openai-api-rs --example assistant
3 changes: 2 additions & 1 deletion examples/chat_completion.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
use openai_api_rs::v1::api::Client;
use openai_api_rs::v1::chat_completion::{self, ChatCompletionRequest};
use openai_api_rs::v1::common::GPT4;
use std::env;

fn main() -> Result<(), Box<dyn std::error::Error>> {
let client = Client::new(env::var("OPENAI_API_KEY").unwrap().to_string());

let req = ChatCompletionRequest::new(
chat_completion::GPT4.to_string(),
GPT4.to_string(),
vec![chat_completion::ChatCompletionMessage {
role: chat_completion::MessageRole::user,
content: String::from("What is Bitcoin?"),
Expand Down
3 changes: 2 additions & 1 deletion examples/function_call.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use openai_api_rs::v1::api::Client;
use openai_api_rs::v1::chat_completion::{self, ChatCompletionRequest, FunctionCallType};
use openai_api_rs::v1::common::GPT3_5_TURBO_0613;
use serde::{Deserialize, Serialize};
use std::collections::HashMap;
use std::{env, vec};
Expand Down Expand Up @@ -30,7 +31,7 @@ fn main() -> Result<(), Box<dyn std::error::Error>> {
);

let req = ChatCompletionRequest::new(
chat_completion::GPT3_5_TURBO_0613.to_string(),
GPT3_5_TURBO_0613.to_string(),
vec![chat_completion::ChatCompletionMessage {
role: chat_completion::MessageRole::user,
content: String::from("What is the price of Ethereum?"),
Expand Down
5 changes: 3 additions & 2 deletions examples/function_call_role.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use openai_api_rs::v1::api::Client;
use openai_api_rs::v1::chat_completion::{self, ChatCompletionRequest};
use openai_api_rs::v1::common::GPT3_5_TURBO_0613;
use serde::{Deserialize, Serialize};
use std::collections::HashMap;
use std::{env, vec};
Expand Down Expand Up @@ -30,7 +31,7 @@ fn main() -> Result<(), Box<dyn std::error::Error>> {
);

let req = ChatCompletionRequest::new(
chat_completion::GPT3_5_TURBO_0613.to_string(),
GPT3_5_TURBO_0613.to_string(),
vec![chat_completion::ChatCompletionMessage {
role: chat_completion::MessageRole::user,
content: String::from("What is the price of Ethereum?"),
Expand Down Expand Up @@ -70,7 +71,7 @@ fn main() -> Result<(), Box<dyn std::error::Error>> {
let coin = c.coin;

let req = ChatCompletionRequest::new(
chat_completion::GPT3_5_TURBO_0613.to_string(),
GPT3_5_TURBO_0613.to_string(),
vec![
chat_completion::ChatCompletionMessage {
role: chat_completion::MessageRole::user,
Expand Down
Loading

0 comments on commit 075acf5

Please sign in to comment.