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

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]

On Hosted Agents in Foundry Agent Service

pip install twilio-agent-connect-microsoft[hosted-agents]

The hosted-agents extra provides the Hosted Agents runtime (TACHostedAgentsApp) and includes tac[server], so a separate server extra isn't needed. TACHostedAgentsApp hosts any TAC connector, so add the extra for the connector you want — e.g. [hosted-agents,agent-framework] (as the deployment example does) or [hosted-agents,voice-live]. Or pair it with TAC core to host an agent built on any other SDK.

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). Also the recommended store for Hosted Agents in Foundry Agent Service, where APIM pins each conversation to one sandbox via agent_session_id affinity and $HOME survives idle eviction — giving durable continuity without Cosmos DB
  • 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.1.0.tar.gz (31.9 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.1.0.tar.gz.

File metadata

File hashes

Hashes for twilio_agent_connect_microsoft-1.1.0.tar.gz
Algorithm Hash digest
SHA256 9a1cd85b552f0efc593b5071dde9276c7182cc2362de2690a9b0ae10dc9f6833
MD5 79878adfa363d5c3448bcfc52f39dfc7
BLAKE2b-256 8fd7d65a01f70ef4265b7c6c08084247d30c8b668cab1c5f56047593cc0d7d2f

See more details on using hashes here.

Provenance

The following attestation bundles were made for twilio_agent_connect_microsoft-1.1.0.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.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for twilio_agent_connect_microsoft-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 32ca2eaaf4b96c2fca7d22a4d2b6a5d3238a5d5e86161e2bef3a6959361deafa
MD5 dc4c79123ab7d62dfbe21882deb97591
BLAKE2b-256 cec4830f242d9dd25294bff16ef7cd3acef2929a60747aef74c9674ffed61864

See more details on using hashes here.

Provenance

The following attestation bundles were made for twilio_agent_connect_microsoft-1.1.0-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