Cin7 Core Meta MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Cin7 Core Meta MCP ServerList all available API endpoints"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Cin7 Core Meta MCP Server
This is a Model Context Protocol (MCP) server for the Cin7 Core (DEAR) API. Instead of exposing one tool per Cin7 endpoint, this server exposes three generic API-walking tools plus a structured bug-report tool. The model finds what it needs at runtime: list endpoints → read an endpoint's schema → invoke it.
It's a sibling to mcp-cin7-core — that server ships hand-curated tools (cin7_products, cin7_create_purchase_order, …) for common operations. This one covers the full Cin7 Core API surface (Brands, Categories, Carriers, Chart of Accounts, Disassembly, Finished Goods, anything Cin7 ships) with a tiny tool list that doesn't grow as the API grows. Both servers can be installed in the same client; they're complementary.
Features
Four MCP tools that cover the full Cin7 Core REST API surface
API-walking pattern (
list → describe → invoke) keeps the tool list tinyRequest validation against a vendored API Blueprint spec — unknown endpoints, wrong methods, missing required params, and type mismatches are caught before any network call
Rate-limit passthrough — Cin7's
X-RateLimit-Remainingheader is surfaced so the model can self-throttleStructured bug-report tool — appends
ISSUE_REPORT <json>to both a controlled file and stderrScaleKit OAuth 2.0 / Streamable HTTP transport for remote deployments
Stdio transport for local Claude Desktop integration
MCP protocol compliance
Related MCP server: Skulabs MCP Server
Prerequisites
Python 3.10+
uv package manager
A Cin7 Core (DEAR) account with API access — get your
AccountIDandApplication Keyfrom Integrations → API
Docs and Links
docs/tools.md— full reference for the four MCP toolsdocs/spec_refresh.md— how/when to refresh the vendored API Blueprint spec
Setup
Get Cin7 Core API credentials
Log in to Cin7 Core (DEAR)
Navigate to Integrations → API
Copy the AccountID and create/copy the Application Key
Authentication
There are 2 modes of running the Cin7 Core Meta MCP server:
1. Streamable HTTP with OAuth (Recommended for production)
This mode runs the server as a web service with OAuth 2.0 authentication via ScaleKit. This is the recommended approach for shared or remote deployments, including connecting via Claude Desktop's remote MCP connector.
Required environment variables:
CIN7_ACCOUNT_ID- Your Cin7 AccountIDCIN7_API_KEY- Your Cin7 Application KeySCALEKIT_ENVIRONMENT_URL- ScaleKit environment URL (e.g.,https://yourapp.scalekit.com)SCALEKIT_CLIENT_ID- ScaleKit application client IDSCALEKIT_CLIENT_SECRET- ScaleKit application client secretSCALEKIT_RESOURCE_ID- ScaleKit resource identifier (e.g.,res_xxx)SCALEKIT_INTERCEPTOR_SECRET- Secret for verifying interceptor payloadsSERVER_URL- Your MCP server's public URL (e.g.,https://your-server.example.com)
Optional:
ALLOWED_EMAILS- Comma-separated list of allowed email addresses (leave empty to allow all authenticated users)CIN7_BASE_URL- Override the Cin7 base URL (defaulthttps://inventory.dearsystems.com/ExternalApi/v2/)ISSUE_REPORT_PATH- Wherereport_issueappends itsISSUE_REPORT <json>lines (default./data/issue_reports.log)MCP_LOG_LEVEL- Logging level (defaultINFO)MCP_LOG_FILE- Enable file logging with rotation
Running the server:
uv run python -m cin7_meta.server_httpEndpoints:
GET /health- Health check (no auth required)GET /.well-known/oauth-protected-resource- OAuth discovery (no auth required)POST /mcp- MCP endpoint (requires OAuth 2.0 Bearer token)
Connecting from Claude Desktop (remote):
Deploy your server (e.g., to Render — see
render.yaml)Open Claude Desktop > Settings > Connectors
Click "Add Connector" and enter your server URL:
https://your-server.com/mcpClaude will auto-discover OAuth configuration
Click "Authorize" and log in
See CLAUDE.md for detailed ScaleKit setup and interceptor configuration.
2. Stdio Transport (Local development)
This mode runs the server locally using stdio transport for direct integration with Claude Desktop. No OAuth configuration needed — Cin7 credentials are used directly.
Required environment variables:
CIN7_ACCOUNT_IDCIN7_API_KEY
Optional: CIN7_BASE_URL, ISSUE_REPORT_PATH, MCP_LOG_LEVEL, MCP_LOG_FILE.
Claude Desktop configuration:
Add this to your claude_desktop_config.json:
{
"mcpServers": {
"cin7-meta": {
"command": "uv",
"args": [
"--directory",
"/absolute/path/to/mcp-cin7-meta",
"run",
"python",
"-m",
"cin7_meta.server_stdio"
],
"env": {
"CIN7_ACCOUNT_ID": "your-account-id",
"CIN7_API_KEY": "your-application-key"
}
}
}
}Replace /absolute/path/to/mcp-cin7-meta with the actual path to your clone of this repository.
If you're running both servers together, give them distinct names (e.g. cin7-core for the curated server and cin7-meta for this one) so Claude lists their tools separately.
Installation
# Create virtual environment and install dependencies
uv venv
uv pip install -e .
# Quick import check
uv run python -c "import cin7_meta.server; print('OK')"Vendor the API Blueprint spec (one-time)
This server validates requests against a vendored API Blueprint that ships at cin7_meta/spec/cin7_v2.apib, plus a derived normalized JSON catalog at cin7_meta/spec/cin7_v2.json. A fresh clone won't have these — generate them:
uv run python scripts/refresh_spec.pyRe-run any time the Cin7 API changes or you want to pick up new endpoints. See docs/spec_refresh.md for the full workflow.
Testing with MCP Inspector
# Start the HTTP server
uv run python -m cin7_meta.server_http
# In another terminal, open MCP Inspector
npx @modelcontextprotocol/inspector http://localhost:3000/mcpAvailable MCP Tools
API walking:
list_api_endpoints(keyword, methods, limit)— Ranked keyword search across endpoint paths, summaries, groups, and parameter names. Returns{"results": [...], "total": int, "truncated": bool}.get_api_endpoint_schema(method, path)— Return the full schema for one endpoint: query params (with types and defaults), request body schema, response schema, and JSON examples.
Execution:
invoke_api_endpoint(method, path, query_params, body)— Validate, then execute, an arbitrary Cin7 Core API call. Validation errors (unknown endpoint, wrong method, missing required param, type mismatch) are returned without a network call. Returns{"status", "data", "rate_limit_remaining"}— userate_limit_remainingfor self-throttling.
Issue reporting:
report_issue(summary, tool_name, tool_arguments, observed_behavior, expected_behavior, ...)— File a structured bug report when a tool doesn't behave as expected. Each report is appended as oneISSUE_REPORT <json>line todata/issue_reports.logand emitted on stderr in the same format, so reports survive even on hosts with ephemeral filesystems (Render's log stream captures the stderr line). Returns areport_idthe model can quote in follow-ups.
For detailed signatures, examples, and return shapes, see docs/tools.md.
For the underlying Cin7 Core API documentation, refer to the Cin7 Core API Reference.
For Developers
Running Tests
# Full test suite
uv run pytest -v
# Quick pass/fail check
uv run pytest --tb=short
# Specific test file
uv run pytest tests/test_invoke_api_endpoint.py -vContributing — Test-Driven Development
This project follows a strict test-driven development (TDD) workflow. Every utility and tool was implemented test-first:
Add fixtures to
tests/fixtures/— either using the small hand-rolledmini_spec.py(fast, deterministic) or the vendoredcin7_v2.jsonfor contract testsWrite failing tests — unit tests against the mini spec, contract tests against the real vendored spec where relevant
Implement to make the tests pass
No new code should be merged without corresponding test coverage. See CLAUDE.md for detailed test patterns, the mock_cin7 fixture, and the EXPECTED_TOOLS registration assertion.
Architecture
cin7_client.py- Async REST client for the Cin7 Core API with retry and error handling (ported frommcp-cin7-core)spec_loader.py- Loads the vendored normalized JSON catalog at startup, builds the in-memory endpoint and search indexesspec_parser.py- Parses API Blueprint markdown into the normalized JSON catalog (used byscripts/refresh_spec.py)spec_search.py- Ranked substring search over the spec index (exact path > prefix > substring > summary/param-name match)validator.py- Validates query params (unknowns, required, types) and body (required fields) against the loaded spec; returns structured error responses instead of raisingissue_reporter.py- Single-function entry point forreport_issuestorage — appends oneISSUE_REPORT <json>line to a controlled file and to stderrsession_store.py- In-memory session storage with TTL (ported)server.py- FastMCP server with the four tool registrationsserver_http.py- Starlette wrapper with MCP Streamable HTTP transport and ScaleKit OAuth (ported)server_stdio.py- Stdio transport for local Claude Desktop integrationresources/- Tool implementations (endpoints.py,invoke.py,issues.py)utils/- Shared utilities
See CLAUDE.md for comprehensive development documentation, test patterns, and architecture details.
Security
Do not commit your .env file or any Cin7 API credentials to version control (it is included in .gitignore as a safe default).
Issue reports written by report_issue may contain raw request bodies, query parameters, and response excerpts — review data/issue_reports.log before sharing it with anyone outside the project.
License
MIT
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/tzenderman/mcp-cin7-meta'
If you have feedback or need assistance with the MCP directory API, please join our Discord server