vapi_client/models/
custom_llm_credential.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 CustomLlmCredential {
16    #[serde(rename = "provider")]
17    pub provider: ProviderTrue,
18    /// This is not returned in the API.
19    #[serde(rename = "apiKey")]
20    pub api_key: String,
21    /// This is the authentication plan. Currently supports OAuth2 RFC 6749. To use Bearer authentication, use apiKey
22    #[serde(rename = "authenticationPlan", skip_serializing_if = "Option::is_none")]
23    pub authentication_plan: Option<models::OAuth2AuthenticationPlan>,
24    /// This is the unique identifier for the credential.
25    #[serde(rename = "id")]
26    pub id: String,
27    /// This is the unique identifier for the org that this credential belongs to.
28    #[serde(rename = "orgId")]
29    pub org_id: String,
30    /// This is the ISO 8601 date-time string of when the credential was created.
31    #[serde(rename = "createdAt")]
32    pub created_at: String,
33    /// This is the ISO 8601 date-time string of when the assistant was last updated.
34    #[serde(rename = "updatedAt")]
35    pub updated_at: String,
36    /// This is the authentication session for the credential. Available for credentials that have an authentication plan.
37    #[serde(
38        rename = "authenticationSession",
39        skip_serializing_if = "Option::is_none"
40    )]
41    pub authentication_session: Option<models::Oauth2AuthenticationSession>,
42    /// This is the name of credential. This is just for your reference.
43    #[serde(rename = "name", skip_serializing_if = "Option::is_none")]
44    pub name: Option<String>,
45}
46
47impl CustomLlmCredential {
48    pub fn new(
49        provider: ProviderTrue,
50        api_key: String,
51        id: String,
52        org_id: String,
53        created_at: String,
54        updated_at: String,
55    ) -> CustomLlmCredential {
56        CustomLlmCredential {
57            provider,
58            api_key,
59            authentication_plan: None,
60            id,
61            org_id,
62            created_at,
63            updated_at,
64            authentication_session: None,
65            name: None,
66        }
67    }
68}
69///
70#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
71pub enum ProviderTrue {
72    #[serde(rename = "custom-llm")]
73    CustomLlm,
74}
75
76impl Default for ProviderTrue {
77    fn default() -> ProviderTrue {
78        Self::CustomLlm
79    }
80}