Server data from the Official MCP Registry
MCP server for Gong.io - access calls, transcripts, and users
MCP server for Gong.io - access calls, transcripts, and users
Valid MCP server (1 strong, 1 medium validity signals). 4 known CVEs in dependencies (0 critical, 3 high severity) Package registry verified. Imported from the Official MCP Registry. Trust signals: trusted author (3/3 approved).
5 files analyzed · 5 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-justinbeckwith-gongio-mcp": {
"args": [
"-y",
"gongio-mcp"
],
"command": "npx"
}
}
}From the project's GitHub README.
An MCP (Model Context Protocol) server that provides access to your Gong.io data. Query calls, transcripts, users, keyword trackers, and more directly from Claude or any MCP-compatible client.
| Tool | Description |
|---|---|
list_calls | List calls with date/workspace filtering |
get_call | Get metadata for a specific call |
get_call_summary | AI summary: key points, topics, action items |
get_call_transcript | Full speaker-attributed transcript (paginated) |
search_calls | Rich call search — participant, customer, tracker, scope, duration, title, and more |
search_calls_by_account | Find calls involving a specific account/company by email domain |
search_calls_by_opportunity | Find calls linked to specific CRM Opportunities |
search_transcripts | Free-text keyword search across transcript sentences |
get_trackers | List keyword trackers (competitors, topics, etc.) |
list_workspaces | List workspaces and get IDs for use in other tools |
list_library_folders | List public call library folders |
get_library_folder_calls | Get calls saved in a specific library folder |
get_user | Get a specific user's profile |
search_users | Search/filter users by IDs or creation date |
list_users | List all workspace users |
search_calls can return a lot of data. Under the hood it:
Guardrails built in:
MAX_MCP_OUTPUT_LENGTH (default 50000 chars, configurable via env var), the tool automatically falls back to a compact table with a warning. You still get every call ID and title — drill in with get_call_summary on specific ones.include: ["outline"] is expensive (~80KB per call). Avoid it in multi-call searches.trackers filter (or non-zero trackers if no filter) — no more walls of (0x) noise.If your query hits the output cap, narrow it:
fromDateTime / toDateTimescope: "External" or scope: "Internal"minDuration: 600 to skip short no-showscustomerName or trackers filterinclude options like outlinenpx gongio-mcp
npm install -g gongio-mcp
gongio-mcp
git clone https://github.com/JustinBeckwith/gongio-mcp.git
cd gongio-mcp
npm install
npm run build
node dist/index.js
git clone https://github.com/JustinBeckwith/gongio-mcp.git
cd gongio-mcp
docker build -t gongio-mcp .
docker run --rm -i \
-e GONG_ACCESS_KEY=your-access-key \
-e GONG_ACCESS_KEY_SECRET=your-secret-key \
gongio-mcp
Set your Gong credentials as environment variables:
export GONG_ACCESS_KEY="your-access-key"
export GONG_ACCESS_KEY_SECRET="your-secret-key"
Or pass them inline:
GONG_ACCESS_KEY=your-key GONG_ACCESS_KEY_SECRET=your-secret npx gongio-mcp
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
Using npx:
{
"mcpServers": {
"gong": {
"command": "npx",
"args": ["gongio-mcp"],
"env": {
"GONG_ACCESS_KEY": "your-access-key",
"GONG_ACCESS_KEY_SECRET": "your-secret-key"
}
}
}
}
Using Docker:
{
"mcpServers": {
"gong": {
"command": "docker",
"args": ["run", "--rm", "-i",
"-e", "GONG_ACCESS_KEY",
"-e", "GONG_ACCESS_KEY_SECRET",
"gongio-mcp"],
"env": {
"GONG_ACCESS_KEY": "your-access-key",
"GONG_ACCESS_KEY_SECRET": "your-secret-key"
}
}
}
}
Using npx:
claude mcp add gong -e GONG_ACCESS_KEY=your-key -e GONG_ACCESS_KEY_SECRET=your-secret -- npx gongio-mcp
Using Docker (after docker build -t gongio-mcp .):
claude mcp add gong -e GONG_ACCESS_KEY=your-key -e GONG_ACCESS_KEY_SECRET=your-secret -- docker run --rm -i -e GONG_ACCESS_KEY -e GONG_ACCESS_KEY_SECRET gongio-mcp
List calls with optional date range and workspace filters. Returns minimal call metadata (ID, title, date, duration).
Parameters:
| Parameter | Required | Description |
|---|---|---|
fromDateTime | No | Start date in ISO 8601 format (e.g., 2024-01-01T00:00:00Z) |
toDateTime | No | End date in ISO 8601 format (e.g., 2024-01-31T23:59:59Z) |
workspaceId | No | Filter calls by workspace ID (use list_workspaces to find IDs) |
cursor | No | Pagination cursor for next page |
Get the URL, timing, direction, scope, system, and other metadata for one call. Faster than get_call_summary when you only need call metadata.
Parameters:
| Parameter | Required | Description |
|---|---|---|
callId | Yes | Gong call ID (numeric string) |
Get an AI-generated summary including brief overview, key points, topics, action items, and detailed outline. This is the recommended way to understand a call — use get_call_transcript only if you need exact quotes.
Parameters:
| Parameter | Required | Description |
|---|---|---|
callId | Yes | Gong call ID (numeric string) |
Get the raw transcript with speaker attribution. Transcripts are paginated (default 10KB) to prevent context overflow — use maxLength and offset to navigate.
Parameters:
| Parameter | Required | Description |
|---|---|---|
callId | Yes | Gong call ID (numeric string) |
maxLength | No | Maximum characters to return (default: 10000, max: 100000) |
offset | No | Character offset to start from for pagination (default: 0) |
Search calls with advanced filters including participant lookup, customer name search, and rich content selection. Automatically paginates through all results and returns participant info, brief summary, and topics by default.
Parameters:
Date & workspace
| Parameter | Description |
|---|---|
fromDateTime | Start date in ISO 8601 format |
toDateTime | End date in ISO 8601 format |
workspaceId | Filter by workspace ID (use list_workspaces to find IDs) |
callIds | Array of specific call IDs to retrieve |
Host / participant
| Parameter | Description |
|---|---|
primaryUserIds | Host user IDs (server-side) |
primaryUserEmails | Host emails (case-insensitive) |
excludePrimaryUserIds | Exclude these host user IDs |
participantUserIds | Any participant (host/attendee/invitee) user IDs |
excludeParticipantUserIds | Exclude calls where any participant has these user IDs |
participantEmails | Any participant emails (case-insensitive) |
excludeParticipantEmails | Exclude calls where any participant has these emails |
Content & customer
| Parameter | Description |
|---|---|
customerName | Fuzzy match against CRM account name, external email domains, and titles |
titleContains | Substring match on call title (case-insensitive) |
trackers | Calls where matching tracker(s) fired (count > 0). Workspace-specific — use get_trackers to discover |
Metadata
| Parameter | Description |
|---|---|
scope | External, Internal, or Unknown |
direction | Inbound, Outbound, Conference, or Unknown |
system | Conferencing platform (e.g., Zoom) — case-insensitive substring |
language | Language code (e.g., eng) — case-insensitive exact match |
minDuration | Minimum duration in seconds |
maxDuration | Maximum duration in seconds |
Response shape
| Parameter | Description |
|---|---|
include | Additional data to return — see table below |
include options:
| Value | What it adds | Size |
|---|---|---|
keyPoints | AI-extracted key points as bullets | ~5KB/call |
trackers | Keyword/smart tracker hits with counts | ~3KB/call |
highlights | AI-curated highlight clips grouped by theme | ~3KB/call |
speakers | Talk time per participant | ~1KB/call |
comments | Public comments left on the call | varies |
context | CRM account/opportunity linkage (HubSpot, Salesforce) | ~1KB/call |
outline | Full section-by-section outline with items | ~80KB/call (large) |
media | Audio/video URLs (valid 8 hours) | ~3KB/call |
Defaults (always returned): participants, brief summary, and topics — ~3KB per call.
Filter behavior notes:
primaryUserIds + participantUserIds compose: primary narrows server-side, participant post-filters.customerName matches any of: CRM account Name field, external participant email domain, or call title (case-insensitive substring).trackers names are workspace-specific — call get_trackers first to see what's configured. Match is case-insensitive substring (so "competitor" matches both "Competitors" and "Competitor Mentions").trackers filter is set, the relevant tracker content is auto-included and the output shows only the trackers you asked about. Without a filter, only non-zero trackers are shown."No calls found" rather than an error.See Response Size & Context Limits for how large-result fallback works.
Find calls involving a specific account or company by matching the email domains of external participants. The Gong API does not natively support filtering by account name (a known gap) — this tool fetches calls in the date range and post-filters on parties[].emailAddress. Auto-paginates the underlying /v2/calls/extensive endpoint up to maxCalls.
Use this when:
acme.com, acme.io, regional TLDs) and you need them allParameters:
| Parameter | Required | Description |
|---|---|---|
domains | Yes | Email domains, e.g. ["acme.com", "acme.io"]. A call matches if any external participant has an email at one of these domains. |
fromDateTime | No | Start date in ISO 8601 format |
toDateTime | No | End date in ISO 8601 format |
workspaceId | No | Filter by workspace ID |
primaryUserIds | No | Pre-narrow by call host user IDs (faster, server-side) |
matchCrmAccount | No | Also match where a CRM Account context object name contains a domain root (e.g. "acme" from "acme.com"). Requires CRM integration. Default false. |
maxCalls | No | Max calls to fetch & filter (default: 500, max: 5000). Auto-paginates underlying API. |
cursor | No | Pagination cursor (advanced) |
Cost note: This is fetch-then-filter. A 90-day window with no other narrowing typically pages through 1–5 API calls. Combine with primaryUserIds to bound cost on long ranges.
Find calls linked to specific CRM Opportunities by ID or name substring. Requires Gong-CRM integration (Salesforce / HubSpot) — calls without CRM linkage will not match.
Use this when:
opportunityIds: ["006xxxxx"] is the most precise option"Acme Q4 Renewal") and you want fuzzy matching across renamed/duplicated opportunitiesParameters:
| Parameter | Required | Description |
|---|---|---|
opportunityIds | At least one of opportunityIds or opportunityNames is required | CRM Opportunity IDs (e.g., Salesforce 18-character IDs) |
opportunityNames | At least one of opportunityIds or opportunityNames is required | Name substrings (case-insensitive) matched against the Name field of Opportunity context objects |
fromDateTime | No | Start date in ISO 8601 format |
toDateTime | No | End date in ISO 8601 format |
workspaceId | No | Filter by workspace ID |
primaryUserIds | No | Pre-narrow by call host user IDs |
maxCalls | No | Max calls to fetch & filter (default: 500, max: 5000) |
cursor | No | Pagination cursor (advanced) |
Cost note: Uses the same fetch-then-filter pattern as search_calls_by_account. CRM context lookup adds no extra API calls — it rides on the same /v2/calls/extensive request with context: "Extended".
Free-text keyword search across call transcript sentences within a bounded date range. Two-phase: (1) /v2/calls/extensive narrows the call set by date + optional primaryUserIds / domains, (2) /v2/calls/transcript fetches transcripts for the narrowed set and returns sentence-level matches with speaker attribution and timestamps.
Prefer Gong Trackers for recurring terms. For competitor names, ESP/tech terms (Klaviyo, Braze, Iterable, Postscript, Attentive, Sendgrid, Customer.io, etc.), and other terms you'll search for repeatedly — set them up as Gong Trackers in the UI (one-time, ~30 minutes for ~20 terms). Then use get_trackers + search_calls + get_call_summary instead. Trackers are server-side, the cost is dramatically lower, and they surface counts and timestamps natively. Use search_transcripts for ad-hoc one-offs.
Cost guard: Date ranges greater than 30 days require additional narrowing via primaryUserIds or domains. A 6-month unbounded scan would burn API quota and is rejected at the schema level.
Parameters:
| Parameter | Required | Description |
|---|---|---|
keywords | Yes | Keywords to search for. Each must be at least 2 characters. |
fromDateTime | Yes | Start of date window (ISO 8601). |
toDateTime | Yes | End of date window (ISO 8601). |
primaryUserIds | Required if window > 30 days and domains not set | Narrow to calls hosted by these users before scanning |
domains | Required if window > 30 days and primaryUserIds not set | Narrow to calls with external parties from these domains before scanning |
workspaceId | No | Filter by workspace ID |
caseSensitive | No | Default false. |
wholeWord | No | Default true — "ai" will not match "said" or "again". Set false for substring matching. |
maxCalls | No | Max calls to scan (default: 500). |
maxMatchesPerCall | No | Max sentence matches returned per call (default: 10) — prevents context overflow on calls with many hits. |
Returns: Sentence-level matches grouped by call, including speaker name and affiliation (when available), keyword matched, timestamp (mm:ss), and the sentence snippet.
List all keyword tracker definitions including tracked phrases, affiliation (whose speech is tracked), and filter queries. Explains tracker hits visible in get_call_summary output.
Parameters:
| Parameter | Required | Description |
|---|---|---|
workspaceId | No | Filter trackers by workspace ID (use list_workspaces to find IDs) |
List all Gong workspaces with their IDs and names. Use these IDs as filters in list_calls, search_calls, get_trackers, and other tools. Most companies have 1–3 workspaces (e.g., by region or product line).
Parameters: None
Get a specific user's profile including name, email, title, phone, and settings. Useful for resolving user IDs returned from call data.
Parameters:
| Parameter | Required | Description |
|---|---|---|
userId | Yes | Gong user ID (numeric string) |
Search and filter users by IDs or creation date. More flexible than list_users for resolving specific user IDs from call data in bulk.
Parameters:
| Parameter | Required | Description |
|---|---|---|
userIds | No | Array of specific user IDs to look up |
createdFromDateTime | No | Filter users created after this datetime (ISO 8601) |
createdToDateTime | No | Filter users created before this datetime (ISO 8601) |
cursor | No | Pagination cursor |
List all Gong users in your workspace. Returns name, email, and title for each user.
Parameters:
| Parameter | Required | Description |
|---|---|---|
cursor | No | Pagination cursor |
includeAvatars | No | Whether to include user avatar URLs |
List all public Gong call library folders for a workspace. Returns folder IDs and names used with get_library_folder_calls. Private and archived folders are not returned.
Parameters:
| Parameter | Required | Description |
|---|---|---|
workspaceId | Yes | Workspace ID to list folders for (use list_workspaces to find IDs) |
Get all calls saved in a specific Gong library folder. Returns call IDs, titles, curator notes, and snippet timing for clips. Call IDs can be passed directly to get_call_summary or get_call_transcript.
Parameters:
| Parameter | Required | Description |
|---|---|---|
folderId | Yes | Library folder ID (numeric string, from list_library_folders) |
Returns a markdown-formatted list of all users in your Gong workspace. Useful for resolving user IDs found in call data.
Parameters: None
Once connected to Claude, you can ask:
Interested in contributing? Check out CONTRIBUTING.md for development setup, testing instructions, and guidelines.
The repository includes gong-openapi.json — a local copy of the Gong API OpenAPI spec. It's useful as a reference when adding new tools: use it to look up endpoint paths, parameter names, and response shapes without leaving your editor. The latest spec can be downloaded from the Gong API documentation.
Be the first to review this server!
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.
by Microsoft · Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption