Connects Squad's product management platform to Claude or any MCP client via OAuth, exposing 30+ tools for managing opportunities, solutions, goals, feedback, and knowledge. You get full CRUD on each entity type, plus relationship management between them, semantic search across your workspace, and strategic views like OST mapping and roadmaps. The server mints JWTs from OAuth tokens and proxies requests to Squad's API with user isolation. Reach for this when you want to research product ideas, build roadmaps, or query customer insights without leaving your AI conversation. Authentication happens through PropelAuth with automatic OAuth discovery, and there's a companion NPM package if you want to use the tools programmatically in Node apps.
Public tool metadata for what this MCP can expose to an agent.
list_workspacesList all organisations and workspaces available to the current user. Use this to see what workspaces you can switch to.List all organisations and workspaces available to the current user. Use this to see what workspaces you can switch to.
No parameter schema in public metadata yet.
select_workspaceSelect which organisation and workspace to use for subsequent operations. Required when user has access to multiple orgs/workspaces.2 paramsSelect which organisation and workspace to use for subsequent operations. Required when user has access to multiple orgs/workspaces.
orgIdstringworkspaceIdstringget_workspaceGet details of the current workspace. Workspaces contain the project name, detailed description, and mission statement.Get details of the current workspace. Workspaces contain the project name, detailed description, and mission statement.
No parameter schema in public metadata yet.
update_workspaceUpdate the current workspace's details such as name, description, mission statement.5 paramsUpdate the current workspace's details such as name, description, mission statement.
namestringlogoUrlstringdescriptionstringhomepageUrlstringmissionStatementstringcreate_opportunityCreate a new opportunity. An opportunity is a detailed problem statement identified for the organisation. It doesn't have any solutionising and simply captures an opportunity for the organisation.2 paramsCreate a new opportunity. An opportunity is a detailed problem statement identified for the organisation. It doesn't have any solutionising and simply captures an opportunity for the organisation.
titlestringdescriptionstringlist_opportunitiesList all opportunities in the workspace. Opportunities are problem statements identified for the organisation.List all opportunities in the workspace. Opportunities are problem statements identified for the organisation.
No parameter schema in public metadata yet.
get_opportunityGet details of a specific opportunity by ID. Opportunities are problem statements identified for the organisation.2 paramsGet details of a specific opportunity by ID. Opportunities are problem statements identified for the organisation.
opportunityIdstringrelationshipsarrayupdate_opportunityUpdate an existing opportunity's details such as title, description, or status.4 paramsUpdate an existing opportunity's details such as title, description, or status.
titlestringstatusstringNew · Solved · Planned · InProgressdescriptionstringopportunityIdstringdelete_opportunityDelete an opportunity by ID.1 paramsDelete an opportunity by ID.
opportunityIdstringgenerate_solutionsStart the process of generating solutions for an opportunity. This will use Squad AI to generate new potential solutions for a given opportunity.2 paramsStart the process of generating solutions for an opportunity. This will use Squad AI to generate new potential solutions for a given opportunity.
promptstringopportunityIdstringmanage_opportunity_relationshipsAdd or remove relationships between an opportunity and other entities (solutions, outcomes, or insights).5 paramsAdd or remove relationships between an opportunity and other entities (solutions, outcomes, or insights).
actionstringadd · removeinsightIdsarrayoutcomeIdsarraysolutionIdsarrayopportunityIdstringcreate_solutionCreate a new solution. A solution is a proposed approach to address an opportunity. The 'prd' field should contain the complete detailed specification, while 'description' should be a brief summary for AI context.6 paramsCreate a new solution. A solution is a proposed approach to address an opportunity. The 'prd' field should contain the complete detailed specification, while 'description' should be a brief summary for AI context.
prdstringconsarrayprosarraytitlestringstatusstringNew · InDevelopment · Planned · Complete · Cancelled · Backlogdescriptionstringlist_solutionsList all solutions in the workspace. Solutions are proposed approaches to address opportunities.2 paramsList all solutions in the workspace. Solutions are proposed approaches to address opportunities.
filterstringroadmap · recommendedhorizonstringnow · next · laterget_solutionGet details of a specific solution by ID.2 paramsGet details of a specific solution by ID.
solutionIdstringrelationshipsarrayedit_solution_prdEdit the PRD (Product Requirements Document) of a solution. Use this to write or rewrite the detailed specification, implementation plan, and requirements for a solution.2 paramsEdit the PRD (Product Requirements Document) of a solution. Use this to write or rewrite the detailed specification, implementation plan, and requirements for a solution.
prdstringsolutionIdstringupdate_solutionUpdate a solution's metadata (title, description, pros, cons, status, horizon). To edit the PRD content, use edit_solution_prd. To change priority, use prioritise_solutions. To move a solution between roadmap horizons, set the horizon field.8 paramsUpdate a solution's metadata (title, description, pros, cons, status, horizon). To edit the PRD content, use edit_solution_prd. To change priority, use prioritise_solutions. To move a solution between roadmap horizons, set the horizon field.
prdstringconsarrayprosarraytitlestringstatusstringNew · InDevelopment · Planned · Complete · Cancelled · Backloghorizonstringnow · next · latersolutionIdstringdescriptionstringdelete_solutionDelete a solution by ID.1 paramsDelete a solution by ID.
solutionIdstringmanage_solution_relationshipsAdd or remove relationships between a solution and other entities (opportunities).3 paramsAdd or remove relationships between a solution and other entities (opportunities).
actionstringadd · removesolutionIdstringopportunityIdsarrayprioritise_solutionsReorder the priority of solutions by moving them before a specified solution. This is the only way to change solution priority/ordering in the workspace.2 paramsReorder the priority of solutions by moving them before a specified solution. This is the only way to change solution priority/ordering in the workspace.
beforeIdvaluesolutionIdsarraycreate_goalCreate a new goal. A goal is a business objective that the organization aims to achieve.7 paramsCreate a new goal. A goal is a business objective that the organization aims to achieve.
titlestringtrendnumberownerIdstringprioritynumberdescriptionstringhideContentbooleananalyticEventsarraylist_goalsList all goals in the workspace. Goals are business objectives that the organization aims to achieve.List all goals in the workspace. Goals are business objectives that the organization aims to achieve.
No parameter schema in public metadata yet.
get_goalGet details of a specific goal by ID. Goals are business objectives that the organization aims to achieve.2 paramsGet details of a specific goal by ID. Goals are business objectives that the organization aims to achieve.
goalIdstringrelationshipsarrayupdate_goalUpdate an existing goal's details.8 paramsUpdate an existing goal's details.
titlestringtrendnumbergoalIdstringownerIdstringprioritynumberdescriptionstringhideContentbooleananalyticEventsarraydelete_goalDelete a goal by ID.1 paramsDelete a goal by ID.
goalIdstringmanage_goal_relationshipsAdd or remove relationships between a goal and opportunities for the business.3 paramsAdd or remove relationships between a goal and opportunities for the business.
actionstringadd · removegoalIdstringopportunityIdsarraycreate_knowledgeCreate a new knowledge entry. Knowledge entries are text documents that can be used as references or information sources.3 paramsCreate a new knowledge entry. Knowledge entries are text documents that can be used as references or information sources.
titlestringcontentstringdescriptionstringlist_knowledgeList all knowledge entries in the workspace. Knowledge entries are text documents that can be used as references or information sources. List only shows the available items and a short description for the actual knowledge use the get by id call.List all knowledge entries in the workspace. Knowledge entries are text documents that can be used as references or information sources. List only shows the available items and a short description for the actual knowledge use the get by id call.
No parameter schema in public metadata yet.
get_knowledgeGet details of a specific knowledge entry by ID. Knowledge entries are text documents that can be used as references or information sources.1 paramsGet details of a specific knowledge entry by ID. Knowledge entries are text documents that can be used as references or information sources.
knowledgeIdstringdelete_knowledgeDelete a knowledge entry by ID.1 paramsDelete a knowledge entry by ID.
knowledgeIdstringcreate_feedbackCreate a new feedback entry. Feedback represents raw, unprocessed feedback from users that can later be analyzed and converted into insights.5 paramsCreate a new feedback entry. Feedback represents raw, unprocessed feedback from users that can later be analyzed and converted into insights.
sourcestringcontentstringsentimentScorenumbersentimentCategorystringPositive · Neutral · NegativesentimentConfidencenumberlist_feedbackList all feedback entries in the workspace. Feedback entries are raw customer feedback that can be processed into insights.List all feedback entries in the workspace. Feedback entries are raw customer feedback that can be processed into insights.
No parameter schema in public metadata yet.
get_feedbackGet details of a specific feedback entry by ID. Feedback entries are raw customer feedback.2 paramsGet details of a specific feedback entry by ID. Feedback entries are raw customer feedback.
feedbackIdstringrelationshipsstringinsightsdelete_feedbackDelete a feedback entry by ID.1 paramsDelete a feedback entry by ID.
feedbackIdstringcreate_insightCreate a new insight entry. An insight is customer-generated feedback about your product, often from reviews, surveys, or questionnaires.3 paramsCreate a new insight entry. An insight is customer-generated feedback about your product, often from reviews, surveys, or questionnaires.
typestringFeedback · Bug · FeatureRequesttitlestringdescriptionstringlist_insightsList all insights for the workspace. These insights are gathered from various sources, created by customers, and help understand how to improve the business.List all insights for the workspace. These insights are gathered from various sources, created by customers, and help understand how to improve the business.
No parameter schema in public metadata yet.
get_insightGet details of a specific insight entry by ID. Insight entries are text documents that can be used as references or information sources.2 paramsGet details of a specific insight entry by ID. Insight entries are text documents that can be used as references or information sources.
insightIdstringrelationshipsarraydelete_insightDelete an insight entry by ID.1 paramsDelete an insight entry by ID.
insightIdstringsimilarity_searchPerform a semantic similarity search across the workspace. This searches through knowledge documents, feedback insights, opportunities, and solutions to find content similar to your query. Each result will contain a nodeId or an id. These can be used to retrieve the full conte...2 paramsPerform a semantic similarity search across the workspace. This searches through knowledge documents, feedback insights, opportunities, and solutions to find content similar to your query. Each result will contain a nodeId or an id. These can be used to retrieve the full conte...
querystringfiltersarrayview_strategy_contextShow an entity in its product strategy tree — displays the entity, its parent chain, and direct children in a rich visual UI. ALWAYS use this tool when the user asks about strategy, prioritisation, reasoning, context, positioning, or 'why' behind any entity. Use it when the us...2 paramsShow an entity in its product strategy tree — displays the entity, its parent chain, and direct children in a rich visual UI. ALWAYS use this tool when the user asks about strategy, prioritisation, reasoning, context, positioning, or 'why' behind any entity. Use it when the us...
entityIdstringentityTypestringworkspace · goal · opportunity · solution · insight · feedbackview_roadmapShow the product roadmap — solutions organized by time horizon (Now/Next/Later) with goal context. Use this when the user asks about the roadmap, what's planned, what's coming next, priorities, or wants to see an overview of solutions being built.3 paramsShow the product roadmap — solutions organized by time horizon (Now/Next/Later) with goal context. Use this when the user asks about the roadmap, what's planned, what's coming next, priorities, or wants to see an overview of solutions being built.
goalIdstringshowResolvedbooleanstatusFilterarrayA remote MCP server that brings Squad — the AI-powered product discovery and strategy platform — directly into your AI workflows. Connect Squad to Claude, ChatGPT, or any MCP-compatible AI assistant to research, ideate, and plan products without context switching.
Connect Squad to your AI assistant in seconds:
Claude Code:
claude mcp add --transport http squad https://mcp.meetsquad.ai/mcp
On first use, you'll be prompted to authenticate via OAuth in your browser.
Claude Connectors:
ChatGPT:
Other MCP Clients:
Connect using https://mcp.meetsquad.ai/mcp - OAuth configuration is automatically discovered via the server's .well-known/oauth-authorization-server endpoint.
See USAGE_EXAMPLES.md for detailed real-world examples including:
Each example shows the actual user prompt, which tools get called behind the scenes, and the expected output based on real Squad data.
The Squad MCP server provides 30+ tools across 9 categories:
| Category | Tools | Purpose |
|---|---|---|
| Opportunities | list_opportunities, get_opportunity, create_opportunity, update_opportunity, delete_opportunity, generate_solutions, manage_opportunity_relationships | Discover and refine product opportunities |
| Solutions | list_solutions, get_solution, create_solution, update_solution, delete_solution, manage_solution_relationships, prioritise_solutions | Generate and iterate on solution ideas |
| Goals | list_goals, get_goal, create_goal, update_goal, delete_goal, manage_goal_relationships | Define and track business objectives |
| Knowledge | list_knowledge, get_knowledge, create_knowledge, delete_knowledge | Store research, references, and insights |
| Feedback | list_feedback, get_feedback, create_feedback, delete_feedback | Manage customer and stakeholder feedback |
| Insights | list_insights, get_insight, create_insight, delete_insight | Track customer insights and feature requests |
| Workspace | list_workspaces, select_workspace, get_workspace, update_workspace | Configure workspace settings |
| Search | similarity_search | Semantic search across all entities |
| Views | view_strategy_context, view_roadmap | Rich visual strategy and roadmap widgets |
All tools include:
readOnlyHint / destructiveHint)┌─────────────┐ OAuth ┌──────────────┐
│ Claude / │ ◄────────────────────► │ PropelAuth │
│ ChatGPT │ (Authentication) │ (IdP) │
└─────────────┘ └──────────────┘
│
│ HTTPS + Bearer Token
▼
┌──────────────────────────────────────────────┐
│ Squad MCP Server │
│ ┌────────────────────────────────────────┐ │
│ │ OAuth Middleware → Validate Token │ │
│ │ JWT Minting → Service Credentials │ │
│ │ Session Store → Manage State │ │
│ │ MCP Handler → Execute Tools │ │
│ └────────────────────────────────────────┘ │
└──────────────────────────────────────────────┘
│
│ Squad API Calls (minted JWT)
▼
┌──────────────┐
│ Squad API │
└──────────────┘
For programmatic access to Squad tools in your Node.js applications:
npm install @squadai/tools
import { tools as squadTools } from "@squadai/tools";
// Use with Vercel AI SDK
const result = await generateText({
model: anthropic("claude-3-5-sonnet-20241022"),
tools: squadTools({
jwt: "YOUR_JWT_TOKEN",
orgId: "org-123",
workspaceId: "ws-456",
}),
prompt: "List my current product opportunities",
});
This repository contains the source code for the Squad MCP remote server.
flake.nix)# Clone repository
git clone https://github.com/the-basilisk-ai/squad-mcp.git
cd squad-mcp
# Install dependencies
yarn install
# Configure environment
cp .env.example .env
# Edit .env with your PropelAuth credentials
# Start development server with hot reload
yarn dev
# Server available at http://localhost:3232
yarn build # Compile TypeScript
yarn dev # Start dev server with hot reload
yarn start # Start production server
yarn test # Run unit tests (vitest)
yarn format # Lint with biome
yarn format:fix # Auto-fix lint issues
yarn openapi:squad # Regenerate API client from OpenAPI spec
yarn storybook # Run Storybook for widget development
# Check health
curl http://localhost:3232/health
# Check OAuth discovery
curl http://localhost:3232/.well-known/oauth-authorization-server
# Test with MCP Inspector
npx @modelcontextprotocol/inspector
# Then connect to http://localhost:3232/mcp
squad-mcp/
├── index.ts # MCP server entry point with OAuth
├── server.json # MCP registry metadata
├── src/
│ ├── client.ts # MCP client export
│ ├── helpers/
│ │ ├── config.ts # Environment configuration
│ │ ├── getUser.ts # OAuth context + workspace selection
│ │ └── mintToken.ts # JWT minting + per-user cache
│ ├── lib/
│ │ ├── logger.ts # Structured logging
│ │ └── clients/
│ │ ├── squad.ts # Squad API client factory
│ │ └── middleware/ # Bearer token middleware
│ └── tools/ # Tool implementations
│ ├── opportunity.ts
│ ├── solution.ts
│ ├── goal.ts
│ ├── knowledge.ts
│ ├── feedback.ts
│ ├── insight.ts
│ ├── workspace.ts
│ ├── search.ts
│ ├── views.ts
│ └── helpers.ts
├── resources/ # React widget components
│ ├── view-strategy-context/
│ └── view-roadmap/
├── railway.toml # Railway deployment config
└── .env.example # Environment template
This is a hosted service maintained by Squad. Users connect via OAuth - no self-hosting required.
Architecture Notes (for contributors):
Need help with the Squad MCP server?
Contributions welcome! Pre-commit hooks run biome lint and vitest automatically. Please ensure:
yarn format passes (biome lint)yarn build compiles without errorsyarn test passesMIT