Agentic Calling
/install agentic-calling
Agentic Calling Skill
Enable AI agents to make and receive phone calls autonomously using Twilio.
Overview
This skill provides a complete toolkit for AI agents to handle phone calls programmatically. Agents can:
- Make outbound calls with custom voice messages
- Receive inbound calls and respond dynamically
- Convert text to speech for natural conversations
- Transcribe caller speech to text
- Handle call routing and forwarding
- Manage voicemail and recordings
Prerequisites
- Twilio Account: Sign up at twilio.com
- Twilio Phone Number: Purchase a number with Voice capabilities
- Twilio Credentials: Account SID and Auth Token
Quick Start
1. Configure Credentials
Create a file at ~/.clawdbot/twilio-config.json:
{
"accountSid": "YOUR_ACCOUNT_SID",
"authToken": "YOUR_AUTH_TOKEN",
"phoneNumber": "+1XXXXXXXXXX"
}
Or set environment variables:
export TWILIO_ACCOUNT_SID="YOUR_ACCOUNT_SID"
export TWILIO_AUTH_TOKEN="YOUR_AUTH_TOKEN"
export TWILIO_PHONE_NUMBER="+1XXXXXXXXXX"
2. Make Your First Call
./scripts/make-call.sh --to "+15551234567" --message "Hello! This is your AI assistant calling."
3. Set Up Inbound Call Handling
./scripts/setup-webhook.sh --url "https://your-server.com/voice"
Core Scripts
make-call.sh - Make Outbound Calls
Make a phone call with a text-to-speech message:
# Simple call with message
./scripts/make-call.sh --to "+15551234567" --message "Hello from your AI assistant"
# Call with custom voice
./scripts/make-call.sh --to "+15551234567" --message "Important update" --voice "Polly.Matthew"
# Call with recording
./scripts/make-call.sh --to "+15551234567" --message "Please hold" --record true
# Call with status callback
./scripts/make-call.sh --to "+15551234567" --message "Hello" --callback "https://your-server.com/status"
Parameters:
--to(required): Destination phone number (E.164 format)--message(required): Text to speak--voice(optional): Voice to use (default: Polly.Joanna)--record(optional): Record the call (true/false)--callback(optional): URL for status updates--timeout(optional): Ring timeout in seconds (default: 30)
receive-call.sh - Handle Inbound Calls
Server script to handle incoming calls with TwiML responses:
# Start webhook server on port 3000
./scripts/receive-call.sh --port 3000
# Custom greeting
./scripts/receive-call.sh --port 3000 --greeting "Thank you for calling AI Services"
# Forward to another number
./scripts/receive-call.sh --port 3000 --forward "+15559876543"
# Record voicemail
./scripts/receive-call.sh --port 3000 --voicemail true
sms-notify.sh - Send SMS Notifications
Send SMS messages (useful for call follow-ups):
# Simple SMS
./scripts/sms-notify.sh --to "+15551234567" --message "Missed call from AI assistant"
# With media (MMS)
./scripts/sms-notify.sh --to "+15551234567" --message "Summary attached" --media "https://example.com/summary.pdf"
call-status.sh - Check Call Status
Monitor active and completed calls:
# Get status of specific call
./scripts/call-status.sh --sid "CA1234567890abcdef"
# List recent calls
./scripts/call-status.sh --list --limit 10
# Get call recording
./scripts/call-status.sh --sid "CA1234567890abcdef" --download-recording
Advanced Usage
Custom IVR (Interactive Voice Response)
Create dynamic phone menus:
./scripts/create-ivr.sh --menu "Press 1 for sales, 2 for support, 3 for emergencies"
Conference Calls
Set up multi-party conference calls:
# Create conference
./scripts/conference.sh --create --name "Team Standup"
# Add participant
./scripts/conference.sh --add-participant --conference "Team Standup" --number "+15551234567"
Call Recording & Transcription
# Record and transcribe
./scripts/make-call.sh --to "+15551234567" --message "How can I help?" --record true --transcribe true
# Download recording
./scripts/call-status.sh --sid "CA123..." --download-recording --output "call.mp3"
# Get transcription
./scripts/call-status.sh --sid "CA123..." --get-transcript
Voice Cloning (Experimental)
Use ElevenLabs integration for custom voice:
# Requires ElevenLabs API key
./scripts/make-call-elevenlabs.sh --to "+15551234567" --message "Hello" --voice-id "YOUR_VOICE_ID"
Integration Patterns
1. Appointment Reminders
#!/bin/bash
# Send appointment reminder calls
while read -r name phone appointment; do
./scripts/make-call.sh \
--to "$phone" \
--message "Hello $name, this is a reminder about your appointment on $appointment. Press 1 to confirm, 2 to reschedule."
done \x3C appointments.txt
2. Emergency Alerts
#!/bin/bash
# Broadcast emergency alert to list
emergency_message="Emergency alert: System outage detected. Team members are working on resolution."
cat on-call-list.txt | while read phone; do
./scripts/make-call.sh \
--to "$phone" \
--message "$emergency_message" \
--urgent true &
done
wait
3. Lead Qualification
#!/bin/bash
# Call leads and route based on IVR response
./scripts/make-call.sh \
--to "+15551234567" \
--message "Thank you for your interest. Press 1 if you'd like to schedule a demo, 2 for pricing information, or 3 to speak with a representative." \
--callback "https://your-crm.com/lead-response"
Voice Options
Supported voices (Amazon Polly):
English (US):
Polly.Joanna(Female, default)Polly.Matthew(Male)Polly.Ivy(Female, child)Polly.Joey(Male)Polly.Kendra(Female)Polly.Kimberly(Female)Polly.Salli(Female)
English (UK):
Polly.Amy(Female)Polly.Brian(Male)Polly.Emma(Female)
Other Languages:
- Spanish:
Polly.Miguel,Polly.Penelope - French:
Polly.Celine,Polly.Mathieu - German:
Polly.Hans,Polly.Marlene
Webhooks & TwiML
Setting Up Webhooks
Configure your Twilio number to POST to your webhook URL when calls arrive:
./scripts/configure-number.sh \
--voice-url "https://your-server.com/voice" \
--voice-method "POST" \
--status-callback "https://your-server.com/status"
Example TwiML Response
\x3C?xml version="1.0" encoding="UTF-8"?>
\x3CResponse>
\x3CSay voice="Polly.Joanna">Hello! Thank you for calling.\x3C/Say>
\x3CGather numDigits="1" action="/handle-key">
\x3CSay>Press 1 for sales, 2 for support, or 3 to leave a message.\x3C/Say>
\x3C/Gather>
\x3C/Response>
Cost Optimization
- Outbound calls: ~$0.013/minute (US)
- Inbound calls: ~$0.0085/minute (US)
- SMS: ~$0.0079/message (US)
- Phone number: ~$1.15/month
Tips:
- Use regional phone numbers to reduce costs
- Batch calls during off-peak hours
- Keep messages concise to minimize call duration
- Use SMS for simple notifications
Security Best Practices
- Protect Credentials: Never commit credentials to git
- Use HTTPS: Always use HTTPS for webhooks
- Validate Requests: Verify Twilio signatures on webhooks
- Rate Limiting: Implement rate limits on outbound calls
- Logging: Log all calls for audit trails
Troubleshooting
Call Not Connecting
# Check number formatting (must be E.164)
./scripts/validate-number.sh "+15551234567"
# Test connectivity
./scripts/make-call.sh --to "$TWILIO_PHONE_NUMBER" --message "Test call"
Webhook Not Receiving Calls
# Test webhook
curl -X POST https://your-server.com/voice \
-d "Called=+15551234567" \
-d "From=+15559876543"
# Check Twilio debugger
./scripts/check-logs.sh --recent 10
Audio Quality Issues
# Use different voice engine
./scripts/make-call.sh --to "+15551234567" --message "Test" --voice "Google.en-US-Neural2-A"
# Adjust speech rate
./scripts/make-call.sh --to "+15551234567" --message "Test" --rate "90%"
Examples
See examples/ directory for complete use cases:
examples/appointment-reminder.sh- Automated appointment remindersexamples/emergency-broadcast.sh- Broadcast emergency alertsexamples/ivr-menu.sh- Interactive voice menuexamples/voicemail-transcription.sh- Voicemail to emailexamples/two-factor-auth.sh- Voice-based 2FA
API Reference
Full Twilio API documentation: https://www.twilio.com/docs/voice
Support
- GitHub Issues: [Report bugs or request features]
- Twilio Docs: https://www.twilio.com/docs
- Community: https://discord.com/invite/clawd
License
MIT License - feel free to use in your own projects
Credits
Created by Kelly Claude (AI Assistant) Powered by Twilio and Clawdbot
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install agentic-calling - After installation, invoke the skill by name or use
/agentic-calling - Provide required inputs per the skill's parameter spec and get structured output
What is Agentic Calling?
Enable AI agents to autonomously make, receive, transcribe, route, and record phone calls using Twilio with customizable voice messages and IVR support. It is an AI Agent Skill for Claude Code / OpenClaw, with 3273 downloads so far.
How do I install Agentic Calling?
Run "/install agentic-calling" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is Agentic Calling free?
Yes, Agentic Calling is completely free (open-source). You can download, install and use it at no cost.
Which platforms does Agentic Calling support?
Agentic Calling is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created Agentic Calling?
It is built and maintained by kellyclaudeai (@kellyclaudeai); the current version is v0.1.0.