use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize, bon::Builder)]
pub struct RealtimeConversationItemWithReferenceContentInner {
#[serde(rename = "type", skip_serializing_if = "Option::is_none")]
pub r#type: Option<Type>,
#[serde(rename = "text", skip_serializing_if = "Option::is_none")]
pub text: Option<String>,
#[serde(rename = "id", skip_serializing_if = "Option::is_none")]
pub id: Option<String>,
#[serde(rename = "audio", skip_serializing_if = "Option::is_none")]
pub audio: Option<String>,
#[serde(rename = "transcript", skip_serializing_if = "Option::is_none")]
pub transcript: Option<String>,
}
impl RealtimeConversationItemWithReferenceContentInner {
pub fn new() -> RealtimeConversationItemWithReferenceContentInner {
RealtimeConversationItemWithReferenceContentInner {
r#type: None,
text: None,
id: None,
audio: None,
transcript: None,
}
}
}
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Type {
#[serde(rename = "input_audio")]
InputAudio,
#[serde(rename = "input_text")]
InputText,
#[serde(rename = "item_reference")]
ItemReference,
#[serde(rename = "text")]
Text,
}
impl Default for Type {
fn default() -> Type {
Self::InputAudio
}
}
impl std::fmt::Display for RealtimeConversationItemWithReferenceContentInner {
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),
}
}
}