mirror of
https://github.com/mii443/openai-api-rs.git
synced 2025-12-03 02:58:20 +00:00
Add text-to-speech
This commit is contained in:
@@ -3,8 +3,8 @@ use crate::v1::assistant::{
|
||||
ListAssistant, ListAssistantFile,
|
||||
};
|
||||
use crate::v1::audio::{
|
||||
AudioTranscriptionRequest, AudioTranscriptionResponse, AudioTranslationRequest,
|
||||
AudioTranslationResponse,
|
||||
AudioSpeechRequest, AudioSpeechResponse, AudioTranscriptionRequest, AudioTranscriptionResponse,
|
||||
AudioTranslationRequest, AudioTranslationResponse,
|
||||
};
|
||||
use crate::v1::chat_completion::{ChatCompletionRequest, ChatCompletionResponse};
|
||||
use crate::v1::completion::{CompletionRequest, CompletionResponse};
|
||||
@@ -38,6 +38,9 @@ use crate::v1::run::{
|
||||
use crate::v1::thread::{CreateThreadRequest, ModifyThreadRequest, ThreadObject};
|
||||
|
||||
use minreq::Response;
|
||||
use std::fs::{create_dir_all, File};
|
||||
use std::io::Write;
|
||||
use std::path::Path;
|
||||
|
||||
const API_URL_V1: &str = "https://api.openai.com/v1";
|
||||
|
||||
@@ -300,6 +303,39 @@ impl Client {
|
||||
}
|
||||
}
|
||||
|
||||
pub fn audio_speech(&self, req: AudioSpeechRequest) -> Result<AudioSpeechResponse, APIError> {
|
||||
let res = self.post("/audio/speech", &req)?;
|
||||
let bytes = res.as_bytes();
|
||||
let path = req.output.as_str();
|
||||
let path = Path::new(path);
|
||||
if let Some(parent) = path.parent() {
|
||||
match create_dir_all(parent) {
|
||||
Ok(_) => {}
|
||||
Err(e) => {
|
||||
return Err(APIError {
|
||||
message: e.to_string(),
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
match File::create(path) {
|
||||
Ok(mut file) => match file.write_all(bytes) {
|
||||
Ok(_) => {}
|
||||
Err(e) => {
|
||||
return Err(APIError {
|
||||
message: e.to_string(),
|
||||
})
|
||||
}
|
||||
},
|
||||
Err(e) => {
|
||||
return Err(APIError {
|
||||
message: e.to_string(),
|
||||
})
|
||||
}
|
||||
}
|
||||
Ok(AudioSpeechResponse { result: true })
|
||||
}
|
||||
|
||||
pub fn create_fine_tune(
|
||||
&self,
|
||||
req: CreateFineTuneRequest,
|
||||
|
||||
@@ -79,3 +79,39 @@ impl_builder_methods!(
|
||||
pub struct AudioTranslationResponse {
|
||||
pub text: String,
|
||||
}
|
||||
|
||||
pub const TTS_1: &str = "tts-1";
|
||||
pub const TTS_1_HD: &str = "tts-1-hd";
|
||||
|
||||
pub const VOICE_ALLOY: &str = "alloy";
|
||||
pub const VOICE_ECHO: &str = "echo";
|
||||
pub const VOICE_FABLE: &str = "fable";
|
||||
pub const VOICE_ONYX: &str = "onyx";
|
||||
pub const VOICE_NOVA: &str = "nova";
|
||||
pub const VOICE_SHIMMER: &str = "shimmer";
|
||||
|
||||
#[derive(Debug, Serialize, Clone)]
|
||||
pub struct AudioSpeechRequest {
|
||||
pub model: String,
|
||||
pub input: String,
|
||||
pub voice: String,
|
||||
pub output: String,
|
||||
}
|
||||
|
||||
impl AudioSpeechRequest {
|
||||
pub fn new(model: String, input: String, voice: String, output: String) -> Self {
|
||||
Self {
|
||||
model,
|
||||
input,
|
||||
voice,
|
||||
output,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl_builder_methods!(AudioSpeechRequest,);
|
||||
|
||||
#[derive(Debug, Deserialize)]
|
||||
pub struct AudioSpeechResponse {
|
||||
pub result: bool,
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user