SignalWire is a programmable unified communications platform that unifies voice, messaging, video, and AI into a single control plane. SignalWire’s APIs and SDKs enable developers to build state-of-the-art realtime communication experiences without needing to manage complex telecom infrastructure or stitch together disconnected tools.
This guide will help you set up your account, explore the core APIs, and launch your first application.
When you create a SignalWire account, you also create a Space,
like spacename.signalwire.com.
Your Dashboard is located at that subdomain.
In your Dashboard, you can:

Let’s begin by figuring out the best way for you to build. The right approach depends on what you’re creating and how you prefer to work.
You want to build an AI-powered voice agent that handles phone calls.
This is common for:
Agents SDK - A Python framework for building sophisticated AI voice agents. You get full control over prompts, custom functions (SWAIG) dedicated to AI, customizeable conversation flow, and seamless LLM integration. Best for complex agents that need to perform actions like booking appointments, looking up data, or integrating with your systems.
AI Agent (Dashboard) - Configure an AI agent directly in your Dashboard without writing code. Set up prompts, choose a voice, add functions, and connect it to a phone number. Great for getting started quickly or simpler use cases.
SWML with AI - Add AI capabilities to your SWML scripts using the ai method.
Good when you want AI as part of a larger call flow that includes other logic.
You want voice, video, or chat directly in a web browser or mobile app.
This is common for:
Browser SDK - Our JavaScript SDK for building custom WebRTC experiences. You get full control over the UI and user experience. Best when you need video conferencing, custom calling interfaces, or real-time chat.
You’re building a backend service that handles calls or messages.
This is common for:
If you need simple call handling (IVRs, call forwarding, playing messages), use SWML. Your server responds to webhooks with JSON/YAML instructions. It’s stateless, works with any programming language, and is the simplest approach for most use cases.
If you need real-time control (live call monitoring, mid-call transfers, complex orchestration), use the Realtime SDK. It maintains a persistent WebSocket connection for instant, bi-directional communication. Best for applications that need to react to events as they happen.
If you’re building AI voice agents, use the Agents SDK. It’s a Python framework specifically designed for creating conversational AI that handles phone calls. It handles the complexity of integrating with LLMs and managing conversations.
You want to build without writing much (or any) code.
This is common for quick prototypes, simple IVRs, and small businesses needing basic call handling.
Call Flow Builder - A visual, drag-and-drop interface for building call handling logic. No code required. You connect nodes to define what happens when someone calls - play a message, gather input, route to different people, etc.
SWML Scripts - Write simple JSON or YAML scripts directly in your Dashboard. It’s not quite “no code” but it’s very low code, and you don’t need to run any servers. SignalWire hosts the scripts for you.
AI Agent - Configure a conversational AI agent through your Dashboard. Set up prompts, choose a voice, and connect it to a phone number. The AI handles conversations autonomously.
You have an existing Twilio application and want to move to SignalWire.
Good news, SignalWire’s Compatibility API is designed as a drop-in replacement. In most cases, you can switch by changing a few lines of code.
AI is not supported in the Compatibility API. Check out the AI Application section instead.
SignalWire supports the following communication channels:
Phone calls, IVRs, recording, conferencing
Video rooms, screen sharing, recordings
SMS and MMS text messages
Real-time chat for web and mobile apps
Intelligent voice agents powered by LLMs
Send and receive faxes programmatically
Most channels can work over different transports depending on how you want to connect:
For example, a voice call could come in via PSTN (someone dialing your number), SIP (from a desk phone), or WebRTC (from your web app). SignalWire will handle all three.
To make or receive calls and messages through the phone network, you’ll need SignalWire phone numbers. You can buy local numbers, toll-free numbers, or short codes directly from your Dashboard or the API.
Each number can be configured to handle incoming calls and messages differently - whether that’s forwarding to another number, running a script, connecting to an AI agent, or triggering your own application.
We also offer the option of purchasing phone numbers programmatically via our Purchase a Phone Number API Endpoint.
In SignalWire, a Resource is anything that can handle communications - an AI agent, a script, a SIP connection, or your own application. When a call or message comes in, you tell SignalWire which Resource should handle it.
Common resource types include:
Every Resource has an Address. This is a unique identifier that lets you target and interact with it. Think of addresses as the phone number for any resource, but broader in scope.
Addresses can be:
+14155551234 for PSTN callssip:user@domain.com/support-queue or /main-conference that are easy to rememberA single Resource can have multiple addresses, and you can change them anytime. For example, you might point both a phone number and a custom alias to the same AI agent.
Subscribers are end users who authenticate with SignalWire to make and receive calls. If you’re building a contact center, business phone system, or video conferencing app for example, your users become Subscribers.
SignalWire manages these users for you. You create, update, and delete them through our REST APIs, and each Subscriber gets:
/private/usernameThis means you don’t have to build user management, authentication, or device registration yourself - SignalWire handles it.
Once you’ve chosen your path, here are some resources to help you along the way:
If you get stuck or have questions, our support team is here to help at support@signalwire.com.
*Twilio and TwiML are trademarks of Twilio, Inc. SignalWire, Inc. and its products are not affiliated with or endorsed by Twilio, Inc.