@patricksardinha/agentkit-cli 0.2.0 → 0.3.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/dist/cli.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/cli.ts","../src/commands/init.ts","../src/detectors/stackDetector.ts","../src/detectors/gitDetector.ts","../src/utils/blueprintParser.ts","../src/templates/react.ts","../src/templates/nextjs.ts","../src/templates/tauri.ts","../src/templates/fastapi.ts","../src/templates/express.ts","../src/templates/node.ts","../src/templates/unknown.ts","../src/generators/claudeMdGenerator.ts","../src/utils/agentParser.ts","../src/generators/workflowGenerator.ts","../src/generators/playbookGenerator.ts","../src/generators/skillsGenerator.ts","../src/utils/logger.ts","../src/commands/add.ts","../src/commands/status.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from 'commander'\nimport { registerInit } from './commands/init.js'\nimport { registerAdd } from './commands/add.js'\nimport { registerStatus } from './commands/status.js'\n\nconst program = new Command()\n\nprogram\n .name('agentkit')\n .description('Scaffolder des workflows multi-agents Claude Code')\n .version('0.1.0')\n\nregisterInit(program)\nregisterAdd(program)\nregisterStatus(program)\n\nprogram.parse()\n","import type { Command } from 'commander'\nimport { writeFile, readFile } from 'node:fs/promises'\nimport { join } from 'node:path'\nimport inquirer from 'inquirer'\nimport ora from 'ora'\nimport { detectStack } from '../detectors/stackDetector.js'\nimport { isGitRepo } from '../detectors/gitDetector.js'\nimport { generateClaudeMd } from '../generators/claudeMdGenerator.js'\nimport { generateWorkflow } from '../generators/workflowGenerator.js'\nimport { generatePlaybook } from '../generators/playbookGenerator.js'\nimport { generateSkills } from '../generators/skillsGenerator.js'\nimport { extractAgentsFromWorkflow } from '../utils/agentParser.js'\nimport { logger } from '../utils/logger.js'\nimport type { StackInfo } from '../detectors/stackDetector.js'\nimport { basename } from 'node:path'\n\nconst FRAMEWORK_LABELS: Record<StackInfo['framework'], string> = {\n react: 'React',\n nextjs: 'Next.js',\n tauri: 'Tauri',\n fastapi: 'FastAPI (Python)',\n express: 'Express',\n node: 'Node.js',\n unknown: 'Unknown (generic)',\n}\n\nasync function fileExists(path: string): Promise<boolean> {\n try {\n await readFile(path)\n return true\n } catch {\n return false\n }\n}\n\nexport function registerInit(program: Command): void {\n program\n .command('init')\n .description('Génère CLAUDE.md et AGENT_WORKFLOW.md dans le dossier courant')\n .option('-f, --force', 'Écrase les fichiers existants sans confirmation')\n .option('--blueprint <path>', 'Fichier blueprint .md à utiliser pour personnaliser les fichiers générés')\n .action(async (options: { force?: boolean; blueprint?: string }) => {\n const cwd = process.cwd()\n\n const spinner = ora('Détection de la stack…').start()\n const [stack, isGit] = await Promise.all([detectStack(cwd), isGitRepo(cwd)])\n spinner.stop()\n\n if (!isGit) {\n logger.warn('Ce dossier n\\'est pas un repo git — lancez git init si nécessaire')\n }\n\n const label = FRAMEWORK_LABELS[stack.framework]\n logger.info(`Stack détectée : ${label} (${stack.language})`)\n\n const { confirmed } = await inquirer.prompt<{ confirmed: boolean }>([\n {\n type: 'confirm',\n name: 'confirmed',\n message: `Générer les fichiers pour ${label} ?`,\n default: true,\n },\n ])\n\n if (!confirmed) {\n logger.warn('Annulé.')\n return\n }\n\n const claudeMdPath = join(cwd, 'CLAUDE.md')\n const workflowPath = join(cwd, 'AGENT_WORKFLOW.md')\n const playbookPath = join(cwd, 'PLAYBOOK.md')\n\n // Resolve project name from package.json or directory name\n let projectName = basename(cwd)\n try {\n const pkg = JSON.parse(await readFile(join(cwd, 'package.json'), 'utf-8')) as { name?: string }\n if (pkg.name) projectName = pkg.name\n } catch { /* fallback to dirname */ }\n\n if (!options.force) {\n const existing: string[] = []\n if (await fileExists(claudeMdPath)) existing.push('CLAUDE.md')\n if (await fileExists(workflowPath)) existing.push('AGENT_WORKFLOW.md')\n if (await fileExists(playbookPath)) existing.push('PLAYBOOK.md')\n\n if (existing.length > 0) {\n const { overwrite } = await inquirer.prompt<{ overwrite: boolean }>([\n {\n type: 'confirm',\n name: 'overwrite',\n message: `${existing.join(' et ')} existe déjà. Écraser ?`,\n default: false,\n },\n ])\n if (!overwrite) {\n logger.warn('Annulé.')\n return\n }\n }\n }\n\n // Load blueprint if provided\n let blueprintContent: string | undefined\n if (options.blueprint) {\n try {\n blueprintContent = await readFile(options.blueprint, 'utf-8')\n } catch {\n logger.error(`Blueprint introuvable : ${options.blueprint}`)\n process.exit(1)\n }\n }\n\n const genSpinner = ora('Génération des fichiers…').start()\n const claudeMdContent = generateClaudeMd(stack, blueprintContent)\n const workflowContent = generateWorkflow(stack, blueprintContent)\n const agents = extractAgentsFromWorkflow(workflowContent)\n const playbookContent = generatePlaybook({ agents, projectName })\n await writeFile(claudeMdPath, claudeMdContent, 'utf-8')\n await writeFile(workflowPath, workflowContent, 'utf-8')\n await writeFile(playbookPath, playbookContent, 'utf-8')\n await generateSkills(agents, cwd)\n genSpinner.succeed('Fichiers générés')\n\n logger.success('CLAUDE.md → créé')\n logger.success('AGENT_WORKFLOW.md → créé')\n logger.success('PLAYBOOK.md → créé')\n logger.success(`agents/ → ${agents.length} dossier(s) créé(s)`)\n })\n}\n","import { readFile, access } from 'node:fs/promises'\nimport { join } from 'node:path'\n\nexport interface StackInfo {\n framework: 'react' | 'nextjs' | 'tauri' | 'fastapi' | 'express' | 'node' | 'unknown'\n language: 'typescript' | 'javascript' | 'python' | 'unknown'\n hasTypeScript: boolean\n extras: string[]\n}\n\nasync function pathExists(p: string): Promise<boolean> {\n try {\n await access(p)\n return true\n } catch {\n return false\n }\n}\n\nasync function readJson(p: string): Promise<Record<string, unknown> | null> {\n try {\n const raw = await readFile(p, 'utf-8')\n return JSON.parse(raw) as Record<string, unknown>\n } catch {\n return null\n }\n}\n\nasync function readText(p: string): Promise<string | null> {\n try {\n return await readFile(p, 'utf-8')\n } catch {\n return null\n }\n}\n\nexport async function detectStack(projectPath: string): Promise<StackInfo> {\n const info: StackInfo = {\n framework: 'unknown',\n language: 'unknown',\n hasTypeScript: false,\n extras: [],\n }\n\n const packageJson = await readJson(join(projectPath, 'package.json'))\n const requirementsTxt = await readText(join(projectPath, 'requirements.txt'))\n const hasTauriDir = await pathExists(join(projectPath, 'src-tauri'))\n const hasTsConfig = await pathExists(join(projectPath, 'tsconfig.json'))\n\n if (packageJson !== null) {\n const deps = (packageJson.dependencies as Record<string, string>) ?? {}\n const devDeps = (packageJson.devDependencies as Record<string, string>) ?? {}\n const allDeps = { ...deps, ...devDeps }\n\n info.hasTypeScript = 'typescript' in allDeps || hasTsConfig\n info.language = info.hasTypeScript ? 'typescript' : 'javascript'\n\n // Order matters: most specific first\n if ('next' in allDeps) {\n info.framework = 'nextjs'\n } else if (hasTauriDir || '@tauri-apps/api' in allDeps || '@tauri-apps/cli' in allDeps) {\n info.framework = 'tauri'\n } else if ('react' in allDeps) {\n info.framework = 'react'\n } else if ('express' in allDeps) {\n info.framework = 'express'\n } else {\n info.framework = 'node'\n }\n\n if ('vitest' in allDeps || 'jest' in allDeps) info.extras.push('testing')\n if ('prisma' in allDeps || '@prisma/client' in allDeps) info.extras.push('prisma')\n if ('tailwindcss' in allDeps) info.extras.push('tailwind')\n }\n\n if (requirementsTxt !== null && info.framework === 'unknown') {\n info.language = 'python'\n if (/\\bfastapi\\b/i.test(requirementsTxt)) {\n info.framework = 'fastapi'\n }\n }\n\n if (hasTauriDir && info.framework === 'unknown') {\n info.framework = 'tauri'\n }\n\n return info\n}\n","import { access } from 'node:fs/promises'\nimport { join } from 'node:path'\n\nexport async function isGitRepo(projectPath: string): Promise<boolean> {\n try {\n await access(join(projectPath, '.git'))\n return true\n } catch {\n return false\n }\n}\n","export interface BlueprintFeature {\n name: string\n items: string[]\n}\n\nexport function parseBlueprint(content: string): BlueprintFeature[] {\n const features: BlueprintFeature[] = []\n\n // Locate all ## headings (not # or ###)\n const sectionRegex = /^## (.+)$/gm\n const sections: Array<{ name: string; start: number }> = []\n let m: RegExpExecArray | null\n while ((m = sectionRegex.exec(content)) !== null) {\n sections.push({ name: m[1].trim(), start: m.index })\n }\n\n for (let i = 0; i < sections.length; i++) {\n const section = sections[i]\n const end = i + 1 < sections.length ? sections[i + 1].start : content.length\n const body = content.slice(section.start, end)\n\n const items = [...body.matchAll(/^[-*]\\s+(.+)$/gm)].map((r) => r[1].trim())\n\n features.push({ name: section.name, items })\n }\n\n return features\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n const testLine = stack.extras.includes('testing') ? '- `npm test` — run tests\\n' : ''\n return `# CLAUDE.md — React Project\n\n## Stack\n- Framework : React (${lang})\n- Language : ${lang}\n- Build : Vite\n\n## Commands\n- \\`npm run dev\\` — development server\n- \\`npm run build\\` — production build\n${testLine}\n## Structure\nsrc/\n components/ ← UI components (PascalCase)\n hooks/ ← custom hooks (prefix: use*)\n pages/ ← page-level components\n utils/ ← shared helpers\n\n## Conventions\n1. Components in PascalCase\n2. Hooks prefixed with \\`use\\`\n3. Props interfaces named \\`*Props\\`\n4. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# Agent Workflow — React Project\n\n## Stack détectée\nFramework: React | Language: ${lang}\n\n## Agents\n\n### Agent 1 · Components\nPérimètre : composants UI réutilisables\nProduit : src/components/\nCritère : composants documentés et testés\n\n### Agent 2 · State & Hooks\nPérimètre : state management, hooks personnalisés\nProduit : src/hooks/\nCritère : hooks testés unitairement\n\n### Agent 3 · Pages & Routing\nPérimètre : assemblage des pages, react-router\nProduit : src/pages/\nCritère : navigation fonctionnelle\n\n### Agent 4 · Tests & CI\nPérimètre : couverture de tests, configuration CI\nProduit : tests/, .github/workflows/\nCritère : npm test passe\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const hasTailwind = stack.extras.includes('tailwind')\n const hasPrisma = stack.extras.includes('prisma')\n return `# CLAUDE.md — Next.js Project\n\n## Stack\n- Framework : Next.js (TypeScript)\n- Rendering : App Router (RSC + Client Components)\n- Styling : ${hasTailwind ? 'Tailwind CSS' : 'CSS Modules'}\n${hasPrisma ? '- Database : Prisma ORM\\n' : ''}\n## Commands\n- \\`npm run dev\\` — development server (http://localhost:3000)\n- \\`npm run build\\` — production build\n- \\`npm start\\` — production server\n- \\`npm test\\` — run tests\n\n## Structure\nsrc/\n app/ ← App Router pages and layouts\n components/ ← shared UI components\n lib/ ← server utilities, db clients\n utils/ ← shared helpers\n\n## Conventions\n1. Server Components by default, \\`'use client'\\` only when needed\n2. API routes in \\`src/app/api/\\`\n3. Environment variables via \\`src/env.ts\\` (validated)\n4. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const hasPrisma = stack.extras.includes('prisma')\n return `# Agent Workflow — Next.js Project\n\n## Stack détectée\nFramework: Next.js | Language: TypeScript\n\n## Agents\n\n### Agent 1 · Data Layer\nPérimètre : schéma${hasPrisma ? ' Prisma' : ''}, types, server actions\nProduit : src/lib/, ${hasPrisma ? 'prisma/schema.prisma' : 'src/types/'}\nCritère : types compilent, migrations propres\n\n### Agent 2 · UI Components\nPérimètre : composants réutilisables (Server + Client)\nProduit : src/components/\nCritère : composants rendus sans erreur\n\n### Agent 3 · Pages & Layout\nPérimètre : App Router, layouts, pages\nProduit : src/app/\nCritère : navigation fonctionnelle, build passe\n\n### Agent 4 · API & Tests\nPérimètre : API routes, tests e2e/unitaires\nProduit : src/app/api/, tests/\nCritère : npm test passe\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# CLAUDE.md — Tauri Project\n\n## Stack\n- Framework : Tauri (Rust + ${lang} frontend)\n- Language : Rust (backend) + ${lang} (frontend)\n- Build : Cargo + Vite\n\n## Commands\n- \\`npm run tauri dev\\` — development (hot reload)\n- \\`npm run tauri build\\` — production bundle\n- \\`npm run build\\` — frontend only\n- \\`npm test\\` — run tests\n\n## Structure\nsrc/ ← frontend (${lang})\n components/\n utils/\nsrc-tauri/ ← Rust backend\n src/\n main.rs ← Tauri entry point\n commands.rs ← Tauri commands (IPC)\n tauri.conf.json\n\n## Conventions\n1. IPC commands defined in \\`src-tauri/src/commands.rs\\`\n2. Frontend invokes via \\`@tauri-apps/api/tauri\\`\n3. No direct filesystem access from frontend\n4. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# Agent Workflow — Tauri Project\n\n## Stack détectée\nFramework: Tauri | Language: Rust + ${lang}\n\n## Agents\n\n### Agent 1 · Rust Commands\nPérimètre : commandes Tauri (IPC), permissions\nProduit : src-tauri/src/commands.rs, tauri.conf.json\nCritère : \\`cargo build\\` passe\n\n### Agent 2 · Frontend UI\nPérimètre : interface ${lang}, intégration IPC\nProduit : src/components/, src/utils/\nCritère : appels IPC fonctionnels\n\n### Agent 3 · Build & Packaging\nPérimètre : configuration build, icônes, installeurs\nProduit : src-tauri/tauri.conf.json, icons/\nCritère : \\`npm run tauri build\\` produit un bundle\n\n### Agent 4 · Tests\nPérimètre : tests Rust + tests frontend\nProduit : src-tauri/tests/, tests/\nCritère : \\`cargo test\\` + \\`npm test\\` passent\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(_stack: StackInfo): string {\n return `# CLAUDE.md — FastAPI Project\n\n## Stack\n- Framework : FastAPI (Python)\n- Language : Python 3.11+\n- Server : Uvicorn\n- Validation: Pydantic v2\n\n## Commands\n- \\`uvicorn main:app --reload\\` — development server (http://localhost:8000)\n- \\`pytest\\` — run tests\n- \\`pip install -r requirements.txt\\` — install dependencies\n\n## Structure\napp/\n main.py ← FastAPI app entry point\n routers/ ← API route groups\n models/ ← Pydantic models\n services/ ← business logic\n dependencies/ ← FastAPI dependencies (DI)\ntests/ ← pytest tests\n\n## Conventions\n1. Routers grouped by domain in \\`app/routers/\\`\n2. Pydantic models for all request/response bodies\n3. Business logic in \\`app/services/\\`, not in routes\n4. Async endpoints by default (\\`async def\\`)\n5. Environment variables via \\`python-dotenv\\` + \\`pydantic-settings\\`\n`\n}\n\nexport function workflow(_stack: StackInfo): string {\n return `# Agent Workflow — FastAPI Project\n\n## Stack détectée\nFramework: FastAPI | Language: Python\n\n## Agents\n\n### Agent 1 · Models & Schemas\nPérimètre : modèles Pydantic, schémas DB (SQLAlchemy/SQLModel)\nProduit : app/models/\nCritère : modèles validés, migrations propres\n\n### Agent 2 · Services\nPérimètre : logique métier, accès base de données\nProduit : app/services/\nCritère : services testés unitairement (pytest)\n\n### Agent 3 · Routers & API\nPérimètre : routes FastAPI, dépendances, auth\nProduit : app/routers/, app/dependencies/\nCritère : endpoints documentés (OpenAPI), tests d'intégration\n\n### Agent 4 · Tests & CI\nPérimètre : couverture pytest, configuration CI\nProduit : tests/, .github/workflows/\nCritère : \\`pytest\\` passe à 100%\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n const hasPrisma = stack.extras.includes('prisma')\n return `# CLAUDE.md — Express Project\n\n## Stack\n- Framework : Express (${lang})\n- Language : ${lang}\n- Runtime : Node.js 20+\n${hasPrisma ? '- Database : Prisma ORM\\n' : ''}\n## Commands\n- \\`npm run dev\\` — development server (nodemon)\n- \\`npm run build\\` — compile TypeScript\n- \\`npm start\\` — production server\n- \\`npm test\\` — run tests\n\n## Structure\nsrc/\n routes/ ← Express routers (one per domain)\n controllers/ ← request handlers\n services/ ← business logic\n middleware/ ← Express middleware\n utils/ ← shared helpers\n\n## Conventions\n1. Routes grouped by domain in \\`src/routes/\\`\n2. Business logic in \\`src/services/\\`, not in controllers\n3. Middleware for cross-cutting concerns (auth, validation)\n4. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# Agent Workflow — Express Project\n\n## Stack détectée\nFramework: Express | Language: ${lang}\n\n## Agents\n\n### Agent 1 · Data & Models\nPérimètre : modèles de données, accès DB\nProduit : src/models/, src/services/db.ts\nCritère : connexion DB fonctionnelle\n\n### Agent 2 · Services\nPérimètre : logique métier\nProduit : src/services/\nCritère : services testés unitairement\n\n### Agent 3 · Routes & Controllers\nPérimètre : routes Express, validation, auth\nProduit : src/routes/, src/controllers/, src/middleware/\nCritère : endpoints répondent correctement\n\n### Agent 4 · Tests & CI\nPérimètre : tests d'intégration, configuration CI\nProduit : tests/, .github/workflows/\nCritère : npm test passe\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# CLAUDE.md — Node.js Project\n\n## Stack\n- Runtime : Node.js 20+\n- Language : ${lang}\n\n## Commands\n- \\`npm run dev\\` — development (with watch)\n- \\`npm run build\\` — compile${stack.hasTypeScript ? ' TypeScript' : ''}\n- \\`npm start\\` — run production build\n- \\`npm test\\` — run tests\n\n## Structure\nsrc/\n index.ts ← entry point\n lib/ ← core library code\n utils/ ← shared helpers\n\n## Conventions\n1. Modules follow single-responsibility principle\n2. Async/await over callbacks\n3. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# Agent Workflow — Node.js Project\n\n## Stack détectée\nRuntime: Node.js | Language: ${lang}\n\n## Agents\n\n### Agent 1 · Core Library\nPérimètre : logique principale\nProduit : src/lib/\nCritère : module fonctionne et testé\n\n### Agent 2 · CLI / API\nPérimètre : interface utilisateur (CLI ou API)\nProduit : src/index.ts, src/cli.ts\nCritère : commandes fonctionnelles\n\n### Agent 3 · Tests & CI\nPérimètre : couverture de tests, configuration CI\nProduit : tests/, .github/workflows/\nCritère : npm test passe\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(_stack: StackInfo): string {\n return `# CLAUDE.md\n\n## Stack\nStack non détectée automatiquement — à remplir manuellement.\n\n## Commands\n- À définir selon le projet\n\n## Structure\nsrc/ ← code source\ntests/ ← tests\n\n## Conventions\n1. Tout output console passe par un logger centralisé\n2. À compléter selon les conventions du projet\n`\n}\n\nexport function workflow(_stack: StackInfo): string {\n return `# Agent Workflow\n\n## Stack détectée\nStack inconnue — workflow générique.\n\n## Agents\n\n### Agent 1 · Setup\nPérimètre : configuration initiale du projet\nProduit : structure de base\nCritère : projet compilable\n\n### Agent 2 · Core\nPérimètre : logique principale\nProduit : src/\nCritère : fonctionnalités principales opérationnelles\n\n### Agent 3 · Tests\nPérimètre : couverture de tests\nProduit : tests/\nCritère : tests passent\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\nimport { parseBlueprint } from '../utils/blueprintParser.js'\nimport * as react from '../templates/react.js'\nimport * as nextjs from '../templates/nextjs.js'\nimport * as tauri from '../templates/tauri.js'\nimport * as fastapi from '../templates/fastapi.js'\nimport * as express from '../templates/express.js'\nimport * as node from '../templates/node.js'\nimport * as unknown from '../templates/unknown.js'\n\nexport function generateClaudeMd(stack: StackInfo, blueprintContent?: string): string {\n let base: string\n switch (stack.framework) {\n case 'react': base = react.claudeMd(stack); break\n case 'nextjs': base = nextjs.claudeMd(stack); break\n case 'tauri': base = tauri.claudeMd(stack); break\n case 'fastapi': base = fastapi.claudeMd(stack); break\n case 'express': base = express.claudeMd(stack); break\n case 'node': base = node.claudeMd(stack); break\n default: base = unknown.claudeMd(stack)\n }\n\n if (!blueprintContent) return base\n\n const features = parseBlueprint(blueprintContent)\n if (features.length === 0) return base\n\n const featureLines = features\n .map((f, i) => {\n const sub = f.items.length > 0 ? '\\n' + f.items.map((it) => ` - ${it}`).join('\\n') : ''\n return `${i + 1}. **${f.name}**${sub}`\n })\n .join('\\n')\n\n const featureSection = `\\n## Features (Blueprint)\\n\\n${featureLines}\\n`\n\n const conventionsIdx = base.indexOf('\\n## Conventions')\n if (conventionsIdx !== -1) {\n return base.slice(0, conventionsIdx) + featureSection + base.slice(conventionsIdx)\n }\n return base + featureSection\n}\n","import type { Agent } from '../types/agent.js'\n\nexport function toSlug(name: string): string {\n return name\n .toLowerCase()\n .replace(/[·•&]/g, ' ')\n .replace(/[^\\w\\s-]/g, '')\n .trim()\n .replace(/\\s+/g, '-')\n .replace(/-+/g, '-')\n .replace(/^-|-$/g, '')\n}\n\nfunction getFieldValue(lines: string[], pattern: RegExp): string {\n for (const line of lines) {\n const m = line.match(pattern)\n if (m) return (m[1] ?? '').trim()\n }\n return ''\n}\n\nexport function extractAgentsFromWorkflow(content: string): Agent[] {\n const agents: Agent[] = []\n\n // Split into blocks starting with \"### Agent N\"\n const blocks = content\n .split(/(?=^### Agent \\d)/m)\n .filter((b) => /^### Agent \\d/.test(b.trimStart()))\n\n for (const block of blocks) {\n const lines = block.split('\\n')\n\n const headerMatch = lines[0].match(/^### Agent (\\d+)\\s*[·•]\\s*(.+)$/)\n if (!headerMatch) continue\n\n const number = parseInt(headerMatch[1], 10)\n const name = headerMatch[2].trim()\n const fullName = `Agent ${number} · ${name}`\n const slug = toSlug(name)\n\n const scope = getFieldValue(lines, /Périmètre\\s*:\\s*(.+)/)\n const criterion = getFieldValue(lines, /Critère[s]?\\s*:\\s*(.+)/)\n\n // Outputs: may be inline or multi-line (indented \"- item\")\n const outputs: string[] = []\n const produitIdx = lines.findIndex((l) => /Produit\\s*:/.test(l))\n if (produitIdx !== -1) {\n const inlineVal = (lines[produitIdx].match(/Produit\\s*:\\s*(.+)/)?.[1] ?? '').trim()\n if (inlineVal) {\n outputs.push(inlineVal)\n } else {\n for (let i = produitIdx + 1; i < lines.length; i++) {\n const line = lines[i]\n if (/^\\s+[-]/.test(line)) {\n outputs.push(line.trim().replace(/^-\\s*/, ''))\n } else if (line.trim() !== '' && !/^\\s/.test(line)) {\n break\n }\n }\n }\n }\n\n agents.push({ number, name, fullName, slug, scope, outputs, criterion })\n }\n\n return agents\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\nimport { parseBlueprint } from '../utils/blueprintParser.js'\nimport { toSlug } from '../utils/agentParser.js'\nimport * as react from '../templates/react.js'\nimport * as nextjs from '../templates/nextjs.js'\nimport * as tauri from '../templates/tauri.js'\nimport * as fastapi from '../templates/fastapi.js'\nimport * as express from '../templates/express.js'\nimport * as node from '../templates/node.js'\nimport * as unknown from '../templates/unknown.js'\n\nexport function generateWorkflow(stack: StackInfo, blueprintContent?: string): string {\n if (blueprintContent) return blueprintWorkflow(stack, blueprintContent)\n\n switch (stack.framework) {\n case 'react': return react.workflow(stack)\n case 'nextjs': return nextjs.workflow(stack)\n case 'tauri': return tauri.workflow(stack)\n case 'fastapi': return fastapi.workflow(stack)\n case 'express': return express.workflow(stack)\n case 'node': return node.workflow(stack)\n default: return unknown.workflow(stack)\n }\n}\n\nfunction blueprintWorkflow(stack: StackInfo, blueprintContent: string): string {\n const features = parseBlueprint(blueprintContent)\n\n const agentBlocks = features.map((feature, i) => {\n const n = i + 1\n const slug = toSlug(feature.name)\n const outputLines =\n feature.items.length > 0\n ? feature.items.map((item) => ` - ${item}`).join('\\n')\n : ` - src/${slug}/`\n return `### Agent ${n} · ${feature.name}\nPérimètre : Implémenter la fonctionnalité ${feature.name.toLowerCase()}\nProduit :\n${outputLines}\nCritère : npm test (tests ${feature.name.toLowerCase()} passent)`\n })\n\n const ciN = features.length + 1\n agentBlocks.push(\n `### Agent ${ciN} · Tests & CI\nPérimètre : Couverture de tests complète et configuration du pipeline CI\nProduit :\n - tests/\n - .github/workflows/\nCritère : npm test passe, pipeline CI vert`,\n )\n\n return `# Agent Workflow — ${stack.framework} (Blueprint)\n\n## Stack détectée\nFramework: ${stack.framework} | Language: ${stack.language}\n\n## Agents\n\n${agentBlocks.join('\\n\\n')}\n`\n}\n","import type { Agent } from '../types/agent.js'\n\nexport interface PlaybookInput {\n agents: Agent[]\n projectName: string\n}\n\nexport function generatePlaybook({ agents, projectName }: PlaybookInput): string {\n const agentBlocks = agents.map((a) => agentBlock(a)).join('\\n---\\n\\n')\n\n return `# PLAYBOOK.md — ${projectName}\n\n> Donne cette instruction à Claude Code : 'Lis PLAYBOOK.md et exécute la procédure.'\n\n## Règles d'exécution globales\n\nAvant chaque agent :\n1. Lire \\`CLAUDE.md\\`\n2. Lire \\`agents/agent-{N}-{slug}/skills.md\\` (le fichier de l'agent courant)\n\nAprès chaque agent :\n- Exécuter le critère de succès\n- Si succès → annoncer \"✅ Agent N terminé\" et passer au suivant\n- Si échec → analyser la cause racine, corriger, réexécuter (max 3 tentatives)\n- Après 3 échecs consécutifs → pause et demander validation humaine\n- **Ne jamais passer à l'agent suivant sans critère validé**\n\n## Agents\n\n${agentBlocks}\n\n## Itérations futures\n\nLorsqu'un nouvel agent est ajouté via \\`agentkit add --feature <description>\\` :\n1. Un nouveau bloc agent est ajouté à la fin de \\`AGENT_WORKFLOW.md\\`\n2. Le dossier \\`agents/agent-{N}-{slug}/\\` est créé avec \\`skills.md\\` et \\`context.md\\`\n3. Ce \\`PLAYBOOK.md\\` est régénéré automatiquement pour inclure le nouvel agent\n4. L'exécution reprend à ce nouvel agent uniquement — les agents précédents ne sont pas réexécutés\n\n## Validation humaine requise\n\nLes cas suivants nécessitent une pause et une confirmation humaine avant de continuer :\n- **3 échecs consécutifs** sur le critère de succès d'un agent\n- **Dépendance externe manquante** : clé API, variable d'environnement non définie, service tiers inaccessible\n- **Conflit** entre le blueprint fourni (\\`--blueprint\\`) et la stack détectée automatiquement\n`\n}\n\nfunction agentBlock(agent: Agent): string {\n const skillsPath = `agents/agent-${agent.number}-${agent.slug}/skills.md`\n const outputLines =\n agent.outputs.length > 0\n ? agent.outputs.map((o) => `- ${o}`).join('\\n')\n : '- (voir skills.md pour le détail)'\n\n return `### ${agent.fullName}\n\n**Périmètre** : ${agent.scope}\n\n**Skills** : \\`${skillsPath}\\`\n\n**Fichiers produits** :\n${outputLines}\n\n**Critère de succès** :\n\\`\\`\\`bash\n${agent.criterion || 'npm run build && npm test'}\n\\`\\`\\`\n\n**En cas d'échec** :\n1. Analyser le message d'erreur complet\n2. Corriger la cause racine (pas les symptômes)\n3. Réexécuter le critère (max 3 tentatives)\n4. Après 3 échecs → demander validation humaine\n`\n}\n","import { mkdir, writeFile } from 'node:fs/promises'\nimport { join } from 'node:path'\nimport type { Agent } from '../types/agent.js'\n\nexport async function generateSkills(agents: Agent[], outputDir: string): Promise<void> {\n for (const agent of agents) {\n const agentDir = join(outputDir, 'agents', `agent-${agent.number}-${agent.slug}`)\n await mkdir(agentDir, { recursive: true })\n await writeFile(join(agentDir, 'skills.md'), skillsMd(agent), 'utf-8')\n await writeFile(join(agentDir, 'context.md'), contextMd(agent), 'utf-8')\n }\n}\n\nfunction skillsMd(agent: Agent): string {\n return `# Skills — ${agent.fullName}\n\n> Ce fichier est lu par l'agent avant de commencer.\n\n## Contexte technique\n\n<!-- À remplir : bibliothèques, versions, décisions d'architecture spécifiques à cet agent -->\n\n## Documentation de référence\n\n<!-- À remplir : liens vers docs, exemples, ADRs pertinents -->\n\n## Conventions spécifiques\n\n<!-- À remplir : règles propres à cet agent (naming, patterns, structure de fichiers) -->\n`\n}\n\nfunction contextMd(agent: Agent): string {\n const outputLines =\n agent.outputs.length > 0\n ? agent.outputs.map((o) => `- ${o}`).join('\\n')\n : '- (voir AGENT_WORKFLOW.md)'\n\n return `# Context — ${agent.fullName}\n\n> Ce fichier fournit le contexte additionnel à l'agent avant exécution.\n> À compléter avant de lancer cet agent.\n\n## Périmètre\n\n${agent.scope}\n\n## Fichiers produits attendus\n\n${outputLines}\n\n## Critère de succès\n\n\\`${agent.criterion || 'npm run build && npm test'}\\`\n`\n}\n","import chalk from 'chalk'\n\nexport const logger = {\n info: (message: string): void => {\n process.stdout.write(chalk.blue('ℹ') + ' ' + message + '\\n')\n },\n success: (message: string): void => {\n process.stdout.write(chalk.green('✔') + ' ' + message + '\\n')\n },\n warn: (message: string): void => {\n process.stdout.write(chalk.yellow('⚠') + ' ' + message + '\\n')\n },\n error: (message: string): void => {\n process.stderr.write(chalk.red('✖') + ' ' + message + '\\n')\n },\n}\n","import type { Command } from 'commander'\nimport { readFile, writeFile } from 'node:fs/promises'\nimport { join, basename } from 'node:path'\nimport inquirer from 'inquirer'\nimport { logger } from '../utils/logger.js'\nimport { extractAgentsFromWorkflow, toSlug } from '../utils/agentParser.js'\nimport { generatePlaybook } from '../generators/playbookGenerator.js'\nimport { generateSkills } from '../generators/skillsGenerator.js'\nimport type { Agent } from '../types/agent.js'\n\nfunction featureToAgentName(description: string): string {\n const clean = description\n .replace(/^(add|implement|create|build|integrate|setup|configure|refactor|improve)\\s+/i, '')\n .trim()\n return clean.replace(/\\b\\w/g, (c) => c.toUpperCase())\n}\n\nexport interface AddFeatureResult {\n agent: Agent\n agentDirPath: string\n}\n\nexport async function addFeatureToProject(\n description: string,\n projectDir: string,\n): Promise<AddFeatureResult> {\n const workflowPath = join(projectDir, 'AGENT_WORKFLOW.md')\n const playbookPath = join(projectDir, 'PLAYBOOK.md')\n\n let workflowContent = ''\n try {\n workflowContent = await readFile(workflowPath, 'utf-8')\n } catch {\n throw new Error(`AGENT_WORKFLOW.md introuvable dans ${projectDir} — lancez agentkit init`)\n }\n\n const existingAgents = extractAgentsFromWorkflow(workflowContent)\n const nextNumber = existingAgents.length + 1\n const name = featureToAgentName(description)\n const slug = toSlug(name)\n const fullName = `Agent ${nextNumber} · ${name}`\n\n const newAgent: Agent = {\n number: nextNumber,\n name,\n fullName,\n slug,\n scope: description,\n outputs: [`agents/agent-${nextNumber}-${slug}/`],\n criterion: 'npm run build && npm test',\n }\n\n const agentBlock = `\n### ${fullName}\nPérimètre : ${description}\nProduit :\n - agents/agent-${nextNumber}-${slug}/\nCritère : npm run build && npm test\n`\n\n await writeFile(workflowPath, workflowContent + agentBlock, 'utf-8')\n await generateSkills([newAgent], projectDir)\n\n let projectName = basename(projectDir)\n try {\n const pkg = JSON.parse(\n await readFile(join(projectDir, 'package.json'), 'utf-8'),\n ) as { name?: string }\n if (pkg.name) projectName = pkg.name\n } catch { /* use dirname fallback */ }\n\n const allAgents = [...existingAgents, newAgent]\n const playbookContent = generatePlaybook({ agents: allAgents, projectName })\n await writeFile(playbookPath, playbookContent, 'utf-8')\n\n return {\n agent: newAgent,\n agentDirPath: join(projectDir, 'agents', `agent-${nextNumber}-${slug}`),\n }\n}\n\nexport function registerAdd(program: Command): void {\n const addCmd = program\n .command('add')\n .description('Ajoute des ressources au projet agentkit')\n .option('--feature <description>', 'Ajoute un agent depuis une description de feature et régénère PLAYBOOK.md')\n .action(async (options: { feature?: string }) => {\n if (options.feature) {\n try {\n const result = await addFeatureToProject(options.feature, process.cwd())\n logger.success(`Agent ajouté : ${result.agent.fullName}`)\n logger.success(`Dossier créé : agents/agent-${result.agent.number}-${result.agent.slug}/`)\n logger.success('PLAYBOOK.md : régénéré')\n } catch (err) {\n logger.error(err instanceof Error ? err.message : String(err))\n process.exit(1)\n }\n } else {\n addCmd.help()\n }\n })\n\n addCmd\n .command('agent')\n .description('Ajoute un nouvel agent dans AGENT_WORKFLOW.md (interactif)')\n .action(async () => {\n const cwd = process.cwd()\n const workflowPath = join(cwd, 'AGENT_WORKFLOW.md')\n\n let existing = ''\n try {\n existing = await readFile(workflowPath, 'utf-8')\n } catch {\n logger.error('AGENT_WORKFLOW.md introuvable — lancez d\\'abord : agentkit init')\n process.exit(1)\n }\n\n const agentCount = (existing.match(/^### Agent \\d+/gm) ?? []).length\n const nextNumber = agentCount + 1\n\n const answers = await inquirer.prompt<{\n name: string\n scope: string\n outputs: string\n criterion: string\n }>([\n {\n type: 'input',\n name: 'name',\n message: `Nom de l'agent (ex: \"Agent ${nextNumber} · Feature X\") :`,\n default: `Agent ${nextNumber}`,\n },\n {\n type: 'input',\n name: 'scope',\n message: 'Périmètre (une phrase) :',\n },\n {\n type: 'input',\n name: 'outputs',\n message: 'Fichiers produits (séparés par des virgules) :',\n },\n {\n type: 'input',\n name: 'criterion',\n message: 'Critère de succès :',\n },\n ])\n\n const outputLines = answers.outputs\n .split(',')\n .map((o: string) => ` - ${o.trim()}`)\n .join('\\n')\n\n const agentSection = `\n### ${answers.name}\nPérimètre : ${answers.scope}\nProduit :\n${outputLines}\nCritère : ${answers.criterion}\n`\n\n await writeFile(workflowPath, existing + agentSection, 'utf-8')\n logger.success(`Agent \"${answers.name}\" ajouté dans AGENT_WORKFLOW.md`)\n })\n}\n","import type { Command } from 'commander'\nimport { readFile } from 'node:fs/promises'\nimport { join } from 'node:path'\nimport chalk from 'chalk'\nimport { detectStack } from '../detectors/stackDetector.js'\nimport { isGitRepo } from '../detectors/gitDetector.js'\nimport { logger } from '../utils/logger.js'\n\nexport function registerStatus(program: Command): void {\n program\n .command('status')\n .description('Affiche l\\'état du workflow agentkit dans le dossier courant')\n .action(async () => {\n const cwd = process.cwd()\n\n const [stack, isGit, claudeMd, workflow] = await Promise.all([\n detectStack(cwd),\n isGitRepo(cwd),\n readFile(join(cwd, 'CLAUDE.md'), 'utf-8').catch(() => null),\n readFile(join(cwd, 'AGENT_WORKFLOW.md'), 'utf-8').catch(() => null),\n ])\n\n process.stdout.write('\\n' + chalk.bold('AgentKit Status') + '\\n')\n process.stdout.write('─'.repeat(40) + '\\n')\n\n process.stdout.write(\n chalk.bold('Git repo : ') +\n (isGit ? chalk.green('✔ oui') : chalk.red('✖ non')) +\n '\\n',\n )\n\n process.stdout.write(\n chalk.bold('Stack : ') + chalk.cyan(stack.framework) + ' (' + stack.language + ')\\n',\n )\n\n process.stdout.write(\n chalk.bold('CLAUDE.md : ') +\n (claudeMd !== null ? chalk.green('✔ présent') : chalk.yellow('✖ absent — lancez agentkit init')) +\n '\\n',\n )\n\n process.stdout.write(\n chalk.bold('AGENT_WORKFLOW.md : ') +\n (workflow !== null ? chalk.green('✔ présent') : chalk.yellow('✖ absent — lancez agentkit init')) +\n '\\n',\n )\n\n if (workflow !== null) {\n const agentMatches = workflow.match(/^### Agent \\d+/gm) ?? []\n process.stdout.write(\n chalk.bold('Agents définis : ') + chalk.cyan(String(agentMatches.length)) + '\\n',\n )\n }\n\n process.stdout.write('─'.repeat(40) + '\\n\\n')\n })\n}\n"],"mappings":"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","names":["writeFile","readFile","join","access","join","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","join","readFile","program","join","writeFile","readFile","writeFile","join","basename","inquirer","join","readFile","agentBlock","writeFile","basename","program","inquirer","readFile","join","chalk","program","claudeMd","workflow","readFile","join","chalk"]}
1
+ {"version":3,"sources":["../src/cli.ts","../src/commands/init.ts","../src/detectors/stackDetector.ts","../src/detectors/gitDetector.ts","../src/utils/blueprintParser.ts","../src/templates/react.ts","../src/templates/nextjs.ts","../src/templates/tauri.ts","../src/templates/fastapi.ts","../src/templates/express.ts","../src/templates/node.ts","../src/templates/unknown.ts","../src/generators/claudeMdGenerator.ts","../src/utils/agentParser.ts","../src/generators/workflowGenerator.ts","../src/generators/playbookGenerator.ts","../src/generators/skillsGenerator.ts","../src/utils/logger.ts","../src/commands/add.ts","../src/commands/status.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from 'commander'\nimport { registerInit } from './commands/init.js'\nimport { registerAdd } from './commands/add.js'\nimport { registerStatus } from './commands/status.js'\n\nconst program = new Command()\n\nprogram\n .name('agentkit')\n .description('Scaffolder des workflows multi-agents Claude Code')\n .version('0.1.0')\n\nregisterInit(program)\nregisterAdd(program)\nregisterStatus(program)\n\nprogram.parse()\n","import type { Command } from 'commander'\nimport { writeFile, readFile } from 'node:fs/promises'\nimport { join } from 'node:path'\nimport inquirer from 'inquirer'\nimport ora from 'ora'\nimport { detectStack } from '../detectors/stackDetector.js'\nimport { isGitRepo } from '../detectors/gitDetector.js'\nimport { generateClaudeMd } from '../generators/claudeMdGenerator.js'\nimport { generateWorkflow } from '../generators/workflowGenerator.js'\nimport { generatePlaybook } from '../generators/playbookGenerator.js'\nimport { generateSkills } from '../generators/skillsGenerator.js'\nimport { extractAgentsFromWorkflow } from '../utils/agentParser.js'\nimport { logger } from '../utils/logger.js'\nimport type { StackInfo } from '../detectors/stackDetector.js'\nimport { basename } from 'node:path'\n\nconst FRAMEWORK_LABELS: Record<StackInfo['framework'], string> = {\n react: 'React',\n nextjs: 'Next.js',\n tauri: 'Tauri',\n fastapi: 'FastAPI (Python)',\n express: 'Express',\n node: 'Node.js',\n unknown: 'Unknown (generic)',\n}\n\nasync function fileExists(path: string): Promise<boolean> {\n try {\n await readFile(path)\n return true\n } catch {\n return false\n }\n}\n\nexport function registerInit(program: Command): void {\n program\n .command('init')\n .description('Génère CLAUDE.md et AGENT_WORKFLOW.md dans le dossier courant')\n .option('-f, --force', 'Écrase les fichiers existants sans confirmation')\n .option('--blueprint <path>', 'Fichier blueprint .md à utiliser pour personnaliser les fichiers générés')\n .action(async (options: { force?: boolean; blueprint?: string }) => {\n const cwd = process.cwd()\n\n const spinner = ora('Détection de la stack…').start()\n const [stack, isGit] = await Promise.all([detectStack(cwd), isGitRepo(cwd)])\n spinner.stop()\n\n if (!isGit) {\n logger.warn('Ce dossier n\\'est pas un repo git — lancez git init si nécessaire')\n }\n\n const label = FRAMEWORK_LABELS[stack.framework]\n logger.info(`Stack détectée : ${label} (${stack.language})`)\n\n const { confirmed } = await inquirer.prompt<{ confirmed: boolean }>([\n {\n type: 'confirm',\n name: 'confirmed',\n message: `Générer les fichiers pour ${label} ?`,\n default: true,\n },\n ])\n\n if (!confirmed) {\n logger.warn('Annulé.')\n return\n }\n\n const claudeMdPath = join(cwd, 'CLAUDE.md')\n const workflowPath = join(cwd, 'AGENT_WORKFLOW.md')\n const playbookPath = join(cwd, 'PLAYBOOK.md')\n\n // Resolve project name from package.json or directory name\n let projectName = basename(cwd)\n try {\n const pkg = JSON.parse(await readFile(join(cwd, 'package.json'), 'utf-8')) as { name?: string }\n if (pkg.name) projectName = pkg.name\n } catch { /* fallback to dirname */ }\n\n if (!options.force) {\n const existing: string[] = []\n if (await fileExists(claudeMdPath)) existing.push('CLAUDE.md')\n if (await fileExists(workflowPath)) existing.push('AGENT_WORKFLOW.md')\n if (await fileExists(playbookPath)) existing.push('PLAYBOOK.md')\n\n if (existing.length > 0) {\n const { overwrite } = await inquirer.prompt<{ overwrite: boolean }>([\n {\n type: 'confirm',\n name: 'overwrite',\n message: `${existing.join(' et ')} existe déjà. Écraser ?`,\n default: false,\n },\n ])\n if (!overwrite) {\n logger.warn('Annulé.')\n return\n }\n }\n }\n\n // Load blueprint if provided\n let blueprintContent: string | undefined\n if (options.blueprint) {\n try {\n blueprintContent = await readFile(options.blueprint, 'utf-8')\n } catch {\n logger.error(`Blueprint introuvable : ${options.blueprint}`)\n process.exit(1)\n }\n }\n\n const genSpinner = ora('Génération des fichiers…').start()\n const claudeMdContent = generateClaudeMd(stack, blueprintContent)\n const workflowContent = generateWorkflow(stack, blueprintContent)\n const agents = extractAgentsFromWorkflow(workflowContent)\n const playbookContent = generatePlaybook({ agents, projectName, hasBlueprint: !!blueprintContent })\n await writeFile(claudeMdPath, claudeMdContent, 'utf-8')\n await writeFile(workflowPath, workflowContent, 'utf-8')\n await writeFile(playbookPath, playbookContent, 'utf-8')\n await generateSkills(agents, cwd)\n genSpinner.succeed('Fichiers générés')\n\n logger.success('CLAUDE.md → créé')\n logger.success('AGENT_WORKFLOW.md → créé')\n logger.success('PLAYBOOK.md → créé')\n logger.success(`agents/ → ${agents.length} dossier(s) créé(s)`)\n })\n}\n","import { readFile, access } from 'node:fs/promises'\nimport { join } from 'node:path'\n\nexport interface StackInfo {\n framework: 'react' | 'nextjs' | 'tauri' | 'fastapi' | 'express' | 'node' | 'unknown'\n language: 'typescript' | 'javascript' | 'python' | 'unknown'\n hasTypeScript: boolean\n extras: string[]\n}\n\nasync function pathExists(p: string): Promise<boolean> {\n try {\n await access(p)\n return true\n } catch {\n return false\n }\n}\n\nasync function readJson(p: string): Promise<Record<string, unknown> | null> {\n try {\n const raw = await readFile(p, 'utf-8')\n return JSON.parse(raw) as Record<string, unknown>\n } catch {\n return null\n }\n}\n\nasync function readText(p: string): Promise<string | null> {\n try {\n return await readFile(p, 'utf-8')\n } catch {\n return null\n }\n}\n\nexport async function detectStack(projectPath: string): Promise<StackInfo> {\n const info: StackInfo = {\n framework: 'unknown',\n language: 'unknown',\n hasTypeScript: false,\n extras: [],\n }\n\n const packageJson = await readJson(join(projectPath, 'package.json'))\n const requirementsTxt = await readText(join(projectPath, 'requirements.txt'))\n const hasTauriDir = await pathExists(join(projectPath, 'src-tauri'))\n const hasTsConfig = await pathExists(join(projectPath, 'tsconfig.json'))\n\n if (packageJson !== null) {\n const deps = (packageJson.dependencies as Record<string, string>) ?? {}\n const devDeps = (packageJson.devDependencies as Record<string, string>) ?? {}\n const allDeps = { ...deps, ...devDeps }\n\n info.hasTypeScript = 'typescript' in allDeps || hasTsConfig\n info.language = info.hasTypeScript ? 'typescript' : 'javascript'\n\n // Order matters: most specific first\n if ('next' in allDeps) {\n info.framework = 'nextjs'\n } else if (hasTauriDir || '@tauri-apps/api' in allDeps || '@tauri-apps/cli' in allDeps) {\n info.framework = 'tauri'\n } else if ('react' in allDeps) {\n info.framework = 'react'\n } else if ('express' in allDeps) {\n info.framework = 'express'\n } else {\n info.framework = 'node'\n }\n\n if ('vitest' in allDeps || 'jest' in allDeps) info.extras.push('testing')\n if ('prisma' in allDeps || '@prisma/client' in allDeps) info.extras.push('prisma')\n if ('tailwindcss' in allDeps) info.extras.push('tailwind')\n }\n\n if (requirementsTxt !== null && info.framework === 'unknown') {\n info.language = 'python'\n if (/\\bfastapi\\b/i.test(requirementsTxt)) {\n info.framework = 'fastapi'\n }\n }\n\n if (hasTauriDir && info.framework === 'unknown') {\n info.framework = 'tauri'\n }\n\n return info\n}\n","import { access } from 'node:fs/promises'\nimport { join } from 'node:path'\n\nexport async function isGitRepo(projectPath: string): Promise<boolean> {\n try {\n await access(join(projectPath, '.git'))\n return true\n } catch {\n return false\n }\n}\n","export interface BlueprintFeature {\n name: string\n items: string[]\n}\n\nexport function parseBlueprint(content: string): BlueprintFeature[] {\n const features: BlueprintFeature[] = []\n\n // Locate all ## headings (not # or ###)\n const sectionRegex = /^## (.+)$/gm\n const sections: Array<{ name: string; start: number }> = []\n let m: RegExpExecArray | null\n while ((m = sectionRegex.exec(content)) !== null) {\n sections.push({ name: m[1].trim(), start: m.index })\n }\n\n for (let i = 0; i < sections.length; i++) {\n const section = sections[i]\n const end = i + 1 < sections.length ? sections[i + 1].start : content.length\n const body = content.slice(section.start, end)\n\n const items = [...body.matchAll(/^[-*]\\s+(.+)$/gm)].map((r) => r[1].trim())\n\n features.push({ name: section.name, items })\n }\n\n return features\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n const testLine = stack.extras.includes('testing') ? '- `npm test` — run tests\\n' : ''\n return `# CLAUDE.md — React Project\n\n## Stack\n- Framework : React (${lang})\n- Language : ${lang}\n- Build : Vite\n\n## Commands\n- \\`npm run dev\\` — development server\n- \\`npm run build\\` — production build\n${testLine}\n## Structure\nsrc/\n components/ ← UI components (PascalCase)\n hooks/ ← custom hooks (prefix: use*)\n pages/ ← page-level components\n utils/ ← shared helpers\n\n## Conventions\n1. Components in PascalCase\n2. Hooks prefixed with \\`use\\`\n3. Props interfaces named \\`*Props\\`\n4. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# Agent Workflow — React Project\n\n## Stack détectée\nFramework: React | Language: ${lang}\n\n## Agents\n\n### Agent 1 · Components\nPérimètre : composants UI réutilisables\nProduit : src/components/\nCritère : composants documentés et testés\n\n### Agent 2 · State & Hooks\nPérimètre : state management, hooks personnalisés\nProduit : src/hooks/\nCritère : hooks testés unitairement\n\n### Agent 3 · Pages & Routing\nPérimètre : assemblage des pages, react-router\nProduit : src/pages/\nCritère : navigation fonctionnelle\n\n### Agent 4 · Tests & CI\nPérimètre : couverture de tests, configuration CI\nProduit : tests/, .github/workflows/\nCritère : npm test passe\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const hasTailwind = stack.extras.includes('tailwind')\n const hasPrisma = stack.extras.includes('prisma')\n return `# CLAUDE.md — Next.js Project\n\n## Stack\n- Framework : Next.js (TypeScript)\n- Rendering : App Router (RSC + Client Components)\n- Styling : ${hasTailwind ? 'Tailwind CSS' : 'CSS Modules'}\n${hasPrisma ? '- Database : Prisma ORM\\n' : ''}\n## Commands\n- \\`npm run dev\\` — development server (http://localhost:3000)\n- \\`npm run build\\` — production build\n- \\`npm start\\` — production server\n- \\`npm test\\` — run tests\n\n## Structure\nsrc/\n app/ ← App Router pages and layouts\n components/ ← shared UI components\n lib/ ← server utilities, db clients\n utils/ ← shared helpers\n\n## Conventions\n1. Server Components by default, \\`'use client'\\` only when needed\n2. API routes in \\`src/app/api/\\`\n3. Environment variables via \\`src/env.ts\\` (validated)\n4. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const hasPrisma = stack.extras.includes('prisma')\n return `# Agent Workflow — Next.js Project\n\n## Stack détectée\nFramework: Next.js | Language: TypeScript\n\n## Agents\n\n### Agent 1 · Data Layer\nPérimètre : schéma${hasPrisma ? ' Prisma' : ''}, types, server actions\nProduit : src/lib/, ${hasPrisma ? 'prisma/schema.prisma' : 'src/types/'}\nCritère : types compilent, migrations propres\n\n### Agent 2 · UI Components\nPérimètre : composants réutilisables (Server + Client)\nProduit : src/components/\nCritère : composants rendus sans erreur\n\n### Agent 3 · Pages & Layout\nPérimètre : App Router, layouts, pages\nProduit : src/app/\nCritère : navigation fonctionnelle, build passe\n\n### Agent 4 · API & Tests\nPérimètre : API routes, tests e2e/unitaires\nProduit : src/app/api/, tests/\nCritère : npm test passe\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# CLAUDE.md — Tauri Project\n\n## Stack\n- Framework : Tauri (Rust + ${lang} frontend)\n- Language : Rust (backend) + ${lang} (frontend)\n- Build : Cargo + Vite\n\n## Commands\n- \\`npm run tauri dev\\` — development (hot reload)\n- \\`npm run tauri build\\` — production bundle\n- \\`npm run build\\` — frontend only\n- \\`npm test\\` — run tests\n\n## Structure\nsrc/ ← frontend (${lang})\n components/\n utils/\nsrc-tauri/ ← Rust backend\n src/\n main.rs ← Tauri entry point\n commands.rs ← Tauri commands (IPC)\n tauri.conf.json\n\n## Conventions\n1. IPC commands defined in \\`src-tauri/src/commands.rs\\`\n2. Frontend invokes via \\`@tauri-apps/api/tauri\\`\n3. No direct filesystem access from frontend\n4. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# Agent Workflow — Tauri Project\n\n## Stack détectée\nFramework: Tauri | Language: Rust + ${lang}\n\n## Agents\n\n### Agent 1 · Rust Commands\nPérimètre : commandes Tauri (IPC), permissions\nProduit : src-tauri/src/commands.rs, tauri.conf.json\nCritère : \\`cargo build\\` passe\n\n### Agent 2 · Frontend UI\nPérimètre : interface ${lang}, intégration IPC\nProduit : src/components/, src/utils/\nCritère : appels IPC fonctionnels\n\n### Agent 3 · Build & Packaging\nPérimètre : configuration build, icônes, installeurs\nProduit : src-tauri/tauri.conf.json, icons/\nCritère : \\`npm run tauri build\\` produit un bundle\n\n### Agent 4 · Tests\nPérimètre : tests Rust + tests frontend\nProduit : src-tauri/tests/, tests/\nCritère : \\`cargo test\\` + \\`npm test\\` passent\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(_stack: StackInfo): string {\n return `# CLAUDE.md — FastAPI Project\n\n## Stack\n- Framework : FastAPI (Python)\n- Language : Python 3.11+\n- Server : Uvicorn\n- Validation: Pydantic v2\n\n## Commands\n- \\`uvicorn main:app --reload\\` — development server (http://localhost:8000)\n- \\`pytest\\` — run tests\n- \\`pip install -r requirements.txt\\` — install dependencies\n\n## Structure\napp/\n main.py ← FastAPI app entry point\n routers/ ← API route groups\n models/ ← Pydantic models\n services/ ← business logic\n dependencies/ ← FastAPI dependencies (DI)\ntests/ ← pytest tests\n\n## Conventions\n1. Routers grouped by domain in \\`app/routers/\\`\n2. Pydantic models for all request/response bodies\n3. Business logic in \\`app/services/\\`, not in routes\n4. Async endpoints by default (\\`async def\\`)\n5. Environment variables via \\`python-dotenv\\` + \\`pydantic-settings\\`\n`\n}\n\nexport function workflow(_stack: StackInfo): string {\n return `# Agent Workflow — FastAPI Project\n\n## Stack détectée\nFramework: FastAPI | Language: Python\n\n## Agents\n\n### Agent 1 · Models & Schemas\nPérimètre : modèles Pydantic, schémas DB (SQLAlchemy/SQLModel)\nProduit : app/models/\nCritère : modèles validés, migrations propres\n\n### Agent 2 · Services\nPérimètre : logique métier, accès base de données\nProduit : app/services/\nCritère : services testés unitairement (pytest)\n\n### Agent 3 · Routers & API\nPérimètre : routes FastAPI, dépendances, auth\nProduit : app/routers/, app/dependencies/\nCritère : endpoints documentés (OpenAPI), tests d'intégration\n\n### Agent 4 · Tests & CI\nPérimètre : couverture pytest, configuration CI\nProduit : tests/, .github/workflows/\nCritère : \\`pytest\\` passe à 100%\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n const hasPrisma = stack.extras.includes('prisma')\n return `# CLAUDE.md — Express Project\n\n## Stack\n- Framework : Express (${lang})\n- Language : ${lang}\n- Runtime : Node.js 20+\n${hasPrisma ? '- Database : Prisma ORM\\n' : ''}\n## Commands\n- \\`npm run dev\\` — development server (nodemon)\n- \\`npm run build\\` — compile TypeScript\n- \\`npm start\\` — production server\n- \\`npm test\\` — run tests\n\n## Structure\nsrc/\n routes/ ← Express routers (one per domain)\n controllers/ ← request handlers\n services/ ← business logic\n middleware/ ← Express middleware\n utils/ ← shared helpers\n\n## Conventions\n1. Routes grouped by domain in \\`src/routes/\\`\n2. Business logic in \\`src/services/\\`, not in controllers\n3. Middleware for cross-cutting concerns (auth, validation)\n4. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# Agent Workflow — Express Project\n\n## Stack détectée\nFramework: Express | Language: ${lang}\n\n## Agents\n\n### Agent 1 · Data & Models\nPérimètre : modèles de données, accès DB\nProduit : src/models/, src/services/db.ts\nCritère : connexion DB fonctionnelle\n\n### Agent 2 · Services\nPérimètre : logique métier\nProduit : src/services/\nCritère : services testés unitairement\n\n### Agent 3 · Routes & Controllers\nPérimètre : routes Express, validation, auth\nProduit : src/routes/, src/controllers/, src/middleware/\nCritère : endpoints répondent correctement\n\n### Agent 4 · Tests & CI\nPérimètre : tests d'intégration, configuration CI\nProduit : tests/, .github/workflows/\nCritère : npm test passe\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# CLAUDE.md — Node.js Project\n\n## Stack\n- Runtime : Node.js 20+\n- Language : ${lang}\n\n## Commands\n- \\`npm run dev\\` — development (with watch)\n- \\`npm run build\\` — compile${stack.hasTypeScript ? ' TypeScript' : ''}\n- \\`npm start\\` — run production build\n- \\`npm test\\` — run tests\n\n## Structure\nsrc/\n index.ts ← entry point\n lib/ ← core library code\n utils/ ← shared helpers\n\n## Conventions\n1. Modules follow single-responsibility principle\n2. Async/await over callbacks\n3. Tout output console passe par un logger centralisé\n`\n}\n\nexport function workflow(stack: StackInfo): string {\n const lang = stack.hasTypeScript ? 'TypeScript' : 'JavaScript'\n return `# Agent Workflow — Node.js Project\n\n## Stack détectée\nRuntime: Node.js | Language: ${lang}\n\n## Agents\n\n### Agent 1 · Core Library\nPérimètre : logique principale\nProduit : src/lib/\nCritère : module fonctionne et testé\n\n### Agent 2 · CLI / API\nPérimètre : interface utilisateur (CLI ou API)\nProduit : src/index.ts, src/cli.ts\nCritère : commandes fonctionnelles\n\n### Agent 3 · Tests & CI\nPérimètre : couverture de tests, configuration CI\nProduit : tests/, .github/workflows/\nCritère : npm test passe\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\n\nexport function claudeMd(_stack: StackInfo): string {\n return `# CLAUDE.md\n\n## Stack\nStack non détectée automatiquement — à remplir manuellement.\n\n## Commands\n- À définir selon le projet\n\n## Structure\nsrc/ ← code source\ntests/ ← tests\n\n## Conventions\n1. Tout output console passe par un logger centralisé\n2. À compléter selon les conventions du projet\n`\n}\n\nexport function workflow(_stack: StackInfo): string {\n return `# Agent Workflow\n\n## Stack détectée\nStack inconnue — workflow générique.\n\n## Agents\n\n### Agent 1 · Setup\nPérimètre : configuration initiale du projet\nProduit : structure de base\nCritère : projet compilable\n\n### Agent 2 · Core\nPérimètre : logique principale\nProduit : src/\nCritère : fonctionnalités principales opérationnelles\n\n### Agent 3 · Tests\nPérimètre : couverture de tests\nProduit : tests/\nCritère : tests passent\n`\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\nimport { parseBlueprint } from '../utils/blueprintParser.js'\nimport * as react from '../templates/react.js'\nimport * as nextjs from '../templates/nextjs.js'\nimport * as tauri from '../templates/tauri.js'\nimport * as fastapi from '../templates/fastapi.js'\nimport * as express from '../templates/express.js'\nimport * as node from '../templates/node.js'\nimport * as unknown from '../templates/unknown.js'\n\nexport function generateClaudeMd(stack: StackInfo, blueprintContent?: string): string {\n let base: string\n switch (stack.framework) {\n case 'react': base = react.claudeMd(stack); break\n case 'nextjs': base = nextjs.claudeMd(stack); break\n case 'tauri': base = tauri.claudeMd(stack); break\n case 'fastapi': base = fastapi.claudeMd(stack); break\n case 'express': base = express.claudeMd(stack); break\n case 'node': base = node.claudeMd(stack); break\n default: base = unknown.claudeMd(stack)\n }\n\n if (!blueprintContent) return base\n\n const features = parseBlueprint(blueprintContent)\n if (features.length === 0) return base\n\n const featureLines = features\n .map((f, i) => {\n const sub = f.items.length > 0 ? '\\n' + f.items.map((it) => ` - ${it}`).join('\\n') : ''\n return `${i + 1}. **${f.name}**${sub}`\n })\n .join('\\n')\n\n const featureSection = `\\n## Features (Blueprint)\\n\\n${featureLines}\\n`\n\n const conventionsIdx = base.indexOf('\\n## Conventions')\n if (conventionsIdx !== -1) {\n return base.slice(0, conventionsIdx) + featureSection + base.slice(conventionsIdx)\n }\n return base + featureSection\n}\n","import type { Agent } from '../types/agent.js'\n\nexport function toSlug(name: string): string {\n return name\n .toLowerCase()\n .replace(/[·•&]/g, ' ')\n .replace(/[^\\w\\s-]/g, '')\n .trim()\n .replace(/\\s+/g, '-')\n .replace(/-+/g, '-')\n .replace(/^-|-$/g, '')\n}\n\nfunction getFieldValue(lines: string[], pattern: RegExp): string {\n for (const line of lines) {\n const m = line.match(pattern)\n if (m) return (m[1] ?? '').trim()\n }\n return ''\n}\n\nexport function extractAgentsFromWorkflow(content: string): Agent[] {\n const agents: Agent[] = []\n\n // Split into blocks starting with \"### Agent N\"\n const blocks = content\n .split(/(?=^### Agent \\d)/m)\n .filter((b) => /^### Agent \\d/.test(b.trimStart()))\n\n for (const block of blocks) {\n const lines = block.split('\\n')\n\n const headerMatch = lines[0].match(/^### Agent (\\d+)\\s*[·•]\\s*(.+)$/)\n if (!headerMatch) continue\n\n const number = parseInt(headerMatch[1], 10)\n const name = headerMatch[2].trim()\n const fullName = `Agent ${number} · ${name}`\n const slug = toSlug(name)\n\n const scope = getFieldValue(lines, /Périmètre\\s*:\\s*(.+)/)\n const criterion = getFieldValue(lines, /Critère[s]?\\s*:\\s*(.+)/)\n\n // Outputs: may be inline or multi-line (indented \"- item\")\n const outputs: string[] = []\n const produitIdx = lines.findIndex((l) => /Produit\\s*:/.test(l))\n if (produitIdx !== -1) {\n const inlineVal = (lines[produitIdx].match(/Produit\\s*:\\s*(.+)/)?.[1] ?? '').trim()\n if (inlineVal) {\n outputs.push(inlineVal)\n } else {\n for (let i = produitIdx + 1; i < lines.length; i++) {\n const line = lines[i]\n if (/^\\s+[-]/.test(line)) {\n outputs.push(line.trim().replace(/^-\\s*/, ''))\n } else if (line.trim() !== '' && !/^\\s/.test(line)) {\n break\n }\n }\n }\n }\n\n agents.push({ number, name, fullName, slug, scope, outputs, criterion })\n }\n\n return agents\n}\n","import type { StackInfo } from '../detectors/stackDetector.js'\nimport { parseBlueprint } from '../utils/blueprintParser.js'\nimport { toSlug } from '../utils/agentParser.js'\nimport * as react from '../templates/react.js'\nimport * as nextjs from '../templates/nextjs.js'\nimport * as tauri from '../templates/tauri.js'\nimport * as fastapi from '../templates/fastapi.js'\nimport * as express from '../templates/express.js'\nimport * as node from '../templates/node.js'\nimport * as unknown from '../templates/unknown.js'\n\nexport function generateWorkflow(stack: StackInfo, blueprintContent?: string): string {\n if (blueprintContent) return blueprintWorkflow(stack, blueprintContent)\n\n switch (stack.framework) {\n case 'react': return react.workflow(stack)\n case 'nextjs': return nextjs.workflow(stack)\n case 'tauri': return tauri.workflow(stack)\n case 'fastapi': return fastapi.workflow(stack)\n case 'express': return express.workflow(stack)\n case 'node': return node.workflow(stack)\n default: return unknown.workflow(stack)\n }\n}\n\nfunction blueprintWorkflow(stack: StackInfo, blueprintContent: string): string {\n const features = parseBlueprint(blueprintContent)\n\n const agentBlocks = features.map((feature, i) => {\n const n = i + 1\n const slug = toSlug(feature.name)\n const outputLines =\n feature.items.length > 0\n ? feature.items.map((item) => ` - ${item}`).join('\\n')\n : ` - src/${slug}/`\n return `### Agent ${n} · ${feature.name}\nPérimètre : Implémenter la fonctionnalité ${feature.name.toLowerCase()}\nProduit :\n${outputLines}\nCritère : npm test (tests ${feature.name.toLowerCase()} passent)`\n })\n\n const ciN = features.length + 1\n agentBlocks.push(\n `### Agent ${ciN} · Tests & CI\nPérimètre : Couverture de tests complète et configuration du pipeline CI\nProduit :\n - tests/\n - .github/workflows/\nCritère : npm test passe, pipeline CI vert`,\n )\n\n return `# Agent Workflow — ${stack.framework} (Blueprint)\n\n## Stack détectée\nFramework: ${stack.framework} | Language: ${stack.language}\n\n## Agents\n\n${agentBlocks.join('\\n\\n')}\n`\n}\n","import type { Agent } from '../types/agent.js'\n\nexport interface PlaybookInput {\n agents: Agent[]\n projectName: string\n hasBlueprint: boolean\n}\n\nexport function generatePlaybook({ agents, projectName, hasBlueprint }: PlaybookInput): string {\n const agentBlocks = agents.map((a) => agentBlock(a)).join('\\n---\\n\\n')\n\n const phase0 = hasBlueprint\n ? `## Phase 0 — Agent Decomposition (run this first)\n\n> A \\`PROJECT_BLUEPRINT.md\\` was provided.\n> Claude Code reads it and decomposes the project into specialized agents\n> before writing a single line of code.\n\n**Read these files in order:**\n1. \\`CLAUDE.md\\`\n2. \\`PROJECT_BLUEPRINT.md\\`\n\n**Then decompose the project into agents** following these rules:\n\n- One agent = one coherent technical layer (never mix two layers)\n- Each agent must have a runnable success criterion (\\`npm test\\`, \\`cargo build\\`…)\n- Agents must be ordered by dependency (no feature without infra first)\n- Maximum 6 agents — if you have more, group related ones\n- Always respect this order:\n 1. Infra & Configuration\n 2. Data layer (DB schema, models, services)\n 3. External integrations (auth, APIs, local services like Ollama)\n 4. UI & pages\n 5. Advanced features (RAG, export, realtime…)\n 6. Build & release (CI/CD, packaging, installers)\n\n**Write the result directly into \\`AGENT_WORKFLOW.md\\`** — replace its current\ncontent with your decomposition.\n\n**Then ask for human validation:**\n> \"I have decomposed the project into N agents: [list them].\n> Should I proceed with execution?\"\n\nWait for confirmation before moving to Phase 1.\n\n---\n\n`\n : `## Phase 0 — Project Discovery (run this first)\n\n> No \\`PROJECT_BLUEPRINT.md\\` was provided.\n> Before writing any code, Claude Code asks the user what they want to build,\n> then decomposes the project into agents — exactly as if a blueprint had been provided.\n\n**Ask the user these questions and wait for their answers:**\n\n1. What is this project? (one sentence describing the goal)\n2. What are the main features you want to build? (list them)\n3. Are there any tech constraints or architecture preferences?\n (e.g. offline-only, specific DB, no auth, specific framework)\n\n**Once you have the answers, decompose the project into agents**\nfollowing these rules:\n\n- One agent = one coherent technical layer (never mix two layers)\n- Each agent must have a runnable success criterion (\\`npm test\\`, \\`cargo build\\`…)\n- Agents must be ordered by dependency (no feature without infra first)\n- Maximum 6 agents — if you have more, group related ones\n- Always respect this order:\n 1. Infra & Configuration\n 2. Data layer (DB schema, models, services)\n 3. External integrations (auth, APIs, local services like Ollama)\n 4. UI & pages\n 5. Advanced features (RAG, export, realtime…)\n 6. Build & release (CI/CD, packaging, installers)\n\n**Write the result directly into \\`AGENT_WORKFLOW.md\\`** — replace its current\ncontent with your decomposition.\n\n**Then ask for human validation:**\n> \"I have decomposed the project into N agents: [list them].\n> Should I proceed with execution?\"\n\nWait for confirmation before moving to Phase 1.\n\n---\n\n`\n\n return `# PLAYBOOK.md — ${projectName}\n\n> **One instruction to give Claude Code:**\n> \"Read PLAYBOOK.md and execute the procedure.\"\n>\n> Claude Code handles the rest autonomously — project discovery or blueprint reading,\n> agent decomposition, execution, success validation, retries, and human escalation.\n> No API key required. No additional cost beyond your LLM subscription.\n\n---\n\n## Global Execution Rules\n\nBefore each agent:\n1. Read \\`CLAUDE.md\\`\n2. Read \\`agents/agent-{N}-{slug}/skills.md\\` (current agent's file)\n3. Read the agent's section in \\`AGENT_WORKFLOW.md\\`\n\nAfter each agent:\n- Run the success criterion command\n- ✅ Passes → announce \"✅ Agent N complete\" and move to the next\n- ❌ Fails → analyze the root cause, fix, rerun (max 3 attempts)\n- After 3 consecutive failures → stop and ask for human validation\n\n**Never move to the next agent without a passing success criterion.**\n**Stay strictly within your current agent's defined scope.**\n\n---\n\n${phase0}## Phase 1 — Execution\n\n${agentBlocks}\n\n---\n\n## Future Iterations\n\nWhen a new agent is added via \\`agentkit add --feature <description>\\`:\n1. A new agent block is appended to \\`AGENT_WORKFLOW.md\\`\n2. The folder \\`agents/agent-{N}-{slug}/\\` is created with \\`skills.md\\`\n3. This \\`PLAYBOOK.md\\` is regenerated to include the new agent\n4. Execution resumes at the new agent only — completed agents are not rerun\n\nWhen you receive the instruction to continue after an iteration:\n> \"Read PLAYBOOK.md and execute only the agents that haven't been completed yet.\"\n\n---\n\n## Human Validation Required\n\nStop and wait for confirmation in these situations:\n- **3 consecutive failures** on the same success criterion\n- **Missing external dependency**: API key, env variable, unavailable service\n- **Conflict** between the detected stack and the user's stated constraints\n- **Destructive operation**: overwriting files not listed in deliverables\n- **End of Phase 0**: agent decomposition must be validated before execution\n`\n}\n\nfunction agentBlock(agent: Agent): string {\n const skillsPath = `agents/agent-${agent.number}-${agent.slug}/skills.md`\n const outputLines =\n agent.outputs.length > 0\n ? agent.outputs.map((o) => `- ${o}`).join('\\n')\n : '- (see skills.md for details)'\n\n return `### Agent ${agent.number} · ${agent.name}\n\n**Scope**: ${agent.scope}\n\n**Skills**: \\`${skillsPath}\\`\n\n**Deliverables**:\n${outputLines}\n\n**Success criterion**:\n\\`\\`\\`bash\n${agent.criterion || 'npm run build && npm test'}\n\\`\\`\\`\n\n**On failure**:\n1. Read the full error output\n2. Fix the root cause — not the symptoms\n3. Rerun the success criterion (max 3 attempts)\n4. After 3 failures → ask for human validation\n`\n}","import { mkdir, writeFile } from 'node:fs/promises'\nimport { join } from 'node:path'\nimport type { Agent } from '../types/agent.js'\n\nexport async function generateSkills(agents: Agent[], outputDir: string): Promise<void> {\n for (const agent of agents) {\n const agentDir = join(outputDir, 'agents', `agent-${agent.number}-${agent.slug}`)\n await mkdir(agentDir, { recursive: true })\n await writeFile(join(agentDir, 'skills.md'), skillsMd(agent), 'utf-8')\n await writeFile(join(agentDir, 'context.md'), contextMd(agent), 'utf-8')\n }\n}\n\nfunction skillsMd(agent: Agent): string {\n return `# Skills — ${agent.fullName}\n\n> Ce fichier est lu par l'agent avant de commencer.\n\n## Contexte technique\n\n<!-- À remplir : bibliothèques, versions, décisions d'architecture spécifiques à cet agent -->\n\n## Documentation de référence\n\n<!-- À remplir : liens vers docs, exemples, ADRs pertinents -->\n\n## Conventions spécifiques\n\n<!-- À remplir : règles propres à cet agent (naming, patterns, structure de fichiers) -->\n`\n}\n\nfunction contextMd(agent: Agent): string {\n const outputLines =\n agent.outputs.length > 0\n ? agent.outputs.map((o) => `- ${o}`).join('\\n')\n : '- (voir AGENT_WORKFLOW.md)'\n\n return `# Context — ${agent.fullName}\n\n> Ce fichier fournit le contexte additionnel à l'agent avant exécution.\n> À compléter avant de lancer cet agent.\n\n## Périmètre\n\n${agent.scope}\n\n## Fichiers produits attendus\n\n${outputLines}\n\n## Critère de succès\n\n\\`${agent.criterion || 'npm run build && npm test'}\\`\n`\n}\n","import chalk from 'chalk'\n\nexport const logger = {\n info: (message: string): void => {\n process.stdout.write(chalk.blue('ℹ') + ' ' + message + '\\n')\n },\n success: (message: string): void => {\n process.stdout.write(chalk.green('✔') + ' ' + message + '\\n')\n },\n warn: (message: string): void => {\n process.stdout.write(chalk.yellow('⚠') + ' ' + message + '\\n')\n },\n error: (message: string): void => {\n process.stderr.write(chalk.red('✖') + ' ' + message + '\\n')\n },\n}\n","import type { Command } from 'commander'\nimport { readFile, writeFile } from 'node:fs/promises'\nimport { join, basename } from 'node:path'\nimport inquirer from 'inquirer'\nimport { logger } from '../utils/logger.js'\nimport { extractAgentsFromWorkflow, toSlug } from '../utils/agentParser.js'\nimport { generatePlaybook } from '../generators/playbookGenerator.js'\nimport { generateSkills } from '../generators/skillsGenerator.js'\nimport type { Agent } from '../types/agent.js'\n\nfunction featureToAgentName(description: string): string {\n const clean = description\n .replace(/^(add|implement|create|build|integrate|setup|configure|refactor|improve)\\s+/i, '')\n .trim()\n return clean.replace(/\\b\\w/g, (c) => c.toUpperCase())\n}\n\nexport interface AddFeatureResult {\n agent: Agent\n agentDirPath: string\n}\n\nexport async function addFeatureToProject(\n description: string,\n projectDir: string,\n): Promise<AddFeatureResult> {\n const workflowPath = join(projectDir, 'AGENT_WORKFLOW.md')\n const playbookPath = join(projectDir, 'PLAYBOOK.md')\n\n let workflowContent = ''\n try {\n workflowContent = await readFile(workflowPath, 'utf-8')\n } catch {\n throw new Error(`AGENT_WORKFLOW.md not found in ${projectDir} — run agentkit init first`)\n }\n\n const existingAgents = extractAgentsFromWorkflow(workflowContent)\n const nextNumber = existingAgents.length + 1\n const name = featureToAgentName(description)\n const slug = toSlug(name)\n const fullName = `Agent ${nextNumber} · ${name}`\n\n const newAgent: Agent = {\n number: nextNumber,\n name,\n fullName,\n slug,\n scope: description,\n outputs: [`agents/agent-${nextNumber}-${slug}/`],\n criterion: 'npm run build && npm test',\n }\n\n const agentBlock = `\n### ${fullName}\nPérimètre : ${description}\nProduit :\n - agents/agent-${nextNumber}-${slug}/\nCritère : npm run build && npm test\n`\n\n await writeFile(workflowPath, workflowContent + agentBlock, 'utf-8')\n await generateSkills([newAgent], projectDir)\n\n let projectName = basename(projectDir)\n try {\n const pkg = JSON.parse(\n await readFile(join(projectDir, 'package.json'), 'utf-8'),\n ) as { name?: string }\n if (pkg.name) projectName = pkg.name\n } catch { /* use dirname fallback */ }\n\n const allAgents = [...existingAgents, newAgent]\n\n // When adding a feature iteration, hasBlueprint is false —\n // Phase 0 decomposition only runs during the initial init with --blueprint.\n const playbookContent = generatePlaybook({\n agents: allAgents,\n projectName,\n hasBlueprint: false,\n })\n await writeFile(playbookPath, playbookContent, 'utf-8')\n\n return {\n agent: newAgent,\n agentDirPath: join(projectDir, 'agents', `agent-${nextNumber}-${slug}`),\n }\n}\n\nexport function registerAdd(program: Command): void {\n const addCmd = program\n .command('add')\n .description('Add resources to the agentkit project')\n .option('--feature <description>', 'Add an agent from a feature description and regenerate PLAYBOOK.md')\n .action(async (options: { feature?: string }) => {\n if (options.feature) {\n try {\n const result = await addFeatureToProject(options.feature, process.cwd())\n logger.success(`Agent added : ${result.agent.fullName}`)\n logger.success(`Folder created : agents/agent-${result.agent.number}-${result.agent.slug}/`)\n logger.success('PLAYBOOK.md : regenerated')\n } catch (err) {\n logger.error(err instanceof Error ? err.message : String(err))\n process.exit(1)\n }\n } else {\n addCmd.help()\n }\n })\n\n addCmd\n .command('agent')\n .description('Add a new agent to AGENT_WORKFLOW.md (interactive)')\n .action(async () => {\n const cwd = process.cwd()\n const workflowPath = join(cwd, 'AGENT_WORKFLOW.md')\n\n let existing = ''\n try {\n existing = await readFile(workflowPath, 'utf-8')\n } catch {\n logger.error('AGENT_WORKFLOW.md not found — run agentkit init first')\n process.exit(1)\n }\n\n const agentCount = (existing.match(/^### Agent \\d+/gm) ?? []).length\n const nextNumber = agentCount + 1\n\n const answers = await inquirer.prompt<{\n name: string\n scope: string\n outputs: string\n criterion: string\n }>([\n {\n type: 'input',\n name: 'name',\n message: `Agent name (e.g. \"Agent ${nextNumber} · Feature X\"):`,\n default: `Agent ${nextNumber}`,\n },\n {\n type: 'input',\n name: 'scope',\n message: 'Scope (one sentence):',\n },\n {\n type: 'input',\n name: 'outputs',\n message: 'Deliverables (comma-separated):',\n },\n {\n type: 'input',\n name: 'criterion',\n message: 'Success criterion:',\n },\n ])\n\n const outputLines = answers.outputs\n .split(',')\n .map((o: string) => ` - ${o.trim()}`)\n .join('\\n')\n\n const agentSection = `\n### ${answers.name}\nPérimètre : ${answers.scope}\nProduit :\n${outputLines}\nCritère : ${answers.criterion}\n`\n\n await writeFile(workflowPath, existing + agentSection, 'utf-8')\n logger.success(`Agent \"${answers.name}\" added to AGENT_WORKFLOW.md`)\n })\n}","import type { Command } from 'commander'\nimport { readFile } from 'node:fs/promises'\nimport { join } from 'node:path'\nimport chalk from 'chalk'\nimport { detectStack } from '../detectors/stackDetector.js'\nimport { isGitRepo } from '../detectors/gitDetector.js'\nimport { logger } from '../utils/logger.js'\n\nexport function registerStatus(program: Command): void {\n program\n .command('status')\n .description('Affiche l\\'état du workflow agentkit dans le dossier courant')\n .action(async () => {\n const cwd = process.cwd()\n\n const [stack, isGit, claudeMd, workflow] = await Promise.all([\n detectStack(cwd),\n isGitRepo(cwd),\n readFile(join(cwd, 'CLAUDE.md'), 'utf-8').catch(() => null),\n readFile(join(cwd, 'AGENT_WORKFLOW.md'), 'utf-8').catch(() => null),\n ])\n\n process.stdout.write('\\n' + chalk.bold('AgentKit Status') + '\\n')\n process.stdout.write('─'.repeat(40) + '\\n')\n\n process.stdout.write(\n chalk.bold('Git repo : ') +\n (isGit ? chalk.green('✔ oui') : chalk.red('✖ non')) +\n '\\n',\n )\n\n process.stdout.write(\n chalk.bold('Stack : ') + chalk.cyan(stack.framework) + ' (' + stack.language + ')\\n',\n )\n\n process.stdout.write(\n chalk.bold('CLAUDE.md : ') +\n (claudeMd !== null ? chalk.green('✔ présent') : chalk.yellow('✖ absent — lancez agentkit init')) +\n '\\n',\n )\n\n process.stdout.write(\n chalk.bold('AGENT_WORKFLOW.md : ') +\n (workflow !== null ? chalk.green('✔ présent') : chalk.yellow('✖ absent — lancez agentkit init')) +\n '\\n',\n )\n\n if (workflow !== null) {\n const agentMatches = workflow.match(/^### Agent \\d+/gm) ?? []\n process.stdout.write(\n chalk.bold('Agents définis : ') + chalk.cyan(String(agentMatches.length)) + '\\n',\n )\n }\n\n process.stdout.write('─'.repeat(40) + '\\n\\n')\n })\n}\n"],"mappings":"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","names":["writeFile","readFile","join","access","join","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","claudeMd","workflow","join","readFile","program","join","writeFile","readFile","writeFile","join","basename","inquirer","join","readFile","agentBlock","writeFile","basename","program","inquirer","readFile","join","chalk","program","claudeMd","workflow","readFile","join","chalk"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@patricksardinha/agentkit-cli",
3
- "version": "0.2.0",
3
+ "version": "0.3.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -31,7 +31,7 @@ export async function addFeatureToProject(
31
31
  try {
32
32
  workflowContent = await readFile(workflowPath, 'utf-8')
33
33
  } catch {
34
- throw new Error(`AGENT_WORKFLOW.md introuvable dans ${projectDir} — lancez agentkit init`)
34
+ throw new Error(`AGENT_WORKFLOW.md not found in ${projectDir} — run agentkit init first`)
35
35
  }
36
36
 
37
37
  const existingAgents = extractAgentsFromWorkflow(workflowContent)
@@ -70,7 +70,14 @@ Critère : npm run build && npm test
70
70
  } catch { /* use dirname fallback */ }
71
71
 
72
72
  const allAgents = [...existingAgents, newAgent]
73
- const playbookContent = generatePlaybook({ agents: allAgents, projectName })
73
+
74
+ // When adding a feature iteration, hasBlueprint is false —
75
+ // Phase 0 decomposition only runs during the initial init with --blueprint.
76
+ const playbookContent = generatePlaybook({
77
+ agents: allAgents,
78
+ projectName,
79
+ hasBlueprint: false,
80
+ })
74
81
  await writeFile(playbookPath, playbookContent, 'utf-8')
75
82
 
76
83
  return {
@@ -82,15 +89,15 @@ Critère : npm run build && npm test
82
89
  export function registerAdd(program: Command): void {
83
90
  const addCmd = program
84
91
  .command('add')
85
- .description('Ajoute des ressources au projet agentkit')
86
- .option('--feature <description>', 'Ajoute un agent depuis une description de feature et régénère PLAYBOOK.md')
92
+ .description('Add resources to the agentkit project')
93
+ .option('--feature <description>', 'Add an agent from a feature description and regenerate PLAYBOOK.md')
87
94
  .action(async (options: { feature?: string }) => {
88
95
  if (options.feature) {
89
96
  try {
90
97
  const result = await addFeatureToProject(options.feature, process.cwd())
91
- logger.success(`Agent ajouté : ${result.agent.fullName}`)
92
- logger.success(`Dossier créé : agents/agent-${result.agent.number}-${result.agent.slug}/`)
93
- logger.success('PLAYBOOK.md : régénéré')
98
+ logger.success(`Agent added : ${result.agent.fullName}`)
99
+ logger.success(`Folder created : agents/agent-${result.agent.number}-${result.agent.slug}/`)
100
+ logger.success('PLAYBOOK.md : regenerated')
94
101
  } catch (err) {
95
102
  logger.error(err instanceof Error ? err.message : String(err))
96
103
  process.exit(1)
@@ -102,7 +109,7 @@ export function registerAdd(program: Command): void {
102
109
 
103
110
  addCmd
104
111
  .command('agent')
105
- .description('Ajoute un nouvel agent dans AGENT_WORKFLOW.md (interactif)')
112
+ .description('Add a new agent to AGENT_WORKFLOW.md (interactive)')
106
113
  .action(async () => {
107
114
  const cwd = process.cwd()
108
115
  const workflowPath = join(cwd, 'AGENT_WORKFLOW.md')
@@ -111,7 +118,7 @@ export function registerAdd(program: Command): void {
111
118
  try {
112
119
  existing = await readFile(workflowPath, 'utf-8')
113
120
  } catch {
114
- logger.error('AGENT_WORKFLOW.md introuvablelancez d\'abord : agentkit init')
121
+ logger.error('AGENT_WORKFLOW.md not found run agentkit init first')
115
122
  process.exit(1)
116
123
  }
117
124
 
@@ -127,23 +134,23 @@ export function registerAdd(program: Command): void {
127
134
  {
128
135
  type: 'input',
129
136
  name: 'name',
130
- message: `Nom de l'agent (ex: "Agent ${nextNumber} · Feature X") :`,
137
+ message: `Agent name (e.g. "Agent ${nextNumber} · Feature X"):`,
131
138
  default: `Agent ${nextNumber}`,
132
139
  },
133
140
  {
134
141
  type: 'input',
135
142
  name: 'scope',
136
- message: 'Périmètre (une phrase) :',
143
+ message: 'Scope (one sentence):',
137
144
  },
138
145
  {
139
146
  type: 'input',
140
147
  name: 'outputs',
141
- message: 'Fichiers produits (séparés par des virgules) :',
148
+ message: 'Deliverables (comma-separated):',
142
149
  },
143
150
  {
144
151
  type: 'input',
145
152
  name: 'criterion',
146
- message: 'Critère de succès :',
153
+ message: 'Success criterion:',
147
154
  },
148
155
  ])
149
156
 
@@ -161,6 +168,6 @@ Critère : ${answers.criterion}
161
168
  `
162
169
 
163
170
  await writeFile(workflowPath, existing + agentSection, 'utf-8')
164
- logger.success(`Agent "${answers.name}" ajouté dans AGENT_WORKFLOW.md`)
171
+ logger.success(`Agent "${answers.name}" added to AGENT_WORKFLOW.md`)
165
172
  })
166
- }
173
+ }
@@ -115,7 +115,7 @@ export function registerInit(program: Command): void {
115
115
  const claudeMdContent = generateClaudeMd(stack, blueprintContent)
116
116
  const workflowContent = generateWorkflow(stack, blueprintContent)
117
117
  const agents = extractAgentsFromWorkflow(workflowContent)
118
- const playbookContent = generatePlaybook({ agents, projectName })
118
+ const playbookContent = generatePlaybook({ agents, projectName, hasBlueprint: !!blueprintContent })
119
119
  await writeFile(claudeMdPath, claudeMdContent, 'utf-8')
120
120
  await writeFile(workflowPath, workflowContent, 'utf-8')
121
121
  await writeFile(playbookPath, playbookContent, 'utf-8')