mirror of
https://github.com/mii443/openai-api-rs.git
synced 2025-08-23 15:48:07 +00:00
Merge pull request #28 from dongri/add-header-for-organization
Add new_with_organization
This commit is contained in:
@ -31,6 +31,7 @@ const API_URL_V1: &str = "https://api.openai.com/v1";
|
||||
pub struct Client {
|
||||
pub api_endpoint: String,
|
||||
pub api_key: String,
|
||||
pub organization: Option<String>,
|
||||
}
|
||||
|
||||
impl Client {
|
||||
@ -43,30 +44,58 @@ impl Client {
|
||||
Self {
|
||||
api_endpoint,
|
||||
api_key,
|
||||
organization: None,
|
||||
}
|
||||
}
|
||||
|
||||
pub fn new_with_organization(api_key: String, organization: String) -> Self {
|
||||
let endpoint = std::env::var("OPENAI_API_BASE").unwrap_or_else(|_| API_URL_V1.to_owned());
|
||||
Self {
|
||||
api_endpoint: endpoint,
|
||||
api_key,
|
||||
organization: organization.into(),
|
||||
}
|
||||
}
|
||||
|
||||
pub async fn client_builder(&self) -> Result<reqwest::Client, reqwest::Error> {
|
||||
let mut headers = reqwest::header::HeaderMap::new();
|
||||
headers.insert(
|
||||
reqwest::header::CONTENT_TYPE,
|
||||
reqwest::header::HeaderValue::from_static("application/json"),
|
||||
);
|
||||
headers.insert(
|
||||
reqwest::header::AUTHORIZATION,
|
||||
reqwest::header::HeaderValue::from_str(&("Bearer ".to_owned() + &self.api_key))
|
||||
.unwrap(),
|
||||
);
|
||||
match &self.organization {
|
||||
Some(organization) => headers.insert(
|
||||
reqwest::header::HeaderName::from_static("openai-organization"),
|
||||
reqwest::header::HeaderValue::from_str(organization).unwrap(),
|
||||
),
|
||||
None => None,
|
||||
};
|
||||
let client = reqwest::Client::builder()
|
||||
.default_headers(headers)
|
||||
.build()?;
|
||||
Ok(client)
|
||||
}
|
||||
|
||||
pub async fn post<T: serde::ser::Serialize>(
|
||||
&self,
|
||||
path: &str,
|
||||
params: &T,
|
||||
) -> Result<Response, APIError> {
|
||||
let client = reqwest::Client::new();
|
||||
let url = format!(
|
||||
"{api_endpoint}{path}",
|
||||
api_endpoint = self.api_endpoint,
|
||||
path = path
|
||||
);
|
||||
let res = client
|
||||
.post(&url)
|
||||
.header(reqwest::header::CONTENT_TYPE, "application/json")
|
||||
.header(
|
||||
reqwest::header::AUTHORIZATION,
|
||||
"Bearer ".to_owned() + &self.api_key,
|
||||
)
|
||||
.json(¶ms)
|
||||
.send()
|
||||
.await;
|
||||
let client = match self.client_builder().await {
|
||||
Ok(c) => c,
|
||||
Err(e) => return Err(self.new_error(e)),
|
||||
};
|
||||
let res = client.post(&url).json(¶ms).send().await;
|
||||
match res {
|
||||
Ok(res) => match res.status().is_success() {
|
||||
true => Ok(res),
|
||||
@ -79,21 +108,16 @@ impl Client {
|
||||
}
|
||||
|
||||
pub async fn get(&self, path: &str) -> Result<Response, APIError> {
|
||||
let client = reqwest::Client::new();
|
||||
let url = format!(
|
||||
"{api_endpoint}{path}",
|
||||
api_endpoint = self.api_endpoint,
|
||||
path = path
|
||||
);
|
||||
let res = client
|
||||
.get(&url)
|
||||
.header(reqwest::header::CONTENT_TYPE, "application/json")
|
||||
.header(
|
||||
reqwest::header::AUTHORIZATION,
|
||||
"Bearer ".to_owned() + &self.api_key,
|
||||
)
|
||||
.send()
|
||||
.await;
|
||||
let client = match self.client_builder().await {
|
||||
Ok(c) => c,
|
||||
Err(e) => return Err(self.new_error(e)),
|
||||
};
|
||||
let res = client.get(&url).send().await;
|
||||
match res {
|
||||
Ok(res) => match res.status().is_success() {
|
||||
true => Ok(res),
|
||||
@ -106,21 +130,16 @@ impl Client {
|
||||
}
|
||||
|
||||
pub async fn delete(&self, path: &str) -> Result<Response, APIError> {
|
||||
let client = reqwest::Client::new();
|
||||
let url = format!(
|
||||
"{api_endpoint}{path}",
|
||||
api_endpoint = self.api_endpoint,
|
||||
path = path
|
||||
);
|
||||
let res = client
|
||||
.delete(&url)
|
||||
.header(reqwest::header::CONTENT_TYPE, "application/json")
|
||||
.header(
|
||||
reqwest::header::AUTHORIZATION,
|
||||
"Bearer ".to_owned() + &self.api_key,
|
||||
)
|
||||
.send()
|
||||
.await;
|
||||
let client = match self.client_builder().await {
|
||||
Ok(c) => c,
|
||||
Err(e) => return Err(self.new_error(e)),
|
||||
};
|
||||
let res = client.delete(&url).send().await;
|
||||
match res {
|
||||
Ok(res) => match res.status().is_success() {
|
||||
true => Ok(res),
|
||||
|
Reference in New Issue
Block a user