Skip to main content

Azure integrations for Twilio Agent Connect (TAC) - connectors for Azure AI agent services

Project description

Twilio Agent Connect for Microsoft Logo

Twilio Agent Connect for Microsoft

Azure integrations for Twilio Agent Connect — connect Microsoft Foundry agents to Twilio's channels, memory, and context.

Python SDK License CI Status Getting Started

DocumentationPython SDKExamplesDeployment

Ships Microsoft Agent Framework and Azure AI Voice Live connectors for Twilio Agent Connect (TAC), plus production Azure deployments for each.


Features

  • AgentFrameworkConnector - Microsoft Agent Framework integration
  • VoiceLiveConnector - Voice Live API integration
    • Text-in / text-streaming-out over WebSocket (STT and TTS handled by Twilio Conversation Relay)
    • Server-side conversation state (no local session management)
    • Native interrupt handling via Voice Live response.cancel (server-side truncation of in-flight responses)
    • Tool execution with async handlers
  • Multi-channel support (Voice + SMS + Chat)
  • Built-in TAC tools (memory recall, knowledge search, Studio Flow handoff)
  • Getting-started deployment guide with Dockerfile and deployment helpers
  • AgentSessionStore implementations for in-memory, file, and Cosmos DB

Installation

With Agent Framework

pip install twilio-agent-connect-microsoft[agent-framework,server]

With Voice Live

pip install twilio-agent-connect-microsoft[voice-live,server]

Development

git clone https://github.com/twilio/twilio-agent-connect-microsoft.git
cd twilio-agent-connect-microsoft
uv sync --all-extras

Prerequisites

Before running any examples, you need to create and configure the required Twilio services (Conversation Configuration, phone number, etc.). Follow the TAC Quickstart guide to set these up.

Configuration

TAC Microsoft requires TAC environment variables. See TAC Configuration for details.

Required Environment Variables

# Twilio Agent Connect (required for all examples)
TWILIO_CONVERSATION_CONFIGURATION_ID=conv_configuration_xxxxxxxxxxxxxxxxxx
TWILIO_ACCOUNT_SID=ACxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
TWILIO_AUTH_TOKEN=your_auth_token
TWILIO_API_KEY=SKxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
TWILIO_API_SECRET=your_api_key_secret
TWILIO_PHONE_NUMBER=+1234567890

# Server (required for voice)
TWILIO_VOICE_PUBLIC_DOMAIN=your-domain.ngrok.io

# Azure OpenAI — Agent Framework basic example (API key auth)
# Endpoint is the resource base URL only — no /openai/v1 suffix.
AZURE_OPENAI_ENDPOINT=https://your-resource.openai.azure.com/
AZURE_AI_API_KEY=your_azure_openai_api_key
AZURE_AI_DEPLOYMENT_NAME=gpt-4o

# Agent Framework advanced example uses the same AZURE_OPENAI_ENDPOINT as basic,
# but authenticates via `DefaultAzureCredential` (run `az login` first) instead of an API key.

# Voice Live API — voice_live example (hostname only, no https:// prefix)
# AZURE_VOICE_LIVE_ENDPOINT=your-resource.services.ai.azure.com
# AZURE_VOICE_LIVE_API_KEY=your_voice_live_api_key
# AZURE_VOICE_LIVE_MODEL=gpt-realtime

See getting_started/examples/.env.example for the full list including optional features (Cosmos DB, knowledge base, conversation intelligence). Copy it to getting_started/examples/.env and fill in your values — all examples load from that shared file.

Quick Start

Everything imports from tac_microsoft — no need to import from the underlying tac package:

from tac_microsoft import (
    TAC, TACConfig, TACFastAPIServer,
    AgentFrameworkConnector, ConversationSession,
    FileAgentSessionStore,
)
from tac_microsoft.agent_framework_tools import create_memory_tool

Examples

Full examples available in getting_started/examples/:

  • agent_framework/basic.py - Minimal Agent Framework setup (~30 lines)
  • agent_framework/advanced.py - Full feature set (channel-aware prompts, tools, hooks, session persistence)
  • voice_live/basic.py - Voice Live API with tool calling

AgentSessionStore

The AgentSessionStore protocol defines how Agent Framework sessions are persisted between requests, enabling conversation continuity across SMS messages and horizontal scaling for voice.

Three implementations are included:

  • InMemoryAgentSessionStore — default, suitable for single-instance deployments
  • FileAgentSessionStore — persists sessions as JSON files on disk (single-instance, local dev)
  • CosmosDBAgentSessionStore — persists sessions in Azure Cosmos DB for NoSQL (horizontally scaled production). Requires the cosmos extra: pip install twilio-agent-connect-microsoft[cosmos]

Implement the protocol to use any other backing store (Redis, DynamoDB, Postgres, etc.).

Development

Setup

# Clone repository
git clone https://github.com/twilio/twilio-agent-connect-microsoft.git
cd twilio-agent-connect-microsoft

# Install dependencies
uv sync --all-extras

Getting Started

See getting_started/README.md for the full setup and deployment guide.

Dependencies

TAC Microsoft depends on:

  • twilio-agent-connect - Core Twilio Agent Connect framework (installed from PyPI)
    • Requires twilio-agent-connect[server] extra for TACFastAPIServer support
  • agent-framework (optional) - Microsoft Agent Framework
  • websockets (optional) - For Voice Live connector
  • azure-cosmos (optional) - For CosmosDB session store

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

MIT License - see LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

twilio_agent_connect_microsoft-1.0.1.tar.gz (25.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file twilio_agent_connect_microsoft-1.0.1.tar.gz.

File metadata

File hashes

Hashes for twilio_agent_connect_microsoft-1.0.1.tar.gz
Algorithm Hash digest
SHA256 7e1b7d403e9f7f347932310b88079c7b6ec3394988b9a0d51a3a4acd167714ed
MD5 cfb2fa0947c7bdd224ccf9f0713a2a58
BLAKE2b-256 eda85410a527e48154439b547c3e07d2e9a24cc4e25ab5e6b567c4933d526e32

See more details on using hashes here.

Provenance

The following attestation bundles were made for twilio_agent_connect_microsoft-1.0.1.tar.gz:

Publisher: deploy.yml on twilio/twilio-agent-connect-microsoft

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file twilio_agent_connect_microsoft-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for twilio_agent_connect_microsoft-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e979900ed7f374c8ba8346050f635ef01828a1980e4164cac99a6a3c2a1c27d6
MD5 c171a61ced42a66d78816e30a8528546
BLAKE2b-256 cc8e06bcfa79e41d6d07e4316b4c713d18e3e2143f0227f1f64bf60117d6cc8a

See more details on using hashes here.

Provenance

The following attestation bundles were made for twilio_agent_connect_microsoft-1.0.1-py3-none-any.whl:

Publisher: deploy.yml on twilio/twilio-agent-connect-microsoft

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page