Skip to main content

MCP server for ComfyUI - enables ChatGPT to control ComfyUI workflows

Project description

🧠 Serveur MCP pour ComfyUI (Version Alpha-1)

image

Ce projet expose ComfyUI via un serveur compatible MCP (Model Context Protocol).

Il permet :

  • de piloter ComfyUI depuis ChatGPT via un connecteur (mode dev) ;
  • de piloter l’interface ComfyUI dans Chrome via une extension WebSocket.
image

Pour bientôt : en local, interfaces Gradio pour Ollama et Google CLI


⚙️ Installation

1️⃣ Cloner le dépôt

git clone https://github.com/orion4d/ComfyUI_mcp.git

2️⃣ Créer l’environnement virtuel

python -m venv venv
# Linux / Mac
source venv/bin/activate
# Windows
venv\Scripts\activate

3️⃣ Installer les dépendances

pip install -r requirements.txt

🔐 Génération des clés et configuration

python generate_key.py

Ce script :

  • génère MCP_API_KEY (pour ChatGPT)
  • génère WEBSOCKET_TOKEN (pour l’extension Chrome)
  • crée automatiquement .env et .env.example

🚀 Démarrage du serveur

python server.py

Le serveur démarre par défaut sur :
http://127.0.0.1:8000


🌐 Points d’accès

🔧 MCP Tools exposés

  • list_workflows, save_workflow, load_workflow
  • read_custom_node, write_custom_node
  • queue_prompt, get_history
  • create_custom_node_template, list_custom_subdir
  • ui_click_element, ui_fill_input, ui_get_current_workflow

🧩 Routes Debug

  • /debug/health → infos système, versions, outils
  • /ws → WebSocket pour l’extension Chrome

🧱 Exemple d’usage

Depuis ChatGPT (Custom GPT)

  • Authentification : X-API-Key → ta clé MCP_API_KEY
  • Appels possibles : list_workflows, queue_prompt, read_custom_node, etc.

Depuis Chrome (Extension MCP)

  • URL WebSocket : ws://127.0.0.1:8000/ws
  • Token : WEBSOCKET_TOKEN

🧠 Intégration ComfyUI

Le client (ComfyUIClient) communique via HTTP avec ton ComfyUI local :

  • URL : http://127.0.0.1:8188
  • Support des workflows UI et API
  • Conversion automatique via _convert_ui_to_api()

Tester la connexion

curl http://127.0.0.1:8000/debug/health

📘 Commandes MCP–ComfyUI

🗂️ Arborescence des commandes

ComfyUI
│
├── 🧠 Exécution (moteur)
│   ├─ /queue_prompt
│   ├─ /get_queue_status
│   ├─ /cancel_prompt
│   ├─ /get_history
│   └─ /interrupt_execution
│
├── ⚙️ Système & Modèles
│   ├─ /get_system_stats
│   ├─ /list_models
│   └─ /model_info
│
├── 🧩 Workflows
│   ├─ /save_workflow
│   ├─ /load_workflow
│   ├─ /list_workflows
│   └─ /inspect_workflow
│
├── 🔧 Custom Nodes (→ ComfyUI/custom_nodes/)
│   ├─ /create_custom_node_template
│   ├─ /write_custom_node
│   ├─ /read_custom_node
│   ├─ /list_custom_subdir
│   └─ /autodoc_nodes
│
├── 🖼️ Images
│   ├─ /upload_image
│   ├─ /get_image
│   └─ /list_output_images
│
└── 📂 MCP_exchange (→ output/MCP_exchange/)
    ├─ /list_exchange
    ├─ /read_exchange
    ├─ /write_exchange
    └─ /delete_exchange

🧠 Exécution & File

  • /queue_prompt → exécuter un workflow
  • /get_queue_status → état de la file
  • /get_history → historique d’un prompt
  • /cancel_prompt → annuler un prompt
  • /interrupt_execution → stopper tout en cours

⚙️ Système & Modèles

  • /get_system_stats → infos GPU, RAM, versions
  • /list_models → lister les modèles disponibles
  • /model_info → détails d’un modèle

🧩 Workflows

  • /save_workflow → enregistrer un workflow
  • /load_workflow → charger un workflow
  • /list_workflows → lister tous les workflows
  • /inspect_workflow → analyser la structure

🖼️ Images & Fichiers

  • /list_output_images → voir les images produites
  • /get_image → récupérer une image
  • /upload_image → envoyer une image d’entrée

🔧 Custom Nodes

  • /create_custom_node_template → créer un squelette de node
  • /write_custom_node → écrire un fichier node
  • /read_custom_node → lire le code d’un node
  • /list_custom_subdir → explorer un dossier custom
  • /autodoc_nodes → générer la doc de tous les custom nodes

🖥️ Interface (Chrome UI)

  • /ui_click_element → simuler un clic
  • /ui_fill_input → remplir un champ texte
  • /ui_get_current_workflow → récupérer le workflow affiché

📂 Structure MCP_exchange

Ce répertoire sert d’espace d’échange entre MCP–ComfyUI et ton environnement local.
Toutes les commandes ci-dessous interagissent uniquement avec le dossier :
output/MCP_exchange/

🔍 Lister les fichiers

call_tool /MCP-ComfyUI/.../list_exchange {"limit": 200, "exts": "png,jpg,jpeg,webp,bmp,tif,tiff,txt,md,html,htm,json,js,py,css"}

📖 Lire un fichier

call_tool /MCP-ComfyUI/.../read_exchange {"name": "nom_du_fichier.txt", "as_data_url": true}

✏️ Écrire un fichier

call_tool /MCP-ComfyUI/.../write_exchange {"name": "nouveau_fichier.md", "content": "contenu du fichier", "mode": "text", "overwrite": true}

Modes disponibles : text, base64, data_url.

❌ Supprimer un fichier

call_tool /MCP-ComfyUI/.../delete_exchange {"name": "fichier_a_supprimer.json"}

🧭 Usages typiques

  • Exporter un résultat ou une image générée pour inspection.
  • Importer un script, un JSON de workflow ou un dataset.
  • Automatiser des échanges entre MCP et ComfyUI.

Chemin complet : ComfyUI/output/MCP_exchange/

Les autres commandes (workflows, modèles, nœuds) agissent ailleurs ; ce groupe-ci se limite à la gestion des fichiers d’échange.


Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

iflow_mcp_orion4d_comfyui_mcp-1.0.1.tar.gz (106.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

iflow_mcp_orion4d_comfyui_mcp-1.0.1-py3-none-any.whl (22.4 kB view details)

Uploaded Python 3

File details

Details for the file iflow_mcp_orion4d_comfyui_mcp-1.0.1.tar.gz.

File metadata

  • Download URL: iflow_mcp_orion4d_comfyui_mcp-1.0.1.tar.gz
  • Upload date:
  • Size: 106.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.28 {"installer":{"name":"uv","version":"0.9.28","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_orion4d_comfyui_mcp-1.0.1.tar.gz
Algorithm Hash digest
SHA256 8da329d6ce4716760d6119aab17a0bc275aa2d86b10ccc38fa7cbff303c6adf0
MD5 0abd05590792b388727ee84adcef7981
BLAKE2b-256 4127db7c901df40f7b9103ed632e6a0b8157f5d1a270c80cf3eb6fd6fafdc18d

See more details on using hashes here.

File details

Details for the file iflow_mcp_orion4d_comfyui_mcp-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_orion4d_comfyui_mcp-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 22.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.28 {"installer":{"name":"uv","version":"0.9.28","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_orion4d_comfyui_mcp-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7c4808a5e7fe0ef5f3b31fc5c71c6448a4f2e329f6d13a5e44d8cf3d1652239b
MD5 ef8fe85584e77d4364154e0c50bbf927
BLAKE2b-256 b571dcc6289f86cbcee1cb3a58ad37219b676da35c15b94d1e1b10bd04458e13

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page