vapi-client 0.4.2

Unofficial crate for Vapi - Voice AI for developers.
Documentation
/*
 * Vapi API
 *
 * Voice AI for developers.
 *
 * The version of the OpenAPI document: 1.0
 *
 * Generated by: https://openapi-generator.tech
 */

use crate::models;
use serde::{Deserialize, Serialize};

#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct ComputerTool {
    /// These are the messages that will be spoken to the user as the tool is running.  For some tools, this is auto-filled based on special fields like `tool.destinations`. For others like the function tool, these can be custom configured.
    #[serde(rename = "messages", skip_serializing_if = "Option::is_none")]
    pub messages: Option<Vec<models::CreateDtmfToolDtoMessagesInner>>,
    /// The type of tool. \"computer\" for Computer tool.
    #[serde(rename = "type")]
    pub r#type: TypeTrue,
    /// The sub type of tool.
    #[serde(rename = "subType")]
    pub sub_type: SubTypeTrue,
    ///    This is the server where a `tool-calls` webhook will be sent.    Notes:   - Webhook is sent to this server when a tool call is made.   - Webhook contains the call, assistant, and phone number objects.   - Webhook contains the variables set on the assistant.   - Webhook is sent to the first available URL in this order: {{tool.server.url}}, {{assistant.server.url}}, {{phoneNumber.server.url}}, {{org.server.url}}.   - Webhook expects a response with tool call result.
    #[serde(rename = "server", skip_serializing_if = "Option::is_none")]
    pub server: Option<models::Server>,
    /// This is the unique identifier for the tool.
    #[serde(rename = "id")]
    pub id: String,
    /// This is the unique identifier for the organization that this tool belongs to.
    #[serde(rename = "orgId")]
    pub org_id: String,
    /// This is the ISO 8601 date-time string of when the tool was created.
    #[serde(rename = "createdAt")]
    pub created_at: String,
    /// This is the ISO 8601 date-time string of when the tool was last updated.
    #[serde(rename = "updatedAt")]
    pub updated_at: String,
    /// This is the function definition of the tool.  For `endCall`, `transferCall`, and `dtmf` tools, this is auto-filled based on tool-specific fields like `tool.destinations`. But, even in those cases, you can provide a custom function definition for advanced use cases.  An example of an advanced use case is if you want to customize the message that's spoken for `endCall` tool. You can specify a function where it returns an argument \"reason\". Then, in `messages` array, you can have many \"request-complete\" messages. One of these messages will be triggered if the `messages[].conditions` matches the \"reason\" argument.
    #[serde(rename = "function", skip_serializing_if = "Option::is_none")]
    pub function: Option<models::OpenAiFunction>,
    /// The name of the tool, fixed to 'computer'
    #[serde(rename = "name")]
    pub name: NameTrue,
    /// The display width in pixels
    #[serde(rename = "displayWidthPx")]
    pub display_width_px: f64,
    /// The display height in pixels
    #[serde(rename = "displayHeightPx")]
    pub display_height_px: f64,
    /// Optional display number
    #[serde(rename = "displayNumber", skip_serializing_if = "Option::is_none")]
    pub display_number: Option<f64>,
}

impl ComputerTool {
    pub fn new(
        r#type: TypeTrue,
        sub_type: SubTypeTrue,
        id: String,
        org_id: String,
        created_at: String,
        updated_at: String,
        name: NameTrue,
        display_width_px: f64,
        display_height_px: f64,
    ) -> ComputerTool {
        ComputerTool {
            messages: None,
            r#type,
            sub_type,
            server: None,
            id,
            org_id,
            created_at,
            updated_at,
            function: None,
            name,
            display_width_px,
            display_height_px,
            display_number: None,
        }
    }
}
/// The type of tool. \"computer\" for Computer tool.
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum TypeTrue {
    #[serde(rename = "computer")]
    Computer,
}

impl Default for TypeTrue {
    fn default() -> TypeTrue {
        Self::Computer
    }
}
/// The sub type of tool.
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum SubTypeTrue {
    #[serde(rename = "computer_20241022")]
    Computer20241022,
}

impl Default for SubTypeTrue {
    fn default() -> SubTypeTrue {
        Self::Computer20241022
    }
}
/// The name of the tool, fixed to 'computer'
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum NameTrue {
    #[serde(rename = "computer")]
    Computer,
}

impl Default for NameTrue {
    fn default() -> NameTrue {
        Self::Computer
    }
}