forsonny/Coolify-MCP-Server-for-Claude-Code
If you are the rightful owner of Coolify-MCP-Server-for-Claude-Code and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
Coolify MCP Server is a Model Context Protocol server that integrates with Coolify, an open-source deployment platform, enabling interaction through API endpoints.
Coolify MCP Server
A Model Context Protocol (MCP) server that integrates with Coolify to let AI assistants manage your Coolify instance via a clean toolkit that wraps the official REST API.
Table of Contents
Features
Core Capabilities
- Coverage of key Coolify API endpoints (applications, services, deployments, teams, private keys, domains, health/version)
- Team Management – List teams, get team details, and view members
- Server & Domain Insights – Query domains configured per server
- Application Lifecycle – Start/stop/restart and create applications
- Service Management – List/create/start/stop/restart services
- Deployments – List running deployments; fetch deployment by UUID
- Private Keys – List and create SSH private keys for server auth
- Env Vars – CRUD for application/service environment variables
Note: Some aggregated operations (e.g., "resources by server") are implemented by client-side filtering over the supported endpoints rather than a dedicated API path.
Prerequisites
- Node.js v18 or newer
- npm or yarn
- A running Coolify instance (self‑hosted or cloud)
- A Coolify API token with appropriate permissions
Installation
1) Clone & install
git clone https://github.com/forsonny/Coolify-MCP-Server-for-Claude-Code.git
cd Coolify-MCP-Server-for-Claude-Code
npm install
2) Build
npm run build
(Compiles TypeScript into dist/)
Configuration
Environment Setup
Create a .env file at the project root:
# Required
COOLIFY_BASE_URL=https://your-coolify-instance.com
COOLIFY_API_TOKEN=your-api-token-here
# Optional
COOLIFY_TIMEOUT=30000
Notes
- Use a full base URL (no trailing slash). Example:
https://coolify.example.com - Do not use inline comments in
.envvalues. - Never commit
.envto version control.
Claude Code Setup
You can connect the server to Claude Code using the automated setup script or manually.
Option A — Automated Setup (Recommended)
The easiest way is to use the setup script:
# Run the setup script
npm run setup
This will:
- Validate your
.envfile configuration - Build the TypeScript project if needed
- Generate the correct
claude mcp add-jsoncommand with environment variables - Provide troubleshooting tips
Option B — Manual Setup
If you prefer to set it up manually, you have two approaches:
Method 1: With explicit environment variables (most reliable)
claude mcp add-json coolify '{
"type": "stdio",
"command": "node",
"args": ["/absolute/path/to/Coolify-MCP-Server-for-Claude-Code/dist/index.js"],
"env": {
"COOLIFY_BASE_URL": "https://your-coolify-instance.com",
"COOLIFY_API_TOKEN": "your-api-token-here",
"COOLIFY_TIMEOUT": "30000"
}
}' -s local
Method 2: Simple command (relies on .env file)
claude mcp add coolify "node /absolute/path/to/Coolify-MCP-Server-for-Claude-Code/dist/index.js" -s local
Verify the connection
claude mcp list
Option C — Import from Claude Desktop If you already have the server configured in Claude Desktop:
claude mcp add-from-claude-desktop
claude mcp list
Important: Method 1 (explicit environment variables) is more reliable because it ensures environment variables are available to the MCP server process, regardless of the working directory from which Claude Code launches the server.
Tip: Some setups store Claude Code MCP config in
~/.claude.json. The Desktop app usesclaude_desktop_config.jsonunder your OS application data directory.
Cursor Setup
Cursor supports MCP. The easiest route is through Settings → Extensions → MCP Servers → Add Server, then point to your built script (node …/dist/index.js) and add the three environment variables. Restart Cursor after saving.
For advanced/enterprise setups, see Cursor's MCP docs on programmatic registration.
API Token Generation
- Open your Coolify dashboard.
- Navigate to Keys & Tokens → API tokens.
- Create a new token (name it e.g. "MCP Server"), select the permissions you need, and optionally set an expiration.
- Copy the token once when shown and paste it into your
.env.
Available Tools
System
| Tool | What it does |
|---|---|
get_version | Get Coolify version |
health_check | Healthcheck probe |
Teams
| Tool | What it does |
|---|---|
list_teams | List all teams |
get_team | Get team by ID |
get_current_team | Get current team |
get_current_team_members | List members of current team |
Servers & Domains
| Tool | What it does |
|---|---|
get_server_domains | Get domains for a server UUID |
Applications
| Tool | What it does |
|---|---|
list_applications | List applications |
create_application | Create application |
start_application | Start application |
stop_application | Stop application |
restart_application | Restart application |
Services
| Tool | What it does |
|---|---|
list_services | List services |
create_service | Create service |
start_service | Start service |
stop_service | Stop service |
restart_service | Restart service |
Deployments & Keys
| Tool | What it does |
|---|---|
list_deployments | List running deployments |
get_deployment | Get deployment by UUID |
list_private_keys | List SSH private keys |
create_private_key | Create a new SSH private key |
Environment Variables
Application and service env vars support: list, create, update (single/bulk), and delete.
Usage Examples
Natural language you can try once connected:
Basics
"List my applications"
"Who's in the current team?"
"What version is my Coolify instance?"
Servers & Apps
"Show domains for server 123e4567-e89b-12d3-a456-426614174000"
"Create a new app from https://github.com/user/repo"
"Restart the backend app"
Services & Env Vars
"List running services"
"Create a PostgreSQL service on the main server"
"Add DATABASE_URL to the frontend app"
Development
Dev mode (watch):
npm run dev
Build:
npm run build
Setup:
npm run setup
Clean:
npm run clean
Project Structure
Coolify-MCP-Server-for-Claude-Code/
├── src/
│ ├── index.ts # MCP server entrypoint
│ ├── coolify-client.ts # Coolify API client
│ └── types.ts # Type definitions
├── dist/ # Compiled JS (generated)
├── .env # Environment variables (create this)
├── setup-mcp.js # Setup script for easy configuration
├── package.json
├── tsconfig.json
└── README.md # This file
API Reference
Selected endpoint mapping used by this server
| MCP Tool | Method | Path |
|---|---|---|
get_version | GET | /version |
health_check | GET | /health |
list_teams | GET | /teams |
get_team | GET | /teams/{id} |
get_current_team | GET | /teams/current |
get_current_team_members | GET | /teams/current/members |
list_applications | GET | /applications |
create_application | POST | /applications |
start_application | POST | /applications/{uuid}/start |
stop_application | POST | /applications/{uuid}/stop |
restart_application | POST | /applications/{uuid}/restart |
list_services | GET | /services |
create_service | POST | /services |
list_deployments | GET | /deployments |
get_deployment | GET | /deployments/{uuid} |
list_private_keys | GET | /security/keys |
create_private_key | POST | /security/keys |
get_server_domains | GET | /servers/{uuid}/domains |
Endpoint paths follow the official Coolify API and do not use a
/api/v1prefix.
Environment variable flags
| Flag | Meaning | Apps | Services |
|---|---|---|---|
is_build_time | Present at build time | ✅ | — |
is_preview | Applies to preview deployments only | ✅ | ✅ |
is_literal | Disable variable substitution | ✅ | ✅ |
Services are prebuilt images (no build phase), so
is_build_timehas no effect for services.
Troubleshooting
Server won't start
- Confirm Node ≥ 18:
node --version - Reinstall deps:
rm -rf node_modules && npm install - Rebuild:
npm run clean && npm run build - Confirm absolute paths in MCP config
Auth errors (401 Unauthorized)
- Verify token is valid and scoped to the correct team
- Recreate token if expired; paste into
.env
Connection issues (ECONNREFUSED/timeouts)
- Check
COOLIFY_BASE_URL(no trailing slash) - Ensure the Coolify instance is reachable and healthy
- Increase
COOLIFY_TIMEOUTfor slow links
Tools not appearing
- Restart your client (Claude Code / Cursor)
- Verify with
claude mcp list - Check server logs in your terminal
- Ensure environment variables are set for the MCP process
Environment variable issues
If you see COOLIFY_BASE_URL and COOLIFY_API_TOKEN environment variables are required errors:
-
Use the automated setup script:
npm run setup -
Or use explicit environment variables: Remove the existing MCP server and re-add with explicit env vars:
claude mcp remove coolify -s local claude mcp add-json coolify '{ "type": "stdio", "command": "node", "args": ["/absolute/path/to/your/dist/index.js"], "env": { "COOLIFY_BASE_URL": "https://your-coolify-instance.com", "COOLIFY_API_TOKEN": "your-api-token-here" } }' -s local -
Verify your .env file exists and has proper values:
cat .env
Why this happens: When MCP servers are launched by Claude Code, they may run from a different working directory, causing the
.envfile to not be found. Explicit environment variables in the MCP configuration solve this issue.
Debug mode
DEBUG=coolify-mcp npm run dev
Security
- Keep API tokens out of VCS; rotate regularly
- Use HTTPS; consider IP allowlists / VPN for private instances
- Add
.envto.gitignore; restrict file permissions - Use least-privilege tokens per environment; audit and revoke regularly
Contributing
We welcome contributions!
-
Fork the repo and clone your fork
git clone https://github.com/<your-username>/Coolify-MCP-Server-for-Claude-Code.git -
Create a branch
git checkout -b feat/your-feature -
Code & test – follow existing style; add tests where useful
-
Commit
git commit -m "feat: add <thing>" -
Push & open PR
git push origin feat/your-feature
Guidelines
- TypeScript best practices; backward compat where feasible
- Clear commit messages and error handling
- Update README when adding features
License
MIT — see .
Support
Issues – open on GitHub
Docs
Version: 1.0.0 Maintainer: @forsonny