Use when writing or reviewing C# code in this repo that builds an interactive Deepgram Voice Agent over WebSocket. Covers `ClientFactory.CreateAgentWebSocketClient()`, `SettingsSchema`, event subscriptions, microphone audio streaming, injected user messages, and function-call-related message types. Use `deepgram-dotnet-text-to-speech` for one-way synthesis and STT skills for transcription-only flows.
76
93%
Does it follow best practices?
Impact
—
No eval scenarios have been run
Passed
No known issues
Full-duplex voice agent sessions over a single WebSocket.
Use a different skill when:
deepgram-dotnet-speech-to-text or deepgram-dotnet-conversational-stt.deepgram-dotnet-text-to-speech.deepgram-dotnet-management-api.dotnet add package Deepgram
dotnet add package Deepgram.Microphone # only if you need local mic captureusing Deepgram;
Deepgram.Library.Initialize();
// Uses DEEPGRAM_API_KEY env var; pass apiKey: "..." to override
var agentClient = ClientFactory.CreateAgentWebSocketClient();using Deepgram.Models.Agent.v2.WebSocket;
var agentClient = ClientFactory.CreateAgentWebSocketClient();
await agentClient.Subscribe(new EventHandler<ConversationTextResponse>((sender, e) =>
{
Console.WriteLine(e);
}));
await agentClient.Subscribe(new EventHandler<AudioResponse>((sender, e) =>
{
if (e.Stream != null)
{
// Raw linear16 PCM — see examples/agent/websocket/no_mic/Program.cs for WAV header.
using var writer = new BinaryWriter(File.Open("output.raw", FileMode.Append));
writer.Write(e.Stream.ToArray());
}
}));
var settings = new SettingsSchema();
settings.Agent.Think.Provider.Type = "open_ai";
settings.Agent.Think.Provider.Model = "gpt-4o-mini";
settings.Agent.Greeting = "Hello! How can I help you today?";
settings.Agent.Listen.Provider.Type = "deepgram";
settings.Agent.Listen.Provider.Model = "nova-3";
settings.Agent.Speak.Provider.Type = "deepgram";
settings.Agent.Speak.Provider.Model = "aura-2-thalia-en";
settings.Audio.Input.Encoding = "linear16";
settings.Audio.Input.SampleRate = 24000;
settings.Audio.Output.Encoding = "linear16";
settings.Audio.Output.SampleRate = 24000;
bool connected = await agentClient.Connect(settings);
if (!connected)
{
Console.Error.WriteLine("Agent WebSocket connection failed — check API key and network.");
return;
}
await agentClient.SendInjectUserMessage("Say hello in one sentence.");
// Cleanup when done
Console.ReadKey();
await agentClient.Stop();var microphone = new Microphone(
push_callback: (audioData, length) =>
{
byte[] chunk = new byte[length];
Array.Copy(audioData, chunk, length);
agentClient.SendBinary(chunk);
},
rate: 24000,
channels: 1,
format: SampleFormat.Int16);
microphone.Start();
// Cleanup
Console.ReadKey();
microphone.Stop();
await agentClient.Stop();Settings models:
SettingsSchemaAudio, Input, OutputAgent, Listen, Think, SpeakProvider (dynamic extra properties supported)Important events:
ConversationTextResponseAudioResponseAgentStartedSpeakingResponseAgentAudioDoneResponseAgentThinkingResponseUserStartedSpeakingResponseFunctionCallRequestResponseSettingsAppliedResponseSend helpers:
SendInjectUserMessage(string)SendInjectUserMessage(InjectUserMessageSchema)SendBinary(...)SendBinaryImmediately(...)SendKeepAlive()Deepgram/Clients/Agent/v2/Websocket/Client.cs, Deepgram/Clients/Interfaces/v2/IAgentWebSocketClient.cs, Deepgram/Models/Agent/v2/WebSocket/*.cs, Deepgram.Microphone/Microphone.csSettingsSchema, ConversationTextResponse, etc. — not the Python names.Provider is dynamic. Extra provider-specific properties are stored through JsonExtensionData; set them carefully.FunctionCallRequestResponse is marked TODO: this needs to be defined, so inspect raw payload behavior before relying on typed fields.SendFunctionCallResponse(...) helper on the public interface. If you need it, send serialized FunctionCallResponseSchema manually via the generic send path.linear16 / 24000.Deepgram.Microphone depends on PortAudio. Local microphone examples need the helper project/package and a working PortAudio environment.examples/agent/websocket/simple/Program.csexamples/agent/websocket/no_mic/Program.csexamples/agent/websocket/arbitrary_keys/Program.csCross-language product knowledge (API reference, recipes, MCP setup): npx skills add deepgram/skills.
3b953f0
If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.