overmind-mcp 2.5.0 → 2.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.mcp.json.example +21 -0
- package/README.md +107 -80
- package/assets/overmind.png +0 -0
- package/bin/.gitkeep +0 -0
- package/bin/README.md +34 -0
- package/bin/install-overmind-unix.sh +412 -0
- package/bin/install-overmind-windows.bat +407 -0
- package/dist/bin/cli.js +438 -7
- package/dist/bin/cli.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -2
- package/dist/index.js.map +1 -1
- package/dist/lib/InstallHelper.d.ts +14 -0
- package/dist/lib/InstallHelper.d.ts.map +1 -0
- package/dist/lib/InstallHelper.js +115 -0
- package/dist/lib/InstallHelper.js.map +1 -0
- package/dist/lib/config.d.ts +31 -1
- package/dist/lib/config.d.ts.map +1 -1
- package/dist/lib/config.js +19 -27
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/envUtils.d.ts +10 -0
- package/dist/lib/envUtils.d.ts.map +1 -0
- package/dist/lib/envUtils.js +24 -0
- package/dist/lib/envUtils.js.map +1 -0
- package/dist/lib/loadEnv.d.ts +2 -0
- package/dist/lib/loadEnv.d.ts.map +1 -0
- package/dist/lib/loadEnv.js +26 -0
- package/dist/lib/loadEnv.js.map +1 -0
- package/dist/lib/logger.d.ts +8 -0
- package/dist/lib/logger.d.ts.map +1 -0
- package/dist/lib/logger.js +81 -0
- package/dist/lib/logger.js.map +1 -0
- package/dist/lib/modelMapping.d.ts +18 -0
- package/dist/lib/modelMapping.d.ts.map +1 -0
- package/dist/lib/modelMapping.js +90 -0
- package/dist/lib/modelMapping.js.map +1 -0
- package/dist/lib/orchestration/dispatcher.d.ts +32 -0
- package/dist/lib/orchestration/dispatcher.d.ts.map +1 -0
- package/dist/lib/orchestration/dispatcher.js +113 -0
- package/dist/lib/orchestration/dispatcher.js.map +1 -0
- package/dist/lib/orchestration/swarm.d.ts +75 -0
- package/dist/lib/orchestration/swarm.d.ts.map +1 -0
- package/dist/lib/orchestration/swarm.js +239 -0
- package/dist/lib/orchestration/swarm.js.map +1 -0
- package/dist/lib/processRegistry.d.ts +10 -0
- package/dist/lib/processRegistry.d.ts.map +1 -1
- package/dist/lib/processRegistry.js +85 -29
- package/dist/lib/processRegistry.js.map +1 -1
- package/dist/lib/sessions.d.ts +3 -2
- package/dist/lib/sessions.d.ts.map +1 -1
- package/dist/lib/sessions.js +94 -25
- package/dist/lib/sessions.js.map +1 -1
- package/dist/lib/telemetry.d.ts +21 -0
- package/dist/lib/telemetry.d.ts.map +1 -0
- package/dist/lib/telemetry.js +30 -0
- package/dist/lib/telemetry.js.map +1 -0
- package/dist/memory/MemoryFactory.d.ts +15 -1
- package/dist/memory/MemoryFactory.d.ts.map +1 -1
- package/dist/memory/MemoryFactory.js +53 -3
- package/dist/memory/MemoryFactory.js.map +1 -1
- package/dist/memory/PostgresMemoryProvider.d.ts +7 -0
- package/dist/memory/PostgresMemoryProvider.d.ts.map +1 -1
- package/dist/memory/PostgresMemoryProvider.js +180 -105
- package/dist/memory/PostgresMemoryProvider.js.map +1 -1
- package/dist/server.d.ts +41 -0
- package/dist/server.d.ts.map +1 -1
- package/dist/server.js +145 -41
- package/dist/server.js.map +1 -1
- package/dist/services/AgentManager.d.ts.map +1 -1
- package/dist/services/AgentManager.js +67 -11
- package/dist/services/AgentManager.js.map +1 -1
- package/dist/services/ClaudeRunner.d.ts +20 -0
- package/dist/services/ClaudeRunner.d.ts.map +1 -1
- package/dist/services/ClaudeRunner.js +626 -272
- package/dist/services/ClaudeRunner.js.map +1 -1
- package/dist/services/ClineRunner.d.ts +7 -0
- package/dist/services/ClineRunner.d.ts.map +1 -1
- package/dist/services/ClineRunner.js +76 -22
- package/dist/services/ClineRunner.js.map +1 -1
- package/dist/services/GeminiRunner.d.ts +6 -0
- package/dist/services/GeminiRunner.d.ts.map +1 -1
- package/dist/services/GeminiRunner.js +283 -69
- package/dist/services/GeminiRunner.js.map +1 -1
- package/dist/services/KiloRunner.d.ts +12 -0
- package/dist/services/KiloRunner.d.ts.map +1 -1
- package/dist/services/KiloRunner.js +439 -70
- package/dist/services/KiloRunner.js.map +1 -1
- package/dist/services/NousHermesRunner.d.ts +35 -0
- package/dist/services/NousHermesRunner.d.ts.map +1 -0
- package/dist/services/NousHermesRunner.js +535 -0
- package/dist/services/NousHermesRunner.js.map +1 -0
- package/dist/services/OpenClawRunner.d.ts +7 -0
- package/dist/services/OpenClawRunner.d.ts.map +1 -1
- package/dist/services/OpenClawRunner.js +75 -22
- package/dist/services/OpenClawRunner.js.map +1 -1
- package/dist/services/OpenCodeRunner.d.ts +7 -0
- package/dist/services/OpenCodeRunner.d.ts.map +1 -1
- package/dist/services/OpenCodeRunner.js +75 -22
- package/dist/services/OpenCodeRunner.js.map +1 -1
- package/dist/services/{TraeRunner.d.ts → QwenCliRunner.d.ts} +9 -2
- package/dist/services/QwenCliRunner.d.ts.map +1 -0
- package/dist/services/QwenCliRunner.js +155 -0
- package/dist/services/QwenCliRunner.js.map +1 -0
- package/dist/tools/agent_control.d.ts +2 -2
- package/dist/tools/agent_control.d.ts.map +1 -1
- package/dist/tools/agent_control.js +79 -50
- package/dist/tools/agent_control.js.map +1 -1
- package/dist/tools/config_example.d.ts +7 -4
- package/dist/tools/config_example.d.ts.map +1 -1
- package/dist/tools/config_example.js +191 -86
- package/dist/tools/config_example.js.map +1 -1
- package/dist/tools/create_agent.d.ts +13 -7
- package/dist/tools/create_agent.d.ts.map +1 -1
- package/dist/tools/create_agent.js +8 -9
- package/dist/tools/create_agent.js.map +1 -1
- package/dist/tools/get_agent_configs.d.ts +10 -4
- package/dist/tools/get_agent_configs.d.ts.map +1 -1
- package/dist/tools/get_agent_configs.js.map +1 -1
- package/dist/tools/initialization_check.d.ts +2 -0
- package/dist/tools/initialization_check.d.ts.map +1 -0
- package/dist/tools/initialization_check.js +23 -0
- package/dist/tools/initialization_check.js.map +1 -0
- package/dist/tools/manage_agents.d.ts +34 -16
- package/dist/tools/manage_agents.d.ts.map +1 -1
- package/dist/tools/manage_agents.js +2 -2
- package/dist/tools/manage_agents.js.map +1 -1
- package/dist/tools/manage_prompts.d.ts +13 -8
- package/dist/tools/manage_prompts.d.ts.map +1 -1
- package/dist/tools/manage_prompts.js.map +1 -1
- package/dist/tools/memory_runs.d.ts +3 -4
- package/dist/tools/memory_runs.d.ts.map +1 -1
- package/dist/tools/memory_runs.js.map +1 -1
- package/dist/tools/memory_search.d.ts +3 -4
- package/dist/tools/memory_search.d.ts.map +1 -1
- package/dist/tools/memory_search.js.map +1 -1
- package/dist/tools/memory_store.d.ts +10 -4
- package/dist/tools/memory_store.d.ts.map +1 -1
- package/dist/tools/memory_store.js.map +1 -1
- package/dist/tools/run_agent.d.ts +14 -14
- package/dist/tools/run_agent.d.ts.map +1 -1
- package/dist/tools/run_agent.js +135 -156
- package/dist/tools/run_agent.js.map +1 -1
- package/dist/tools/run_agent_cli.d.ts +21 -0
- package/dist/tools/run_agent_cli.d.ts.map +1 -0
- package/dist/tools/run_agent_cli.js +137 -0
- package/dist/tools/run_agent_cli.js.map +1 -0
- package/dist/tools/run_agents_parallel.d.ts +35 -0
- package/dist/tools/run_agents_parallel.d.ts.map +1 -0
- package/dist/tools/run_agents_parallel.js +28 -0
- package/dist/tools/run_agents_parallel.js.map +1 -0
- package/dist/tools/run_claude.d.ts +9 -3
- package/dist/tools/run_claude.d.ts.map +1 -1
- package/dist/tools/run_claude.js +67 -41
- package/dist/tools/run_claude.js.map +1 -1
- package/dist/tools/run_cline.d.ts +13 -4
- package/dist/tools/run_cline.d.ts.map +1 -1
- package/dist/tools/run_cline.js +55 -43
- package/dist/tools/run_cline.js.map +1 -1
- package/dist/tools/run_gemini.d.ts +13 -4
- package/dist/tools/run_gemini.d.ts.map +1 -1
- package/dist/tools/run_gemini.js +53 -33
- package/dist/tools/run_gemini.js.map +1 -1
- package/dist/tools/run_hermes.d.ts +25 -0
- package/dist/tools/run_hermes.d.ts.map +1 -0
- package/dist/tools/run_hermes.js +93 -0
- package/dist/tools/run_hermes.js.map +1 -0
- package/dist/tools/run_kilo.d.ts +17 -7
- package/dist/tools/run_kilo.d.ts.map +1 -1
- package/dist/tools/run_kilo.js +68 -41
- package/dist/tools/run_kilo.js.map +1 -1
- package/dist/tools/run_openclaw.d.ts +13 -4
- package/dist/tools/run_openclaw.d.ts.map +1 -1
- package/dist/tools/run_openclaw.js +52 -44
- package/dist/tools/run_openclaw.js.map +1 -1
- package/dist/tools/run_opencode.d.ts +13 -4
- package/dist/tools/run_opencode.d.ts.map +1 -1
- package/dist/tools/run_opencode.js +52 -39
- package/dist/tools/run_opencode.js.map +1 -1
- package/dist/tools/run_qwencli.d.ts +24 -0
- package/dist/tools/run_qwencli.d.ts.map +1 -0
- package/dist/tools/run_qwencli.js +59 -0
- package/dist/tools/run_qwencli.js.map +1 -0
- package/docs/README.md +128 -0
- package/docs/agent_control.md +656 -0
- package/docs/index.html +493 -0
- package/docs/library.html +239 -0
- package/docs/prompt.html +1212 -0
- package/docs/script.js +428 -0
- package/docs/styles.css +2816 -0
- package/package.json +54 -25
- package/scripts/auto-changelog.mjs +132 -0
- package/scripts/auto-install.mjs +322 -0
- package/scripts/install-dependencies.mjs +462 -0
- package/scripts/postgres-manager.mjs +219 -0
- package/scripts/postinstall.mjs +538 -0
- package/scripts/setup-overmind-db.mjs +199 -0
- package/scripts/setup-windows.js +266 -0
- package/scripts/setup.mjs +397 -0
- package/scripts/test-installation.mjs +158 -0
- package/scripts/uninstall.mjs +238 -0
- package/assets/overmind_mcp_pro_banner_v3.png +0 -0
- package/dist/services/QwenRunner.d.ts +0 -19
- package/dist/services/QwenRunner.d.ts.map +0 -1
- package/dist/services/QwenRunner.js +0 -102
- package/dist/services/QwenRunner.js.map +0 -1
- package/dist/services/TraeRunner.d.ts.map +0 -1
- package/dist/services/TraeRunner.js +0 -103
- package/dist/services/TraeRunner.js.map +0 -1
- package/dist/tools/run_qwen.d.ts +0 -15
- package/dist/tools/run_qwen.d.ts.map +0 -1
- package/dist/tools/run_qwen.js +0 -61
- package/dist/tools/run_qwen.js.map +0 -1
- package/dist/tools/run_trae.d.ts +0 -15
- package/dist/tools/run_trae.d.ts.map +0 -1
- package/dist/tools/run_trae.js +0 -66
- package/dist/tools/run_trae.js.map +0 -1
- package/dist/tools/shell_execute.d.ts +0 -10
- package/dist/tools/shell_execute.d.ts.map +0 -1
- package/dist/tools/shell_execute.js +0 -24
- package/dist/tools/shell_execute.js.map +0 -1
- package/dist/tools/test_agent_control.d.ts +0 -2
- package/dist/tools/test_agent_control.d.ts.map +0 -1
- package/dist/tools/test_agent_control.js +0 -92
- package/dist/tools/test_agent_control.js.map +0 -1
|
@@ -0,0 +1,412 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# ============================================================
|
|
3
|
+
# OVERMIND-MCP - INSTALLATION INTELLIGENTE Linux/macOS
|
|
4
|
+
# ============================================================
|
|
5
|
+
# Ce script détecte et utilise l'infrastructure existante
|
|
6
|
+
# - PostgreSQL existant ? Utilise-le !
|
|
7
|
+
# - Ports occupés ? Adapte la configuration !
|
|
8
|
+
# ============================================================
|
|
9
|
+
|
|
10
|
+
set -e
|
|
11
|
+
|
|
12
|
+
# Couleurs
|
|
13
|
+
RED='\033[0;31m'
|
|
14
|
+
GREEN='\033[0;32m'
|
|
15
|
+
YELLOW='\033[1;33m'
|
|
16
|
+
BLUE='\033[0;34m'
|
|
17
|
+
MAGENTA='\033[0;35m'
|
|
18
|
+
CYAN='\033[0;36m'
|
|
19
|
+
WHITE='\033[1;37m'
|
|
20
|
+
NC='\033[0m'
|
|
21
|
+
|
|
22
|
+
clear
|
|
23
|
+
echo -e "${CYAN}***************************************************************${NC}"
|
|
24
|
+
echo -e "${CYAN}* *${NC}"
|
|
25
|
+
echo -e "${MAGENTA} 🚀 OVERMIND-MCP - INSTALLATION INTELLIGENTE ${NC}"
|
|
26
|
+
echo -e "${CYAN}* Linux/macOS + Docker Desktop *${NC}"
|
|
27
|
+
echo -e "${CYAN}* *${NC}"
|
|
28
|
+
echo -e "${CYAN}***************************************************************${NC}"
|
|
29
|
+
echo ""
|
|
30
|
+
|
|
31
|
+
# ============================================================
|
|
32
|
+
# STEP 1: Vérifier Node.js et NPM
|
|
33
|
+
# ============================================================
|
|
34
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
35
|
+
echo -e "${CYAN}[ STEP 1/8 ] VERIFICATION NODE.JS${NC}"
|
|
36
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
37
|
+
echo ""
|
|
38
|
+
|
|
39
|
+
if ! command -v node &> /dev/null; then
|
|
40
|
+
echo -e "${RED}[ERREUR] Node.js non trouvé${NC}"
|
|
41
|
+
echo -e "${YELLOW}Linux: curl -fsSL https://deb.nodesource.com/setup_lts.x | sudo -E bash -${NC}"
|
|
42
|
+
echo -e "${YELLOW}macOS: brew install node${NC}"
|
|
43
|
+
exit 1
|
|
44
|
+
fi
|
|
45
|
+
|
|
46
|
+
echo -e "${GREEN}[OK] Node.js détecté:${NC}"
|
|
47
|
+
node --version
|
|
48
|
+
echo -e "${GREEN}[OK] NPM détecté:${NC}"
|
|
49
|
+
npm --version
|
|
50
|
+
echo ""
|
|
51
|
+
|
|
52
|
+
# ============================================================
|
|
53
|
+
# STEP 2: Installer OverMind-MCP
|
|
54
|
+
# ============================================================
|
|
55
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
56
|
+
echo -e "${CYAN}[ STEP 2/8 ] INSTALLATION OVERMIND-MCP${NC}"
|
|
57
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
58
|
+
echo ""
|
|
59
|
+
|
|
60
|
+
echo -e "${YELLOW}[INFO] Installation d'overmind-mcp...${NC}"
|
|
61
|
+
npm install -g overmind-mcp@latest
|
|
62
|
+
|
|
63
|
+
echo -e "${GREEN}[OK] overmind-mcp installé:${NC}"
|
|
64
|
+
npm view overmind-mcp version
|
|
65
|
+
echo ""
|
|
66
|
+
|
|
67
|
+
# ============================================================
|
|
68
|
+
# STEP 3: Vérifier Docker
|
|
69
|
+
# ============================================================
|
|
70
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
71
|
+
echo -e "${CYAN}[ STEP 3/8 ] VERIFICATION DOCKER${NC}"
|
|
72
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
73
|
+
echo ""
|
|
74
|
+
|
|
75
|
+
if ! command -v docker &> /dev/null; then
|
|
76
|
+
echo -e "${RED}[ERREUR] Docker non trouvé${NC}"
|
|
77
|
+
echo -e "${YELLOW}Linux: https://docs.docker.com/engine/install/${NC}"
|
|
78
|
+
echo -e "${YELLOW}macOS: https://www.docker.com/products/docker-desktop/${NC}"
|
|
79
|
+
exit 1
|
|
80
|
+
fi
|
|
81
|
+
|
|
82
|
+
echo -e "${GREEN}[OK] Docker détecté:${NC}"
|
|
83
|
+
docker --version
|
|
84
|
+
echo ""
|
|
85
|
+
|
|
86
|
+
# ============================================================
|
|
87
|
+
# STEP 4: Analyse infrastructure existante
|
|
88
|
+
# ============================================================
|
|
89
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
90
|
+
echo -e "${CYAN}[ STEP 4/8 ] ANALYSE INFRASTRUCTURE${NC}"
|
|
91
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
92
|
+
echo ""
|
|
93
|
+
|
|
94
|
+
echo -e "${YELLOW}[INFO] Détection des services existants...${NC}"
|
|
95
|
+
echo ""
|
|
96
|
+
|
|
97
|
+
POSTGRES_EXISTS=0
|
|
98
|
+
POSTGRES_CONTAINER=""
|
|
99
|
+
USE_EXTERNAL_POSTGRES=0
|
|
100
|
+
|
|
101
|
+
# Vérifier PostgreSQL sur port 5432
|
|
102
|
+
if docker ps -a --filter "publish=5432" --format "{{.Names}}" | grep -qi "postgres"; then
|
|
103
|
+
POSTGRES_CONTAINER=$(docker ps -a --filter "publish=5432" --format "{{.Names}}" | head -1)
|
|
104
|
+
POSTGRES_EXISTS=1
|
|
105
|
+
USE_EXTERNAL_POSTGRES=1
|
|
106
|
+
echo -e "${GREEN}[OK] PostgreSQL existant détecté: ${POSTGRES_CONTAINER}${NC}"
|
|
107
|
+
else
|
|
108
|
+
echo -e "${YELLOW}[INFO] PostgreSQL non détecté - installation prévue${NC}"
|
|
109
|
+
fi
|
|
110
|
+
|
|
111
|
+
echo ""
|
|
112
|
+
echo -e "${YELLOW}[INFO] Vérification des ports...${NC}"
|
|
113
|
+
netstat -tuln 2>/dev/null | grep ":5432 " > /dev/null && echo -e "${YELLOW}[WARN] Port 5432 utilisé${NC}" || echo -e "${GREEN}[OK] Port 5432 libre${NC}"
|
|
114
|
+
netstat -tuln 2>/dev/null | grep ":5672 " > /dev/null && echo -e "${YELLOW}[WARN] Port 5672 utilisé${NC}" || echo -e "${GREEN}[OK] Port 5672 libre${NC}"
|
|
115
|
+
netstat -tuln 2>/dev/null | grep ":9090 " > /dev/null && echo -e "${YELLOW}[WARN] Port 9090 utilisé${NC}" || echo -e "${GREEN}[OK] Port 9090 libre${NC}"
|
|
116
|
+
netstat -tuln 2>/dev/null | grep ":3000 " > /dev/null && echo -e "${YELLOW}[WARN] Port 3000 utilisé${NC}" || echo -e "${GREEN}[OK] Port 3000 libre${NC}"
|
|
117
|
+
|
|
118
|
+
echo ""
|
|
119
|
+
|
|
120
|
+
# ============================================================
|
|
121
|
+
# STEP 5: PostgreSQL intelligent
|
|
122
|
+
# ============================================================
|
|
123
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
124
|
+
echo -e "${CYAN}[ STEP 5/8 ] POSTGRESQL INTELLIGENT${NC}"
|
|
125
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
126
|
+
echo ""
|
|
127
|
+
|
|
128
|
+
if [ "$USE_EXTERNAL_POSTGRES" -eq 1 ]; then
|
|
129
|
+
echo -e "${GREEN}[OK] Utilisation PostgreSQL existant: ${POSTGRES_CONTAINER}${NC}"
|
|
130
|
+
|
|
131
|
+
# Vérifier pgvector
|
|
132
|
+
if docker exec "${POSTGRES_CONTAINER}" psql -U postgres -c "SELECT extname FROM pg_extension WHERE extname = 'vector';" 2>/dev/null | grep -q vector; then
|
|
133
|
+
echo -e "${GREEN}[OK] pgvector détecté${NC}"
|
|
134
|
+
else
|
|
135
|
+
echo -e "${YELLOW}[WARN] pgvector non détecté${NC}"
|
|
136
|
+
echo ""
|
|
137
|
+
echo -e "${YELLOW}Pour installer pgvector manuellement :${NC}"
|
|
138
|
+
echo " docker exec ${POSTGRES_CONTAINER} psql -U postgres -c \"CREATE EXTENSION vector;\""
|
|
139
|
+
fi
|
|
140
|
+
else
|
|
141
|
+
echo -e "${YELLOW}[INFO] Installation PostgreSQL + pgvector...${NC}"
|
|
142
|
+
npx overmind-mcp install-dependencies
|
|
143
|
+
fi
|
|
144
|
+
|
|
145
|
+
echo ""
|
|
146
|
+
|
|
147
|
+
# ============================================================
|
|
148
|
+
# STEP 6: Configuration intelligente
|
|
149
|
+
# ============================================================
|
|
150
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
151
|
+
echo -e "${CYAN}[ STEP 6/8 ] CONFIGURATION ADAPTIVE${NC}"
|
|
152
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
153
|
+
echo ""
|
|
154
|
+
|
|
155
|
+
OVERMIND_DIR="$HOME/.overmind"
|
|
156
|
+
mkdir -p "$OVERMIND_DIR"
|
|
157
|
+
|
|
158
|
+
# Créer .env intelligent
|
|
159
|
+
if [ ! -f "$OVERMIND_DIR/.env" ]; then
|
|
160
|
+
echo -e "${YELLOW}[INFO] Création configuration .env...${NC}"
|
|
161
|
+
cat > "$OVERMIND_DIR/.env" << EOF
|
|
162
|
+
# OverMind-MCP Environment Configuration
|
|
163
|
+
# Généré par install-overmind-unix.sh
|
|
164
|
+
|
|
165
|
+
# PostgreSQL
|
|
166
|
+
POSTGRES_HOST=localhost
|
|
167
|
+
POSTGRES_PORT=5432
|
|
168
|
+
POSTGRES_USER=postgres
|
|
169
|
+
POSTGRES_PASSWORD=overmind_temp_password_change_me
|
|
170
|
+
POSTGRES_DB=overmind
|
|
171
|
+
|
|
172
|
+
# Infrastructure détectée
|
|
173
|
+
EOF
|
|
174
|
+
|
|
175
|
+
if [ "$USE_EXTERNAL_POSTGRES" -eq 1 ]; then
|
|
176
|
+
echo "POSTGRES_EXTERNAL=${POSTGRES_CONTAINER}" >> "$OVERMIND_DIR/.env"
|
|
177
|
+
fi
|
|
178
|
+
|
|
179
|
+
cat >> "$OVERMIND_DIR/.env" << EOF
|
|
180
|
+
|
|
181
|
+
# OpenTelemetry
|
|
182
|
+
OTEL_ENABLED=false
|
|
183
|
+
|
|
184
|
+
# Workspace
|
|
185
|
+
OVERMIND_WORKSPACE=$OVERMIND_DIR
|
|
186
|
+
EOF
|
|
187
|
+
echo -e "${GREEN}[OK] Configuration créée: ${OVERMIND_DIR}/.env${NC}"
|
|
188
|
+
fi
|
|
189
|
+
|
|
190
|
+
echo ""
|
|
191
|
+
|
|
192
|
+
# ============================================================
|
|
193
|
+
# STEP 7: Télécharger docker-compose
|
|
194
|
+
# ============================================================
|
|
195
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
196
|
+
echo -e "${CYAN}[ STEP 7/8 ] TÉLECHARGEMENT CONFIG${NC}"
|
|
197
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
198
|
+
echo ""
|
|
199
|
+
|
|
200
|
+
echo -e "${YELLOW}[INFO] Téléchargement docker-compose.yml...${NC}"
|
|
201
|
+
curl -sL https://raw.githubusercontent.com/DeamonDev888/overmind-mcp/main/docker-compose.yml -o "$OVERMIND_DIR/docker-compose.yml"
|
|
202
|
+
curl -sL https://raw.githubusercontent.com/DeamonDev888/overmind-mcp/main/docker-compose.exporters.yml -o "$OVERMIND_DIR/docker-compose.exporters.yml"
|
|
203
|
+
|
|
204
|
+
# Adapter docker-compose si PostgreSQL externe
|
|
205
|
+
if [ "$USE_EXTERNAL_POSTGRES" -eq 1 ]; then
|
|
206
|
+
echo -e "${YELLOW}[INFO] Adaptation docker-compose (PostgreSQL externe)...${NC}"
|
|
207
|
+
sed -i.bak 's/^ postgres:/# postgres:/' "$OVERMIND_DIR/docker-compose.yml"
|
|
208
|
+
sed -i.bak 's/^ image: pgvector/# image:/' "$OVERMIND_DIR/docker-compose.yml"
|
|
209
|
+
sed -i.bak 's/^ container_name: overmind-postgres/# container_name:/' "$OVERMIND_DIR/docker-compose.yml"
|
|
210
|
+
echo -e "${GREEN}[OK] Docker-compose adapté (postgres désactivé)${NC}"
|
|
211
|
+
fi
|
|
212
|
+
|
|
213
|
+
echo -e "${GREEN}[OK] Fichers téléchargés${NC}"
|
|
214
|
+
|
|
215
|
+
echo -e "${YELLOW}[INFO] Création fichiers de configuration...${NC}"
|
|
216
|
+
mkdir -p "$OVERMIND_DIR/config/grafana/provisioning/datasources"
|
|
217
|
+
|
|
218
|
+
echo -e "${YELLOW}[INFO] Création config OTEL collector...${NC}"
|
|
219
|
+
cat > "$OVERMIND_DIR/config/otel-collector.yml" << 'EOF'
|
|
220
|
+
receivers:
|
|
221
|
+
otlp:
|
|
222
|
+
protocols:
|
|
223
|
+
grpc:
|
|
224
|
+
endpoint: 0.0.0.0:4317
|
|
225
|
+
http:
|
|
226
|
+
endpoint: 0.0.0.0:4318
|
|
227
|
+
|
|
228
|
+
processors:
|
|
229
|
+
batch:
|
|
230
|
+
|
|
231
|
+
exporters:
|
|
232
|
+
otlp/jaeger:
|
|
233
|
+
endpoint: jaeger:4317
|
|
234
|
+
tls:
|
|
235
|
+
insecure: true
|
|
236
|
+
|
|
237
|
+
prometheusremotewrite:
|
|
238
|
+
endpoint: http://prometheus:9090/api/v1/write
|
|
239
|
+
|
|
240
|
+
service:
|
|
241
|
+
pipelines:
|
|
242
|
+
traces:
|
|
243
|
+
receivers: [otlp]
|
|
244
|
+
processors: [batch]
|
|
245
|
+
exporters: [otlp/jaeger]
|
|
246
|
+
|
|
247
|
+
metrics:
|
|
248
|
+
receivers: [otlp]
|
|
249
|
+
processors: [batch]
|
|
250
|
+
exporters: [prometheusremotewrite]
|
|
251
|
+
EOF
|
|
252
|
+
|
|
253
|
+
echo -e "${YELLOW}[INFO] Création config Prometheus...${NC}"
|
|
254
|
+
cat > "$OVERMIND_DIR/config/prometheus.yml" << 'EOF'
|
|
255
|
+
global:
|
|
256
|
+
scrape_interval: 15s
|
|
257
|
+
evaluation_interval: 15s
|
|
258
|
+
|
|
259
|
+
scrape_configs:
|
|
260
|
+
- job_name: 'prometheus'
|
|
261
|
+
static_configs:
|
|
262
|
+
- targets: ['localhost:9090']
|
|
263
|
+
|
|
264
|
+
- job_name: 'otel-collector'
|
|
265
|
+
static_configs:
|
|
266
|
+
- targets: ['otel-collector:9464']
|
|
267
|
+
EOF
|
|
268
|
+
|
|
269
|
+
echo -e "${YELLOW}[INFO] Création config Grafana datasource...${NC}"
|
|
270
|
+
cat > "$OVERMIND_DIR/config/grafana/provisioning/datasources/prometheus.yml" << 'EOF'
|
|
271
|
+
apiVersion: 1
|
|
272
|
+
|
|
273
|
+
datasources:
|
|
274
|
+
- name: Prometheus
|
|
275
|
+
type: prometheus
|
|
276
|
+
access: proxy
|
|
277
|
+
url: http://prometheus:9090
|
|
278
|
+
isDefault: true
|
|
279
|
+
EOF
|
|
280
|
+
|
|
281
|
+
echo -e "${GREEN}[OK] Fichiers de configuration créés${NC}"
|
|
282
|
+
|
|
283
|
+
echo -e "${YELLOW}[INFO] Création init-db.sql...${NC}"
|
|
284
|
+
curl -sL https://raw.githubusercontent.com/DeamonDev888/overmind-mcp/main/init-db.sql -o "$OVERMIND_DIR/init-db.sql"
|
|
285
|
+
echo -e "${GREEN}[OK] init-db.sql téléchargé${NC}"
|
|
286
|
+
|
|
287
|
+
|
|
288
|
+
echo ""
|
|
289
|
+
|
|
290
|
+
# ============================================================
|
|
291
|
+
# STEP 8: Démarrage intelligent
|
|
292
|
+
# ============================================================
|
|
293
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
294
|
+
echo -e "${CYAN}[ STEP 8/8 ] DÉMARRAGE DOCKER${NC}"
|
|
295
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
296
|
+
echo ""
|
|
297
|
+
|
|
298
|
+
echo -e "${YELLOW}[INFO] Démarrage infrastructure Docker...${NC}"
|
|
299
|
+
cd "$OVERMIND_DIR"
|
|
300
|
+
docker-compose -f docker-compose.yml up -d
|
|
301
|
+
|
|
302
|
+
if [ $? -ne 0 ]; then
|
|
303
|
+
echo -e "${YELLOW}[WARN] Certains services ont pu échouer${NC}"
|
|
304
|
+
echo -e "${YELLOW}[INFO] Vérification des services démarrés...${NC}"
|
|
305
|
+
fi
|
|
306
|
+
|
|
307
|
+
echo ""
|
|
308
|
+
sleep 15
|
|
309
|
+
|
|
310
|
+
# ============================================================
|
|
311
|
+
# VALIDATION INTELLIGENTE
|
|
312
|
+
# ============================================================
|
|
313
|
+
echo ""
|
|
314
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
315
|
+
echo -e "${CYAN}[ VALIDATION DES SERVICES ]${NC}"
|
|
316
|
+
echo -e "${CYAN}=======================================================${NC}"
|
|
317
|
+
echo ""
|
|
318
|
+
|
|
319
|
+
echo -e "${YELLOW}[INFO] Vérification des containers...${NC}"
|
|
320
|
+
echo ""
|
|
321
|
+
docker ps --filter "name=overmind" --format "table {{.Names}}\t{{.Status}}\t{{.Ports}}"
|
|
322
|
+
echo ""
|
|
323
|
+
|
|
324
|
+
echo -e "${YELLOW}[INFO] Tests de connexion...${NC}"
|
|
325
|
+
echo ""
|
|
326
|
+
|
|
327
|
+
# Test PostgreSQL
|
|
328
|
+
echo -e " • PostgreSQL:"
|
|
329
|
+
if [ "$USE_EXTERNAL_POSTGRES" -eq 1 ]; then
|
|
330
|
+
docker exec "${POSTGRES_CONTAINER}" pg_isready -U postgres > /dev/null 2>&1
|
|
331
|
+
if [ $? -eq 0 ]; then
|
|
332
|
+
echo -e "${GREEN} [OK] PostgreSQL actif (${POSTGRES_CONTAINER})${NC}"
|
|
333
|
+
else
|
|
334
|
+
echo -e "${RED} [FAIL] PostgreSQL non prêt${NC}"
|
|
335
|
+
fi
|
|
336
|
+
else
|
|
337
|
+
docker ps --filter "name=overmind-postgres" --format "{{.Names}}" | grep -q postgres
|
|
338
|
+
if [ $? -eq 0 ]; then
|
|
339
|
+
docker exec overmind-postgres pg_isready -U postgres > /dev/null 2>&1
|
|
340
|
+
if [ $? -eq 0 ]; then
|
|
341
|
+
echo -e "${GREEN} [OK] OverMind PostgreSQL actif${NC}"
|
|
342
|
+
else
|
|
343
|
+
echo -e "${RED} [FAIL] PostgreSQL non prêt${NC}"
|
|
344
|
+
fi
|
|
345
|
+
else
|
|
346
|
+
echo -e "${RED} [FAIL] OverMind PostgreSQL non trouvé${NC}"
|
|
347
|
+
fi
|
|
348
|
+
fi
|
|
349
|
+
|
|
350
|
+
# Test RabbitMQ
|
|
351
|
+
echo -e " • RabbitMQ:"
|
|
352
|
+
docker ps --filter "name=overmind-rabbitmq" --format "{{.Names}}" | grep -q rabbitmq
|
|
353
|
+
if [ $? -eq 0 ]; then
|
|
354
|
+
echo -e "${GREEN} [OK] RabbitMQ actif${NC}"
|
|
355
|
+
else
|
|
356
|
+
echo -e "${RED} [FAIL] RabbitMQ non trouvé${NC}"
|
|
357
|
+
fi
|
|
358
|
+
|
|
359
|
+
# Test Temporal
|
|
360
|
+
echo -e " • Temporal:"
|
|
361
|
+
echo -e "${YELLOW} [INFO] Désactivé (requiert init DB)${NC}"
|
|
362
|
+
|
|
363
|
+
# Test Prometheus
|
|
364
|
+
echo -e " • Prometheus:"
|
|
365
|
+
docker ps --filter "name=overmind-prometheus" --format "{{.Names}}" | grep -q prometheus
|
|
366
|
+
if [ $? -eq 0 ]; then
|
|
367
|
+
echo -e "${GREEN} [OK] Prometheus actif${NC}"
|
|
368
|
+
else
|
|
369
|
+
echo -e "${RED} [FAIL] Prometheus non trouvé${NC}"
|
|
370
|
+
fi
|
|
371
|
+
|
|
372
|
+
# Test Grafana
|
|
373
|
+
echo -e " • Grafana:"
|
|
374
|
+
docker ps --filter "name=overmind-grafana" --format "{{.Names}}" | grep -q grafana
|
|
375
|
+
if [eq $? -eq 0 ]; then
|
|
376
|
+
echo -e "${GREEN} [OK] Grafana actif${NC}"
|
|
377
|
+
else
|
|
378
|
+
echo -e "${RED} [FAIL] Grafana non trouvé${NC}"
|
|
379
|
+
fi
|
|
380
|
+
|
|
381
|
+
# Test Jaeger
|
|
382
|
+
echo -e " • Jaeger:"
|
|
383
|
+
docker ps --filter "name=overmind-jaeger" --format "{{.Names}}" | grep -q jaeger
|
|
384
|
+
if [ $? -eq 0 ]; then
|
|
385
|
+
echo -e "${GREEN} [OK] Jaeger actif${NC}"
|
|
386
|
+
else
|
|
387
|
+
echo -e "${RED} [FAIL] Jaeger non trouvé${NC}"
|
|
388
|
+
fi
|
|
389
|
+
|
|
390
|
+
echo ""
|
|
391
|
+
echo -e "${GREEN}***************************************************************${NC}"
|
|
392
|
+
echo -e "${GREEN}* *${NC}"
|
|
393
|
+
echo -e "${GREEN}* ✅ INSTALLATION TERMINÉE ! *${NC}"
|
|
394
|
+
echo -e "${GREEN}* *${NC}"
|
|
395
|
+
echo -e "${GREEN}***************************************************************${NC}"
|
|
396
|
+
echo ""
|
|
397
|
+
echo -e "${YELLOW}[SERVICES ACTIFS]"
|
|
398
|
+
echo ""
|
|
399
|
+
echo " Ouvrez Docker Desktop → onglet Containers"
|
|
400
|
+
echo ""
|
|
401
|
+
echo " URLs utiles:"
|
|
402
|
+
echo " • Prometheus: http://localhost:9090"
|
|
403
|
+
echo " • Grafana: http://localhost:3000 (admin/admin)"
|
|
404
|
+
echo " • Jaeger: http://localhost:16686"
|
|
405
|
+
echo " • RabbitMQ: http://localhost:15672 (guest/guest)"
|
|
406
|
+
echo " • Temporal: http://localhost:8233"
|
|
407
|
+
echo ""
|
|
408
|
+
echo -e "${YELLOW}[PROCHAINE ÉTAPE]"
|
|
409
|
+
echo ""
|
|
410
|
+
echo " • Créez votre premier agent: overmind create-agent"
|
|
411
|
+
echo " • Ou listez les agents: overmind list-agents"
|
|
412
|
+
echo ""
|