How to integrate Affinity MCP with Codex

Affinity logo
Codex logo
divider

Introduction

Codex is one of the most popular coding harnesses out there. And MCP makes the experience even better. With Affinity MCP integration, you can draft, triage, summarise emails, and much more, all without leaving the terminal or the app, whichever you prefer.

Also integrate Affinity with

Why use Composio?

Apart from a managed and hosted MCP server, you will get:

  • CodeAct: A dedicated workbench that allows GPT to write its code to handle complex tool chaining. Reduces to-and-fro with LLMs for frequent tool calling.
  • Large tool responses: Handle them to minimise context rot.
  • Dynamic just-in-time access to 20,000 tools across 870+ other Apps for cross-app workflows. It loads the tools you need, so GPTs aren't overwhelmed by tools you don't need.

How to install Affinity MCP in Codex

Run the setup command

Run this command in your terminal to add the Composio MCP server to Codex.

Terminal

It will initiate the authentication in a browser window, authorize Codex to access your Composio account.

Composio authentication page

(Optional) Authenticate with OAuth

To authenticate manually, run the login command to open a browser window and authorize Codex to access your Composio account.

bash
codex mcp login composio

Verify the connection

Run codex mcp list to confirm Composio appears as a registered MCP server.

bash
codex mcp list

Codex App

Codex App follows the same approach as VS Code.

  1. Click ⚙️ on the bottom left → MCP Servers → + Add servers → Streamable HTTP:
  2. Fill the header and Key fields with { "x-consumer-api-key" = "ck_*******" }.
  3. The Key is the Composio API key, that you can find on connect.composio.dev
  4. Click on Authenticate and authorize Codex to your Composio account and you're all set.
Codex App MCP setup
  1. Restart and verify if it's there in .codex/config.toml
bash
[mcp_servers.composio]
url = "https://connect.composio.dev/mcp"
http_headers = { "x-consumer-api-key" = "ck_*******" }

What is the Affinity MCP server, and what's possible with it?

The Affinity MCP server is an implementation of the Model Context Protocol that connects your AI agent and assistants like Claude, Cursor, etc directly to your Affinity account. It provides structured and secure access to your deal, company, and contact data, so your agent can analyze lists, fetch opportunity details, extract company insights, and organize people or organizations on your behalf.

  • Company data extraction and analysis: Let your agent retrieve detailed company profiles, summarize list entries, and pull custom field data for deeper insights and reporting.
  • Opportunity pipeline management: Automatically fetch and review all ongoing opportunities, track changes, and surface high-priority deals for follow-up.
  • List and view organization: Ask your agent to access entries across lists or saved views, aggregating metadata and field values for efficient CRM workflows.
  • Contact and relationship intelligence: Effortlessly browse, analyze, and summarize person records, including their list memberships, activity, and custom fields.
  • Automated CRM reporting: Generate summaries, export data, and monitor changes across companies, people, and opportunities to keep your pipeline up-to-date and actionable.

Supported Tools & Triggers

Tools
Get a company s list entriesSummarize company data across all lists, including list-specific fields and metadata like creation date and author.
Get a company s listsReturns metadata for all the lists on which the given company appears.
Get all companiesAffinity api allows paginated access to company info and custom fields.
Get all list entries on a listAccess and export essential data and metadata for companies, persons, or opportunities from a list, specifying data via `fieldids` or `fieldtypes`.
Get all list entries on a saved viewUse the endpoint to access rows in a saved view with specific filters and selected fields from a web app.
Get all opportunitiesPagination through opportunities in affinity yields basic info but excludes field data.
Get all personsThe affinity api offers paginated access to person data using `fieldids` or `fieldtypes`.
Get a person s list entriesSummary: browse rows for a person in all lists, showing field data and entry metadata like creation time and author.
Get a person s listsReturns metadata for all the lists on which the given person appears.
Get a single companyRetrieve basic company info and specific field data by using `fieldids` or `fieldtypes` parameters.
Get a single opportunityGet basic details about an opportunity without field data via provided endpoints.
Get a single personUse get `/v2/persons/fields` with `fieldids` or `fieldtypes` for detailed data; basic info by default.
Get current userReturns metadata about the current user.
Get metadata on all listsReturns metadata on lists.
Get metadata on a single listReturns metadata on a single list.
Get metadata on a single list s fieldsReturns metadata on the fields available on a single list.
Get metadata on a single saved viewReturns metadata on a single saved view.
Get metadata on company fieldsReturns metadata on non-list-specific company fields.
Get metadata on person fieldsReturns metadata on non-list-specific person fields.
Get metadata on saved viewsReturns metadata on the saved views on a list.

Conclusion

You've successfully integrated Affinity with Codex using Composio's MCP server. Now you can interact with Affinity directly from your terminal, VS Code, or the Codex App using natural language commands.

Key benefits of this setup:

  • Seamless integration across CLI, VS Code, and standalone app
  • Natural language commands for Affinity operations
  • Managed authentication through Composio
  • Access to 20,000+ tools across 870+ apps for cross-app workflows
  • CodeAct workbench for complex tool chaining

Next steps:

  • Try asking Codex to perform various Affinity operations
  • Explore cross-app workflows by connecting more toolkits
  • Build automation scripts that leverage Codex's AI capabilities

How to build Affinity MCP Agent with another framework

FAQ

What are the differences in Tool Router MCP and Affinity MCP?

With a standalone Affinity MCP server, the agents and LLMs can only access a fixed set of Affinity tools tied to that server. However, with the Composio Tool Router, agents can dynamically load tools from Affinity and many other apps based on the task at hand, all through a single MCP endpoint.

Can I use Tool Router MCP with Codex?

Yes, you can. Codex fully supports MCP integration. You get structured tool calling, message history handling, and model orchestration while Tool Router takes care of discovering and serving the right Affinity tools.

Can I manage the permissions and scopes for Affinity while using Tool Router?

Yes, absolutely. You can configure which Affinity scopes and actions are allowed when connecting your account to Composio. You can also bring your own OAuth credentials or API configuration so you keep full control over what the agent can do.

How safe is my data with Composio Tool Router?

All sensitive data such as tokens, keys, and configuration is fully encrypted at rest and in transit. Composio is SOC 2 Type 2 compliant and follows strict security practices so your Affinity data and credentials are handled as safely as possible.

Used by agents from

Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai

Never worry about agent reliability

We handle tool reliability, observability, and security so you never have to second-guess an agent action.