Affinity MCP server
Project description
affinity-mcp: An Affinity MCP Server
This package sets up the Affinity MCP server locally to interact with the Affinity APIs. Affinity now offers a hosted version. See the setup instructions to get started.
Note: When this MCP server makes requests to the Affinity API, it includes a User-Agent header that identifies the request as coming from the Affinity MCP Server. This helps the Affinity team understand API usage patterns and provide better support for MCP-specific issues.
Features
Persons
- Search Persons: Search for persons by name or email, with optional filtering by interaction dates (first/last email, meetings)
- Get Person Info: Retrieve detailed information about a person including current organization, job title, and more.
- Get Person List Entries: View which lists a person appears on
- Create Person: Create a new person with first name, last name, emails, and optional organization associations
Companies
- Search Companies: Search for companies by name or domain, with optional filtering by interaction history
- Get Company Info: Retrieve detailed information about a company including location, description, and more.
- Get Company List Entries: View which lists a company appears on
- Create Company: Create a new company with a required
nameand optionaldomainand person associations viaperson_ids
Entity Files
- Download Entity File: Download a file/attachment by its entity file ID and save it into the server's download sandbox
Opportunities
- Search Opportunities: Search for opportunities by keyword or list all opportunities
Semantic Search
- Semantic Search: Finds companies matching a natural language description about business context, characteristics, or relationship data. Support for searching on persons coming soon!
Notes
- Create Note: Create an HTML note and attach it to persons, companies, or opportunities
- Get Notes: Find notes with filtering by ID, creator, or creation date
- Get Notes for Entity: Retrieve all notes attached to a specific person, company, or opportunity
- Get Entities Attached to Note: Find all persons, companies, or opportunities linked to a specific note
Lists
- Get Lists: View all lists in your organization that you have access to
- Get List Info: Retrieve metadata about a specific list
- Get List Entries: Retrieve list entries from a specific list
- Get Single List Entry: Retrieve metadata about a single list entry from a specific list
- Create List: Create a new company, person, or opportunity list, optionally public
- Create List Entry: Add an existing person or company as a list entry to a specific list
Saved Views
- Get Saved Views: Retrieve all saved views configured on a specific list
- Get Saved View List Entries: Retrieve list entries from a specific saved view, returning the fields the view is configured to display
Meetings
- Get Meetings: Retrieve past and future meetings with filtering by meeting ID, start time, creation time, or update time
- Get Meetings for Entity: Retrieve past and future meetings for a specific company, person, or opportunity, with filtering by internal person and logging type
Fields
- Get Entity Fields: View metadata about available fields for companies or persons, with optional filtering by field name
- Get List Fields: View metadata about available fields for a specific list, with optional filtering by field name
- Get List Field Dropdown Options: View metadata about available dropdown options for a list field
- Get Entity Field Dropdown Options: View metadata about available dropdown options for a company or person field
- Create Field: Create a new field (custom column) on a list or globally on an entity
Field Values
- Upsert Entity Field Values: Create, update, or clear field values in bulk for a company or person
- Upsert List Entry Field Values: Create or update field values in bulk for a specific list entry
Field Value Changes
- Get Field Value Changes: Retrieve a paginated audit log of field value changes across the org, filterable by field, list entry, changer, action type, or change time — designed for delta sync workflows
Files
- Get Entity Files: Retrieve metadata for all files attached to a specific company, person, or opportunity
Relationship Strengths
- Get Relationship Strengths: Retrieve relationship strengths between an external person and internal team members
- Get Person Relationships: Retrieve relationship strengths (V2) between a person (internal or external) and the people they interact with, with pagination and optional filtering by interaction score
- Get Company Relationships: Retrieve relationship strengths (V2) between your team and the people associated with a company, with pagination and optional filtering by interaction score
Reminders
- Get Reminders: Get reminders with optional filtering by entity, creator, owner, completer, type, reset type, and due date
- Create Reminder: Create a new reminder
- Update Reminder: Update an existing reminder's owner, content, due date, recurrence, or completion status
- Delete Reminder: Delete a reminder by ID
Transcripts
- Get Transcript Fragments: Get dialogue fragments from a specific transcript
Auth
- Get Current User: Get information about the current user and organization
Feedback
- Send Feedback: Submit feedback about a missing capability or limitation directly to Affinity
Prerequisites
1. Setup API Key
Follow the steps in this article to obtain your Affinity API key.
⚠️ Never store your API key in
.envfiles or commit it to version control. Always store it in an environment variable as shown in the configuration examples below.
2. Install UV
Install UV Python package manager (recommended over pip for simpler dependency management)
MCP Client Configuration
Claude Setup
Claude CLI
-
Add server
Run the following command with your API key:
claude mcp add affinity-mcp \ --scope user \ --transport stdio \ --env AFFINITY_API_KEY=your_api_key_here \ -- uvx affinity-mcp
-
Verify MCP server configuration
- Run command:
claude mcp list - Ensure that the following server is connected:
affinity-mcp: uvx affinity-mcp - ✓ Connected
- Run command:
Claude Desktop
Reference: Connect Local MCP Servers to Claude Desktop
- Go to File → Settings → Developer → Edit Config and open claude_desktop_config.json.
- Run
which uvxin your terminal and copy the full path it returns. - Add the following to the config, replacing the
commandwith the path from the previous step and the API key with your own:{ "mcpServers": { "affinity-mcp": { "command": "your-uvx-path-here", "args": ["affinity-mcp"], "env": { "AFFINITY_API_KEY": "your_api_key_here" } } } }
- Restart Claude Desktop to apply the changes.
Gemini Setup
Reference: Gemini CLI MCP Configuration
Gemini CLI
-
Open settings.json
- Go to ~/.gemini
- Open settings.json
-
Add server to config file
Add the server configurations to the config file:
{ //...file contains other config objects "mcpServers": { "affinity-mcp": { "command": "uvx", "args": ["affinity-mcp"], "env": { "AFFINITY_API_KEY": "your_api_key_here" }, "trust": false } } }
-
Verify server is connected
- Run
gemini mcp listor rungemini→/mcp - You should see your server connected:
Configured MCP servers: ✓ affinity-mcp: uvx affinity-mcp (stdio) - Connected
- Run
GitHub Copilot Setup
Copilot VSCode
-
Add server through VSCode
- Open the command palette by pressing
Cmd+Shift+P(macOS) orCtrl+Shift+P(Windows/Linux). You'll see a search bar appear at the top of VSCode. - Type
>MCP: Add Serverin the search bar and select it from the dropdown. - Select Command (stdio) when prompted
- Enter
uvx affinity-mcpas the command - Enter
affinity-mcpas the Server ID - When prompted for a configuration, choose Global if you want the MCP server to be available in all workspaces, or choose a specific workspace.
- Open the command palette by pressing
-
Add API Key
- You should now be able to see a new .vscode/mcp.json file
- Open it to verify the configuration.
- Underneath
args, add your API key:
"env": { "AFFINITY_API_KEY": "your_api_key_here" }Your configuration should look like this:
{ "servers": { "affinity-mcp": { "type": "stdio", "command": "uvx", "args": ["affinity-mcp"], "env": { "AFFINITY_API_KEY": "your_api_key_here" } } }, "inputs": [] }
-
On the Copilot panel in VSCode, try asking it "What are the available tools?" and you should be able to see the available tools for Affinity MCP.
Copilot CLI
-
Run Copilot CLI
-
Add server using /mcp
- Run /mcp add
- Add the server information:
Server Name: affinity-mcp Server Type: STDIO Command: uvx affinity-mcp Environment Variables: {"AFFINITY_API_KEY": "your_api_key_here"} Tools: *
- Press CTRL + S to save.
-
Verify configurations
- Run /mcp show and you should see the server is connected.
- Open ~/.copilot/mcp_config.json to verify.
{ "mcpServers": { "affinity-mcp": { "tools": ["*"], "type": "stdio", "command": "uvx", "args": ["affinity-mcp"], "env": { "AFFINITY_API_KEY": "your_api_key_here" } } } }
Other Clients
See MCP Clients for more options.
OpenTelemetry (Optional)
The server supports OpenTelemetry tracing. To export telemetry data to an OTLP-compatible collector, set the OTEL_EXPORTER_OTLP_ENDPOINT environment variable in your LLM client config alongside your API key:
"env": {
"AFFINITY_API_KEY": "your_api_key_here",
"OTEL_EXPORTER_OTLP_ENDPOINT": "http://localhost:4317"
}
If OTEL_EXPORTER_OTLP_ENDPOINT is not set, telemetry export is disabled and the server operates normally without it.
Download Directory (Optional)
The Download Entity File tool writes downloaded files into a sandbox directory on the machine running the server. By default this is the current user's ~/Downloads folder. To write somewhere else, set the AFFINITY_DOWNLOAD_DIR environment variable to an absolute path in your LLM client config alongside your API key:
"env": {
"AFFINITY_API_KEY": "your_api_key_here",
"AFFINITY_DOWNLOAD_DIR": "/path/to/downloads"
}
Downloads are constrained to this directory: callers can request a relative subdirectory but cannot write outside the sandbox. On a remote/hosted server, files are saved on that server, not on the caller's machine.
Troubleshooting
View Server Logs
If the server isn't working as expected, you can view the logs to debug issues.
macOS (Claude Desktop): Open a terminal and run:
tail -n 20 -F ~/Library/Logs/Claude/mcp*.log
Windows (Claude Desktop):
Logs are typically located in %APPDATA%\Roaming\Claude\logs.
Common Issues
1. "Authentication failed" or 401 Errors
- Cause: The
AFFINITY_API_KEYenvironment variable is missing or invalid. - Fix: Double-check your API key. Ensure there are no extra spaces or quotes around the key.
2. "Connection refused" or Timeout
- Cause: The server cannot reach
api.affinity.co. - Fix:
- Check your internet connection.
- If you are on a corporate VPN, ensure it allows traffic to Affinity's API.
3. Changes to API key not taking effect
- Cause: Claude Desktop loads environment variables when it starts.
- Fix: You must fully quit and restart Claude Desktop.
4. "Tool not found"
- Cause: The MCP server might have crashed or failed to start.
- Fix: Check the logs (see above) for startup errors.
Security
The MCP server acts as a wrapper around the Affinity APIs and does not create a new data access mechanism. The trust boundary and access controls remain at the API layer.
Vulnerability Reporting
If you discover a security vulnerability, please refer to our Security Policy for more information about the disclosure procedure.
Software Bill of Materials (SBOM)
A Software Bill of Materials (SBOM) is automatically generated and included with each release for compliance and security auditing purposes. The SBOM provides a complete inventory of all dependencies and their versions in CycloneDX JSON format.
Access the SBOM:
Option 1: Download from PyPI website
- Visit the PyPI package page
- Navigate to the Download files tab
- Download the
.tar.gzsource distribution file - Extract and view the SBOM:
tar -xzf affinity_mcp-{version}.tar.gz cat affinity_mcp-{version}/src/affinity_mcp/affinity-mcp-{version}-sbom.json
Option 2: Use pip to download
pip download affinity-mcp --no-deps --no-binary :all:
tar -xzf affinity_mcp-*.tar.gz
cat affinity_mcp-*/src/affinity_mcp/affinity-mcp-*-sbom.json
The SBOM can be used with security scanning tools to audit dependencies and identify potential vulnerabilities.
Terms of Use
This MCP server is governed by Affinity's Terms of Use. By using this server, you agree to comply with these terms.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file affinity_mcp-0.4.0.tar.gz.
File metadata
- Download URL: affinity_mcp-0.4.0.tar.gz
- Upload date:
- Size: 140.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
619681251e22b8c1beb2f3d61278643a6b46a1c207f22d9bdd11a15767d4c596
|
|
| MD5 |
aa17fd7eee4b71d59df8a557f270ab05
|
|
| BLAKE2b-256 |
487dfdb115f6cc0af7213bb4e8c50dbb9cfafd13e6207032b59f8fcb2c021562
|
File details
Details for the file affinity_mcp-0.4.0-py3-none-any.whl.
File metadata
- Download URL: affinity_mcp-0.4.0-py3-none-any.whl
- Upload date:
- Size: 58.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
32943cb660a7df13ebb37074936f4bd2a05da15c73ffbf4bc3aedee21a83a8b6
|
|
| MD5 |
1607154e021b95445d3821916147ef30
|
|
| BLAKE2b-256 |
48cb2dc15df95c1f60dfc98aee5458a6be8c9c914c82f1111a7649e70e0c8056
|