use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize, bon::Builder)]
pub struct RealtimeTranscriptionSessionCreateResponseGa {
#[serde(rename = "type")]
pub r#type: Type,
#[serde(rename = "id")]
pub id: String,
#[serde(rename = "object")]
pub object: String,
#[serde(rename = "expires_at", skip_serializing_if = "Option::is_none")]
pub expires_at: Option<i32>,
#[serde(rename = "include", skip_serializing_if = "Option::is_none")]
pub include: Option<Vec<Include>>,
#[serde(rename = "audio", skip_serializing_if = "Option::is_none")]
pub audio: Option<Box<models::RealtimeTranscriptionSessionCreateResponseGaAudio>>,
}
impl RealtimeTranscriptionSessionCreateResponseGa {
pub fn new(
r#type: Type,
id: String,
object: String,
) -> RealtimeTranscriptionSessionCreateResponseGa {
RealtimeTranscriptionSessionCreateResponseGa {
r#type,
id,
object,
expires_at: None,
include: None,
audio: None,
}
}
}
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Type {
#[serde(rename = "transcription")]
Transcription,
}
impl Default for Type {
fn default() -> Type {
Self::Transcription
}
}
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Include {
#[serde(rename = "item.input_audio_transcription.logprobs")]
ItemInputAudioTranscriptionLogprobs,
}
impl Default for Include {
fn default() -> Include {
Self::ItemInputAudioTranscriptionLogprobs
}
}
impl std::fmt::Display for RealtimeTranscriptionSessionCreateResponseGa {
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),
}
}
}