Manages Webex Calling infrastructure including users, call forwarding, voicemail, hunt groups, call queues, phone numbers, call analytics, locations, schedules, devices, workspaces, caller ID, and organization contacts.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Webex Calling MCP ServerFind available phone numbers in the London office."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Webex Calling MCP Server
An MCP (Model Context Protocol) server that lets you manage your entire Webex Calling infrastructure using natural language through an AI assistant like Claude.
Built for Cisco partners and network engineers to demonstrate the power of AI-driven network administration.
Prerequisites
1. Node.js (v18 or later)
Node.js is the runtime needed to execute the MCP server. You must install it on every machine where you want to run the server.
Option A — Installer:
Go to nodejs.org and download the LTS version (green button)
Open the
.pkgfile and follow the installerOpen Terminal (Spotlight → type "Terminal") and verify:
node --version npm --version
Option B — Homebrew (if you have it):
brew install nodeGo to nodejs.org and download the LTS version (green button)
Run the
.msiinstaller — keep all default options (this addsnodeandnpmto your PATH automatically)Restart your terminal (close and reopen PowerShell or cmd)
Verify the installation:
node --version npm --version
Troubleshooting: If
npmis not recognized after installation, restart your computer to ensure the PATH is updated.
2. Git
Git is needed to clone this repository.
Git is pre-installed on macOS. Verify with:
git --versionIf prompted to install Xcode Command Line Tools, accept the installation.
Download Git from git-scm.com
Run the installer — keep all default options
Restart your terminal and verify:
git --version
3. A Webex Full Admin account
4. An AI client that supports MCP
VS Code with GitHub Copilot (Chat agent mode) — Download VS Code
Claude Desktop — Download Claude Desktop
Related MCP server: Cisco MCP Pods Server
Demo Scenarios (Live with partners)
Natural Language Command | What it does |
"Redirect all incoming calls from the Paris office to voicemail until Monday morning." | Uses call intercept to redirect calls |
"Create a hunt group for the support team with these 5 numbers, using a round-robin distribution." | Creates a hunt group with CIRCULAR policy |
"Show me which users in the organization do not have a phone assigned." | Audits users missing phone numbers |
"Generate a report of missed calls over the last 24 hours." | Analyzes CDR data and produces a summary |
"Set up a holiday schedule for all locations — close offices Dec 24-Jan 2." | Creates holiday schedules per location |
"List all call queues and their average wait times." | Queries call queue configurations |
"Enable Do Not Disturb for the entire executive team." | Batch-updates DND settings |
"Find available phone numbers in the London office." | Queries number inventory |
Available Tools (35+)
People & Users
list_people— List/search users with calling dataget_person— Get detailed user infofind_users_without_phones— Audit users without phone numbers
Call Forwarding & Voicemail
get_call_forwarding/update_call_forwarding— Manage forwarding rulesget_voicemail/update_voicemail— Configure voicemailredirect_calls_to_voicemail— Quick call intercept (great for demos!)set_do_not_disturb— Enable/disable DND
Hunt Groups
list_hunt_groups/get_hunt_group— View hunt groupscreate_hunt_group— Create with agents & routing policyupdate_hunt_group/delete_hunt_group— Manage existing groups
Call Queues
list_call_queues/get_call_queue— View queuescreate_call_queue— Create with agents & queue settingsupdate_call_queue/delete_call_queue— Manage existing queues
Phone Numbers
list_numbers— List all numbers with filteringfind_available_numbers— Find unassigned numbers
Call Analytics
get_call_history— Raw CDR dataget_missed_calls_report— Formatted missed call analysis with charts-ready data
Locations & Schedules
list_locations/get_location— View office locationslist_schedules— View business hours & holiday schedulescreate_holiday_schedule— Create holiday scheduleslist_auto_attendants/get_auto_attendant— View IVR menus
Devices & Workspaces
list_devices/get_device— View device inventorylist_workspaces— View conference rooms & shared spacesget_caller_id/update_caller_id— Manage caller ID settings
Organization Contacts & Groups
list_org_contacts/get_org_contact— View org directory contactscreate_org_contact— Add external contacts to the org directoryupdate_org_contact/delete_org_contact— Manage existing contactslist_groups— List groups (used to scope contact visibility)
Quick Start
1. Clone the repository
Open Terminal and run:
cd ~/Desktop
git clone https://github.com/rochaussee/webex-calling-mcp.git
cd webex-calling-mcpOpen PowerShell and run:
cd $HOME\Desktop
git clone https://github.com/rochaussee/webex-calling-mcp.git
cd webex-calling-mcp2. Create a Webex Integration
Go to developer.webex.com
Sign in with your Webex Full Admin account
Create a new Integration and note the Client ID and Client Secret
Set the Redirect URI to
http://localhost:22991/callbackSelect the required scopes (see
src/auth.tsfor the default list)
3. Install dependencies & Build
These commands are the same on macOS and Windows:
npm install
npm run buildNote: You must be in the project folder (e.g.
cd webex-calling-mcp) before running these commands.
4. Authenticate (one-time setup)
WEBEX_CLIENT_ID=xxx WEBEX_CLIENT_SECRET=yyy npm run authOn Windows, you must set environment variables separately — the VAR=value command syntax does not work in PowerShell:
$env:WEBEX_CLIENT_ID="xxx"
$env:WEBEX_CLIENT_SECRET="yyy"
npm run authReplace xxx and yyy with the Client ID and Client Secret from step 2.
What happens:
Your browser opens the Webex login page
You sign in with your Webex Full Admin account
Webex sends back authentication tokens to the local server
Tokens are saved locally:
macOS / Linux:
~/.webex-mcp/tokens.jsonWindows:
%USERPROFILE%\.webex-mcp\tokens.json
About tokens:
Access token (~14 days): used by the MCP server to call Webex APIs
Refresh token (~90 days): used to automatically renew the access token when it expires
You only need to re-run
npm run authevery ~90 days when the refresh token expires
Useful commands:
npm run auth -- --status # Check token status
npm run auth -- --logout # Clear stored tokens
npm run auth -- --help # Full help5. Configure in your MCP Client
The MCP server needs your Client ID and Client Secret at runtime to automatically refresh expired access tokens. These are passed as environment variables in the MCP configuration.
Why are Client ID / Secret needed here too? The
npm run authstep uses them to obtain tokens. The MCP server config needs them to refresh tokens automatically. Without them, you'd have to re-authenticate manually every ~14 days instead of every ~90 days.
VS Code (Copilot / Claude Dev)
Add to your .vscode/mcp.json or VS Code global settings:
macOS:
~/Library/Application Support/Code/User/mcp.jsonWindows:
%APPDATA%\Code\User\mcp.json
{
"mcpServers": {
"webex-calling": {
"command": "node",
"args": ["/Users/<your-username>/Desktop/webex-calling-mcp/dist/index.js"],
"env": {
"WEBEX_CLIENT_ID": "your-integration-client-id",
"WEBEX_CLIENT_SECRET": "your-integration-client-secret"
}
}
}
}{
"mcpServers": {
"webex-calling": {
"command": "node",
"args": ["C:\\Users\\<your-username>\\Desktop\\webex-calling-mcp\\dist\\index.js"],
"env": {
"WEBEX_CLIENT_ID": "your-integration-client-id",
"WEBEX_CLIENT_SECRET": "your-integration-client-secret"
}
}
}
}Note: Use double backslashes
\\in JSON paths on Windows.
Security note: This file is local to your machine and not tracked by git. Never commit your credentials.
Claude Desktop
Add to your Claude Desktop config:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"webex-calling": {
"command": "node",
"args": ["/Users/<your-username>/Desktop/webex-calling-mcp/dist/index.js"],
"env": {
"WEBEX_CLIENT_ID": "your-integration-client-id",
"WEBEX_CLIENT_SECRET": "your-integration-client-secret"
}
}
}
}{
"mcpServers": {
"webex-calling": {
"command": "node",
"args": ["C:\\Users\\<your-username>\\Desktop\\webex-calling-mcp\\dist\\index.js"],
"env": {
"WEBEX_CLIENT_ID": "your-integration-client-id",
"WEBEX_CLIENT_SECRET": "your-integration-client-secret"
}
}
}
}6. Start Talking to Your Infrastructure
Once configured, restart VS Code or Claude Desktop, then just ask questions in natural language. The AI will automatically pick the right MCP tools.
Architecture
┌─────────────────┐ stdio / JSON-RPC ┌──────────────────────┐
│ AI Assistant │ ◄──────────────────────► │ MCP Server │
│ (Claude/Copilot) │ │ (this project) │
└─────────────────┘ └──────┬───────────────┘
│ HTTPS
▼
┌──────────────────────┐
│ Webex REST APIs │
│ webexapis.com/v1 │
└──────────────────────┘Transport: stdio (standard model context protocol)
SDK:
@modelcontextprotocol/sdk(official MCP TypeScript SDK)API Client: Typed wrapper around Webex REST API v1
Auth: OAuth2 Integration (Client ID / Client Secret) with auto-refresh
Project Structure
src/
├── index.ts # MCP server entry point
├── auth.ts # OAuth2 authentication (PKCE flow + token refresh)
├── auth-cli.ts # CLI for login, status, logout
├── webex-api.ts # Webex REST API client
└── tools/
├── people.ts # People & user management
├── call-forwarding.ts # Call forwarding, voicemail, DND, intercept
├── hunt-groups.ts # Hunt group CRUD
├── call-queues.ts # Call queue CRUD
├── numbers.ts # Phone number management
├── analytics.ts # CDR & missed call reports
├── locations.ts # Locations, schedules, auto attendants
├── devices.ts # Devices, workspaces, caller ID
└── contacts.ts # Organization contacts & groupsDevelopment
# Run in development mode (no build step)
WEBEX_CLIENT_ID=xxx WEBEX_CLIENT_SECRET=yyy npx tsx src/index.ts
# Build for production
npm run build
# Run production build
WEBEX_CLIENT_ID=xxx WEBEX_CLIENT_SECRET=yyy node dist/index.js# Set environment variables (do this once per terminal session)
$env:WEBEX_CLIENT_ID="xxx"
$env:WEBEX_CLIENT_SECRET="yyy"
# Run in development mode
npx tsx src/index.ts
# Build for production
npm run build
# Run production build
node dist/index.jsSecurity Notes
Never commit your Client ID / Client Secret — always use environment variables
Tokens are stored locally in
~/.webex-mcp/tokens.json(macOS/Linux) or%USERPROFILE%\.webex-mcp\tokens.json(Windows) with restricted permissionsToken scope requirements depend on which tools you use:
spark-admin:people_read— people listingspark-admin:telephony_config_read/_write— calling configspark-admin:calling_cdr_read— call history/CDRspark-admin:devices_read— device inventory
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/rochaussee/webex-calling-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server
