Open camelCase12 opened 4 weeks ago
i dont know if it helps, but any unhandled exception on your code will terminate the websocket, been there.
I am having the same issue. Because the AsyncWebsocketMessageResultEnumerator disposes the client websocket, I cannot do anything with the websocket after iterating through the responses. I don't think AsyncWebsocketMessageResultEnumerator should be responsible for disposing the client websocket because it doesn't create it. the RealtimeConversationSession class should solely be responsible for this, IMO
I've opened PR #261 to address this
Service
OpenAI
Describe the bug
I was setting up the realtime API for voice chatting, but I found after my first question and reply from the model, the web socket would close and terminate the conversation. (This was while using
CreateServerVoiceActivityTurnDetectionOptions
)When calling
ReceiveUpdatesAsync
to receive server messages, I didn't expect this to close the_clientWebSocket
, but it did.It took me a while to figure out that the
AsyncWebsocketMessageResultEnumerator
is automatically disposing of the_clientWebSocket
when it finishes iterating, causingReceiveUpdatesAsync
to terminate the WebSocket. Commenting out the disposing call withinAsyncWebsocketMessageResultEnumerator
resulted in the expected behavior for me:This allowed me to have my expected 2-way conversation. If there's another intended method to receive server events without terminating the socket, or to keep the socket alive for more than one request-response, please let me know.
Steps to reproduce
RealtimeConversationSession
with server voice activity turn detection:CancellationTokenSource cts = new();
var session = await client.StartConversationSessionAsync(cts.Token);
var options = new ConversationSessionOptions() { Instructions = "",
TurnDetectionOptions = ConversationTurnDetectionOptions.CreateServerVoiceActivityTurnDetectionOptions(0.5f, TimeSpan.FromMilliseconds(300), TimeSpan.FromMilliseconds(200)),
Voice = ConversationVoice.Alloy,
OutputAudioFormat = ConversationAudioFormat.Pcm16,
InputTranscriptionOptions = new ConversationInputTranscriptionOptions()
{
Model = "whisper-1"
}
};
await session.ConfigureSessionAsync(options);
ReceiveUpdatesAsync
in a loop:ReceiveUpdatesAsync
will throw aSystem.ObjectDisposedException
:Code snippets
No response
OS
winOS
.NET version
.NET 8 Core
Library version
2.1.0-beta.1