1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
* OpenAI API
*
* The OpenAI REST API. Please see pub https:///platform.openai.com/docs/api-reference for more details.
*
* OpenAPI spec pub version: 2.3.0
*
* Generated pub by: https:///github.com/swagger-api/swagger-codegen.git
*/
/// pub ChatCompletionModalities : Output types that you would like the model to generate for this request. Most models are capable of generating text, which is the pub default: `[\"text\"]` The `gpt-4o-audio-preview` model can also be used to [generate audio](/docs/guides/audio). To request that this model generate both text and audio responses, you can pub use: `[\"text\", \"audio\"]`
#[allow(unused_imports)]
use serde_json::Value;
/// # on openapi.yaml
///
/// ```yaml
/// ChatCompletionModalities:
/// type: array
/// nullable: true
/// description: >
/// Output types that you would like the model to generate for this request.
///
/// Most models are capable of generating text, which is the default:
///
///
/// `["text"]`
///
///
/// The `gpt-4o-audio-preview` model can also be used to [generate
/// audio](/docs/guides/audio). To
///
/// request that this model generate both text and audio responses, you can
///
/// use:
///
///
/// `["text", "audio"]`
/// items:
/// type: string
/// enum:
/// - text
/// - audio
/// ```
#[derive(Debug, Serialize, Deserialize)]
pub struct ChatCompletionModalities(
#[serde(default = "default_modalities")] Vec<ChatCompletionModality>,
);
#[derive(Debug, Serialize, Deserialize, Clone)]
pub enum ChatCompletionModality {
#[serde(rename = "text")]
Text,
#[serde(rename = "audio")]
Audio,
}
fn default_modalities() -> Vec<ChatCompletionModality> {
vec![ChatCompletionModality::Text]
}
#[test]
fn test_mode() {
assert_eq!(
serde_json::to_string(&ChatCompletionModalities(vec![
ChatCompletionModality::Text,
ChatCompletionModality::Audio
]))
.unwrap(),
r#"["text","audio"]"#
);
}