con un clic
telephony
// Give Gauss phone capabilities without core tool changes. Provision and persist a Twilio number, send and receive SMS/MMS, make direct calls, and place AI-driven outbound calls through Bland.ai or Vapi.
// Give Gauss phone capabilities without core tool changes. Provision and persist a Twilio number, send and receive SMS/MMS, make direct calls, and place AI-driven outbound calls through Bland.ai or Vapi.
Delegate coding tasks to Blackbox AI CLI agent. Multi-model agent with built-in judge that runs tasks through multiple LLMs and picks the best result. Requires the blackbox CLI and a Blackbox AI API key.
Query Solana blockchain data with USD pricing — wallet balances, token portfolios with values, transaction details, NFTs, whale detection, and live network stats. Uses Solana RPC + CoinGecko. No API key required.
Control Blender directly from Gauss via socket connection to the blender-mcp addon. Create 3D objects, materials, animations, and run arbitrary Blender Python (bpy) code. Use when user wants to create or modify anything in Blender.
Give the agent its own dedicated email inbox via AgentMail. Send, receive, and manage email autonomously using agent-owned email addresses (e.g. gauss-agent@agentmail.to).
Connect to a running NeuroSkill instance and incorporate the user's real-time cognitive and emotional state (focus, relaxation, mood, cognitive load, drowsiness, heart rate, HRV, sleep staging, and 40+ derived EXG scores) into responses. Requires a BCI wearable (Muse 2/S or OpenBCI) and the NeuroSkill desktop app running locally.
Migrate a user's OpenClaw customization footprint into Gauss Agent. Imports Gauss-compatible memories, SOUL.md, command allowlists, user skills, and selected workspace assets from ~/.openclaw, then reports exactly what could not be migrated and why.
| name | telephony |
| description | Give Gauss phone capabilities without core tool changes. Provision and persist a Twilio number, send and receive SMS/MMS, make direct calls, and place AI-driven outbound calls through Bland.ai or Vapi. |
| version | 1.0.0 |
| author | Nous Research |
| license | MIT |
| metadata | {"gauss":{"tags":["telephony","phone","sms","mms","voice","twilio","bland.ai","vapi","calling","texting"],"related_skills":["find-nearby","google-workspace","agentmail"],"category":"productivity"}} |
This optional skill gives Gauss practical phone capabilities while keeping telephony out of the core tool list.
It ships with a helper script, scripts/telephony.py, that can:
~/.gauss/.env<Say> or <Play>This skill is meant to cover the practical phone tasks users actually want:
It does not turn Gauss into a real-time inbound phone gateway. Inbound SMS is handled by polling the Twilio REST API. That is enough for many workflows, including notifications and some one-time-code retrieval, without adding core webhook infrastructure.
Use this logic instead of hardcoded provider routing:
Use Twilio.
Why:
Use cases:
Use Bland.ai.
Why:
Tradeoff:
Use Twilio + Vapi.
Why:
Recommended flow:
VAPI_PHONE_NUMBER_IDai-call --provider vapiUse Twilio direct call with a public audio URL.
Why:
text_to_speech plus a public file host or tunnelThe skill persists telephony state in two places:
~/.gauss/.envUsed for long-lived provider credentials and owned-number IDs, for example:
TWILIO_ACCOUNT_SIDTWILIO_AUTH_TOKENTWILIO_PHONE_NUMBERTWILIO_PHONE_NUMBER_SIDBLAND_API_KEYVAPI_API_KEYVAPI_PHONE_NUMBER_IDPHONE_PROVIDER (AI call provider: bland or vapi)~/.gauss/telephony_state.jsonUsed for skill-only state that should survive across sessions, for example:
This means:
diagnose can tell you what number is already configuredtwilio-inbox --since-last --mark-seen can continue from the previous checkpointAfter installing this skill, locate the script like this:
SCRIPT="$(find ~/.gauss/skills -path '*/telephony/scripts/telephony.py' -print -quit)"
If SCRIPT is empty, the skill is not installed yet.
This is an official optional skill, so install it from the Skills Hub:
gauss skills search telephony
gauss skills install official/productivity/telephony
Sign up at:
Then save credentials into Gauss:
python3 "$SCRIPT" save-twilio ACXXXXXXXXXXXXXXXXXXXXXXXXXXXX your_auth_token_here
Search for available numbers:
python3 "$SCRIPT" twilio-search --country US --area-code 702 --limit 5
Buy and remember a number:
python3 "$SCRIPT" twilio-buy "+17025551234" --save-env
List owned numbers:
python3 "$SCRIPT" twilio-owned
Set one of them as the default later:
python3 "$SCRIPT" twilio-set-default "+17025551234" --save-env
# or
python3 "$SCRIPT" twilio-set-default PNXXXXXXXXXXXXXXXXXXXXXXXXXXXX --save-env
Sign up at:
Save config:
python3 "$SCRIPT" save-bland your_bland_api_key --voice mason
Sign up at:
Save the API key first:
python3 "$SCRIPT" save-vapi your_vapi_api_key
Import your owned Twilio number into Vapi and persist the returned phone number ID:
python3 "$SCRIPT" vapi-import-twilio --save-env
If you already know the Vapi phone number ID, save it directly:
python3 "$SCRIPT" save-vapi your_vapi_api_key --phone-number-id vapi_phone_number_id_here
At any time, inspect what the skill already knows:
python3 "$SCRIPT" diagnose
Use this first when resuming work in a later session.
python3 "$SCRIPT" save-twilio AC... auth_token_here
python3 "$SCRIPT" twilio-search --country US --area-code 702 --limit 10
~/.gauss/.env + state:python3 "$SCRIPT" twilio-buy "+17025551234" --save-env
python3 "$SCRIPT" diagnose
This shows the remembered default number and inbox checkpoint state.
python3 "$SCRIPT" twilio-send-sms "+15551230000" "Your deployment completed successfully."
With media:
python3 "$SCRIPT" twilio-send-sms "+15551230000" "Here is the chart." --media-url "https://example.com/chart.png"
Poll the inbox for the default Twilio number:
python3 "$SCRIPT" twilio-inbox --limit 20
Only show messages that arrived after the last checkpoint, and advance the checkpoint when you're done reading:
python3 "$SCRIPT" twilio-inbox --since-last --mark-seen
This is the main answer to “how do I access messages the number receives next time the skill is loaded?”
python3 "$SCRIPT" twilio-call "+15551230000" --message "Hello! This is Gauss calling with your status update." --voice Polly.Joanna
This is the main path for reusing Gauss's existing text_to_speech support.
Use this when:
<Say>Generate or host audio separately, then:
python3 "$SCRIPT" twilio-call "+155****0000" --audio-url "https://example.com/briefing.mp3"
Recommended Gauss TTS -> Twilio Play workflow:
text_to_speech.--audio-url.Example agent flow:
text_to_speechtwilio-call --audio-url ... to deliver it by phoneGood hosting options for the MP3:
Important note:
If you need to press digits after the call connects, use --send-digits.
Twilio interprets w as a short wait.
python3 "$SCRIPT" twilio-call "+18005551234" --message "Connecting to billing now." --send-digits "ww1w2w3"
This is useful for reaching a specific menu branch before handing off to a human or delivering a short status message.
python3 "$SCRIPT" ai-call "+15551230000" "Call the dental office, ask for a cleaning appointment on Tuesday afternoon, and if they do not have Tuesday availability, ask for Wednesday or Thursday instead." --provider bland --voice mason --max-duration 3
Check status:
python3 "$SCRIPT" ai-status <call_id> --provider bland
Ask Bland analysis questions after completion:
python3 "$SCRIPT" ai-status <call_id> --provider bland --analyze "Was the appointment confirmed?,What date and time?,Any special instructions?"
python3 "$SCRIPT" vapi-import-twilio --save-env
python3 "$SCRIPT" ai-call "+15551230000" "You are calling to make a dinner reservation for two at 7:30 PM. If that is unavailable, ask for the nearest time between 6:30 and 8:30 PM." --provider vapi --max-duration 4
python3 "$SCRIPT" ai-status <call_id> --provider vapi
When the user asks for a call or text:
diagnose if configuration state is unclear.Those would require more infrastructure than a pure optional skill.
twilio-inbox polls the REST API; it is not instant push delivery.After setup, you should be able to do all of the following with just this skill:
diagnose shows provider readiness and remembered state~/.gauss/.env