openai 0.61.0 → 0.63.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +26 -0
- data/README.md +2 -5
- data/lib/openai/auth/workload_identity.rb +2 -2
- data/lib/openai/auth/workload_identity_auth.rb +4 -3
- data/lib/openai/models/admin/organization/usage_audio_speeches_response.rb +10 -1
- data/lib/openai/models/admin/organization/usage_audio_transcriptions_response.rb +10 -1
- data/lib/openai/models/admin/organization/usage_code_interpreter_sessions_response.rb +10 -1
- data/lib/openai/models/admin/organization/usage_completions_response.rb +10 -1
- data/lib/openai/models/admin/organization/usage_costs_response.rb +10 -1
- data/lib/openai/models/admin/organization/usage_embeddings_response.rb +10 -1
- data/lib/openai/models/admin/organization/usage_images_response.rb +10 -1
- data/lib/openai/models/admin/organization/usage_moderations_response.rb +10 -1
- data/lib/openai/models/admin/organization/usage_vector_stores_response.rb +10 -1
- data/lib/openai/models/chat/chat_completion_token_logprob.rb +1 -2
- data/lib/openai/models/chat/completion_create_params.rb +4 -3
- data/lib/openai/models/image_edit_params.rb +85 -31
- data/lib/openai/models/image_generate_params.rb +78 -26
- data/lib/openai/models/image_model.rb +5 -2
- data/lib/openai/models/realtime/audio_transcription.rb +37 -5
- data/lib/openai/models/realtime/client_secret_create_response.rb +1 -2
- data/lib/openai/models/realtime/realtime_audio_config_input.rb +3 -0
- data/lib/openai/models/realtime/realtime_audio_input_turn_detection.rb +3 -0
- data/lib/openai/models/realtime/realtime_reasoning.rb +24 -0
- data/lib/openai/models/realtime/realtime_reasoning_effort.rb +22 -0
- data/lib/openai/models/realtime/realtime_response_create_params.rb +18 -1
- data/lib/openai/models/realtime/realtime_session.rb +6 -0
- data/lib/openai/models/realtime/realtime_session_create_request.rb +21 -1
- data/lib/openai/models/realtime/realtime_session_create_response.rb +41 -17
- data/lib/openai/models/realtime/realtime_transcription_session_audio_input.rb +3 -0
- data/lib/openai/models/realtime/realtime_transcription_session_audio_input_turn_detection.rb +3 -0
- data/lib/openai/models/realtime/realtime_transcription_session_create_response.rb +9 -5
- data/lib/openai/models/realtime/realtime_transcription_session_turn_detection.rb +2 -1
- data/lib/openai/models/realtime/realtime_translation_client_event.rb +45 -0
- data/lib/openai/models/realtime/realtime_translation_client_secret_create_request.rb +85 -0
- data/lib/openai/models/realtime/realtime_translation_client_secret_create_response.rb +42 -0
- data/lib/openai/models/realtime/realtime_translation_input_audio_buffer_append_event.rb +51 -0
- data/lib/openai/models/realtime/realtime_translation_input_transcript_delta_event.rb +55 -0
- data/lib/openai/models/realtime/realtime_translation_output_audio_delta_event.rb +89 -0
- data/lib/openai/models/realtime/realtime_translation_output_transcript_delta_event.rb +54 -0
- data/lib/openai/models/realtime/realtime_translation_server_event.rb +53 -0
- data/lib/openai/models/realtime/realtime_translation_session.rb +158 -0
- data/lib/openai/models/realtime/realtime_translation_session_close_event.rb +30 -0
- data/lib/openai/models/realtime/realtime_translation_session_closed_event.rb +28 -0
- data/lib/openai/models/realtime/realtime_translation_session_create_request.rb +138 -0
- data/lib/openai/models/realtime/realtime_translation_session_created_event.rb +38 -0
- data/lib/openai/models/realtime/realtime_translation_session_update_event.rb +43 -0
- data/lib/openai/models/realtime/realtime_translation_session_update_request.rb +129 -0
- data/lib/openai/models/realtime/realtime_translation_session_updated_event.rb +37 -0
- data/lib/openai/models/realtime/transcription_session_updated_event.rb +1 -2
- data/lib/openai/models/responses/response.rb +4 -3
- data/lib/openai/models/responses/response_compact_params.rb +22 -1
- data/lib/openai/models/responses/response_create_params.rb +4 -3
- data/lib/openai/models/responses/response_includable.rb +2 -0
- data/lib/openai/models/responses/response_text_delta_event.rb +2 -2
- data/lib/openai/models/responses/response_text_done_event.rb +2 -2
- data/lib/openai/models/responses/responses_client_event.rb +4 -3
- data/lib/openai/models/responses/tool.rb +81 -16
- data/lib/openai/resources/chat/completions.rb +2 -2
- data/lib/openai/resources/images.rb +6 -6
- data/lib/openai/resources/realtime/calls.rb +5 -1
- data/lib/openai/resources/responses.rb +5 -3
- data/lib/openai/version.rb +1 -1
- data/lib/openai.rb +18 -1
- data/rbi/openai/auth.rbi +3 -3
- data/rbi/openai/models/admin/organization/usage_audio_speeches_response.rbi +11 -1
- data/rbi/openai/models/admin/organization/usage_audio_transcriptions_response.rbi +11 -1
- data/rbi/openai/models/admin/organization/usage_code_interpreter_sessions_response.rbi +11 -1
- data/rbi/openai/models/admin/organization/usage_completions_response.rbi +11 -1
- data/rbi/openai/models/admin/organization/usage_costs_response.rbi +11 -1
- data/rbi/openai/models/admin/organization/usage_embeddings_response.rbi +11 -1
- data/rbi/openai/models/admin/organization/usage_images_response.rbi +11 -1
- data/rbi/openai/models/admin/organization/usage_moderations_response.rbi +11 -1
- data/rbi/openai/models/admin/organization/usage_vector_stores_response.rbi +11 -1
- data/rbi/openai/models/chat/chat_completion_token_logprob.rbi +2 -4
- data/rbi/openai/models/chat/completion_create_params.rbi +6 -4
- data/rbi/openai/models/image_edit_params.rbi +102 -45
- data/rbi/openai/models/image_generate_params.rbi +93 -39
- data/rbi/openai/models/image_model.rbi +8 -3
- data/rbi/openai/models/realtime/audio_transcription.rbi +85 -6
- data/rbi/openai/models/realtime/realtime_audio_config_input.rbi +6 -0
- data/rbi/openai/models/realtime/realtime_audio_input_turn_detection.rbi +3 -0
- data/rbi/openai/models/realtime/realtime_reasoning.rbi +54 -0
- data/rbi/openai/models/realtime/realtime_reasoning_effort.rbi +44 -0
- data/rbi/openai/models/realtime/realtime_response_create_params.rbi +26 -0
- data/rbi/openai/models/realtime/realtime_session.rbi +9 -0
- data/rbi/openai/models/realtime/realtime_session_create_request.rbi +31 -0
- data/rbi/openai/models/realtime/realtime_session_create_response.rbi +53 -32
- data/rbi/openai/models/realtime/realtime_transcription_session_audio_input.rbi +6 -0
- data/rbi/openai/models/realtime/realtime_transcription_session_audio_input_turn_detection.rbi +3 -0
- data/rbi/openai/models/realtime/realtime_transcription_session_create_response.rbi +13 -7
- data/rbi/openai/models/realtime/realtime_transcription_session_turn_detection.rbi +2 -1
- data/rbi/openai/models/realtime/realtime_translation_client_event.rbi +29 -0
- data/rbi/openai/models/realtime/realtime_translation_client_secret_create_request.rbi +193 -0
- data/rbi/openai/models/realtime/realtime_translation_client_secret_create_response.rbi +69 -0
- data/rbi/openai/models/realtime/realtime_translation_input_audio_buffer_append_event.rbi +69 -0
- data/rbi/openai/models/realtime/realtime_translation_input_transcript_delta_event.rbi +77 -0
- data/rbi/openai/models/realtime/realtime_translation_output_audio_delta_event.rbi +148 -0
- data/rbi/openai/models/realtime/realtime_translation_output_transcript_delta_event.rbi +76 -0
- data/rbi/openai/models/realtime/realtime_translation_server_event.rbi +33 -0
- data/rbi/openai/models/realtime/realtime_translation_session.rbi +339 -0
- data/rbi/openai/models/realtime/realtime_translation_session_close_event.rbi +44 -0
- data/rbi/openai/models/realtime/realtime_translation_session_closed_event.rbi +39 -0
- data/rbi/openai/models/realtime/realtime_translation_session_create_request.rbi +322 -0
- data/rbi/openai/models/realtime/realtime_translation_session_created_event.rbi +68 -0
- data/rbi/openai/models/realtime/realtime_translation_session_update_event.rbi +78 -0
- data/rbi/openai/models/realtime/realtime_translation_session_update_request.rbi +313 -0
- data/rbi/openai/models/realtime/realtime_translation_session_updated_event.rbi +67 -0
- data/rbi/openai/models/realtime/transcription_session_updated_event.rbi +0 -2
- data/rbi/openai/models/responses/response.rbi +6 -4
- data/rbi/openai/models/responses/response_compact_params.rbi +65 -0
- data/rbi/openai/models/responses/response_create_params.rbi +6 -4
- data/rbi/openai/models/responses/response_includable.rbi +2 -0
- data/rbi/openai/models/responses/response_text_delta_event.rbi +2 -2
- data/rbi/openai/models/responses/response_text_done_event.rbi +2 -2
- data/rbi/openai/models/responses/responses_client_event.rbi +6 -4
- data/rbi/openai/models/responses/tool.rbi +122 -27
- data/rbi/openai/resources/chat/completions.rbi +6 -4
- data/rbi/openai/resources/images.rbi +110 -44
- data/rbi/openai/resources/realtime/calls.rbi +7 -0
- data/rbi/openai/resources/responses.rbi +12 -4
- data/sig/openai/models/admin/organization/usage_audio_speeches_response.rbs +7 -2
- data/sig/openai/models/admin/organization/usage_audio_transcriptions_response.rbs +7 -2
- data/sig/openai/models/admin/organization/usage_code_interpreter_sessions_response.rbs +7 -2
- data/sig/openai/models/admin/organization/usage_completions_response.rbs +7 -2
- data/sig/openai/models/admin/organization/usage_costs_response.rbs +7 -2
- data/sig/openai/models/admin/organization/usage_embeddings_response.rbs +7 -2
- data/sig/openai/models/admin/organization/usage_images_response.rbs +7 -2
- data/sig/openai/models/admin/organization/usage_moderations_response.rbs +7 -2
- data/sig/openai/models/admin/organization/usage_vector_stores_response.rbs +7 -2
- data/sig/openai/models/image_edit_params.rbs +5 -4
- data/sig/openai/models/image_generate_params.rbs +5 -4
- data/sig/openai/models/image_model.rbs +11 -5
- data/sig/openai/models/realtime/audio_transcription.rbs +25 -0
- data/sig/openai/models/realtime/realtime_reasoning.rbs +24 -0
- data/sig/openai/models/realtime/realtime_reasoning_effort.rbs +20 -0
- data/sig/openai/models/realtime/realtime_response_create_params.rbs +16 -0
- data/sig/openai/models/realtime/realtime_session_create_request.rbs +18 -0
- data/sig/openai/models/realtime/realtime_session_create_response.rbs +27 -4
- data/sig/openai/models/realtime/realtime_transcription_session_create_response.rbs +4 -8
- data/sig/openai/models/realtime/realtime_translation_client_event.rbs +16 -0
- data/sig/openai/models/realtime/realtime_translation_client_secret_create_request.rbs +69 -0
- data/sig/openai/models/realtime/realtime_translation_client_secret_create_response.rbs +32 -0
- data/sig/openai/models/realtime/realtime_translation_input_audio_buffer_append_event.rbs +34 -0
- data/sig/openai/models/realtime/realtime_translation_input_transcript_delta_event.rbs +37 -0
- data/sig/openai/models/realtime/realtime_translation_output_audio_delta_event.rbs +70 -0
- data/sig/openai/models/realtime/realtime_translation_output_transcript_delta_event.rbs +37 -0
- data/sig/openai/models/realtime/realtime_translation_server_event.rbs +20 -0
- data/sig/openai/models/realtime/realtime_translation_session.rbs +131 -0
- data/sig/openai/models/realtime/realtime_translation_session_close_event.rbs +20 -0
- data/sig/openai/models/realtime/realtime_translation_session_closed_event.rbs +18 -0
- data/sig/openai/models/realtime/realtime_translation_session_create_request.rbs +120 -0
- data/sig/openai/models/realtime/realtime_translation_session_created_event.rbs +32 -0
- data/sig/openai/models/realtime/realtime_translation_session_update_event.rbs +34 -0
- data/sig/openai/models/realtime/realtime_translation_session_update_request.rbs +115 -0
- data/sig/openai/models/realtime/realtime_translation_session_updated_event.rbs +32 -0
- data/sig/openai/models/responses/response_compact_params.rbs +19 -1
- data/sig/openai/models/responses/tool.rbs +15 -5
- data/sig/openai/resources/realtime/calls.rbs +2 -0
- data/sig/openai/resources/responses.rbs +1 -0
- metadata +56 -5
- data/lib/openai/models/realtime/realtime_session_client_secret.rb +0 -36
- data/rbi/openai/models/realtime/realtime_session_client_secret.rbi +0 -49
- data/sig/openai/models/realtime/realtime_session_client_secret.rbs +0 -20
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
# typed: strong
|
|
2
|
+
|
|
3
|
+
module OpenAI
|
|
4
|
+
module Models
|
|
5
|
+
module Realtime
|
|
6
|
+
class RealtimeTranslationSessionUpdateRequest < OpenAI::Internal::Type::BaseModel
|
|
7
|
+
OrHash =
|
|
8
|
+
T.type_alias do
|
|
9
|
+
T.any(
|
|
10
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest,
|
|
11
|
+
OpenAI::Internal::AnyHash
|
|
12
|
+
)
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
# Configuration for translation input and output audio.
|
|
16
|
+
sig do
|
|
17
|
+
returns(
|
|
18
|
+
T.nilable(
|
|
19
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio
|
|
20
|
+
)
|
|
21
|
+
)
|
|
22
|
+
end
|
|
23
|
+
attr_reader :audio
|
|
24
|
+
|
|
25
|
+
sig do
|
|
26
|
+
params(
|
|
27
|
+
audio:
|
|
28
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::OrHash
|
|
29
|
+
).void
|
|
30
|
+
end
|
|
31
|
+
attr_writer :audio
|
|
32
|
+
|
|
33
|
+
# Realtime translation session fields that can be updated with `session.update`.
|
|
34
|
+
sig do
|
|
35
|
+
params(
|
|
36
|
+
audio:
|
|
37
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::OrHash
|
|
38
|
+
).returns(T.attached_class)
|
|
39
|
+
end
|
|
40
|
+
def self.new(
|
|
41
|
+
# Configuration for translation input and output audio.
|
|
42
|
+
audio: nil
|
|
43
|
+
)
|
|
44
|
+
end
|
|
45
|
+
|
|
46
|
+
sig do
|
|
47
|
+
override.returns(
|
|
48
|
+
{
|
|
49
|
+
audio:
|
|
50
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio
|
|
51
|
+
}
|
|
52
|
+
)
|
|
53
|
+
end
|
|
54
|
+
def to_hash
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
class Audio < OpenAI::Internal::Type::BaseModel
|
|
58
|
+
OrHash =
|
|
59
|
+
T.type_alias do
|
|
60
|
+
T.any(
|
|
61
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio,
|
|
62
|
+
OpenAI::Internal::AnyHash
|
|
63
|
+
)
|
|
64
|
+
end
|
|
65
|
+
|
|
66
|
+
sig do
|
|
67
|
+
returns(
|
|
68
|
+
T.nilable(
|
|
69
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input
|
|
70
|
+
)
|
|
71
|
+
)
|
|
72
|
+
end
|
|
73
|
+
attr_reader :input
|
|
74
|
+
|
|
75
|
+
sig do
|
|
76
|
+
params(
|
|
77
|
+
input:
|
|
78
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::OrHash
|
|
79
|
+
).void
|
|
80
|
+
end
|
|
81
|
+
attr_writer :input
|
|
82
|
+
|
|
83
|
+
sig do
|
|
84
|
+
returns(
|
|
85
|
+
T.nilable(
|
|
86
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Output
|
|
87
|
+
)
|
|
88
|
+
)
|
|
89
|
+
end
|
|
90
|
+
attr_reader :output
|
|
91
|
+
|
|
92
|
+
sig do
|
|
93
|
+
params(
|
|
94
|
+
output:
|
|
95
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Output::OrHash
|
|
96
|
+
).void
|
|
97
|
+
end
|
|
98
|
+
attr_writer :output
|
|
99
|
+
|
|
100
|
+
# Configuration for translation input and output audio.
|
|
101
|
+
sig do
|
|
102
|
+
params(
|
|
103
|
+
input:
|
|
104
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::OrHash,
|
|
105
|
+
output:
|
|
106
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Output::OrHash
|
|
107
|
+
).returns(T.attached_class)
|
|
108
|
+
end
|
|
109
|
+
def self.new(input: nil, output: nil)
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
sig do
|
|
113
|
+
override.returns(
|
|
114
|
+
{
|
|
115
|
+
input:
|
|
116
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input,
|
|
117
|
+
output:
|
|
118
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Output
|
|
119
|
+
}
|
|
120
|
+
)
|
|
121
|
+
end
|
|
122
|
+
def to_hash
|
|
123
|
+
end
|
|
124
|
+
|
|
125
|
+
class Input < OpenAI::Internal::Type::BaseModel
|
|
126
|
+
OrHash =
|
|
127
|
+
T.type_alias do
|
|
128
|
+
T.any(
|
|
129
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input,
|
|
130
|
+
OpenAI::Internal::AnyHash
|
|
131
|
+
)
|
|
132
|
+
end
|
|
133
|
+
|
|
134
|
+
# Optional input noise reduction. Set to `null` to disable it.
|
|
135
|
+
sig do
|
|
136
|
+
returns(
|
|
137
|
+
T.nilable(
|
|
138
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::NoiseReduction
|
|
139
|
+
)
|
|
140
|
+
)
|
|
141
|
+
end
|
|
142
|
+
attr_reader :noise_reduction
|
|
143
|
+
|
|
144
|
+
sig do
|
|
145
|
+
params(
|
|
146
|
+
noise_reduction:
|
|
147
|
+
T.nilable(
|
|
148
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::NoiseReduction::OrHash
|
|
149
|
+
)
|
|
150
|
+
).void
|
|
151
|
+
end
|
|
152
|
+
attr_writer :noise_reduction
|
|
153
|
+
|
|
154
|
+
# Optional source-language transcription. When configured, the server emits
|
|
155
|
+
# `session.input_transcript.delta` events. Translation itself still runs from the
|
|
156
|
+
# input audio stream.
|
|
157
|
+
sig do
|
|
158
|
+
returns(
|
|
159
|
+
T.nilable(
|
|
160
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::Transcription
|
|
161
|
+
)
|
|
162
|
+
)
|
|
163
|
+
end
|
|
164
|
+
attr_reader :transcription
|
|
165
|
+
|
|
166
|
+
sig do
|
|
167
|
+
params(
|
|
168
|
+
transcription:
|
|
169
|
+
T.nilable(
|
|
170
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::Transcription::OrHash
|
|
171
|
+
)
|
|
172
|
+
).void
|
|
173
|
+
end
|
|
174
|
+
attr_writer :transcription
|
|
175
|
+
|
|
176
|
+
sig do
|
|
177
|
+
params(
|
|
178
|
+
noise_reduction:
|
|
179
|
+
T.nilable(
|
|
180
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::NoiseReduction::OrHash
|
|
181
|
+
),
|
|
182
|
+
transcription:
|
|
183
|
+
T.nilable(
|
|
184
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::Transcription::OrHash
|
|
185
|
+
)
|
|
186
|
+
).returns(T.attached_class)
|
|
187
|
+
end
|
|
188
|
+
def self.new(
|
|
189
|
+
# Optional input noise reduction. Set to `null` to disable it.
|
|
190
|
+
noise_reduction: nil,
|
|
191
|
+
# Optional source-language transcription. When configured, the server emits
|
|
192
|
+
# `session.input_transcript.delta` events. Translation itself still runs from the
|
|
193
|
+
# input audio stream.
|
|
194
|
+
transcription: nil
|
|
195
|
+
)
|
|
196
|
+
end
|
|
197
|
+
|
|
198
|
+
sig do
|
|
199
|
+
override.returns(
|
|
200
|
+
{
|
|
201
|
+
noise_reduction:
|
|
202
|
+
T.nilable(
|
|
203
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::NoiseReduction
|
|
204
|
+
),
|
|
205
|
+
transcription:
|
|
206
|
+
T.nilable(
|
|
207
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::Transcription
|
|
208
|
+
)
|
|
209
|
+
}
|
|
210
|
+
)
|
|
211
|
+
end
|
|
212
|
+
def to_hash
|
|
213
|
+
end
|
|
214
|
+
|
|
215
|
+
class NoiseReduction < OpenAI::Internal::Type::BaseModel
|
|
216
|
+
OrHash =
|
|
217
|
+
T.type_alias do
|
|
218
|
+
T.any(
|
|
219
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::NoiseReduction,
|
|
220
|
+
OpenAI::Internal::AnyHash
|
|
221
|
+
)
|
|
222
|
+
end
|
|
223
|
+
|
|
224
|
+
# Type of noise reduction. `near_field` is for close-talking microphones such as
|
|
225
|
+
# headphones, `far_field` is for far-field microphones such as laptop or
|
|
226
|
+
# conference room microphones.
|
|
227
|
+
sig { returns(OpenAI::Realtime::NoiseReductionType::OrSymbol) }
|
|
228
|
+
attr_accessor :type
|
|
229
|
+
|
|
230
|
+
# Optional input noise reduction. Set to `null` to disable it.
|
|
231
|
+
sig do
|
|
232
|
+
params(
|
|
233
|
+
type: OpenAI::Realtime::NoiseReductionType::OrSymbol
|
|
234
|
+
).returns(T.attached_class)
|
|
235
|
+
end
|
|
236
|
+
def self.new(
|
|
237
|
+
# Type of noise reduction. `near_field` is for close-talking microphones such as
|
|
238
|
+
# headphones, `far_field` is for far-field microphones such as laptop or
|
|
239
|
+
# conference room microphones.
|
|
240
|
+
type:
|
|
241
|
+
)
|
|
242
|
+
end
|
|
243
|
+
|
|
244
|
+
sig do
|
|
245
|
+
override.returns(
|
|
246
|
+
{ type: OpenAI::Realtime::NoiseReductionType::OrSymbol }
|
|
247
|
+
)
|
|
248
|
+
end
|
|
249
|
+
def to_hash
|
|
250
|
+
end
|
|
251
|
+
end
|
|
252
|
+
|
|
253
|
+
class Transcription < OpenAI::Internal::Type::BaseModel
|
|
254
|
+
OrHash =
|
|
255
|
+
T.type_alias do
|
|
256
|
+
T.any(
|
|
257
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Input::Transcription,
|
|
258
|
+
OpenAI::Internal::AnyHash
|
|
259
|
+
)
|
|
260
|
+
end
|
|
261
|
+
|
|
262
|
+
# The transcription model to use for source transcript deltas.
|
|
263
|
+
sig { returns(String) }
|
|
264
|
+
attr_accessor :model
|
|
265
|
+
|
|
266
|
+
# Optional source-language transcription. When configured, the server emits
|
|
267
|
+
# `session.input_transcript.delta` events. Translation itself still runs from the
|
|
268
|
+
# input audio stream.
|
|
269
|
+
sig { params(model: String).returns(T.attached_class) }
|
|
270
|
+
def self.new(
|
|
271
|
+
# The transcription model to use for source transcript deltas.
|
|
272
|
+
model:
|
|
273
|
+
)
|
|
274
|
+
end
|
|
275
|
+
|
|
276
|
+
sig { override.returns({ model: String }) }
|
|
277
|
+
def to_hash
|
|
278
|
+
end
|
|
279
|
+
end
|
|
280
|
+
end
|
|
281
|
+
|
|
282
|
+
class Output < OpenAI::Internal::Type::BaseModel
|
|
283
|
+
OrHash =
|
|
284
|
+
T.type_alias do
|
|
285
|
+
T.any(
|
|
286
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdateRequest::Audio::Output,
|
|
287
|
+
OpenAI::Internal::AnyHash
|
|
288
|
+
)
|
|
289
|
+
end
|
|
290
|
+
|
|
291
|
+
# Target language for translated output audio and transcript deltas.
|
|
292
|
+
sig { returns(T.nilable(String)) }
|
|
293
|
+
attr_reader :language
|
|
294
|
+
|
|
295
|
+
sig { params(language: String).void }
|
|
296
|
+
attr_writer :language
|
|
297
|
+
|
|
298
|
+
sig { params(language: String).returns(T.attached_class) }
|
|
299
|
+
def self.new(
|
|
300
|
+
# Target language for translated output audio and transcript deltas.
|
|
301
|
+
language: nil
|
|
302
|
+
)
|
|
303
|
+
end
|
|
304
|
+
|
|
305
|
+
sig { override.returns({ language: String }) }
|
|
306
|
+
def to_hash
|
|
307
|
+
end
|
|
308
|
+
end
|
|
309
|
+
end
|
|
310
|
+
end
|
|
311
|
+
end
|
|
312
|
+
end
|
|
313
|
+
end
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
# typed: strong
|
|
2
|
+
|
|
3
|
+
module OpenAI
|
|
4
|
+
module Models
|
|
5
|
+
module Realtime
|
|
6
|
+
class RealtimeTranslationSessionUpdatedEvent < OpenAI::Internal::Type::BaseModel
|
|
7
|
+
OrHash =
|
|
8
|
+
T.type_alias do
|
|
9
|
+
T.any(
|
|
10
|
+
OpenAI::Realtime::RealtimeTranslationSessionUpdatedEvent,
|
|
11
|
+
OpenAI::Internal::AnyHash
|
|
12
|
+
)
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
# The unique ID of the server event.
|
|
16
|
+
sig { returns(String) }
|
|
17
|
+
attr_accessor :event_id
|
|
18
|
+
|
|
19
|
+
# The translation session configuration.
|
|
20
|
+
sig { returns(OpenAI::Realtime::RealtimeTranslationSession) }
|
|
21
|
+
attr_reader :session
|
|
22
|
+
|
|
23
|
+
sig do
|
|
24
|
+
params(
|
|
25
|
+
session: OpenAI::Realtime::RealtimeTranslationSession::OrHash
|
|
26
|
+
).void
|
|
27
|
+
end
|
|
28
|
+
attr_writer :session
|
|
29
|
+
|
|
30
|
+
# The event type, must be `session.updated`.
|
|
31
|
+
sig { returns(Symbol) }
|
|
32
|
+
attr_accessor :type
|
|
33
|
+
|
|
34
|
+
# Returned when a translation session is updated with a `session.update` event,
|
|
35
|
+
# unless there is an error.
|
|
36
|
+
sig do
|
|
37
|
+
params(
|
|
38
|
+
event_id: String,
|
|
39
|
+
session: OpenAI::Realtime::RealtimeTranslationSession::OrHash,
|
|
40
|
+
type: Symbol
|
|
41
|
+
).returns(T.attached_class)
|
|
42
|
+
end
|
|
43
|
+
def self.new(
|
|
44
|
+
# The unique ID of the server event.
|
|
45
|
+
event_id:,
|
|
46
|
+
# The translation session configuration.
|
|
47
|
+
session:,
|
|
48
|
+
# The event type, must be `session.updated`.
|
|
49
|
+
type: :"session.updated"
|
|
50
|
+
)
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
sig do
|
|
54
|
+
override.returns(
|
|
55
|
+
{
|
|
56
|
+
event_id: String,
|
|
57
|
+
session: OpenAI::Realtime::RealtimeTranslationSession,
|
|
58
|
+
type: Symbol
|
|
59
|
+
}
|
|
60
|
+
)
|
|
61
|
+
end
|
|
62
|
+
def to_hash
|
|
63
|
+
end
|
|
64
|
+
end
|
|
65
|
+
end
|
|
66
|
+
end
|
|
67
|
+
end
|
|
@@ -108,7 +108,6 @@ module OpenAI
|
|
|
108
108
|
sig { params(input_audio_format: String).void }
|
|
109
109
|
attr_writer :input_audio_format
|
|
110
110
|
|
|
111
|
-
# Configuration of the transcription model.
|
|
112
111
|
sig { returns(T.nilable(OpenAI::Realtime::AudioTranscription)) }
|
|
113
112
|
attr_reader :input_audio_transcription
|
|
114
113
|
|
|
@@ -189,7 +188,6 @@ module OpenAI
|
|
|
189
188
|
client_secret:,
|
|
190
189
|
# The format of input audio. Options are `pcm16`, `g711_ulaw`, or `g711_alaw`.
|
|
191
190
|
input_audio_format: nil,
|
|
192
|
-
# Configuration of the transcription model.
|
|
193
191
|
input_audio_transcription: nil,
|
|
194
192
|
# The set of modalities the model can respond with. To disable audio, set this to
|
|
195
193
|
# ["text"].
|
|
@@ -277,8 +277,9 @@ module OpenAI
|
|
|
277
277
|
sig { params(text: OpenAI::Responses::ResponseTextConfig::OrHash).void }
|
|
278
278
|
attr_writer :text
|
|
279
279
|
|
|
280
|
-
# An integer between 0 and 20 specifying the number of most likely tokens
|
|
281
|
-
# return at each token position, each with an associated log probability.
|
|
280
|
+
# An integer between 0 and 20 specifying the maximum number of most likely tokens
|
|
281
|
+
# to return at each token position, each with an associated log probability. In
|
|
282
|
+
# some cases, the number of returned tokens may be fewer than requested.
|
|
282
283
|
sig { returns(T.nilable(Integer)) }
|
|
283
284
|
attr_accessor :top_logprobs
|
|
284
285
|
|
|
@@ -568,8 +569,9 @@ module OpenAI
|
|
|
568
569
|
# - [Text inputs and outputs](https://platform.openai.com/docs/guides/text)
|
|
569
570
|
# - [Structured Outputs](https://platform.openai.com/docs/guides/structured-outputs)
|
|
570
571
|
text: nil,
|
|
571
|
-
# An integer between 0 and 20 specifying the number of most likely tokens
|
|
572
|
-
# return at each token position, each with an associated log probability.
|
|
572
|
+
# An integer between 0 and 20 specifying the maximum number of most likely tokens
|
|
573
|
+
# to return at each token position, each with an associated log probability. In
|
|
574
|
+
# some cases, the number of returned tokens may be fewer than requested.
|
|
573
575
|
top_logprobs: nil,
|
|
574
576
|
# The truncation strategy to use for the model response.
|
|
575
577
|
#
|
|
@@ -68,6 +68,16 @@ module OpenAI
|
|
|
68
68
|
end
|
|
69
69
|
attr_accessor :prompt_cache_retention
|
|
70
70
|
|
|
71
|
+
# The service tier to use for this request.
|
|
72
|
+
sig do
|
|
73
|
+
returns(
|
|
74
|
+
T.nilable(
|
|
75
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier::OrSymbol
|
|
76
|
+
)
|
|
77
|
+
)
|
|
78
|
+
end
|
|
79
|
+
attr_accessor :service_tier
|
|
80
|
+
|
|
71
81
|
sig do
|
|
72
82
|
params(
|
|
73
83
|
model:
|
|
@@ -88,6 +98,10 @@ module OpenAI
|
|
|
88
98
|
T.nilable(
|
|
89
99
|
OpenAI::Responses::ResponseCompactParams::PromptCacheRetention::OrSymbol
|
|
90
100
|
),
|
|
101
|
+
service_tier:
|
|
102
|
+
T.nilable(
|
|
103
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier::OrSymbol
|
|
104
|
+
),
|
|
91
105
|
request_options: OpenAI::RequestOptions::OrHash
|
|
92
106
|
).returns(T.attached_class)
|
|
93
107
|
end
|
|
@@ -114,6 +128,8 @@ module OpenAI
|
|
|
114
128
|
prompt_cache_key: nil,
|
|
115
129
|
# How long to retain a prompt cache entry created by this request.
|
|
116
130
|
prompt_cache_retention: nil,
|
|
131
|
+
# The service tier to use for this request.
|
|
132
|
+
service_tier: nil,
|
|
117
133
|
request_options: {}
|
|
118
134
|
)
|
|
119
135
|
end
|
|
@@ -139,6 +155,10 @@ module OpenAI
|
|
|
139
155
|
T.nilable(
|
|
140
156
|
OpenAI::Responses::ResponseCompactParams::PromptCacheRetention::OrSymbol
|
|
141
157
|
),
|
|
158
|
+
service_tier:
|
|
159
|
+
T.nilable(
|
|
160
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier::OrSymbol
|
|
161
|
+
),
|
|
142
162
|
request_options: OpenAI::RequestOptions
|
|
143
163
|
}
|
|
144
164
|
)
|
|
@@ -705,6 +725,51 @@ module OpenAI
|
|
|
705
725
|
def self.values
|
|
706
726
|
end
|
|
707
727
|
end
|
|
728
|
+
|
|
729
|
+
# The service tier to use for this request.
|
|
730
|
+
module ServiceTier
|
|
731
|
+
extend OpenAI::Internal::Type::Enum
|
|
732
|
+
|
|
733
|
+
TaggedSymbol =
|
|
734
|
+
T.type_alias do
|
|
735
|
+
T.all(
|
|
736
|
+
Symbol,
|
|
737
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier
|
|
738
|
+
)
|
|
739
|
+
end
|
|
740
|
+
OrSymbol = T.type_alias { T.any(Symbol, String) }
|
|
741
|
+
|
|
742
|
+
AUTO =
|
|
743
|
+
T.let(
|
|
744
|
+
:auto,
|
|
745
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier::TaggedSymbol
|
|
746
|
+
)
|
|
747
|
+
DEFAULT =
|
|
748
|
+
T.let(
|
|
749
|
+
:default,
|
|
750
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier::TaggedSymbol
|
|
751
|
+
)
|
|
752
|
+
FLEX =
|
|
753
|
+
T.let(
|
|
754
|
+
:flex,
|
|
755
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier::TaggedSymbol
|
|
756
|
+
)
|
|
757
|
+
PRIORITY =
|
|
758
|
+
T.let(
|
|
759
|
+
:priority,
|
|
760
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier::TaggedSymbol
|
|
761
|
+
)
|
|
762
|
+
|
|
763
|
+
sig do
|
|
764
|
+
override.returns(
|
|
765
|
+
T::Array[
|
|
766
|
+
OpenAI::Responses::ResponseCompactParams::ServiceTier::TaggedSymbol
|
|
767
|
+
]
|
|
768
|
+
)
|
|
769
|
+
end
|
|
770
|
+
def self.values
|
|
771
|
+
end
|
|
772
|
+
end
|
|
708
773
|
end
|
|
709
774
|
end
|
|
710
775
|
end
|
|
@@ -403,8 +403,9 @@ module OpenAI
|
|
|
403
403
|
end
|
|
404
404
|
attr_writer :tools
|
|
405
405
|
|
|
406
|
-
# An integer between 0 and 20 specifying the number of most likely tokens
|
|
407
|
-
# return at each token position, each with an associated log probability.
|
|
406
|
+
# An integer between 0 and 20 specifying the maximum number of most likely tokens
|
|
407
|
+
# to return at each token position, each with an associated log probability. In
|
|
408
|
+
# some cases, the number of returned tokens may be fewer than requested.
|
|
408
409
|
sig { returns(T.nilable(Integer)) }
|
|
409
410
|
attr_accessor :top_logprobs
|
|
410
411
|
|
|
@@ -691,8 +692,9 @@ module OpenAI
|
|
|
691
692
|
# [function calling](https://platform.openai.com/docs/guides/function-calling).
|
|
692
693
|
# You can also use custom tools to call your own code.
|
|
693
694
|
tools: nil,
|
|
694
|
-
# An integer between 0 and 20 specifying the number of most likely tokens
|
|
695
|
-
# return at each token position, each with an associated log probability.
|
|
695
|
+
# An integer between 0 and 20 specifying the maximum number of most likely tokens
|
|
696
|
+
# to return at each token position, each with an associated log probability. In
|
|
697
|
+
# some cases, the number of returned tokens may be fewer than requested.
|
|
696
698
|
top_logprobs: nil,
|
|
697
699
|
# An alternative to sampling with temperature, called nucleus sampling, where the
|
|
698
700
|
# model considers the results of the tokens with top_p probability mass. So 0.1
|
|
@@ -6,6 +6,8 @@ module OpenAI
|
|
|
6
6
|
# Specify additional output data to include in the model response. Currently
|
|
7
7
|
# supported values are:
|
|
8
8
|
#
|
|
9
|
+
# - `web_search_call.results`: Include the search results of the web search tool
|
|
10
|
+
# call.
|
|
9
11
|
# - `web_search_call.action.sources`: Include the sources of the web search tool
|
|
10
12
|
# call.
|
|
11
13
|
# - `code_interpreter_call.outputs`: Includes the outputs of python code execution
|
|
@@ -109,7 +109,7 @@ module OpenAI
|
|
|
109
109
|
sig { returns(Float) }
|
|
110
110
|
attr_accessor :logprob
|
|
111
111
|
|
|
112
|
-
# The log
|
|
112
|
+
# The log probabilities of up to 20 of the most likely tokens.
|
|
113
113
|
sig do
|
|
114
114
|
returns(
|
|
115
115
|
T.nilable(
|
|
@@ -149,7 +149,7 @@ module OpenAI
|
|
|
149
149
|
token:,
|
|
150
150
|
# The log probability of this token.
|
|
151
151
|
logprob:,
|
|
152
|
-
# The log
|
|
152
|
+
# The log probabilities of up to 20 of the most likely tokens.
|
|
153
153
|
top_logprobs: nil
|
|
154
154
|
)
|
|
155
155
|
end
|
|
@@ -109,7 +109,7 @@ module OpenAI
|
|
|
109
109
|
sig { returns(Float) }
|
|
110
110
|
attr_accessor :logprob
|
|
111
111
|
|
|
112
|
-
# The log
|
|
112
|
+
# The log probabilities of up to 20 of the most likely tokens.
|
|
113
113
|
sig do
|
|
114
114
|
returns(
|
|
115
115
|
T.nilable(
|
|
@@ -149,7 +149,7 @@ module OpenAI
|
|
|
149
149
|
token:,
|
|
150
150
|
# The log probability of this token.
|
|
151
151
|
logprob:,
|
|
152
|
-
# The log
|
|
152
|
+
# The log probabilities of up to 20 of the most likely tokens.
|
|
153
153
|
top_logprobs: nil
|
|
154
154
|
)
|
|
155
155
|
end
|
|
@@ -405,8 +405,9 @@ module OpenAI
|
|
|
405
405
|
end
|
|
406
406
|
attr_writer :tools
|
|
407
407
|
|
|
408
|
-
# An integer between 0 and 20 specifying the number of most likely tokens
|
|
409
|
-
# return at each token position, each with an associated log probability.
|
|
408
|
+
# An integer between 0 and 20 specifying the maximum number of most likely tokens
|
|
409
|
+
# to return at each token position, each with an associated log probability. In
|
|
410
|
+
# some cases, the number of returned tokens may be fewer than requested.
|
|
410
411
|
sig { returns(T.nilable(Integer)) }
|
|
411
412
|
attr_accessor :top_logprobs
|
|
412
413
|
|
|
@@ -701,8 +702,9 @@ module OpenAI
|
|
|
701
702
|
# [function calling](https://platform.openai.com/docs/guides/function-calling).
|
|
702
703
|
# You can also use custom tools to call your own code.
|
|
703
704
|
tools: nil,
|
|
704
|
-
# An integer between 0 and 20 specifying the number of most likely tokens
|
|
705
|
-
# return at each token position, each with an associated log probability.
|
|
705
|
+
# An integer between 0 and 20 specifying the maximum number of most likely tokens
|
|
706
|
+
# to return at each token position, each with an associated log probability. In
|
|
707
|
+
# some cases, the number of returned tokens may be fewer than requested.
|
|
706
708
|
top_logprobs: nil,
|
|
707
709
|
# An alternative to sampling with temperature, called nucleus sampling, where the
|
|
708
710
|
# model considers the results of the tokens with top_p probability mass. So 0.1
|