use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, bon::Builder)]
pub struct CreateTranscriptionResponseDiarizedJson {
#[serde(rename = "task")]
pub task: Task,
#[serde(rename = "duration")]
pub duration: f64,
#[serde(rename = "text")]
pub text: String,
#[serde(rename = "segments")]
pub segments: Vec<models::TranscriptionDiarizedSegment>,
#[serde(rename = "usage", skip_serializing_if = "Option::is_none")]
pub usage: Option<Box<models::CreateTranscriptionResponseDiarizedJsonUsage>>,
}
impl CreateTranscriptionResponseDiarizedJson {
pub fn new(
task: Task,
duration: f64,
text: String,
segments: Vec<models::TranscriptionDiarizedSegment>,
) -> CreateTranscriptionResponseDiarizedJson {
CreateTranscriptionResponseDiarizedJson {
task,
duration,
text,
segments,
usage: None,
}
}
}
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Task {
#[serde(rename = "transcribe")]
Transcribe,
}
impl Default for Task {
fn default() -> Task {
Self::Transcribe
}
}
impl std::fmt::Display for CreateTranscriptionResponseDiarizedJson {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match serde_json::to_string(self) {
Ok(s) => write!(f, "{}", s),
Err(_) => Err(std::fmt::Error),
}
}
}