vapi_client/models/
lmnt_voice.rs

1/*
2 * Vapi API
3 *
4 * Voice AI for developers.
5 *
6 * The version of the OpenAPI document: 1.0
7 * 
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
15pub struct LmntVoice {
16    /// This is the voice provider that will be used.
17    #[serde(rename = "provider")]
18    pub provider: Provider,
19    #[serde(rename = "voiceId")]
20    pub voice_id: Box<models::LmntVoiceVoiceId>,
21    /// This is the speed multiplier that will be used.
22    #[serde(rename = "speed", skip_serializing_if = "Option::is_none")]
23    pub speed: Option<f64>,
24    /// This is the plan for chunking the model output before it is sent to the voice provider.
25    #[serde(rename = "chunkPlan", skip_serializing_if = "Option::is_none")]
26    pub chunk_plan: Option<Box<models::ChunkPlan>>,
27    /// This is the plan for voice provider fallbacks in the event that the primary voice provider fails.
28    #[serde(rename = "fallbackPlan", skip_serializing_if = "Option::is_none")]
29    pub fallback_plan: Option<Box<models::FallbackPlan>>,
30}
31
32impl LmntVoice {
33    pub fn new(provider: Provider, voice_id: models::LmntVoiceVoiceId) -> LmntVoice {
34        LmntVoice {
35            provider,
36            voice_id: Box::new(voice_id),
37            speed: None,
38            chunk_plan: None,
39            fallback_plan: None,
40        }
41    }
42}
43/// This is the voice provider that will be used.
44#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
45pub enum Provider {
46    #[serde(rename = "lmnt")]
47    Lmnt,
48}
49
50impl Default for Provider {
51    fn default() -> Provider {
52        Self::Lmnt
53    }
54}
55