loading…
Search for a command to run...
loading…
Model Context Protocol server for the Apideck Unified API. Connect any MCP-compatible agent framework to 100+ accounting systems, HRIS platforms, file storage p
Model Context Protocol server for the Apideck Unified API. Connect any MCP-compatible agent framework to 100+ accounting systems, HRIS platforms, file storage providers, and more through one integration. More information https://www.apideck.com/mcp-server
npm version MCP Registry Glama score CI License: MIT
Model Context Protocol server for the Apideck Unified API. Connect any MCP-compatible agent framework to 200+ connectors — accounting systems, HRIS platforms, file storage providers, and more — through one integration.
Generated from Apideck's OpenAPI spec using Speakeasy.
330 tools across 10 unified APIs:
| API | Tools | Coverage |
|---|---|---|
| Accounting | 143 | Invoices, bills, payments, suppliers, customers, journal entries, ledger accounts, purchase orders, tax rates, P&L, balance sheet, and more |
| CRM | 50 | Companies, contacts, leads, opportunities, pipelines, notes, activities, users |
| File Storage | 32 | Files, folders, drives, shared links, upload sessions |
| HRIS | 25 | Employees, companies, departments, payrolls, time-off requests |
| Vault | 23 | Connections, consumers, sessions, custom mappings, logs |
| ATS | 15 | Applicants, applications, jobs |
| Issue Tracking | 15 | Collections, tickets, users, tags, comments |
| Connector | 8 | APIs, connectors, resources, coverage metadata |
| Ecommerce | 7 | Customers, orders, products, stores |
| Webhook | 6 | Webhook subscriptions, logs |
| Proxy | 6 | GET, POST, PUT, PATCH, DELETE, OPTIONS |
On top of the 330 endpoint tools, the server ships intent-grouped workflows — single MCP tools that orchestrate 2-4 underlying calls behind a high-level intent. Saves agents the round-trips and the field-plumbing they routinely get wrong (AR vs AP, allocation arrays, customer vs supplier refs).
| Tool | What it does | Calls |
|---|---|---|
apideck-month-end-close-check |
One-shot read-only snapshot — aged creditors, aged debtors, balance sheet, P&L in parallel. Partial results when some reports aren't supported by the connector. | 4 |
apideck-pay-bill |
Pays a vendor bill: looks up the bill, then writes a bill-payment with the right allocation back to it. AP. | 2 |
apideck-receive-customer-payment |
Records a customer payment against an invoice. AR mirror of pay-bill. | 2 |
apideck-onboard-employee |
Converts a hired ATS applicant into an HRIS employee, optionally moves the applicant to a Hired stage. Crosses two unified APIs. | 2-3 |
Workflows propagate Vault OAuth elicitations (so a missing connection still hands the user a consent URL) and surface upstream errors with failingStep so the agent knows which leg broke. See docs/authoring-workflow-tools.md for the pattern.
The MCP server is live at:
https://mcp.apideck.dev/mcp
Pass Apideck credentials via headers:
| Header | Description |
|---|---|
x-apideck-api-key |
Your Apideck API key |
x-apideck-consumer-id |
The end-user/customer ID in your app |
x-apideck-app-id |
Your Apideck application ID |
# OpenAI Agents SDK (remote)
from agents import Agent
from agents.mcp import MCPServerHTTP
agent = Agent(
name="AP Agent",
mcp_servers=[MCPServerHTTP(
url="https://mcp.apideck.dev/mcp",
headers={
"x-apideck-api-key": "...",
"x-apideck-consumer-id": "...",
"x-apideck-app-id": "..."
}
)]
)
# Pydantic AI (remote)
from pydantic_ai import Agent
from pydantic_ai.mcp import MCPServerHTTP
agent = Agent("anthropic:claude-sonnet-4-5", mcp_servers=[
MCPServerHTTP(
url="https://mcp.apideck.dev/mcp",
headers={
"x-apideck-api-key": "...",
"x-apideck-consumer-id": "...",
"x-apideck-app-id": "..."
}
)
])
# LangChain / LangGraph (remote)
from langchain_mcp_adapters.client import MultiServerMCPClient
client = MultiServerMCPClient({
"apideck": {
"url": "https://mcp.apideck.dev/mcp",
"transport": "streamable_http",
"headers": {
"x-apideck-api-key": "...",
"x-apideck-consumer-id": "...",
"x-apideck-app-id": "..."
}
}
})
tools = await client.get_tools()
Apideck ships a Claude plugin bundle (.mcpb — Anthropic's Model Context Protocol Bundle format). Drop it into Claude Desktop and you get the full server (330 endpoint tools + 4 workflow tools) with API key / consumer ID / app ID prompted via the standard plugin UI.
# Build the bundle locally:
npm run mcpb:build # → mcp-server.mcpb (~590 KB)
Or grab a prebuilt bundle from the latest GitHub Release. Open it with Claude Desktop's plugin installer; Claude Desktop reads manifest.json to wire credentials and spawn the server.
Add to your MCP client config:
{
"mcpServers": {
"apideck": {
"url": "https://mcp.apideck.dev/mcp",
"headers": {
"x-apideck-api-key": "YOUR_API_KEY",
"x-apideck-consumer-id": "YOUR_CONSUMER_ID",
"x-apideck-app-id": "YOUR_APP_ID"
}
}
}
}
npm install
# Dynamic mode (default — progressive discovery, 4 meta-tools, ~1,300 tokens)
node bin/mcp-server.js start --api-key "$APIDECK_API_KEY" --consumer-id "$APIDECK_CONSUMER_ID" --app-id "$APIDECK_APP_ID"
# Static mode (all 330 tools)
node bin/mcp-server.js start --api-key "$APIDECK_API_KEY" --consumer-id "$APIDECK_CONSUMER_ID" --app-id "$APIDECK_APP_ID" --mode static
# Read-only tools only
node bin/mcp-server.js start --api-key "$APIDECK_API_KEY" --consumer-id "$APIDECK_CONSUMER_ID" --app-id "$APIDECK_APP_ID" --scope read
# OpenAI Agents SDK (local stdio)
from agents import Agent
from agents.mcp import MCPServerStdio
mcp = MCPServerStdio(name="apideck", params={
"command": "node",
"args": ["bin/mcp-server.js", "start", "--mode", "dynamic"],
"env": {
"APIDECK_API_KEY": "...",
"APIDECK_CONSUMER_ID": "...",
"APIDECK_APP_ID": "..."
}
})
agent = Agent(name="AP Agent", mcp_servers=[mcp])
# Pydantic AI (local stdio)
from pydantic_ai import Agent
from pydantic_ai.mcp import MCPServerStdio
agent = Agent("anthropic:claude-sonnet-4-5", mcp_servers=[
MCPServerStdio("node", [
"bin/mcp-server.js", "start", "--mode", "dynamic",
"--api-key", "...", "--consumer-id", "...", "--app-id", "..."
])
])
| Mode | Tools exposed | Initial tokens | Best for |
|---|---|---|---|
dynamic (default) |
4 meta-tools: list_tools, describe_tool_input, execute_tool, list_scopes |
~1,300 | General-purpose agents, token-sensitive contexts |
static |
All 330 tools | ~35-55K | Focused agents doing specific operations |
In dynamic mode, agents discover tools progressively:
list_tools({"search_terms": ["invoices"]})
→ accounting-invoices-list, accounting-invoices-create, accounting-invoices-get, ...
describe_tool_input({"tool_names": ["accounting-invoices-list"]})
→ Full JSON Schema with all parameters
execute_tool({"tool_name": "accounting-invoices-list", "input": {"request": {"limit": 10}}})
→ Invoice data from the connected accounting system
The generate-overlay.py script controls which Apideck APIs are included:
# Default: all unified APIs except SMS (330 tools)
python generate-overlay.py accounting,ats,connector,crm,ecommerce,fileStorage,hris,issueTracking,proxy,vault,webhook
# Accounting only (143 tools)
python generate-overlay.py accounting
# Custom selection
python generate-overlay.py accounting,hris,vault
# All APIs including SMS (~334 tools)
python generate-overlay.py all
# Then regenerate + apply fixes:
speakeasy run
./post-generate.sh
The MCP server is generated from Apideck's Speakeasy-optimized OpenAPI spec. To regenerate after spec changes:
# 1. Optionally reconfigure APIs
python generate-overlay.py accounting,fileStorage,hris,vault,proxy
# 2. Regenerate
speakeasy run
# 3. Apply post-generation fixes (Zod transforms fix + wrangler.toml)
./post-generate.sh
# 4. Run tests
node bin/mcp-server.js serve --port 4567 --mode dynamic --log-level error &
npx tsx test/mcp-server.test.ts
Tools are annotated with scopes for fine-grained control:
| Scope | HTTP methods | Flag |
|---|---|---|
read |
GET, HEAD | --scope read |
write |
POST, PUT, PATCH | --scope write |
destructive |
DELETE | --scope destructive |
# Local
node bin/mcp-server.js serve --port 4567 --mode dynamic --log-level error &
npx tsx test/mcp-server.test.ts
# Remote
MCP_URL=https://mcp.apideck.dev/mcp npx tsx test/mcp-server.test.ts
The repo ships a .mcp.json with two project-scope MCP servers that Claude Code / Cursor / Windsurf pick up automatically:
| Server | Purpose |
|---|---|
aikido |
Scans AI-generated code for vulnerabilities + hardcoded secrets. Needs AIKIDO_API_KEY in your shell — get one. |
apideck-local |
Runs this server from the local build (bin/mcp-server.js start) so you can exercise your own changes through an agent. Uses the standard APIDECK_* env vars. |
No credentials are committed — each entry reads its token from the environment.
MIT
Apideck: The Apideck OpenAPI Spec: SDK Optimized
For more information about the API: Apideck Developer Docs
[!TIP] To finish publishing your MCP Server to npm and others you must run your first generation action.
Install the MCP server as a Desktop Extension using the pre-built mcp-server.mcpb file:
Simply drag and drop the mcp-server.mcpb file onto Claude Desktop to install the extension.
The MCP bundle package includes the MCP server and all necessary configuration. Once installed, the server will be available without additional setup.
[!NOTE] MCP bundles provide a streamlined way to package and distribute MCP servers. Learn more about Desktop Extensions.
Or manually:
{
"command": "npx",
"args": [
"@apideck/mcp",
"start",
"--api-key",
"",
"--consumer-id",
"",
"--app-id",
""
]
}
claude mcp add ApideckMcp -- npx -y @apideck/mcp start --api-key --consumer-id --app-id
gemini mcp add ApideckMcp -- npx -y @apideck/mcp start --api-key --consumer-id --app-id
Refer to Official Windsurf documentation for latest information
Manage MCPs. (To Manage MCPs you should be signed in with a Windsurf Account)View raw config to open up the mcp configuration file.{
"command": "npx",
"args": [
"@apideck/mcp",
"start",
"--api-key",
"",
"--consumer-id",
"",
"--app-id",
""
]
}
Or manually:
Refer to Official VS Code documentation for latest information
MCP: Open User Configuration. This should open mcp.json file{
"command": "npx",
"args": [
"@apideck/mcp",
"start",
"--api-key",
"",
"--consumer-id",
"",
"--app-id",
""
]
}
npx @apideck/mcp start --api-key --consumer-id --app-id
For a full list of server arguments, run:
npx @apideck/mcp --help
MCP servers with many tools can bloat LLM context windows, leading to increased token usage and tool confusion. Dynamic mode solves this by exposing only a small set of meta-tools that let agents progressively discover and invoke tools on demand.
To enable dynamic mode, pass the --mode dynamic flag when starting your server:
{
"mcpServers": {
"ApideckMcp": {
"command": "npx",
"args": ["@apideck/mcp", "start", "--mode", "dynamic"],
// ... other server arguments
}
}
}
In dynamic mode, the server registers only the following meta-tools instead of every individual tool:
list_tools: Lists all available tools with their names and descriptions.describe_tool_input: Returns the input schema for one or more tools by name.execute_tool: Executes a tool by name with its arguments.list_scopes: Lists the scopes available on the server.This approach significantly reduces the number of tokens sent to the LLM on each request, which is especially useful for servers with a large number of tools.
You can combine dynamic mode with scope and tool filters:
{
"mcpServers": {
"ApideckMcp": {
"command": "npx",
"args": ["@apideck/mcp", "start", "--mode", "dynamic", "--scope", "destructive"],
// ... other server arguments
}
}
}
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"apideck-mcp": {
"command": "npx",
"args": []
}
}
}