@kieksme/contabo-mcp
v1.3.0
Published
MCP server for the Contabo API (VMs, snapshots, object storage, secrets, domains)
Maintainers
Readme
Contabo MCP Server
MCP (Model Context Protocol) server for the Contabo API. Manage virtual machines, snapshots/backups, object storage, secrets, and domains from Cursor or other MCP clients.
Features
- 57 tools with
contabo_*naming - OAuth2 password grant (or static bearer token for development)
- Automatic
x-request-idper request and token refresh on 401 - Secret value redaction in tool responses (secrets and S3 credentials)
- MCP tool annotations (
readOnlyHint,destructiveHint,idempotentHint,openWorldHint) on all tools - Structured error payloads with
x-request-idand audit-tool hints
Security and Socket
This package is an API client: it reads CONTABO_* environment variables and calls Contabo over HTTPS only. Outbound hosts are restricted to *.contabo.com unless CONTABO_ALLOW_CUSTOM_HOSTS=true (staging). See SECURITY.md for the full allowlist and reporting process.
The Socket.dev badge may show network access, environment variable access, URL strings, and GPL license alerts — these are intentional for this package type, not indicators of malware. Dependency CVEs are tracked via pnpm audit in CI.
Tool annotations
Every tool sets MCP hints so clients can warn before destructive calls:
| Annotation | Used for |
|--------------------------|-------------------------------------------------------------|
| readOnlyHint | List, get, stats, availability checks, audits |
| destructiveHint: false | Safe writes (metadata updates, start instance) |
| destructiveHint: true | Deletes, cancels, reinstall, power actions, billing changes |
| openWorldHint | Creates and purchases that affect live account resources |
| idempotentHint | DELETE operations safe to retry with the same id |
Errors return structured JSON (structuredContent.error) with code, message, status, and xRequestId.
Releases
Versioning and npm publish are automated with release-please on main. Any conventional commit under contabo-mcp/ updates the next release pull request. See CONTRIBUTING.md in the repository root.
Prerequisites
- Node.js 20 or newer
- Contabo API credentials (see Obtaining API credentials below)
- Optional background: Contabo help — How can I access the Contabo API?
Obtaining API credentials
All values come from the Contabo Customer Control Panel. You need a normal control-panel login (including 2FA if enabled).
Open the API page
- Sign in at my.contabo.com.
- Open API details (menu path may vary; the direct URL is stable).
The page title is API. It states that the data shown there plus the API password are required to use the API.
Fields on the API page
The panel lists four pieces of information (labels may appear in German or English depending on locale):
| Control panel (DE) | Control panel (EN) | Environment variable | Notes |
|--------------------|--------------------|-------------------------|--------------------------------------------------------------------------------------|
| Kunden-ID | Customer ID | CONTABO_CLIENT_ID | Format like DE-8791. This is the OAuth client id, not your VPS name. |
| Client-Secret | Client secret | CONTABO_CLIENT_SECRET | Shown masked (••••••). Copy when displayed or regenerate if you no longer have it. |
| Benutzername | Username | CONTABO_API_USER | Your API user email (often the same as your control-panel login). |
| API-Passwort | API password | CONTABO_API_PASSWORD | Separate from your control-panel login password (see below). |
Set the API password (required once)
Until you set an API password, the panel typically asks you to set a new password before you can use the API (“Bitte setzen Sie ein neues Passwort, um die API nutzen zu können”).
- On API details, use the control to set or change the API password.
- Choose a strong password and store it in a password manager.
- Use that value for
CONTABO_API_PASSWORD— not your normal my.contabo.com login password.
You can change the API password anytime in the same place.
Map credentials to this MCP server
Copy the four values into .env (local development) or your MCP client env block:
CONTABO_CLIENT_ID=DE-XXXX # Customer ID from the panel
CONTABO_CLIENT_SECRET=... # Client secret (full string)
[email protected] # Username from the panel
CONTABO_API_PASSWORD=... # API password you set on the API pageExample .cursor/mcp.json fragment:
"env": {
"CONTABO_CLIENT_ID": "DE-XXXX",
"CONTABO_CLIENT_SECRET": "your-client-secret",
"CONTABO_API_USER": "[email protected]",
"CONTABO_API_PASSWORD": "your-api-password"
}Verify credentials
After saving config, restart the MCP client (or reload MCP servers in Cursor). A quick check:
- OAuth errors such as
unauthorized_client/ Invalid client credentials usually mean a wrong Customer ID or Client secret. invalid_grantor login-related errors often mean a wrong API user or API password (e.g. using the control-panel login password instead of the API password).
Do not commit .env or paste secrets into chat, issues, or screenshots.
Install from npm (recommended)
Published as @kieksme/contabo-mcp on npm under the kieksme account. No clone and no build step required.
Cursor / MCP client
Add to .cursor/mcp.json (or your global MCP config):
{
"mcpServers": {
"contabo": {
"command": "npx",
"args": ["-y", "@kieksme/contabo-mcp"],
"env": {
"CONTABO_CLIENT_ID": "your-client-id",
"CONTABO_CLIENT_SECRET": "your-client-secret",
"CONTABO_API_USER": "[email protected]",
"CONTABO_API_PASSWORD": "your-api-password"
}
}
}
}With pnpm:
{
"mcpServers": {
"contabo": {
"command": "pnpm",
"args": ["dlx", "@kieksme/contabo-mcp"],
"env": {
"CONTABO_CLIENT_ID": "your-client-id",
"CONTABO_CLIENT_SECRET": "your-client-secret",
"CONTABO_API_USER": "[email protected]",
"CONTABO_API_PASSWORD": "your-api-password"
}
}
}
}See mcp.json.example for more variants.
Terminal (stdio)
npx -y @kieksme/contabo-mcppnpm dlx @kieksme/contabo-mcpGlobal install
npm install -g @kieksme/contabo-mcp
contabo-mcpInstall from GitHub (alternative)
Without npm, install from the repository (first run builds the package; requires pnpm via Corepack on Node 20+):
{
"mcpServers": {
"contabo": {
"command": "npx",
"args": [
"-y",
"--package=git+https://github.com/kieksme/mcp-contabo.git#main",
"contabo-mcp"
],
"env": { "...": "..." }
}
}
}npx -y --package=git+https://github.com/kieksme/mcp-contabo.git#main contabo-mcpEvaluations
Read-only evaluation scenarios for agent testing live in evaluations/contabo.eval.xml. Regenerate answers against your account when adding live-data questions.
Contributing
Development setup, testing, OpenAPI refresh, and release process: see CONTRIBUTING.md in the repository root.
Tool inventory
| Area | Tools |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Instances | contabo_instances_* (list, get, create, update, reinstall, cancel, upgrade, start/stop/restart/shutdown/rescue/reset_password, audits) |
| Snapshots / backups | contabo_snapshots_* |
| Object storage | contabo_object_storages_*, contabo_object_storage_credentials_* |
| Secrets | contabo_secrets_* |
| Domains | contabo_domains_*, contabo_domain_handles_* |
Automated VM backups: use contabo_instances_upgrade with body { "backup": {} }.
Object storage S3 credentials require userId (Contabo user UUID from the control panel).
License
GPL-3.0-or-later (see LICENSE).
