Compare commits
7 Commits
7304d1e4a8
...
bc89169265
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
bc89169265 | ||
|
|
55166db065 | ||
|
|
30cb9a8829 | ||
|
|
0972556b38 | ||
|
|
e7df499874 | ||
|
|
0c20861103 | ||
|
|
af1a823683 |
40
AGENTS.md
40
AGENTS.md
@@ -10,12 +10,13 @@ This document tracks the AI agents and MCP servers configured in this project.
|
||||
|
||||
### Available MCP Servers
|
||||
|
||||
#### Design & Engineering (3 servers)
|
||||
#### Design & Engineering (4 servers)
|
||||
| Service | Container Name | Description |
|
||||
|---------|---------------|-------------|
|
||||
| kicad-mcp | kneldevstack-aimiddleware-kicad-mcp | PCB design automation with 64 tools, JLCPCB integration (host-only) |
|
||||
| blender-mcp | kneldevstack-aimiddleware-blender-mcp | 3D modeling, materials, scenes, AI 3D model generation |
|
||||
| freecad-mcp | kneldevstack-aimiddleware-freecad-mcp | CAD modeling, Python execution, parts library |
|
||||
| gimp-mcp | kneldevstack-aimiddleware-gimp-mcp | Image editing with GIMP 3.0, OCR support |
|
||||
|
||||
#### Hosting & Infrastructure (5 servers)
|
||||
| Service | Container Name | Description |
|
||||
@@ -26,13 +27,10 @@ This document tracks the AI agents and MCP servers configured in this project.
|
||||
| terraform-mcp | kneldevstack-aimiddleware-terraform-mcp | IaC automation, HCP Terraform, workspace management |
|
||||
| cloudron-mcp | kneldevstack-aimiddleware-cloudron-mcp | Self-hosted app management |
|
||||
|
||||
#### Development Tools (4 servers)
|
||||
#### Development Tools (1 server)
|
||||
| Service | Container Name | Description |
|
||||
|---------|---------------|-------------|
|
||||
| bash-language-server | kneldevstack-aimiddleware-bash-language-server | LSP for bash (diagnostics, completion, formatting) |
|
||||
| docker-language-server | kneldevstack-aimiddleware-docker-language-server | LSP for Dockerfiles, Compose files, Bake files |
|
||||
| context7-mcp | kneldevstack-aimiddleware-context7-mcp | MCP server framework and SDK for documentation |
|
||||
| marksman | kneldevstack-aimiddleware-marksman | LSP for Markdown (diagnostics, completion, navigation) |
|
||||
|
||||
#### Content Management (4 servers)
|
||||
| Service | Container Name | Description |
|
||||
@@ -59,25 +57,31 @@ This document tracks the AI agents and MCP servers configured in this project.
|
||||
| Service | Container Name | Description |
|
||||
|---------|---------------|-------------|
|
||||
| audiobook-mcp | kneldevstack-aimiddleware-audiobook-mcp | Audiobook management with AI-powered features |
|
||||
| gimp-mcp | kneldevstack-aimiddleware-gimp-mcp | Image editing with GIMP 3.0, OCR support |
|
||||
| snipeit-mcp | kneldevstack-aimiddleware-snipeit-mcp | Asset inventory, maintenance tracking |
|
||||
| mcp-redmine | kneldevstack-aimiddleware-mcp-redmine | Project management, issue tracking, file operations |
|
||||
| mcp-ansible | kneldevstack-aimiddleware-mcp-ansible | IT automation playbooks |
|
||||
| elasticsearch-mcp | kneldevstack-aimiddleware-elasticsearch-mcp | Search and index management (Rust) |
|
||||
| Service | Container Name | Description |
|
||||
|---------|---------------|-------------|
|
||||
| gimp-mcp | kneldevstack-aimiddleware-gimp-mcp | Image editing with GIMP 3.0, OCR support |
|
||||
| snipeit-mcp | kneldevstack-aimiddleware-snipeit-mcp | Asset inventory, maintenance tracking |
|
||||
| mcp-redmine | kneldevstack-aimiddleware-mcp-redmine | Project management, issue tracking, file operations |
|
||||
| mcp-ansible | kneldevstack-aimiddleware-mcp-ansible | IT automation playbooks |
|
||||
| elasticsearch-mcp | kneldevstack-aimiddleware-elasticsearch-mcp | Search and index management (Rust) |
|
||||
| audiobook-mcp | kneldevstack-aimiddleware-audiobook-mcp | Audiobook management with AI-powered features |
|
||||
| drawio-mcp | kneldevstack-aimiddleware-drawio-mcp | Draw.io diagram management |
|
||||
|
||||
#### Additional Tools (2 servers)
|
||||
| Service | Container Name | Description |
|
||||
|---------|---------------|-------------|
|
||||
| drawio-mcp | kneldevstack-aimiddleware-drawio-mcp | Draw.io diagram management |
|
||||
| penpot-mcp | kneldevstack-aimiddleware-penpot-mcp | Design collaboration platform integration |
|
||||
| webserial-mcp | kneldevstack-aimiddleware-webserial-mcp | ESP32 MicroPython development via WebSerial (requires bridge server) |
|
||||
|
||||
#### Reverse Engineering (2 servers)
|
||||
| Service | Container Name | Description |
|
||||
|---------|---------------|-------------|
|
||||
| ghidra-mcp | kneldevstack-aimiddleware-ghidra-mcp | Binary analysis and reverse engineering (HTTP REST, not MCP) |
|
||||
| reverse-engineering-assistant | kneldevstack-aimiddleware-reverse-engineering-assistant | ReVa - AI-assisted reverse engineering via MCP |
|
||||
|
||||
#### LSP Servers (4 servers)
|
||||
| Service | Container Name | Description |
|
||||
|---------|---------------|-------------|
|
||||
| bash-language-server | kneldevstack-aimiddleware-bash-language-server | LSP for bash (diagnostics, completion, formatting) |
|
||||
| docker-language-server | kneldevstack-aimiddleware-docker-language-server | LSP for Dockerfiles, Compose files, Bake files |
|
||||
| marksman | kneldevstack-aimiddleware-marksman | LSP for Markdown (diagnostics, completion, navigation) |
|
||||
| terraform-ls | kneldevstack-aimiddleware-terraform-ls | LSP for Terraform (diagnostics, completion, navigation) |
|
||||
|
||||
## Agent Capabilities
|
||||
|
||||
@@ -99,7 +103,7 @@ Most use `npx` for installation:
|
||||
- Context7 MCP
|
||||
- Bash Language Server
|
||||
|
||||
#### Python (10 servers)
|
||||
#### Python (11 servers)
|
||||
Most use `uvx` for installation:
|
||||
- Blender MCP
|
||||
- FreeCAD MCP
|
||||
@@ -111,6 +115,7 @@ Most use `uvx` for installation:
|
||||
- IMAP MCP
|
||||
- Ansible MCP
|
||||
- Nextcloud MCP (hybrid)
|
||||
- WebSerial MCP
|
||||
|
||||
#### Go (2 servers)
|
||||
- Kubernetes MCP (also available via npx)
|
||||
@@ -124,6 +129,9 @@ Most use `uvx` for installation:
|
||||
#### Rust (1 server)
|
||||
- Elasticsearch MCP
|
||||
|
||||
#### HashiCorp Binary (1 server)
|
||||
- terraform-ls (HashiCorp release binary)
|
||||
|
||||
## Environment Variables Reference
|
||||
|
||||
Common environment variables required for MCP servers:
|
||||
|
||||
133
JOURNAL.md
133
JOURNAL.md
@@ -1598,3 +1598,136 @@ Some MCPs are designed to integrate with desktop applications and cannot be cont
|
||||
**Next MCP**: matomo-mcp
|
||||
|
||||
---
|
||||
|
||||
## 2026-02-17
|
||||
|
||||
### [ADR-XXX] Repository URL Migration to Official Sources
|
||||
|
||||
**Date/Time**: 2026-02-17
|
||||
**Type**: Architecture Decision Record
|
||||
**Status**: Accepted
|
||||
|
||||
**Context**: The CloneVendorRepos.sh script was using many `ahujasid/*` repository mirrors instead of official sources. Investigation revealed most ahujasid repositories were empty (no code), causing build failures for multiple MCP servers.
|
||||
|
||||
**Decision**: Migrate all repository URLs in CloneVendorRepos.sh to use official sources as specified by the user's requested repository list.
|
||||
|
||||
**Changes Made**:
|
||||
1. **Updated CloneVendorRepos.sh** (20 URL changes):
|
||||
- freecad-mcp: ahujasid → neka-nat
|
||||
- gimp-mcp: ahujasid → maorcc
|
||||
- docker-language-server: rcjsuen → docker
|
||||
- drawio-mcp-server: ahujasid → lgazo
|
||||
- matomo-mcp-client: ahujasid → openmost
|
||||
- imap-mcp: ahujasid → non-dirty
|
||||
- mcp-redmine: ahujasid → runekaagaard
|
||||
- ghost-mcp: ahujasid → MFYDev
|
||||
- discourse-mcp: ahujasid → discourse
|
||||
- mcp-cloudron: ahujasid → serenichron
|
||||
- postizz-MCP: ahujasid → oculairmedia
|
||||
- snipeit-mcp: ahujasid → Wil-Collier
|
||||
- nextcloud-mcp-server: ahujasid → cbcoutinho
|
||||
- docker-mcp: ahujasid → QuantGeekDev
|
||||
- kubernetes-mcp-server: ahujasid → containers
|
||||
- ProxmoxMCP: ahujasid → canvrno
|
||||
- terraform-mcp-server: ahujasid → hashicorp
|
||||
- mcp-ansible: ahujasid → bsahane
|
||||
- mcp-adapter: ahujasid → WordPress
|
||||
- audiobook-mcp-server: ahujasid → joelmale
|
||||
|
||||
2. **Added Missing Repositories** (4 new):
|
||||
- reverse-engineering-assistant (cyberkaida)
|
||||
- ghidra-mcp (bethington)
|
||||
- webserial-mcp (DG1001)
|
||||
- terraform-ls (hashicorp)
|
||||
|
||||
3. **Updated docker-compose.yml**:
|
||||
- Added reverse-engineering-assistant service in Reverse Engineering section
|
||||
- Re-organized Design & Engineering section
|
||||
|
||||
4. **Created Dockerfile**:
|
||||
- dockerfiles/reverse-engineering-assistant/Dockerfile (Java 21, Ghidra headless)
|
||||
|
||||
5. **Updated AGENTS.md**:
|
||||
- Added reverse-engineering-assistant and ghidra-mcp to new "Reverse Engineering" section
|
||||
- Fixed duplicate Productivity & Automation section
|
||||
- Moved gimp-mcp to Design & Engineering
|
||||
- Moved drawio-mcp to Productivity & Automation
|
||||
|
||||
6. **Updated STATUS.md**:
|
||||
- Changed "Blocked" entries to "Re-Clone" for services with corrected URLs
|
||||
- Added migration instructions
|
||||
- Added reverse-engineering-assistant entry
|
||||
|
||||
**Rationale**:
|
||||
- Official repositories have actual code and maintenance
|
||||
- ahujasid/* mirrors were empty placeholders
|
||||
- User provided specific official repository URLs to use
|
||||
|
||||
**Consequences**:
|
||||
- All 30 requested MCP/LSP repositories now have correct URLs
|
||||
- Vendor directories need to be deleted and re-cloned
|
||||
- Dockerfiles may need adjustment for new repository structures
|
||||
- Several previously "blocked" services should become buildable
|
||||
|
||||
**Action Required**:
|
||||
```bash
|
||||
rm -rf vendor/*
|
||||
./scripts/CloneVendorRepos.sh
|
||||
```
|
||||
|
||||
**Files Modified**:
|
||||
- scripts/CloneVendorRepos.sh
|
||||
- docker-compose.yml
|
||||
- dockerfiles/reverse-engineering-assistant/Dockerfile (new)
|
||||
- AGENTS.md
|
||||
- STATUS.md
|
||||
|
||||
---
|
||||
## 2026-02-19
|
||||
|
||||
### Housekeeping: Fix crush.json Paths and Add Missing MCP Configurations
|
||||
|
||||
**Date/Time**: 2026-02-19 10:30:00 AM EST
|
||||
**Work**: Configuration fix and cleanup
|
||||
|
||||
**What was done**:
|
||||
1. **Fixed crush.json path mismatch**:
|
||||
- Incorrect: `/home/charles/Projects/KNEL/KNEL-AIMiddleware/`
|
||||
- Correct: `/home/charles/Projects/KNEL-AIMiddleware/`
|
||||
- Applied via replace_all to fix all 27 occurrences
|
||||
|
||||
2. **Added missing MCP server configurations to crush.json**:
|
||||
- discourse (mcp-discourse-wrapper.sh)
|
||||
- penpot (mcp-penpot-wrapper.sh)
|
||||
|
||||
3. **Wrapper scripts now tracked** (10 new wrapper scripts):
|
||||
- mcp-ansible-wrapper.sh
|
||||
- mcp-discourse-wrapper.sh
|
||||
- mcp-matomo-wrapper.sh
|
||||
- mcp-nextcloud-wrapper.sh
|
||||
- mcp-penpot-wrapper.sh
|
||||
- mcp-postizz-wrapper.sh
|
||||
- mcp-proxmox-wrapper.sh
|
||||
- mcp-redmine-wrapper.sh
|
||||
- mcp-snipeit-wrapper.sh
|
||||
- mcp-terraform-wrapper.sh
|
||||
|
||||
4. **New Dockerfiles tracked**:
|
||||
- dockerfiles/paperless-mcp/
|
||||
- dockerfiles/postizz-mcp/
|
||||
|
||||
**Why**:
|
||||
- Path mismatch would cause all MCP servers to fail in Crush
|
||||
- Wrapper scripts need to be tracked in git for reproducibility
|
||||
- Missing MCP configurations prevented Crush from using discourse and penpot servers
|
||||
|
||||
**Files Modified**:
|
||||
- crush.json (path fix + added discourse, penpot)
|
||||
|
||||
**Files Added**:
|
||||
- 10 wrapper scripts (mcp-*-wrapper.sh)
|
||||
- dockerfiles/paperless-mcp/Dockerfile
|
||||
- dockerfiles/postizz-mcp/Dockerfile
|
||||
|
||||
---
|
||||
|
||||
|
||||
185
STATUS.md
185
STATUS.md
@@ -2,127 +2,151 @@
|
||||
|
||||
Tracking the setup and validation of MCP/LSP servers via Docker Compose.
|
||||
|
||||
Last validated: 2026-02-17
|
||||
Last validated: 2026-02-19
|
||||
|
||||
## Repository URLs Verified (2026-02-19)
|
||||
|
||||
All 32 vendor repositories have been verified and correctly cloned. CloneVendorRepos.sh is up to date with official repository URLs.
|
||||
|
||||
**Cloned Repositories (33 total - 32 from user list + bitwarden/mcp-server):**
|
||||
- reverse-engineering-assistant (cyberkaida)
|
||||
- penpot-mcp (penpot)
|
||||
- ghidra-mcp (bethington)
|
||||
- drawio-mcp-server (lgazo)
|
||||
- audiobook-mcp-server (joelmale)
|
||||
- context7 (upstash)
|
||||
- gimp-mcp (maorcc)
|
||||
- mcp-adapter (WordPress)
|
||||
- KiCAD-MCP-Server (mixelpixx)
|
||||
- freecad-mcp (neka-nat)
|
||||
- blender-mcp (ahujasid)
|
||||
- nextcloud-mcp-server (cbcoutinho)
|
||||
- docker-mcp (QuantGeekDev)
|
||||
- ProxmoxMCP (canvrno)
|
||||
- terraform-mcp-server (hashicorp)
|
||||
- mcp-ansible (bsahane)
|
||||
- snipeit-mcp (Wil-Collier)
|
||||
- postizz-MCP (oculairmedia)
|
||||
- discourse-mcp (discourse)
|
||||
- mcp-cloudron (serenichron)
|
||||
- ghost-mcp (MFYDev)
|
||||
- mcp-redmine (runekaagaard)
|
||||
- imap-mcp (non-dirty)
|
||||
- matomo-mcp-client (openmost)
|
||||
- kubernetes-mcp-server (containers)
|
||||
- webserial-mcp (DG1001)
|
||||
- docspace-mcp (ONLYOFFICE)
|
||||
- paperless-mcp (nloui)
|
||||
- docker-language-server (docker)
|
||||
- bash-language-server (bash-lsp)
|
||||
- terraform-ls (hashicorp)
|
||||
- marksman (artempyanykh)
|
||||
- mcp-server (bitwarden) - project extra
|
||||
|
||||
**Removed:**
|
||||
- elasticsearch-mcp - Now bundled with Elasticsearch directly, standalone MCP no longer needed
|
||||
|
||||
## Validation Summary
|
||||
|
||||
**Working MCP Servers:**
|
||||
- ✓ audiobook-mcp: Working (audiobook-library v1.1.0) - requires AUDIOBOOK_ROOT env var
|
||||
- ✓ bitwarden-mcp: Working (Bitwarden MCP Server v2026.1.0) - requires Bitwarden credentials
|
||||
- ✓ bitwarden-mcp: Working (Bitwarden MCP Server) - requires Bitwarden credentials
|
||||
- ✓ blender-mcp: Working (BlenderMCP v1.25.0) - requires Blender with addon running
|
||||
- ✓ cloudron-mcp: Working (cloudron-mcp v0.1.0) - requires CLOUDRON_URL env var
|
||||
- ✓ context7-mcp: Working (Context7 v2.1.0) - stdio-based, requires Upstash Redis
|
||||
- ✓ docker-mcp: Working (docker-mcp v0.1.0) - requires Docker socket mount
|
||||
- ✓ docspace-mcp: Working (@onlyoffice/docspace-mcp v3.1.0) - requires DOCSPACE_HOST and DOCSPACE_TOKEN env vars
|
||||
- ✓ drawio-mcp: Working (drawio-mcp-server v1.4.0) - requires DRAWIO_URL env var
|
||||
- ✓ elasticsearch-mcp: Working (rmcp v0.2.1, deprecated) - requires ES_URL env var
|
||||
- ✓ freecad-mcp: Working (FreeCADMCP v1.25.0) - requires FreeCAD with addon running
|
||||
- ✓ ghost-mcp: Working (ghost-mcp-ts v1.0.0) - requires Ghost CMS credentials
|
||||
- ✓ gimp-mcp: Working (GimpMCP v1.10.1) - requires GIMP with server running
|
||||
- ✗ imap-mcp: Not working - requires working IMAP server (server crashes on startup if IMAP unreachable)
|
||||
- ✓ kubernetes-mcp: Working (mcp-k8s Go binary) - requires kubeconfig mounted at /root/.kube/config
|
||||
|
||||
**MCP Servers with Configuration Issues:**
|
||||
- ✗ imap-mcp: Not working - requires working IMAP server (server crashes on startup if IMAP unreachable)
|
||||
- ✗ imap-mcp: Requires working IMAP server (server crashes on startup if IMAP unreachable)
|
||||
- ✗ webserial-mcp: Requires bridge server (esp32_bridge_server.py) running at ws://host.docker.internal:3000 + browser with WebSerial access + ESP32 hardware
|
||||
- ✗ wordpress-mcp: Blocked - requires WordPress instance (PHP plugin, not standalone MCP server)
|
||||
|
||||
**Host-Only MCP Servers:**
|
||||
- ✗ kicad-mcp: Requires KiCAD installed on host (pcbnew Python module unavailable in container)
|
||||
|
||||
**HTTP-based MCP Servers:**
|
||||
- None
|
||||
**HTTP-based REST API Servers:**
|
||||
- ✓ ghidra-mcp: Working (v1.9.4-headless) - 91 REST endpoints for binary analysis - NOT MCP protocol (uses HTTP REST)
|
||||
|
||||
**Pending Build:**
|
||||
- All other MCP servers pending build
|
||||
|
||||
**Recently Built:**
|
||||
- audiobook-mcp: Built (v1.1.0) - stdio-based, requires AUDIOBOOK_ROOT
|
||||
- bitwarden-mcp: Built (v2026.1.0) - stdio-based, requires Bitwarden credentials
|
||||
- blender-mcp: Built (v1.25.0) - stdio-based, Python-based, requires Blender with addon
|
||||
- cloudron-mcp: Built (v0.1.0) - stdio-based, requires CLOUDRON_URL
|
||||
- context7-mcp: Built (v2.1.0) - stdio-based, TypeScript-based, requires Upstash Redis
|
||||
- docker-mcp: Built (v0.1.0) - stdio-based, Python-based, requires Docker socket
|
||||
- drawio-mcp: Built (v1.4.0) - stdio-based, TypeScript/pnpm, requires DRAWIO_URL
|
||||
- docspace-mcp: Built (v3.1.0) - stdio-based, TypeScript/pnpm, official ONLYOFFICE repo, requires DOCSPACE_HOST/TOKEN
|
||||
- elasticsearch-mcp: Built (v0.2.1) - stdio-based, Rust-based, requires ES_URL
|
||||
- bash-language-server: Built (v5.6.0) - configured in crush.json via wrapper script
|
||||
- docker-language-server: Built (v0.0.0) - configured in crush.json via wrapper script
|
||||
- marksman: Built (2025-12-13) - configured in crush.json via wrapper script
|
||||
|
||||
**Builds in Progress:**
|
||||
- None
|
||||
|
||||
**Build Failures:**
|
||||
- None
|
||||
|
||||
**Missing Vendor Repositories:**
|
||||
- ✗ matomo-mcp: Cannot build - vendor repo `https://github.com/ahujasid/matomo-mcp-client.git` does not exist (404)
|
||||
- ✗ discourse-mcp: Cannot build - vendor repo `https://github.com/ahujasid/discourse-mcp.git` exists but is empty (no commits)
|
||||
|
||||
**Empty Vendor Repositories (ahujasid):**
|
||||
All the following ahujasid repositories exist but contain no code (empty repos with only .git folder):
|
||||
- ✗ kubernetes-mcp-server: Empty repo - `https://github.com/ahujasid/kubernetes-mcp-server.git`
|
||||
- ✗ proxmox-mcp: Empty repo - `https://github.com/ahujasid/ProxmoxMCP.git`
|
||||
- ✗ terraform-mcp: Empty repo - `https://github.com/ahujasid/terraform-mcp-server.git`
|
||||
- ✗ nextcloud-mcp: Empty repo - `https://github.com/ahujasid/nextcloud-mcp-server.git`
|
||||
- ✗ snipeit-mcp: Empty repo - `https://github.com/ahujasid/snipeit-mcp.git`
|
||||
- ✗ mcp-redmine: Empty repo - `https://github.com/ahujasid/mcp-redmine.git`
|
||||
- ✗ mcp-ansible: Empty repo - `https://github.com/ahujasid/mcp-ansible.git`
|
||||
- ✗ penpot-mcp: Empty repo - `https://github.com/ahujasid/penpot-mcp.git`
|
||||
- ✗ postizz-mcp: Empty repo - `https://github.com/ahujasid/postizz-MCP.git`
|
||||
**Pending Build/Validation:**
|
||||
- discourse-mcp
|
||||
- matomo-mcp
|
||||
- mcp-ansible
|
||||
- mcp-redmine
|
||||
- nextcloud-mcp
|
||||
- paperless-mcp
|
||||
- penpot-mcp
|
||||
- postizz-mcp
|
||||
- proxmox-mcp
|
||||
- reverse-engineering-assistant
|
||||
- snipeit-mcp
|
||||
- terraform-mcp
|
||||
|
||||
**LSP Servers:**
|
||||
- ✓ bash-language-server: Working (v5.6.0) - stdio-based, configured in crush.json
|
||||
- ✓ docker-language-server: Working (v0.0.0) - stdio-based, configured in crush.json
|
||||
- ✓ marksman: Working (2025-12-13) - stdio-based, configured in crush.json
|
||||
- ✓ terraform-ls: Working (v0.38.4) - stdio-based, configured in crush.json
|
||||
|
||||
## Detailed Status
|
||||
|
||||
| Repository | Status | Notes |
|
||||
|------------|--------|-------|
|
||||
| audiobook-mcp | Built | Container built from source (361MB). MCP stdio-based, requires AUDIOBOOK_ROOT env var. Fixed Dockerfile to use npm install instead of npm ci. Version 1.1.0. |
|
||||
| bitwarden-mcp | Built | Container built from source (377MB). Multi-stage distroless build. MCP stdio-based, requires Bitwarden credentials. Version 2026.1.0. |
|
||||
| audiobook-mcp | Built | Container built from source (361MB). MCP stdio-based, requires AUDIOBOOK_ROOT env var. Version 1.1.0. |
|
||||
| bitwarden-mcp | Built | Container built from bitwarden/mcp-server. MCP stdio-based, requires Bitwarden credentials. |
|
||||
| blender-mcp | Built | Container built from source (321MB). Python-based with uv package manager. MCP stdio-based, requires Blender running with addon. Version 1.25.0. |
|
||||
| cloudron-mcp | Built | Container built from source (374MB). Fixed Dockerfile CMD to use dist/server.js. MCP stdio-based, requires CLOUDRON_URL env var. Version 0.1.0. |
|
||||
| cloudron-mcp | Built | Container built from source (374MB). MCP stdio-based, requires CLOUDRON_URL env var. Version 0.1.0. |
|
||||
| context7-mcp | Built | Container built from source (224MB). Multi-stage Node.js build with tsc. MCP stdio-based, requires UPSTASH_REDIS_REST_URL and TOKEN env vars. Version 2.1.0. |
|
||||
| discourse-mcp | Pending Build | Official discourse/discourse-mcp repository cloned. Ready to build. |
|
||||
| docker-mcp | Built | Container built from Python source (188MB). Uses uv package manager. MCP stdio-based, requires Docker socket mount (/var/run/docker.sock). Version 0.1.0. |
|
||||
| docspace-mcp | Built | Container built from official ONLYOFFICE TypeScript source (236MB). Uses pnpm package manager. MCP stdio-based, requires DOCSPACE_HOST and DOCSPACE_TOKEN env vars. Version 3.1.0. |
|
||||
| drawio-mcp | Built | Container built from TypeScript source (302MB). Uses pnpm package manager. MCP stdio-based, requires DRAWIO_URL env var. Version 1.4.0. |
|
||||
| elasticsearch-mcp | Built | Container built from Rust source (22MB). Fixed Dockerfile to pass "stdio" subcommand. MCP stdio-based, requires ES_URL env var. NOTE: Server is deprecated. Version 0.2.1. |
|
||||
| freecad-mcp | Built | Container built from Python source (317MB). Uses uv package manager. MCP stdio-based, requires FreeCAD running with addon. Version 1.25.0. |
|
||||
| ghost-mcp | Built | Container built from TypeScript source (284MB). npm build with tsc. MCP stdio-based, requires Ghost CMS URL and API key. Version 1.0.0. |
|
||||
| gimp-mcp | Built | Container built from Python source (418MB). Uses uv package manager. Fixed Dockerfile to use python -m instead of uvx. MCP stdio-based, requires GIMP with server running. Version 1.10.1. |
|
||||
| imap-mcp | Built | Container built from Python source (317MB). Uses uv package manager. MCP stdio-based, requires working IMAP server (crashes on startup if IMAP unreachable). Version 0.1.0. |
|
||||
| kicad-mcp | Host-Only | Container builds successfully (463MB) but cannot run containerized. Requires KiCAD's pcbnew Python module which is only available with a KiCAD installation on the host. Cannot be pip-installed. Use on host machine only. |
|
||||
| matomo-mcp | Blocked | Cannot build - vendor repository does not exist. CloneVendorRepos.sh references https://github.com/ahujasid/matomo-mcp-client.git which returns 404. |
|
||||
| discourse-mcp | Blocked | Cannot build - vendor repository exists but is empty. CloneVendorRepos.sh references https://github.com/ahujasid/discourse-mcp.git which has no commits. |
|
||||
| kubernetes-mcp | Blocked | Cannot build - ahujasid/kubernetes-mcp-server repo is empty. Alternative: silenceper/mcp-k8s has content and Dockerfile. |
|
||||
| proxmox-mcp | Blocked | Cannot build - vendor repository https://github.com/ahujasid/ProxmoxMCP.git is empty (no code). |
|
||||
| terraform-mcp | Blocked | Cannot build - vendor repository https://github.com/ahujasid/terraform-mcp-server.git is empty (no code). |
|
||||
| nextcloud-mcp | Blocked | Cannot build - vendor repository https://github.com/ahujasid/nextcloud-mcp-server.git is empty (no code). |
|
||||
| snipeit-mcp | Blocked | Cannot build - vendor repository https://github.com/ahujasid/snipeit-mcp.git is empty (no code). |
|
||||
| mcp-redmine | Blocked | Cannot build - vendor repository https://github.com/ahujasid/mcp-redmine.git is empty (no code). |
|
||||
| mcp-ansible | Blocked | Cannot build - vendor repository https://github.com/ahujasid/mcp-ansible.git is empty (no code). |
|
||||
| penpot-mcp | Blocked | Cannot build - vendor repository https://github.com/ahujasid/penpot-mcp.git is empty (no code). |
|
||||
| postizz-mcp | Blocked | Cannot build - vendor repository https://github.com/ahujasid/postizz-MCP.git is empty (no code). |
|
||||
| bash-language-server | Built | Container built using prebuilt npm package (190MB). LSP configured in crush.json via wrapper script. Version 5.6.0. |
|
||||
| docker-language-server | Built | Container built from Go source (49.2MB). LSP configured in crush.json via wrapper script. Version 0.0.0. |
|
||||
| marksman | Built | Container built from prebuilt binary (144MB). LSP configured in crush.json via wrapper script. Version 2025-12-13. |
|
||||
| ghidra-mcp | Built | Container built from Java source (1.2GB). Multi-stage build with Ghidra 12.0.3. REST API server (NOT MCP protocol) - 91 endpoints for binary analysis. Version 1.9.4-headless. |
|
||||
| gimp-mcp | Built | Container built from Python source (418MB). Uses uv package manager. MCP stdio-based, requires GIMP with server running. Version 1.10.1. |
|
||||
| imap-mcp | Built | Container built from Python source (317MB). MCP stdio-based, requires working IMAP server (crashes on startup if IMAP unreachable). Version 0.1.0. |
|
||||
| kicad-mcp | Host-Only | Container builds successfully (463MB) but cannot run containerized. Requires KiCAD's pcbnew Python module which is only available with a KiCAD installation on the host. |
|
||||
| kubernetes-mcp | Built | Container built from Go source (67MB). MCP stdio-based, requires kubeconfig mounted at /root/.kube/config. Supports K8s resources and Helm operations. |
|
||||
| matomo-mcp | Pending Build | Official openmost/matomo-mcp-client repository cloned. Ready to build. |
|
||||
| mcp-ansible | Pending Build | Official bsahane/mcp-ansible repository cloned. Ready to build. |
|
||||
| mcp-redmine | Pending Build | Official runekaagaard/mcp-redmine repository cloned. Ready to build. |
|
||||
| nextcloud-mcp | Pending Build | Official cbcoutinho/nextcloud-mcp-server repository cloned. Ready to build. |
|
||||
| paperless-mcp | Pending Build | Official nloui/paperless-mcp repository cloned. Ready to build. |
|
||||
| penpot-mcp | Pending Build | Official penpot/penpot-mcp repository cloned. Ready to build. |
|
||||
| postizz-mcp | Pending Build | Official oculairmedia/postizz-MCP repository cloned. Ready to build. |
|
||||
| proxmox-mcp | Pending Build | Official canvrno/ProxmoxMCP repository cloned. Ready to build. |
|
||||
| reverse-engineering-assistant | Pending Build | Official cyberkaida/reverse-engineering-assistant repository cloned. Dockerfile created, pending build/test. |
|
||||
| snipeit-mcp | Pending Build | Official Wil-Collier/snipeit-mcp repository cloned. Ready to build. |
|
||||
| terraform-mcp | Pending Build | Official hashicorp/terraform-mcp-server repository cloned. Ready to build. |
|
||||
| webserial-mcp | Built | Container built from Python source. MCP stdio-based, requires bridge server + browser + ESP32 hardware. |
|
||||
| wordpress-mcp | Blocked | Cannot build as standalone MCP server. The WordPress MCP Adapter is a PHP plugin that must be installed within a running WordPress instance. |
|
||||
| bash-language-server | Built | Container built using prebuilt npm package (190MB). LSP configured in crush.json. Version 5.6.0. |
|
||||
| docker-language-server | Built | Container built from Go source (49.2MB). LSP configured in crush.json. Version 0.0.0. |
|
||||
| marksman | Built | Container built from prebuilt binary (144MB). LSP configured in crush.json. Version 2025-12-13. |
|
||||
| terraform-ls | Built | Container built from HashiCorp binary (64MB). LSP configured in crush.json. Version 0.38.4. |
|
||||
|
||||
## Known Issues
|
||||
|
||||
### Empty ahujasid Repositories (2026-02-17)
|
||||
Investigation revealed that most ahujasid vendor repositories are empty (contain only .git folder, no code):
|
||||
- kubernetes-mcp-server, ProxmoxMCP, terraform-mcp-server, nextcloud-mcp-server, snipeit-mcp, mcp-redmine, mcp-ansible, penpot-mcp, postizz-MCP
|
||||
- discourse-mcp (previously documented) - also empty
|
||||
- matomo-mcp-client - repo doesn't exist (404)
|
||||
### imap-mcp
|
||||
Server crashes on startup if IMAP connection fails. Server tries to connect to IMAP during lifespan context entry. If connection fails, server raises ConnectionError and exits before responding to JSON-RPC initialize.
|
||||
|
||||
These repos cannot be used to build MCP containers. Alternative sources or official repos should be identified.
|
||||
### webserial-mcp
|
||||
Requires bridge server (esp32_bridge_server.py) running on host at ws://host.docker.internal:3000 plus browser with WebSerial access and ESP32 hardware.
|
||||
|
||||
### Alternative Repositories Available
|
||||
- kubernetes-mcp: Use silenceper/mcp-k8s instead (has content and Dockerfile)
|
||||
### kicad-mcp
|
||||
Host-only - requires KiCAD installed on the host machine. The pcbnew Python module cannot be pip-installed and is only available with a full KiCAD installation.
|
||||
|
||||
### Previously Documented Issues
|
||||
- matomo-mcp: Vendor repository does not exist. The CloneVendorRepos.sh references `https://github.com/ahujasid/matomo-mcp-client.git` which returns 404. Unable to build until a valid source is identified.
|
||||
- discourse-mcp: Vendor repository exists but is empty. The CloneVendorRepos.sh references `https://github.com/ahujasid/discourse-mcp.git` which has no commits. Unable to build until repository has content.
|
||||
### wordpress-mcp
|
||||
The WordPress MCP Adapter is a PHP plugin that must be installed within a running WordPress instance. It requires WordPress + Abilities API plugin + MCP Adapter plugin. Not suitable for containerized standalone deployment.
|
||||
|
||||
### discourse-mcp
|
||||
Build may fail with TypeScript errors in upstream repository. Pending validation.
|
||||
|
||||
## Usage
|
||||
|
||||
@@ -146,11 +170,4 @@ To rebuild a server after changes:
|
||||
docker compose build --no-cache <service-name>
|
||||
```
|
||||
|
||||
To test MCP server with Crush:
|
||||
```bash
|
||||
# Stdio-based servers are run on-demand by Crush
|
||||
# Configuration is in crush.json
|
||||
# Crush automatically handles docker run -i --rm
|
||||
```
|
||||
|
||||
Note: Use lowercase service names from compose file. Container names will be prefixed with kneldevstack-aimiddleware-.
|
||||
|
||||
95
crush.json
95
crush.json
@@ -2,79 +2,142 @@
|
||||
"$schema": "https://charm.land/crush.json",
|
||||
"lsp": {
|
||||
"bash": {
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/lsp-bash-wrapper.sh"
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/lsp-bash-wrapper.sh"
|
||||
},
|
||||
"docker": {
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/lsp-docker-wrapper.sh"
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/lsp-docker-wrapper.sh"
|
||||
},
|
||||
"markdown": {
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/lsp-marksman-wrapper.sh"
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/lsp-marksman-wrapper.sh"
|
||||
},
|
||||
"terraform": {
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/lsp-terraform-wrapper.sh"
|
||||
}
|
||||
},
|
||||
"mcp": {
|
||||
"audiobook": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-audiobook-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-audiobook-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"bitwarden": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-bitwarden-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-bitwarden-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"blender": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-blender-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-blender-wrapper.sh",
|
||||
"timeout": 180
|
||||
},
|
||||
"cloudron": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-cloudron-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-cloudron-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"context7": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-context7-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-context7-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"docker": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-docker-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-docker-wrapper.sh",
|
||||
"timeout": 180
|
||||
},
|
||||
"drawio": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-drawio-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-drawio-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"elasticsearch": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-elasticsearch-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-elasticsearch-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"freecad": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-freecad-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-freecad-wrapper.sh",
|
||||
"timeout": 180
|
||||
},
|
||||
"ghost": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-ghost-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-ghost-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"gimp": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-gimp-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-gimp-wrapper.sh",
|
||||
"timeout": 180
|
||||
},
|
||||
"imap": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-imap-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-imap-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"kubernetes": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-kubernetes-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"docspace": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL/KNEL-AIMiddleware/mcp-docspace-wrapper.sh",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-docspace-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"webserial": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-webserial-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"proxmox": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-proxmox-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"terraform": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-terraform-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"nextcloud": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-nextcloud-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"matomo": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-matomo-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"snipeit": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-snipeit-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"redmine": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-redmine-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"ansible": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-ansible-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"postizz": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-postizz-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"discourse": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-discourse-wrapper.sh",
|
||||
"timeout": 60
|
||||
},
|
||||
"penpot": {
|
||||
"type": "stdio",
|
||||
"command": "/home/charles/Projects/KNEL-AIMiddleware/mcp-penpot-wrapper.sh",
|
||||
"timeout": 60
|
||||
}
|
||||
}
|
||||
|
||||
@@ -26,7 +26,7 @@ services:
|
||||
image: kneldevstack-aimiddleware-blender-mcp
|
||||
build:
|
||||
context: ./vendor/blender-mcp
|
||||
dockerfile: Dockerfile
|
||||
dockerfile: ../../dockerfiles/blender-mcp/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-blender-mcp
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
@@ -39,7 +39,7 @@ services:
|
||||
image: kneldevstack-aimiddleware-freecad-mcp
|
||||
build:
|
||||
context: ./vendor/freecad-mcp
|
||||
dockerfile: Dockerfile
|
||||
dockerfile: ../../dockerfiles/freecad-mcp/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-freecad-mcp
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
@@ -47,6 +47,23 @@ services:
|
||||
profiles:
|
||||
- dev
|
||||
|
||||
# ESP32 WebSerial MCP - MicroPython development via WebSerial
|
||||
# NOTE: Requires bridge server running on host (esp32_bridge_server.py)
|
||||
# and browser with WebSerial connected to ESP32
|
||||
webserial-mcp:
|
||||
image: kneldevstack-aimiddleware-webserial-mcp
|
||||
build:
|
||||
context: ./vendor/webserial-mcp
|
||||
dockerfile: ../../dockerfiles/webserial-mcp/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-webserial-mcp
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
- PYTHONUNBUFFERED=1
|
||||
- WEBSOCKET_URL=ws://host.docker.internal:3000
|
||||
- MCP_TIMEOUT=30
|
||||
profiles:
|
||||
- dev
|
||||
|
||||
# ==========================================
|
||||
# Hosting & Infrastructure (5 servers)
|
||||
# ==========================================
|
||||
@@ -59,8 +76,6 @@ services:
|
||||
dockerfile: Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-kubernetes-mcp
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- "8081:8080"
|
||||
volumes:
|
||||
- ~/.kube/config:/root/.kube/config:ro
|
||||
profiles:
|
||||
@@ -71,7 +86,7 @@ services:
|
||||
image: kneldevstack-aimiddleware-docker-mcp
|
||||
build:
|
||||
context: ./vendor/docker-mcp
|
||||
dockerfile: Dockerfile
|
||||
dockerfile: ../../dockerfiles/docker-mcp/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-docker-mcp
|
||||
restart: unless-stopped
|
||||
volumes:
|
||||
@@ -132,7 +147,7 @@ services:
|
||||
- ops
|
||||
|
||||
# ==========================================
|
||||
# Development Tools (2 servers)
|
||||
# Development Tools (3 servers)
|
||||
# ==========================================
|
||||
|
||||
# Bash Language Server - LSP for bash
|
||||
@@ -147,6 +162,18 @@ services:
|
||||
profiles:
|
||||
- dev
|
||||
|
||||
# Terraform Language Server - LSP for Terraform
|
||||
# NOTE: This is a stdio-based LSP server, run on-demand by Crush via docker run
|
||||
terraform-ls:
|
||||
image: kneldevstack-aimiddleware-terraform-ls
|
||||
build:
|
||||
context: .
|
||||
dockerfile: dockerfiles/terraform-ls/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-terraform-ls
|
||||
restart: "no"
|
||||
profiles:
|
||||
- dev
|
||||
|
||||
# Context7 MCP - Documentation framework
|
||||
# NOTE: This is a stdio-based MCP server, run on-demand by Crush via docker run
|
||||
context7-mcp:
|
||||
@@ -217,7 +244,7 @@ services:
|
||||
image: kneldevstack-aimiddleware-wordpress-mcp
|
||||
build:
|
||||
context: ./vendor/mcp-adapter
|
||||
dockerfile: Dockerfile
|
||||
dockerfile: ../../dockerfiles/wordpress-mcp/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-wordpress-mcp
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
@@ -288,7 +315,7 @@ services:
|
||||
image: kneldevstack-aimiddleware-matomo-mcp
|
||||
build:
|
||||
context: ./vendor/matomo-mcp-client
|
||||
dockerfile: Dockerfile
|
||||
dockerfile: ../../dockerfiles/matomo-mcp/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-matomo-mcp
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
@@ -302,7 +329,7 @@ services:
|
||||
image: kneldevstack-aimiddleware-bitwarden-mcp
|
||||
build:
|
||||
context: ./vendor/mcp-server
|
||||
dockerfile: Dockerfile
|
||||
dockerfile: ../../dockerfiles/bitwarden-mcp/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-bitwarden-mcp
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
@@ -335,8 +362,8 @@ services:
|
||||
snipeit-mcp:
|
||||
image: kneldevstack-aimiddleware-snipeit-mcp
|
||||
build:
|
||||
context: ./vendor/snipeit-mcp
|
||||
dockerfile: Dockerfile
|
||||
context: ./vendor
|
||||
dockerfile: ../dockerfiles/snipeit-mcp/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-snipeit-mcp
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
@@ -368,7 +395,7 @@ services:
|
||||
image: kneldevstack-aimiddleware-mcp-ansible
|
||||
build:
|
||||
context: ./vendor/mcp-ansible
|
||||
dockerfile: Dockerfile
|
||||
dockerfile: ../../dockerfiles/mcp-ansible/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-mcp-ansible
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
@@ -472,3 +499,52 @@ services:
|
||||
- PENPOT_TOKEN=${PENPOT_TOKEN}
|
||||
profiles:
|
||||
- dev
|
||||
|
||||
# ==========================================
|
||||
# Reverse Engineering (2 servers)
|
||||
# ==========================================
|
||||
|
||||
# Ghidra MCP - Binary analysis and reverse engineering
|
||||
# NOTE: Requires Ghidra 12.0.2 (downloaded during build, ~300MB)
|
||||
# Uses bridge_mcp_ghidra.py for stdio transport
|
||||
ghidra-mcp:
|
||||
image: kneldevstack-aimiddleware-ghidra-mcp
|
||||
build:
|
||||
context: ./vendor/ghidra-mcp
|
||||
dockerfile: docker/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-ghidra-mcp
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
- GHIDRA_MCP_PORT=8089
|
||||
- JAVA_OPTS=-Xmx4g -XX:+UseG1GC
|
||||
volumes:
|
||||
- ghidra-projects:/projects
|
||||
- ghidra-data:/data
|
||||
ports:
|
||||
- "8089:8089"
|
||||
profiles:
|
||||
- dev
|
||||
|
||||
# ReVa - Reverse Engineering Assistant (MCP for Ghidra)
|
||||
# NOTE: Requires Ghidra 12.0+ and Java 21
|
||||
# Runs in headless mode for containerized AI-assisted reverse engineering
|
||||
reverse-engineering-assistant:
|
||||
image: kneldevstack-aimiddleware-reverse-engineering-assistant
|
||||
build:
|
||||
context: ./vendor/reverse-engineering-assistant
|
||||
dockerfile: ../../dockerfiles/reverse-engineering-assistant/Dockerfile
|
||||
container_name: kneldevstack-aimiddleware-reverse-engineering-assistant
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
- GHIDRA_INSTALL_DIR=/opt/ghidra
|
||||
- REVA_MODE=headless
|
||||
- JAVA_OPTS=-Xmx4g -XX:+UseG1GC
|
||||
volumes:
|
||||
- ghidra-projects:/projects
|
||||
- ghidra-data:/data
|
||||
profiles:
|
||||
- dev
|
||||
|
||||
volumes:
|
||||
ghidra-projects:
|
||||
ghidra-data:
|
||||
|
||||
14
dockerfiles/bitwarden-mcp/Dockerfile
Normal file
14
dockerfiles/bitwarden-mcp/Dockerfile
Normal file
@@ -0,0 +1,14 @@
|
||||
FROM node:22-slim
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Install dependencies for running npx
|
||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
ca-certificates \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# Set up environment
|
||||
ENV NODE_ENV=production
|
||||
|
||||
# The Bitwarden MCP server is run via npx
|
||||
ENTRYPOINT ["npx", "-y", "@bitwarden/mcp-server"]
|
||||
@@ -5,20 +5,14 @@ COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Copy dependency files
|
||||
COPY pyproject.toml ./
|
||||
|
||||
# Install dependencies
|
||||
RUN uv sync --frozen --no-dev --no-install-project --no-cache
|
||||
|
||||
# Copy source code
|
||||
COPY . .
|
||||
|
||||
# Install the project
|
||||
RUN uv sync --frozen --no-dev --no-editable --no-cache
|
||||
# Install the project with uv
|
||||
RUN uv venv && uv pip install --no-cache -e .
|
||||
|
||||
# Set up environment
|
||||
ENV PYTHONUNBUFFERED=1
|
||||
ENV PATH=/app/.venv/bin:$PATH
|
||||
|
||||
ENTRYPOINT ["uvx", "blender-mcp"]
|
||||
ENTRYPOINT ["python", "-m", "blender_mcp.server"]
|
||||
|
||||
@@ -6,7 +6,7 @@ COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/
|
||||
WORKDIR /app
|
||||
|
||||
# Copy dependency files
|
||||
COPY pyproject.toml ./
|
||||
COPY pyproject.toml uv.lock ./
|
||||
|
||||
# Install dependencies
|
||||
RUN uv sync --frozen --no-dev --no-install-project --no-cache
|
||||
|
||||
@@ -5,20 +5,14 @@ COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Copy dependency files
|
||||
COPY pyproject.toml ./
|
||||
|
||||
# Install dependencies
|
||||
RUN uv sync --frozen --no-dev --no-install-project --no-cache
|
||||
|
||||
# Copy source code
|
||||
COPY . .
|
||||
|
||||
# Install the project
|
||||
RUN uv sync --frozen --no-dev --no-editable --no-cache
|
||||
# Install the project with uv
|
||||
RUN uv venv && uv pip install --no-cache -e .
|
||||
|
||||
# Set up environment
|
||||
ENV PYTHONUNBUFFERED=1
|
||||
ENV PATH=/app/.venv/bin:$PATH
|
||||
|
||||
ENTRYPOINT ["uvx", "freecad-mcp"]
|
||||
ENTRYPOINT ["python", "-m", "freecad_mcp.server"]
|
||||
|
||||
@@ -4,10 +4,8 @@ WORKDIR /app
|
||||
|
||||
COPY package.json package-lock.json* ./
|
||||
|
||||
RUN npm ci
|
||||
RUN npm install
|
||||
|
||||
COPY . .
|
||||
|
||||
RUN npm run build
|
||||
|
||||
CMD ["node", "dist/index.js"]
|
||||
CMD ["node", "matomo-mcp-client.js"]
|
||||
|
||||
18
dockerfiles/mcp-ansible/Dockerfile
Normal file
18
dockerfiles/mcp-ansible/Dockerfile
Normal file
@@ -0,0 +1,18 @@
|
||||
FROM python:3.12-slim
|
||||
|
||||
# Install uv for faster package management
|
||||
COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Copy source code
|
||||
COPY . .
|
||||
|
||||
# Install the project with uv
|
||||
RUN uv venv && uv pip install --no-cache -e .
|
||||
|
||||
# Set up environment
|
||||
ENV PYTHONUNBUFFERED=1
|
||||
ENV PATH=/app/.venv/bin:$PATH
|
||||
|
||||
ENTRYPOINT ["uvx", "mcp-ansible"]
|
||||
25
dockerfiles/paperless-mcp/Dockerfile
Normal file
25
dockerfiles/paperless-mcp/Dockerfile
Normal file
@@ -0,0 +1,25 @@
|
||||
# Paperless-NGX MCP Server
|
||||
# https://github.com/nloui/paperless-mcp
|
||||
|
||||
FROM node:20-slim AS builder
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
COPY package.json package-lock.json ./
|
||||
RUN npm ci
|
||||
|
||||
COPY . .
|
||||
RUN npm run build
|
||||
|
||||
FROM node:20-slim AS production
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
COPY --from=builder /app/build ./build
|
||||
COPY --from=builder /app/node_modules ./node_modules
|
||||
COPY --from=builder /app/package.json ./package.json
|
||||
|
||||
ENV PAPERLESS_URL=""
|
||||
ENV PAPERLESS_TOKEN=""
|
||||
|
||||
ENTRYPOINT ["node", "build/index.js"]
|
||||
1
dockerfiles/postizz-mcp/Dockerfile
Symbolic link
1
dockerfiles/postizz-mcp/Dockerfile
Symbolic link
@@ -0,0 +1 @@
|
||||
../../vendor/postizz-MCP/Dockerfile
|
||||
47
dockerfiles/reverse-engineering-assistant/Dockerfile
Normal file
47
dockerfiles/reverse-engineering-assistant/Dockerfile
Normal file
@@ -0,0 +1,47 @@
|
||||
# ReVa (Reverse Engineering Assistant) MCP Server
|
||||
# Ghidra extension providing MCP server for AI-assisted reverse engineering
|
||||
# https://github.com/cyberkaida/reverse-engineering-assistant
|
||||
|
||||
FROM eclipse-temurin:21-jdk-jammy AS builder
|
||||
|
||||
ARG GHIDRA_VERSION=11.2.1
|
||||
ARG GHIDRA_SHA256=1234567890abcdef
|
||||
|
||||
ENV DEBIAN_FRONTEND=noninteractive
|
||||
ENV GHIDRA_INSTALL_DIR=/opt/ghidra
|
||||
|
||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
wget \
|
||||
unzip \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
WORKDIR /build
|
||||
|
||||
COPY . /build/reva
|
||||
|
||||
RUN wget -q "https://github.com/NationalSecurityAgency/ghidra/releases/download/Ghidra_${GHIDRA_VERSION}_build/ghidra_${GHIDRA_VERSION}_PUBLIC.zip" \
|
||||
-O /tmp/ghidra.zip \
|
||||
&& unzip -q /tmp/ghidra.zip -d /opt \
|
||||
&& mv /opt/ghidra_${GHIDRA_VERSION}_PUBLIC /opt/ghidra \
|
||||
&& rm /tmp/ghidra.zip
|
||||
|
||||
WORKDIR /build/reva
|
||||
|
||||
RUN ./gradlew buildExtension -x test || true
|
||||
|
||||
FROM eclipse-temurin:21-jre-jammy
|
||||
|
||||
ENV GHIDRA_INSTALL_DIR=/opt/ghidra
|
||||
ENV REVA_MODE=headless
|
||||
ENV JAVA_OPTS=-Xmx4g
|
||||
|
||||
COPY --from=builder /opt/ghidra /opt/ghidra
|
||||
COPY --from=builder /build/reva /opt/reva
|
||||
|
||||
WORKDIR /opt/reva
|
||||
|
||||
RUN mkdir -p /projects /data
|
||||
|
||||
VOLUME ["/projects", "/data"]
|
||||
|
||||
ENTRYPOINT ["/bin/bash", "-c", "java $JAVA_OPTS -jar /opt/reva/build/libs/*.jar"]
|
||||
@@ -5,20 +5,17 @@ COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Copy dependency files
|
||||
COPY pyproject.toml ./
|
||||
# Copy the main project
|
||||
COPY snipeit-mcp /app/
|
||||
|
||||
# Install dependencies
|
||||
RUN uv sync --frozen --no-dev --no-install-project --no-cache
|
||||
# Replace local snipeit-api dependency with PyPI package
|
||||
RUN sed -i 's|snipeit-api @ file:///Users/work/Documents/Projects/Inventory/snipeit-python-api|snipeit>=1.1|g' pyproject.toml
|
||||
|
||||
# Copy source code
|
||||
COPY . .
|
||||
|
||||
# Install the project
|
||||
RUN uv sync --frozen --no-dev --no-editable --no-cache
|
||||
# Install the project with uv
|
||||
RUN uv venv && uv pip install --no-cache -e .
|
||||
|
||||
# Set up environment
|
||||
ENV PYTHONUNBUFFERED=1
|
||||
ENV PATH=/app/.venv/bin:$PATH
|
||||
|
||||
ENTRYPOINT ["uvx", "snipeit-mcp"]
|
||||
ENTRYPOINT ["python", "-m", "snipeit_mcp"]
|
||||
|
||||
27
dockerfiles/terraform-ls/Dockerfile
Normal file
27
dockerfiles/terraform-ls/Dockerfile
Normal file
@@ -0,0 +1,27 @@
|
||||
# Terraform Language Server (terraform-ls)
|
||||
# Official HashiCorp LSP for Terraform
|
||||
# https://github.com/hashicorp/terraform-ls
|
||||
|
||||
FROM alpine:3.18
|
||||
|
||||
# Install dependencies
|
||||
RUN apk add --no-cache \
|
||||
curl \
|
||||
ca-certificates \
|
||||
git \
|
||||
unzip
|
||||
|
||||
# Install terraform-ls
|
||||
ARG TERRAFORM_LS_VERSION=0.38.4
|
||||
RUN curl -fsSL https://releases.hashicorp.com/terraform-ls/${TERRAFORM_LS_VERSION}/terraform-ls_${TERRAFORM_LS_VERSION}_linux_amd64.zip \
|
||||
-o terraform-ls.zip && \
|
||||
unzip terraform-ls.zip && \
|
||||
mv terraform-ls /usr/local/bin/ && \
|
||||
chmod +x /usr/local/bin/terraform-ls && \
|
||||
rm terraform-ls.zip
|
||||
|
||||
# Set up working directory
|
||||
WORKDIR /workspace
|
||||
|
||||
# Run terraform-ls in stdio mode
|
||||
ENTRYPOINT ["terraform-ls", "serve"]
|
||||
26
dockerfiles/webserial-mcp/Dockerfile
Normal file
26
dockerfiles/webserial-mcp/Dockerfile
Normal file
@@ -0,0 +1,26 @@
|
||||
# ESP32 WebSerial MCP Bridge
|
||||
# This MCP requires the bridge server to be running and a browser+ESP32 connected
|
||||
|
||||
FROM python:3.11-slim
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Install dependencies
|
||||
COPY requirements.txt .
|
||||
RUN pip install --no-cache-dir -r requirements.txt && \
|
||||
pip install --no-cache-dir nest-asyncio
|
||||
|
||||
# Copy application files
|
||||
COPY mcp_handler.py .
|
||||
COPY mcp_client.py .
|
||||
COPY esp32_bridge_server.py .
|
||||
COPY templates/ templates/
|
||||
|
||||
# Environment variables
|
||||
ENV PYTHONUNBUFFERED=1
|
||||
ENV WEBSOCKET_URL=ws://localhost:3000
|
||||
ENV MCP_TIMEOUT=30
|
||||
|
||||
# Default entrypoint is the MCP client (stdio-based)
|
||||
ENTRYPOINT ["python", "mcp_client.py"]
|
||||
CMD ["ws://host.docker.internal:3000"]
|
||||
@@ -1,13 +1,2 @@
|
||||
FROM node:22-alpine
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
COPY package.json package-lock.json* ./
|
||||
|
||||
RUN npm ci
|
||||
|
||||
COPY . .
|
||||
|
||||
RUN npm run build
|
||||
|
||||
CMD ["node", "dist/index.js"]
|
||||
FROM node:22-slim
|
||||
ENTRYPOINT ["npx", "-y", "@wordpress/mcp-adapter"]
|
||||
|
||||
4
lsp-terraform-wrapper.sh
Executable file
4
lsp-terraform-wrapper.sh
Executable file
@@ -0,0 +1,4 @@
|
||||
#!/bin/bash
|
||||
docker run -i --rm \
|
||||
-v "$(pwd):/workspace" \
|
||||
kneldevstack-aimiddleware-terraform-ls
|
||||
21
mcp-ansible-wrapper.sh
Executable file
21
mcp-ansible-wrapper.sh
Executable file
@@ -0,0 +1,21 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for mcp-ansible
|
||||
# Ensures clean container with proper name, playbooks mount, and Docker socket
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-mcp-ansible-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-mcp-ansible"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name, playbooks mount, and Docker socket
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-v "${HOME}/Projects/KNEL/KNEL-AIMiddleware/ansible-playbooks:/playbooks:ro" \
|
||||
-v /var/run/docker.sock:/var/run/docker.sock \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
22
mcp-discourse-wrapper.sh
Executable file
22
mcp-discourse-wrapper.sh
Executable file
@@ -0,0 +1,22 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for discourse-mcp
|
||||
# Ensures clean container with proper name
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-discourse-mcp-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-discourse-mcp"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and environment variables
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-e "DISCOURSE_URL=${DISCOURSE_URL:-}" \
|
||||
-e "DISCOURSE_API_KEY=${DISCOURSE_API_KEY:-}" \
|
||||
-e "DISCOURSE_API_USERNAME=${DISCOURSE_API_USERNAME:-}" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
5
mcp-kubernetes-wrapper.sh
Executable file
5
mcp-kubernetes-wrapper.sh
Executable file
@@ -0,0 +1,5 @@
|
||||
#!/bin/bash
|
||||
docker run -i --rm \
|
||||
-v ~/.kube/config:/root/.kube/config:ro \
|
||||
kneldevstack-aimiddleware-kubernetes-mcp \
|
||||
--transport stdio
|
||||
21
mcp-matomo-wrapper.sh
Executable file
21
mcp-matomo-wrapper.sh
Executable file
@@ -0,0 +1,21 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for matomo-mcp
|
||||
# Ensures clean container with proper name
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-matomo-mcp-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-matomo-mcp"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and environment variables
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-e "MATOMO_URL=${MATOMO_URL:-}" \
|
||||
-e "MATOMO_TOKEN=${MATOMO_TOKEN:-}" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
22
mcp-nextcloud-wrapper.sh
Executable file
22
mcp-nextcloud-wrapper.sh
Executable file
@@ -0,0 +1,22 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for nextcloud-mcp
|
||||
# Ensures clean container with proper name
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-nextcloud-mcp-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-nextcloud-mcp"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and environment variables
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-e "NEXTCLOUD_HOST=${NEXTCLOUD_HOST:-}" \
|
||||
-e "NEXTCLOUD_USERNAME=${NEXTCLOUD_USERNAME:-}" \
|
||||
-e "NEXTCLOUD_PASSWORD=${NEXTCLOUD_PASSWORD:-}" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
21
mcp-penpot-wrapper.sh
Executable file
21
mcp-penpot-wrapper.sh
Executable file
@@ -0,0 +1,21 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for penpot-mcp
|
||||
# Ensures clean container with proper name
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-penpot-mcp-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-penpot-mcp"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and environment variables
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-e "PENPOT_URL=${PENPOT_URL:-https://design.penpot.app}" \
|
||||
-e "PENPOT_TOKEN=${PENPOT_TOKEN:-}" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
21
mcp-postizz-wrapper.sh
Executable file
21
mcp-postizz-wrapper.sh
Executable file
@@ -0,0 +1,21 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for postizz-mcp
|
||||
# Ensures clean container with proper name
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-postizz-mcp-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-postizz-mcp"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and environment variables
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-e "POSTIZ_API_KEY=${POSTIZ_API_KEY:-}" \
|
||||
-e "POSTIZ_URL=${POSTIZ_URL:-}" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
23
mcp-proxmox-wrapper.sh
Executable file
23
mcp-proxmox-wrapper.sh
Executable file
@@ -0,0 +1,23 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for proxmox-mcp
|
||||
# Ensures clean container with proper name
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-proxmox-mcp-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-proxmox-mcp"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and environment variables
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-e "PROXMOX_HOST=${PROXMOX_HOST:-}" \
|
||||
-e "PROXMOX_USER=${PROXMOX_USER:-}" \
|
||||
-e "PROXMOX_TOKEN=${PROXMOX_TOKEN:-}" \
|
||||
-e "PROXMOX_NODE=${PROXMOX_NODE:-}" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
21
mcp-redmine-wrapper.sh
Executable file
21
mcp-redmine-wrapper.sh
Executable file
@@ -0,0 +1,21 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for mcp-redmine
|
||||
# Ensures clean container with proper name
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-mcp-redmine-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-mcp-redmine"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and environment variables
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-e "REDMINE_URL=${REDMINE_URL:-}" \
|
||||
-e "REDMINE_API_KEY=${REDMINE_API_KEY:-}" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
21
mcp-snipeit-wrapper.sh
Executable file
21
mcp-snipeit-wrapper.sh
Executable file
@@ -0,0 +1,21 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for snipeit-mcp
|
||||
# Ensures clean container with proper name
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-snipeit-mcp-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-snipeit-mcp"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and environment variables
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-e "SNIPEIT_URL=${SNIPEIT_URL:-}" \
|
||||
-e "SNIPEIT_TOKEN=${SNIPEIT_TOKEN:-}" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
20
mcp-terraform-wrapper.sh
Executable file
20
mcp-terraform-wrapper.sh
Executable file
@@ -0,0 +1,20 @@
|
||||
#!/bin/sh
|
||||
# Wrapper script for terraform-mcp
|
||||
# Ensures clean container with proper name and Terraform credentials
|
||||
|
||||
CONTAINER_NAME="kneldevstack-aimiddleware-terraform-mcp-crush"
|
||||
IMAGE_NAME="kneldevstack-aimiddleware-terraform-mcp"
|
||||
|
||||
# Force remove existing container if it exists (in any state)
|
||||
if docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; then
|
||||
docker rm -f "${CONTAINER_NAME}" >/dev/null 2>&1
|
||||
# Wait for container to be fully removed
|
||||
while docker ps -a --filter "name=${CONTAINER_NAME}" --format '{{.Names}}' 2>/dev/null | grep -q "^${CONTAINER_NAME}$"; do
|
||||
sleep 0.05
|
||||
done
|
||||
fi
|
||||
|
||||
# Start MCP server with explicit name and Terraform credential mounts
|
||||
exec docker run -i --rm --name "${CONTAINER_NAME}" \
|
||||
-v "${HOME}/.terraform.d:/terraform/.terraform.d:ro" \
|
||||
"${IMAGE_NAME}" "$@"
|
||||
4
mcp-webserial-wrapper.sh
Executable file
4
mcp-webserial-wrapper.sh
Executable file
@@ -0,0 +1,4 @@
|
||||
#!/bin/bash
|
||||
docker run -i --rm \
|
||||
kneldevstack-aimiddleware-webserial-mcp \
|
||||
ws://host.docker.internal:3000
|
||||
@@ -50,33 +50,37 @@ clone_repo() {
|
||||
# Clone all repositories
|
||||
clone_repo "KiCAD-MCP-Server" "https://github.com/mixelpixx/KiCAD-MCP-Server.git"
|
||||
clone_repo "blender-mcp" "https://github.com/ahujasid/blender-mcp.git"
|
||||
clone_repo "freecad-mcp" "https://github.com/ahujasid/freecad-mcp.git"
|
||||
clone_repo "freecad-mcp" "https://github.com/neka-nat/freecad-mcp.git"
|
||||
clone_repo "context7" "https://github.com/upstash/context7.git"
|
||||
clone_repo "gimp-mcp" "https://github.com/ahujasid/gimp-mcp.git"
|
||||
clone_repo "gimp-mcp" "https://github.com/maorcc/gimp-mcp.git"
|
||||
clone_repo "bash-language-server" "https://github.com/bash-lsp/bash-language-server.git"
|
||||
clone_repo "docker-language-server" "https://github.com/rcjsuen/docker-language-server.git"
|
||||
clone_repo "docker-language-server" "https://github.com/docker/docker-language-server.git"
|
||||
clone_repo "marksman" "https://github.com/artempyanykh/marksman.git"
|
||||
clone_repo "drawio-mcp-server" "https://github.com/ahujasid/drawio-mcp-server.git"
|
||||
clone_repo "matomo-mcp-client" "https://github.com/ahujasid/matomo-mcp-client.git"
|
||||
clone_repo "imap-mcp" "https://github.com/ahujasid/imap-mcp.git"
|
||||
clone_repo "mcp-redmine" "https://github.com/ahujasid/mcp-redmine.git"
|
||||
clone_repo "ghost-mcp" "https://github.com/ahujasid/ghost-mcp.git"
|
||||
clone_repo "discourse-mcp" "https://github.com/ahujasid/discourse-mcp.git"
|
||||
clone_repo "mcp-cloudron" "https://github.com/ahujasid/mcp-cloudron.git"
|
||||
clone_repo "postizz-MCP" "https://github.com/ahujasid/postizz-MCP.git"
|
||||
clone_repo "snipeit-mcp" "https://github.com/ahujasid/snipeit-mcp.git"
|
||||
clone_repo "nextcloud-mcp-server" "https://github.com/ahujasid/nextcloud-mcp-server.git"
|
||||
clone_repo "drawio-mcp-server" "https://github.com/lgazo/drawio-mcp-server.git"
|
||||
clone_repo "matomo-mcp-client" "https://github.com/openmost/matomo-mcp-client.git"
|
||||
clone_repo "imap-mcp" "https://github.com/non-dirty/imap-mcp.git"
|
||||
clone_repo "mcp-redmine" "https://github.com/runekaagaard/mcp-redmine.git"
|
||||
clone_repo "ghost-mcp" "https://github.com/MFYDev/ghost-mcp.git"
|
||||
clone_repo "discourse-mcp" "https://github.com/discourse/discourse-mcp.git"
|
||||
clone_repo "mcp-cloudron" "https://github.com/serenichron/mcp-cloudron.git"
|
||||
clone_repo "postizz-MCP" "https://github.com/oculairmedia/postizz-MCP.git"
|
||||
clone_repo "snipeit-mcp" "https://github.com/Wil-Collier/snipeit-mcp.git"
|
||||
clone_repo "nextcloud-mcp-server" "https://github.com/cbcoutinho/nextcloud-mcp-server.git"
|
||||
clone_repo "docspace-mcp" "https://github.com/ONLYOFFICE/docspace-mcp.git"
|
||||
clone_repo "docker-mcp" "https://github.com/ahujasid/docker-mcp.git"
|
||||
clone_repo "kubernetes-mcp-server" "https://github.com/ahujasid/kubernetes-mcp-server.git"
|
||||
clone_repo "ProxmoxMCP" "https://github.com/ahujasid/ProxmoxMCP.git"
|
||||
clone_repo "terraform-mcp-server" "https://github.com/ahujasid/terraform-mcp-server.git"
|
||||
clone_repo "mcp-ansible" "https://github.com/ahujasid/mcp-ansible.git"
|
||||
clone_repo "mcp-server" "https://github.com/Bitwarden/clients.git"
|
||||
clone_repo "mcp-adapter" "https://github.com/ahujasid/mcp-adapter.git"
|
||||
clone_repo "audiobook-mcp-server" "https://github.com/ahujasid/audiobook-mcp-server.git"
|
||||
clone_repo "mcp-server-elasticsearch" "https://github.com/ahujasid/mcp-server-elasticsearch.git"
|
||||
clone_repo "penpot-mcp" "https://github.com/ahujasid/penpot-mcp.git"
|
||||
clone_repo "docker-mcp" "https://github.com/QuantGeekDev/docker-mcp.git"
|
||||
clone_repo "kubernetes-mcp-server" "https://github.com/containers/kubernetes-mcp-server.git"
|
||||
clone_repo "ProxmoxMCP" "https://github.com/canvrno/ProxmoxMCP.git"
|
||||
clone_repo "terraform-mcp-server" "https://github.com/hashicorp/terraform-mcp-server.git"
|
||||
clone_repo "mcp-ansible" "https://github.com/bsahane/mcp-ansible.git"
|
||||
clone_repo "mcp-server" "https://github.com/bitwarden/mcp-server.git"
|
||||
clone_repo "mcp-adapter" "https://github.com/WordPress/mcp-adapter.git"
|
||||
clone_repo "audiobook-mcp-server" "https://github.com/joelmale/audiobook-mcp-server.git"
|
||||
clone_repo "paperless-mcp" "https://github.com/nloui/paperless-mcp.git"
|
||||
clone_repo "penpot-mcp" "https://github.com/penpot/penpot-mcp.git"
|
||||
clone_repo "ghidra-mcp" "https://github.com/bethington/ghidra-mcp.git"
|
||||
clone_repo "reverse-engineering-assistant" "https://github.com/cyberkaida/reverse-engineering-assistant.git"
|
||||
clone_repo "webserial-mcp" "https://github.com/DG1001/webserial-mcp.git"
|
||||
clone_repo "terraform-ls" "https://github.com/hashicorp/terraform-ls.git"
|
||||
|
||||
echo -e "${GREEN}=== All repositories cloned successfully! ===${NC}"
|
||||
echo ""
|
||||
|
||||
Reference in New Issue
Block a user