overmind-mcp 2.8.9 → 2.8.11

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/scripts/setup.mjs CHANGED
@@ -1,395 +1,395 @@
1
- #!/usr/bin/env node
2
- /**
3
- * ═══════════════════════════════════════════════════════════════════════════════
4
- * SETUP SCRIPT - Installation Automatique OverMind
5
- * ═══════════════════════════════════════════════════════════════════════════════
6
- * Script principal qui installe TOUTES les dépendances nécessaires à OverMind:
7
- * - Docker (si pas présent)
8
- * - PostgreSQL + pgvector (si pas présent)
9
- * - RabbitMQ
10
- * - Temporal
11
- * - Configuration automatique
12
- *
13
- * Usage:
14
- * overmind-setup [--full]
15
- * ═══════════════════════════════════════════════════════════════════════════════
16
- */
17
-
18
- import { execSync, spawn } from 'child_process';
19
- import { copyFileSync, existsSync, mkdirSync, writeFileSync } from 'fs';
20
- import { join } from 'path';
21
- import { fileURLToPath } from 'url';
22
- import { dirname } from 'path';
23
- import { createInterface } from 'readline';
24
-
25
- const __filename = fileURLToPath(import.meta.url);
26
- const __dirname = dirname(__filename);
27
- const projectRoot = join(__dirname, '..');
28
- const INSTALL_DIR = join(process.env.HOME || process.env.USERPROFILE || process.env.HOMEPATH, '.overmind');
29
-
30
- // ═══════════════════════════════════════════════════════════════════════════════
31
- // UTILS
32
- // ═══════════════════════════════════════════════════════════════════════════════
33
-
34
- function logSection(title) {
35
- console.log('\n╔══════════════════════════════════════════════════════════════════╗');
36
- console.log(`║ ${title.padEnd(64)} ║`);
37
- console.log('╚══════════════════════════════════════════════════════════════════╝');
38
- }
39
-
40
- function runCommand(cmd, description) {
41
- console.log(`\n🔧 ${description}`);
42
- console.log(` $ ${cmd}`);
43
- try {
44
- execSync(cmd, { stdio: 'inherit' });
45
- console.log(`✅ ${description} terminé`);
46
- return true;
47
- } catch (error) {
48
- console.error(`❌ Erreur: ${error.message}`);
49
- return false;
50
- }
51
- }
52
-
53
- function runCommandAsync(cmd, description) {
54
- return new Promise((resolve, reject) => {
55
- console.log(`\n🔧 ${description}`);
56
- console.log(` $ ${cmd}`);
57
- const child = spawn(cmd, { shell: true, stdio: 'inherit' });
58
-
59
- child.on('close', (code) => {
60
- if (code === 0) {
61
- console.log(`✅ ${description} terminé`);
62
- resolve(true);
63
- } else {
64
- console.error(`❌ Erreur (code ${code})`);
65
- reject(new Error(`Command failed with code ${code}`));
66
- }
67
- });
68
-
69
- child.on('error', (err) => {
70
- console.error('❌ Erreur:', err.message);
71
- reject(err);
72
- });
73
- });
74
- }
75
-
76
- async function promptYesNo(question) {
77
- const rl = createInterface({
78
- input: process.stdin,
79
- output: process.stdout,
80
- });
81
-
82
- const answer = await new Promise((resolve) => {
83
- rl.question(`${question} (y/N): `, (answer) => {
84
- rl.close();
85
- resolve(answer.toLowerCase().startsWith('y'));
86
- });
87
- });
88
-
89
- return answer;
90
- }
91
-
92
- // ═══════════════════════════════════════════════════════════════════════════════
93
- // CHECKS
94
- // ═══════════════════════════════════════════════════════════════════════════════
95
-
96
- function checkDocker() {
97
- try {
98
- execSync('docker --version', { stdio: 'pipe' });
99
- return true;
100
- } catch {
101
- return false;
102
- }
103
- }
104
-
105
- function checkPostgreSQL() {
106
- try {
107
- execSync('docker ps --filter "name=postgres" --format "{{.Names}}"', { stdio: 'pipe' });
108
- return true;
109
- } catch {
110
- try {
111
- execSync('psql --version', { stdio: 'pipe' });
112
- return true;
113
- } catch {
114
- return false;
115
- }
116
- }
117
- }
118
-
119
- // ═══════════════════════════════════════════════════════════════════════════════
120
- // INSTALLATION STEPS
121
- // ═══════════════════════════════════════════════════════════════════════════════
122
-
123
- async function installDocker() {
124
- logSection('INSTALLATION DOCKER');
125
-
126
- if (checkDocker()) {
127
- console.log('✅ Docker est déjà installé');
128
- return true;
129
- }
130
-
131
- console.log('ℹ️ Docker non trouvé.');
132
- console.log('');
133
- console.log('📥 Docker Desktop est requis pour OverMind-MCP:');
134
- console.log(' - Windows: https://www.docker.com/products/docker-desktop/');
135
- console.log(' - Mac: https://www.docker.com/products/docker-desktop/');
136
- console.log('');
137
- console.log('📋 Instructions:');
138
- console.log(' 1. Téléchargez et installez Docker Desktop');
139
- console.log(' 2. Démarrez Docker Desktop');
140
- console.log(' 3. Relancez: overmind-setup --full');
141
- console.log('');
142
-
143
- const answer = await promptYesNo('Voulez-vous ouvrir le site de téléchargement maintenant ?');
144
- if (answer) {
145
- const url = process.platform === 'win32'
146
- ? 'https://www.docker.com/products/docker-desktop/'
147
- : 'https://www.docker.com/products/docker-desktop/';
148
-
149
- try {
150
- execSync(`start ${url}`, { stdio: 'inherit' });
151
- console.log('✅ Navigateur ouvert. Attendez l\'installation de Docker.');
152
- } catch {
153
- console.log('⚠️ Impossible d\'ouvrir le navigateur automatiquement.');
154
- console.log(` Ouvrez manuellement: ${url}`);
155
- }
156
- }
157
-
158
- return false;
159
- }
160
-
161
- async function installPostgreSQL() {
162
- logSection('INSTALLATION POSTGRESQL + PGVECTOR');
163
-
164
- if (checkPostgreSQL()) {
165
- console.log('✅ PostgreSQL est déjà installé');
166
- return true;
167
- }
168
-
169
- console.log('🐳 Installation PostgreSQL + pgvector en Docker...');
170
- console.log('');
171
-
172
- try {
173
- // Pull and start PostgreSQL container
174
- console.log('📥 Téléchargement image pgvector/pgvector:pg16...');
175
- execSync('docker pull pgvector/pgvector:pg16', { stdio: 'inherit' });
176
-
177
- console.log('🚀 Démarrage container PostgreSQL...');
178
- const runCommand = `docker run -d --name overmind-postgres-pgvector \\
179
- -p 5432:5432 \\
180
- -e POSTGRES_PASSWORD=overmind_temp_password_change_me \\
181
- -e POSTGRES_USER=postgres \\
182
- -v overmind_postgres_data:/var/lib/postgresql/data \\
183
- --restart unless-stopped \\
184
- pgvector/pgvector:pg16`;
185
-
186
- await runCommandAsync(runCommand, 'Démarrage PostgreSQL');
187
-
188
- // Wait for PostgreSQL to be ready
189
- console.log('⏳ Attente démarrage PostgreSQL (30s)...');
190
- await new Promise((resolve) => setTimeout(resolve, 30000));
191
-
192
- // Verify pgvector
193
- console.log('🔍 Vérification pgvector...');
194
- await runCommandAsync(
195
- 'docker exec overmind-postgres-pgvector psql -U postgres -c "CREATE EXTENSION IF NOT EXISTS vector;"',
196
- 'Activation pgvector'
197
- );
198
-
199
- console.log('✅ PostgreSQL + pgvector installés avec succès !');
200
- return true;
201
-
202
- } catch (error) {
203
- console.error('❌ Erreur installation PostgreSQL:', error.message);
204
- return false;
205
- }
206
- }
207
-
208
- function setupConfigurationFiles() {
209
- logSection('CONFIGURATION OVERMIND');
210
-
211
- // Create install directory
212
- if (!existsSync(INSTALL_DIR)) {
213
- mkdirSync(INSTALL_DIR, { recursive: true });
214
- console.log('✅ Dossier créé:', INSTALL_DIR);
215
- }
216
-
217
- // Copy docker-compose file
218
- const dockerComposePath = join(projectRoot, 'docker', 'docker-compose.yml');
219
- const destComposePath = join(INSTALL_DIR, 'docker-compose.yml');
220
-
221
- if (existsSync(dockerComposePath)) {
222
- copyFileSync(dockerComposePath, destComposePath);
223
- console.log('✅ docker-compose.yml copié');
224
- }
225
-
226
- // Copy .env.example if .env doesn't exist
227
- const envExamplePath = join(projectRoot, '.env.example');
228
- const envPath = join(INSTALL_DIR, '.env');
229
-
230
- if (!existsSync(envPath) && existsSync(envExamplePath)) {
231
- copyFileSync(envExamplePath, envPath);
232
- console.log('✅ .env créé (à éditer avec vos credentials)');
233
- }
234
-
235
- // Copy postgres-manager script
236
- const dockerManagerPath = join(__dirname, 'postgres-manager.mjs');
237
- const destManagerPath = join(INSTALL_DIR, 'postgres-manager.mjs');
238
-
239
- if (existsSync(dockerManagerPath)) {
240
- copyFileSync(dockerManagerPath, destManagerPath);
241
- console.log('✅ Scripts Docker installés');
242
- }
243
-
244
- return true;
245
- }
246
-
247
- async function startDockerServices() {
248
- logSection('DÉMARRAGE SERVICES DOCKER');
249
-
250
- const composeFile = join(INSTALL_DIR, 'docker-compose.yml');
251
-
252
- console.log('🚀 Démarrage PostgreSQL + pgvector...');
253
- try {
254
- await runCommandAsync(
255
- `docker-compose -f "${composeFile}" up -d`,
256
- 'Démarrage PostgreSQL'
257
- );
258
- console.log('✅ PostgreSQL + pgvector démarré');
259
- return true;
260
- } catch (error) {
261
- console.error('❌ Erreur démarrage Docker:', error.message);
262
- return false;
263
- }
264
- }
265
-
266
- async function createOvermindDatabase() {
267
- logSection('CRÉATION BASE OVERMIND');
268
-
269
- const setupDbPath = join(__dirname, 'setup-overmind-db.mjs');
270
- const destDbDir = INSTALL_DIR;
271
- const destDbPath = join(destDbDir, 'setup-overmind-db.mjs');
272
-
273
- try {
274
- if (!existsSync(destDbDir)) {
275
- mkdirSync(destDbDir, { recursive: true });
276
- }
277
- copyFileSync(setupDbPath, destDbPath);
278
-
279
- await runCommandAsync(
280
- `node "${destDbPath}"`,
281
- 'Initialisation DB OverMind'
282
- );
283
- return true;
284
- } catch (error) {
285
- console.error('❌ Erreur création DB:', error.message);
286
- return false;
287
- }
288
- }
289
-
290
- // ═══════════════════════════════════════════════════════════════════════════════
291
- // MAIN
292
- // ═══════════════════════════════════════════════════════════════════════════════
293
-
294
- async function main() {
295
- const args = process.argv.slice(2);
296
- const isFull = args.includes('--full');
297
-
298
- console.log('╔══════════════════════════════════════════════════════════════════╗');
299
- console.log('║ ║');
300
- console.log('║ 🧠 OVERMIND-MCP: SETUP AUTOMATISÉ COMPLET ║');
301
- console.log('║ ║');
302
- console.log('╚══════════════════════════════════════════════════════════════════╝');
303
- console.log('');
304
-
305
- if (!isFull) {
306
- console.log('ℹ️ USAGE: overmind-setup [--full]');
307
- console.log('');
308
- console.log(' --full: Installe TOUTES les dépendances (Docker, PostgreSQL, etc.)');
309
- console.log(' et configure OverMind automatiquement');
310
- console.log('');
311
- console.log(' Sans --full: Prépare juste les fichiers de configuration');
312
- console.log('');
313
-
314
- return;
315
- }
316
-
317
- // Step 1: Check Docker
318
- const hasDocker = checkDocker();
319
- if (!hasDocker) {
320
- const installed = await installDocker();
321
- if (!installed) {
322
- console.log('\n❌ SETUP ANNULÉ - Docker est requis pour le mode complet');
323
- console.log(' Installez Docker Desktop et relancez: overmind-setup --full');
324
- process.exit(1);
325
- }
326
- }
327
-
328
- // Step 2: Check PostgreSQL
329
- const hasPostgreSQL = checkPostgreSQL();
330
- if (!hasPostgreSQL) {
331
- const installed = await installPostgreSQL();
332
- if (!installed) {
333
- console.log('\n❌ SETUP ANNULÉ - PostgreSQL est requis pour le mode complet');
334
- process.exit(1);
335
- }
336
- }
337
-
338
- // Step 3: Setup configuration files
339
- setupConfigurationFiles();
340
-
341
- // Step 4: Start Docker services
342
- const servicesStarted = await startDockerServices();
343
- if (!servicesStarted) {
344
- console.log('\n❌ SETUP ANNULÉ - Impossible de démarrer les services');
345
- process.exit(1);
346
- }
347
-
348
- // Step 5: Create OverMind database
349
- const dbCreated = await createOvermindDatabase();
350
- if (!dbCreated) {
351
- console.log('\n❌ SETUP ANNULÉ - Impossible de créer la base OverMind');
352
- process.exit(1);
353
- }
354
-
355
- // Success!
356
- logSection('✅ SETUP COMPLET TERMINÉ AVEC SUCCÈS');
357
-
358
- console.log(`
359
- 🎉 OVERMIND-MCP EST PRÊT !
360
-
361
- 📋 SERVICES ACTIFS:
362
- ✅ PostgreSQL + pgvector (Vector DB 4096D)
363
- ✅ RabbitMQ (Message Broker)
364
- ✅ Temporal (Workflow Orchestrator)
365
- ✅ OverMind Agents (prêt à l'emploi)
366
-
367
- 🌐 INTERFACES:
368
- 📊 RabbitMQ Management: http://localhost:15672
369
- 📈 Temporal Web: http://localhost:8088
370
- 🗄️ PostgreSQL: localhost:5432
371
-
372
- 🚀 COMMANDES DISPONIBLES:
373
- overmind create-agent --name expert --runner claude
374
- overmind run-agent --runner claude --prompt "Analyse..."
375
- overmind-infra up/down/status/logs
376
-
377
- 📚 DOCUMENTATION:
378
- - https://deamondev888.github.io/overmind-mcp/
379
- - https://github.com/DeamonDev888/overmind-mcp
380
- - Discord: https://discord.gg/4AR82phtBz
381
-
382
- 💡 PREMIER TEST:
383
- overmind create-agent --name test --runner claude --prompt "Test d'OverMind"
384
-
385
- ═══════════════════════════════════════════════════════════════════════
386
- `);
387
- }
388
-
389
- // Run main
390
- if (import.meta.url === `file://${process.argv[1]}`) {
391
- main().catch((error) => {
392
- console.error('\n❌ ERREUR FATALE:', error.message);
393
- process.exit(1);
394
- });
395
- }
1
+ #!/usr/bin/env node
2
+ /**
3
+ * ═══════════════════════════════════════════════════════════════════════════════
4
+ * SETUP SCRIPT - Installation Automatique OverMind
5
+ * ═══════════════════════════════════════════════════════════════════════════════
6
+ * Script principal qui installe TOUTES les dépendances nécessaires à OverMind:
7
+ * - Docker (si pas présent)
8
+ * - PostgreSQL + pgvector (si pas présent)
9
+ * - RabbitMQ
10
+ * - Temporal
11
+ * - Configuration automatique
12
+ *
13
+ * Usage:
14
+ * overmind-setup [--full]
15
+ * ═══════════════════════════════════════════════════════════════════════════════
16
+ */
17
+
18
+ import { execSync, spawn } from 'child_process';
19
+ import { copyFileSync, existsSync, mkdirSync, writeFileSync } from 'fs';
20
+ import { join } from 'path';
21
+ import { fileURLToPath } from 'url';
22
+ import { dirname } from 'path';
23
+ import { createInterface } from 'readline';
24
+
25
+ const __filename = fileURLToPath(import.meta.url);
26
+ const __dirname = dirname(__filename);
27
+ const projectRoot = join(__dirname, '..');
28
+ const INSTALL_DIR = join(process.env.HOME || process.env.USERPROFILE || process.env.HOMEPATH, '.overmind');
29
+
30
+ // ═══════════════════════════════════════════════════════════════════════════════
31
+ // UTILS
32
+ // ═══════════════════════════════════════════════════════════════════════════════
33
+
34
+ function logSection(title) {
35
+ console.log('\n╔══════════════════════════════════════════════════════════════════╗');
36
+ console.log(`║ ${title.padEnd(64)} ║`);
37
+ console.log('╚══════════════════════════════════════════════════════════════════╝');
38
+ }
39
+
40
+ function runCommand(cmd, description) {
41
+ console.log(`\n🔧 ${description}`);
42
+ console.log(` $ ${cmd}`);
43
+ try {
44
+ execSync(cmd, { stdio: 'inherit' });
45
+ console.log(`✅ ${description} terminé`);
46
+ return true;
47
+ } catch (error) {
48
+ console.error(`❌ Erreur: ${error.message}`);
49
+ return false;
50
+ }
51
+ }
52
+
53
+ function runCommandAsync(cmd, description) {
54
+ return new Promise((resolve, reject) => {
55
+ console.log(`\n🔧 ${description}`);
56
+ console.log(` $ ${cmd}`);
57
+ const child = spawn(cmd, { shell: true, stdio: 'inherit' });
58
+
59
+ child.on('close', (code) => {
60
+ if (code === 0) {
61
+ console.log(`✅ ${description} terminé`);
62
+ resolve(true);
63
+ } else {
64
+ console.error(`❌ Erreur (code ${code})`);
65
+ reject(new Error(`Command failed with code ${code}`));
66
+ }
67
+ });
68
+
69
+ child.on('error', (err) => {
70
+ console.error('❌ Erreur:', err.message);
71
+ reject(err);
72
+ });
73
+ });
74
+ }
75
+
76
+ async function promptYesNo(question) {
77
+ const rl = createInterface({
78
+ input: process.stdin,
79
+ output: process.stdout,
80
+ });
81
+
82
+ const answer = await new Promise((resolve) => {
83
+ rl.question(`${question} (y/N): `, (answer) => {
84
+ rl.close();
85
+ resolve(answer.toLowerCase().startsWith('y'));
86
+ });
87
+ });
88
+
89
+ return answer;
90
+ }
91
+
92
+ // ═══════════════════════════════════════════════════════════════════════════════
93
+ // CHECKS
94
+ // ═══════════════════════════════════════════════════════════════════════════════
95
+
96
+ function checkDocker() {
97
+ try {
98
+ execSync('docker --version', { stdio: 'pipe' });
99
+ return true;
100
+ } catch {
101
+ return false;
102
+ }
103
+ }
104
+
105
+ function checkPostgreSQL() {
106
+ try {
107
+ execSync('docker ps --filter "name=postgres" --format "{{.Names}}"', { stdio: 'pipe' });
108
+ return true;
109
+ } catch {
110
+ try {
111
+ execSync('psql --version', { stdio: 'pipe' });
112
+ return true;
113
+ } catch {
114
+ return false;
115
+ }
116
+ }
117
+ }
118
+
119
+ // ═══════════════════════════════════════════════════════════════════════════════
120
+ // INSTALLATION STEPS
121
+ // ═══════════════════════════════════════════════════════════════════════════════
122
+
123
+ async function installDocker() {
124
+ logSection('INSTALLATION DOCKER');
125
+
126
+ if (checkDocker()) {
127
+ console.log('✅ Docker est déjà installé');
128
+ return true;
129
+ }
130
+
131
+ console.log('ℹ️ Docker non trouvé.');
132
+ console.log('');
133
+ console.log('📥 Docker Desktop est requis pour OverMind-MCP:');
134
+ console.log(' - Windows: https://www.docker.com/products/docker-desktop/');
135
+ console.log(' - Mac: https://www.docker.com/products/docker-desktop/');
136
+ console.log('');
137
+ console.log('📋 Instructions:');
138
+ console.log(' 1. Téléchargez et installez Docker Desktop');
139
+ console.log(' 2. Démarrez Docker Desktop');
140
+ console.log(' 3. Relancez: overmind-setup --full');
141
+ console.log('');
142
+
143
+ const answer = await promptYesNo('Voulez-vous ouvrir le site de téléchargement maintenant ?');
144
+ if (answer) {
145
+ const url = process.platform === 'win32'
146
+ ? 'https://www.docker.com/products/docker-desktop/'
147
+ : 'https://www.docker.com/products/docker-desktop/';
148
+
149
+ try {
150
+ execSync(`start ${url}`, { stdio: 'inherit' });
151
+ console.log('✅ Navigateur ouvert. Attendez l\'installation de Docker.');
152
+ } catch {
153
+ console.log('⚠️ Impossible d\'ouvrir le navigateur automatiquement.');
154
+ console.log(` Ouvrez manuellement: ${url}`);
155
+ }
156
+ }
157
+
158
+ return false;
159
+ }
160
+
161
+ async function installPostgreSQL() {
162
+ logSection('INSTALLATION POSTGRESQL + PGVECTOR');
163
+
164
+ if (checkPostgreSQL()) {
165
+ console.log('✅ PostgreSQL est déjà installé');
166
+ return true;
167
+ }
168
+
169
+ console.log('🐳 Installation PostgreSQL + pgvector en Docker...');
170
+ console.log('');
171
+
172
+ try {
173
+ // Pull and start PostgreSQL container
174
+ console.log('📥 Téléchargement image pgvector/pgvector:pg16...');
175
+ execSync('docker pull pgvector/pgvector:pg16', { stdio: 'inherit' });
176
+
177
+ console.log('🚀 Démarrage container PostgreSQL...');
178
+ const runCommand = `docker run -d --name overmind-postgres-pgvector \\
179
+ -p 5432:5432 \\
180
+ -e POSTGRES_PASSWORD=overmind_temp_password_change_me \\
181
+ -e POSTGRES_USER=postgres \\
182
+ -v overmind_postgres_data:/var/lib/postgresql/data \\
183
+ --restart unless-stopped \\
184
+ pgvector/pgvector:pg16`;
185
+
186
+ await runCommandAsync(runCommand, 'Démarrage PostgreSQL');
187
+
188
+ // Wait for PostgreSQL to be ready
189
+ console.log('⏳ Attente démarrage PostgreSQL (30s)...');
190
+ await new Promise((resolve) => setTimeout(resolve, 30000));
191
+
192
+ // Verify pgvector
193
+ console.log('🔍 Vérification pgvector...');
194
+ await runCommandAsync(
195
+ 'docker exec overmind-postgres-pgvector psql -U postgres -c "CREATE EXTENSION IF NOT EXISTS vector;"',
196
+ 'Activation pgvector'
197
+ );
198
+
199
+ console.log('✅ PostgreSQL + pgvector installés avec succès !');
200
+ return true;
201
+
202
+ } catch (error) {
203
+ console.error('❌ Erreur installation PostgreSQL:', error.message);
204
+ return false;
205
+ }
206
+ }
207
+
208
+ function setupConfigurationFiles() {
209
+ logSection('CONFIGURATION OVERMIND');
210
+
211
+ // Create install directory
212
+ if (!existsSync(INSTALL_DIR)) {
213
+ mkdirSync(INSTALL_DIR, { recursive: true });
214
+ console.log('✅ Dossier créé:', INSTALL_DIR);
215
+ }
216
+
217
+ // Copy docker-compose file
218
+ const dockerComposePath = join(projectRoot, 'docker', 'docker-compose.yml');
219
+ const destComposePath = join(INSTALL_DIR, 'docker-compose.yml');
220
+
221
+ if (existsSync(dockerComposePath)) {
222
+ copyFileSync(dockerComposePath, destComposePath);
223
+ console.log('✅ docker-compose.yml copié');
224
+ }
225
+
226
+ // Copy .env.example if .env doesn't exist
227
+ const envExamplePath = join(projectRoot, '.env.example');
228
+ const envPath = join(INSTALL_DIR, '.env');
229
+
230
+ if (!existsSync(envPath) && existsSync(envExamplePath)) {
231
+ copyFileSync(envExamplePath, envPath);
232
+ console.log('✅ .env créé (à éditer avec vos credentials)');
233
+ }
234
+
235
+ // Copy postgres-manager script
236
+ const dockerManagerPath = join(__dirname, 'postgres-manager.mjs');
237
+ const destManagerPath = join(INSTALL_DIR, 'postgres-manager.mjs');
238
+
239
+ if (existsSync(dockerManagerPath)) {
240
+ copyFileSync(dockerManagerPath, destManagerPath);
241
+ console.log('✅ Scripts Docker installés');
242
+ }
243
+
244
+ return true;
245
+ }
246
+
247
+ async function startDockerServices() {
248
+ logSection('DÉMARRAGE SERVICES DOCKER');
249
+
250
+ const composeFile = join(INSTALL_DIR, 'docker-compose.yml');
251
+
252
+ console.log('🚀 Démarrage PostgreSQL + pgvector...');
253
+ try {
254
+ await runCommandAsync(
255
+ `docker-compose -f "${composeFile}" up -d`,
256
+ 'Démarrage PostgreSQL'
257
+ );
258
+ console.log('✅ PostgreSQL + pgvector démarré');
259
+ return true;
260
+ } catch (error) {
261
+ console.error('❌ Erreur démarrage Docker:', error.message);
262
+ return false;
263
+ }
264
+ }
265
+
266
+ async function createOvermindDatabase() {
267
+ logSection('CRÉATION BASE OVERMIND');
268
+
269
+ const setupDbPath = join(__dirname, 'setup-overmind-db.mjs');
270
+ const destDbDir = INSTALL_DIR;
271
+ const destDbPath = join(destDbDir, 'setup-overmind-db.mjs');
272
+
273
+ try {
274
+ if (!existsSync(destDbDir)) {
275
+ mkdirSync(destDbDir, { recursive: true });
276
+ }
277
+ copyFileSync(setupDbPath, destDbPath);
278
+
279
+ await runCommandAsync(
280
+ `node "${destDbPath}"`,
281
+ 'Initialisation DB OverMind'
282
+ );
283
+ return true;
284
+ } catch (error) {
285
+ console.error('❌ Erreur création DB:', error.message);
286
+ return false;
287
+ }
288
+ }
289
+
290
+ // ═══════════════════════════════════════════════════════════════════════════════
291
+ // MAIN
292
+ // ═══════════════════════════════════════════════════════════════════════════════
293
+
294
+ async function main() {
295
+ const args = process.argv.slice(2);
296
+ const isFull = args.includes('--full');
297
+
298
+ console.log('╔══════════════════════════════════════════════════════════════════╗');
299
+ console.log('║ ║');
300
+ console.log('║ 🧠 OVERMIND-MCP: SETUP AUTOMATISÉ COMPLET ║');
301
+ console.log('║ ║');
302
+ console.log('╚══════════════════════════════════════════════════════════════════╝');
303
+ console.log('');
304
+
305
+ if (!isFull) {
306
+ console.log('ℹ️ USAGE: overmind-setup [--full]');
307
+ console.log('');
308
+ console.log(' --full: Installe TOUTES les dépendances (Docker, PostgreSQL, etc.)');
309
+ console.log(' et configure OverMind automatiquement');
310
+ console.log('');
311
+ console.log(' Sans --full: Prépare juste les fichiers de configuration');
312
+ console.log('');
313
+
314
+ return;
315
+ }
316
+
317
+ // Step 1: Check Docker
318
+ const hasDocker = checkDocker();
319
+ if (!hasDocker) {
320
+ const installed = await installDocker();
321
+ if (!installed) {
322
+ console.log('\n❌ SETUP ANNULÉ - Docker est requis pour le mode complet');
323
+ console.log(' Installez Docker Desktop et relancez: overmind-setup --full');
324
+ process.exit(1);
325
+ }
326
+ }
327
+
328
+ // Step 2: Check PostgreSQL
329
+ const hasPostgreSQL = checkPostgreSQL();
330
+ if (!hasPostgreSQL) {
331
+ const installed = await installPostgreSQL();
332
+ if (!installed) {
333
+ console.log('\n❌ SETUP ANNULÉ - PostgreSQL est requis pour le mode complet');
334
+ process.exit(1);
335
+ }
336
+ }
337
+
338
+ // Step 3: Setup configuration files
339
+ setupConfigurationFiles();
340
+
341
+ // Step 4: Start Docker services
342
+ const servicesStarted = await startDockerServices();
343
+ if (!servicesStarted) {
344
+ console.log('\n❌ SETUP ANNULÉ - Impossible de démarrer les services');
345
+ process.exit(1);
346
+ }
347
+
348
+ // Step 5: Create OverMind database
349
+ const dbCreated = await createOvermindDatabase();
350
+ if (!dbCreated) {
351
+ console.log('\n❌ SETUP ANNULÉ - Impossible de créer la base OverMind');
352
+ process.exit(1);
353
+ }
354
+
355
+ // Success!
356
+ logSection('✅ SETUP COMPLET TERMINÉ AVEC SUCCÈS');
357
+
358
+ console.log(`
359
+ 🎉 OVERMIND-MCP EST PRÊT !
360
+
361
+ 📋 SERVICES ACTIFS:
362
+ ✅ PostgreSQL + pgvector (Vector DB 4096D)
363
+ ✅ RabbitMQ (Message Broker)
364
+ ✅ Temporal (Workflow Orchestrator)
365
+ ✅ OverMind Agents (prêt à l'emploi)
366
+
367
+ 🌐 INTERFACES:
368
+ 📊 RabbitMQ Management: http://localhost:15672
369
+ 📈 Temporal Web: http://localhost:8088
370
+ 🗄️ PostgreSQL: localhost:5432
371
+
372
+ 🚀 COMMANDES DISPONIBLES:
373
+ overmind create-agent --name expert --runner claude
374
+ overmind run-agent --runner claude --prompt "Analyse..."
375
+ overmind-infra up/down/status/logs
376
+
377
+ 📚 DOCUMENTATION:
378
+ - https://deamondev888.github.io/overmind-mcp/
379
+ - https://github.com/DeamonDev888/overmind-mcp
380
+ - Discord: https://discord.gg/4AR82phtBz
381
+
382
+ 💡 PREMIER TEST:
383
+ overmind create-agent --name test --runner claude --prompt "Test d'OverMind"
384
+
385
+ ═══════════════════════════════════════════════════════════════════════
386
+ `);
387
+ }
388
+
389
+ // Run main
390
+ if (import.meta.url === `file://${process.argv[1]}`) {
391
+ main().catch((error) => {
392
+ console.error('\n❌ ERREUR FATALE:', error.message);
393
+ process.exit(1);
394
+ });
395
+ }