use serde::{Deserialize, Serialize};
#[derive(Debug, Clone, Serialize)]
pub struct CreateSpeechRequest {
pub model: String,
pub input: String,
pub voice: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub response_format: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub speed: Option<f64>,
}
#[derive(Debug, Clone)]
pub struct TranscriptionRequest {
pub model: String,
pub language: Option<String>,
pub prompt: Option<String>,
pub timestamps: Option<bool>,
}
#[derive(Debug, Clone, Deserialize)]
pub struct TranscriptionResponse {
pub text: String,
#[serde(default)]
pub language: Option<String>,
#[serde(default)]
pub duration: Option<f64>,
#[serde(default)]
pub segments: Option<Vec<TranscriptionSegment>>,
}
#[derive(Debug, Clone, Deserialize)]
pub struct TranscriptionSegment {
pub id: Option<u32>,
pub start: Option<f64>,
pub end: Option<f64>,
pub text: Option<String>,
}