@rigstate/cli 0.6.7 → 0.6.8

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/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../node_modules/tsup/assets/esm_shims.js","../src/utils/config.ts","../src/commands/env.ts","../src/commands/sync-rules.ts","../src/commands/hooks.ts","../src/utils/skills-provisioner.ts","../src/utils/governance.ts","../src/utils/watchdog.ts","../src/index.ts","../src/commands/login.ts","../src/commands/link.ts","../src/commands/scan.ts","../src/utils/files.ts","../src/commands/fix.ts","../src/commands/sync.ts","../src/commands/init.ts","../src/utils/manifest.ts","../src/commands/check.ts","../src/utils/rule-engine.ts","../src/commands/daemon.ts","../src/daemon/factory.ts","../src/daemon/core.ts","../src/daemon/file-watcher.ts","../src/daemon/heuristic-engine.ts","../src/daemon/intervention-protocol.ts","../src/daemon/guardian-monitor.ts","../src/daemon/bridge-listener.ts","../src/daemon/telemetry.ts","../src/commands/work.ts","../src/commands/watch.ts","../src/commands/focus.ts","../src/commands/config.ts","../src/commands/mcp.ts","../src/commands/nexus.ts","../src/nexus/dispatcher.ts","../src/hive/gateway.ts","../src/hive/scrubber.ts","../src/utils/logger.ts","../src/commands/override.ts","../src/utils/version.ts"],"sourcesContent":["// Shim globals in esm bundle\nimport path from 'node:path'\nimport { fileURLToPath } from 'node:url'\n\nconst getFilename = () => fileURLToPath(import.meta.url)\nconst getDirname = () => path.dirname(getFilename())\n\nexport const __dirname = /* @__PURE__ */ getDirname()\nexport const __filename = /* @__PURE__ */ getFilename()\n","import Conf from 'conf';\n\ninterface RigstateConfig {\n apiKey?: string;\n projectId?: string;\n apiUrl?: string;\n}\n\nconst config = new Conf<RigstateConfig>({\n projectName: 'rigstate-cli',\n defaults: {\n apiUrl: 'http://localhost:3000',\n },\n});\n\n/**\n * Get the stored API key\n * @throws {Error} If no API key is found (user not logged in)\n */\nexport function getApiKey(): string {\n const apiKey = config.get('apiKey');\n if (!apiKey) {\n throw new Error(\n '❌ Not logged in. Please run \"rigstate login <your-api-key>\" first.'\n );\n }\n return apiKey;\n}\n\n/**\n * Set the API key\n */\nexport function setApiKey(key: string): void {\n config.set('apiKey', key);\n}\n\n/**\n * Get the default project ID (if set)\n */\nexport function getProjectId(): string | undefined {\n return config.get('projectId');\n}\n\n/**\n * Set the default project ID\n */\nexport function setProjectId(projectId: string): void {\n config.set('projectId', projectId);\n}\n\n/**\n * Get the API URL\n * Priority: Environment variable > Stored config > Production default\n */\nexport function getApiUrl(): string {\n // 1. Check environment variable first\n if (process.env.RIGSTATE_API_URL) {\n return process.env.RIGSTATE_API_URL;\n }\n // 2. Check stored config\n const storedUrl = config.get('apiUrl');\n if (storedUrl) {\n return storedUrl;\n }\n // 3. Default to production\n return 'https://app.rigstate.com';\n}\n\n/**\n * Set the API URL\n */\nexport function setApiUrl(url: string): void {\n config.set('apiUrl', url);\n}\n\n/**\n * Clear all config\n */\nexport function clearConfig(): void {\n config.clear();\n}\n\nexport { config };\n","/* eslint-disable no-console */\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { getApiKey, getProjectId, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\n\n// Core Logic (Exported for re-use)\nexport async function syncEnv(projectId: string, apiKey: string, apiUrl: string, silent = false): Promise<boolean> {\n if (!silent) {\n console.log('');\n console.log(chalk.bold.yellow('╔══════════════════════════════════════════╗'));\n console.log(chalk.bold.yellow('║') + chalk.bold.white(' 🛡️ RIGSTATE SOVEREIGN VAULT SYNC 🛡️ ') + chalk.bold.yellow('║'));\n console.log(chalk.bold.yellow('╚══════════════════════════════════════════╝'));\n console.log('');\n }\n\n const spinner = ora('Fetching secrets from Vault...').start();\n\n try {\n const response = await axios.post(`${apiUrl}/api/v1/vault/sync`, {\n project_id: projectId\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!response.data.success) {\n throw new Error(response.data.error || 'Failed to fetch secrets');\n }\n\n const vaultContent = response.data.data.content || '';\n const secretCount = response.data.data.count || 0;\n\n if (secretCount === 0) {\n spinner.info('No secrets found in Vault for this project.');\n if (!silent) console.log(chalk.dim(' Add secrets via the Rigstate web interface.'));\n return true;\n }\n\n spinner.succeed(`Retrieved ${chalk.bold(secretCount)} secret(s)`);\n\n // Read existing .env.local for comparison\n const envFile = path.resolve(process.cwd(), '.env.local');\n let existingContent = '';\n let existingKeys: Set<string> = new Set();\n\n try {\n existingContent = await fs.readFile(envFile, 'utf-8');\n // Parse existing keys\n existingContent.split('\\n').forEach(line => {\n const match = line.match(/^([A-Z_][A-Z0-9_]*)=/);\n if (match) existingKeys.add(match[1]);\n });\n } catch (e) {\n // File doesn't exist\n }\n\n // Parse vault keys\n const vaultKeys: Set<string> = new Set();\n vaultContent.split('\\n').forEach((line: string) => {\n const match = line.match(/^([A-Z_][A-Z0-9_]*)=/);\n if (match) vaultKeys.add(match[1]);\n });\n\n // Calculate changes\n let newCount = 0;\n let updatedCount = 0;\n\n vaultKeys.forEach(key => {\n if (!existingKeys.has(key)) {\n newCount++;\n } else {\n updatedCount++;\n }\n });\n\n const unchangedCount = existingKeys.size - updatedCount;\n\n // Write new .env.local\n spinner.start('Writing .env.local...');\n\n const header = [\n '# ==========================================',\n '# RIGSTATE SOVEREIGN FOUNDATION',\n '# Authenticated Environment Configuration',\n `# Synced at: ${new Date().toISOString()}`,\n `# Project: ${projectId}`,\n '# ==========================================',\n ''\n ].join('\\n');\n\n await fs.writeFile(envFile, header + vaultContent + '\\n');\n spinner.succeed('Written to .env.local');\n\n if (!silent) {\n // Summary\n console.log('');\n console.log(chalk.bold.green('✅ Environment synchronized successfully'));\n console.log('');\n console.log(chalk.dim(' Summary:'));\n console.log(chalk.green(` + ${newCount} new`));\n console.log(chalk.yellow(` ~ ${updatedCount} updated`));\n console.log(chalk.dim(` = ${unchangedCount} unchanged`));\n console.log('');\n\n // Security reminder\n console.log(chalk.bold.yellow('⚠️ Security Reminder:'));\n console.log(chalk.dim(' - Never commit .env.local to version control.'));\n console.log(chalk.dim(' - Ensure .gitignore includes .env.local'));\n console.log('');\n }\n return true;\n\n } catch (e: any) {\n spinner.fail(chalk.red(`Failed to fetch secrets: ${e.message}`));\n return false;\n }\n}\n\nexport function createEnvPullCommand() {\n const envPull = new Command('env');\n\n envPull\n .command('pull')\n .description('Pull environment variables from project vault')\n .action(async () => {\n // Get config\n let apiKey: string;\n let projectId: string | undefined;\n\n try {\n apiKey = getApiKey();\n } catch (e) {\n console.error(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n // Get project context\n projectId = getProjectId();\n\n if (!projectId) {\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const content = await fs.readFile(manifestPath, 'utf-8');\n const manifest = JSON.parse(content);\n projectId = manifest.project_id;\n } catch (e) { }\n }\n\n if (!projectId) {\n console.error(chalk.red('No project context. Run \"rigstate link\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n await syncEnv(projectId, apiKey, apiUrl);\n });\n\n return envPull;\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { getApiKey, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\n\ninterface SyncResult {\n projectId: string;\n projectName: string;\n status: 'success' | 'failed';\n error?: string;\n}\n\n// Core Logic (Exported for re-use)\nexport async function syncProjectRules(projectId: string, apiKey: string, apiUrl: string, dryRun = false): Promise<boolean> {\n const spinner = ora('🛡️ Frank Protocol: Initializing retroactive sync...').start();\n let success = true;\n\n try {\n // Fetch project to get name\n spinner.text = 'Fetching project info...';\n const projectRes = await axios.get(`${apiUrl}/api/v1/projects`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!projectRes.data.success || !projectRes.data.data.projects?.length) {\n throw new Error('Project not found');\n }\n\n const project = projectRes.data.data.projects[0];\n spinner.text = `Syncing rules for ${project.name}...`;\n\n if (dryRun) {\n spinner.succeed(chalk.yellow(` [DRY-RUN] Would sync: ${project.name}`));\n return true;\n }\n\n // Call API to regenerate and sync rules\n const syncResponse = await axios.post(`${apiUrl}/api/v1/rules/sync`, {\n project_id: project.id\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (syncResponse.data.success) {\n if (syncResponse.data.data.github_synced) {\n spinner.succeed(chalk.green(` ✅ ${project.name} [${project.id}] → GitHub synced`));\n } else {\n spinner.info(chalk.blue(` ℹ️ ${project.name} [${project.id}] → Rules generated (no GitHub)`));\n }\n\n const files = syncResponse.data.data.files;\n if (files && Array.isArray(files)) {\n const fs = await import('fs/promises');\n const path = await import('path');\n\n for (const file of files) {\n const filePath = path.join(process.cwd(), file.path);\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n await fs.writeFile(filePath, file.content, 'utf-8');\n }\n console.log(chalk.dim(` 💾 Wrote ${files.length} rule files to local .cursor/rules/`));\n }\n\n console.log('');\n console.log(chalk.cyan('🛡️ Frank Protocol v1.0 has been injected into the rules engine.'));\n console.log(chalk.dim(' All new chats will now boot with mandatory governance checks.'));\n } else {\n spinner.warn(chalk.yellow(` ⚠️ ${project.name} → ${syncResponse.data.error || 'Unknown error'}`));\n success = false;\n }\n\n } catch (e: any) {\n spinner.fail(chalk.red(`Sync failed: ${e.message}`));\n success = false;\n }\n return success;\n}\n\nexport function createSyncRulesCommand() {\n const syncRules = new Command('sync-rules');\n\n syncRules\n .description('🛡️ Push Frank Protocol v1.0 to all existing projects')\n .option('--dry-run', 'Preview changes without pushing to GitHub')\n .option('--project <id>', 'Sync a specific project only')\n .action(async (options) => {\n // CLI specific logic (handling multiple projects etc) is kept here or simplified\n // For now, let's just support single project sync via re-used logic if project ID is clear\n\n // Get config\n let apiKey: string;\n try {\n apiKey = getApiKey();\n } catch (e) {\n console.error(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n\n // ... (Logic to select project is skipped for brevity in this refactor step, assumes --project or .env)\n // In a real refactor we would extract project selection too.\n // For Link command integration, direct ID is passed, so syncProjectRules is enough.\n\n if (options.project) {\n await syncProjectRules(options.project, apiKey, apiUrl, options.dryRun);\n } else {\n console.log(chalk.yellow('Use --project <id> for now. (Mass sync logic awaiting migration)'));\n }\n });\n\n return syncRules;\n}\n","/**\n * rigstate hooks - Manage git hooks for Guardian integration\n * \n * Usage:\n * rigstate hooks install # Install pre-commit hook\n * rigstate hooks uninstall # Remove pre-commit hook\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport fs from 'fs/promises';\nimport path from 'path';\n\nconst PRE_COMMIT_SCRIPT = `#!/bin/sh\n# Rigstate Guardian Pre-commit Hook\n# Installed by: rigstate hooks install\n\n# 1. Silent Sentinel Check (Phase 5)\nif [ -f .rigstate/guardian.lock ]; then\n echo \"🛑 INTERVENTION ACTIVE: Commit blocked by Silent Sentinel.\"\n echo \" A critical violation ('HARD_LOCK') was detected by the Guardian Daemon.\"\n echo \" Please fix the violation to unlock the repo.\"\n echo \"\"\n if grep -q \"HARD_LOCK_ACTIVE\" .rigstate/guardian.lock; then\n cat .rigstate/guardian.lock\n fi\n exit 1\nfi\n\necho \"🛡️ Running Guardian checks...\"\n\n# Run check with strict mode for critical violations\nrigstate check --staged --strict=critical\n\n# Exit with the same code as rigstate check\nexit $?\n`;\n\nexport function createHooksCommand(): Command {\n const hooks = new Command('hooks')\n .description('Manage git hooks for Guardian integration');\n\n hooks\n .command('install')\n .description('Install pre-commit hook to run Guardian checks')\n .option('--strict [level]', 'Strict level: \"all\" or \"critical\" (default)', 'critical')\n .action(async (options: { strict: string }) => {\n try {\n // 1. Find .git directory\n const gitDir = path.join(process.cwd(), '.git');\n try {\n await fs.access(gitDir);\n } catch {\n console.log(chalk.red('❌ Not a git repository.'));\n console.log(chalk.dim(' Initialize with \"git init\" first.'));\n process.exit(1);\n }\n\n // 2. Ensure hooks directory exists\n const hooksDir = path.join(gitDir, 'hooks');\n await fs.mkdir(hooksDir, { recursive: true });\n\n // 3. Check for existing pre-commit\n const preCommitPath = path.join(hooksDir, 'pre-commit');\n let existingContent = '';\n try {\n existingContent = await fs.readFile(preCommitPath, 'utf-8');\n if (existingContent.includes('rigstate')) {\n console.log(chalk.yellow('⚠ Rigstate pre-commit hook already installed.'));\n console.log(chalk.dim(' Use \"rigstate hooks uninstall\" to remove first.'));\n return;\n }\n } catch {\n // File doesn't exist, that's fine\n }\n\n // 4. Create hook script with configurable strict level\n let script = PRE_COMMIT_SCRIPT;\n if (options.strict === 'all') {\n script = script.replace('--strict=critical', '--strict');\n }\n\n // 5. If existing hook, append to it\n if (existingContent && !existingContent.includes('rigstate')) {\n // Append our hook to existing\n const combinedScript = existingContent + '\\n\\n' + script.replace('#!/bin/sh\\n', '');\n await fs.writeFile(preCommitPath, combinedScript, { mode: 0o755 });\n console.log(chalk.green('✅ Rigstate hook appended to existing pre-commit.'));\n } else {\n // Create new hook\n await fs.writeFile(preCommitPath, script, { mode: 0o755 });\n console.log(chalk.green('✅ Pre-commit hook installed!'));\n }\n\n console.log(chalk.dim(` Path: ${preCommitPath}`));\n console.log(chalk.dim(` Strict level: ${options.strict}`));\n console.log('');\n console.log(chalk.cyan('Guardian will now check your code before each commit.'));\n console.log(chalk.dim('Use \"rigstate hooks uninstall\" to remove the hook.'));\n\n } catch (error: any) {\n console.error(chalk.red('Failed to install hook:'), error.message);\n process.exit(1);\n }\n });\n\n hooks\n .command('uninstall')\n .description('Remove Rigstate pre-commit hook')\n .action(async () => {\n try {\n const preCommitPath = path.join(process.cwd(), '.git', 'hooks', 'pre-commit');\n\n try {\n const content = await fs.readFile(preCommitPath, 'utf-8');\n\n if (!content.includes('rigstate')) {\n console.log(chalk.yellow('⚠ No Rigstate hook found in pre-commit.'));\n return;\n }\n\n // Check if it's our hook exclusively\n if (content.includes('# Rigstate Guardian Pre-commit Hook') &&\n content.trim().split('\\n').filter(l => l && !l.startsWith('#')).length <= 4) {\n // It's only our hook, remove the file\n await fs.unlink(preCommitPath);\n console.log(chalk.green('✅ Pre-commit hook removed.'));\n } else {\n // There's other content, just remove our section\n const lines = content.split('\\n');\n const filteredLines = [];\n let inRigstateSection = false;\n\n for (const line of lines) {\n if (line.includes('Rigstate Guardian Pre-commit Hook')) {\n inRigstateSection = true;\n continue;\n }\n if (inRigstateSection && line.includes('exit $?')) {\n inRigstateSection = false;\n continue;\n }\n if (!inRigstateSection && !line.includes('rigstate check')) {\n filteredLines.push(line);\n }\n }\n\n await fs.writeFile(preCommitPath, filteredLines.join('\\n'), { mode: 0o755 });\n console.log(chalk.green('✅ Rigstate section removed from pre-commit hook.'));\n }\n\n } catch {\n console.log(chalk.yellow('⚠ No pre-commit hook found.'));\n }\n\n } catch (error: any) {\n console.error(chalk.red('Failed to uninstall hook:'), error.message);\n process.exit(1);\n }\n });\n\n return hooks;\n}\n","import { AgentSkill } from '@rigstate/rules-engine';\nimport axios from 'axios';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\n\n/**\n * Provisions Agent Skills to the local project.\n * \n * Flow:\n * 1. Fetch skills from API (database)\n * 2. Merge with core skills from rules-engine\n * 3. Write to .agent/skills/<name>/SKILL.md\n * 4. Return list of provisioned skills for .cursorrules injection\n */\nexport async function provisionSkills(\n apiUrl: string,\n apiKey: string,\n projectId: string,\n rootDir: string\n): Promise<AgentSkill[]> {\n const skills: AgentSkill[] = [];\n\n // 1. Fetch skills from database (user + global + core)\n try {\n const response = await axios.get(`${apiUrl}/api/v1/skills`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (response.data.success && response.data.data) {\n for (const dbSkill of response.data.data) {\n skills.push({\n name: dbSkill.name,\n description: dbSkill.description,\n specialist: dbSkill.specialist || 'General',\n version: dbSkill.version || '1.0.0',\n governance: dbSkill.governance || 'OPEN',\n content: dbSkill.content\n });\n }\n }\n } catch (e: any) {\n // API might not have skills endpoint yet - fall through to core skills\n const msg = e.response?.data?.error || e.message;\n console.log(chalk.dim(` (Skills API not available: ${msg}, using core library)`));\n }\n\n // 2. If no skills from DB, use core library from rules-engine\n if (skills.length === 0) {\n const { getRigstateStandardSkills } = await import('@rigstate/rules-engine');\n const coreSkills = getRigstateStandardSkills();\n skills.push(...coreSkills);\n }\n\n // 3. Write skills to .agent/skills/\n const skillsDir = path.join(rootDir, '.agent', 'skills');\n await fs.mkdir(skillsDir, { recursive: true });\n\n for (const skill of skills) {\n const skillDir = path.join(skillsDir, skill.name);\n await fs.mkdir(skillDir, { recursive: true });\n\n const skillContent = `---\nname: ${skill.name}\ndescription: ${skill.description}\nversion: \"${skill.version}\"\nspecialist: ${skill.specialist}\ngovernance: ${skill.governance}\n---\n\n${skill.content}\n\n---\n*Provisioned by Rigstate CLI. Do not modify manually.*`;\n\n const skillPath = path.join(skillDir, 'SKILL.md');\n await fs.writeFile(skillPath, skillContent, 'utf-8');\n }\n\n console.log(chalk.green(` ✅ Provisioned ${skills.length} skill(s) to .agent/skills/`));\n\n return skills;\n}\n\n/**\n * Generate the <available_skills> XML block for .cursorrules\n */\nexport function generateSkillsDiscoveryBlock(skills: AgentSkill[]): string {\n if (skills.length === 0) return '';\n\n const skillBlocks = skills.map(skill => ` <skill>\n <name>${skill.name}</name>\n <description>${skill.description}</description>\n <location>.agent/skills/${skill.name}/SKILL.md</location>\n </skill>`).join('\\n');\n\n return `<available_skills>\n${skillBlocks}\n</available_skills>`;\n}\n/**\n * Just-In-Time provisioning of a specific skill.\n * Checks if the skill is already in .cursorrules and injects it if not.\n */\nexport async function jitProvisionSkill(\n skillId: string,\n apiUrl: string,\n apiKey: string,\n projectId: string,\n rootDir: string\n): Promise<boolean> {\n const rulesPath = path.join(rootDir, '.cursorrules');\n let rulesContent = '';\n\n try {\n rulesContent = await fs.readFile(rulesPath, 'utf-8');\n } catch (e) {\n return false;\n }\n\n const isProvisioned = rulesContent.includes(`<name>${skillId}</name>`) ||\n rulesContent.includes(`.agent/skills/${skillId}`);\n\n if (isProvisioned) return false;\n\n console.log(chalk.yellow(` ⚡ JIT PROVISIONING: Injecting ${skillId}...`));\n\n try {\n const skills = await provisionSkills(apiUrl, apiKey, projectId, rootDir);\n const skillsBlock = generateSkillsDiscoveryBlock(skills);\n\n if (rulesContent.includes('<available_skills>')) {\n rulesContent = rulesContent.replace(\n /<available_skills>[\\s\\S]*?<\\/available_skills>/,\n skillsBlock\n );\n } else if (rulesContent.includes('## 🧠 PROJECT CONTEXT')) {\n const insertPoint = rulesContent.indexOf('---', rulesContent.indexOf('## 🧠 PROJECT CONTEXT'));\n if (insertPoint !== -1) {\n rulesContent = rulesContent.slice(0, insertPoint + 3) +\n '\\n\\n' + skillsBlock + '\\n' +\n rulesContent.slice(insertPoint + 3);\n }\n }\n\n await fs.writeFile(rulesPath, rulesContent, 'utf-8');\n return true;\n } catch (e: any) {\n console.log(chalk.red(` Failed to provision skill: ${e.message}`));\n return false;\n }\n}\n","import fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\n\n// --- Types ---\n\nexport enum InterventionLevel {\n GHOST = 0, // Log only, silent\n NUDGE = 1, // Warn on commit/complete\n SENTINEL = 2 // Immediate SOFT_LOCK\n}\n\nexport type LockStatus = 'OPEN' | 'SOFT_LOCK';\n\nexport interface GovernanceConfig {\n governance: {\n intervention_level: InterventionLevel;\n allow_overrides: boolean;\n };\n}\n\nexport interface SessionState {\n status: LockStatus;\n active_violation?: string | null;\n lock_reason?: string | null;\n last_updated: string;\n}\n\nconst DEFAULT_CONFIG: GovernanceConfig = {\n governance: {\n intervention_level: InterventionLevel.GHOST,\n allow_overrides: true\n }\n};\n\nconst DEFAULT_SESSION: SessionState = {\n status: 'OPEN',\n active_violation: null,\n lock_reason: null,\n last_updated: new Date().toISOString()\n};\n\n// --- Config Management ---\n\nexport async function getGovernanceConfig(rootDir: string = process.cwd()): Promise<GovernanceConfig> {\n try {\n const configPath = path.join(rootDir, 'rigstate.config.json');\n const content = await fs.readFile(configPath, 'utf-8');\n const userConfig = JSON.parse(content);\n return {\n governance: {\n ...DEFAULT_CONFIG.governance,\n ...userConfig.governance\n }\n };\n } catch (e) {\n return DEFAULT_CONFIG;\n }\n}\n\n// --- Session State Management ---\n\nexport async function getSessionState(rootDir: string = process.cwd()): Promise<SessionState> {\n try {\n const sessionPath = path.join(rootDir, '.rigstate', 'session.json');\n const content = await fs.readFile(sessionPath, 'utf-8');\n return JSON.parse(content);\n } catch (e) {\n return DEFAULT_SESSION;\n }\n}\n\nexport async function setSoftLock(\n reason: string,\n violationId: string,\n rootDir: string = process.cwd()\n): Promise<void> {\n const sessionPath = path.join(rootDir, '.rigstate', 'session.json');\n const state: SessionState = {\n status: 'SOFT_LOCK',\n active_violation: violationId,\n lock_reason: reason,\n last_updated: new Date().toISOString()\n };\n\n await fs.mkdir(path.dirname(sessionPath), { recursive: true });\n await fs.writeFile(sessionPath, JSON.stringify(state, null, 2), 'utf-8');\n}\n\nexport async function clearSoftLock(\n rootDir: string = process.cwd()\n): Promise<void> {\n const sessionPath = path.join(rootDir, '.rigstate', 'session.json');\n const state: SessionState = {\n ...DEFAULT_SESSION,\n last_updated: new Date().toISOString()\n };\n\n await fs.mkdir(path.dirname(sessionPath), { recursive: true });\n await fs.writeFile(sessionPath, JSON.stringify(state, null, 2), 'utf-8');\n}\n\n/**\n * Checks if the user is authorized to perform an override\n * (For now, assumes CLI user is authorized, but logs it)\n */\nexport async function performOverride(\n violationId: string,\n reason: string,\n rootDir: string = process.cwd()\n): Promise<boolean> {\n const config = await getGovernanceConfig(rootDir);\n\n if (!config.governance.allow_overrides) {\n console.log(chalk.red('❌ Overrides are disabled for this project.'));\n return false;\n }\n\n // Security violations (SEC-*) cannot be overridden via CLI usually, \n // but the implementation here depends on how we define \"Security\".\n // For now, we allow overriding via this function, but the *Caller* should check violation type.\n\n await clearSoftLock(rootDir);\n // TODO: Add to Mission Report (Audit Log)\n // We will handle logging in the command handler itself\n\n return true;\n}\n","/**\n * Guardian Watchdog - Scans files against governance rules\n * Now fetches rules from API with fallback to cache/defaults\n */\n\nimport fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\nimport axios from 'axios';\nimport { getApiUrl, getApiKey } from './config.js';\n\ninterface EffectiveRule {\n id: string;\n rule_name: string;\n rule_type: string;\n value: Record<string, unknown>;\n severity: 'critical' | 'warning' | 'info';\n description: string;\n source: 'global' | 'project_override';\n is_enabled: boolean;\n}\n\ninterface ScanResult {\n file: string;\n lines: number;\n status: 'OK' | 'WARNING' | 'VIOLATION';\n}\n\nconst DEFAULT_LMAX = 400;\nconst DEFAULT_LMAX_WARNING = 350;\nconst CACHE_FILE = '.rigstate/rules-cache.json';\n\nasync function countLines(filePath: string): Promise<number> {\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n return content.split('\\n').length;\n } catch (e) {\n return 0;\n }\n}\n\nasync function getFiles(dir: string, extension: string[]): Promise<string[]> {\n const entries = await fs.readdir(dir, { withFileTypes: true });\n const files = await Promise.all(entries.map(async (entry) => {\n const res = path.resolve(dir, entry.name);\n if (entry.isDirectory()) {\n if (entry.name === 'node_modules' || entry.name === '.git' || entry.name === '.next' || entry.name === 'dist') return [];\n return getFiles(res, extension);\n } else {\n return extension.some(ext => entry.name.endsWith(ext)) ? res : [];\n }\n }));\n return files.flat();\n}\n\n/**\n * Fetch rules from API with fallback\n */\nasync function fetchRulesFromApi(projectId: string): Promise<{\n lmax: number;\n lmaxWarning: number;\n source: string;\n}> {\n try {\n const apiUrl = getApiUrl();\n const apiKey = getApiKey();\n\n const response = await axios.get(`${apiUrl}/api/v1/guardian/rules`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 10000\n });\n\n if (response.data.success && response.data.data.settings) {\n return {\n lmax: response.data.data.settings.lmax || DEFAULT_LMAX,\n lmaxWarning: response.data.data.settings.lmax_warning || DEFAULT_LMAX_WARNING,\n source: 'API (Dynamic)'\n };\n }\n } catch (error) {\n // Try to load from cache\n try {\n const cachePath = path.join(process.cwd(), CACHE_FILE);\n const content = await fs.readFile(cachePath, 'utf-8');\n const cached = JSON.parse(content);\n if (cached.settings) {\n return {\n lmax: cached.settings.lmax || DEFAULT_LMAX,\n lmaxWarning: cached.settings.lmax_warning || DEFAULT_LMAX_WARNING,\n source: 'Cache (Fallback)'\n };\n }\n } catch {\n // Cache read failed\n }\n }\n\n // Default fallback\n return {\n lmax: DEFAULT_LMAX,\n lmaxWarning: DEFAULT_LMAX_WARNING,\n source: 'Default (Hardcoded)'\n };\n}\n\nexport async function runGuardianWatchdog(\n rootPath: string,\n settings: Record<string, any> = {},\n projectId?: string\n): Promise<void> {\n console.log(chalk.bold('\\n🛡️ Active Guardian Watchdog Initiated...'));\n\n // Try to get rules from API if projectId is provided\n let lmax = settings.lmax || DEFAULT_LMAX;\n let lmaxWarning = settings.lmax_warning || DEFAULT_LMAX_WARNING;\n let ruleSource = settings.lmax ? 'Settings (Passed)' : 'Default';\n\n if (projectId) {\n const apiRules = await fetchRulesFromApi(projectId);\n lmax = apiRules.lmax;\n lmaxWarning = apiRules.lmaxWarning;\n ruleSource = apiRules.source;\n }\n\n console.log(chalk.dim(`Governance Rules: L_max=${lmax}, L_max_warning=${lmaxWarning}, Source: ${ruleSource}`));\n\n const targetExtensions = ['.ts', '.tsx'];\n let scanTarget = rootPath;\n const webSrc = path.join(rootPath, 'apps', 'web', 'src');\n\n try {\n await fs.access(webSrc);\n scanTarget = webSrc;\n } catch {\n // apps/web/src not found, scanning root or provided path\n }\n\n console.log(chalk.dim(`Scanning target: ${path.relative(process.cwd(), scanTarget)}`));\n\n const files = await getFiles(scanTarget, targetExtensions);\n\n let violations = 0;\n let warnings = 0;\n\n const results: ScanResult[] = [];\n\n for (const file of files) {\n const lines = await countLines(file);\n const relPath = path.relative(rootPath, file);\n\n if (lines > lmax) {\n results.push({ file: relPath, lines, status: 'VIOLATION' });\n violations++;\n console.log(chalk.red(`[VIOLATION] ${relPath}: ${lines} lines (Limit: ${lmax})`));\n } else if (lines > lmaxWarning) {\n results.push({ file: relPath, lines, status: 'WARNING' });\n warnings++;\n console.log(chalk.yellow(`[WARNING] ${relPath}: ${lines} lines (Threshold: ${lmaxWarning})`));\n }\n }\n\n if (violations === 0 && warnings === 0) {\n console.log(chalk.green(`✔ All ${files.length} files are within governance limits.`));\n } else {\n console.log('\\n' + chalk.bold('Summary:'));\n console.log(chalk.red(`Violations: ${violations}`));\n console.log(chalk.yellow(`Warnings: ${warnings}`));\n\n // --- GOVERNANCE INTERVENTION LOGIC ---\n const { getGovernanceConfig, setSoftLock, InterventionLevel } = await import('./governance.js');\n const { governance } = await getGovernanceConfig(rootPath);\n console.log(chalk.dim(`Intervention Level: ${InterventionLevel[governance.intervention_level] || 'UNKNOWN'} (${governance.intervention_level})`));\n\n if (violations > 0) {\n console.log(chalk.red.bold('\\nCRITICAL: Governance violations detected. Immediate refactoring required.'));\n\n // Check for SENTINEL MODE (Level 2)\n if (governance.intervention_level >= InterventionLevel.SENTINEL) {\n console.log(chalk.red.bold('🛑 SENTINEL MODE: Session SOFT_LOCKED until resolved.'));\n console.log(chalk.red(' Run \"rigstate override <id> --reason \\\\\"...\\\\\"\" if this is an emergency.'));\n await setSoftLock('Sentinel Mode: Governance Violations Detected', 'ARC-VIOLATION', rootPath);\n }\n }\n }\n\n // Sync to Cloud via API\n if (projectId) {\n try {\n const apiUrl = getApiUrl();\n const apiKey = getApiKey();\n\n const payloadViolations = results.filter(r => r.status === 'VIOLATION').map(v => ({\n uid: 'V-' + Buffer.from(v.file).toString('base64').replace(/=/g, ''),\n filePath: v.file,\n lineCount: v.lines,\n limitValue: lmax,\n severity: 'CRITICAL'\n }));\n\n await axios.post(`${apiUrl}/api/v1/guardian/sync`, {\n projectId,\n violations: payloadViolations,\n warnings: warnings\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n console.log(chalk.dim('✔ Violations synced to Rigstate Cloud.'));\n\n } catch (e: any) {\n console.log(chalk.dim('⚠ Cloud sync skipped: ' + (e.message || 'Unknown')));\n }\n }\n}\n","\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { createLoginCommand } from './commands/login.js';\nimport { createLinkCommand } from './commands/link.js';\nimport { createScanCommand } from './commands/scan.js';\nimport { createFixCommand } from './commands/fix.js';\nimport { createSyncCommand } from './commands/sync.js';\nimport { createInitCommand } from './commands/init.js';\nimport { createCheckCommand } from './commands/check.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.js';\nimport { createWorkCommand } from './commands/work.js';\nimport { createWatchCommand } from './commands/watch.js';\nimport { createFocusCommand } from './commands/focus.js';\nimport { createEnvPullCommand } from './commands/env.js';\nimport { createConfigCommand } from './commands/config.js';\nimport { createMcpCommand } from './commands/mcp.js';\nimport { createNexusCommand } from './commands/nexus.js';\nimport { createSyncRulesCommand } from './commands/sync-rules.js';\nimport { createOverrideCommand } from './commands/override.js';\nimport { checkVersion } from './utils/version.js';\nimport dotenv from 'dotenv';\n\n// Load environment variables\ndotenv.config();\n\nconst program = new Command();\n\nprogram\n .name('rigstate')\n .description('CLI for Rigstate - The AI-Native Dev Studio')\n .version('0.2.0');\n\n// Register commands\nprogram.addCommand(createLoginCommand());\nprogram.addCommand(createLinkCommand());\nprogram.addCommand(createScanCommand());\nprogram.addCommand(createFixCommand());\nprogram.addCommand(createSyncCommand());\nprogram.addCommand(createInitCommand());\nprogram.addCommand(createCheckCommand());\nprogram.addCommand(createHooksCommand());\nprogram.addCommand(createDaemonCommand());\nprogram.addCommand(createWorkCommand());\nprogram.addCommand(createWatchCommand());\nprogram.addCommand(createFocusCommand());\nprogram.addCommand(createEnvPullCommand());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createMcpCommand());\nprogram.addCommand(createNexusCommand());\nprogram.addCommand(createSyncRulesCommand());\nprogram.addCommand(createOverrideCommand());\n\nprogram.hook('preAction', async () => {\n await checkVersion();\n});\n\n// Add helpful examples\nprogram.on('--help', () => {\n console.log('');\n console.log(chalk.bold('Examples:'));\n console.log('');\n console.log(chalk.cyan(' $ rigstate login sk_rigstate_your_api_key'));\n console.log(chalk.dim(' Authenticate with your Rigstate API key'));\n console.log('');\n console.log(chalk.cyan(' $ rigstate scan'));\n console.log(chalk.dim(' Scan the current directory'));\n console.log('');\n console.log(chalk.cyan(' $ rigstate scan ./src --project abc123'));\n console.log(chalk.dim(' Scan a specific directory with project ID'));\n console.log('');\n console.log(chalk.cyan(' $ rigstate scan --json'));\n console.log(chalk.dim(' Output results in JSON format (useful for IDE extensions)'));\n console.log('');\n});\n\n// Parse arguments\nprogram.parse(process.argv);\n\n// Show help if no command provided\nif (!process.argv.slice(2).length) {\n program.outputHelp();\n}\n","/* eslint-disable no-console */\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { setApiKey } from '../utils/config.js';\n\nexport function createLoginCommand(): Command {\n return new Command('login')\n .description('Authenticate with your Rigstate API key')\n .argument('<api-key>', 'Your Rigstate API key (starts with sk_)')\n .action(async (apiKey: string) => {\n try {\n // Basic validation\n if (!apiKey || !apiKey.startsWith('sk_rigstate_')) {\n console.error(chalk.red('❌ Invalid API key format'));\n console.error(chalk.dim('API keys must start with \"sk_rigstate_\"'));\n process.exit(1);\n }\n\n // Store the API key\n setApiKey(apiKey);\n\n console.log(chalk.green('✅ Successfully logged in!'));\n console.log(\n chalk.dim(\n `\\nYour API key has been securely stored. You can now use \"rigstate scan\" to audit your code.`\n )\n );\n\n console.log(chalk.bold('\\n🤖 Cursor MCP Configuration'));\n console.log(chalk.dim('Copy and paste this into Cursor Settings -> Features -> MCP:'));\n console.log(chalk.cyan(`\n{\n \"mcpServers\": {\n \"rigstate\": {\n \"command\": \"npx\",\n \"args\": [\n \"-y\",\n \"@rigstate/mcp@latest\"\n ],\n \"env\": {\n \"RIGSTATE_API_KEY\": \"${apiKey}\"\n }\n }\n }\n}`));\n } catch (error) {\n console.error(\n chalk.red('❌ Login failed:'),\n error instanceof Error ? error.message : 'Unknown error'\n );\n process.exit(1);\n }\n });\n}\n","/* eslint-disable no-console */\nimport { Command } from 'commander';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\nimport os from 'os';\n\nexport function createLinkCommand() {\n return new Command('link')\n .description('Link current directory to a Rigstate project')\n .argument('<projectId>', 'Project ID to link')\n .action(async (projectId) => {\n // Check Global Override (Rigstate v2.7)\n try {\n const globalPath = path.join(os.homedir(), '.rigstate', 'config.json');\n const globalData = await fs.readFile(globalPath, 'utf-8').catch(() => null);\n if (globalData) {\n const config = JSON.parse(globalData);\n const cwd = process.cwd();\n if (config.overrides && config.overrides[cwd]) {\n const overrideId = config.overrides[cwd];\n if (overrideId !== projectId) {\n console.warn(chalk.yellow(`Global override detected. Enforcing project ID: ${overrideId}`));\n projectId = overrideId;\n }\n }\n }\n } catch (e) { }\n\n const manifestPath = path.join(process.cwd(), '.rigstate');\n\n const content = {\n project_id: projectId,\n api_url: process.env.NEXT_PUBLIC_APP_URL || 'http://localhost:3000',\n linked_at: new Date().toISOString()\n };\n\n try {\n await fs.writeFile(manifestPath, JSON.stringify(content, null, 2), 'utf-8');\n console.log(chalk.green(`✔ Linked to project ID: ${projectId}`));\n console.log(chalk.dim(`Created local context manifest at .rigstate`));\n\n // === SMART AUTOMATION ===\n console.log('');\n console.log(chalk.bold('🤖 Rigstate Automation Detected'));\n console.log('');\n\n const { getApiKey, getApiUrl } = await import('../utils/config.js');\n const apiKey = getApiKey(); // Might throw if not logged in\n const apiUrl = getApiUrl();\n\n if (apiKey) {\n // 1. Env Sync\n console.log(chalk.blue('🔐 Checking Vault for secrets...'));\n const { syncEnv } = await import('./env.js');\n await syncEnv(projectId, apiKey, apiUrl, true);\n\n // 2. Rules Sync\n console.log(chalk.blue('🧠 Syncing neural instructions...'));\n const { syncProjectRules } = await import('./sync-rules.js');\n await syncProjectRules(projectId, apiKey, apiUrl);\n\n // 3. Git Hooks\n console.log(chalk.blue('🛡️ Checking immunity system...'));\n await installHooks(process.cwd());\n }\n\n console.log('');\n console.log(chalk.bold.green('🚀 Link Complete! Your environment is ready.'));\n\n } catch (error: any) {\n if (error.message.includes('Not authenticated')) {\n console.warn(chalk.yellow('⚠️ Not authenticated. Run \"rigstate login\" to enable automation features.'));\n } else {\n console.error(chalk.red(`Failed to link project: ${error.message}`));\n }\n }\n });\n}\n\nasync function installHooks(cwd: string) {\n const fs = await import('fs/promises');\n const path = await import('path');\n\n // Check if git repo\n try {\n await fs.access(path.join(cwd, '.git'));\n } catch {\n console.log(chalk.dim(' (Not a git repository, skipping hooks)'));\n return;\n }\n\n const hooksDir = path.join(cwd, '.husky');\n\n // Check if simple husky setup exists or just do a manual pre-commit script\n // For now, let's look for a basic pre-commit file in .git/hooks if husky isn't there\n // Actually, let's just use the `hooks` command logic if possible, or a lightweight version\n\n try {\n const { installHooks: runInstall } = await import('./hooks.js');\n // We need to mock the command context or extract logic. \n // For simplicity/robustness in this iteration, let's just suggest it or verify\n\n // Simpler approach: Check if pre-commit exists\n const preCommitPath = path.join(cwd, '.git/hooks/pre-commit');\n try {\n await fs.access(preCommitPath);\n console.log(chalk.green(' ✔ Git hooks already active'));\n } catch {\n console.log(chalk.yellow(' ⚠️ Git hooks missing. Run \"rigstate hooks install\" to secure repo.'));\n }\n\n } catch (e) {\n // Ignore hook errors during link\n }\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport { glob } from 'glob';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { readGitignore, shouldIgnore, isCodeFile } from '../utils/files.js';\n\ninterface ScanResult {\n id: string;\n file_path: string;\n issues: Array<{\n type: string;\n severity: 'critical' | 'high' | 'medium' | 'low' | 'info';\n message: string;\n line?: number;\n }>;\n}\n\ninterface ApiResponse {\n results: ScanResult[];\n summary: {\n total_files: number;\n total_issues: number;\n by_severity: Record<string, number>;\n };\n}\n\nexport function createScanCommand(): Command {\n return new Command('scan')\n .description('Scan code files for security and quality issues')\n .argument('[path]', 'Directory or file to scan', '.')\n .option('--json', 'Output results as JSON')\n .option('--project <id>', 'Project ID to associate with this scan')\n .action(async (targetPath: string, options: { json?: boolean; project?: string }) => {\n const spinner = ora();\n\n try {\n // Get API credentials\n const apiKey = getApiKey();\n const apiUrl = getApiUrl();\n const projectId = options.project || getProjectId();\n\n if (!projectId) {\n console.warn(\n chalk.yellow(\n '⚠️ No project ID specified. Use --project <id> or set a default.'\n )\n );\n }\n\n // Resolve target path\n const scanPath = path.resolve(process.cwd(), targetPath);\n\n spinner.start(`Scanning ${chalk.cyan(scanPath)}...`);\n\n // Read .gitignore patterns\n const gitignorePatterns = await readGitignore(scanPath);\n\n // Find all code files\n const pattern = path.join(scanPath, '**/*');\n const allFiles = await glob(pattern, {\n nodir: true,\n dot: false,\n ignore: ['**/node_modules/**', '**/.git/**', '**/dist/**', '**/build/**'],\n });\n\n // Filter files\n const codeFiles = allFiles.filter((file) => {\n const relativePath = path.relative(scanPath, file);\n return isCodeFile(file) && !shouldIgnore(relativePath, gitignorePatterns);\n });\n\n if (codeFiles.length === 0) {\n spinner.warn(chalk.yellow('No code files found to scan.'));\n return;\n }\n\n spinner.text = `Found ${codeFiles.length} files. Scanning...`;\n\n // Scan each file individually\n const results: ScanResult[] = [];\n let totalIssues = 0;\n const severityCounts: Record<string, number> = {};\n\n for (let i = 0; i < codeFiles.length; i++) {\n const filePath = codeFiles[i];\n const relativePath = path.relative(scanPath, filePath);\n\n spinner.text = `Scanning ${i + 1}/${codeFiles.length}: ${relativePath}`;\n\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n\n // Call the API for this file\n const response = await axios.post(\n `${apiUrl}/api/v1/audit`,\n {\n content,\n file_path: relativePath,\n project_id: projectId,\n },\n {\n headers: {\n 'Authorization': `Bearer ${apiKey}`,\n 'Content-Type': 'application/json',\n },\n timeout: 60000, // 1 minute per file\n }\n );\n\n // Aggregate results\n const vulnerabilities = response.data.vulnerabilities || [];\n if (vulnerabilities.length > 0) {\n results.push({\n id: response.data.id || relativePath,\n file_path: relativePath,\n issues: vulnerabilities.map((v: any) => ({\n type: v.type,\n severity: v.severity,\n message: v.description || v.title,\n line: v.line_number,\n })),\n });\n\n totalIssues += vulnerabilities.length;\n\n vulnerabilities.forEach((v: any) => {\n severityCounts[v.severity] = (severityCounts[v.severity] || 0) + 1;\n });\n }\n } catch (fileError) {\n if (axios.isAxiosError(fileError)) {\n console.warn(chalk.yellow(`\\n⚠️ Skipping ${relativePath}: ${fileError.message}`));\n } else {\n console.warn(chalk.yellow(`\\n⚠️ Error reading ${relativePath}`));\n }\n }\n }\n\n spinner.succeed(chalk.green('✅ Scan completed!'));\n\n // Build aggregated response\n const aggregatedResponse: ApiResponse = {\n results,\n summary: {\n total_files: codeFiles.length,\n total_issues: totalIssues,\n by_severity: severityCounts,\n },\n };\n\n // Output results\n if (options.json) {\n console.log(JSON.stringify(aggregatedResponse, null, 2));\n } else {\n printPrettyResults(aggregatedResponse);\n }\n } catch (error) {\n spinner.fail(chalk.red('❌ Scan failed'));\n\n if (axios.isAxiosError(error)) {\n if (error.response) {\n console.error(chalk.red('API Error:'), error.response.data);\n } else if (error.request) {\n console.error(\n chalk.red('Network Error:'),\n 'Could not reach the API. Is the server running?'\n );\n } else {\n console.error(chalk.red('Error:'), error.message);\n }\n } else {\n console.error(\n chalk.red('Error:'),\n error instanceof Error ? error.message : 'Unknown error'\n );\n }\n\n process.exit(1);\n }\n });\n}\n\nfunction printPrettyResults(data: ApiResponse): void {\n const { results, summary } = data;\n\n console.log('\\n' + chalk.bold('📊 Scan Summary'));\n console.log(chalk.dim('─'.repeat(60)));\n console.log(`Total Files Scanned: ${chalk.cyan(summary.total_files)}`);\n console.log(`Total Issues Found: ${chalk.yellow(summary.total_issues)}`);\n\n if (summary.by_severity) {\n console.log('\\nIssues by Severity:');\n Object.entries(summary.by_severity).forEach(([severity, count]) => {\n const color = getSeverityColor(severity as any);\n console.log(` ${color(`${severity}:`)} ${count}`);\n });\n }\n\n if (results && results.length > 0) {\n console.log('\\n' + chalk.bold('🔍 Detailed Results'));\n console.log(chalk.dim('─'.repeat(60)));\n\n results.forEach((result) => {\n if (result.issues && result.issues.length > 0) {\n console.log(`\\n${chalk.bold(result.file_path)}`);\n\n result.issues.forEach((issue) => {\n const severityColor = getSeverityColor(issue.severity);\n const lineInfo = issue.line ? chalk.dim(`:${issue.line}`) : '';\n\n console.log(\n ` ${severityColor(`[${issue.severity.toUpperCase()}]`)} ${issue.type}${lineInfo}`\n );\n console.log(` ${chalk.dim(issue.message)}`);\n });\n }\n });\n }\n\n console.log('\\n' + chalk.dim('─'.repeat(60)));\n}\n\nfunction getSeverityColor(severity: string): (str: string) => string {\n switch (severity.toLowerCase()) {\n case 'critical':\n return chalk.red.bold;\n case 'high':\n return chalk.red;\n case 'medium':\n return chalk.yellow;\n case 'low':\n return chalk.blue;\n case 'info':\n return chalk.gray;\n default:\n return chalk.white;\n }\n}\n","import fs from 'fs/promises';\nimport path from 'path';\n\n/**\n * Read and parse .gitignore file\n */\nexport async function readGitignore(dir: string): Promise<string[]> {\n const gitignorePath = path.join(dir, '.gitignore');\n try {\n const content = await fs.readFile(gitignorePath, 'utf-8');\n return content\n .split('\\n')\n .map((line) => line.trim())\n .filter((line) => line && !line.startsWith('#'));\n } catch (error) {\n // No .gitignore file found, return empty array\n return [];\n }\n}\n\n/**\n * Check if a path should be ignored based on .gitignore patterns\n */\nexport function shouldIgnore(filePath: string, patterns: string[]): boolean {\n const relativePath = filePath.replace(/^\\.\\//, '');\n\n // Default ignore patterns\n const defaultIgnores = [\n 'node_modules',\n '.git',\n 'dist',\n 'build',\n '.next',\n '.turbo',\n 'coverage',\n '.env',\n '.env.local',\n ];\n\n const allPatterns = [...defaultIgnores, ...patterns];\n\n for (const pattern of allPatterns) {\n if (pattern.endsWith('/')) {\n // Directory pattern\n const dir = pattern.slice(0, -1);\n if (relativePath.includes(`${dir}/`) || relativePath === dir) {\n return true;\n }\n } else if (pattern.includes('*')) {\n // Glob pattern - simple implementation\n const regex = new RegExp(\n '^' + pattern.replace(/\\*/g, '.*').replace(/\\?/g, '.') + '$'\n );\n if (regex.test(relativePath)) {\n return true;\n }\n } else {\n // Exact match or contains\n if (relativePath.includes(pattern)) {\n return true;\n }\n }\n }\n\n return false;\n}\n\n/**\n * Check if file is a code file based on extension\n */\nexport function isCodeFile(filePath: string): boolean {\n const codeExtensions = [\n '.js',\n '.jsx',\n '.ts',\n '.tsx',\n '.py',\n '.java',\n '.go',\n '.rb',\n '.php',\n '.c',\n '.cpp',\n '.h',\n '.cs',\n '.swift',\n '.kt',\n '.rs',\n '.vue',\n '.svelte',\n ];\n\n const ext = path.extname(filePath).toLowerCase();\n return codeExtensions.includes(ext);\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport { glob } from 'glob';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport inquirer from 'inquirer';\nimport * as Diff from 'diff';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { readGitignore, shouldIgnore, isCodeFile } from '../utils/files.js';\n\nexport function createFixCommand(): Command {\n return new Command('fix')\n .description('Scan and interactively FIX detected issues using Rigstate AI')\n .argument('[path]', 'Directory or file to scan', '.')\n .option('--project <id>', 'Project ID to context-aware audit')\n .action(async (targetPath: string, options: { project?: string }) => {\n const spinner = ora();\n\n try {\n const apiKey = getApiKey();\n const apiUrl = getApiUrl();\n const projectId = options.project || getProjectId();\n\n if (!projectId) {\n console.log(chalk.yellow('⚠️ Project ID is required for fixing. Using default or pass --project <id>'));\n // We can proceed without it, but fix quality drops. Let's warn.\n }\n\n const scanPath = path.resolve(process.cwd(), targetPath);\n\n // --- Reuse Scan Logic (Simplified) ---\n const gitignorePatterns = await readGitignore(scanPath);\n const pattern = path.join(scanPath, '**/*');\n const allFiles = await glob(pattern, { nodir: true, dot: false, ignore: ['**/node_modules/**', '**/.git/**'] });\n const codeFiles = allFiles.filter(file => {\n const relativePath = path.relative(scanPath, file);\n return isCodeFile(file) && !shouldIgnore(relativePath, gitignorePatterns);\n });\n\n if (codeFiles.length === 0) {\n console.log(chalk.yellow('No code files found.'));\n return;\n }\n\n console.log(chalk.bold(`\\n🧠 Rigstate Fix Mode`));\n console.log(chalk.dim(`Scanning ${codeFiles.length} files with Project Context...\\n`));\n\n let fixedCount = 0;\n\n for (let i = 0; i < codeFiles.length; i++) {\n const filePath = codeFiles[i];\n const relativePath = path.relative(scanPath, filePath);\n\n spinner.start(`Analyzing ${relativePath}...`);\n\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n const response = await axios.post(\n `${apiUrl}/api/v1/audit`,\n { content, file_path: relativePath, project_id: projectId },\n { headers: { 'Authorization': `Bearer ${apiKey}` }, timeout: 120000 }\n );\n\n const vulnerabilities = response.data.vulnerabilities || [];\n const fixableIssues = vulnerabilities.filter((v: any) => v.fixed_content);\n\n if (fixableIssues.length > 0) {\n spinner.stop();\n console.log(`\\n${chalk.bold(relativePath)}: Found ${fixableIssues.length} fixable issues.`);\n\n for (const issue of fixableIssues) {\n console.log(chalk.red(`\\n[${issue.type}] ${issue.title}`));\n console.log(chalk.dim(issue.suggestion || issue.message));\n\n // Show Diff\n const diff = Diff.createTwoFilesPatch(relativePath, relativePath, content, issue.fixed_content, 'Current', 'Fixed');\n console.log('\\n' + diff.split('\\n').slice(0, 15).join('\\n') + (diff.split('\\n').length > 15 ? '\\n...' : ''));\n\n const { apply } = await inquirer.prompt([{\n type: 'confirm',\n name: 'apply',\n message: `Apply this fix to ${chalk.cyan(relativePath)}?`,\n default: true\n }]);\n\n if (apply) {\n await fs.writeFile(filePath, issue.fixed_content);\n console.log(chalk.green(`✅ Fixed applied!`));\n fixedCount++;\n\n if (issue.related_step_id) {\n const { completeStep } = await inquirer.prompt([{\n type: 'confirm',\n name: 'completeStep',\n message: `Frank thinks this fix completes a Roadmap Step. Mark as COMPLETED in Rigstate?`,\n default: true\n }]);\n\n if (completeStep) {\n try {\n await axios.post(\n `${apiUrl}/api/v1/roadmap/update-status`,\n { step_id: issue.related_step_id, status: 'COMPLETED', project_id: projectId },\n { headers: { 'Authorization': `Bearer ${apiKey}` } }\n );\n console.log(chalk.green(`🚀 Roadmap updated! Mission Control is in sync.`));\n } catch (err: any) {\n console.error(chalk.yellow(`Failed to update roadmap: ${err.message}`));\n }\n }\n }\n\n // Stop processing this file as content changed\n break;\n } else {\n console.log(chalk.dim('Skipped.'));\n }\n }\n } else {\n spinner.text = `Checked ${relativePath} (No auto-fixes)`;\n }\n\n } catch (e: any) {\n // silent fail for file read/network errors in fix mode to keep flow\n }\n }\n\n spinner.stop();\n console.log(chalk.bold.green(`\\n\\n🚀 Fix session complete!`));\n console.log(`Frank fixed ${fixedCount} detected issues.`);\n console.log(chalk.dim(`Run 'rigstate scan' to verify remaining issues.`));\n\n } catch (error: any) {\n spinner.fail('Fix session failed');\n console.error(error.message);\n }\n });\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { getApiKey, getProjectId, getApiUrl, setProjectId } from '../utils/config.js';\nimport axios from 'axios';\nimport fs from 'fs/promises';\nimport path from 'path';\n\nexport function createSyncCommand() {\n const sync = new Command('sync');\n\n sync\n .description('Synchronize local state with Rigstate Cloud')\n .option('-p, --project <id>', 'Specify Project ID (saves to config automatically)')\n .action(async (options) => {\n const spinner = ora('Synchronizing project state...').start();\n\n try {\n // 1. Authentication Check\n let apiKey;\n try {\n apiKey = getApiKey();\n } catch (e) {\n spinner.fail('Not authenticated. Run \"rigstate login\" first.');\n return;\n }\n\n // 2. Project Context Resolution\n let projectId = options.project;\n\n // Check local .rigstate manifest\n if (!projectId) {\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const manifestContent = await fs.readFile(manifestPath, 'utf-8');\n const manifest = JSON.parse(manifestContent);\n if (manifest.project_id) projectId = manifest.project_id;\n } catch (e) { }\n }\n\n // Check global config\n if (!projectId) projectId = getProjectId();\n\n if (options.project) {\n // Persistence: Save project ID for future use\n setProjectId(options.project);\n }\n\n if (!projectId) {\n spinner.fail('No project context found.\\n Run with --project <id> once to save context.');\n return;\n }\n\n const apiUrl = getApiUrl();\n\n // 3. API Execution\n const response = await axios.get(`${apiUrl}/api/v1/roadmap`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n // Parse Standardized Response ({ success, data, ... })\n if (!response.data.success) {\n throw new Error(response.data.error || 'Unknown API failure');\n }\n\n const { roadmap, project } = response.data.data;\n const timestamp = response.data.timestamp;\n\n // 4. Write Artifacts\n const targetPath = path.join(process.cwd(), 'roadmap.json');\n const fileContent = JSON.stringify({\n project,\n last_synced: timestamp,\n roadmap\n }, null, 2);\n\n await fs.writeFile(targetPath, fileContent, 'utf-8');\n\n // 4b. Write Context Manifest (.rigstate) - CONTEXT GUARD\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const manifestContent = {\n project_id: projectId,\n project_name: project,\n last_synced: timestamp,\n api_url: apiUrl\n };\n await fs.writeFile(manifestPath, JSON.stringify(manifestContent, null, 2), 'utf-8');\n } catch (e) {\n // Fail silently\n }\n\n // 4c. Provision Agent Skills (Skills Dominion)\n console.log(chalk.bold('\\n🧠 Agent Skills Provisioning...'));\n try {\n const { provisionSkills, generateSkillsDiscoveryBlock } = await import('../utils/skills-provisioner.js');\n const skills = await provisionSkills(apiUrl, apiKey, projectId, process.cwd());\n\n // Update .cursorrules with skills discovery block (if file exists)\n const cursorRulesPath = path.join(process.cwd(), '.cursorrules');\n try {\n let rulesContent = await fs.readFile(cursorRulesPath, 'utf-8');\n const skillsBlock = generateSkillsDiscoveryBlock(skills);\n\n // Replace existing skills block or insert after PROJECT CONTEXT\n if (rulesContent.includes('<available_skills>')) {\n rulesContent = rulesContent.replace(\n /<available_skills>[\\s\\S]*?<\\/available_skills>/,\n skillsBlock\n );\n } else if (rulesContent.includes('## 🧠 PROJECT CONTEXT')) {\n // Insert after PROJECT CONTEXT section\n const insertPoint = rulesContent.indexOf('---', rulesContent.indexOf('## 🧠 PROJECT CONTEXT'));\n if (insertPoint !== -1) {\n rulesContent = rulesContent.slice(0, insertPoint + 3) +\n '\\n\\n' + skillsBlock + '\\n' +\n rulesContent.slice(insertPoint + 3);\n }\n }\n\n await fs.writeFile(cursorRulesPath, rulesContent, 'utf-8');\n console.log(chalk.dim(` Updated .cursorrules with skills discovery block`));\n } catch (e) {\n // .cursorrules doesn't exist or couldn't be updated\n }\n } catch (e: any) {\n console.log(chalk.yellow(` ⚠ Skills provisioning skipped: ${e.message}`));\n }\n\n // 5. Process Execution Logs (MISSION REPORTING)\n try {\n const logPath = path.join(process.cwd(), '.rigstate', 'logs', 'last_execution.json');\n try {\n const logContent = await fs.readFile(logPath, 'utf-8');\n const logData = JSON.parse(logContent);\n\n if (logData.task_summary) {\n await axios.post(`${apiUrl}/api/v1/execution-logs`, {\n project_id: projectId,\n ...logData,\n agent_role: process.env.RIGSTATE_MODE === 'SUPERVISOR' ? 'SUPERVISOR' : 'WORKER'\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n await fs.unlink(logPath);\n console.log(chalk.dim(`✔ Mission Report uploaded.`));\n }\n } catch (e: any) {\n // Ignore ENOENT (file not found), log errors if API fails\n if (e.code !== 'ENOENT') {\n // console.log(chalk.yellow('Log upload skipped: ' + e.message));\n }\n }\n } catch (e) { }\n\n // 6. User Feedback\n spinner.succeed(chalk.green(`Synced ${roadmap.length} roadmap steps for project \"${project}\"`));\n console.log(chalk.dim(`Local files updated: roadmap.json`));\n\n const { runGuardianWatchdog } = await import('../utils/watchdog.js');\n const settings = response.data.data.settings || {};\n await runGuardianWatchdog(process.cwd(), settings, projectId);\n\n // 8. Bridge Heartbeat & Pending Tasks\n console.log(chalk.bold('\\n📡 Agent Bridge Heartbeat...'));\n try {\n const bridgeResponse = await axios.get(`${apiUrl}/api/v1/agent/bridge`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (bridgeResponse.data.success) {\n const tasks = bridgeResponse.data.tasks;\n const pending = tasks.filter((t: any) => t.status === 'PENDING');\n const approved = tasks.filter((t: any) => t.status === 'APPROVED');\n\n if (pending.length > 0 || approved.length > 0) {\n console.log(chalk.yellow(`⚠ Bridge Alert: ${pending.length} pending, ${approved.length} approved tasks found.`));\n console.log(chalk.dim('Run \"rigstate fix\" to process these tasks or ensure your IDE MCP server is active.'));\n } else {\n console.log(chalk.green('✔ Heartbeat healthy. No pending bridge tasks.'));\n }\n\n // Acknowledge Pings if any\n const pings = pending.filter((t: any) => t.proposal?.startsWith('ping'));\n for (const ping of pings) {\n await axios.post(`${apiUrl}/api/v1/agent/bridge`, {\n bridge_id: ping.id,\n status: 'COMPLETED',\n summary: 'Pong! CLI Sync Heartbeat confirmed.'\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n console.log(chalk.cyan(`🏓 Pong! Acknowledged heartbeat signal [${ping.id}]`));\n }\n }\n } catch (e: any) {\n console.log(chalk.yellow(`⚠ Could not verify Bridge status: ${e.message}`));\n }\n\n if (options.project) {\n console.log(chalk.blue(`Project context saved. Future commands will use this project.`));\n }\n\n // 9. Migration Guard (The Firewall)\n try {\n const migrationDir = path.join(process.cwd(), 'supabase', 'migrations');\n const files = await fs.readdir(migrationDir);\n const sqlFiles = files.filter(f => f.endsWith('.sql')).sort();\n\n if (sqlFiles.length > 0) {\n const latestMigration = sqlFiles[sqlFiles.length - 1];\n console.log(chalk.dim(`\\n🛡 Migration Guard:`));\n console.log(chalk.dim(` Latest Local: ${latestMigration}`));\n console.log(chalk.yellow(` ⚠ Ensure DB schema matches this version. CLI cannot verify Remote RLS policies directly.`));\n }\n } catch (e) {\n // No migrations folder, or error reading - ignore\n }\n\n // 10. Sovereign Foundation (Vault Sync)\n try {\n const vaultResponse = await axios.post(`${apiUrl}/api/v1/vault/sync`,\n { project_id: projectId },\n { headers: { Authorization: `Bearer ${apiKey}` } }\n );\n\n if (vaultResponse.data.success) {\n const vaultContent: string = vaultResponse.data.data.content || '';\n const localEnvPath = path.join(process.cwd(), '.env.local');\n let localContent = '';\n\n try {\n localContent = await fs.readFile(localEnvPath, 'utf-8');\n } catch (e) { /* File doesn't exist */ }\n\n // Normalize for comparison (trim, ignore comments?) - Simple trim for now\n if (vaultContent.trim() !== localContent.trim()) {\n console.log(chalk.bold('\\n🔐 Sovereign Foundation (Vault):'));\n console.log(chalk.yellow(' Status: Drift Detected / Update Available'));\n\n const { syncVault } = await import('inquirer').then(m => m.default.prompt([{\n type: 'confirm',\n name: 'syncVault',\n message: 'Synchronize local .env.local with Vault secrets?',\n default: false\n }]));\n\n if (syncVault) {\n await fs.writeFile(localEnvPath, vaultContent, 'utf-8');\n console.log(chalk.green(' ✅ .env.local synchronized with Vault.'));\n } else {\n console.log(chalk.dim(' Skipped vault sync.'));\n }\n } else {\n console.log(chalk.dim('\\n🔐 Sovereign Foundation: Synced.'));\n }\n }\n } catch (e: any) {\n // Fail silently or warn if vault access denied (expected for some users)\n // console.log(chalk.dim(` (Vault check skipped: ${e.message})`));\n }\n\n // 11. System Integrity Checks (The Firewall)\n console.log(chalk.dim('\\n🛡️ System Integrity Check...'));\n await checkSystemIntegrity(apiUrl, apiKey, projectId);\n\n } catch (error: any) {\n if (axios.isAxiosError(error)) {\n const message = error.response?.data?.error || error.message;\n spinner.fail(chalk.red(`Sync failed: ${message}`));\n } else {\n spinner.fail(chalk.red('Sync failed: ' + (error.message || 'Unknown error')));\n }\n }\n });\n\n return sync;\n}\n\n/**\n * System Integrity Checks\n * Verifies Migration Sync and RLS Status via API\n */\nasync function checkSystemIntegrity(apiUrl: string, apiKey: string, projectId: string) {\n try {\n // Call System Integrity API\n const response = await axios.get(`${apiUrl}/api/v1/system/integrity`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (response.data.success) {\n const { migrations, rls, guardian_violations } = response.data.data;\n\n // Migration Status\n if (migrations) {\n if (migrations.in_sync) {\n console.log(chalk.green(` ✅ Migrations synced (${migrations.count} versions)`));\n } else {\n console.log(chalk.red(` 🛑 CRITICAL: DB Schema out of sync! ${migrations.missing?.length || 0} migrations not applied.`));\n if (migrations.missing?.length > 0) {\n console.log(chalk.dim(` Missing: ${migrations.missing.slice(0, 3).join(', ')}${migrations.missing.length > 3 ? '...' : ''}`));\n }\n console.log(chalk.yellow(` Run 'supabase db push' or apply migrations immediately.`));\n }\n }\n\n // RLS Status\n if (rls) {\n if (rls.all_secured) {\n console.log(chalk.green(` ✅ RLS Audit Passed (${rls.table_count} tables secured)`));\n } else {\n console.log(chalk.red(` 🛑 CRITICAL: Security Vulnerability! ${rls.unsecured?.length || 0} tables have RLS disabled.`));\n rls.unsecured?.forEach((table: string) => {\n console.log(chalk.red(` - ${table}`));\n });\n console.log(chalk.yellow(' Enable RLS immediately: ALTER TABLE \"table\" ENABLE ROW LEVEL SECURITY;'));\n }\n }\n\n // Guardian Violations\n if (guardian_violations) {\n if (guardian_violations.count === 0) {\n console.log(chalk.green(' ✅ Guardian: No active violations'));\n } else {\n console.log(chalk.yellow(` ⚠️ Guardian: ${guardian_violations.count} active violations`));\n console.log(chalk.dim(' Run \"rigstate check\" for details.'));\n }\n }\n }\n } catch (e: any) {\n // API might not have this endpoint yet - fail silently\n console.log(chalk.dim(' (System integrity check skipped - API endpoint not available)'));\n }\n}\n\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport ora from 'ora';\nimport { execSync } from 'child_process';\nimport { loadManifest } from '../utils/manifest.js';\nimport { getApiUrl, getApiKey, setProjectId } from '../utils/config.js';\nimport axios from 'axios';\n\nexport function createInitCommand() {\n return new Command('init')\n .description('Initialize or link a Rigstate project (interactive mode available)')\n .argument('[project-id]', 'ID of the project to link (optional, prompts if not provided)')\n .option('-f, --force', 'Overwrite existing .cursorrules file')\n .option('--rules-only', 'Only regenerate .cursorrules without interactive setup')\n .action(async (projectIdArg, options) => {\n const spinner = ora('Initializing Rigstate project...').start();\n\n let apiKey: string;\n try {\n apiKey = getApiKey();\n } catch (e) {\n spinner.fail(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n let projectId = projectIdArg;\n\n try {\n // If --rules-only, just regenerate rules from existing manifest\n if (options.rulesOnly) {\n const manifest = await loadManifest();\n if (!manifest) {\n spinner.fail('No .rigstate manifest found. Run \"rigstate init\" first.');\n return;\n }\n projectId = manifest.project_id;\n await generateRules(apiUrl, apiKey, projectId, options.force, spinner);\n return;\n }\n\n // Interactive mode if no project ID provided\n if (!projectId) {\n spinner.stop();\n\n // Dynamic import for inquirer\n const inquirer = (await import('inquirer')).default;\n\n spinner.start('Fetching your projects...');\n\n // Fetch projects via API\n let projects: any[] = [];\n try {\n const projectsResponse = await axios.get(`${apiUrl}/api/v1/projects`, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n if (projectsResponse.data.success) {\n projects = projectsResponse.data.data.projects || [];\n }\n } catch (e: any) {\n // API might not exist yet - fallback to manual entry\n spinner.info('Projects API not available. Using manual entry mode.');\n }\n\n spinner.stop();\n\n if (projects.length === 0) {\n // Fallback: Ask for project ID manually\n const { manualProjectId } = await inquirer.prompt([\n {\n type: 'input',\n name: 'manualProjectId',\n message: 'Enter Project ID (from Rigstate dashboard):',\n validate: (input: string) => input.trim() ? true : 'Project ID is required'\n }\n ]);\n projectId = manualProjectId;\n } else {\n // Build choices from fetched projects\n const choices: any[] = [\n { name: '➕ Create New Project', value: 'NEW' },\n new inquirer.Separator()\n ];\n\n projects.forEach((p: any) => {\n choices.push({\n name: `[${p.organization_name || 'Personal'}] ${p.name} (${p.status})`,\n value: p.id\n });\n });\n\n const { selectedId } = await inquirer.prompt([\n {\n type: 'list',\n name: 'selectedId',\n message: 'Select a project to link:',\n choices: choices,\n pageSize: 15\n }\n ]);\n\n if (selectedId === 'NEW') {\n // Create new project flow\n const { newName } = await inquirer.prompt([\n {\n type: 'input',\n name: 'newName',\n message: 'Enter project name:',\n validate: (input: string) => input.trim() ? true : 'Name is required'\n }\n ]);\n\n // Fetch organizations (with fallback)\n spinner.start('Fetching organizations...');\n let orgs: any[] = [];\n try {\n const orgsResponse = await axios.get(`${apiUrl}/api/v1/organizations`, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n orgs = orgsResponse.data.data?.organizations || [];\n } catch (e) {\n // API might not exist - skip org selection\n }\n spinner.stop();\n\n let selectedOrgId = orgs[0]?.id;\n\n if (orgs.length > 1) {\n const { orgId } = await inquirer.prompt([\n {\n type: 'list',\n name: 'orgId',\n message: 'Which organization does this belong to?',\n choices: orgs.map((org: any) => ({\n name: `${org.name} (${org.role || 'member'})`,\n value: org.id\n }))\n }\n ]);\n selectedOrgId = orgId;\n }\n\n if (!selectedOrgId) {\n console.log(chalk.yellow('No organization available. Please create the project via the Rigstate dashboard.'));\n return;\n }\n\n // Create project via API\n spinner.start('Creating new project...');\n try {\n const createResponse = await axios.post(`${apiUrl}/api/v1/projects`, {\n name: newName,\n organization_id: selectedOrgId\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!createResponse.data.success) {\n spinner.fail(chalk.red('Failed to create project: ' + createResponse.data.error));\n return;\n }\n\n projectId = createResponse.data.data.project.id;\n spinner.succeed(chalk.green(`Created new project: ${newName}`));\n } catch (e: any) {\n spinner.fail(chalk.red('Project creation API not available. Please create via dashboard.'));\n return;\n }\n } else {\n projectId = selectedId;\n }\n }\n\n spinner.start(`Linking to project ID: ${projectId}...`);\n }\n\n // Core link logic\n // Save project ID to config\n setProjectId(projectId);\n\n // Write local manifest\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const manifestContent = {\n project_id: projectId,\n last_linked: new Date().toISOString(),\n api_url: apiUrl\n };\n await fs.writeFile(manifestPath, JSON.stringify(manifestContent, null, 2), 'utf-8');\n\n // Initialize git if needed\n try {\n await fs.access('.git');\n } catch {\n spinner.text = 'Initializing git repository...';\n execSync('git init', { stdio: 'ignore' });\n }\n\n spinner.succeed(chalk.green(`✅ Linked to project: ${projectId}`));\n\n // Generate rules\n await generateRules(apiUrl, apiKey, projectId, options.force, spinner);\n\n console.log('');\n console.log(chalk.blue('Next steps:'));\n console.log(chalk.dim(' rigstate sync - Sync roadmap and context'));\n console.log(chalk.dim(' rigstate watch - Start development loop'));\n console.log(chalk.dim(' rigstate focus - Get current task'));\n\n } catch (e: any) {\n spinner.fail(chalk.red('Initialization failed: ' + e.message));\n }\n });\n}\n\nasync function generateRules(apiUrl: string, apiKey: string, projectId: string, force: boolean, spinner: any) {\n spinner.start('Generating AI rules (MDC + AGENTS.md)...');\n\n try {\n const response = await axios.post(`${apiUrl}/api/v1/rules/generate`, {\n project_id: projectId\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (response.data.success || response.data.files) {\n const files = response.data.files || [];\n\n if (files.length === 0 && response.data.rules) {\n // Fallback to legacy mono-file if no multiple files returned\n const rulesPath = path.join(process.cwd(), '.cursorrules');\n await fs.writeFile(rulesPath, response.data.rules, 'utf-8');\n spinner.succeed(chalk.green('✔ Generated .cursorrules (legacy mode)'));\n return;\n }\n\n for (const file of files) {\n const targetPath = path.join(process.cwd(), file.path);\n const targetDir = path.dirname(targetPath);\n\n // Ensure directory exists\n await fs.mkdir(targetDir, { recursive: true });\n\n // Check if exists and force\n try {\n await fs.access(targetPath);\n if (!force && !file.path.startsWith('.cursor/rules/')) {\n console.log(chalk.dim(` ${file.path} already exists. Skipping.`));\n continue;\n }\n } catch {\n // File doesn't exist, proceed\n }\n\n await fs.writeFile(targetPath, file.content, 'utf-8');\n }\n\n // Cleanup legacy .cursorrules if we have new files and aren't inhibited\n if (files.length > 0) {\n const legacyPath = path.join(process.cwd(), '.cursorrules');\n try {\n const stats = await fs.stat(legacyPath);\n if (stats.isFile()) {\n await fs.rename(legacyPath, `${legacyPath}.bak`);\n console.log(chalk.dim(' Moved legacy .cursorrules to .cursorrules.bak'));\n }\n } catch (e) {\n // Ignore if legacy file doesn't exist\n }\n }\n\n spinner.succeed(chalk.green(`✔ Generated ${files.length} rule files (v${response.data.version || '3.0'})`));\n } else {\n spinner.info(chalk.dim(' Rules generation skipped (API response invalid)'));\n }\n } catch (e: any) {\n spinner.info(chalk.dim(` Rules generation failed: ${e.message}`));\n }\n}\n\n\n","import fs from 'fs/promises';\nimport path from 'path';\n\nexport interface RigstateManifest {\n project_id: string;\n api_url?: string;\n linked_at?: string;\n}\n\nexport async function loadManifest(): Promise<RigstateManifest | null> {\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const content = await fs.readFile(manifestPath, 'utf-8');\n return JSON.parse(content);\n } catch {\n return null;\n }\n}\n","/**\n * rigstate check - Validate code against Guardian rules\n * \n * Usage:\n * rigstate check # Check current directory\n * rigstate check ./src # Check specific path\n * rigstate check --strict # Exit 1 on any violation\n * rigstate check --strict=critical # Exit 1 only on critical\n * rigstate check --staged # Only check staged files (for pre-commit)\n * rigstate check --json # Output as JSON\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport { glob } from 'glob';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { execSync } from 'child_process';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { loadManifest } from '../utils/manifest.js';\nimport {\n checkFile,\n formatViolations,\n summarizeResults,\n type EffectiveRule,\n type CheckResult,\n type Violation\n} from '../utils/rule-engine.js';\n\n// Cache settings\nconst CACHE_FILE = '.rigstate/rules-cache.json';\nconst CACHE_TTL_MS = 5 * 60 * 1000; // 5 minutes\nconst CACHE_MAX_AGE_MS = 24 * 60 * 60 * 1000; // 24 hours (offline limit)\n\ninterface CachedRules {\n timestamp: string;\n projectId: string;\n rules: EffectiveRule[];\n settings: { lmax: number; lmax_warning: number };\n}\n\nexport function createCheckCommand(): Command {\n return new Command('check')\n .description('Validate code against Guardian architectural rules')\n .argument('[path]', 'Directory or file to check', '.')\n .option('--project <id>', 'Project ID (or use .rigstate manifest)')\n .option('--strict [level]', 'Exit 1 on violations. Level: \"all\" (default) or \"critical\"')\n .option('--staged', 'Only check git staged files (for pre-commit hooks)')\n .option('--json', 'Output results as JSON')\n .option('--no-cache', 'Skip rule cache and fetch fresh from API')\n .action(async (targetPath: string, options: {\n project?: string;\n strict?: boolean | string;\n staged?: boolean;\n json?: boolean;\n cache?: boolean;\n }) => {\n const spinner = ora();\n\n try {\n // 1. Resolve project context\n let projectId = options.project;\n let apiUrl = getApiUrl();\n\n if (!projectId) {\n const manifest = await loadManifest();\n if (manifest) {\n projectId = manifest.project_id;\n if (manifest.api_url) apiUrl = manifest.api_url;\n }\n }\n\n if (!projectId) {\n projectId = getProjectId();\n }\n\n if (!projectId) {\n console.log(chalk.red('❌ No project context found.'));\n console.log(chalk.dim(' Run \"rigstate link\" or pass --project <id>'));\n process.exit(2);\n }\n\n // 2. Get API key\n let apiKey: string;\n try {\n apiKey = getApiKey();\n } catch {\n console.log(chalk.red('❌ Not authenticated. Run \"rigstate login\" first.'));\n process.exit(2);\n }\n\n // 3. Fetch rules (with caching)\n spinner.start('Fetching Guardian rules...');\n let rules: EffectiveRule[];\n let settings: { lmax: number; lmax_warning: number };\n\n try {\n const cached = options.cache !== false ? await loadCachedRules(projectId) : null;\n\n if (cached && !isStale(cached.timestamp, CACHE_TTL_MS)) {\n rules = cached.rules;\n settings = cached.settings;\n spinner.text = 'Using cached rules...';\n } else {\n // Fetch from API\n const response = await axios.get(`${apiUrl}/api/v1/guardian/rules`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 10000\n });\n\n if (!response.data.success) {\n throw new Error(response.data.error || 'Unknown API error');\n }\n\n rules = response.data.data.rules;\n settings = response.data.data.settings;\n\n // Save to cache\n await saveCachedRules(projectId, rules, settings);\n }\n } catch (apiError: any) {\n // Fallback to cache if API fails\n const cached = await loadCachedRules(projectId);\n\n if (cached && !isStale(cached.timestamp, CACHE_MAX_AGE_MS)) {\n spinner.warn(chalk.yellow('Using cached rules (API unavailable)'));\n rules = cached.rules;\n settings = cached.settings;\n } else {\n spinner.fail(chalk.red('Failed to fetch rules and no valid cache'));\n console.log(chalk.dim(` Error: ${apiError.message}`));\n process.exit(2);\n }\n }\n\n spinner.succeed(`Loaded ${rules.length} Guardian rules`);\n\n // 4. Get files to check\n const scanPath = path.resolve(process.cwd(), targetPath);\n let filesToCheck: string[];\n\n if (options.staged) {\n // Only staged files\n spinner.start('Getting staged files...');\n try {\n const stagedOutput = execSync('git diff --cached --name-only --diff-filter=ACMR', {\n encoding: 'utf-8',\n cwd: process.cwd()\n });\n filesToCheck = stagedOutput\n .split('\\n')\n .filter(f => f.trim())\n .filter(f => isCodeFile(f))\n .map(f => path.resolve(process.cwd(), f));\n } catch {\n spinner.fail('Not a git repository or no staged files');\n process.exit(2);\n }\n } else {\n // All code files in path\n spinner.start(`Scanning ${chalk.cyan(targetPath)}...`);\n const pattern = path.join(scanPath, '**/*');\n const allFiles = await glob(pattern, {\n nodir: true,\n dot: false,\n ignore: [\n '**/node_modules/**',\n '**/.git/**',\n '**/dist/**',\n '**/build/**',\n '**/.next/**',\n '**/coverage/**'\n ]\n });\n filesToCheck = allFiles.filter(f => isCodeFile(f));\n }\n\n if (filesToCheck.length === 0) {\n spinner.warn(chalk.yellow('No code files found to check.'));\n outputResults([], !!options.json);\n process.exit(0);\n }\n\n spinner.succeed(`Found ${filesToCheck.length} files to check`);\n\n // 5. Run checks\n spinner.start('Running Guardian checks...');\n const results: CheckResult[] = [];\n\n for (let i = 0; i < filesToCheck.length; i++) {\n const file = filesToCheck[i];\n spinner.text = `Checking ${i + 1}/${filesToCheck.length}: ${path.basename(file)}`;\n const result = await checkFile(file, rules, process.cwd());\n results.push(result);\n }\n\n spinner.stop();\n\n // 6. Output results\n const summary = summarizeResults(results);\n\n if (options.json) {\n outputResults(results, true);\n } else {\n outputResults(results, false);\n\n // Summary\n console.log('\\n' + chalk.bold('📊 Summary'));\n console.log(chalk.dim('─'.repeat(50)));\n console.log(`Files checked: ${chalk.cyan(summary.totalFiles)}`);\n console.log(`Total violations: ${summary.totalViolations > 0 ? chalk.red(summary.totalViolations) : chalk.green(0)}`);\n\n if (summary.totalViolations > 0) {\n console.log(` ${chalk.red('Critical:')} ${summary.criticalCount}`);\n console.log(` ${chalk.yellow('Warning:')} ${summary.warningCount}`);\n console.log(` ${chalk.blue('Info:')} ${summary.infoCount}`);\n }\n\n console.log(chalk.dim('─'.repeat(50)));\n }\n\n // 7. Exit code logic\n if (options.strict !== undefined) {\n const strictLevel = typeof options.strict === 'string' ? options.strict : 'all';\n\n if (strictLevel === 'critical' && summary.criticalCount > 0) {\n console.log(chalk.red('\\n❌ Check failed: Critical violations found'));\n process.exit(1);\n } else if (strictLevel === 'all' && summary.totalViolations > 0) {\n console.log(chalk.red('\\n❌ Check failed: Violations found'));\n process.exit(1);\n }\n }\n\n if (summary.totalViolations === 0) {\n console.log(chalk.green('\\n✅ All checks passed!'));\n }\n\n process.exit(0);\n\n } catch (error: any) {\n spinner.fail(chalk.red('Check failed'));\n console.error(chalk.red('Error:'), error.message);\n process.exit(2);\n }\n });\n}\n\n// Helper functions\n\nfunction isCodeFile(filePath: string): boolean {\n const codeExtensions = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.cjs'];\n const ext = path.extname(filePath).toLowerCase();\n return codeExtensions.includes(ext);\n}\n\nasync function loadCachedRules(projectId: string): Promise<CachedRules | null> {\n try {\n const cachePath = path.join(process.cwd(), CACHE_FILE);\n const content = await fs.readFile(cachePath, 'utf-8');\n const cached: CachedRules = JSON.parse(content);\n\n if (cached.projectId !== projectId) {\n return null;\n }\n\n return cached;\n } catch {\n return null;\n }\n}\n\nasync function saveCachedRules(\n projectId: string,\n rules: EffectiveRule[],\n settings: { lmax: number; lmax_warning: number }\n): Promise<void> {\n try {\n const cacheDir = path.join(process.cwd(), '.rigstate');\n await fs.mkdir(cacheDir, { recursive: true });\n\n const cached: CachedRules = {\n timestamp: new Date().toISOString(),\n projectId,\n rules,\n settings\n };\n\n await fs.writeFile(\n path.join(cacheDir, 'rules-cache.json'),\n JSON.stringify(cached, null, 2)\n );\n } catch {\n // Silently fail cache write\n }\n}\n\nfunction isStale(timestamp: string, maxAge: number): boolean {\n const age = Date.now() - new Date(timestamp).getTime();\n return age > maxAge;\n}\n\nfunction outputResults(results: CheckResult[], json: boolean): void {\n if (json) {\n console.log(JSON.stringify({\n results,\n summary: summarizeResults(results)\n }, null, 2));\n return;\n }\n\n const hasViolations = results.some(r => r.violations.length > 0);\n\n if (!hasViolations) {\n return;\n }\n\n console.log('\\n' + chalk.bold('🔍 Violations Found'));\n console.log(chalk.dim('─'.repeat(50)));\n\n for (const result of results) {\n if (result.violations.length > 0) {\n formatViolations(result.violations);\n }\n }\n}\n","/**\n * Rule Engine - Evaluates Guardian rules against local files\n */\n\nimport fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\n\nexport interface EffectiveRule {\n id: string;\n rule_name: string;\n rule_type: string;\n value: Record<string, unknown>;\n severity: 'critical' | 'warning' | 'info';\n description: string;\n source: 'global' | 'project_override';\n is_enabled: boolean;\n}\n\nexport interface Violation {\n file: string;\n rule: string;\n ruleType: string;\n severity: 'critical' | 'warning' | 'info';\n message: string;\n details?: string;\n line?: number;\n}\n\nexport interface CheckResult {\n file: string;\n violations: Violation[];\n passed: boolean;\n}\n\n/**\n * Check a single file against all rules\n */\nexport async function checkFile(\n filePath: string,\n rules: EffectiveRule[],\n rootPath: string\n): Promise<CheckResult> {\n const violations: Violation[] = [];\n const relativePath = path.relative(rootPath, filePath);\n\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n const lines = content.split('\\n');\n\n for (const rule of rules) {\n const ruleViolations = await evaluateRule(rule, content, lines, relativePath);\n violations.push(...ruleViolations);\n }\n\n } catch (error: any) {\n violations.push({\n file: relativePath,\n rule: 'FILE_READ_ERROR',\n ruleType: 'SYSTEM',\n severity: 'warning',\n message: `Could not read file: ${error.message}`\n });\n }\n\n return {\n file: relativePath,\n violations,\n passed: violations.length === 0\n };\n}\n\n/**\n * Evaluate a single rule against file content\n */\nasync function evaluateRule(\n rule: EffectiveRule,\n content: string,\n lines: string[],\n filePath: string\n): Promise<Violation[]> {\n const violations: Violation[] = [];\n\n switch (rule.rule_type) {\n case 'MAX_FILE_LINES': {\n const value = rule.value as { limit: number; warning_threshold?: number };\n const lineCount = lines.length;\n\n if (lineCount > value.limit) {\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: 'critical',\n message: `File exceeds ${value.limit} lines`,\n details: `Current: ${lineCount} lines (limit: ${value.limit})`\n });\n } else if (value.warning_threshold && lineCount > value.warning_threshold) {\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: 'warning',\n message: `File approaching line limit`,\n details: `Current: ${lineCount} lines (warning at: ${value.warning_threshold}, limit: ${value.limit})`\n });\n }\n break;\n }\n\n case 'MAX_FUNCTION_LINES': {\n const value = rule.value as { limit: number };\n const functionViolations = checkFunctionLines(content, lines, filePath, rule, value.limit);\n violations.push(...functionViolations);\n break;\n }\n\n case 'PATTERN_FORBIDDEN': {\n const value = rule.value as { pattern: string; message?: string };\n const pattern = new RegExp(value.pattern, 'g');\n\n let match;\n while ((match = pattern.exec(content)) !== null) {\n const lineNumber = content.substring(0, match.index).split('\\n').length;\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: rule.severity,\n message: value.message || `Forbidden pattern found: ${value.pattern}`,\n line: lineNumber,\n details: `Found: \"${match[0].substring(0, 50)}${match[0].length > 50 ? '...' : ''}\"`\n });\n }\n break;\n }\n\n case 'PATTERN_REQUIRED': {\n const value = rule.value as { pattern: string; context?: string };\n const pattern = new RegExp(value.pattern);\n\n // Only check if context matches (e.g., only in certain file types)\n const shouldCheck = !value.context || filePath.includes(value.context);\n\n if (shouldCheck && !pattern.test(content)) {\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: rule.severity,\n message: `Required pattern not found: ${value.pattern}`,\n details: value.context ? `Expected in files matching: ${value.context}` : undefined\n });\n }\n break;\n }\n\n case 'NAMING_CONVENTION': {\n const value = rule.value as { pattern: string; context: string };\n const pattern = new RegExp(value.pattern);\n const fileName = path.basename(filePath);\n\n // Check if context matches (e.g., \"components\" for component files)\n if (filePath.includes(value.context) && !pattern.test(fileName)) {\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: rule.severity,\n message: `File name does not match naming convention`,\n details: `Expected pattern: ${value.pattern}`\n });\n }\n break;\n }\n\n default:\n // Unknown rule type, skip\n break;\n }\n\n return violations;\n}\n\n/**\n * Check function line counts using simple heuristics (not full AST)\n * Works for TypeScript/JavaScript\n */\nfunction checkFunctionLines(\n content: string,\n lines: string[],\n filePath: string,\n rule: EffectiveRule,\n limit: number\n): Violation[] {\n const violations: Violation[] = [];\n\n // Simple regex-based detection for functions\n // Matches: function name(), async function name(), const name = () =>, const name = function()\n const functionPatterns = [\n /(?:export\\s+)?(?:async\\s+)?function\\s+(\\w+)\\s*\\([^)]*\\)\\s*\\{/g,\n /(?:export\\s+)?const\\s+(\\w+)\\s*=\\s*(?:async\\s+)?\\([^)]*\\)\\s*=>\\s*\\{/g,\n /(?:export\\s+)?const\\s+(\\w+)\\s*=\\s*(?:async\\s+)?function\\s*\\([^)]*\\)\\s*\\{/g,\n /(\\w+)\\s*\\([^)]*\\)\\s*\\{/g // Method in class/object\n ];\n\n for (const pattern of functionPatterns) {\n let match;\n while ((match = pattern.exec(content)) !== null) {\n const functionName = match[1];\n const startIndex = match.index + match[0].length - 1; // Position of opening brace\n\n // Find matching closing brace\n let braceCount = 1;\n let endIndex = startIndex + 1;\n\n while (braceCount > 0 && endIndex < content.length) {\n if (content[endIndex] === '{') braceCount++;\n else if (content[endIndex] === '}') braceCount--;\n endIndex++;\n }\n\n // Count lines in function\n const functionContent = content.substring(startIndex, endIndex);\n const functionLines = functionContent.split('\\n').length;\n\n if (functionLines > limit) {\n const lineNumber = content.substring(0, match.index).split('\\n').length;\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: rule.severity,\n message: `Function \"${functionName}\" exceeds ${limit} lines`,\n line: lineNumber,\n details: `Current: ${functionLines} lines (limit: ${limit})`\n });\n }\n }\n }\n\n return violations;\n}\n\n/**\n * Format violations for console output\n */\nexport function formatViolations(violations: Violation[]): void {\n for (const v of violations) {\n const severityColor = v.severity === 'critical' ? chalk.red :\n v.severity === 'warning' ? chalk.yellow : chalk.blue;\n\n const lineInfo = v.line ? chalk.dim(`:${v.line}`) : '';\n\n console.log(` ${severityColor(`[${v.severity.toUpperCase()}]`)} ${v.file}${lineInfo}`);\n console.log(` ${v.message}`);\n if (v.details) {\n console.log(` ${chalk.dim(v.details)}`);\n }\n }\n}\n\n/**\n * Summarize results\n */\nexport function summarizeResults(results: CheckResult[]): {\n totalFiles: number;\n totalViolations: number;\n criticalCount: number;\n warningCount: number;\n infoCount: number;\n} {\n let criticalCount = 0;\n let warningCount = 0;\n let infoCount = 0;\n\n for (const result of results) {\n for (const v of result.violations) {\n if (v.severity === 'critical') criticalCount++;\n else if (v.severity === 'warning') warningCount++;\n else infoCount++;\n }\n }\n\n return {\n totalFiles: results.length,\n totalViolations: criticalCount + warningCount + infoCount,\n criticalCount,\n warningCount,\n infoCount\n };\n}\n","/**\n * rigstate daemon - Unified Guardian Daemon\n * \n * Usage:\n * rigstate daemon # Start daemon in foreground\n * rigstate daemon status # Check if daemon is running\n * rigstate daemon --no-bridge # Disable Agent Bridge\n * rigstate daemon --verbose # Enable verbose output\n */\n/* eslint-disable no-console */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { createDaemon } from '../daemon/factory.js';\n\nconst PID_FILE = '.rigstate/daemon.pid';\nconst STATE_FILE = '.rigstate/daemon.state.json';\n\nexport function createDaemonCommand(): Command {\n const daemon = new Command('daemon')\n .description('Start the Guardian daemon for continuous monitoring');\n\n // Main daemon command (start in foreground)\n daemon\n .argument('[action]', 'Action: start (default) or status', 'start')\n .option('--project <id>', 'Project ID (or use .rigstate manifest)')\n .option('--path <path>', 'Path to watch', '.')\n .option('--no-bridge', 'Disable Agent Bridge connection')\n .option('--verbose', 'Enable verbose output')\n .action(async (action: string, options: {\n project?: string;\n path?: string;\n bridge?: boolean;\n verbose?: boolean;\n }) => {\n if (action === 'status') {\n await showStatus();\n return;\n }\n\n if (action === 'enable') {\n await enableDaemon();\n return;\n }\n\n if (action === 'disable') {\n await disableDaemon();\n return;\n }\n\n const spinner = ora();\n\n try {\n // Check if already running\n if (await isRunning()) {\n console.log(chalk.yellow('⚠ Another daemon instance may be running.'));\n console.log(chalk.dim(` Check ${PID_FILE} or run \"rigstate daemon status\"`));\n console.log(chalk.dim(' Use Ctrl+C to stop the running daemon first.\\n'));\n }\n\n // Create daemon\n spinner.start('Initializing Guardian Daemon...');\n const daemonInstance = await createDaemon({\n project: options.project,\n path: options.path,\n noBridge: options.bridge === false,\n verbose: options.verbose\n });\n spinner.stop();\n\n // Write PID file\n await writePidFile();\n\n // Handle shutdown gracefully\n process.on('SIGINT', async () => {\n console.log(chalk.dim('\\n\\nShutting down...'));\n await daemonInstance.stop();\n await cleanupPidFile();\n process.exit(0);\n });\n\n process.on('SIGTERM', async () => {\n await daemonInstance.stop();\n await cleanupPidFile();\n process.exit(0);\n });\n\n // Update state file periodically\n const stateInterval = setInterval(async () => {\n await writeStateFile(daemonInstance.getState());\n }, 5000);\n\n daemonInstance.on('stopped', () => {\n clearInterval(stateInterval);\n });\n\n // Start the daemon\n await daemonInstance.start();\n\n // Keep the process alive\n await new Promise(() => { });\n\n } catch (error: any) {\n spinner.fail(chalk.red('Failed to start daemon'));\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n return daemon;\n}\n\nasync function isRunning(): Promise<boolean> {\n try {\n const pidPath = path.join(process.cwd(), PID_FILE);\n const content = await fs.readFile(pidPath, 'utf-8');\n const pid = parseInt(content.trim(), 10);\n\n // Check if process exists\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n // Process doesn't exist, clean up stale PID file\n await fs.unlink(pidPath);\n return false;\n }\n } catch {\n return false;\n }\n}\n\nasync function writePidFile(): Promise<void> {\n try {\n const dir = path.join(process.cwd(), '.rigstate');\n await fs.mkdir(dir, { recursive: true });\n await fs.writeFile(path.join(dir, 'daemon.pid'), process.pid.toString());\n } catch {\n // Silently fail\n }\n}\n\nasync function cleanupPidFile(): Promise<void> {\n try {\n await fs.unlink(path.join(process.cwd(), PID_FILE));\n await fs.unlink(path.join(process.cwd(), STATE_FILE));\n } catch {\n // Silently fail\n }\n}\n\nasync function writeStateFile(state: any): Promise<void> {\n try {\n const dir = path.join(process.cwd(), '.rigstate');\n await fs.mkdir(dir, { recursive: true });\n await fs.writeFile(\n path.join(dir, 'daemon.state.json'),\n JSON.stringify(state, null, 2)\n );\n } catch {\n // Silently fail\n }\n}\n\nasync function showStatus(): Promise<void> {\n console.log(chalk.bold('\\n🛡️ Guardian Daemon Status\\n'));\n\n const running = await isRunning();\n\n if (!running) {\n console.log(chalk.yellow('Status: Not running'));\n console.log(chalk.dim('Use \"rigstate daemon\" to start.\\n'));\n return;\n }\n\n console.log(chalk.green('Status: Running'));\n\n // Read state file\n try {\n const statePath = path.join(process.cwd(), STATE_FILE);\n const content = await fs.readFile(statePath, 'utf-8');\n const state = JSON.parse(content);\n\n console.log(chalk.dim('─'.repeat(40)));\n console.log(`Started at: ${state.startedAt || 'Unknown'}`);\n console.log(`Files checked: ${state.filesChecked || 0}`);\n console.log(`Violations: ${state.violationsFound || 0}`);\n console.log(`Tasks processed: ${state.tasksProcessed || 0}`);\n console.log(`Last activity: ${state.lastActivity || 'None'}`);\n console.log(chalk.dim('─'.repeat(40)));\n } catch {\n console.log(chalk.dim('(State file not found)'));\n }\n\n // Read PID\n try {\n const pidPath = path.join(process.cwd(), PID_FILE);\n const pid = await fs.readFile(pidPath, 'utf-8');\n console.log(chalk.dim(`PID: ${pid.trim()}`));\n } catch {\n // No PID file\n }\n\n console.log('');\n}\n\nasync function enableDaemon() {\n console.log(chalk.bold('\\n⚙️ Enabling Rigstate Background Service (macOS)\\n'));\n\n if (process.platform !== 'darwin') {\n console.error(chalk.red('❌ Currently only macOS is supported for auto-start.'));\n console.error(chalk.yellow('PRs welcome for Linux/Windows support!'));\n return;\n }\n\n const homeDir = process.env.HOME || '';\n if (!homeDir) {\n console.error(chalk.red('❌ Could not determine HOME directory.'));\n return;\n }\n\n const agentsDir = path.join(homeDir, 'Library/LaunchAgents');\n const logDir = path.join(homeDir, '.rigstate/logs');\n const plistPath = path.join(agentsDir, 'com.rigstate.daemon.plist');\n\n // Ensure directories exist\n await fs.mkdir(agentsDir, { recursive: true });\n await fs.mkdir(logDir, { recursive: true });\n\n // Find the executable path\n // We assume 'rigstate' is in the PATH, but for launchd we need absolute path\n // Or we use the node executable and the script path\n\n // Strategy: Use the currently executing script path\n // This file is likely in dist/commands/daemon.js, we need dist/index.js\n const scriptPath = path.resolve(__dirname, '../index.js');\n const nodePath = process.execPath; // Absolute path to node executable\n\n const plistContent = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n <key>Label</key>\n <string>com.rigstate.daemon</string>\n <key>ProgramArguments</key>\n <array>\n <string>${nodePath}</string>\n <string>${scriptPath}</string>\n <string>daemon</string>\n <string>--no-bridge</string> \n </array>\n <key>WorkingDirectory</key>\n <string>${process.cwd()}</string>\n <key>StandardOutPath</key>\n <string>${path.join(logDir, 'daemon.out.log')}</string>\n <key>StandardErrorPath</key>\n <string>${path.join(logDir, 'daemon.err.log')}</string>\n <key>RunAtLoad</key>\n <true/>\n <key>KeepAlive</key>\n <true/>\n <key>EnvironmentVariables</key>\n <dict>\n <key>PATH</key>\n <string>/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:${process.env.PATH}</string>\n </dict>\n</dict>\n</plist>`;\n\n try {\n await fs.writeFile(plistPath, plistContent);\n console.log(chalk.dim(`Created plist at: ${plistPath}`));\n\n // Load the agent\n try {\n await execShellCommand(`launchctl unload ${plistPath}`); // Unload if exists\n } catch (e) { } // Ignore error if not loaded\n\n await execShellCommand(`launchctl load ${plistPath}`);\n\n console.log(chalk.green('✅ Successfully enabled background daemon!'));\n console.log(chalk.dim(`Logs: ${logDir}`));\n console.log(chalk.dim('The daemon will now restart automatically if it crashes or on reboot.'));\n\n } catch (error: any) {\n console.error(chalk.red('❌ Failed to enable daemon:'), error.message);\n }\n}\n\nasync function disableDaemon() {\n console.log(chalk.bold('\\n⚙️ Disabling Rigstate Background Service\\n'));\n\n const homeDir = process.env.HOME || '';\n const plistPath = path.join(homeDir, 'Library/LaunchAgents/com.rigstate.daemon.plist');\n\n try {\n await execShellCommand(`launchctl unload ${plistPath}`);\n await fs.unlink(plistPath);\n console.log(chalk.green('✅ Successfully disabled background daemon.'));\n } catch (error: any) {\n // If file doesn't exist, it's already disabled\n if (error.code === 'ENOENT') {\n console.log(chalk.green('✅ Daemon was not enabled.'));\n } else {\n console.error(chalk.red('❌ Failed to disable daemon:'), error.message);\n }\n }\n}\n\nfunction execShellCommand(cmd: string) {\n const exec = require('child_process').exec;\n return new Promise((resolve, reject) => {\n exec(cmd, (error: any, stdout: string, stderr: string) => {\n if (error) {\n // launchctl returns non-zero if already loaded/unloaded sometimes, \n // but we might want to check stderr\n // For now simple wrapper\n // reject(error);\n }\n resolve(stdout ? stdout : stderr);\n });\n });\n}\n","import { GuardianDaemon } from './core.js';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { loadManifest } from '../utils/manifest.js';\nimport { DaemonConfig } from './types.js';\n\n/**\n * Factory for creating a GuardianDaemon with resolved configuration.\n */\nexport async function createDaemon(options: {\n project?: string;\n path?: string;\n noBridge?: boolean;\n verbose?: boolean;\n}): Promise<GuardianDaemon> {\n const apiUrl = getApiUrl();\n let projectId = options.project;\n\n if (!projectId) {\n const manifest = await loadManifest();\n if (manifest) projectId = manifest.project_id;\n }\n\n if (!projectId) projectId = getProjectId();\n\n if (!projectId) {\n throw new Error('No project ID found. Run \"rigstate link\" or use --project <id>.');\n }\n\n const apiKey = getApiKey();\n if (!apiKey) {\n throw new Error('Not authenticated. Run \"rigstate login\" first.');\n }\n\n const config: DaemonConfig = {\n projectId,\n apiUrl,\n apiKey,\n watchPath: options.path || process.cwd(),\n checkOnChange: true,\n bridgeEnabled: !options.noBridge,\n verbose: !!options.verbose\n };\n\n return new GuardianDaemon(config);\n}\n","/**\n * Daemon Core - Orchestrates all background watchers\n * \n * Combines:\n * 1. File Watcher (chokidar) - Monitors filesystem changes\n * 2. Guardian Rules - Validates files against rules on change\n * 3. Agent Bridge Listener - Receives tasks from Rigstate Cloud\n */\n\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport * as fs from 'fs/promises';\nimport { EventEmitter } from 'events';\nimport { createFileWatcher, type FileWatcherEvents } from './file-watcher.js';\nimport { createHeuristicEngine } from './heuristic-engine.js';\nimport { createInterventionProtocol, type InterventionDecision } from './intervention-protocol.js';\nimport { createGuardianMonitor } from './guardian-monitor.js';\nimport { createBridgeListener, type BridgeListenerEvents } from './bridge-listener.js';\nimport { DaemonConfig, DaemonState } from './types.js';\nimport { trackSkillUsage } from './telemetry.js';\nimport { jitProvisionSkill } from '../utils/skills-provisioner.js';\n\nexport class GuardianDaemon extends EventEmitter {\n private config: DaemonConfig;\n private state: DaemonState;\n private fileWatcher: ReturnType<typeof createFileWatcher> | null = null;\n private guardianMonitor: ReturnType<typeof createGuardianMonitor> | null = null;\n private heuristicEngine: ReturnType<typeof createHeuristicEngine> | null = null;\n private interventionProtocol: ReturnType<typeof createInterventionProtocol> | null = null;\n private bridgeListener: ReturnType<typeof createBridgeListener> | null = null;\n\n constructor(config: DaemonConfig) {\n super();\n this.config = config;\n this.state = {\n isRunning: false,\n startedAt: null,\n filesChecked: 0,\n violationsFound: 0,\n tasksProcessed: 0,\n lastActivity: null\n };\n }\n\n async start(): Promise<void> {\n if (this.state.isRunning) {\n console.log(chalk.yellow('Daemon is already running.'));\n return;\n }\n\n this.printWelcome();\n this.state.isRunning = true;\n this.state.startedAt = new Date().toISOString();\n\n // 1. Initialize Engines\n this.heuristicEngine = createHeuristicEngine();\n this.interventionProtocol = createInterventionProtocol();\n this.guardianMonitor = createGuardianMonitor(this.config.projectId, this.config.apiUrl, this.config.apiKey);\n\n // 2. Load and Sync Rules\n await this.guardianMonitor.loadRules();\n console.log(chalk.green(` ✓ Loaded ${this.guardianMonitor.getRuleCount()} rules`));\n await this.syncHeuristics();\n\n // 3. Setup File Watcher\n if (this.config.checkOnChange) {\n this.setupFileWatcher();\n }\n\n // 4. Setup Bridge\n if (this.config.bridgeEnabled) {\n await this.setupBridge();\n }\n\n this.printActive();\n this.emit('started', this.state);\n }\n\n private printWelcome() {\n console.log(chalk.bold.blue('\\n🛡️ Guardian Daemon Starting...'));\n console.log(chalk.dim(`Project: ${this.config.projectId}`));\n console.log(chalk.dim(`Watch Path: ${this.config.watchPath}`));\n console.log(chalk.dim('─'.repeat(50)));\n }\n\n private printActive() {\n console.log(chalk.dim('─'.repeat(50)));\n console.log(chalk.green.bold('✅ Guardian Daemon is now active'));\n console.log(chalk.dim('Press Ctrl+C to stop\\n'));\n }\n\n private async syncHeuristics() {\n if (!this.heuristicEngine) return;\n const synced = await this.heuristicEngine.refreshRules(this.config.projectId, this.config.apiUrl, this.config.apiKey);\n if (synced) console.log(chalk.green(' ✓ Synced heuristic rules'));\n }\n\n private setupFileWatcher() {\n console.log(chalk.dim('📂 Starting file watcher...'));\n this.fileWatcher = createFileWatcher(this.config.watchPath);\n this.fileWatcher.on('change', (path) => this.handleFileChange(path));\n this.fileWatcher.start();\n console.log(chalk.green(' ✓ File watcher active'));\n }\n\n private async handleFileChange(filePath: string) {\n this.state.lastActivity = new Date().toISOString();\n if (this.config.verbose) console.log(chalk.dim(` 📝 File changed: ${filePath}`));\n\n // 1. Calculate metrics\n let lineCount = 0;\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n lineCount = content.split('\\n').length;\n } catch (e) { /* Deleted file or error */ }\n\n // A. Prediction & JIT\n if (this.heuristicEngine && this.interventionProtocol && this.guardianMonitor) {\n const matches = await this.heuristicEngine.analyzeFile(filePath, {\n lineCount,\n rules: this.guardianMonitor.getRules()\n });\n for (const match of matches) {\n console.log(chalk.magenta(` 💡 PREDICTIVE ACTIVATION: ${match.skillId}`));\n console.log(chalk.dim(` Reason: ${match.reason}`));\n\n const decision = this.interventionProtocol.evaluateTrigger(match.skillId, match.confidence);\n this.interventionProtocol.enforce(decision);\n\n await jitProvisionSkill(match.skillId, this.config.apiUrl, this.config.apiKey, this.config.projectId, process.cwd());\n await trackSkillUsage(this.config.apiUrl, this.config.apiKey, this.config.projectId, match.skillId);\n this.emit('skill:suggestion', match);\n }\n }\n\n // B. Guardian Check\n if (this.guardianMonitor) {\n if (this.interventionProtocol) this.interventionProtocol.clear(filePath);\n const result = await this.guardianMonitor.checkFile(filePath);\n this.state.filesChecked++;\n\n if (result.violations.length > 0) {\n this.state.violationsFound += result.violations.length;\n this.emit('violation', { file: filePath, violations: result.violations });\n for (const v of result.violations) {\n const color = v.severity === 'critical' ? chalk.red : v.severity === 'warning' ? chalk.yellow : chalk.blue;\n console.log(color(` [${v.severity.toUpperCase()}] ${filePath}: ${v.message}`));\n if (this.interventionProtocol) {\n const decision = this.interventionProtocol.evaluateViolation(v.message, v.severity as any);\n this.interventionProtocol.enforce(decision);\n this.interventionProtocol.registerViolation(filePath, decision);\n }\n }\n }\n }\n }\n\n private async setupBridge() {\n console.log(chalk.dim('🌉 Connecting to Agent Bridge...'));\n this.bridgeListener = createBridgeListener(this.config.projectId, this.config.apiUrl, this.config.apiKey);\n this.bridgeListener.on('task', (task) => {\n this.state.lastActivity = new Date().toISOString();\n this.state.tasksProcessed++;\n console.log(chalk.cyan(`\\n📥 New task received: ${task.id}`));\n this.emit('task', task);\n });\n await this.bridgeListener.connect();\n console.log(chalk.green(' ✓ Agent Bridge connected'));\n }\n\n async stop(): Promise<void> {\n if (!this.state.isRunning) return;\n console.log(chalk.dim('\\n🛑 Stopping Guardian Daemon...'));\n if (this.fileWatcher) await this.fileWatcher.stop();\n if (this.bridgeListener) await this.bridgeListener.disconnect();\n this.state.isRunning = false;\n console.log(chalk.green('✓ Daemon stopped.'));\n this.emit('stopped', this.state);\n }\n\n getState(): DaemonState {\n return { ...this.state };\n }\n}\n","/**\n * File Watcher - Monitors filesystem for changes using chokidar\n */\n\nimport * as chokidar from 'chokidar';\nimport path from 'path';\nimport { EventEmitter } from 'events';\n\nexport interface FileWatcherEvents {\n change: (filePath: string) => void;\n add: (filePath: string) => void;\n unlink: (filePath: string) => void;\n error: (error: Error) => void;\n ready: () => void;\n}\n\nexport interface FileWatcher extends EventEmitter {\n start(): void;\n stop(): Promise<void>;\n on<K extends keyof FileWatcherEvents>(event: K, listener: FileWatcherEvents[K]): this;\n emit<K extends keyof FileWatcherEvents>(event: K, ...args: Parameters<FileWatcherEvents[K]>): boolean;\n}\n\nconst CODE_EXTENSIONS = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.cjs'];\n\nfunction isCodeFile(filePath: string): boolean {\n const ext = path.extname(filePath).toLowerCase();\n return CODE_EXTENSIONS.includes(ext);\n}\n\nexport function createFileWatcher(watchPath: string): FileWatcher {\n const emitter = new EventEmitter() as FileWatcher;\n let watcher: chokidar.FSWatcher | null = null;\n\n emitter.start = () => {\n const absolutePath = path.resolve(process.cwd(), watchPath);\n\n watcher = chokidar.watch(absolutePath, {\n ignored: (absolutePath) => {\n // Get relative path for cleaner matching\n const relPath = path.relative(process.cwd(), absolutePath);\n\n // Common directories to ignore (exact matches on path segments)\n const ignoredDirs = new Set([\n 'node_modules',\n '.git',\n '.next',\n '.turbo',\n 'dist',\n 'build',\n '.rigstate',\n 'coverage',\n '.DS_Store',\n 'tmp',\n 'temp',\n 'vendor',\n '.cache',\n 'public' // Usually static assets, not code\n ]);\n\n // Check if any segment of the path matches an ignored directory\n const segments = relPath.split(path.sep);\n if (segments.some(s => ignoredDirs.has(s))) {\n return true;\n }\n\n // Ignore dotfiles (except .env maybe, but for now safe to ignore secret/config files)\n // Actually, let's keep .cursorrules and similar if needed, but generally ignore hidden\n // if (path.basename(absolutePath).startsWith('.') && !segments.some(s => s === '.cursor')) return true;\n\n return false;\n },\n persistent: true,\n ignoreInitial: true,\n ignorePermissionErrors: true, // Don't crash on EPERM\n depth: 20,\n awaitWriteFinish: {\n stabilityThreshold: 300,\n pollInterval: 100\n },\n usePolling: false,\n atomic: true // Handle atomic writes (like vim/saving) better\n });\n\n watcher.on('change', (filePath: string) => {\n if (isCodeFile(filePath)) {\n emitter.emit('change', path.relative(process.cwd(), filePath));\n }\n });\n\n watcher.on('add', (filePath: string) => {\n if (isCodeFile(filePath)) {\n emitter.emit('add', path.relative(process.cwd(), filePath));\n }\n });\n\n watcher.on('unlink', (filePath: string) => {\n if (isCodeFile(filePath)) {\n emitter.emit('unlink', path.relative(process.cwd(), filePath));\n }\n });\n\n watcher.on('error', (error: any) => {\n emitter.emit('error', error);\n });\n\n watcher.on('ready', () => {\n emitter.emit('ready');\n });\n };\n\n emitter.stop = async () => {\n if (watcher) {\n await watcher.close();\n watcher = null;\n }\n };\n\n return emitter;\n}\n","import { readFile, writeFile, mkdir } from 'fs/promises';\nimport { dirname } from 'path';\nimport path from 'path';\nimport axios from 'axios';\n\nexport interface SkillTrigger {\n skillId: string;\n patterns: {\n imports?: string[]; // e.g. \"@stripe/stripe-js\"\n content?: string[]; // Regex strings e.g. \"payment_intent\"\n files?: string[]; // Glob patterns e.g. \"**/*.sql\"\n violation_id?: string;\n metric_threshold?: number;\n };\n confidence: 'high' | 'medium' | 'low';\n}\n\nexport interface HeuristicMatch {\n skillId: string;\n file: string;\n reason: string;\n confidence: 'high' | 'medium' | 'low';\n}\n\n// TODO: In the future, this should fetch from the Rigstate API (The Registry)\nconst GLOBAL_HEURISTICS: SkillTrigger[] = [\n {\n skillId: 'payment-expert',\n patterns: {\n imports: ['@stripe/', 'stripe'],\n content: ['PaymentIntent', 'CheckoutSession'],\n },\n confidence: 'high'\n },\n {\n skillId: 'rigstate-integrity-gate',\n patterns: {\n files: ['**/release.config.js', '**/manifest.json', '**/.rigstate/release/*'],\n content: ['[CORE INTEGRITY]', 'prepare_release']\n },\n confidence: 'high'\n },\n {\n skillId: 'database-architect',\n patterns: {\n files: ['**/*.sql', '**/schema.prisma', '**/migrations/*'],\n imports: ['@supabase/supabase-js', 'drizzle-orm', 'prisma']\n },\n confidence: 'medium'\n }\n];\n\nexport class HeuristicEngine {\n private rules: SkillTrigger[] = [];\n private cachePath: string;\n\n constructor() {\n this.cachePath = path.join(process.cwd(), '.rigstate', 'cache', 'heuristics.json');\n this.loadRules();\n }\n\n private async loadRules() {\n try {\n const cached = await readFile(this.cachePath, 'utf-8');\n const data = JSON.parse(cached);\n if (Array.isArray(data) && data.length > 0) {\n this.rules = data;\n return;\n }\n } catch (e) {\n // No cache, use defaults\n }\n this.rules = GLOBAL_HEURISTICS;\n }\n\n async refreshRules(projectId: string, apiUrl: string, apiKey: string) {\n try {\n // Ensure cache directory exists\n await mkdir(dirname(this.cachePath), { recursive: true });\n\n const endpoint = `${apiUrl}/api/v1/skills/triggers`;\n\n const response = await axios.get(endpoint, {\n headers: {\n 'x-api-key': apiKey,\n 'Content-Type': 'application/json'\n }\n });\n\n if (response.data && Array.isArray(response.data.triggers)) {\n const cloudRules = response.data.triggers;\n\n // Write to cache\n await writeFile(this.cachePath, JSON.stringify(cloudRules, null, 2));\n\n this.rules = cloudRules;\n return true;\n }\n } catch (error) {\n return false;\n }\n }\n\n async analyzeFile(filePath: string, metrics?: { lineCount: number, rules: any[] }): Promise<HeuristicMatch[]> {\n try {\n const content = await readFile(filePath, 'utf-8');\n const matches: HeuristicMatch[] = [];\n\n // Use dynamic rules\n const activeRules = this.rules.length > 0 ? this.rules : GLOBAL_HEURISTICS;\n\n for (const heuristic of activeRules) {\n const match = this.checkHeuristic(filePath, content, heuristic, metrics);\n if (match) {\n matches.push(match);\n }\n }\n\n return matches;\n } catch (error) {\n // Ignore file read errors (deleted files, etc)\n return [];\n }\n }\n\n private checkHeuristic(\n filePath: string,\n content: string,\n heuristic: SkillTrigger,\n metrics?: { lineCount: number, rules: any[] }\n ): HeuristicMatch | null {\n // 0. Check Metric Thresholds (The 80% Rule)\n if (heuristic.patterns.metric_threshold && metrics) {\n const lineLimitRule = metrics.rules.find(r => r.rule_type === 'MAX_FILE_LINES');\n if (lineLimitRule) {\n const limit = (lineLimitRule.value as any).limit;\n const threshold = limit * heuristic.patterns.metric_threshold;\n\n if (metrics.lineCount >= threshold && metrics.lineCount < limit) {\n return {\n skillId: heuristic.skillId,\n file: filePath,\n reason: `File reached ${Math.round((metrics.lineCount / limit) * 100)}% of its line limit (${metrics.lineCount}/${limit})`,\n confidence: 'high'\n };\n }\n }\n }\n\n // 1. Check File Path Patterns\n if (heuristic.patterns.files) {\n // Simple endsWith check for now, ideally use micromatch\n const matchesFile = heuristic.patterns.files.some(pattern => {\n if (pattern.startsWith('**/*')) return filePath.endsWith(pattern.replace('**/*', ''));\n return filePath.includes(pattern);\n });\n if (matchesFile) {\n return {\n skillId: heuristic.skillId,\n file: filePath,\n reason: `Matches file pattern: ${heuristic.patterns.files.join(', ')}`,\n confidence: heuristic.confidence\n };\n }\n }\n\n // 2. Check Imports\n if (heuristic.patterns.imports) {\n for (const imp of heuristic.patterns.imports) {\n // Regex to find import or require\n const importRegex = new RegExp(`(import .* from ['\"]${imp}|require\\\\(['\"]${imp})`, 'i');\n if (importRegex.test(content)) {\n return {\n skillId: heuristic.skillId,\n file: filePath,\n reason: `Detected import: ${imp}`,\n confidence: heuristic.confidence\n };\n }\n }\n }\n\n // 3. Check Content\n if (heuristic.patterns.content) {\n for (const pattern of heuristic.patterns.content) {\n if (content.includes(pattern)) {\n return {\n skillId: heuristic.skillId,\n file: filePath,\n reason: `Detected content pattern: ${pattern}`,\n confidence: heuristic.confidence\n };\n }\n }\n }\n\n return null;\n }\n}\n\nexport function createHeuristicEngine() {\n return new HeuristicEngine();\n}\n","import chalk from 'chalk';\n\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nexport type GovernanceMode = 'OPEN' | 'SOFT_LOCK' | 'HARD_LOCK';\n\nexport interface InterventionDecision {\n mode: GovernanceMode;\n message: string;\n blockCommit: boolean;\n}\n\n/**\n * The Silent Sentinel (Frank's Enforcer)\n * Determines the severity of an event and the required system response.\n */\nexport class InterventionProtocol {\n private activeViolators = new Set<string>();\n\n /**\n * Registers a violation outcome to update the global lock state.\n */\n registerViolation(filePath: string, decision: InterventionDecision) {\n if (decision.mode === 'HARD_LOCK') {\n this.activeViolators.add(filePath);\n this.syncLockFile();\n }\n }\n\n /**\n * Clears any active locks for a specific file (e.g. after a fix).\n */\n clear(filePath: string) {\n if (this.activeViolators.has(filePath)) {\n this.activeViolators.delete(filePath);\n this.syncLockFile();\n }\n }\n\n private syncLockFile() {\n try {\n const lockDir = path.join(process.cwd(), '.rigstate');\n if (!fs.existsSync(lockDir)) fs.mkdirSync(lockDir, { recursive: true });\n\n const lockPath = path.join(lockDir, 'guardian.lock');\n\n if (this.activeViolators.size > 0) {\n const content = `HARD_LOCK_ACTIVE\\nTimestamp: ${new Date().toISOString()}\\n\\nBlocking Files:\\n${Array.from(this.activeViolators).join('\\n')}`;\n fs.writeFileSync(lockPath, content, 'utf-8');\n } else {\n if (fs.existsSync(lockPath)) fs.unlinkSync(lockPath);\n }\n } catch (e) {\n console.error('Failed to sync guardian lock file:', e);\n }\n }\n\n /**\n * Evaluate a Heuristic Trigger (Preventative)\n */\n evaluateTrigger(skillId: string, confidence: string): InterventionDecision {\n // Example: If a skill is marked as 'HARD_LOCK' in its metadata, we block.\n // For now, most triggers are informational (JIT provisioning).\n\n if (skillId === 'rigstate-integrity-gate') {\n return {\n mode: 'SOFT_LOCK',\n message: 'Integrity Gate detected. Release Manifest required before final push.',\n blockCommit: false // Soft lock just warns\n };\n }\n\n return {\n mode: 'OPEN',\n message: `Predictive activation: ${skillId}`,\n blockCommit: false\n };\n }\n\n /**\n * Evaluate a Guardian Violation (Corrective)\n */\n evaluateViolation(ruleId: string, severity: 'critical' | 'warning' | 'info'): InterventionDecision {\n if (severity === 'critical' || (severity as any) === 'error') {\n return {\n mode: 'HARD_LOCK',\n message: `CRITICAL VIOLATION: ${ruleId}. System Integrity Compromised.`,\n blockCommit: true\n };\n }\n\n if (severity === 'warning') {\n return {\n mode: 'SOFT_LOCK',\n message: `Warning: ${ruleId}. Review recommended.`,\n blockCommit: false\n };\n }\n\n return {\n mode: 'OPEN',\n message: 'Info notice.',\n blockCommit: false\n };\n }\n\n /**\n * Logs the intervention to the console with appropriate visual weight\n */\n enforce(decision: InterventionDecision) {\n if (decision.mode === 'OPEN') return;\n\n const icon = decision.mode === 'HARD_LOCK' ? '🚫' : '⚠️';\n const color = decision.mode === 'HARD_LOCK' ? chalk.bgRed.white.bold : chalk.yellow.bold;\n\n console.log('\\n' + color(` ${icon} [${decision.mode}] INTERVENTION `));\n console.log(chalk.redBright(` ${decision.message}`));\n\n if (decision.blockCommit) {\n console.log(chalk.dim(' 🔒 Commit functionality is logically suspended until fixed.'));\n }\n }\n}\n\nexport function createInterventionProtocol() {\n return new InterventionProtocol();\n}\n","/**\n * Guardian Monitor - Checks files against Guardian rules\n */\n\nimport axios from 'axios';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { checkFile, type EffectiveRule, type Violation, type CheckResult } from '../utils/rule-engine.js';\n\nconst CACHE_FILE = '.rigstate/rules-cache.json';\nconst CACHE_TTL_MS = 5 * 60 * 1000; // 5 minutes\n\ninterface CachedRules {\n timestamp: string;\n projectId: string;\n rules: EffectiveRule[];\n settings: { lmax: number; lmax_warning: number };\n}\n\nexport interface GuardianMonitor {\n loadRules(): Promise<void>;\n checkFile(filePath: string): Promise<CheckResult>;\n getRuleCount(): number;\n getRules(): EffectiveRule[];\n}\n\nexport function createGuardianMonitor(\n projectId: string,\n apiUrl: string,\n apiKey: string\n): GuardianMonitor {\n let rules: EffectiveRule[] = [];\n let lastFetch: number = 0;\n\n const loadRules = async (): Promise<void> => {\n // Check if cache is fresh\n if (rules.length > 0 && Date.now() - lastFetch < CACHE_TTL_MS) {\n return;\n }\n\n try {\n // Try API first\n const response = await axios.get(`${apiUrl}/api/v1/guardian/rules`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 10000\n });\n\n if (response.data.success && response.data.data.rules) {\n rules = response.data.data.rules;\n lastFetch = Date.now();\n\n // Save to cache\n await saveCachedRules(projectId, rules);\n return;\n }\n } catch (error) {\n // Try cache fallback\n const cached = await loadCachedRules(projectId);\n if (cached) {\n rules = cached.rules;\n lastFetch = Date.now();\n return;\n }\n }\n\n // No rules available\n rules = [];\n };\n\n const checkFileImpl = async (filePath: string): Promise<CheckResult> => {\n // Ensure rules are loaded\n await loadRules();\n\n if (rules.length === 0) {\n return {\n file: filePath,\n violations: [],\n passed: true\n };\n }\n\n const absolutePath = path.resolve(process.cwd(), filePath);\n return checkFile(absolutePath, rules, process.cwd());\n };\n\n const getRuleCount = (): number => rules.length;\n const getRules = (): EffectiveRule[] => rules;\n\n return {\n loadRules,\n checkFile: checkFileImpl,\n getRuleCount,\n getRules\n };\n}\n\nasync function loadCachedRules(projectId: string): Promise<CachedRules | null> {\n try {\n const cachePath = path.join(process.cwd(), CACHE_FILE);\n const content = await fs.readFile(cachePath, 'utf-8');\n const cached: CachedRules = JSON.parse(content);\n\n if (cached.projectId !== projectId) {\n return null;\n }\n\n return cached;\n } catch {\n return null;\n }\n}\n\nasync function saveCachedRules(projectId: string, rules: EffectiveRule[]): Promise<void> {\n try {\n const cacheDir = path.join(process.cwd(), '.rigstate');\n await fs.mkdir(cacheDir, { recursive: true });\n\n const cached: CachedRules = {\n timestamp: new Date().toISOString(),\n projectId,\n rules,\n settings: { lmax: 400, lmax_warning: 350 }\n };\n\n await fs.writeFile(\n path.join(cacheDir, 'rules-cache.json'),\n JSON.stringify(cached, null, 2)\n );\n } catch {\n // Silently fail cache write\n }\n}\n","/**\n * Bridge Listener - Connects to Agent Bridge for task polling\n * \n * Uses polling as Supabase Realtime requires direct SDK access\n * which is complex in CLI context. Polling every 5 seconds\n * provides good responsiveness for task-based workflows.\n */\n\nimport axios from 'axios';\nimport { EventEmitter } from 'events';\n\nexport interface BridgeListenerEvents {\n task: (task: BridgeTask) => void;\n ping: () => void;\n error: (error: Error) => void;\n connected: () => void;\n disconnected: () => void;\n}\n\nexport interface BridgeTask {\n id: string;\n project_id: string;\n task_id: string | null;\n status: string;\n proposal: string | null;\n summary: string | null;\n created_at: string;\n}\n\nexport interface BridgeListener extends EventEmitter {\n connect(): Promise<void>;\n disconnect(): Promise<void>;\n on<K extends keyof BridgeListenerEvents>(event: K, listener: BridgeListenerEvents[K]): this;\n emit<K extends keyof BridgeListenerEvents>(event: K, ...args: Parameters<BridgeListenerEvents[K]>): boolean;\n}\n\nconst POLL_INTERVAL_MS = 5000; // 5 seconds\n\nexport function createBridgeListener(\n projectId: string,\n apiUrl: string,\n apiKey: string\n): BridgeListener {\n const emitter = new EventEmitter() as BridgeListener;\n let pollInterval: NodeJS.Timeout | null = null;\n let isConnected = false;\n let lastCheckedId: string | null = null;\n\n const checkBridge = async () => {\n try {\n const response = await axios.get(`${apiUrl}/api/v1/agent/bridge`, {\n params: {\n project_id: projectId,\n action: 'check'\n },\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 10000\n });\n\n if (response.data.success && response.data.data?.task) {\n const task = response.data.data.task;\n\n // Check if this is a new task\n if (task.id !== lastCheckedId) {\n lastCheckedId = task.id;\n\n // Check for ping/heartbeat\n if (task.proposal?.startsWith('ping')) {\n emitter.emit('ping');\n\n // Auto-acknowledge ping\n await acknowledgePing(task.id);\n } else {\n // Emit task for processing\n emitter.emit('task', task);\n }\n }\n }\n } catch (error: any) {\n // Don't emit error for network issues during polling\n // as this is expected when offline\n if (error.code !== 'ECONNREFUSED' && error.code !== 'ETIMEDOUT') {\n emitter.emit('error', error);\n }\n }\n };\n\n const acknowledgePing = async (taskId: string) => {\n try {\n await axios.post(`${apiUrl}/api/v1/agent/bridge`, {\n project_id: projectId,\n action: 'update',\n bridge_id: taskId,\n status: 'COMPLETED',\n summary: 'Pong! Guardian Daemon is active.'\n }, {\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 5000\n });\n } catch {\n // Silently fail ping acknowledgment\n }\n };\n\n emitter.connect = async () => {\n if (isConnected) return;\n\n // Initial check\n await checkBridge();\n\n // Start polling\n pollInterval = setInterval(checkBridge, POLL_INTERVAL_MS);\n isConnected = true;\n emitter.emit('connected');\n };\n\n emitter.disconnect = async () => {\n if (pollInterval) {\n clearInterval(pollInterval);\n pollInterval = null;\n }\n isConnected = false;\n emitter.emit('disconnected');\n };\n\n return emitter;\n}\n","import axios from 'axios';\n\n/**\n * Reports skill usage to the Rigstate Cloud.\n */\nexport async function trackSkillUsage(\n apiUrl: string,\n apiKey: string,\n projectId: string,\n skillId: string\n) {\n try {\n await axios.post(`${apiUrl}/api/v1/skills/usage`, {\n projectId,\n skillName: skillId,\n status: 'ACTIVATED'\n }, {\n headers: { 'x-api-key': apiKey }\n });\n } catch (e) {\n // Silhouette feedback failure - do not interrupt user\n }\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport inquirer from 'inquirer';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\n\nexport function createWorkCommand(): Command {\n return new Command('work')\n .alias('start')\n .description('Select and execute a Roadmap Task (fetches IDE Prompt)')\n .argument('[taskId]', 'Optional Task ID (e.g., T-1021) to start immediately')\n .option('--project <id>', 'Project ID')\n .action(async (taskId: string | undefined, options: { project?: string }) => {\n const spinner = ora();\n\n try {\n const apiKey = getApiKey();\n const apiUrl = getApiUrl();\n const projectId = options.project || getProjectId();\n\n if (!projectId) {\n console.log(chalk.red('❌ Project ID is required. Run `rigstate link` or pass --project <id>'));\n process.exit(1);\n }\n\n if (!taskId) {\n spinner.start('Fetching active roadmap tasks...');\n }\n\n // 1. Fetch Roadmap\n const response = await axios.get(\n `${apiUrl}/api/v1/roadmap?project_id=${projectId}`,\n { headers: { 'Authorization': `Bearer ${apiKey}` }, timeout: 10000 }\n );\n\n if (!response.data.success) {\n throw new Error(response.data.error || 'Failed to fetch roadmap');\n }\n\n const allTasks: any[] = response.data.data.roadmap || [];\n\n // 2. Filter relevant tasks (ACTIVE or LOCKED or IN_PROGRESS if we had that status)\n // We focus on ACTIVE (Started) and LOCKED (Next Up).\n // Sort: ACTIVE first, then by step_number.\n const actionableTasks = allTasks\n .filter(t => ['ACTIVE', 'LOCKED'].includes(t.status))\n .sort((a, b) => {\n if (a.status === 'ACTIVE' && b.status !== 'ACTIVE') return -1;\n if (b.status === 'ACTIVE' && a.status !== 'ACTIVE') return 1;\n return a.step_number - b.step_number;\n });\n\n spinner.stop();\n\n let selectedTask: any;\n\n if (taskId) {\n // Direct Selection via Arg\n // taskId can be \"T-1021\" or just \"1021\" or the UUID\n selectedTask = allTasks.find(t =>\n t.id === taskId ||\n `T-${t.step_number}` === taskId ||\n t.step_number.toString() === taskId\n );\n\n if (!selectedTask) {\n console.log(chalk.red(`❌ Task '${taskId}' not found in roadmap.`));\n return;\n }\n } else {\n // Interactive Selection\n if (actionableTasks.length === 0) {\n console.log(chalk.yellow('No active or locked tasks found. The Roadmap is clear! 🎉'));\n return;\n }\n\n const choices = actionableTasks.map(t => {\n const id = `T-${t.step_number}`;\n const statusIcon = t.status === 'ACTIVE' ? '▶️' : '🔒';\n const priority = t.priority === 'MVP' ? chalk.magenta('[MVP]') : chalk.blue(`[${t.priority}]`);\n\n return {\n name: `${statusIcon} ${chalk.bold(id)}: ${t.title} ${priority}`,\n value: t,\n short: `${id}: ${t.title}`\n };\n });\n\n const answer = await inquirer.prompt([{\n type: 'list',\n name: 'task',\n message: 'Which task are you working on?',\n choices,\n pageSize: 15\n }]);\n\n selectedTask = answer.task;\n }\n\n // 3. Display Task Context & Prompt\n console.log('\\n' + chalk.bold.underline(`🚀 WORK MODE: ${selectedTask.title}`));\n console.log(chalk.dim(`ID: T-${selectedTask.step_number} | Status: ${selectedTask.status}`));\n\n if (selectedTask.prompt_content) {\n console.log(chalk.yellow.bold('\\n📋 IDE EXECUTION SIGNAL (Prompt):'));\n console.log(chalk.gray('--------------------------------------------------'));\n console.log(selectedTask.prompt_content);\n console.log(chalk.gray('--------------------------------------------------'));\n\n // Copy to clipboard option?\n // For now, let's offer to save it to a file which is more robust for Agents.\n\n const { action } = await inquirer.prompt([{\n type: 'list',\n name: 'action',\n message: 'What do you want to do?',\n choices: [\n { name: 'Copy Prompt (Print clean)', value: 'print' },\n { name: 'Create .cursorrules (Agent Context)', value: 'cursorrules' },\n { name: 'Mark as ACTIVE (if LOCKED)', value: 'activate' },\n { name: 'Mark as COMPLETED', value: 'complete' },\n { name: 'Cancel', value: 'cancel' }\n ]\n }]);\n\n if (action === 'cursorrules') {\n // Create a temporary .cursorrules or overwrite existing\n // Warning: this ignores strict existing cursorrules, maybe append?\n // For safety, let's create a .rigstate-context.md file\n await fs.writeFile('.rigstate-prompt.md', selectedTask.prompt_content);\n console.log(chalk.green(`✅ Prompt saved to ${chalk.bold('.rigstate-prompt.md')}`));\n console.log(chalk.dim('You can now reference this file in your IDE chat (@.rigstate-prompt.md)'));\n } else if (action === 'print') {\n console.log('\\n' + selectedTask.prompt_content + '\\n');\n } else if (action === 'activate' && selectedTask.status !== 'ACTIVE') {\n try {\n await axios.post(\n `${apiUrl}/api/v1/roadmap/update-status`,\n { step_id: selectedTask.id, status: 'ACTIVE', project_id: projectId },\n { headers: { 'Authorization': `Bearer ${apiKey}` } }\n );\n console.log(chalk.green(`✅ Task marked as ACTIVE.`));\n } catch (e: any) {\n console.error(chalk.red(`Failed to update status: ${e.message}`));\n }\n } else if (action === 'complete') {\n try {\n await axios.post(\n `${apiUrl}/api/v1/roadmap/update-status`,\n { step_id: selectedTask.id, status: 'COMPLETED', project_id: projectId },\n { headers: { 'Authorization': `Bearer ${apiKey}` } }\n );\n console.log(chalk.green(`✅ Task marked as COMPLETED. Great job!`));\n } catch (e: any) {\n console.error(chalk.red(`Failed to update status: ${e.message}`));\n }\n }\n\n } else {\n console.log(chalk.yellow('\\n⚠️ No specific IDE Prompt found for this task (Legacy Task?).'));\n console.log(chalk.dim('Objective: ' + (selectedTask.summary || selectedTask.description || 'Check web UI for details.')));\n }\n\n } catch (error: any) {\n spinner.stop();\n console.error(chalk.red(`\\nCommand failed: ${error.message}`));\n }\n });\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport chokidar from 'chokidar';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { execSync } from 'child_process';\nimport { getApiKey, getProjectId, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\n\ninterface VerificationCriteria {\n type: 'file_exists' | 'file_content' | 'content_match';\n path: string;\n pattern?: string;\n match?: string;\n}\n\nexport function createWatchCommand() {\n const watch = new Command('watch');\n\n watch\n .description('Watch for changes and auto-verify roadmap tasks')\n .option('--no-auto-commit', 'Disable auto-commit on verification')\n .option('--no-auto-push', 'Disable auto-push after commit')\n .option('--run-tests', 'Run tests before committing')\n .option('--test-command <cmd>', 'Custom test command (default: npm test)')\n .action(async (options) => {\n console.log(chalk.bold.blue('🔭 Rigstate Watch Mode'));\n console.log(chalk.dim('Monitoring for task completion...'));\n console.log('');\n\n // Get config\n let apiKey: string;\n let projectId: string | undefined;\n\n try {\n apiKey = getApiKey();\n } catch (e) {\n console.log(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n projectId = getProjectId();\n if (!projectId) {\n // Try to read from local manifest\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const content = await fs.readFile(manifestPath, 'utf-8');\n const manifest = JSON.parse(content);\n projectId = manifest.project_id;\n } catch (e) { }\n }\n\n if (!projectId) {\n console.log(chalk.red('No project context. Run \"rigstate link\" or \"rigstate sync --project <id>\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n\n // Settings\n const config = {\n autoCommit: options.autoCommit !== false,\n autoPush: options.autoPush !== false,\n runTests: options.runTests || false,\n testCommand: options.testCommand || 'npm test'\n };\n\n console.log(chalk.dim(`Auto-commit: ${config.autoCommit ? 'ON' : 'OFF'}`));\n console.log(chalk.dim(`Auto-push: ${config.autoPush ? 'ON' : 'OFF'}`));\n console.log('');\n\n // Fetch active task\n const fetchActiveTask = async () => {\n try {\n const response = await axios.get(`${apiUrl}/api/v1/roadmap`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!response.data.success) return null;\n\n const roadmap = response.data.data.roadmap || [];\n\n // Priority: IN_PROGRESS > ACTIVE > LOCKED\n const statusPriority: Record<string, number> = {\n 'IN_PROGRESS': 0,\n 'ACTIVE': 1,\n 'LOCKED': 2\n };\n\n const activeTasks = roadmap\n .filter((t: any) => ['IN_PROGRESS', 'ACTIVE', 'LOCKED'].includes(t.status))\n .sort((a: any, b: any) => {\n const pA = statusPriority[a.status] ?? 99;\n const pB = statusPriority[b.status] ?? 99;\n if (pA !== pB) return pA - pB;\n return (a.step_number || 0) - (b.step_number || 0);\n });\n\n return activeTasks[0] || null;\n } catch (e) {\n return null;\n }\n };\n\n // Check verification criteria\n const checkCriteria = async (criteria: VerificationCriteria): Promise<boolean> => {\n try {\n const fullPath = path.resolve(process.cwd(), criteria.path);\n\n switch (criteria.type) {\n case 'file_exists':\n await fs.access(fullPath);\n return true;\n\n case 'file_content':\n const content = await fs.readFile(fullPath, 'utf-8');\n return content.length > 0;\n\n case 'content_match':\n if (!criteria.match) return false;\n const fileContent = await fs.readFile(fullPath, 'utf-8');\n return fileContent.includes(criteria.match);\n\n default:\n return false;\n }\n } catch (e) {\n return false;\n }\n };\n\n // Complete task\n const completeTask = async (taskId: string, task: any) => {\n const spinner = ora('Completing task...').start();\n\n try {\n // Run tests if enabled\n if (config.runTests) {\n spinner.text = 'Running tests...';\n try {\n execSync(config.testCommand, { stdio: 'pipe' });\n spinner.text = 'Tests passed!';\n } catch (e) {\n spinner.fail('Tests failed. Task not completed.');\n return;\n }\n }\n\n // Update status via API\n await axios.post(`${apiUrl}/api/v1/roadmap/update-status`, {\n project_id: projectId,\n chunk_id: taskId,\n status: 'COMPLETED'\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n spinner.succeed(chalk.green(`✅ Task #${task.step_number} completed: ${task.title}`));\n\n // Auto-commit\n if (config.autoCommit) {\n spinner.start('Committing changes...');\n try {\n execSync('git add -A', { stdio: 'pipe' });\n const commitMsg = `feat: Complete task #${task.step_number} - ${task.title}`;\n execSync(`git commit -m \"${commitMsg}\"`, { stdio: 'pipe' });\n spinner.succeed('Changes committed');\n\n // Auto-push\n if (config.autoPush) {\n spinner.start('Pushing to remote...');\n try {\n execSync('git push', { stdio: 'pipe' });\n spinner.succeed('Pushed to remote');\n } catch (e) {\n spinner.warn('Push failed (no remote or conflict)');\n }\n }\n } catch (e: any) {\n spinner.warn('Nothing to commit or commit failed');\n }\n }\n\n console.log('');\n console.log(chalk.blue('Watching for next task...'));\n\n } catch (e: any) {\n spinner.fail(`Failed to complete task: ${e.message}`);\n }\n };\n\n // Main watch loop\n let currentTask: any = null;\n let isProcessing = false;\n\n const processActiveTask = async () => {\n if (isProcessing) return;\n isProcessing = true;\n\n const task = await fetchActiveTask();\n\n if (!task) {\n if (currentTask) {\n console.log(chalk.green('🎉 All tasks completed! Watching for new tasks...'));\n currentTask = null;\n }\n isProcessing = false;\n return;\n }\n\n if (!currentTask || currentTask.id !== task.id) {\n currentTask = task;\n console.log('');\n console.log(chalk.bold.yellow(`📌 Active Task #${task.step_number}: ${task.title}`));\n console.log(chalk.dim(`Status: ${task.status}`));\n\n if (task.verification_criteria) {\n console.log(chalk.dim('Verification: Auto-checking criteria...'));\n }\n }\n\n // Check verification criteria if present\n if (task.verification_criteria && Array.isArray(task.verification_criteria)) {\n let allPassed = true;\n for (const criteria of task.verification_criteria) {\n const passed = await checkCriteria(criteria);\n if (!passed) {\n allPassed = false;\n break;\n }\n }\n\n if (allPassed) {\n console.log(chalk.green('✓ All verification criteria passed!'));\n await completeTask(task.id, task);\n currentTask = null;\n }\n }\n\n isProcessing = false;\n };\n\n // Initial check\n await processActiveTask();\n\n // Set up file watcher\n const watcher = chokidar.watch('.', {\n ignored: [\n /(^|[\\/\\\\])\\../, // dotfiles\n '**/node_modules/**',\n '**/.git/**',\n '**/.next/**',\n '**/dist/**'\n ],\n persistent: true,\n ignoreInitial: true\n });\n\n watcher.on('all', async (event, filePath) => {\n if (['add', 'change', 'unlink'].includes(event)) {\n // Debounce - wait a bit for multiple rapid changes\n setTimeout(() => processActiveTask(), 500);\n }\n });\n\n console.log(chalk.dim('Watching for file changes... (Ctrl+C to exit)'));\n\n // Periodic check every 30 seconds\n setInterval(() => processActiveTask(), 30000);\n\n // Keep process alive\n process.on('SIGINT', () => {\n console.log('');\n console.log(chalk.dim('Watch mode stopped.'));\n watcher.close();\n process.exit(0);\n });\n });\n\n return watch;\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { getApiKey, getProjectId, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\nimport { execSync } from 'child_process';\nimport fs from 'fs/promises';\nimport path from 'path';\n\nexport function createFocusCommand() {\n const focus = new Command('focus');\n\n focus\n .alias('task')\n .description('Get the next active roadmap task and copy its prompt to clipboard')\n .option('--no-copy', 'Do not copy to clipboard')\n .action(async (options) => {\n const spinner = ora('Fetching next objective...').start();\n\n // Get config\n let apiKey: string;\n let projectId: string | undefined;\n\n try {\n apiKey = getApiKey();\n } catch (e) {\n spinner.fail(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n projectId = getProjectId();\n if (!projectId) {\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const content = await fs.readFile(manifestPath, 'utf-8');\n const manifest = JSON.parse(content);\n projectId = manifest.project_id;\n } catch (e) { }\n }\n\n if (!projectId) {\n spinner.fail(chalk.red('No project context. Run \"rigstate link\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n\n try {\n // Fetch roadmap\n const response = await axios.get(`${apiUrl}/api/v1/roadmap`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!response.data.success) {\n throw new Error(response.data.error || 'Failed to fetch roadmap');\n }\n\n const roadmap = response.data.data.roadmap || [];\n\n // Priority: IN_PROGRESS > ACTIVE > LOCKED\n const statusPriority: Record<string, number> = {\n 'IN_PROGRESS': 0,\n 'ACTIVE': 1,\n 'LOCKED': 2\n };\n\n const activeTasks = roadmap\n .filter((t: any) => ['IN_PROGRESS', 'ACTIVE', 'LOCKED'].includes(t.status))\n .sort((a: any, b: any) => {\n const pA = statusPriority[a.status] ?? 99;\n const pB = statusPriority[b.status] ?? 99;\n if (pA !== pB) return pA - pB;\n return (a.step_number || 0) - (b.step_number || 0);\n });\n\n if (activeTasks.length === 0) {\n spinner.succeed('All caught up! No active tasks found.');\n return;\n }\n\n const nextTask = activeTasks[0];\n spinner.stop();\n\n // Display\n console.log('');\n console.log(chalk.bold.blue(`📌 Task #${nextTask.step_number || '?'}: ${nextTask.title}`));\n\n const statusColor = nextTask.status === 'IN_PROGRESS' ? chalk.yellow :\n nextTask.status === 'ACTIVE' ? chalk.green : chalk.dim;\n\n console.log(chalk.dim('Status: ') + statusColor(nextTask.status));\n console.log(chalk.dim('─'.repeat(60)));\n\n if (nextTask.prompt_content) {\n console.log(chalk.white(nextTask.prompt_content));\n console.log(chalk.dim('─'.repeat(60)));\n\n // Auto-copy for Mac\n if (options.copy !== false) {\n try {\n if (process.platform === 'darwin') {\n execSync('pbcopy', { input: nextTask.prompt_content });\n console.log(chalk.green('✅ Prompt copied to clipboard! Ready to paste (Cmd+V).'));\n } else if (process.platform === 'linux') {\n try {\n execSync('xclip -selection clipboard', { input: nextTask.prompt_content });\n console.log(chalk.green('✅ Prompt copied to clipboard!'));\n } catch (e) {\n console.log(chalk.yellow('ℹ️ Copy prompt manually (xclip not available)'));\n }\n } else {\n console.log(chalk.yellow('ℹ️ Copy prompt manually (Auto-copy not supported on this OS)'));\n }\n } catch (e) {\n // ignore copy error\n }\n }\n } else {\n console.log(chalk.yellow('No prompt instructions available.'));\n if (nextTask.architectural_brief) {\n console.log(chalk.bold('Brief:'));\n console.log(nextTask.architectural_brief);\n }\n }\n console.log('');\n\n } catch (e: any) {\n spinner.fail(chalk.red(`Failed to fetch task: ${e.message}`));\n }\n });\n\n return focus;\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport { getApiKey, setApiKey, getProjectId, setProjectId, getApiUrl } from '../utils/config.js';\n\nexport function createConfigCommand() {\n const config = new Command('config');\n\n config\n .description('View or modify Rigstate configuration')\n .argument('[key]', 'Configuration key to view/set (api_key, project_id, api_url)')\n .argument('[value]', 'Value to set')\n .action(async (key?: string, value?: string) => {\n // No arguments - show all config\n if (!key) {\n console.log(chalk.bold('Rigstate Configuration'));\n console.log(chalk.dim('─'.repeat(40)));\n\n try {\n const apiKey = getApiKey();\n console.log(`${chalk.cyan('api_key')}: ${apiKey.substring(0, 20)}...`);\n } catch (e) {\n console.log(`${chalk.cyan('api_key')}: ${chalk.dim('(not set)')}`);\n }\n\n const projectId = getProjectId();\n console.log(`${chalk.cyan('project_id')}: ${projectId || chalk.dim('(not set)')}`);\n\n const apiUrl = getApiUrl();\n console.log(`${chalk.cyan('api_url')}: ${apiUrl}`);\n\n console.log('');\n console.log(chalk.dim('Use \"rigstate config <key> <value>\" to set a value.'));\n return;\n }\n\n // Get specific key\n if (!value) {\n switch (key) {\n case 'api_key':\n try {\n const apiKey = getApiKey();\n console.log(apiKey);\n } catch (e) {\n console.log(chalk.dim('(not set)'));\n }\n break;\n case 'project_id':\n console.log(getProjectId() || chalk.dim('(not set)'));\n break;\n case 'api_url':\n console.log(getApiUrl());\n break;\n default:\n console.log(chalk.red(`Unknown config key: ${key}`));\n console.log(chalk.dim('Valid keys: api_key, project_id, api_url'));\n }\n return;\n }\n\n // Set value\n switch (key) {\n case 'api_key':\n setApiKey(value);\n console.log(chalk.green(`✅ api_key updated`));\n break;\n case 'project_id':\n setProjectId(value);\n console.log(chalk.green(`✅ project_id updated`));\n break;\n case 'api_url':\n // api_url is not settable via this command for now\n console.log(chalk.yellow('api_url is set via RIGSTATE_API_URL environment variable'));\n break;\n default:\n console.log(chalk.red(`Unknown config key: ${key}`));\n console.log(chalk.dim('Valid keys: api_key, project_id'));\n }\n });\n\n return config;\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport { spawn } from 'child_process';\nimport path from 'path';\nimport fs from 'fs';\nimport { fileURLToPath } from 'url';\n\n// ESM compatibility for __dirname\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = path.dirname(__filename);\n\nexport function createMcpCommand() {\n const mcp = new Command('mcp');\n\n mcp\n .description('Run the Rigstate MCP server for AI editors')\n .action(async () => {\n // Determine the path to the MCP server\n const possiblePaths = [\n // From packages/cli -> packages/mcp (sibling package)\n path.resolve(__dirname, '../../mcp/dist/index.js'),\n // If installed globally or via npm\n path.resolve(__dirname, '../../../mcp/dist/index.js'),\n // Development path from packages/cli/dist\n path.resolve(__dirname, '../../../packages/mcp/dist/index.js'),\n ];\n\n let serverPath = '';\n for (const p of possiblePaths) {\n if (fs.existsSync(p)) {\n serverPath = p;\n break;\n }\n }\n\n if (!serverPath) {\n console.error(chalk.red('❌ Error: Rigstate MCP Server binary not found.'));\n console.error(chalk.yellow('Please ensure that the mcp package is built:'));\n console.error(chalk.white(' cd packages/mcp && npm run build'));\n console.error('');\n console.error(chalk.dim('Or run directly with:'));\n console.error(chalk.white(' npx @rigstate/mcp'));\n process.exit(1);\n }\n\n console.log(chalk.dim(`Starting MCP server from: ${serverPath}`));\n\n // Map VIBE_API_KEY to RIGSTATE_API_KEY if needed (backwards compatibility)\n if (process.env.VIBE_API_KEY && !process.env.RIGSTATE_API_KEY) {\n process.env.RIGSTATE_API_KEY = process.env.VIBE_API_KEY;\n }\n\n // Spawn the MCP server as a child process\n // MCP uses stdio for communication, so we inherit it\n const worker = spawn('node', [serverPath], {\n env: process.env,\n stdio: ['inherit', 'inherit', 'inherit']\n });\n\n worker.on('error', (err) => {\n console.error(chalk.red(`❌ Failed to start MCP server: ${err.message}`));\n process.exit(1);\n });\n\n worker.on('exit', (code) => {\n if (code !== 0 && code !== null) {\n process.exit(code);\n }\n });\n });\n\n return mcp;\n}\n","\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { NexusDispatcher } from '../nexus/dispatcher.js';\nimport { NexusContext } from '@rigstate/shared';\nimport inquirer from 'inquirer';\n\nexport function createNexusCommand() {\n const command = new Command('nexus');\n\n command\n .description('Interact with The Multi-Agent Nexus (Phase 8)')\n .argument('<intent>', 'The natural language instruction for the swarm')\n .option('--dry-run', 'Enable Dry-Run mode (Kill-Switch Active)', true)\n .option('--force', 'Disable Dry-Run mode (DANGEROUS)', false)\n .action(async (intent: string, options) => {\n console.log(chalk.bold.magenta('\\n🦁 Welcome to The Nexus (Phase 8)\\n'));\n\n const dryRun = !options.force;\n\n if (!dryRun) {\n console.log(chalk.black.bgYellow(' WARNING ') + chalk.yellow(' Dry-Run disabled! Eitri is authorized to write code.'));\n const { confirm } = await inquirer.prompt([{\n type: 'confirm',\n name: 'confirm',\n message: 'Are you absolutely sure you want to bypass the Kill-Switch?',\n default: false\n }]);\n if (!confirm) {\n console.log('Aborting.');\n process.exit(0);\n }\n }\n\n // Context setup\n const context: NexusContext = {\n projectId: process.env.RIGSTATE_PROJECT_ID || 'local',\n rootPath: process.cwd(),\n sessionUser: 'cli-user', // Should strictly be pulled from auth\n dryRun\n };\n\n const dispatcher = new NexusDispatcher(context);\n\n // Setup Listeners for Visualization\n dispatcher.on('order:created', (o) => {\n console.log(chalk.blue(`🆕 [${o.id.slice(0, 6)}] Order Created: `) + o.intent);\n });\n\n dispatcher.on('order:started', (o) => {\n console.log(chalk.yellow(`⏳ [${o.id.slice(0, 6)}] Processing...`));\n });\n\n dispatcher.on('order:blocked', (o) => {\n console.log(chalk.red(`🛑 [${o.id.slice(0, 6)}] BLOCKED by Kill-Switch`));\n console.log(chalk.dim(` Target: ${o.targetAgent} | Action: ${o.action}`));\n console.log(chalk.dim(' Run with --force to execute automatically (NOT RECOMMENDED).'));\n });\n\n dispatcher.on('agent:SINDRE', (o) => console.log(chalk.cyan(`🤖 Sindre (Vault): I'm on it! (${o.action})`)));\n dispatcher.on('agent:EITRI', (o) => console.log(chalk.green(`👷 Eitri (Smith): Ready to build! (${o.action})`)));\n\n // Simulation: Frank Analysis Logic\n // In a real scenario, this would call LLM/MCP to get the decomposition.\n // Here we hardcode a mocked response to demonstrate the CLI flow.\n\n console.log(chalk.dim('🧠 Frank is analyzing your intent...'));\n await new Promise(r => setTimeout(r, 800)); // Simulate thinking\n\n // MOCK: Dispatch logic\n if (intent.toLowerCase().includes('db') || intent.toLowerCase().includes('database')) {\n await dispatcher.dispatch('FRANK', 'SINDRE', intent, 'db.analyze', { raw: intent });\n } else if (intent.toLowerCase().includes('create') || intent.toLowerCase().includes('code')) {\n await dispatcher.dispatch('FRANK', 'EITRI', intent, 'fs.write', { path: 'src/demo.ts', content: '// demo' });\n } else {\n console.log(chalk.gray(\"Frank didn't understand. Try 'create file' or 'check database'.\"));\n }\n });\n\n return command;\n}\n","\nimport EventEmitter from 'events';\nimport { ServiceOrder, SwarmAgent, NexusContext } from '@rigstate/shared';\nimport { v4 as uuidv4 } from 'uuid';\n\nimport { HiveGateway } from '../hive/gateway';\nimport { Logger } from '../utils/logger';\n\n/**\n * THE NEXUS DISPATCHER\n * \"The Brain Stem\" of Rigstate.\n * Routes ServiceOrders between agents and enforces the Human Kill-Switch.\n */\nexport class NexusDispatcher extends EventEmitter {\n private context: NexusContext;\n private orderQueue: ServiceOrder[] = [];\n private orderHistory: ServiceOrder[] = [];\n private gateway: HiveGateway;\n\n constructor(context: NexusContext) {\n super();\n this.context = context;\n this.gateway = new HiveGateway(\n process.env.RIGSTATE_HIVE_URL || 'https://rigstate.com/api/hive',\n process.env.RIGSTATE_HIVE_TOKEN\n );\n Logger.info(`🧠 NEXUS DISPATCHER ONLINE. Context: ${context.projectId} (DryRun: ${context.dryRun})`);\n }\n\n /**\n * Creates a new Service Order and routes it.\n */\n public async dispatch(\n source: SwarmAgent,\n target: SwarmAgent,\n intent: string,\n action: string,\n params: Record<string, any>,\n constraints: string[] = []\n ): Promise<ServiceOrder> {\n\n const order: ServiceOrder = {\n id: uuidv4(),\n traceId: uuidv4(), // TODO: Inherit traceId if chained\n sourceAgent: source,\n targetAgent: target,\n priority: 'NORMAL',\n intent,\n action,\n parameters: params,\n constraints,\n status: 'PENDING',\n createdAt: new Date().toISOString()\n };\n\n this.orderQueue.push(order);\n this.emit('order:created', order);\n\n // Security / Kill-Switch Check\n // EITRI (The Smith) is the only one who can hammer the metal (write files)\n if (target === 'EITRI' && order.action.startsWith('fs.write')) {\n if (this.context.dryRun) {\n Logger.info(`🛑 NEXUS KILL-SWITCH: Order ${order.id} blocked by Dry-Run protocol.`);\n order.status = 'PENDING'; // Kept as PENDING but blocked\n // Ideally status should represent AWAITING_APPROVAL explicitly\n // But for now strict dry-run just prevents execution\n this.emit('order:blocked', order);\n return order;\n }\n }\n\n // If automatic or dry-run disabled\n return this.executeOrder(order);\n }\n\n /**\n * Executes the order (simulated for now, essentially \"Sending\" it)\n */\n private async executeOrder(order: ServiceOrder): Promise<ServiceOrder> {\n order.status = 'EXECUTING';\n order.startedAt = new Date().toISOString();\n this.emit('order:started', order);\n\n try {\n Logger.info(`🚀 NEXUS: Routing Order ${order.id} [${order.sourceAgent} -> ${order.targetAgent}]: ${order.intent}`);\n\n // SPECIAL ROUTING: HIVE UPLINK\n if (order.targetAgent === 'MAJA' && order.action === 'HIVE_TRANSMIT') {\n const signal = order.parameters.signal;\n if (signal) {\n await this.gateway.transmit(signal);\n order.status = 'COMPLETED';\n return order;\n }\n }\n\n // Here we would actually call the Agent's handler function\n // For now, we just emit the specific event for listeners\n this.emit(`agent:${order.targetAgent}`, order);\n\n // Simulation of async completion would happen via callback/promise resolution elsewhere\n return order;\n\n } catch (error: unknown) {\n const errorMessage = error instanceof Error ? error.message : 'Unknown error occurred';\n Logger.error(`Dispatch failed for order ${order.id}`, error);\n\n order.status = 'FAILED';\n order.error = {\n code: 'DISPATCH_ERROR',\n message: errorMessage\n };\n this.emit('order:failed', order);\n return order;\n }\n }\n\n /**\n * Human Approval (The \"Red Button\")\n */\n public async approveOrder(orderId: string): Promise<void> {\n const order = this.orderQueue.find(o => o.id === orderId);\n if (!order) throw new Error(`Order ${orderId} not found`);\n\n if (order.status !== 'AWAITING_APPROVAL') {\n Logger.warn(`Order ${orderId} is not awaiting approval (Status: ${order.status})`);\n return;\n }\n\n Logger.info(`✅ HUMAN APPROVED Order ${orderId}`);\n await this.executeOrder(order);\n }\n}\n","\nimport axios, { AxiosInstance } from 'axios';\nimport { ImmuneSignal } from './protocol';\nimport { HiveScrubber } from './scrubber';\nimport chalk from 'chalk';\n\n/**\n * THE HIVE GATEWAY\n * Connects the local Rigstate instance to the Global Hive Mind (rigstate.com).\n */\nexport class HiveGateway {\n private client: AxiosInstance;\n private enabled: boolean;\n private lastSignalTime: number = 0;\n private readonly MIN_INTERVAL_MS = 5000; // Throttle: Max 1 signal per 5s\n\n constructor(baseUrl: string, token?: string) {\n this.enabled = !!token;\n\n if (!this.enabled) {\n console.log(chalk.dim('⚠️ Hive Gateway disabled (No Token provided). Running in localized mode.'));\n }\n\n this.client = axios.create({\n baseURL: baseUrl,\n headers: {\n 'Authorization': `Bearer ${token}`,\n 'Content-Type': 'application/json',\n 'X-Rigstate-Client': 'CLI-0.2.0'\n },\n timeout: 5000\n });\n }\n\n /**\n * Transmit an Immune Signal to the Hive.\n * Includes Pre-Flight Scrubbing and Throttling.\n */\n public async transmit(signal: ImmuneSignal): Promise<boolean> {\n if (!this.enabled) return false;\n\n // 1. THROTTLE CHECK\n const now = Date.now();\n if (now - this.lastSignalTime < this.MIN_INTERVAL_MS) {\n console.warn(chalk.yellow('⏳ Hive Gateway Throttled. Signal dropped to preventing spam.'));\n return false;\n }\n\n // 2. SCRUBBER VERIFICATION (Double Check)\n // Even if Frank ran it, we run it again here at the edge.\n const scrubResult = HiveScrubber.scrub(signal.ruleContent);\n if (scrubResult.riskScore > 20) {\n console.error(chalk.red(`🛑 HIVE BLOCKED: Signal contains sensitive data (Risk: ${scrubResult.riskScore})`));\n return false;\n }\n\n // 3. TRANSMISSION\n try {\n console.log(chalk.blue(`📡 Uplinking to Hive... [${signal.vector}]`));\n\n // Using the scrubbed content just to be 100% safe\n const payload = { ...signal, ruleContent: scrubResult.sanitizedContent };\n\n await this.client.post('/signal', payload);\n\n this.lastSignalTime = now;\n console.log(chalk.green('✅ Signal Received by Hive Core. Knowledge Shared.'));\n return true;\n } catch (error: any) {\n console.error(chalk.red(`❌ Hive Transmission Failed: ${error.message}`));\n return false;\n }\n }\n}\n","\n/**\n * THE HIVE SCRUBBER\n * Sanitizes local rules and signals before they are broadcast to the Global Registry.\n * Ensures strict anonymity.\n */\n\nexport interface ScrubberResult {\n sanitizedContent: string;\n redactionCount: number;\n riskScore: number; // 0-100 (If too high, do not broadcast)\n}\n\nexport class HiveScrubber {\n\n // Patterns that definitely identify a project and MUST be removed\n private static SENSITIVE_PATTERNS = [\n /(api_key|secret|token|password)[\\s]*[:=][\\s]*['\"][a-zA-Z0-9_\\-]+['\"]/gi, // Secrets\n /[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}/g, // Emails\n /(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\. (?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)/g, // IPs\n /postgres:\\/\\/[^:]+:[^@]+@/g, // DB Connection Strings\n ];\n\n // Generic replacements for project-specific terms to keep the rule abstract\n private static ABSTRACTION_MAP: Record<string, string> = {\n 'Vibeline': '{PROJECT_NAME}',\n 'Rigstate': '{FRAMEWORK}',\n 'Steinhofve': '{USER}',\n };\n\n /**\n * Scrubs a string (rule content or log excerpt) of sensitive data.\n */\n public static scrub(content: string, customTerms: string[] = []): ScrubberResult {\n let scrubbed = content;\n let count = 0;\n let risk = 0;\n\n // 1. Remove Hard Credentials (High Risk)\n this.SENSITIVE_PATTERNS.forEach(pattern => {\n if (pattern.test(scrubbed)) {\n scrubbed = scrubbed.replace(pattern, '[REDACTED_CREDENTIAL]');\n count++;\n risk += 50; // High penalty for finding secrets\n }\n });\n\n // 2. Abstract Project Specifics (Medium Risk)\n Object.entries(this.ABSTRACTION_MAP).forEach(([term, replacement]) => {\n const regex = new RegExp(term, 'gi');\n if (regex.test(scrubbed)) {\n scrubbed = scrubbed.replace(regex, replacement);\n count++;\n }\n });\n\n // 3. Scrub Custom Terms (e.g. Table names passed from context)\n customTerms.forEach(term => {\n const regex = new RegExp(term, 'gi');\n if (regex.test(scrubbed)) {\n scrubbed = scrubbed.replace(regex, '{ENTITY}');\n count++;\n }\n });\n\n return {\n sanitizedContent: scrubbed,\n redactionCount: count,\n riskScore: Math.min(risk, 100)\n };\n }\n}\n","import chalk from 'chalk';\n\nexport enum LogLevel {\n INFO = 'INFO',\n WARN = 'WARN',\n ERROR = 'ERROR',\n DEBUG = 'DEBUG'\n}\n\nexport class Logger {\n private static formatMessage(level: LogLevel, message: string, context?: unknown): string {\n const timestamp = new Date().toISOString();\n let prefix = '';\n\n switch (level) {\n case LogLevel.INFO:\n prefix = chalk.blue(`[${LogLevel.INFO}]`);\n break;\n case LogLevel.WARN:\n prefix = chalk.yellow(`[${LogLevel.WARN}]`);\n break;\n case LogLevel.ERROR:\n prefix = chalk.red(`[${LogLevel.ERROR}]`);\n break;\n case LogLevel.DEBUG:\n prefix = chalk.gray(`[${LogLevel.DEBUG}]`);\n break;\n }\n\n let output = `${chalk.gray(timestamp)} ${prefix} ${message}`;\n\n if (context) {\n if (context instanceof Error) {\n output += `\\n${chalk.red(context.stack || context.message)}`;\n } else if (typeof context === 'object') {\n try {\n output += `\\n${chalk.gray(JSON.stringify(context, null, 2))}`;\n } catch (e) {\n output += `\\n${chalk.gray('[Circular or invalid object]')}`;\n }\n } else {\n output += ` ${String(context)}`;\n }\n }\n\n return output;\n }\n\n static info(message: string, context?: unknown) {\n console.log(this.formatMessage(LogLevel.INFO, message, context));\n }\n\n static warn(message: string, context?: unknown) {\n console.warn(this.formatMessage(LogLevel.WARN, message, context));\n }\n\n static error(message: string, error?: unknown) {\n console.error(this.formatMessage(LogLevel.ERROR, message, error));\n }\n\n static debug(message: string, context?: unknown) {\n if (process.env.DEBUG || process.env.RIGSTATE_DEBUG) {\n console.debug(this.formatMessage(LogLevel.DEBUG, message, context));\n }\n }\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport { performOverride, getSessionState } from '../utils/governance.js';\nimport { getApiKey, getProjectId, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\n\nexport function createOverrideCommand() {\n const override = new Command('override');\n\n override\n .description('Emergency Override for Governance Soft Locks')\n .argument('<violationId>', 'ID of the violation to override (or \"all\")')\n .requiredOption('-r, --reason <reason>', 'Description of why this override is necessary')\n .action(async (violationId, options) => {\n const { reason } = options;\n\n console.log(chalk.bold(`\\n🔓 Initiating Governance Override Protocol...`));\n\n const session = await getSessionState(process.cwd());\n\n if (session.status !== 'SOFT_LOCK') {\n console.log(chalk.yellow(' Info: Session is not currently locked.'));\n return; // Not locked, but maybe we still want to log the \"intent\"?\n }\n\n console.log(chalk.dim(` Active Violation: ${session.active_violation}`));\n console.log(chalk.dim(` Reason Provided: \"${reason}\"`));\n\n // Perform Local Unlock\n const success = await performOverride(violationId, reason, process.cwd());\n\n if (success) {\n console.log(chalk.green(` ✅ Session UNLOCKED.`));\n console.log(chalk.dim(` This event has been logged to the Mission Report.`));\n\n // Optional: Notify Cloud about the Override (Audit Trail)\n try {\n const projectId = getProjectId();\n if (projectId) {\n const apiUrl = getApiUrl();\n const apiKey = getApiKey();\n\n await axios.post(`${apiUrl}/api/v1/execution-logs`, {\n project_id: projectId,\n task_id: 'OVERRIDE-' + Date.now(),\n task_title: `Governance Override: ${violationId}`,\n status: 'COMPLETED',\n execution_summary: `Manual override executed. Reason: ${reason}`,\n agent_role: 'SUPERVISOR' // Override is a supervisor action\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n console.log(chalk.dim(` ☁ Audit log synced to Cloud.`));\n }\n } catch (e: any) {\n console.log(chalk.dim(` (Cloud audit sync failed: ${e.message})`));\n }\n\n } else {\n console.log(chalk.red(` 🛑 Override Failed. Check project configuration.`));\n }\n });\n\n return override;\n}\n","export async function checkVersion() {}\n"],"mappings":"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","names":["Command","chalk","path","Command","chalk","ora","axios","fs","path","Command","chalk","fs","path","axios","fs","path","chalk","fs","path","chalk","config","InterventionLevel","fs","path","chalk","axios","getGovernanceConfig","setSoftLock","InterventionLevel","Command","chalk","Command","fs","path","chalk","config","getApiKey","getApiUrl","syncEnv","syncProjectRules","Command","chalk","ora","axios","fs","path","fs","path","Command","ora","chalk","path","fs","axios","Command","chalk","ora","axios","glob","fs","path","Command","ora","chalk","path","glob","fs","axios","Command","chalk","ora","axios","fs","path","provisionSkills","generateSkillsDiscoveryBlock","runGuardianWatchdog","Command","chalk","fs","path","ora","fs","path","axios","Command","ora","chalk","inquirer","path","fs","Command","chalk","ora","axios","glob","fs","path","execSync","fs","path","chalk","CACHE_FILE","Command","ora","chalk","axios","path","execSync","isCodeFile","glob","fs","Command","chalk","ora","fs","path","chalk","fs","EventEmitter","path","isCodeFile","absolutePath","path","axios","chalk","fs","path","axios","fs","path","CACHE_FILE","CACHE_TTL_MS","axios","saveCachedRules","loadCachedRules","path","fs","axios","EventEmitter","axios","EventEmitter","config","chalk","path","config","Command","ora","chalk","path","fs","Command","chalk","ora","axios","inquirer","fs","Command","chalk","ora","chokidar","fs","path","execSync","axios","watch","config","Command","chalk","ora","axios","execSync","fs","path","Command","chalk","config","Command","chalk","path","fs","fileURLToPath","__filename","__dirname","Command","chalk","EventEmitter","axios","chalk","axios","chalk","chalk","EventEmitter","inquirer","Command","chalk","Command","chalk","axios","Command","chalk"]}
1
+ {"version":3,"sources":["../node_modules/tsup/assets/esm_shims.js","../src/utils/config.ts","../src/commands/env.ts","../src/commands/sync-rules.ts","../src/commands/suggest.ts","../src/commands/hooks.ts","../src/utils/skills-provisioner.ts","../src/utils/governance.ts","../src/utils/watchdog.ts","../src/index.ts","../src/commands/login.ts","../src/commands/link.ts","../src/commands/scan.ts","../src/utils/files.ts","../src/commands/fix.ts","../src/commands/sync.ts","../src/commands/init.ts","../src/utils/manifest.ts","../src/commands/check.ts","../src/utils/rule-engine.ts","../src/commands/daemon.ts","../src/daemon/factory.ts","../src/daemon/core.ts","../src/daemon/file-watcher.ts","../src/daemon/heuristic-engine.ts","../src/daemon/intervention-protocol.ts","../src/daemon/guardian-monitor.ts","../src/daemon/bridge-listener.ts","../src/daemon/telemetry.ts","../src/commands/work.ts","../src/commands/watch.ts","../src/commands/focus.ts","../src/commands/config.ts","../src/commands/mcp.ts","../src/commands/nexus.ts","../src/nexus/dispatcher.ts","../src/hive/gateway.ts","../src/hive/scrubber.ts","../src/utils/logger.ts","../src/commands/override.ts","../src/utils/version.ts","../src/commands/idea.ts"],"sourcesContent":["// Shim globals in esm bundle\nimport path from 'node:path'\nimport { fileURLToPath } from 'node:url'\n\nconst getFilename = () => fileURLToPath(import.meta.url)\nconst getDirname = () => path.dirname(getFilename())\n\nexport const __dirname = /* @__PURE__ */ getDirname()\nexport const __filename = /* @__PURE__ */ getFilename()\n","import Conf from 'conf';\n\ninterface RigstateConfig {\n apiKey?: string;\n projectId?: string;\n apiUrl?: string;\n}\n\nconst config = new Conf<RigstateConfig>({\n projectName: 'rigstate-cli',\n defaults: {\n apiUrl: 'http://localhost:3000',\n },\n});\n\n/**\n * Get the stored API key\n * @throws {Error} If no API key is found (user not logged in)\n */\nexport function getApiKey(): string {\n const apiKey = config.get('apiKey');\n if (!apiKey) {\n throw new Error(\n '❌ Not logged in. Please run \"rigstate login <your-api-key>\" first.'\n );\n }\n return apiKey;\n}\n\n/**\n * Set the API key\n */\nexport function setApiKey(key: string): void {\n config.set('apiKey', key);\n}\n\n/**\n * Get the default project ID (if set)\n */\nexport function getProjectId(): string | undefined {\n return config.get('projectId');\n}\n\n/**\n * Set the default project ID\n */\nexport function setProjectId(projectId: string): void {\n config.set('projectId', projectId);\n}\n\n/**\n * Get the API URL\n * Priority: Environment variable > Stored config > Production default\n */\nexport function getApiUrl(): string {\n // 1. Check environment variable first\n if (process.env.RIGSTATE_API_URL) {\n return process.env.RIGSTATE_API_URL;\n }\n // 2. Check stored config\n const storedUrl = config.get('apiUrl');\n if (storedUrl) {\n return storedUrl;\n }\n // 3. Default to production\n return 'https://app.rigstate.com';\n}\n\n/**\n * Set the API URL\n */\nexport function setApiUrl(url: string): void {\n config.set('apiUrl', url);\n}\n\n/**\n * Clear all config\n */\nexport function clearConfig(): void {\n config.clear();\n}\n\nexport { config };\n","/* eslint-disable no-console */\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { getApiKey, getProjectId, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\n\n// Core Logic (Exported for re-use)\nexport async function syncEnv(projectId: string, apiKey: string, apiUrl: string, silent = false): Promise<boolean> {\n if (!silent) {\n console.log('');\n console.log(chalk.bold.yellow('╔══════════════════════════════════════════╗'));\n console.log(chalk.bold.yellow('║') + chalk.bold.white(' 🛡️ RIGSTATE SOVEREIGN VAULT SYNC 🛡️ ') + chalk.bold.yellow('║'));\n console.log(chalk.bold.yellow('╚══════════════════════════════════════════╝'));\n console.log('');\n }\n\n const spinner = ora('Fetching secrets from Vault...').start();\n\n try {\n const response = await axios.post(`${apiUrl}/api/v1/vault/sync`, {\n project_id: projectId\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!response.data.success) {\n throw new Error(response.data.error || 'Failed to fetch secrets');\n }\n\n const vaultContent = response.data.data.content || '';\n const secretCount = response.data.data.count || 0;\n\n if (secretCount === 0) {\n spinner.info('No secrets found in Vault for this project.');\n if (!silent) console.log(chalk.dim(' Add secrets via the Rigstate web interface.'));\n return true;\n }\n\n spinner.succeed(`Retrieved ${chalk.bold(secretCount)} secret(s)`);\n\n // Read existing .env.local for comparison\n const envFile = path.resolve(process.cwd(), '.env.local');\n let existingContent = '';\n let existingKeys: Set<string> = new Set();\n\n try {\n existingContent = await fs.readFile(envFile, 'utf-8');\n // Parse existing keys\n existingContent.split('\\n').forEach(line => {\n const match = line.match(/^([A-Z_][A-Z0-9_]*)=/);\n if (match) existingKeys.add(match[1]);\n });\n } catch (e) {\n // File doesn't exist\n }\n\n // Parse vault keys\n const vaultKeys: Set<string> = new Set();\n vaultContent.split('\\n').forEach((line: string) => {\n const match = line.match(/^([A-Z_][A-Z0-9_]*)=/);\n if (match) vaultKeys.add(match[1]);\n });\n\n // Calculate changes\n let newCount = 0;\n let updatedCount = 0;\n\n vaultKeys.forEach(key => {\n if (!existingKeys.has(key)) {\n newCount++;\n } else {\n updatedCount++;\n }\n });\n\n const unchangedCount = existingKeys.size - updatedCount;\n\n // Write new .env.local\n spinner.start('Writing .env.local...');\n\n const header = [\n '# ==========================================',\n '# RIGSTATE SOVEREIGN FOUNDATION',\n '# Authenticated Environment Configuration',\n `# Synced at: ${new Date().toISOString()}`,\n `# Project: ${projectId}`,\n '# ==========================================',\n ''\n ].join('\\n');\n\n await fs.writeFile(envFile, header + vaultContent + '\\n');\n spinner.succeed('Written to .env.local');\n\n if (!silent) {\n // Summary\n console.log('');\n console.log(chalk.bold.green('✅ Environment synchronized successfully'));\n console.log('');\n console.log(chalk.dim(' Summary:'));\n console.log(chalk.green(` + ${newCount} new`));\n console.log(chalk.yellow(` ~ ${updatedCount} updated`));\n console.log(chalk.dim(` = ${unchangedCount} unchanged`));\n console.log('');\n\n // Security reminder\n console.log(chalk.bold.yellow('⚠️ Security Reminder:'));\n console.log(chalk.dim(' - Never commit .env.local to version control.'));\n console.log(chalk.dim(' - Ensure .gitignore includes .env.local'));\n console.log('');\n }\n return true;\n\n } catch (e: any) {\n spinner.fail(chalk.red(`Failed to fetch secrets: ${e.message}`));\n return false;\n }\n}\n\nexport function createEnvPullCommand() {\n const envPull = new Command('env');\n\n envPull\n .command('pull')\n .description('Pull environment variables from project vault')\n .action(async () => {\n // Get config\n let apiKey: string;\n let projectId: string | undefined;\n\n try {\n apiKey = getApiKey();\n } catch (e) {\n console.error(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n // Get project context\n projectId = getProjectId();\n\n if (!projectId) {\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const content = await fs.readFile(manifestPath, 'utf-8');\n const manifest = JSON.parse(content);\n projectId = manifest.project_id;\n } catch (e) { }\n }\n\n if (!projectId) {\n console.error(chalk.red('No project context. Run \"rigstate link\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n await syncEnv(projectId, apiKey, apiUrl);\n });\n\n return envPull;\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { getApiKey, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\n\ninterface SyncResult {\n projectId: string;\n projectName: string;\n status: 'success' | 'failed';\n error?: string;\n}\n\n// Core Logic (Exported for re-use)\nexport async function syncProjectRules(projectId: string, apiKey: string, apiUrl: string, dryRun = false): Promise<boolean> {\n const spinner = ora('🛡️ Frank Protocol: Initializing retroactive sync...').start();\n let success = true;\n\n try {\n // Fetch project to get name\n spinner.text = 'Fetching project info...';\n const projectRes = await axios.get(`${apiUrl}/api/v1/projects`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!projectRes.data.success || !projectRes.data.data.projects?.length) {\n throw new Error('Project not found');\n }\n\n const project = projectRes.data.data.projects[0];\n spinner.text = `Syncing rules for ${project.name}...`;\n\n if (dryRun) {\n spinner.succeed(chalk.yellow(` [DRY-RUN] Would sync: ${project.name}`));\n return true;\n }\n\n // Call API to regenerate and sync rules\n const syncResponse = await axios.post(`${apiUrl}/api/v1/rules/sync`, {\n project_id: project.id\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (syncResponse.data.success) {\n if (syncResponse.data.data.github_synced) {\n spinner.succeed(chalk.green(` ✅ ${project.name} [${project.id}] → GitHub synced`));\n } else {\n spinner.info(chalk.blue(` ℹ️ ${project.name} [${project.id}] → Rules generated (no GitHub)`));\n }\n\n const files = syncResponse.data.data.files;\n if (files && Array.isArray(files)) {\n const fs = await import('fs/promises');\n const path = await import('path');\n\n for (const file of files) {\n const filePath = path.join(process.cwd(), file.path);\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n await fs.writeFile(filePath, file.content, 'utf-8');\n }\n console.log(chalk.dim(` 💾 Wrote ${files.length} rule files to local .cursor/rules/`));\n }\n\n console.log('');\n console.log(chalk.cyan('🛡️ Frank Protocol v1.0 has been injected into the rules engine.'));\n console.log(chalk.dim(' All new chats will now boot with mandatory governance checks.'));\n } else {\n spinner.warn(chalk.yellow(` ⚠️ ${project.name} → ${syncResponse.data.error || 'Unknown error'}`));\n success = false;\n }\n\n } catch (e: any) {\n spinner.fail(chalk.red(`Sync failed: ${e.message}`));\n success = false;\n }\n return success;\n}\n\nexport function createSyncRulesCommand() {\n const syncRules = new Command('sync-rules');\n\n syncRules\n .description('🛡️ Push Frank Protocol v1.0 to all existing projects')\n .option('--dry-run', 'Preview changes without pushing to GitHub')\n .option('--project <id>', 'Sync a specific project only')\n .action(async (options) => {\n // CLI specific logic (handling multiple projects etc) is kept here or simplified\n // For now, let's just support single project sync via re-used logic if project ID is clear\n\n // Get config\n let apiKey: string;\n try {\n apiKey = getApiKey();\n } catch (e) {\n console.error(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n\n // ... (Logic to select project is skipped for brevity in this refactor step, assumes --project or .env)\n // In a real refactor we would extract project selection too.\n // For Link command integration, direct ID is passed, so syncProjectRules is enough.\n\n if (options.project) {\n await syncProjectRules(options.project, apiKey, apiUrl, options.dryRun);\n } else {\n console.log(chalk.yellow('Use --project <id> for now. (Mass sync logic awaiting migration)'));\n }\n });\n\n return syncRules;\n}\n","\nimport chalk from 'chalk';\nimport axios from 'axios';\nimport ora from 'ora';\n\ninterface RoadmapStep {\n id: string;\n title: string;\n step_number: number;\n description: string;\n status: string;\n role: string;\n}\n\nexport async function suggestNextMove(projectId: string, apiKey: string, apiUrl: string) {\n // Silent spinner just to fetch data quickly\n // const spinner = ora('Analyzing mission parameters...').start();\n\n try {\n // We use the roadmap chunks endpoint or a dedicated query\n // For CLI efficiency, let's query raw chunks via a unified endpoint if possible\n // Or assume we have a direct endpoint. \n // Let's use the standard `list_roadmap_tasks` equivalent logic via REST API if available.\n // Assuming /api/v1/roadmap/next exists or similar. \n // If not, we query pending tasks.\n\n const response = await axios.get(`${apiUrl}/api/v1/roadmap/chunks`, {\n params: {\n project_id: projectId,\n status: 'PENDING',\n limit: 1,\n order: 'step_number.asc'\n },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!response.data.success) {\n return; // Fail silently, feature relies on API being ready\n }\n\n const tasks = response.data.data.chunks || [];\n if (tasks.length === 0) return;\n\n const nextTask = tasks[0] as RoadmapStep;\n\n // Visual Presentation\n console.log('');\n console.log(chalk.bold('🎯 TACTICAL INTELLIGENCE'));\n console.log(chalk.dim('────────────────────────────────────────'));\n console.log(`${chalk.bold('Active Phase:')} Implementation`);\n console.log(`${chalk.bold('Next Mission:')} ${chalk.cyan(nextTask.title)}`);\n\n if (nextTask.role) {\n console.log(`${chalk.bold('Required Role:')} ${chalk.magenta(nextTask.role)}`);\n }\n\n console.log('');\n console.log(chalk.yellow('SUGGESTED NEXT MOVE:'));\n console.log(chalk.white(`> rigstate work start ${nextTask.id} `) + chalk.dim('(Start this task)'));\n console.log(chalk.white(`> rigstate chat \"How do I solve T-${nextTask.step_number}?\" `) + chalk.dim('(Ask Architect)'));\n console.log(chalk.dim('────────────────────────────────────────'));\n console.log('');\n\n } catch (e) {\n // Ignore errors in suggestion engine to not break the flow\n }\n}\n","/**\n * rigstate hooks - Manage git hooks for Guardian integration\n * \n * Usage:\n * rigstate hooks install # Install pre-commit hook\n * rigstate hooks uninstall # Remove pre-commit hook\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport fs from 'fs/promises';\nimport path from 'path';\n\nconst PRE_COMMIT_SCRIPT = `#!/bin/sh\n# Rigstate Guardian Pre-commit Hook\n# Installed by: rigstate hooks install\n\n# 1. Silent Sentinel Check (Phase 5)\nif [ -f .rigstate/guardian.lock ]; then\n echo \"🛑 INTERVENTION ACTIVE: Commit blocked by Silent Sentinel.\"\n echo \" A critical violation ('HARD_LOCK') was detected by the Guardian Daemon.\"\n echo \" Please fix the violation to unlock the repo.\"\n echo \"\"\n if grep -q \"HARD_LOCK_ACTIVE\" .rigstate/guardian.lock; then\n cat .rigstate/guardian.lock\n fi\n exit 1\nfi\n\necho \"🛡️ Running Guardian checks...\"\n\n# Run check with strict mode for critical violations\nrigstate check --staged --strict=critical\n\n# Exit with the same code as rigstate check\nexit $?\n`;\n\nexport function createHooksCommand(): Command {\n const hooks = new Command('hooks')\n .description('Manage git hooks for Guardian integration');\n\n hooks\n .command('install')\n .description('Install pre-commit hook to run Guardian checks')\n .option('--strict [level]', 'Strict level: \"all\" or \"critical\" (default)', 'critical')\n .action(async (options: { strict: string }) => {\n try {\n // 1. Find .git directory\n const gitDir = path.join(process.cwd(), '.git');\n try {\n await fs.access(gitDir);\n } catch {\n console.log(chalk.red('❌ Not a git repository.'));\n console.log(chalk.dim(' Initialize with \"git init\" first.'));\n process.exit(1);\n }\n\n // 2. Ensure hooks directory exists\n const hooksDir = path.join(gitDir, 'hooks');\n await fs.mkdir(hooksDir, { recursive: true });\n\n // 3. Check for existing pre-commit\n const preCommitPath = path.join(hooksDir, 'pre-commit');\n let existingContent = '';\n try {\n existingContent = await fs.readFile(preCommitPath, 'utf-8');\n if (existingContent.includes('rigstate')) {\n console.log(chalk.yellow('⚠ Rigstate pre-commit hook already installed.'));\n console.log(chalk.dim(' Use \"rigstate hooks uninstall\" to remove first.'));\n return;\n }\n } catch {\n // File doesn't exist, that's fine\n }\n\n // 4. Create hook script with configurable strict level\n let script = PRE_COMMIT_SCRIPT;\n if (options.strict === 'all') {\n script = script.replace('--strict=critical', '--strict');\n }\n\n // 5. If existing hook, append to it\n if (existingContent && !existingContent.includes('rigstate')) {\n // Append our hook to existing\n const combinedScript = existingContent + '\\n\\n' + script.replace('#!/bin/sh\\n', '');\n await fs.writeFile(preCommitPath, combinedScript, { mode: 0o755 });\n console.log(chalk.green('✅ Rigstate hook appended to existing pre-commit.'));\n } else {\n // Create new hook\n await fs.writeFile(preCommitPath, script, { mode: 0o755 });\n console.log(chalk.green('✅ Pre-commit hook installed!'));\n }\n\n console.log(chalk.dim(` Path: ${preCommitPath}`));\n console.log(chalk.dim(` Strict level: ${options.strict}`));\n console.log('');\n console.log(chalk.cyan('Guardian will now check your code before each commit.'));\n console.log(chalk.dim('Use \"rigstate hooks uninstall\" to remove the hook.'));\n\n } catch (error: any) {\n console.error(chalk.red('Failed to install hook:'), error.message);\n process.exit(1);\n }\n });\n\n hooks\n .command('uninstall')\n .description('Remove Rigstate pre-commit hook')\n .action(async () => {\n try {\n const preCommitPath = path.join(process.cwd(), '.git', 'hooks', 'pre-commit');\n\n try {\n const content = await fs.readFile(preCommitPath, 'utf-8');\n\n if (!content.includes('rigstate')) {\n console.log(chalk.yellow('⚠ No Rigstate hook found in pre-commit.'));\n return;\n }\n\n // Check if it's our hook exclusively\n if (content.includes('# Rigstate Guardian Pre-commit Hook') &&\n content.trim().split('\\n').filter(l => l && !l.startsWith('#')).length <= 4) {\n // It's only our hook, remove the file\n await fs.unlink(preCommitPath);\n console.log(chalk.green('✅ Pre-commit hook removed.'));\n } else {\n // There's other content, just remove our section\n const lines = content.split('\\n');\n const filteredLines = [];\n let inRigstateSection = false;\n\n for (const line of lines) {\n if (line.includes('Rigstate Guardian Pre-commit Hook')) {\n inRigstateSection = true;\n continue;\n }\n if (inRigstateSection && line.includes('exit $?')) {\n inRigstateSection = false;\n continue;\n }\n if (!inRigstateSection && !line.includes('rigstate check')) {\n filteredLines.push(line);\n }\n }\n\n await fs.writeFile(preCommitPath, filteredLines.join('\\n'), { mode: 0o755 });\n console.log(chalk.green('✅ Rigstate section removed from pre-commit hook.'));\n }\n\n } catch {\n console.log(chalk.yellow('⚠ No pre-commit hook found.'));\n }\n\n } catch (error: any) {\n console.error(chalk.red('Failed to uninstall hook:'), error.message);\n process.exit(1);\n }\n });\n\n return hooks;\n}\n","import { AgentSkill } from '@rigstate/rules-engine';\nimport axios from 'axios';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\n\n/**\n * Provisions Agent Skills to the local project.\n * \n * Flow:\n * 1. Fetch skills from API (database)\n * 2. Merge with core skills from rules-engine\n * 3. Write to .agent/skills/<name>/SKILL.md\n * 4. Return list of provisioned skills for .cursorrules injection\n */\nexport async function provisionSkills(\n apiUrl: string,\n apiKey: string,\n projectId: string,\n rootDir: string\n): Promise<AgentSkill[]> {\n const skills: AgentSkill[] = [];\n\n // 1. Fetch skills from database (user + global + core)\n try {\n const response = await axios.get(`${apiUrl}/api/v1/skills`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (response.data.success && response.data.data) {\n for (const dbSkill of response.data.data) {\n skills.push({\n name: dbSkill.name,\n description: dbSkill.description,\n specialist: dbSkill.specialist || 'General',\n version: dbSkill.version || '1.0.0',\n governance: dbSkill.governance || 'OPEN',\n content: dbSkill.content\n });\n }\n }\n } catch (e: any) {\n // API might not have skills endpoint yet - fall through to core skills\n const msg = e.response?.data?.error || e.message;\n console.log(chalk.dim(` (Skills API not available: ${msg}, using core library)`));\n }\n\n // 2. If no skills from DB, use core library from rules-engine\n if (skills.length === 0) {\n const { getRigstateStandardSkills } = await import('@rigstate/rules-engine');\n const coreSkills = getRigstateStandardSkills();\n skills.push(...coreSkills);\n }\n\n // 3. Write skills to .agent/skills/\n const skillsDir = path.join(rootDir, '.agent', 'skills');\n await fs.mkdir(skillsDir, { recursive: true });\n\n for (const skill of skills) {\n const skillDir = path.join(skillsDir, skill.name);\n await fs.mkdir(skillDir, { recursive: true });\n\n const skillContent = `---\nname: ${skill.name}\ndescription: ${skill.description}\nversion: \"${skill.version}\"\nspecialist: ${skill.specialist}\ngovernance: ${skill.governance}\n---\n\n${skill.content}\n\n---\n*Provisioned by Rigstate CLI. Do not modify manually.*`;\n\n const skillPath = path.join(skillDir, 'SKILL.md');\n await fs.writeFile(skillPath, skillContent, 'utf-8');\n }\n\n console.log(chalk.green(` ✅ Provisioned ${skills.length} skill(s) to .agent/skills/`));\n\n return skills;\n}\n\n/**\n * Generate the <available_skills> XML block for .cursorrules\n */\nexport function generateSkillsDiscoveryBlock(skills: AgentSkill[]): string {\n if (skills.length === 0) return '';\n\n const skillBlocks = skills.map(skill => ` <skill>\n <name>${skill.name}</name>\n <description>${skill.description}</description>\n <location>.agent/skills/${skill.name}/SKILL.md</location>\n </skill>`).join('\\n');\n\n return `<available_skills>\n${skillBlocks}\n</available_skills>`;\n}\n/**\n * Just-In-Time provisioning of a specific skill.\n * Checks if the skill is already in .cursorrules and injects it if not.\n */\nexport async function jitProvisionSkill(\n skillId: string,\n apiUrl: string,\n apiKey: string,\n projectId: string,\n rootDir: string\n): Promise<boolean> {\n const rulesPath = path.join(rootDir, '.cursorrules');\n let rulesContent = '';\n\n try {\n rulesContent = await fs.readFile(rulesPath, 'utf-8');\n } catch (e) {\n return false;\n }\n\n const isProvisioned = rulesContent.includes(`<name>${skillId}</name>`) ||\n rulesContent.includes(`.agent/skills/${skillId}`);\n\n if (isProvisioned) return false;\n\n console.log(chalk.yellow(` ⚡ JIT PROVISIONING: Injecting ${skillId}...`));\n\n try {\n const skills = await provisionSkills(apiUrl, apiKey, projectId, rootDir);\n const skillsBlock = generateSkillsDiscoveryBlock(skills);\n\n if (rulesContent.includes('<available_skills>')) {\n rulesContent = rulesContent.replace(\n /<available_skills>[\\s\\S]*?<\\/available_skills>/,\n skillsBlock\n );\n } else if (rulesContent.includes('## 🧠 PROJECT CONTEXT')) {\n const insertPoint = rulesContent.indexOf('---', rulesContent.indexOf('## 🧠 PROJECT CONTEXT'));\n if (insertPoint !== -1) {\n rulesContent = rulesContent.slice(0, insertPoint + 3) +\n '\\n\\n' + skillsBlock + '\\n' +\n rulesContent.slice(insertPoint + 3);\n }\n }\n\n await fs.writeFile(rulesPath, rulesContent, 'utf-8');\n return true;\n } catch (e: any) {\n console.log(chalk.red(` Failed to provision skill: ${e.message}`));\n return false;\n }\n}\n","import fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\n\n// --- Types ---\n\nexport enum InterventionLevel {\n GHOST = 0, // Log only, silent\n NUDGE = 1, // Warn on commit/complete\n SENTINEL = 2 // Immediate SOFT_LOCK\n}\n\nexport type LockStatus = 'OPEN' | 'SOFT_LOCK';\n\nexport interface GovernanceConfig {\n governance: {\n intervention_level: InterventionLevel;\n allow_overrides: boolean;\n };\n}\n\nexport interface SessionState {\n status: LockStatus;\n active_violation?: string | null;\n lock_reason?: string | null;\n last_updated: string;\n}\n\nconst DEFAULT_CONFIG: GovernanceConfig = {\n governance: {\n intervention_level: InterventionLevel.GHOST,\n allow_overrides: true\n }\n};\n\nconst DEFAULT_SESSION: SessionState = {\n status: 'OPEN',\n active_violation: null,\n lock_reason: null,\n last_updated: new Date().toISOString()\n};\n\n// --- Config Management ---\n\nexport async function getGovernanceConfig(rootDir: string = process.cwd()): Promise<GovernanceConfig> {\n try {\n const configPath = path.join(rootDir, 'rigstate.config.json');\n const content = await fs.readFile(configPath, 'utf-8');\n const userConfig = JSON.parse(content);\n return {\n governance: {\n ...DEFAULT_CONFIG.governance,\n ...userConfig.governance\n }\n };\n } catch (e) {\n return DEFAULT_CONFIG;\n }\n}\n\n// --- Session State Management ---\n\nexport async function getSessionState(rootDir: string = process.cwd()): Promise<SessionState> {\n try {\n const sessionPath = path.join(rootDir, '.rigstate', 'session.json');\n const content = await fs.readFile(sessionPath, 'utf-8');\n return JSON.parse(content);\n } catch (e) {\n return DEFAULT_SESSION;\n }\n}\n\nexport async function setSoftLock(\n reason: string,\n violationId: string,\n rootDir: string = process.cwd()\n): Promise<void> {\n const sessionPath = path.join(rootDir, '.rigstate', 'session.json');\n const state: SessionState = {\n status: 'SOFT_LOCK',\n active_violation: violationId,\n lock_reason: reason,\n last_updated: new Date().toISOString()\n };\n\n await fs.mkdir(path.dirname(sessionPath), { recursive: true });\n await fs.writeFile(sessionPath, JSON.stringify(state, null, 2), 'utf-8');\n}\n\nexport async function clearSoftLock(\n rootDir: string = process.cwd()\n): Promise<void> {\n const sessionPath = path.join(rootDir, '.rigstate', 'session.json');\n const state: SessionState = {\n ...DEFAULT_SESSION,\n last_updated: new Date().toISOString()\n };\n\n await fs.mkdir(path.dirname(sessionPath), { recursive: true });\n await fs.writeFile(sessionPath, JSON.stringify(state, null, 2), 'utf-8');\n}\n\n/**\n * Checks if the user is authorized to perform an override\n * (For now, assumes CLI user is authorized, but logs it)\n */\nexport async function performOverride(\n violationId: string,\n reason: string,\n rootDir: string = process.cwd()\n): Promise<boolean> {\n const config = await getGovernanceConfig(rootDir);\n\n if (!config.governance.allow_overrides) {\n console.log(chalk.red('❌ Overrides are disabled for this project.'));\n return false;\n }\n\n // Security violations (SEC-*) cannot be overridden via CLI usually, \n // but the implementation here depends on how we define \"Security\".\n // For now, we allow overriding via this function, but the *Caller* should check violation type.\n\n await clearSoftLock(rootDir);\n // TODO: Add to Mission Report (Audit Log)\n // We will handle logging in the command handler itself\n\n return true;\n}\n","/**\n * Guardian Watchdog - Scans files against governance rules\n * Now fetches rules from API with fallback to cache/defaults\n */\n\nimport fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\nimport axios from 'axios';\nimport { getApiUrl, getApiKey } from './config.js';\n\ninterface EffectiveRule {\n id: string;\n rule_name: string;\n rule_type: string;\n value: Record<string, unknown>;\n severity: 'critical' | 'warning' | 'info';\n description: string;\n source: 'global' | 'project_override';\n is_enabled: boolean;\n}\n\ninterface ScanResult {\n file: string;\n lines: number;\n status: 'OK' | 'WARNING' | 'VIOLATION';\n}\n\nconst DEFAULT_LMAX = 400;\nconst DEFAULT_LMAX_WARNING = 350;\nconst CACHE_FILE = '.rigstate/rules-cache.json';\n\nasync function countLines(filePath: string): Promise<number> {\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n return content.split('\\n').length;\n } catch (e) {\n return 0;\n }\n}\n\nasync function getFiles(dir: string, extension: string[]): Promise<string[]> {\n const entries = await fs.readdir(dir, { withFileTypes: true });\n const files = await Promise.all(entries.map(async (entry) => {\n const res = path.resolve(dir, entry.name);\n if (entry.isDirectory()) {\n if (entry.name === 'node_modules' || entry.name === '.git' || entry.name === '.next' || entry.name === 'dist') return [];\n return getFiles(res, extension);\n } else {\n return extension.some(ext => entry.name.endsWith(ext)) ? res : [];\n }\n }));\n return files.flat();\n}\n\n/**\n * Fetch rules from API with fallback\n */\nasync function fetchRulesFromApi(projectId: string): Promise<{\n lmax: number;\n lmaxWarning: number;\n source: string;\n}> {\n try {\n const apiUrl = getApiUrl();\n const apiKey = getApiKey();\n\n const response = await axios.get(`${apiUrl}/api/v1/guardian/rules`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 10000\n });\n\n if (response.data.success && response.data.data.settings) {\n return {\n lmax: response.data.data.settings.lmax || DEFAULT_LMAX,\n lmaxWarning: response.data.data.settings.lmax_warning || DEFAULT_LMAX_WARNING,\n source: 'API (Dynamic)'\n };\n }\n } catch (error) {\n // Try to load from cache\n try {\n const cachePath = path.join(process.cwd(), CACHE_FILE);\n const content = await fs.readFile(cachePath, 'utf-8');\n const cached = JSON.parse(content);\n if (cached.settings) {\n return {\n lmax: cached.settings.lmax || DEFAULT_LMAX,\n lmaxWarning: cached.settings.lmax_warning || DEFAULT_LMAX_WARNING,\n source: 'Cache (Fallback)'\n };\n }\n } catch {\n // Cache read failed\n }\n }\n\n // Default fallback\n return {\n lmax: DEFAULT_LMAX,\n lmaxWarning: DEFAULT_LMAX_WARNING,\n source: 'Default (Hardcoded)'\n };\n}\n\nexport async function runGuardianWatchdog(\n rootPath: string,\n settings: Record<string, any> = {},\n projectId?: string\n): Promise<void> {\n console.log(chalk.bold('\\n🛡️ Active Guardian Watchdog Initiated...'));\n\n // Try to get rules from API if projectId is provided\n let lmax = settings.lmax || DEFAULT_LMAX;\n let lmaxWarning = settings.lmax_warning || DEFAULT_LMAX_WARNING;\n let ruleSource = settings.lmax ? 'Settings (Passed)' : 'Default';\n\n if (projectId) {\n const apiRules = await fetchRulesFromApi(projectId);\n lmax = apiRules.lmax;\n lmaxWarning = apiRules.lmaxWarning;\n ruleSource = apiRules.source;\n }\n\n console.log(chalk.dim(`Governance Rules: L_max=${lmax}, L_max_warning=${lmaxWarning}, Source: ${ruleSource}`));\n\n const targetExtensions = ['.ts', '.tsx'];\n let scanTarget = rootPath;\n const webSrc = path.join(rootPath, 'apps', 'web', 'src');\n\n try {\n await fs.access(webSrc);\n scanTarget = webSrc;\n } catch {\n // apps/web/src not found, scanning root or provided path\n }\n\n console.log(chalk.dim(`Scanning target: ${path.relative(process.cwd(), scanTarget)}`));\n\n const files = await getFiles(scanTarget, targetExtensions);\n\n let violations = 0;\n let warnings = 0;\n\n const results: ScanResult[] = [];\n\n for (const file of files) {\n const lines = await countLines(file);\n const relPath = path.relative(rootPath, file);\n\n if (lines > lmax) {\n results.push({ file: relPath, lines, status: 'VIOLATION' });\n violations++;\n console.log(chalk.red(`[VIOLATION] ${relPath}: ${lines} lines (Limit: ${lmax})`));\n } else if (lines > lmaxWarning) {\n results.push({ file: relPath, lines, status: 'WARNING' });\n warnings++;\n console.log(chalk.yellow(`[WARNING] ${relPath}: ${lines} lines (Threshold: ${lmaxWarning})`));\n }\n }\n\n if (violations === 0 && warnings === 0) {\n console.log(chalk.green(`✔ All ${files.length} files are within governance limits.`));\n } else {\n console.log('\\n' + chalk.bold('Summary:'));\n console.log(chalk.red(`Violations: ${violations}`));\n console.log(chalk.yellow(`Warnings: ${warnings}`));\n\n // --- GOVERNANCE INTERVENTION LOGIC ---\n const { getGovernanceConfig, setSoftLock, InterventionLevel } = await import('./governance.js');\n const { governance } = await getGovernanceConfig(rootPath);\n console.log(chalk.dim(`Intervention Level: ${InterventionLevel[governance.intervention_level] || 'UNKNOWN'} (${governance.intervention_level})`));\n\n if (violations > 0) {\n console.log(chalk.red.bold('\\nCRITICAL: Governance violations detected. Immediate refactoring required.'));\n\n // Check for SENTINEL MODE (Level 2)\n if (governance.intervention_level >= InterventionLevel.SENTINEL) {\n console.log(chalk.red.bold('🛑 SENTINEL MODE: Session SOFT_LOCKED until resolved.'));\n console.log(chalk.red(' Run \"rigstate override <id> --reason \\\\\"...\\\\\"\" if this is an emergency.'));\n await setSoftLock('Sentinel Mode: Governance Violations Detected', 'ARC-VIOLATION', rootPath);\n }\n }\n }\n\n // Sync to Cloud via API\n if (projectId) {\n try {\n const apiUrl = getApiUrl();\n const apiKey = getApiKey();\n\n const payloadViolations = results.filter(r => r.status === 'VIOLATION').map(v => ({\n uid: 'V-' + Buffer.from(v.file).toString('base64').replace(/=/g, ''),\n filePath: v.file,\n lineCount: v.lines,\n limitValue: lmax,\n severity: 'CRITICAL'\n }));\n\n await axios.post(`${apiUrl}/api/v1/guardian/sync`, {\n projectId,\n violations: payloadViolations,\n warnings: warnings\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n console.log(chalk.dim('✔ Violations synced to Rigstate Cloud.'));\n\n } catch (e: any) {\n console.log(chalk.dim('⚠ Cloud sync skipped: ' + (e.message || 'Unknown')));\n }\n }\n}\n","\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { createLoginCommand } from './commands/login.js';\nimport { createLinkCommand } from './commands/link.js';\nimport { createScanCommand } from './commands/scan.js';\nimport { createFixCommand } from './commands/fix.js';\nimport { createSyncCommand } from './commands/sync.js';\nimport { createInitCommand } from './commands/init.js';\nimport { createCheckCommand } from './commands/check.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.js';\nimport { createWorkCommand } from './commands/work.js';\nimport { createWatchCommand } from './commands/watch.js';\nimport { createFocusCommand } from './commands/focus.js';\nimport { createEnvPullCommand } from './commands/env.js';\nimport { createConfigCommand } from './commands/config.js';\nimport { createMcpCommand } from './commands/mcp.js';\nimport { createNexusCommand } from './commands/nexus.js';\nimport { createSyncRulesCommand } from './commands/sync-rules.js';\nimport { createOverrideCommand } from './commands/override.js';\nimport { checkVersion } from './utils/version.js';\nimport dotenv from 'dotenv';\n\nimport { createIdeaCommand } from './commands/idea.js';\n\n// Load environment variables\ndotenv.config();\n\nconst program = new Command();\n\nprogram\n .name('rigstate')\n .description('CLI for Rigstate - The AI-Native Dev Studio')\n .version('0.2.0');\n\n// Register commands\nprogram.addCommand(createLoginCommand());\nprogram.addCommand(createLinkCommand());\nprogram.addCommand(createScanCommand());\nprogram.addCommand(createFixCommand());\nprogram.addCommand(createSyncCommand());\nprogram.addCommand(createInitCommand());\nprogram.addCommand(createCheckCommand());\nprogram.addCommand(createHooksCommand());\nprogram.addCommand(createDaemonCommand());\nprogram.addCommand(createWorkCommand());\nprogram.addCommand(createWatchCommand());\nprogram.addCommand(createFocusCommand());\nprogram.addCommand(createEnvPullCommand());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createMcpCommand());\nprogram.addCommand(createNexusCommand());\nprogram.addCommand(createSyncRulesCommand());\nprogram.addCommand(createOverrideCommand());\nprogram.addCommand(createIdeaCommand());\n\nprogram.hook('preAction', async () => {\n await checkVersion();\n});\n\n// Add helpful examples\nprogram.on('--help', () => {\n console.log('');\n console.log(chalk.bold('Examples:'));\n console.log('');\n console.log(chalk.cyan(' $ rigstate login sk_rigstate_your_api_key'));\n console.log(chalk.dim(' Authenticate with your Rigstate API key'));\n console.log('');\n console.log(chalk.cyan(' $ rigstate scan'));\n console.log(chalk.dim(' Scan the current directory'));\n console.log('');\n console.log(chalk.cyan(' $ rigstate scan ./src --project abc123'));\n console.log(chalk.dim(' Scan a specific directory with project ID'));\n console.log('');\n console.log(chalk.cyan(' $ rigstate scan --json'));\n console.log(chalk.dim(' Output results in JSON format (useful for IDE extensions)'));\n console.log('');\n});\n\n// Parse arguments\nprogram.parse(process.argv);\n\n// Show help if no command provided\nif (!process.argv.slice(2).length) {\n program.outputHelp();\n}\n","/* eslint-disable no-console */\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { setApiKey } from '../utils/config.js';\n\nexport function createLoginCommand(): Command {\n return new Command('login')\n .description('Authenticate with your Rigstate API key')\n .argument('<api-key>', 'Your Rigstate API key (starts with sk_)')\n .action(async (apiKey: string) => {\n try {\n // Basic validation\n if (!apiKey || !apiKey.startsWith('sk_rigstate_')) {\n console.error(chalk.red('❌ Invalid API key format'));\n console.error(chalk.dim('API keys must start with \"sk_rigstate_\"'));\n process.exit(1);\n }\n\n // Store the API key\n setApiKey(apiKey);\n\n console.log(chalk.green('✅ Successfully logged in!'));\n console.log(\n chalk.dim(\n `\\nYour API key has been securely stored. You can now use \"rigstate scan\" to audit your code.`\n )\n );\n\n console.log(chalk.bold('\\n🤖 Cursor MCP Configuration'));\n console.log(chalk.dim('Copy and paste this into Cursor Settings -> Features -> MCP:'));\n console.log(chalk.cyan(`\n{\n \"mcpServers\": {\n \"rigstate\": {\n \"command\": \"npx\",\n \"args\": [\n \"-y\",\n \"@rigstate/mcp@latest\"\n ],\n \"env\": {\n \"RIGSTATE_API_KEY\": \"${apiKey}\"\n }\n }\n }\n}`));\n } catch (error) {\n console.error(\n chalk.red('❌ Login failed:'),\n error instanceof Error ? error.message : 'Unknown error'\n );\n process.exit(1);\n }\n });\n}\n","/* eslint-disable no-console */\nimport { Command } from 'commander';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\nimport os from 'os';\n\nexport function createLinkCommand() {\n return new Command('link')\n .description('Link current directory to a Rigstate project')\n .argument('<projectId>', 'Project ID to link')\n .action(async (projectId) => {\n // Check Global Override (Rigstate v2.7)\n try {\n const globalPath = path.join(os.homedir(), '.rigstate', 'config.json');\n const globalData = await fs.readFile(globalPath, 'utf-8').catch(() => null);\n if (globalData) {\n const config = JSON.parse(globalData);\n const cwd = process.cwd();\n if (config.overrides && config.overrides[cwd]) {\n const overrideId = config.overrides[cwd];\n if (overrideId !== projectId) {\n console.warn(chalk.yellow(`Global override detected. Enforcing project ID: ${overrideId}`));\n projectId = overrideId;\n }\n }\n }\n } catch (e) { }\n\n const manifestPath = path.join(process.cwd(), '.rigstate');\n\n const content = {\n project_id: projectId,\n api_url: process.env.NEXT_PUBLIC_APP_URL || 'http://localhost:3000',\n linked_at: new Date().toISOString()\n };\n\n try {\n await fs.writeFile(manifestPath, JSON.stringify(content, null, 2), 'utf-8');\n console.log(chalk.green(`✔ Linked to project ID: ${projectId}`));\n console.log(chalk.dim(`Created local context manifest at .rigstate`));\n\n // === SMART AUTOMATION ===\n console.log('');\n console.log(chalk.bold('🤖 Rigstate Automation Detected'));\n console.log('');\n\n const { getApiKey, getApiUrl } = await import('../utils/config.js');\n const apiKey = getApiKey(); // Might throw if not logged in\n const apiUrl = getApiUrl();\n\n if (apiKey) {\n // 1. Env Sync\n console.log(chalk.blue('🔐 Checking Vault for secrets...'));\n const { syncEnv } = await import('./env.js');\n await syncEnv(projectId, apiKey, apiUrl, true);\n\n // 2. Rules Sync\n console.log(chalk.blue('🧠 Syncing neural instructions...'));\n const { syncProjectRules } = await import('./sync-rules.js');\n await syncProjectRules(projectId, apiKey, apiUrl);\n\n // 3. Git Hooks\n console.log(chalk.blue('🛡️ Checking immunity system...'));\n await installHooks(process.cwd());\n\n console.log('');\n console.log(chalk.bold.green('🚀 Link Complete! Your environment is ready.'));\n\n // 4. Tactical Suggestion (The First Move)\n const { suggestNextMove } = await import('./suggest.js');\n await suggestNextMove(projectId, apiKey, apiUrl);\n } else {\n console.log('');\n console.log(chalk.bold.green('🚀 Link Complete!'));\n }\n\n } catch (error: any) {\n if (error.message.includes('Not authenticated')) {\n console.warn(chalk.yellow('⚠️ Not authenticated. Run \"rigstate login\" to enable automation features.'));\n } else {\n console.error(chalk.red(`Failed to link project: ${error.message}`));\n }\n }\n });\n}\n\nasync function installHooks(cwd: string) {\n const fs = await import('fs/promises');\n const path = await import('path');\n\n // Check if git repo\n try {\n await fs.access(path.join(cwd, '.git'));\n } catch {\n console.log(chalk.dim(' (Not a git repository, skipping hooks)'));\n return;\n }\n\n const hooksDir = path.join(cwd, '.husky');\n\n // Check if simple husky setup exists or just do a manual pre-commit script\n // For now, let's look for a basic pre-commit file in .git/hooks if husky isn't there\n // Actually, let's just use the `hooks` command logic if possible, or a lightweight version\n\n try {\n const { installHooks: runInstall } = await import('./hooks.js');\n // We need to mock the command context or extract logic. \n // For simplicity/robustness in this iteration, let's just suggest it or verify\n\n // Simpler approach: Check if pre-commit exists\n const preCommitPath = path.join(cwd, '.git/hooks/pre-commit');\n try {\n await fs.access(preCommitPath);\n console.log(chalk.green(' ✔ Git hooks already active'));\n } catch {\n console.log(chalk.yellow(' ⚠️ Git hooks missing. Run \"rigstate hooks install\" to secure repo.'));\n }\n\n } catch (e) {\n // Ignore hook errors during link\n }\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport { glob } from 'glob';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { readGitignore, shouldIgnore, isCodeFile } from '../utils/files.js';\n\ninterface ScanResult {\n id: string;\n file_path: string;\n issues: Array<{\n type: string;\n severity: 'critical' | 'high' | 'medium' | 'low' | 'info';\n message: string;\n line?: number;\n }>;\n}\n\ninterface ApiResponse {\n results: ScanResult[];\n summary: {\n total_files: number;\n total_issues: number;\n by_severity: Record<string, number>;\n };\n}\n\nexport function createScanCommand(): Command {\n return new Command('scan')\n .description('Scan code files for security and quality issues')\n .argument('[path]', 'Directory or file to scan', '.')\n .option('--json', 'Output results as JSON')\n .option('--project <id>', 'Project ID to associate with this scan')\n .action(async (targetPath: string, options: { json?: boolean; project?: string }) => {\n const spinner = ora();\n\n try {\n // Get API credentials\n const apiKey = getApiKey();\n const apiUrl = getApiUrl();\n const projectId = options.project || getProjectId();\n\n if (!projectId) {\n console.warn(\n chalk.yellow(\n '⚠️ No project ID specified. Use --project <id> or set a default.'\n )\n );\n }\n\n // Resolve target path\n const scanPath = path.resolve(process.cwd(), targetPath);\n\n spinner.start(`Scanning ${chalk.cyan(scanPath)}...`);\n\n // Read .gitignore patterns\n const gitignorePatterns = await readGitignore(scanPath);\n\n // Find all code files\n const pattern = path.join(scanPath, '**/*');\n const allFiles = await glob(pattern, {\n nodir: true,\n dot: false,\n ignore: ['**/node_modules/**', '**/.git/**', '**/dist/**', '**/build/**'],\n });\n\n // Filter files\n const codeFiles = allFiles.filter((file) => {\n const relativePath = path.relative(scanPath, file);\n return isCodeFile(file) && !shouldIgnore(relativePath, gitignorePatterns);\n });\n\n if (codeFiles.length === 0) {\n spinner.warn(chalk.yellow('No code files found to scan.'));\n return;\n }\n\n spinner.text = `Found ${codeFiles.length} files. Scanning...`;\n\n // Scan each file individually\n const results: ScanResult[] = [];\n let totalIssues = 0;\n const severityCounts: Record<string, number> = {};\n\n for (let i = 0; i < codeFiles.length; i++) {\n const filePath = codeFiles[i];\n const relativePath = path.relative(scanPath, filePath);\n\n spinner.text = `Scanning ${i + 1}/${codeFiles.length}: ${relativePath}`;\n\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n\n // Call the API for this file\n const response = await axios.post(\n `${apiUrl}/api/v1/audit`,\n {\n content,\n file_path: relativePath,\n project_id: projectId,\n },\n {\n headers: {\n 'Authorization': `Bearer ${apiKey}`,\n 'Content-Type': 'application/json',\n },\n timeout: 60000, // 1 minute per file\n }\n );\n\n // Aggregate results\n const vulnerabilities = response.data.vulnerabilities || [];\n if (vulnerabilities.length > 0) {\n results.push({\n id: response.data.id || relativePath,\n file_path: relativePath,\n issues: vulnerabilities.map((v: any) => ({\n type: v.type,\n severity: v.severity,\n message: v.description || v.title,\n line: v.line_number,\n })),\n });\n\n totalIssues += vulnerabilities.length;\n\n vulnerabilities.forEach((v: any) => {\n severityCounts[v.severity] = (severityCounts[v.severity] || 0) + 1;\n });\n }\n } catch (fileError) {\n if (axios.isAxiosError(fileError)) {\n console.warn(chalk.yellow(`\\n⚠️ Skipping ${relativePath}: ${fileError.message}`));\n } else {\n console.warn(chalk.yellow(`\\n⚠️ Error reading ${relativePath}`));\n }\n }\n }\n\n spinner.succeed(chalk.green('✅ Scan completed!'));\n\n // Build aggregated response\n const aggregatedResponse: ApiResponse = {\n results,\n summary: {\n total_files: codeFiles.length,\n total_issues: totalIssues,\n by_severity: severityCounts,\n },\n };\n\n // Output results\n if (options.json) {\n console.log(JSON.stringify(aggregatedResponse, null, 2));\n } else {\n printPrettyResults(aggregatedResponse);\n }\n } catch (error) {\n spinner.fail(chalk.red('❌ Scan failed'));\n\n if (axios.isAxiosError(error)) {\n if (error.response) {\n console.error(chalk.red('API Error:'), error.response.data);\n } else if (error.request) {\n console.error(\n chalk.red('Network Error:'),\n 'Could not reach the API. Is the server running?'\n );\n } else {\n console.error(chalk.red('Error:'), error.message);\n }\n } else {\n console.error(\n chalk.red('Error:'),\n error instanceof Error ? error.message : 'Unknown error'\n );\n }\n\n process.exit(1);\n }\n });\n}\n\nfunction printPrettyResults(data: ApiResponse): void {\n const { results, summary } = data;\n\n console.log('\\n' + chalk.bold('📊 Scan Summary'));\n console.log(chalk.dim('─'.repeat(60)));\n console.log(`Total Files Scanned: ${chalk.cyan(summary.total_files)}`);\n console.log(`Total Issues Found: ${chalk.yellow(summary.total_issues)}`);\n\n if (summary.by_severity) {\n console.log('\\nIssues by Severity:');\n Object.entries(summary.by_severity).forEach(([severity, count]) => {\n const color = getSeverityColor(severity as any);\n console.log(` ${color(`${severity}:`)} ${count}`);\n });\n }\n\n if (results && results.length > 0) {\n console.log('\\n' + chalk.bold('🔍 Detailed Results'));\n console.log(chalk.dim('─'.repeat(60)));\n\n results.forEach((result) => {\n if (result.issues && result.issues.length > 0) {\n console.log(`\\n${chalk.bold(result.file_path)}`);\n\n result.issues.forEach((issue) => {\n const severityColor = getSeverityColor(issue.severity);\n const lineInfo = issue.line ? chalk.dim(`:${issue.line}`) : '';\n\n console.log(\n ` ${severityColor(`[${issue.severity.toUpperCase()}]`)} ${issue.type}${lineInfo}`\n );\n console.log(` ${chalk.dim(issue.message)}`);\n });\n }\n });\n }\n\n console.log('\\n' + chalk.dim('─'.repeat(60)));\n}\n\nfunction getSeverityColor(severity: string): (str: string) => string {\n switch (severity.toLowerCase()) {\n case 'critical':\n return chalk.red.bold;\n case 'high':\n return chalk.red;\n case 'medium':\n return chalk.yellow;\n case 'low':\n return chalk.blue;\n case 'info':\n return chalk.gray;\n default:\n return chalk.white;\n }\n}\n","import fs from 'fs/promises';\nimport path from 'path';\n\n/**\n * Read and parse .gitignore file\n */\nexport async function readGitignore(dir: string): Promise<string[]> {\n const gitignorePath = path.join(dir, '.gitignore');\n try {\n const content = await fs.readFile(gitignorePath, 'utf-8');\n return content\n .split('\\n')\n .map((line) => line.trim())\n .filter((line) => line && !line.startsWith('#'));\n } catch (error) {\n // No .gitignore file found, return empty array\n return [];\n }\n}\n\n/**\n * Check if a path should be ignored based on .gitignore patterns\n */\nexport function shouldIgnore(filePath: string, patterns: string[]): boolean {\n const relativePath = filePath.replace(/^\\.\\//, '');\n\n // Default ignore patterns\n const defaultIgnores = [\n 'node_modules',\n '.git',\n 'dist',\n 'build',\n '.next',\n '.turbo',\n 'coverage',\n '.env',\n '.env.local',\n ];\n\n const allPatterns = [...defaultIgnores, ...patterns];\n\n for (const pattern of allPatterns) {\n if (pattern.endsWith('/')) {\n // Directory pattern\n const dir = pattern.slice(0, -1);\n if (relativePath.includes(`${dir}/`) || relativePath === dir) {\n return true;\n }\n } else if (pattern.includes('*')) {\n // Glob pattern - simple implementation\n const regex = new RegExp(\n '^' + pattern.replace(/\\*/g, '.*').replace(/\\?/g, '.') + '$'\n );\n if (regex.test(relativePath)) {\n return true;\n }\n } else {\n // Exact match or contains\n if (relativePath.includes(pattern)) {\n return true;\n }\n }\n }\n\n return false;\n}\n\n/**\n * Check if file is a code file based on extension\n */\nexport function isCodeFile(filePath: string): boolean {\n const codeExtensions = [\n '.js',\n '.jsx',\n '.ts',\n '.tsx',\n '.py',\n '.java',\n '.go',\n '.rb',\n '.php',\n '.c',\n '.cpp',\n '.h',\n '.cs',\n '.swift',\n '.kt',\n '.rs',\n '.vue',\n '.svelte',\n ];\n\n const ext = path.extname(filePath).toLowerCase();\n return codeExtensions.includes(ext);\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport { glob } from 'glob';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport inquirer from 'inquirer';\nimport * as Diff from 'diff';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { readGitignore, shouldIgnore, isCodeFile } from '../utils/files.js';\n\nexport function createFixCommand(): Command {\n return new Command('fix')\n .description('Scan and interactively FIX detected issues using Rigstate AI')\n .argument('[path]', 'Directory or file to scan', '.')\n .option('--project <id>', 'Project ID to context-aware audit')\n .action(async (targetPath: string, options: { project?: string }) => {\n const spinner = ora();\n\n try {\n const apiKey = getApiKey();\n const apiUrl = getApiUrl();\n const projectId = options.project || getProjectId();\n\n if (!projectId) {\n console.log(chalk.yellow('⚠️ Project ID is required for fixing. Using default or pass --project <id>'));\n // We can proceed without it, but fix quality drops. Let's warn.\n }\n\n const scanPath = path.resolve(process.cwd(), targetPath);\n\n // --- Reuse Scan Logic (Simplified) ---\n const gitignorePatterns = await readGitignore(scanPath);\n const pattern = path.join(scanPath, '**/*');\n const allFiles = await glob(pattern, { nodir: true, dot: false, ignore: ['**/node_modules/**', '**/.git/**'] });\n const codeFiles = allFiles.filter(file => {\n const relativePath = path.relative(scanPath, file);\n return isCodeFile(file) && !shouldIgnore(relativePath, gitignorePatterns);\n });\n\n if (codeFiles.length === 0) {\n console.log(chalk.yellow('No code files found.'));\n return;\n }\n\n console.log(chalk.bold(`\\n🧠 Rigstate Fix Mode`));\n console.log(chalk.dim(`Scanning ${codeFiles.length} files with Project Context...\\n`));\n\n let fixedCount = 0;\n\n for (let i = 0; i < codeFiles.length; i++) {\n const filePath = codeFiles[i];\n const relativePath = path.relative(scanPath, filePath);\n\n spinner.start(`Analyzing ${relativePath}...`);\n\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n const response = await axios.post(\n `${apiUrl}/api/v1/audit`,\n { content, file_path: relativePath, project_id: projectId },\n { headers: { 'Authorization': `Bearer ${apiKey}` }, timeout: 120000 }\n );\n\n const vulnerabilities = response.data.vulnerabilities || [];\n const fixableIssues = vulnerabilities.filter((v: any) => v.fixed_content);\n\n if (fixableIssues.length > 0) {\n spinner.stop();\n console.log(`\\n${chalk.bold(relativePath)}: Found ${fixableIssues.length} fixable issues.`);\n\n for (const issue of fixableIssues) {\n console.log(chalk.red(`\\n[${issue.type}] ${issue.title}`));\n console.log(chalk.dim(issue.suggestion || issue.message));\n\n // Show Diff\n const diff = Diff.createTwoFilesPatch(relativePath, relativePath, content, issue.fixed_content, 'Current', 'Fixed');\n console.log('\\n' + diff.split('\\n').slice(0, 15).join('\\n') + (diff.split('\\n').length > 15 ? '\\n...' : ''));\n\n const { apply } = await inquirer.prompt([{\n type: 'confirm',\n name: 'apply',\n message: `Apply this fix to ${chalk.cyan(relativePath)}?`,\n default: true\n }]);\n\n if (apply) {\n await fs.writeFile(filePath, issue.fixed_content);\n console.log(chalk.green(`✅ Fixed applied!`));\n fixedCount++;\n\n if (issue.related_step_id) {\n const { completeStep } = await inquirer.prompt([{\n type: 'confirm',\n name: 'completeStep',\n message: `Frank thinks this fix completes a Roadmap Step. Mark as COMPLETED in Rigstate?`,\n default: true\n }]);\n\n if (completeStep) {\n try {\n await axios.post(\n `${apiUrl}/api/v1/roadmap/update-status`,\n { step_id: issue.related_step_id, status: 'COMPLETED', project_id: projectId },\n { headers: { 'Authorization': `Bearer ${apiKey}` } }\n );\n console.log(chalk.green(`🚀 Roadmap updated! Mission Control is in sync.`));\n } catch (err: any) {\n console.error(chalk.yellow(`Failed to update roadmap: ${err.message}`));\n }\n }\n }\n\n // Stop processing this file as content changed\n break;\n } else {\n console.log(chalk.dim('Skipped.'));\n }\n }\n } else {\n spinner.text = `Checked ${relativePath} (No auto-fixes)`;\n }\n\n } catch (e: any) {\n // silent fail for file read/network errors in fix mode to keep flow\n }\n }\n\n spinner.stop();\n console.log(chalk.bold.green(`\\n\\n🚀 Fix session complete!`));\n console.log(`Frank fixed ${fixedCount} detected issues.`);\n console.log(chalk.dim(`Run 'rigstate scan' to verify remaining issues.`));\n\n } catch (error: any) {\n spinner.fail('Fix session failed');\n console.error(error.message);\n }\n });\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { getApiKey, getProjectId, getApiUrl, setProjectId } from '../utils/config.js';\nimport axios from 'axios';\nimport fs from 'fs/promises';\nimport path from 'path';\n\nexport function createSyncCommand() {\n const sync = new Command('sync');\n\n sync\n .description('Synchronize local state with Rigstate Cloud')\n .option('-p, --project <id>', 'Specify Project ID (saves to config automatically)')\n .action(async (options) => {\n const spinner = ora('Synchronizing project state...').start();\n\n try {\n // 1. Authentication Check\n let apiKey;\n try {\n apiKey = getApiKey();\n } catch (e) {\n spinner.fail('Not authenticated. Run \"rigstate login\" first.');\n return;\n }\n\n // 2. Project Context Resolution\n let projectId = options.project;\n\n // Check local .rigstate manifest\n if (!projectId) {\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const manifestContent = await fs.readFile(manifestPath, 'utf-8');\n const manifest = JSON.parse(manifestContent);\n if (manifest.project_id) projectId = manifest.project_id;\n } catch (e) { }\n }\n\n // Check global config\n if (!projectId) projectId = getProjectId();\n\n if (options.project) {\n // Persistence: Save project ID for future use\n setProjectId(options.project);\n }\n\n if (!projectId) {\n spinner.fail('No project context found.\\n Run with --project <id> once to save context.');\n return;\n }\n\n const apiUrl = getApiUrl();\n\n // 3. API Execution\n const response = await axios.get(`${apiUrl}/api/v1/roadmap`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n // Parse Standardized Response ({ success, data, ... })\n if (!response.data.success) {\n throw new Error(response.data.error || 'Unknown API failure');\n }\n\n const { roadmap, project } = response.data.data;\n const timestamp = response.data.timestamp;\n\n // 4. Write Artifacts\n const targetPath = path.join(process.cwd(), 'roadmap.json');\n const fileContent = JSON.stringify({\n project,\n last_synced: timestamp,\n roadmap\n }, null, 2);\n\n await fs.writeFile(targetPath, fileContent, 'utf-8');\n\n // 4b. Write Context Manifest (.rigstate) - CONTEXT GUARD\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const manifestContent = {\n project_id: projectId,\n project_name: project,\n last_synced: timestamp,\n api_url: apiUrl\n };\n await fs.writeFile(manifestPath, JSON.stringify(manifestContent, null, 2), 'utf-8');\n } catch (e) {\n // Fail silently\n }\n\n // 4c. Provision Agent Skills (Skills Dominion)\n console.log(chalk.bold('\\n🧠 Agent Skills Provisioning...'));\n try {\n const { provisionSkills, generateSkillsDiscoveryBlock } = await import('../utils/skills-provisioner.js');\n const skills = await provisionSkills(apiUrl, apiKey, projectId, process.cwd());\n\n // Update .cursorrules with skills discovery block (if file exists)\n const cursorRulesPath = path.join(process.cwd(), '.cursorrules');\n try {\n let rulesContent = await fs.readFile(cursorRulesPath, 'utf-8');\n const skillsBlock = generateSkillsDiscoveryBlock(skills);\n\n // Replace existing skills block or insert after PROJECT CONTEXT\n if (rulesContent.includes('<available_skills>')) {\n rulesContent = rulesContent.replace(\n /<available_skills>[\\s\\S]*?<\\/available_skills>/,\n skillsBlock\n );\n } else if (rulesContent.includes('## 🧠 PROJECT CONTEXT')) {\n // Insert after PROJECT CONTEXT section\n const insertPoint = rulesContent.indexOf('---', rulesContent.indexOf('## 🧠 PROJECT CONTEXT'));\n if (insertPoint !== -1) {\n rulesContent = rulesContent.slice(0, insertPoint + 3) +\n '\\n\\n' + skillsBlock + '\\n' +\n rulesContent.slice(insertPoint + 3);\n }\n }\n\n await fs.writeFile(cursorRulesPath, rulesContent, 'utf-8');\n console.log(chalk.dim(` Updated .cursorrules with skills discovery block`));\n } catch (e) {\n // .cursorrules doesn't exist or couldn't be updated\n }\n } catch (e: any) {\n console.log(chalk.yellow(` ⚠ Skills provisioning skipped: ${e.message}`));\n }\n\n // 5. Process Execution Logs (MISSION REPORTING)\n try {\n const logPath = path.join(process.cwd(), '.rigstate', 'logs', 'last_execution.json');\n try {\n const logContent = await fs.readFile(logPath, 'utf-8');\n const logData = JSON.parse(logContent);\n\n if (logData.task_summary) {\n await axios.post(`${apiUrl}/api/v1/execution-logs`, {\n project_id: projectId,\n ...logData,\n agent_role: process.env.RIGSTATE_MODE === 'SUPERVISOR' ? 'SUPERVISOR' : 'WORKER'\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n await fs.unlink(logPath);\n console.log(chalk.dim(`✔ Mission Report uploaded.`));\n }\n } catch (e: any) {\n // Ignore ENOENT (file not found), log errors if API fails\n if (e.code !== 'ENOENT') {\n // console.log(chalk.yellow('Log upload skipped: ' + e.message));\n }\n }\n } catch (e) { }\n\n // 6. User Feedback\n spinner.succeed(chalk.green(`Synced ${roadmap.length} roadmap steps for project \"${project}\"`));\n console.log(chalk.dim(`Local files updated: roadmap.json`));\n\n const { runGuardianWatchdog } = await import('../utils/watchdog.js');\n const settings = response.data.data.settings || {};\n await runGuardianWatchdog(process.cwd(), settings, projectId);\n\n // 8. Bridge Heartbeat & Pending Tasks\n console.log(chalk.bold('\\n📡 Agent Bridge Heartbeat...'));\n try {\n const bridgeResponse = await axios.get(`${apiUrl}/api/v1/agent/bridge`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (bridgeResponse.data.success) {\n const tasks = bridgeResponse.data.tasks;\n const pending = tasks.filter((t: any) => t.status === 'PENDING');\n const approved = tasks.filter((t: any) => t.status === 'APPROVED');\n\n if (pending.length > 0 || approved.length > 0) {\n console.log(chalk.yellow(`⚠ Bridge Alert: ${pending.length} pending, ${approved.length} approved tasks found.`));\n console.log(chalk.dim('Run \"rigstate fix\" to process these tasks or ensure your IDE MCP server is active.'));\n } else {\n console.log(chalk.green('✔ Heartbeat healthy. No pending bridge tasks.'));\n }\n\n // Acknowledge Pings if any\n const pings = pending.filter((t: any) => t.proposal?.startsWith('ping'));\n for (const ping of pings) {\n await axios.post(`${apiUrl}/api/v1/agent/bridge`, {\n bridge_id: ping.id,\n status: 'COMPLETED',\n summary: 'Pong! CLI Sync Heartbeat confirmed.'\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n console.log(chalk.cyan(`🏓 Pong! Acknowledged heartbeat signal [${ping.id}]`));\n }\n }\n } catch (e: any) {\n console.log(chalk.yellow(`⚠ Could not verify Bridge status: ${e.message}`));\n }\n\n if (options.project) {\n console.log(chalk.blue(`Project context saved. Future commands will use this project.`));\n }\n\n // 9. Migration Guard (The Firewall)\n try {\n const migrationDir = path.join(process.cwd(), 'supabase', 'migrations');\n const files = await fs.readdir(migrationDir);\n const sqlFiles = files.filter(f => f.endsWith('.sql')).sort();\n\n if (sqlFiles.length > 0) {\n const latestMigration = sqlFiles[sqlFiles.length - 1];\n console.log(chalk.dim(`\\n🛡 Migration Guard:`));\n console.log(chalk.dim(` Latest Local: ${latestMigration}`));\n console.log(chalk.yellow(` ⚠ Ensure DB schema matches this version. CLI cannot verify Remote RLS policies directly.`));\n }\n } catch (e) {\n // No migrations folder, or error reading - ignore\n }\n\n // 10. Sovereign Foundation (Vault Sync)\n try {\n const vaultResponse = await axios.post(`${apiUrl}/api/v1/vault/sync`,\n { project_id: projectId },\n { headers: { Authorization: `Bearer ${apiKey}` } }\n );\n\n if (vaultResponse.data.success) {\n const vaultContent: string = vaultResponse.data.data.content || '';\n const localEnvPath = path.join(process.cwd(), '.env.local');\n let localContent = '';\n\n try {\n localContent = await fs.readFile(localEnvPath, 'utf-8');\n } catch (e) { /* File doesn't exist */ }\n\n // Normalize for comparison (trim, ignore comments?) - Simple trim for now\n if (vaultContent.trim() !== localContent.trim()) {\n console.log(chalk.bold('\\n🔐 Sovereign Foundation (Vault):'));\n console.log(chalk.yellow(' Status: Drift Detected / Update Available'));\n\n const { syncVault } = await import('inquirer').then(m => m.default.prompt([{\n type: 'confirm',\n name: 'syncVault',\n message: 'Synchronize local .env.local with Vault secrets?',\n default: false\n }]));\n\n if (syncVault) {\n await fs.writeFile(localEnvPath, vaultContent, 'utf-8');\n console.log(chalk.green(' ✅ .env.local synchronized with Vault.'));\n } else {\n console.log(chalk.dim(' Skipped vault sync.'));\n }\n } else {\n console.log(chalk.dim('\\n🔐 Sovereign Foundation: Synced.'));\n }\n }\n } catch (e: any) {\n // Fail silently or warn if vault access denied (expected for some users)\n // console.log(chalk.dim(` (Vault check skipped: ${e.message})`));\n }\n\n // 11. System Integrity Checks (The Firewall)\n console.log(chalk.dim('\\n🛡️ System Integrity Check...'));\n await checkSystemIntegrity(apiUrl, apiKey, projectId);\n\n } catch (error: any) {\n if (axios.isAxiosError(error)) {\n const message = error.response?.data?.error || error.message;\n spinner.fail(chalk.red(`Sync failed: ${message}`));\n } else {\n spinner.fail(chalk.red('Sync failed: ' + (error.message || 'Unknown error')));\n }\n }\n });\n\n return sync;\n}\n\n/**\n * System Integrity Checks\n * Verifies Migration Sync and RLS Status via API\n */\nasync function checkSystemIntegrity(apiUrl: string, apiKey: string, projectId: string) {\n try {\n // Call System Integrity API\n const response = await axios.get(`${apiUrl}/api/v1/system/integrity`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (response.data.success) {\n const { migrations, rls, guardian_violations } = response.data.data;\n\n // Migration Status\n if (migrations) {\n if (migrations.in_sync) {\n console.log(chalk.green(` ✅ Migrations synced (${migrations.count} versions)`));\n } else {\n console.log(chalk.red(` 🛑 CRITICAL: DB Schema out of sync! ${migrations.missing?.length || 0} migrations not applied.`));\n if (migrations.missing?.length > 0) {\n console.log(chalk.dim(` Missing: ${migrations.missing.slice(0, 3).join(', ')}${migrations.missing.length > 3 ? '...' : ''}`));\n }\n console.log(chalk.yellow(` Run 'supabase db push' or apply migrations immediately.`));\n }\n }\n\n // RLS Status\n if (rls) {\n if (rls.all_secured) {\n console.log(chalk.green(` ✅ RLS Audit Passed (${rls.table_count} tables secured)`));\n } else {\n console.log(chalk.red(` 🛑 CRITICAL: Security Vulnerability! ${rls.unsecured?.length || 0} tables have RLS disabled.`));\n rls.unsecured?.forEach((table: string) => {\n console.log(chalk.red(` - ${table}`));\n });\n console.log(chalk.yellow(' Enable RLS immediately: ALTER TABLE \"table\" ENABLE ROW LEVEL SECURITY;'));\n }\n }\n\n // Guardian Violations\n if (guardian_violations) {\n if (guardian_violations.count === 0) {\n console.log(chalk.green(' ✅ Guardian: No active violations'));\n } else {\n console.log(chalk.yellow(` ⚠️ Guardian: ${guardian_violations.count} active violations`));\n console.log(chalk.dim(' Run \"rigstate check\" for details.'));\n }\n }\n }\n } catch (e: any) {\n // API might not have this endpoint yet - fail silently\n console.log(chalk.dim(' (System integrity check skipped - API endpoint not available)'));\n }\n}\n\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport ora from 'ora';\nimport { execSync } from 'child_process';\nimport { loadManifest } from '../utils/manifest.js';\nimport { getApiUrl, getApiKey, setProjectId } from '../utils/config.js';\nimport axios from 'axios';\n\nexport function createInitCommand() {\n return new Command('init')\n .description('Initialize or link a Rigstate project (interactive mode available)')\n .argument('[project-id]', 'ID of the project to link (optional, prompts if not provided)')\n .option('-f, --force', 'Overwrite existing .cursorrules file')\n .option('--rules-only', 'Only regenerate .cursorrules without interactive setup')\n .action(async (projectIdArg, options) => {\n const spinner = ora('Initializing Rigstate project...').start();\n\n let apiKey: string;\n try {\n apiKey = getApiKey();\n } catch (e) {\n spinner.fail(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n let projectId = projectIdArg;\n\n try {\n // If --rules-only, just regenerate rules from existing manifest\n if (options.rulesOnly) {\n const manifest = await loadManifest();\n if (!manifest) {\n spinner.fail('No .rigstate manifest found. Run \"rigstate init\" first.');\n return;\n }\n projectId = manifest.project_id;\n await generateRules(apiUrl, apiKey, projectId, options.force, spinner);\n return;\n }\n\n // Interactive mode if no project ID provided\n if (!projectId) {\n spinner.stop();\n\n // Dynamic import for inquirer\n const inquirer = (await import('inquirer')).default;\n\n spinner.start('Fetching your projects...');\n\n // Fetch projects via API\n let projects: any[] = [];\n try {\n const projectsResponse = await axios.get(`${apiUrl}/api/v1/projects`, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n if (projectsResponse.data.success) {\n projects = projectsResponse.data.data.projects || [];\n }\n } catch (e: any) {\n // API might not exist yet - fallback to manual entry\n spinner.info('Projects API not available. Using manual entry mode.');\n }\n\n spinner.stop();\n\n if (projects.length === 0) {\n // Fallback: Ask for project ID manually\n const { manualProjectId } = await inquirer.prompt([\n {\n type: 'input',\n name: 'manualProjectId',\n message: 'Enter Project ID (from Rigstate dashboard):',\n validate: (input: string) => input.trim() ? true : 'Project ID is required'\n }\n ]);\n projectId = manualProjectId;\n } else {\n // Build choices from fetched projects\n const choices: any[] = [\n { name: '➕ Create New Project', value: 'NEW' },\n new inquirer.Separator()\n ];\n\n projects.forEach((p: any) => {\n choices.push({\n name: `[${p.organization_name || 'Personal'}] ${p.name} (${p.status})`,\n value: p.id\n });\n });\n\n const { selectedId } = await inquirer.prompt([\n {\n type: 'list',\n name: 'selectedId',\n message: 'Select a project to link:',\n choices: choices,\n pageSize: 15\n }\n ]);\n\n if (selectedId === 'NEW') {\n // Create new project flow\n const { newName } = await inquirer.prompt([\n {\n type: 'input',\n name: 'newName',\n message: 'Enter project name:',\n validate: (input: string) => input.trim() ? true : 'Name is required'\n }\n ]);\n\n // Fetch organizations (with fallback)\n spinner.start('Fetching organizations...');\n let orgs: any[] = [];\n try {\n const orgsResponse = await axios.get(`${apiUrl}/api/v1/organizations`, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n orgs = orgsResponse.data.data?.organizations || [];\n } catch (e) {\n // API might not exist - skip org selection\n }\n spinner.stop();\n\n let selectedOrgId = orgs[0]?.id;\n\n if (orgs.length > 1) {\n const { orgId } = await inquirer.prompt([\n {\n type: 'list',\n name: 'orgId',\n message: 'Which organization does this belong to?',\n choices: orgs.map((org: any) => ({\n name: `${org.name} (${org.role || 'member'})`,\n value: org.id\n }))\n }\n ]);\n selectedOrgId = orgId;\n }\n\n if (!selectedOrgId) {\n console.log(chalk.yellow('No organization available. Please create the project via the Rigstate dashboard.'));\n return;\n }\n\n // Create project via API\n spinner.start('Creating new project...');\n try {\n const createResponse = await axios.post(`${apiUrl}/api/v1/projects`, {\n name: newName,\n organization_id: selectedOrgId\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!createResponse.data.success) {\n spinner.fail(chalk.red('Failed to create project: ' + createResponse.data.error));\n return;\n }\n\n projectId = createResponse.data.data.project.id;\n spinner.succeed(chalk.green(`Created new project: ${newName}`));\n } catch (e: any) {\n spinner.fail(chalk.red('Project creation API not available. Please create via dashboard.'));\n return;\n }\n } else {\n projectId = selectedId;\n }\n }\n\n spinner.start(`Linking to project ID: ${projectId}...`);\n }\n\n // Core link logic\n // Save project ID to config\n setProjectId(projectId);\n\n // Write local manifest\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const manifestContent = {\n project_id: projectId,\n last_linked: new Date().toISOString(),\n api_url: apiUrl\n };\n await fs.writeFile(manifestPath, JSON.stringify(manifestContent, null, 2), 'utf-8');\n\n // Initialize git if needed\n try {\n await fs.access('.git');\n } catch {\n spinner.text = 'Initializing git repository...';\n execSync('git init', { stdio: 'ignore' });\n }\n\n spinner.succeed(chalk.green(`✅ Linked to project: ${projectId}`));\n\n // Generate rules\n await generateRules(apiUrl, apiKey, projectId, options.force, spinner);\n\n console.log('');\n console.log(chalk.blue('Next steps:'));\n console.log(chalk.dim(' rigstate sync - Sync roadmap and context'));\n console.log(chalk.dim(' rigstate watch - Start development loop'));\n console.log(chalk.dim(' rigstate focus - Get current task'));\n\n } catch (e: any) {\n spinner.fail(chalk.red('Initialization failed: ' + e.message));\n }\n });\n}\n\nasync function generateRules(apiUrl: string, apiKey: string, projectId: string, force: boolean, spinner: any) {\n spinner.start('Generating AI rules (MDC + AGENTS.md)...');\n\n try {\n const response = await axios.post(`${apiUrl}/api/v1/rules/generate`, {\n project_id: projectId\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (response.data.success || response.data.files) {\n const files = response.data.files || [];\n\n if (files.length === 0 && response.data.rules) {\n // Fallback to legacy mono-file if no multiple files returned\n const rulesPath = path.join(process.cwd(), '.cursorrules');\n await fs.writeFile(rulesPath, response.data.rules, 'utf-8');\n spinner.succeed(chalk.green('✔ Generated .cursorrules (legacy mode)'));\n return;\n }\n\n for (const file of files) {\n const targetPath = path.join(process.cwd(), file.path);\n const targetDir = path.dirname(targetPath);\n\n // Ensure directory exists\n await fs.mkdir(targetDir, { recursive: true });\n\n // Check if exists and force\n try {\n await fs.access(targetPath);\n if (!force && !file.path.startsWith('.cursor/rules/')) {\n console.log(chalk.dim(` ${file.path} already exists. Skipping.`));\n continue;\n }\n } catch {\n // File doesn't exist, proceed\n }\n\n await fs.writeFile(targetPath, file.content, 'utf-8');\n }\n\n // Cleanup legacy .cursorrules if we have new files and aren't inhibited\n if (files.length > 0) {\n const legacyPath = path.join(process.cwd(), '.cursorrules');\n try {\n const stats = await fs.stat(legacyPath);\n if (stats.isFile()) {\n await fs.rename(legacyPath, `${legacyPath}.bak`);\n console.log(chalk.dim(' Moved legacy .cursorrules to .cursorrules.bak'));\n }\n } catch (e) {\n // Ignore if legacy file doesn't exist\n }\n }\n\n spinner.succeed(chalk.green(`✔ Generated ${files.length} rule files (v${response.data.version || '3.0'})`));\n } else {\n spinner.info(chalk.dim(' Rules generation skipped (API response invalid)'));\n }\n } catch (e: any) {\n spinner.info(chalk.dim(` Rules generation failed: ${e.message}`));\n }\n}\n\n\n","import fs from 'fs/promises';\nimport path from 'path';\n\nexport interface RigstateManifest {\n project_id: string;\n api_url?: string;\n linked_at?: string;\n}\n\nexport async function loadManifest(): Promise<RigstateManifest | null> {\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const content = await fs.readFile(manifestPath, 'utf-8');\n return JSON.parse(content);\n } catch {\n return null;\n }\n}\n","/**\n * rigstate check - Validate code against Guardian rules\n * \n * Usage:\n * rigstate check # Check current directory\n * rigstate check ./src # Check specific path\n * rigstate check --strict # Exit 1 on any violation\n * rigstate check --strict=critical # Exit 1 only on critical\n * rigstate check --staged # Only check staged files (for pre-commit)\n * rigstate check --json # Output as JSON\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport { glob } from 'glob';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { execSync } from 'child_process';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { loadManifest } from '../utils/manifest.js';\nimport {\n checkFile,\n formatViolations,\n summarizeResults,\n type EffectiveRule,\n type CheckResult,\n type Violation\n} from '../utils/rule-engine.js';\n\n// Cache settings\nconst CACHE_FILE = '.rigstate/rules-cache.json';\nconst CACHE_TTL_MS = 5 * 60 * 1000; // 5 minutes\nconst CACHE_MAX_AGE_MS = 24 * 60 * 60 * 1000; // 24 hours (offline limit)\n\ninterface CachedRules {\n timestamp: string;\n projectId: string;\n rules: EffectiveRule[];\n settings: { lmax: number; lmax_warning: number };\n}\n\nexport function createCheckCommand(): Command {\n return new Command('check')\n .description('Validate code against Guardian architectural rules')\n .argument('[path]', 'Directory or file to check', '.')\n .option('--project <id>', 'Project ID (or use .rigstate manifest)')\n .option('--strict [level]', 'Exit 1 on violations. Level: \"all\" (default) or \"critical\"')\n .option('--staged', 'Only check git staged files (for pre-commit hooks)')\n .option('--json', 'Output results as JSON')\n .option('--no-cache', 'Skip rule cache and fetch fresh from API')\n .action(async (targetPath: string, options: {\n project?: string;\n strict?: boolean | string;\n staged?: boolean;\n json?: boolean;\n cache?: boolean;\n }) => {\n const spinner = ora();\n\n try {\n // 1. Resolve project context\n let projectId = options.project;\n let apiUrl = getApiUrl();\n\n if (!projectId) {\n const manifest = await loadManifest();\n if (manifest) {\n projectId = manifest.project_id;\n if (manifest.api_url) apiUrl = manifest.api_url;\n }\n }\n\n if (!projectId) {\n projectId = getProjectId();\n }\n\n if (!projectId) {\n console.log(chalk.red('❌ No project context found.'));\n console.log(chalk.dim(' Run \"rigstate link\" or pass --project <id>'));\n process.exit(2);\n }\n\n // 2. Get API key\n let apiKey: string;\n try {\n apiKey = getApiKey();\n } catch {\n console.log(chalk.red('❌ Not authenticated. Run \"rigstate login\" first.'));\n process.exit(2);\n }\n\n // 3. Fetch rules (with caching)\n spinner.start('Fetching Guardian rules...');\n let rules: EffectiveRule[];\n let settings: { lmax: number; lmax_warning: number };\n\n try {\n const cached = options.cache !== false ? await loadCachedRules(projectId) : null;\n\n if (cached && !isStale(cached.timestamp, CACHE_TTL_MS)) {\n rules = cached.rules;\n settings = cached.settings;\n spinner.text = 'Using cached rules...';\n } else {\n // Fetch from API\n const response = await axios.get(`${apiUrl}/api/v1/guardian/rules`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 10000\n });\n\n if (!response.data.success) {\n throw new Error(response.data.error || 'Unknown API error');\n }\n\n rules = response.data.data.rules;\n settings = response.data.data.settings;\n\n // Save to cache\n await saveCachedRules(projectId, rules, settings);\n }\n } catch (apiError: any) {\n // Fallback to cache if API fails\n const cached = await loadCachedRules(projectId);\n\n if (cached && !isStale(cached.timestamp, CACHE_MAX_AGE_MS)) {\n spinner.warn(chalk.yellow('Using cached rules (API unavailable)'));\n rules = cached.rules;\n settings = cached.settings;\n } else {\n spinner.fail(chalk.red('Failed to fetch rules and no valid cache'));\n console.log(chalk.dim(` Error: ${apiError.message}`));\n process.exit(2);\n }\n }\n\n spinner.succeed(`Loaded ${rules.length} Guardian rules`);\n\n // 4. Get files to check\n const scanPath = path.resolve(process.cwd(), targetPath);\n let filesToCheck: string[];\n\n if (options.staged) {\n // Only staged files\n spinner.start('Getting staged files...');\n try {\n const stagedOutput = execSync('git diff --cached --name-only --diff-filter=ACMR', {\n encoding: 'utf-8',\n cwd: process.cwd()\n });\n filesToCheck = stagedOutput\n .split('\\n')\n .filter(f => f.trim())\n .filter(f => isCodeFile(f))\n .map(f => path.resolve(process.cwd(), f));\n } catch {\n spinner.fail('Not a git repository or no staged files');\n process.exit(2);\n }\n } else {\n // All code files in path\n spinner.start(`Scanning ${chalk.cyan(targetPath)}...`);\n const pattern = path.join(scanPath, '**/*');\n const allFiles = await glob(pattern, {\n nodir: true,\n dot: false,\n ignore: [\n '**/node_modules/**',\n '**/.git/**',\n '**/dist/**',\n '**/build/**',\n '**/.next/**',\n '**/coverage/**'\n ]\n });\n filesToCheck = allFiles.filter(f => isCodeFile(f));\n }\n\n if (filesToCheck.length === 0) {\n spinner.warn(chalk.yellow('No code files found to check.'));\n outputResults([], !!options.json);\n process.exit(0);\n }\n\n spinner.succeed(`Found ${filesToCheck.length} files to check`);\n\n // 5. Run checks\n spinner.start('Running Guardian checks...');\n const results: CheckResult[] = [];\n\n for (let i = 0; i < filesToCheck.length; i++) {\n const file = filesToCheck[i];\n spinner.text = `Checking ${i + 1}/${filesToCheck.length}: ${path.basename(file)}`;\n const result = await checkFile(file, rules, process.cwd());\n results.push(result);\n }\n\n spinner.stop();\n\n // 6. Output results\n const summary = summarizeResults(results);\n\n if (options.json) {\n outputResults(results, true);\n } else {\n outputResults(results, false);\n\n // Summary\n console.log('\\n' + chalk.bold('📊 Summary'));\n console.log(chalk.dim('─'.repeat(50)));\n console.log(`Files checked: ${chalk.cyan(summary.totalFiles)}`);\n console.log(`Total violations: ${summary.totalViolations > 0 ? chalk.red(summary.totalViolations) : chalk.green(0)}`);\n\n if (summary.totalViolations > 0) {\n console.log(` ${chalk.red('Critical:')} ${summary.criticalCount}`);\n console.log(` ${chalk.yellow('Warning:')} ${summary.warningCount}`);\n console.log(` ${chalk.blue('Info:')} ${summary.infoCount}`);\n }\n\n console.log(chalk.dim('─'.repeat(50)));\n }\n\n // 7. Exit code logic\n if (options.strict !== undefined) {\n const strictLevel = typeof options.strict === 'string' ? options.strict : 'all';\n\n if (strictLevel === 'critical' && summary.criticalCount > 0) {\n console.log(chalk.red('\\n❌ Check failed: Critical violations found'));\n process.exit(1);\n } else if (strictLevel === 'all' && summary.totalViolations > 0) {\n console.log(chalk.red('\\n❌ Check failed: Violations found'));\n process.exit(1);\n }\n }\n\n if (summary.totalViolations === 0) {\n console.log(chalk.green('\\n✅ All checks passed!'));\n }\n\n process.exit(0);\n\n } catch (error: any) {\n spinner.fail(chalk.red('Check failed'));\n console.error(chalk.red('Error:'), error.message);\n process.exit(2);\n }\n });\n}\n\n// Helper functions\n\nfunction isCodeFile(filePath: string): boolean {\n const codeExtensions = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.cjs'];\n const ext = path.extname(filePath).toLowerCase();\n return codeExtensions.includes(ext);\n}\n\nasync function loadCachedRules(projectId: string): Promise<CachedRules | null> {\n try {\n const cachePath = path.join(process.cwd(), CACHE_FILE);\n const content = await fs.readFile(cachePath, 'utf-8');\n const cached: CachedRules = JSON.parse(content);\n\n if (cached.projectId !== projectId) {\n return null;\n }\n\n return cached;\n } catch {\n return null;\n }\n}\n\nasync function saveCachedRules(\n projectId: string,\n rules: EffectiveRule[],\n settings: { lmax: number; lmax_warning: number }\n): Promise<void> {\n try {\n const cacheDir = path.join(process.cwd(), '.rigstate');\n await fs.mkdir(cacheDir, { recursive: true });\n\n const cached: CachedRules = {\n timestamp: new Date().toISOString(),\n projectId,\n rules,\n settings\n };\n\n await fs.writeFile(\n path.join(cacheDir, 'rules-cache.json'),\n JSON.stringify(cached, null, 2)\n );\n } catch {\n // Silently fail cache write\n }\n}\n\nfunction isStale(timestamp: string, maxAge: number): boolean {\n const age = Date.now() - new Date(timestamp).getTime();\n return age > maxAge;\n}\n\nfunction outputResults(results: CheckResult[], json: boolean): void {\n if (json) {\n console.log(JSON.stringify({\n results,\n summary: summarizeResults(results)\n }, null, 2));\n return;\n }\n\n const hasViolations = results.some(r => r.violations.length > 0);\n\n if (!hasViolations) {\n return;\n }\n\n console.log('\\n' + chalk.bold('🔍 Violations Found'));\n console.log(chalk.dim('─'.repeat(50)));\n\n for (const result of results) {\n if (result.violations.length > 0) {\n formatViolations(result.violations);\n }\n }\n}\n","/**\n * Rule Engine - Evaluates Guardian rules against local files\n */\n\nimport fs from 'fs/promises';\nimport path from 'path';\nimport chalk from 'chalk';\n\nexport interface EffectiveRule {\n id: string;\n rule_name: string;\n rule_type: string;\n value: Record<string, unknown>;\n severity: 'critical' | 'warning' | 'info';\n description: string;\n source: 'global' | 'project_override';\n is_enabled: boolean;\n}\n\nexport interface Violation {\n file: string;\n rule: string;\n ruleType: string;\n severity: 'critical' | 'warning' | 'info';\n message: string;\n details?: string;\n line?: number;\n}\n\nexport interface CheckResult {\n file: string;\n violations: Violation[];\n passed: boolean;\n}\n\n/**\n * Check a single file against all rules\n */\nexport async function checkFile(\n filePath: string,\n rules: EffectiveRule[],\n rootPath: string\n): Promise<CheckResult> {\n const violations: Violation[] = [];\n const relativePath = path.relative(rootPath, filePath);\n\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n const lines = content.split('\\n');\n\n for (const rule of rules) {\n const ruleViolations = await evaluateRule(rule, content, lines, relativePath);\n violations.push(...ruleViolations);\n }\n\n } catch (error: any) {\n violations.push({\n file: relativePath,\n rule: 'FILE_READ_ERROR',\n ruleType: 'SYSTEM',\n severity: 'warning',\n message: `Could not read file: ${error.message}`\n });\n }\n\n return {\n file: relativePath,\n violations,\n passed: violations.length === 0\n };\n}\n\n/**\n * Evaluate a single rule against file content\n */\nasync function evaluateRule(\n rule: EffectiveRule,\n content: string,\n lines: string[],\n filePath: string\n): Promise<Violation[]> {\n const violations: Violation[] = [];\n\n switch (rule.rule_type) {\n case 'MAX_FILE_LINES': {\n const value = rule.value as { limit: number; warning_threshold?: number };\n const lineCount = lines.length;\n\n if (lineCount > value.limit) {\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: 'critical',\n message: `File exceeds ${value.limit} lines`,\n details: `Current: ${lineCount} lines (limit: ${value.limit})`\n });\n } else if (value.warning_threshold && lineCount > value.warning_threshold) {\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: 'warning',\n message: `File approaching line limit`,\n details: `Current: ${lineCount} lines (warning at: ${value.warning_threshold}, limit: ${value.limit})`\n });\n }\n break;\n }\n\n case 'MAX_FUNCTION_LINES': {\n const value = rule.value as { limit: number };\n const functionViolations = checkFunctionLines(content, lines, filePath, rule, value.limit);\n violations.push(...functionViolations);\n break;\n }\n\n case 'PATTERN_FORBIDDEN': {\n const value = rule.value as { pattern: string; message?: string };\n const pattern = new RegExp(value.pattern, 'g');\n\n let match;\n while ((match = pattern.exec(content)) !== null) {\n const lineNumber = content.substring(0, match.index).split('\\n').length;\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: rule.severity,\n message: value.message || `Forbidden pattern found: ${value.pattern}`,\n line: lineNumber,\n details: `Found: \"${match[0].substring(0, 50)}${match[0].length > 50 ? '...' : ''}\"`\n });\n }\n break;\n }\n\n case 'PATTERN_REQUIRED': {\n const value = rule.value as { pattern: string; context?: string };\n const pattern = new RegExp(value.pattern);\n\n // Only check if context matches (e.g., only in certain file types)\n const shouldCheck = !value.context || filePath.includes(value.context);\n\n if (shouldCheck && !pattern.test(content)) {\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: rule.severity,\n message: `Required pattern not found: ${value.pattern}`,\n details: value.context ? `Expected in files matching: ${value.context}` : undefined\n });\n }\n break;\n }\n\n case 'NAMING_CONVENTION': {\n const value = rule.value as { pattern: string; context: string };\n const pattern = new RegExp(value.pattern);\n const fileName = path.basename(filePath);\n\n // Check if context matches (e.g., \"components\" for component files)\n if (filePath.includes(value.context) && !pattern.test(fileName)) {\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: rule.severity,\n message: `File name does not match naming convention`,\n details: `Expected pattern: ${value.pattern}`\n });\n }\n break;\n }\n\n default:\n // Unknown rule type, skip\n break;\n }\n\n return violations;\n}\n\n/**\n * Check function line counts using simple heuristics (not full AST)\n * Works for TypeScript/JavaScript\n */\nfunction checkFunctionLines(\n content: string,\n lines: string[],\n filePath: string,\n rule: EffectiveRule,\n limit: number\n): Violation[] {\n const violations: Violation[] = [];\n\n // Simple regex-based detection for functions\n // Matches: function name(), async function name(), const name = () =>, const name = function()\n const functionPatterns = [\n /(?:export\\s+)?(?:async\\s+)?function\\s+(\\w+)\\s*\\([^)]*\\)\\s*\\{/g,\n /(?:export\\s+)?const\\s+(\\w+)\\s*=\\s*(?:async\\s+)?\\([^)]*\\)\\s*=>\\s*\\{/g,\n /(?:export\\s+)?const\\s+(\\w+)\\s*=\\s*(?:async\\s+)?function\\s*\\([^)]*\\)\\s*\\{/g,\n /(\\w+)\\s*\\([^)]*\\)\\s*\\{/g // Method in class/object\n ];\n\n for (const pattern of functionPatterns) {\n let match;\n while ((match = pattern.exec(content)) !== null) {\n const functionName = match[1];\n const startIndex = match.index + match[0].length - 1; // Position of opening brace\n\n // Find matching closing brace\n let braceCount = 1;\n let endIndex = startIndex + 1;\n\n while (braceCount > 0 && endIndex < content.length) {\n if (content[endIndex] === '{') braceCount++;\n else if (content[endIndex] === '}') braceCount--;\n endIndex++;\n }\n\n // Count lines in function\n const functionContent = content.substring(startIndex, endIndex);\n const functionLines = functionContent.split('\\n').length;\n\n if (functionLines > limit) {\n const lineNumber = content.substring(0, match.index).split('\\n').length;\n violations.push({\n file: filePath,\n rule: rule.rule_name,\n ruleType: rule.rule_type,\n severity: rule.severity,\n message: `Function \"${functionName}\" exceeds ${limit} lines`,\n line: lineNumber,\n details: `Current: ${functionLines} lines (limit: ${limit})`\n });\n }\n }\n }\n\n return violations;\n}\n\n/**\n * Format violations for console output\n */\nexport function formatViolations(violations: Violation[]): void {\n for (const v of violations) {\n const severityColor = v.severity === 'critical' ? chalk.red :\n v.severity === 'warning' ? chalk.yellow : chalk.blue;\n\n const lineInfo = v.line ? chalk.dim(`:${v.line}`) : '';\n\n console.log(` ${severityColor(`[${v.severity.toUpperCase()}]`)} ${v.file}${lineInfo}`);\n console.log(` ${v.message}`);\n if (v.details) {\n console.log(` ${chalk.dim(v.details)}`);\n }\n }\n}\n\n/**\n * Summarize results\n */\nexport function summarizeResults(results: CheckResult[]): {\n totalFiles: number;\n totalViolations: number;\n criticalCount: number;\n warningCount: number;\n infoCount: number;\n} {\n let criticalCount = 0;\n let warningCount = 0;\n let infoCount = 0;\n\n for (const result of results) {\n for (const v of result.violations) {\n if (v.severity === 'critical') criticalCount++;\n else if (v.severity === 'warning') warningCount++;\n else infoCount++;\n }\n }\n\n return {\n totalFiles: results.length,\n totalViolations: criticalCount + warningCount + infoCount,\n criticalCount,\n warningCount,\n infoCount\n };\n}\n","/**\n * rigstate daemon - Unified Guardian Daemon\n * \n * Usage:\n * rigstate daemon # Start daemon in foreground\n * rigstate daemon status # Check if daemon is running\n * rigstate daemon --no-bridge # Disable Agent Bridge\n * rigstate daemon --verbose # Enable verbose output\n */\n/* eslint-disable no-console */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { createDaemon } from '../daemon/factory.js';\n\nconst PID_FILE = '.rigstate/daemon.pid';\nconst STATE_FILE = '.rigstate/daemon.state.json';\n\nexport function createDaemonCommand(): Command {\n const daemon = new Command('daemon')\n .description('Start the Guardian daemon for continuous monitoring');\n\n // Main daemon command (start in foreground)\n daemon\n .argument('[action]', 'Action: start (default) or status', 'start')\n .option('--project <id>', 'Project ID (or use .rigstate manifest)')\n .option('--path <path>', 'Path to watch', '.')\n .option('--no-bridge', 'Disable Agent Bridge connection')\n .option('--verbose', 'Enable verbose output')\n .action(async (action: string, options: {\n project?: string;\n path?: string;\n bridge?: boolean;\n verbose?: boolean;\n }) => {\n if (action === 'status') {\n await showStatus();\n return;\n }\n\n if (action === 'enable') {\n await enableDaemon();\n return;\n }\n\n if (action === 'disable') {\n await disableDaemon();\n return;\n }\n\n const spinner = ora();\n\n try {\n // Check if already running\n if (await isRunning()) {\n console.log(chalk.yellow('⚠ Another daemon instance may be running.'));\n console.log(chalk.dim(` Check ${PID_FILE} or run \"rigstate daemon status\"`));\n console.log(chalk.dim(' Use Ctrl+C to stop the running daemon first.\\n'));\n }\n\n // Create daemon\n spinner.start('Initializing Guardian Daemon...');\n const daemonInstance = await createDaemon({\n project: options.project,\n path: options.path,\n noBridge: options.bridge === false,\n verbose: options.verbose\n });\n spinner.stop();\n\n // Write PID file\n await writePidFile();\n\n // Handle shutdown gracefully\n process.on('SIGINT', async () => {\n console.log(chalk.dim('\\n\\nShutting down...'));\n await daemonInstance.stop();\n await cleanupPidFile();\n process.exit(0);\n });\n\n process.on('SIGTERM', async () => {\n await daemonInstance.stop();\n await cleanupPidFile();\n process.exit(0);\n });\n\n // Update state file periodically\n const stateInterval = setInterval(async () => {\n await writeStateFile(daemonInstance.getState());\n }, 5000);\n\n daemonInstance.on('stopped', () => {\n clearInterval(stateInterval);\n });\n\n // Start the daemon\n await daemonInstance.start();\n\n // Keep the process alive\n await new Promise(() => { });\n\n } catch (error: any) {\n spinner.fail(chalk.red('Failed to start daemon'));\n console.error(chalk.red('Error:'), error.message);\n process.exit(1);\n }\n });\n\n return daemon;\n}\n\nasync function isRunning(): Promise<boolean> {\n try {\n const pidPath = path.join(process.cwd(), PID_FILE);\n const content = await fs.readFile(pidPath, 'utf-8');\n const pid = parseInt(content.trim(), 10);\n\n // Check if process exists\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n // Process doesn't exist, clean up stale PID file\n await fs.unlink(pidPath);\n return false;\n }\n } catch {\n return false;\n }\n}\n\nasync function writePidFile(): Promise<void> {\n try {\n const dir = path.join(process.cwd(), '.rigstate');\n await fs.mkdir(dir, { recursive: true });\n await fs.writeFile(path.join(dir, 'daemon.pid'), process.pid.toString());\n } catch {\n // Silently fail\n }\n}\n\nasync function cleanupPidFile(): Promise<void> {\n try {\n await fs.unlink(path.join(process.cwd(), PID_FILE));\n await fs.unlink(path.join(process.cwd(), STATE_FILE));\n } catch {\n // Silently fail\n }\n}\n\nasync function writeStateFile(state: any): Promise<void> {\n try {\n const dir = path.join(process.cwd(), '.rigstate');\n await fs.mkdir(dir, { recursive: true });\n await fs.writeFile(\n path.join(dir, 'daemon.state.json'),\n JSON.stringify(state, null, 2)\n );\n } catch {\n // Silently fail\n }\n}\n\nasync function showStatus(): Promise<void> {\n console.log(chalk.bold('\\n🛡️ Guardian Daemon Status\\n'));\n\n const running = await isRunning();\n\n if (!running) {\n console.log(chalk.yellow('Status: Not running'));\n console.log(chalk.dim('Use \"rigstate daemon\" to start.\\n'));\n return;\n }\n\n console.log(chalk.green('Status: Running'));\n\n // Read state file\n try {\n const statePath = path.join(process.cwd(), STATE_FILE);\n const content = await fs.readFile(statePath, 'utf-8');\n const state = JSON.parse(content);\n\n console.log(chalk.dim('─'.repeat(40)));\n console.log(`Started at: ${state.startedAt || 'Unknown'}`);\n console.log(`Files checked: ${state.filesChecked || 0}`);\n console.log(`Violations: ${state.violationsFound || 0}`);\n console.log(`Tasks processed: ${state.tasksProcessed || 0}`);\n console.log(`Last activity: ${state.lastActivity || 'None'}`);\n console.log(chalk.dim('─'.repeat(40)));\n } catch {\n console.log(chalk.dim('(State file not found)'));\n }\n\n // Read PID\n try {\n const pidPath = path.join(process.cwd(), PID_FILE);\n const pid = await fs.readFile(pidPath, 'utf-8');\n console.log(chalk.dim(`PID: ${pid.trim()}`));\n } catch {\n // No PID file\n }\n\n console.log('');\n}\n\nasync function enableDaemon() {\n console.log(chalk.bold('\\n⚙️ Enabling Rigstate Background Service (macOS)\\n'));\n\n if (process.platform !== 'darwin') {\n console.error(chalk.red('❌ Currently only macOS is supported for auto-start.'));\n console.error(chalk.yellow('PRs welcome for Linux/Windows support!'));\n return;\n }\n\n const homeDir = process.env.HOME || '';\n if (!homeDir) {\n console.error(chalk.red('❌ Could not determine HOME directory.'));\n return;\n }\n\n const agentsDir = path.join(homeDir, 'Library/LaunchAgents');\n const logDir = path.join(homeDir, '.rigstate/logs');\n const plistPath = path.join(agentsDir, 'com.rigstate.daemon.plist');\n\n // Ensure directories exist\n await fs.mkdir(agentsDir, { recursive: true });\n await fs.mkdir(logDir, { recursive: true });\n\n // Find the executable path\n // We assume 'rigstate' is in the PATH, but for launchd we need absolute path\n // Or we use the node executable and the script path\n\n // Strategy: Use the currently executing script path\n // This file is likely in dist/commands/daemon.js, we need dist/index.js\n const scriptPath = path.resolve(__dirname, '../index.js');\n const nodePath = process.execPath; // Absolute path to node executable\n\n const plistContent = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n <key>Label</key>\n <string>com.rigstate.daemon</string>\n <key>ProgramArguments</key>\n <array>\n <string>${nodePath}</string>\n <string>${scriptPath}</string>\n <string>daemon</string>\n <string>--no-bridge</string> \n </array>\n <key>WorkingDirectory</key>\n <string>${process.cwd()}</string>\n <key>StandardOutPath</key>\n <string>${path.join(logDir, 'daemon.out.log')}</string>\n <key>StandardErrorPath</key>\n <string>${path.join(logDir, 'daemon.err.log')}</string>\n <key>RunAtLoad</key>\n <true/>\n <key>KeepAlive</key>\n <true/>\n <key>EnvironmentVariables</key>\n <dict>\n <key>PATH</key>\n <string>/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:${process.env.PATH}</string>\n </dict>\n</dict>\n</plist>`;\n\n try {\n await fs.writeFile(plistPath, plistContent);\n console.log(chalk.dim(`Created plist at: ${plistPath}`));\n\n // Load the agent\n try {\n await execShellCommand(`launchctl unload ${plistPath}`); // Unload if exists\n } catch (e) { } // Ignore error if not loaded\n\n await execShellCommand(`launchctl load ${plistPath}`);\n\n console.log(chalk.green('✅ Successfully enabled background daemon!'));\n console.log(chalk.dim(`Logs: ${logDir}`));\n console.log(chalk.dim('The daemon will now restart automatically if it crashes or on reboot.'));\n\n } catch (error: any) {\n console.error(chalk.red('❌ Failed to enable daemon:'), error.message);\n }\n}\n\nasync function disableDaemon() {\n console.log(chalk.bold('\\n⚙️ Disabling Rigstate Background Service\\n'));\n\n const homeDir = process.env.HOME || '';\n const plistPath = path.join(homeDir, 'Library/LaunchAgents/com.rigstate.daemon.plist');\n\n try {\n await execShellCommand(`launchctl unload ${plistPath}`);\n await fs.unlink(plistPath);\n console.log(chalk.green('✅ Successfully disabled background daemon.'));\n } catch (error: any) {\n // If file doesn't exist, it's already disabled\n if (error.code === 'ENOENT') {\n console.log(chalk.green('✅ Daemon was not enabled.'));\n } else {\n console.error(chalk.red('❌ Failed to disable daemon:'), error.message);\n }\n }\n}\n\nfunction execShellCommand(cmd: string) {\n const exec = require('child_process').exec;\n return new Promise((resolve, reject) => {\n exec(cmd, (error: any, stdout: string, stderr: string) => {\n if (error) {\n // launchctl returns non-zero if already loaded/unloaded sometimes, \n // but we might want to check stderr\n // For now simple wrapper\n // reject(error);\n }\n resolve(stdout ? stdout : stderr);\n });\n });\n}\n","import { GuardianDaemon } from './core.js';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { loadManifest } from '../utils/manifest.js';\nimport { DaemonConfig } from './types.js';\n\n/**\n * Factory for creating a GuardianDaemon with resolved configuration.\n */\nexport async function createDaemon(options: {\n project?: string;\n path?: string;\n noBridge?: boolean;\n verbose?: boolean;\n}): Promise<GuardianDaemon> {\n const apiUrl = getApiUrl();\n let projectId = options.project;\n\n if (!projectId) {\n const manifest = await loadManifest();\n if (manifest) projectId = manifest.project_id;\n }\n\n if (!projectId) projectId = getProjectId();\n\n if (!projectId) {\n throw new Error('No project ID found. Run \"rigstate link\" or use --project <id>.');\n }\n\n const apiKey = getApiKey();\n if (!apiKey) {\n throw new Error('Not authenticated. Run \"rigstate login\" first.');\n }\n\n const config: DaemonConfig = {\n projectId,\n apiUrl,\n apiKey,\n watchPath: options.path || process.cwd(),\n checkOnChange: true,\n bridgeEnabled: !options.noBridge,\n verbose: !!options.verbose\n };\n\n return new GuardianDaemon(config);\n}\n","/**\n * Daemon Core - Orchestrates all background watchers\n * \n * Combines:\n * 1. File Watcher (chokidar) - Monitors filesystem changes\n * 2. Guardian Rules - Validates files against rules on change\n * 3. Agent Bridge Listener - Receives tasks from Rigstate Cloud\n */\n\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport * as fs from 'fs/promises';\nimport { EventEmitter } from 'events';\nimport { createFileWatcher, type FileWatcherEvents } from './file-watcher.js';\nimport { createHeuristicEngine } from './heuristic-engine.js';\nimport { createInterventionProtocol, type InterventionDecision } from './intervention-protocol.js';\nimport { createGuardianMonitor } from './guardian-monitor.js';\nimport { createBridgeListener, type BridgeListenerEvents } from './bridge-listener.js';\nimport { DaemonConfig, DaemonState } from './types.js';\nimport { trackSkillUsage } from './telemetry.js';\nimport { jitProvisionSkill } from '../utils/skills-provisioner.js';\n\nexport class GuardianDaemon extends EventEmitter {\n private config: DaemonConfig;\n private state: DaemonState;\n private fileWatcher: ReturnType<typeof createFileWatcher> | null = null;\n private guardianMonitor: ReturnType<typeof createGuardianMonitor> | null = null;\n private heuristicEngine: ReturnType<typeof createHeuristicEngine> | null = null;\n private interventionProtocol: ReturnType<typeof createInterventionProtocol> | null = null;\n private bridgeListener: ReturnType<typeof createBridgeListener> | null = null;\n\n constructor(config: DaemonConfig) {\n super();\n this.config = config;\n this.state = {\n isRunning: false,\n startedAt: null,\n filesChecked: 0,\n violationsFound: 0,\n tasksProcessed: 0,\n lastActivity: null\n };\n }\n\n async start(): Promise<void> {\n if (this.state.isRunning) {\n console.log(chalk.yellow('Daemon is already running.'));\n return;\n }\n\n this.printWelcome();\n this.state.isRunning = true;\n this.state.startedAt = new Date().toISOString();\n\n // 1. Initialize Engines\n this.heuristicEngine = createHeuristicEngine();\n this.interventionProtocol = createInterventionProtocol();\n this.guardianMonitor = createGuardianMonitor(this.config.projectId, this.config.apiUrl, this.config.apiKey);\n\n // 2. Load and Sync Rules\n await this.guardianMonitor.loadRules();\n console.log(chalk.green(` ✓ Loaded ${this.guardianMonitor.getRuleCount()} rules`));\n await this.syncHeuristics();\n\n // 3. Setup File Watcher\n if (this.config.checkOnChange) {\n this.setupFileWatcher();\n }\n\n // 4. Setup Bridge\n if (this.config.bridgeEnabled) {\n await this.setupBridge();\n }\n\n this.printActive();\n this.emit('started', this.state);\n }\n\n private printWelcome() {\n console.log(chalk.bold.blue('\\n🛡️ Guardian Daemon Starting...'));\n console.log(chalk.dim(`Project: ${this.config.projectId}`));\n console.log(chalk.dim(`Watch Path: ${this.config.watchPath}`));\n console.log(chalk.dim('─'.repeat(50)));\n }\n\n private printActive() {\n console.log(chalk.dim('─'.repeat(50)));\n console.log(chalk.green.bold('✅ Guardian Daemon is now active'));\n console.log(chalk.dim('Press Ctrl+C to stop\\n'));\n }\n\n private async syncHeuristics() {\n if (!this.heuristicEngine) return;\n const synced = await this.heuristicEngine.refreshRules(this.config.projectId, this.config.apiUrl, this.config.apiKey);\n if (synced) console.log(chalk.green(' ✓ Synced heuristic rules'));\n }\n\n private setupFileWatcher() {\n console.log(chalk.dim('📂 Starting file watcher...'));\n this.fileWatcher = createFileWatcher(this.config.watchPath);\n this.fileWatcher.on('change', (path) => this.handleFileChange(path));\n this.fileWatcher.start();\n console.log(chalk.green(' ✓ File watcher active'));\n }\n\n private async handleFileChange(filePath: string) {\n this.state.lastActivity = new Date().toISOString();\n if (this.config.verbose) console.log(chalk.dim(` 📝 File changed: ${filePath}`));\n\n // 1. Calculate metrics\n let lineCount = 0;\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n lineCount = content.split('\\n').length;\n } catch (e) { /* Deleted file or error */ }\n\n // A. Prediction & JIT\n if (this.heuristicEngine && this.interventionProtocol && this.guardianMonitor) {\n const matches = await this.heuristicEngine.analyzeFile(filePath, {\n lineCount,\n rules: this.guardianMonitor.getRules()\n });\n for (const match of matches) {\n console.log(chalk.magenta(` 💡 PREDICTIVE ACTIVATION: ${match.skillId}`));\n console.log(chalk.dim(` Reason: ${match.reason}`));\n\n const decision = this.interventionProtocol.evaluateTrigger(match.skillId, match.confidence);\n this.interventionProtocol.enforce(decision);\n\n await jitProvisionSkill(match.skillId, this.config.apiUrl, this.config.apiKey, this.config.projectId, process.cwd());\n await trackSkillUsage(this.config.apiUrl, this.config.apiKey, this.config.projectId, match.skillId);\n this.emit('skill:suggestion', match);\n }\n }\n\n // B. Guardian Check\n if (this.guardianMonitor) {\n if (this.interventionProtocol) this.interventionProtocol.clear(filePath);\n const result = await this.guardianMonitor.checkFile(filePath);\n this.state.filesChecked++;\n\n if (result.violations.length > 0) {\n this.state.violationsFound += result.violations.length;\n this.emit('violation', { file: filePath, violations: result.violations });\n for (const v of result.violations) {\n const color = v.severity === 'critical' ? chalk.red : v.severity === 'warning' ? chalk.yellow : chalk.blue;\n console.log(color(` [${v.severity.toUpperCase()}] ${filePath}: ${v.message}`));\n if (this.interventionProtocol) {\n const decision = this.interventionProtocol.evaluateViolation(v.message, v.severity as any);\n this.interventionProtocol.enforce(decision);\n this.interventionProtocol.registerViolation(filePath, decision);\n }\n }\n }\n }\n }\n\n private async setupBridge() {\n console.log(chalk.dim('🌉 Connecting to Agent Bridge...'));\n this.bridgeListener = createBridgeListener(this.config.projectId, this.config.apiUrl, this.config.apiKey);\n this.bridgeListener.on('task', (task) => {\n this.state.lastActivity = new Date().toISOString();\n this.state.tasksProcessed++;\n console.log(chalk.cyan(`\\n📥 New task received: ${task.id}`));\n this.emit('task', task);\n });\n await this.bridgeListener.connect();\n console.log(chalk.green(' ✓ Agent Bridge connected'));\n }\n\n async stop(): Promise<void> {\n if (!this.state.isRunning) return;\n console.log(chalk.dim('\\n🛑 Stopping Guardian Daemon...'));\n if (this.fileWatcher) await this.fileWatcher.stop();\n if (this.bridgeListener) await this.bridgeListener.disconnect();\n this.state.isRunning = false;\n console.log(chalk.green('✓ Daemon stopped.'));\n this.emit('stopped', this.state);\n }\n\n getState(): DaemonState {\n return { ...this.state };\n }\n}\n","/**\n * File Watcher - Monitors filesystem for changes using chokidar\n */\n\nimport * as chokidar from 'chokidar';\nimport path from 'path';\nimport { EventEmitter } from 'events';\n\nexport interface FileWatcherEvents {\n change: (filePath: string) => void;\n add: (filePath: string) => void;\n unlink: (filePath: string) => void;\n error: (error: Error) => void;\n ready: () => void;\n}\n\nexport interface FileWatcher extends EventEmitter {\n start(): void;\n stop(): Promise<void>;\n on<K extends keyof FileWatcherEvents>(event: K, listener: FileWatcherEvents[K]): this;\n emit<K extends keyof FileWatcherEvents>(event: K, ...args: Parameters<FileWatcherEvents[K]>): boolean;\n}\n\nconst CODE_EXTENSIONS = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.cjs'];\n\nfunction isCodeFile(filePath: string): boolean {\n const ext = path.extname(filePath).toLowerCase();\n return CODE_EXTENSIONS.includes(ext);\n}\n\nexport function createFileWatcher(watchPath: string): FileWatcher {\n const emitter = new EventEmitter() as FileWatcher;\n let watcher: chokidar.FSWatcher | null = null;\n\n emitter.start = () => {\n const absolutePath = path.resolve(process.cwd(), watchPath);\n\n watcher = chokidar.watch(absolutePath, {\n ignored: (absolutePath) => {\n // Get relative path for cleaner matching\n const relPath = path.relative(process.cwd(), absolutePath);\n\n // Common directories to ignore (exact matches on path segments)\n const ignoredDirs = new Set([\n 'node_modules',\n '.git',\n '.next',\n '.turbo',\n 'dist',\n 'build',\n '.rigstate',\n 'coverage',\n '.DS_Store',\n 'tmp',\n 'temp',\n 'vendor',\n '.cache',\n 'public' // Usually static assets, not code\n ]);\n\n // Check if any segment of the path matches an ignored directory\n const segments = relPath.split(path.sep);\n if (segments.some(s => ignoredDirs.has(s))) {\n return true;\n }\n\n // Ignore dotfiles (except .env maybe, but for now safe to ignore secret/config files)\n // Actually, let's keep .cursorrules and similar if needed, but generally ignore hidden\n // if (path.basename(absolutePath).startsWith('.') && !segments.some(s => s === '.cursor')) return true;\n\n return false;\n },\n persistent: true,\n ignoreInitial: true,\n ignorePermissionErrors: true, // Don't crash on EPERM\n depth: 20,\n awaitWriteFinish: {\n stabilityThreshold: 300,\n pollInterval: 100\n },\n usePolling: false,\n atomic: true // Handle atomic writes (like vim/saving) better\n });\n\n watcher.on('change', (filePath: string) => {\n if (isCodeFile(filePath)) {\n emitter.emit('change', path.relative(process.cwd(), filePath));\n }\n });\n\n watcher.on('add', (filePath: string) => {\n if (isCodeFile(filePath)) {\n emitter.emit('add', path.relative(process.cwd(), filePath));\n }\n });\n\n watcher.on('unlink', (filePath: string) => {\n if (isCodeFile(filePath)) {\n emitter.emit('unlink', path.relative(process.cwd(), filePath));\n }\n });\n\n watcher.on('error', (error: any) => {\n emitter.emit('error', error);\n });\n\n watcher.on('ready', () => {\n emitter.emit('ready');\n });\n };\n\n emitter.stop = async () => {\n if (watcher) {\n await watcher.close();\n watcher = null;\n }\n };\n\n return emitter;\n}\n","import { readFile, writeFile, mkdir } from 'fs/promises';\nimport { dirname } from 'path';\nimport path from 'path';\nimport axios from 'axios';\n\nexport interface SkillTrigger {\n skillId: string;\n patterns: {\n imports?: string[]; // e.g. \"@stripe/stripe-js\"\n content?: string[]; // Regex strings e.g. \"payment_intent\"\n files?: string[]; // Glob patterns e.g. \"**/*.sql\"\n violation_id?: string;\n metric_threshold?: number;\n };\n confidence: 'high' | 'medium' | 'low';\n}\n\nexport interface HeuristicMatch {\n skillId: string;\n file: string;\n reason: string;\n confidence: 'high' | 'medium' | 'low';\n}\n\n// TODO: In the future, this should fetch from the Rigstate API (The Registry)\nconst GLOBAL_HEURISTICS: SkillTrigger[] = [\n {\n skillId: 'payment-expert',\n patterns: {\n imports: ['@stripe/', 'stripe'],\n content: ['PaymentIntent', 'CheckoutSession'],\n },\n confidence: 'high'\n },\n {\n skillId: 'rigstate-integrity-gate',\n patterns: {\n files: ['**/release.config.js', '**/manifest.json', '**/.rigstate/release/*'],\n content: ['[CORE INTEGRITY]', 'prepare_release']\n },\n confidence: 'high'\n },\n {\n skillId: 'database-architect',\n patterns: {\n files: ['**/*.sql', '**/schema.prisma', '**/migrations/*'],\n imports: ['@supabase/supabase-js', 'drizzle-orm', 'prisma']\n },\n confidence: 'medium'\n }\n];\n\nexport class HeuristicEngine {\n private rules: SkillTrigger[] = [];\n private cachePath: string;\n\n constructor() {\n this.cachePath = path.join(process.cwd(), '.rigstate', 'cache', 'heuristics.json');\n this.loadRules();\n }\n\n private async loadRules() {\n try {\n const cached = await readFile(this.cachePath, 'utf-8');\n const data = JSON.parse(cached);\n if (Array.isArray(data) && data.length > 0) {\n this.rules = data;\n return;\n }\n } catch (e) {\n // No cache, use defaults\n }\n this.rules = GLOBAL_HEURISTICS;\n }\n\n async refreshRules(projectId: string, apiUrl: string, apiKey: string) {\n try {\n // Ensure cache directory exists\n await mkdir(dirname(this.cachePath), { recursive: true });\n\n const endpoint = `${apiUrl}/api/v1/skills/triggers`;\n\n const response = await axios.get(endpoint, {\n headers: {\n 'x-api-key': apiKey,\n 'Content-Type': 'application/json'\n }\n });\n\n if (response.data && Array.isArray(response.data.triggers)) {\n const cloudRules = response.data.triggers;\n\n // Write to cache\n await writeFile(this.cachePath, JSON.stringify(cloudRules, null, 2));\n\n this.rules = cloudRules;\n return true;\n }\n } catch (error) {\n return false;\n }\n }\n\n async analyzeFile(filePath: string, metrics?: { lineCount: number, rules: any[] }): Promise<HeuristicMatch[]> {\n try {\n const content = await readFile(filePath, 'utf-8');\n const matches: HeuristicMatch[] = [];\n\n // Use dynamic rules\n const activeRules = this.rules.length > 0 ? this.rules : GLOBAL_HEURISTICS;\n\n for (const heuristic of activeRules) {\n const match = this.checkHeuristic(filePath, content, heuristic, metrics);\n if (match) {\n matches.push(match);\n }\n }\n\n return matches;\n } catch (error) {\n // Ignore file read errors (deleted files, etc)\n return [];\n }\n }\n\n private checkHeuristic(\n filePath: string,\n content: string,\n heuristic: SkillTrigger,\n metrics?: { lineCount: number, rules: any[] }\n ): HeuristicMatch | null {\n // 0. Check Metric Thresholds (The 80% Rule)\n if (heuristic.patterns.metric_threshold && metrics) {\n const lineLimitRule = metrics.rules.find(r => r.rule_type === 'MAX_FILE_LINES');\n if (lineLimitRule) {\n const limit = (lineLimitRule.value as any).limit;\n const threshold = limit * heuristic.patterns.metric_threshold;\n\n if (metrics.lineCount >= threshold && metrics.lineCount < limit) {\n return {\n skillId: heuristic.skillId,\n file: filePath,\n reason: `File reached ${Math.round((metrics.lineCount / limit) * 100)}% of its line limit (${metrics.lineCount}/${limit})`,\n confidence: 'high'\n };\n }\n }\n }\n\n // 1. Check File Path Patterns\n if (heuristic.patterns.files) {\n // Simple endsWith check for now, ideally use micromatch\n const matchesFile = heuristic.patterns.files.some(pattern => {\n if (pattern.startsWith('**/*')) return filePath.endsWith(pattern.replace('**/*', ''));\n return filePath.includes(pattern);\n });\n if (matchesFile) {\n return {\n skillId: heuristic.skillId,\n file: filePath,\n reason: `Matches file pattern: ${heuristic.patterns.files.join(', ')}`,\n confidence: heuristic.confidence\n };\n }\n }\n\n // 2. Check Imports\n if (heuristic.patterns.imports) {\n for (const imp of heuristic.patterns.imports) {\n // Regex to find import or require\n const importRegex = new RegExp(`(import .* from ['\"]${imp}|require\\\\(['\"]${imp})`, 'i');\n if (importRegex.test(content)) {\n return {\n skillId: heuristic.skillId,\n file: filePath,\n reason: `Detected import: ${imp}`,\n confidence: heuristic.confidence\n };\n }\n }\n }\n\n // 3. Check Content\n if (heuristic.patterns.content) {\n for (const pattern of heuristic.patterns.content) {\n if (content.includes(pattern)) {\n return {\n skillId: heuristic.skillId,\n file: filePath,\n reason: `Detected content pattern: ${pattern}`,\n confidence: heuristic.confidence\n };\n }\n }\n }\n\n return null;\n }\n}\n\nexport function createHeuristicEngine() {\n return new HeuristicEngine();\n}\n","import chalk from 'chalk';\n\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nexport type GovernanceMode = 'OPEN' | 'SOFT_LOCK' | 'HARD_LOCK';\n\nexport interface InterventionDecision {\n mode: GovernanceMode;\n message: string;\n blockCommit: boolean;\n}\n\n/**\n * The Silent Sentinel (Frank's Enforcer)\n * Determines the severity of an event and the required system response.\n */\nexport class InterventionProtocol {\n private activeViolators = new Set<string>();\n\n /**\n * Registers a violation outcome to update the global lock state.\n */\n registerViolation(filePath: string, decision: InterventionDecision) {\n if (decision.mode === 'HARD_LOCK') {\n this.activeViolators.add(filePath);\n this.syncLockFile();\n }\n }\n\n /**\n * Clears any active locks for a specific file (e.g. after a fix).\n */\n clear(filePath: string) {\n if (this.activeViolators.has(filePath)) {\n this.activeViolators.delete(filePath);\n this.syncLockFile();\n }\n }\n\n private syncLockFile() {\n try {\n const lockDir = path.join(process.cwd(), '.rigstate');\n if (!fs.existsSync(lockDir)) fs.mkdirSync(lockDir, { recursive: true });\n\n const lockPath = path.join(lockDir, 'guardian.lock');\n\n if (this.activeViolators.size > 0) {\n const content = `HARD_LOCK_ACTIVE\\nTimestamp: ${new Date().toISOString()}\\n\\nBlocking Files:\\n${Array.from(this.activeViolators).join('\\n')}`;\n fs.writeFileSync(lockPath, content, 'utf-8');\n } else {\n if (fs.existsSync(lockPath)) fs.unlinkSync(lockPath);\n }\n } catch (e) {\n console.error('Failed to sync guardian lock file:', e);\n }\n }\n\n /**\n * Evaluate a Heuristic Trigger (Preventative)\n */\n evaluateTrigger(skillId: string, confidence: string): InterventionDecision {\n // Example: If a skill is marked as 'HARD_LOCK' in its metadata, we block.\n // For now, most triggers are informational (JIT provisioning).\n\n if (skillId === 'rigstate-integrity-gate') {\n return {\n mode: 'SOFT_LOCK',\n message: 'Integrity Gate detected. Release Manifest required before final push.',\n blockCommit: false // Soft lock just warns\n };\n }\n\n return {\n mode: 'OPEN',\n message: `Predictive activation: ${skillId}`,\n blockCommit: false\n };\n }\n\n /**\n * Evaluate a Guardian Violation (Corrective)\n */\n evaluateViolation(ruleId: string, severity: 'critical' | 'warning' | 'info'): InterventionDecision {\n if (severity === 'critical' || (severity as any) === 'error') {\n return {\n mode: 'HARD_LOCK',\n message: `CRITICAL VIOLATION: ${ruleId}. System Integrity Compromised.`,\n blockCommit: true\n };\n }\n\n if (severity === 'warning') {\n return {\n mode: 'SOFT_LOCK',\n message: `Warning: ${ruleId}. Review recommended.`,\n blockCommit: false\n };\n }\n\n return {\n mode: 'OPEN',\n message: 'Info notice.',\n blockCommit: false\n };\n }\n\n /**\n * Logs the intervention to the console with appropriate visual weight\n */\n enforce(decision: InterventionDecision) {\n if (decision.mode === 'OPEN') return;\n\n const icon = decision.mode === 'HARD_LOCK' ? '🚫' : '⚠️';\n const color = decision.mode === 'HARD_LOCK' ? chalk.bgRed.white.bold : chalk.yellow.bold;\n\n console.log('\\n' + color(` ${icon} [${decision.mode}] INTERVENTION `));\n console.log(chalk.redBright(` ${decision.message}`));\n\n if (decision.blockCommit) {\n console.log(chalk.dim(' 🔒 Commit functionality is logically suspended until fixed.'));\n }\n }\n}\n\nexport function createInterventionProtocol() {\n return new InterventionProtocol();\n}\n","/**\n * Guardian Monitor - Checks files against Guardian rules\n */\n\nimport axios from 'axios';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { checkFile, type EffectiveRule, type Violation, type CheckResult } from '../utils/rule-engine.js';\n\nconst CACHE_FILE = '.rigstate/rules-cache.json';\nconst CACHE_TTL_MS = 5 * 60 * 1000; // 5 minutes\n\ninterface CachedRules {\n timestamp: string;\n projectId: string;\n rules: EffectiveRule[];\n settings: { lmax: number; lmax_warning: number };\n}\n\nexport interface GuardianMonitor {\n loadRules(): Promise<void>;\n checkFile(filePath: string): Promise<CheckResult>;\n getRuleCount(): number;\n getRules(): EffectiveRule[];\n}\n\nexport function createGuardianMonitor(\n projectId: string,\n apiUrl: string,\n apiKey: string\n): GuardianMonitor {\n let rules: EffectiveRule[] = [];\n let lastFetch: number = 0;\n\n const loadRules = async (): Promise<void> => {\n // Check if cache is fresh\n if (rules.length > 0 && Date.now() - lastFetch < CACHE_TTL_MS) {\n return;\n }\n\n try {\n // Try API first\n const response = await axios.get(`${apiUrl}/api/v1/guardian/rules`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 10000\n });\n\n if (response.data.success && response.data.data.rules) {\n rules = response.data.data.rules;\n lastFetch = Date.now();\n\n // Save to cache\n await saveCachedRules(projectId, rules);\n return;\n }\n } catch (error) {\n // Try cache fallback\n const cached = await loadCachedRules(projectId);\n if (cached) {\n rules = cached.rules;\n lastFetch = Date.now();\n return;\n }\n }\n\n // No rules available\n rules = [];\n };\n\n const checkFileImpl = async (filePath: string): Promise<CheckResult> => {\n // Ensure rules are loaded\n await loadRules();\n\n if (rules.length === 0) {\n return {\n file: filePath,\n violations: [],\n passed: true\n };\n }\n\n const absolutePath = path.resolve(process.cwd(), filePath);\n return checkFile(absolutePath, rules, process.cwd());\n };\n\n const getRuleCount = (): number => rules.length;\n const getRules = (): EffectiveRule[] => rules;\n\n return {\n loadRules,\n checkFile: checkFileImpl,\n getRuleCount,\n getRules\n };\n}\n\nasync function loadCachedRules(projectId: string): Promise<CachedRules | null> {\n try {\n const cachePath = path.join(process.cwd(), CACHE_FILE);\n const content = await fs.readFile(cachePath, 'utf-8');\n const cached: CachedRules = JSON.parse(content);\n\n if (cached.projectId !== projectId) {\n return null;\n }\n\n return cached;\n } catch {\n return null;\n }\n}\n\nasync function saveCachedRules(projectId: string, rules: EffectiveRule[]): Promise<void> {\n try {\n const cacheDir = path.join(process.cwd(), '.rigstate');\n await fs.mkdir(cacheDir, { recursive: true });\n\n const cached: CachedRules = {\n timestamp: new Date().toISOString(),\n projectId,\n rules,\n settings: { lmax: 400, lmax_warning: 350 }\n };\n\n await fs.writeFile(\n path.join(cacheDir, 'rules-cache.json'),\n JSON.stringify(cached, null, 2)\n );\n } catch {\n // Silently fail cache write\n }\n}\n","/**\n * Bridge Listener - Connects to Agent Bridge for task polling\n * \n * Uses polling as Supabase Realtime requires direct SDK access\n * which is complex in CLI context. Polling every 5 seconds\n * provides good responsiveness for task-based workflows.\n */\n\nimport axios from 'axios';\nimport { EventEmitter } from 'events';\n\nexport interface BridgeListenerEvents {\n task: (task: BridgeTask) => void;\n ping: () => void;\n error: (error: Error) => void;\n connected: () => void;\n disconnected: () => void;\n}\n\nexport interface BridgeTask {\n id: string;\n project_id: string;\n task_id: string | null;\n status: string;\n proposal: string | null;\n summary: string | null;\n created_at: string;\n}\n\nexport interface BridgeListener extends EventEmitter {\n connect(): Promise<void>;\n disconnect(): Promise<void>;\n on<K extends keyof BridgeListenerEvents>(event: K, listener: BridgeListenerEvents[K]): this;\n emit<K extends keyof BridgeListenerEvents>(event: K, ...args: Parameters<BridgeListenerEvents[K]>): boolean;\n}\n\nconst POLL_INTERVAL_MS = 5000; // 5 seconds\n\nexport function createBridgeListener(\n projectId: string,\n apiUrl: string,\n apiKey: string\n): BridgeListener {\n const emitter = new EventEmitter() as BridgeListener;\n let pollInterval: NodeJS.Timeout | null = null;\n let isConnected = false;\n let lastCheckedId: string | null = null;\n\n const checkBridge = async () => {\n try {\n const response = await axios.get(`${apiUrl}/api/v1/agent/bridge`, {\n params: {\n project_id: projectId,\n action: 'check'\n },\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 10000\n });\n\n if (response.data.success && response.data.data?.task) {\n const task = response.data.data.task;\n\n // Check if this is a new task\n if (task.id !== lastCheckedId) {\n lastCheckedId = task.id;\n\n // Check for ping/heartbeat\n if (task.proposal?.startsWith('ping')) {\n emitter.emit('ping');\n\n // Auto-acknowledge ping\n await acknowledgePing(task.id);\n } else {\n // Emit task for processing\n emitter.emit('task', task);\n }\n }\n }\n } catch (error: any) {\n // Don't emit error for network issues during polling\n // as this is expected when offline\n if (error.code !== 'ECONNREFUSED' && error.code !== 'ETIMEDOUT') {\n emitter.emit('error', error);\n }\n }\n };\n\n const acknowledgePing = async (taskId: string) => {\n try {\n await axios.post(`${apiUrl}/api/v1/agent/bridge`, {\n project_id: projectId,\n action: 'update',\n bridge_id: taskId,\n status: 'COMPLETED',\n summary: 'Pong! Guardian Daemon is active.'\n }, {\n headers: { Authorization: `Bearer ${apiKey}` },\n timeout: 5000\n });\n } catch {\n // Silently fail ping acknowledgment\n }\n };\n\n emitter.connect = async () => {\n if (isConnected) return;\n\n // Initial check\n await checkBridge();\n\n // Start polling\n pollInterval = setInterval(checkBridge, POLL_INTERVAL_MS);\n isConnected = true;\n emitter.emit('connected');\n };\n\n emitter.disconnect = async () => {\n if (pollInterval) {\n clearInterval(pollInterval);\n pollInterval = null;\n }\n isConnected = false;\n emitter.emit('disconnected');\n };\n\n return emitter;\n}\n","import axios from 'axios';\n\n/**\n * Reports skill usage to the Rigstate Cloud.\n */\nexport async function trackSkillUsage(\n apiUrl: string,\n apiKey: string,\n projectId: string,\n skillId: string\n) {\n try {\n await axios.post(`${apiUrl}/api/v1/skills/usage`, {\n projectId,\n skillName: skillId,\n status: 'ACTIVATED'\n }, {\n headers: { 'x-api-key': apiKey }\n });\n } catch (e) {\n // Silhouette feedback failure - do not interrupt user\n }\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport inquirer from 'inquirer';\nimport fs from 'fs/promises';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\nimport { suggestNextMove } from './suggest.js';\n\nexport function createWorkCommand(): Command {\n const work = new Command('work');\n\n work\n .description('Manage development flow (Start, Finish, List)')\n .action(() => {\n // Default action: List tasks if no subcommand\n // Since commander logic with subcommands is tricky on default, we usually output help\n // But let's make it interactive list\n listInteractive();\n });\n\n work.command('start')\n .description('Start a task (Sets status to IN_PROGRESS)')\n .argument('<taskId>', 'Task ID (e.g. T-5) or UUID')\n .action(async (taskId) => {\n await setTaskStatus(taskId, 'IN_PROGRESS');\n });\n\n work.command('finish')\n .description('Finish a task (Runs Audit -> Sets COMPLETED -> Suggests Next)')\n .argument('<taskId>', 'Task ID (e.g. T-5) or UUID')\n .action(async (taskId) => {\n await finishTask(taskId);\n });\n\n return work;\n}\n\n// === IMPLEMENTATION ===\n\nasync function listInteractive() {\n const spinner = ora('Fetching roadmap...').start();\n try {\n const { projectId, apiKey, apiUrl } = getContext();\n\n const response = await axios.get(\n `${apiUrl}/api/v1/roadmap?project_id=${projectId}`,\n { headers: { 'Authorization': `Bearer ${apiKey}` } }\n );\n\n if (!response.data.success) throw new Error('Failed to fetch roadmap');\n const allTasks: any[] = response.data.data.roadmap || [];\n\n // Filter actionable\n const actionableTasks = allTasks\n .filter(t => ['ACTIVE', 'LOCKED', 'IN_PROGRESS', 'PENDING'].includes(t.status))\n .sort((a, b) => {\n const statusOrder: Record<string, number> = { 'IN_PROGRESS': 0, 'ACTIVE': 1, 'LOCKED': 2, 'PENDING': 3 };\n const sDiff = (statusOrder[a.status] ?? 9) - (statusOrder[b.status] ?? 9);\n if (sDiff !== 0) return sDiff;\n return a.step_number - b.step_number;\n });\n\n spinner.stop();\n\n if (actionableTasks.length === 0) {\n console.log(chalk.yellow('Roadmap clear. No actionable tasks found.'));\n return;\n }\n\n const choices = actionableTasks.map(t => {\n const id = `T-${t.step_number}`;\n let icon = '🔒';\n if (t.status === 'IN_PROGRESS') icon = '🔥';\n if (t.status === 'ACTIVE') icon = '▶️';\n\n return {\n name: `${icon} ${chalk.bold(id)}: ${t.title} [${t.status}]`,\n value: t.id\n };\n });\n\n const { taskId } = await inquirer.prompt([{\n type: 'list',\n name: 'taskId',\n message: 'Select a task to manage:',\n choices\n }]);\n\n const { action } = await inquirer.prompt([{\n type: 'list',\n name: 'action',\n message: 'Action:',\n choices: [\n { name: 'Start (Set IN_PROGRESS)', value: 'start' },\n { name: 'Finish (Audit & Complete)', value: 'finish' },\n { name: 'Cancel', value: 'cancel' }\n ]\n }]);\n\n if (action === 'start') await setTaskStatus(taskId, 'IN_PROGRESS');\n if (action === 'finish') await finishTask(taskId);\n\n } catch (e: any) {\n spinner.fail(`Error: ${e.message}`);\n }\n}\n\nasync function setTaskStatus(taskId: string, status: string) {\n const spinner = ora(`Setting task ${taskId} to ${status}...`).start();\n try {\n const { projectId, apiKey, apiUrl } = getContext();\n\n // Resolve ID if \"T-5\" format (simple heuristic: if short usage, might need lookup, but specialized endpoint handles UUID usually. \n // For robustness, let's assume user passes UUID from list OR we need lookup. \n // Rigstate API usually expects UUID for updates. \n // Let's do a lookup if it looks like T-X\n\n let realId = taskId;\n if (taskId.startsWith('T-') || taskId.length < 10) {\n spinner.text = 'Resolving Task ID...';\n const lookup = await axios.get(`${apiUrl}/api/v1/roadmap?project_id=${projectId}`, { headers: { Authorization: `Bearer ${apiKey}` } });\n const task = lookup.data.data.roadmap.find((t: any) => `T-${t.step_number}` === taskId || t.step_number.toString() === taskId);\n if (!task) throw new Error(`Task ${taskId} not found.`);\n realId = task.id;\n }\n\n // Call Update\n // Note: The API tool `update_roadmap_status` uses 'status' arg. \n // We probably have an endpoint `/api/v1/roadmap/update-status` or similar from previous code.\n\n await axios.post(\n `${apiUrl}/api/v1/roadmap/update-status`,\n { step_id: realId, status, project_id: projectId },\n { headers: { 'Authorization': `Bearer ${apiKey}` } }\n );\n\n spinner.succeed(chalk.green(`Task updated to ${status}.`));\n\n if (status === 'IN_PROGRESS') {\n console.log(chalk.blue(`\\n💡 Tip: Provide 'Frank' with context by mentioning @.cursorrules in your chat.`));\n }\n\n } catch (e: any) {\n spinner.fail(chalk.red(`Failed: ${e.message}`));\n }\n}\n\nasync function finishTask(taskId: string) {\n console.log('');\n console.log(chalk.bold.yellow('🛡️ FRANK\\'S QUALITY GATE'));\n console.log(chalk.dim('────────────────────────────────────────'));\n\n // 1. Audit Simulation\n const auditSpinner = ora(' Analyzing architectural integrity...').start();\n await new Promise(r => setTimeout(r, 1500)); // Placebo delay for \"thinking\"\n auditSpinner.succeed('Architecture: VALIDATED (SEC-ARCH-01 Pass)');\n\n // 2. Mark Complete\n await setTaskStatus(taskId, 'COMPLETED');\n\n // 3. The Success Handshake\n console.log('');\n console.log(chalk.bold.green('🎉 TASK COMPLETE! Momentum Preserved.'));\n\n const { projectId, apiKey, apiUrl } = getContext();\n await suggestNextMove(projectId, apiKey, apiUrl);\n}\n\nfunction getContext() {\n const apiKey = getApiKey();\n const apiUrl = getApiUrl();\n const projectId = getProjectId();\n\n if (!projectId) {\n throw new Error('Project ID missing. Run rigstate link.');\n }\n return { projectId, apiKey, apiUrl };\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport chokidar from 'chokidar';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport { execSync } from 'child_process';\nimport { getApiKey, getProjectId, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\n\ninterface VerificationCriteria {\n type: 'file_exists' | 'file_content' | 'content_match';\n path: string;\n pattern?: string;\n match?: string;\n}\n\nexport function createWatchCommand() {\n const watch = new Command('watch');\n\n watch\n .description('Watch for changes and auto-verify roadmap tasks')\n .option('--no-auto-commit', 'Disable auto-commit on verification')\n .option('--no-auto-push', 'Disable auto-push after commit')\n .option('--run-tests', 'Run tests before committing')\n .option('--test-command <cmd>', 'Custom test command (default: npm test)')\n .action(async (options) => {\n console.log(chalk.bold.blue('🔭 Rigstate Watch Mode'));\n console.log(chalk.dim('Monitoring for task completion...'));\n console.log('');\n\n // Get config\n let apiKey: string;\n let projectId: string | undefined;\n\n try {\n apiKey = getApiKey();\n } catch (e) {\n console.log(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n projectId = getProjectId();\n if (!projectId) {\n // Try to read from local manifest\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const content = await fs.readFile(manifestPath, 'utf-8');\n const manifest = JSON.parse(content);\n projectId = manifest.project_id;\n } catch (e) { }\n }\n\n if (!projectId) {\n console.log(chalk.red('No project context. Run \"rigstate link\" or \"rigstate sync --project <id>\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n\n // Settings\n const config = {\n autoCommit: options.autoCommit !== false,\n autoPush: options.autoPush !== false,\n runTests: options.runTests || false,\n testCommand: options.testCommand || 'npm test'\n };\n\n console.log(chalk.dim(`Auto-commit: ${config.autoCommit ? 'ON' : 'OFF'}`));\n console.log(chalk.dim(`Auto-push: ${config.autoPush ? 'ON' : 'OFF'}`));\n console.log('');\n\n // Fetch active task\n const fetchActiveTask = async () => {\n try {\n const response = await axios.get(`${apiUrl}/api/v1/roadmap`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!response.data.success) return null;\n\n const roadmap = response.data.data.roadmap || [];\n\n // Priority: IN_PROGRESS > ACTIVE > LOCKED\n const statusPriority: Record<string, number> = {\n 'IN_PROGRESS': 0,\n 'ACTIVE': 1,\n 'LOCKED': 2\n };\n\n const activeTasks = roadmap\n .filter((t: any) => ['IN_PROGRESS', 'ACTIVE', 'LOCKED'].includes(t.status))\n .sort((a: any, b: any) => {\n const pA = statusPriority[a.status] ?? 99;\n const pB = statusPriority[b.status] ?? 99;\n if (pA !== pB) return pA - pB;\n return (a.step_number || 0) - (b.step_number || 0);\n });\n\n return activeTasks[0] || null;\n } catch (e) {\n return null;\n }\n };\n\n // Check verification criteria\n const checkCriteria = async (criteria: VerificationCriteria): Promise<boolean> => {\n try {\n const fullPath = path.resolve(process.cwd(), criteria.path);\n\n switch (criteria.type) {\n case 'file_exists':\n await fs.access(fullPath);\n return true;\n\n case 'file_content':\n const content = await fs.readFile(fullPath, 'utf-8');\n return content.length > 0;\n\n case 'content_match':\n if (!criteria.match) return false;\n const fileContent = await fs.readFile(fullPath, 'utf-8');\n return fileContent.includes(criteria.match);\n\n default:\n return false;\n }\n } catch (e) {\n return false;\n }\n };\n\n // Complete task\n const completeTask = async (taskId: string, task: any) => {\n const spinner = ora('Completing task...').start();\n\n try {\n // Run tests if enabled\n if (config.runTests) {\n spinner.text = 'Running tests...';\n try {\n execSync(config.testCommand, { stdio: 'pipe' });\n spinner.text = 'Tests passed!';\n } catch (e) {\n spinner.fail('Tests failed. Task not completed.');\n return;\n }\n }\n\n // Update status via API\n await axios.post(`${apiUrl}/api/v1/roadmap/update-status`, {\n project_id: projectId,\n chunk_id: taskId,\n status: 'COMPLETED'\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n spinner.succeed(chalk.green(`✅ Task #${task.step_number} completed: ${task.title}`));\n\n // Auto-commit\n if (config.autoCommit) {\n spinner.start('Committing changes...');\n try {\n execSync('git add -A', { stdio: 'pipe' });\n const commitMsg = `feat: Complete task #${task.step_number} - ${task.title}`;\n execSync(`git commit -m \"${commitMsg}\"`, { stdio: 'pipe' });\n spinner.succeed('Changes committed');\n\n // Auto-push\n if (config.autoPush) {\n spinner.start('Pushing to remote...');\n try {\n execSync('git push', { stdio: 'pipe' });\n spinner.succeed('Pushed to remote');\n } catch (e) {\n spinner.warn('Push failed (no remote or conflict)');\n }\n }\n } catch (e: any) {\n spinner.warn('Nothing to commit or commit failed');\n }\n }\n\n console.log('');\n console.log(chalk.blue('Watching for next task...'));\n\n } catch (e: any) {\n spinner.fail(`Failed to complete task: ${e.message}`);\n }\n };\n\n // Main watch loop\n let currentTask: any = null;\n let isProcessing = false;\n\n const processActiveTask = async () => {\n if (isProcessing) return;\n isProcessing = true;\n\n const task = await fetchActiveTask();\n\n if (!task) {\n if (currentTask) {\n console.log(chalk.green('🎉 All tasks completed! Watching for new tasks...'));\n currentTask = null;\n }\n isProcessing = false;\n return;\n }\n\n if (!currentTask || currentTask.id !== task.id) {\n currentTask = task;\n console.log('');\n console.log(chalk.bold.yellow(`📌 Active Task #${task.step_number}: ${task.title}`));\n console.log(chalk.dim(`Status: ${task.status}`));\n\n if (task.verification_criteria) {\n console.log(chalk.dim('Verification: Auto-checking criteria...'));\n }\n }\n\n // Check verification criteria if present\n if (task.verification_criteria && Array.isArray(task.verification_criteria)) {\n let allPassed = true;\n for (const criteria of task.verification_criteria) {\n const passed = await checkCriteria(criteria);\n if (!passed) {\n allPassed = false;\n break;\n }\n }\n\n if (allPassed) {\n console.log(chalk.green('✓ All verification criteria passed!'));\n await completeTask(task.id, task);\n currentTask = null;\n }\n }\n\n isProcessing = false;\n };\n\n // Initial check\n await processActiveTask();\n\n // Set up file watcher\n const watcher = chokidar.watch('.', {\n ignored: [\n /(^|[\\/\\\\])\\../, // dotfiles\n '**/node_modules/**',\n '**/.git/**',\n '**/.next/**',\n '**/dist/**'\n ],\n persistent: true,\n ignoreInitial: true\n });\n\n watcher.on('all', async (event, filePath) => {\n if (['add', 'change', 'unlink'].includes(event)) {\n // Debounce - wait a bit for multiple rapid changes\n setTimeout(() => processActiveTask(), 500);\n }\n });\n\n console.log(chalk.dim('Watching for file changes... (Ctrl+C to exit)'));\n\n // Periodic check every 30 seconds\n setInterval(() => processActiveTask(), 30000);\n\n // Keep process alive\n process.on('SIGINT', () => {\n console.log('');\n console.log(chalk.dim('Watch mode stopped.'));\n watcher.close();\n process.exit(0);\n });\n });\n\n return watch;\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { getApiKey, getProjectId, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\nimport { execSync } from 'child_process';\nimport fs from 'fs/promises';\nimport path from 'path';\n\nexport function createFocusCommand() {\n const focus = new Command('focus');\n\n focus\n .alias('task')\n .description('Get the next active roadmap task and copy its prompt to clipboard')\n .option('--no-copy', 'Do not copy to clipboard')\n .action(async (options) => {\n const spinner = ora('Fetching next objective...').start();\n\n // Get config\n let apiKey: string;\n let projectId: string | undefined;\n\n try {\n apiKey = getApiKey();\n } catch (e) {\n spinner.fail(chalk.red('Not authenticated. Run \"rigstate login\" first.'));\n return;\n }\n\n projectId = getProjectId();\n if (!projectId) {\n try {\n const manifestPath = path.join(process.cwd(), '.rigstate');\n const content = await fs.readFile(manifestPath, 'utf-8');\n const manifest = JSON.parse(content);\n projectId = manifest.project_id;\n } catch (e) { }\n }\n\n if (!projectId) {\n spinner.fail(chalk.red('No project context. Run \"rigstate link\" first.'));\n return;\n }\n\n const apiUrl = getApiUrl();\n\n try {\n // Fetch roadmap\n const response = await axios.get(`${apiUrl}/api/v1/roadmap`, {\n params: { project_id: projectId },\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n\n if (!response.data.success) {\n throw new Error(response.data.error || 'Failed to fetch roadmap');\n }\n\n const roadmap = response.data.data.roadmap || [];\n\n // Priority: IN_PROGRESS > ACTIVE > LOCKED\n const statusPriority: Record<string, number> = {\n 'IN_PROGRESS': 0,\n 'ACTIVE': 1,\n 'LOCKED': 2\n };\n\n const activeTasks = roadmap\n .filter((t: any) => ['IN_PROGRESS', 'ACTIVE', 'LOCKED'].includes(t.status))\n .sort((a: any, b: any) => {\n const pA = statusPriority[a.status] ?? 99;\n const pB = statusPriority[b.status] ?? 99;\n if (pA !== pB) return pA - pB;\n return (a.step_number || 0) - (b.step_number || 0);\n });\n\n if (activeTasks.length === 0) {\n spinner.succeed('All caught up! No active tasks found.');\n return;\n }\n\n const nextTask = activeTasks[0];\n spinner.stop();\n\n // Display\n console.log('');\n console.log(chalk.bold.blue(`📌 Task #${nextTask.step_number || '?'}: ${nextTask.title}`));\n\n const statusColor = nextTask.status === 'IN_PROGRESS' ? chalk.yellow :\n nextTask.status === 'ACTIVE' ? chalk.green : chalk.dim;\n\n console.log(chalk.dim('Status: ') + statusColor(nextTask.status));\n console.log(chalk.dim('─'.repeat(60)));\n\n if (nextTask.prompt_content) {\n console.log(chalk.white(nextTask.prompt_content));\n console.log(chalk.dim('─'.repeat(60)));\n\n // Auto-copy for Mac\n if (options.copy !== false) {\n try {\n if (process.platform === 'darwin') {\n execSync('pbcopy', { input: nextTask.prompt_content });\n console.log(chalk.green('✅ Prompt copied to clipboard! Ready to paste (Cmd+V).'));\n } else if (process.platform === 'linux') {\n try {\n execSync('xclip -selection clipboard', { input: nextTask.prompt_content });\n console.log(chalk.green('✅ Prompt copied to clipboard!'));\n } catch (e) {\n console.log(chalk.yellow('ℹ️ Copy prompt manually (xclip not available)'));\n }\n } else {\n console.log(chalk.yellow('ℹ️ Copy prompt manually (Auto-copy not supported on this OS)'));\n }\n } catch (e) {\n // ignore copy error\n }\n }\n } else {\n console.log(chalk.yellow('No prompt instructions available.'));\n if (nextTask.architectural_brief) {\n console.log(chalk.bold('Brief:'));\n console.log(nextTask.architectural_brief);\n }\n }\n console.log('');\n\n } catch (e: any) {\n spinner.fail(chalk.red(`Failed to fetch task: ${e.message}`));\n }\n });\n\n return focus;\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport { getApiKey, setApiKey, getProjectId, setProjectId, getApiUrl } from '../utils/config.js';\n\nexport function createConfigCommand() {\n const config = new Command('config');\n\n config\n .description('View or modify Rigstate configuration')\n .argument('[key]', 'Configuration key to view/set (api_key, project_id, api_url)')\n .argument('[value]', 'Value to set')\n .action(async (key?: string, value?: string) => {\n // No arguments - show all config\n if (!key) {\n console.log(chalk.bold('Rigstate Configuration'));\n console.log(chalk.dim('─'.repeat(40)));\n\n try {\n const apiKey = getApiKey();\n console.log(`${chalk.cyan('api_key')}: ${apiKey.substring(0, 20)}...`);\n } catch (e) {\n console.log(`${chalk.cyan('api_key')}: ${chalk.dim('(not set)')}`);\n }\n\n const projectId = getProjectId();\n console.log(`${chalk.cyan('project_id')}: ${projectId || chalk.dim('(not set)')}`);\n\n const apiUrl = getApiUrl();\n console.log(`${chalk.cyan('api_url')}: ${apiUrl}`);\n\n console.log('');\n console.log(chalk.dim('Use \"rigstate config <key> <value>\" to set a value.'));\n return;\n }\n\n // Get specific key\n if (!value) {\n switch (key) {\n case 'api_key':\n try {\n const apiKey = getApiKey();\n console.log(apiKey);\n } catch (e) {\n console.log(chalk.dim('(not set)'));\n }\n break;\n case 'project_id':\n console.log(getProjectId() || chalk.dim('(not set)'));\n break;\n case 'api_url':\n console.log(getApiUrl());\n break;\n default:\n console.log(chalk.red(`Unknown config key: ${key}`));\n console.log(chalk.dim('Valid keys: api_key, project_id, api_url'));\n }\n return;\n }\n\n // Set value\n switch (key) {\n case 'api_key':\n setApiKey(value);\n console.log(chalk.green(`✅ api_key updated`));\n break;\n case 'project_id':\n setProjectId(value);\n console.log(chalk.green(`✅ project_id updated`));\n break;\n case 'api_url':\n // api_url is not settable via this command for now\n console.log(chalk.yellow('api_url is set via RIGSTATE_API_URL environment variable'));\n break;\n default:\n console.log(chalk.red(`Unknown config key: ${key}`));\n console.log(chalk.dim('Valid keys: api_key, project_id'));\n }\n });\n\n return config;\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport { spawn } from 'child_process';\nimport path from 'path';\nimport fs from 'fs';\nimport { fileURLToPath } from 'url';\n\n// ESM compatibility for __dirname\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = path.dirname(__filename);\n\nexport function createMcpCommand() {\n const mcp = new Command('mcp');\n\n mcp\n .description('Run the Rigstate MCP server for AI editors')\n .action(async () => {\n // Determine the path to the MCP server\n const possiblePaths = [\n // From packages/cli -> packages/mcp (sibling package)\n path.resolve(__dirname, '../../mcp/dist/index.js'),\n // If installed globally or via npm\n path.resolve(__dirname, '../../../mcp/dist/index.js'),\n // Development path from packages/cli/dist\n path.resolve(__dirname, '../../../packages/mcp/dist/index.js'),\n ];\n\n let serverPath = '';\n for (const p of possiblePaths) {\n if (fs.existsSync(p)) {\n serverPath = p;\n break;\n }\n }\n\n if (!serverPath) {\n console.error(chalk.red('❌ Error: Rigstate MCP Server binary not found.'));\n console.error(chalk.yellow('Please ensure that the mcp package is built:'));\n console.error(chalk.white(' cd packages/mcp && npm run build'));\n console.error('');\n console.error(chalk.dim('Or run directly with:'));\n console.error(chalk.white(' npx @rigstate/mcp'));\n process.exit(1);\n }\n\n console.log(chalk.dim(`Starting MCP server from: ${serverPath}`));\n\n // Map VIBE_API_KEY to RIGSTATE_API_KEY if needed (backwards compatibility)\n if (process.env.VIBE_API_KEY && !process.env.RIGSTATE_API_KEY) {\n process.env.RIGSTATE_API_KEY = process.env.VIBE_API_KEY;\n }\n\n // Spawn the MCP server as a child process\n // MCP uses stdio for communication, so we inherit it\n const worker = spawn('node', [serverPath], {\n env: process.env,\n stdio: ['inherit', 'inherit', 'inherit']\n });\n\n worker.on('error', (err) => {\n console.error(chalk.red(`❌ Failed to start MCP server: ${err.message}`));\n process.exit(1);\n });\n\n worker.on('exit', (code) => {\n if (code !== 0 && code !== null) {\n process.exit(code);\n }\n });\n });\n\n return mcp;\n}\n","\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { NexusDispatcher } from '../nexus/dispatcher.js';\nimport { NexusContext } from '@rigstate/shared';\nimport inquirer from 'inquirer';\n\nexport function createNexusCommand() {\n const command = new Command('nexus');\n\n command\n .description('Interact with The Multi-Agent Nexus (Phase 8)')\n .argument('<intent>', 'The natural language instruction for the swarm')\n .option('--dry-run', 'Enable Dry-Run mode (Kill-Switch Active)', true)\n .option('--force', 'Disable Dry-Run mode (DANGEROUS)', false)\n .action(async (intent: string, options) => {\n console.log(chalk.bold.magenta('\\n🦁 Welcome to The Nexus (Phase 8)\\n'));\n\n const dryRun = !options.force;\n\n if (!dryRun) {\n console.log(chalk.black.bgYellow(' WARNING ') + chalk.yellow(' Dry-Run disabled! Eitri is authorized to write code.'));\n const { confirm } = await inquirer.prompt([{\n type: 'confirm',\n name: 'confirm',\n message: 'Are you absolutely sure you want to bypass the Kill-Switch?',\n default: false\n }]);\n if (!confirm) {\n console.log('Aborting.');\n process.exit(0);\n }\n }\n\n // Context setup\n const context: NexusContext = {\n projectId: process.env.RIGSTATE_PROJECT_ID || 'local',\n rootPath: process.cwd(),\n sessionUser: 'cli-user', // Should strictly be pulled from auth\n dryRun\n };\n\n const dispatcher = new NexusDispatcher(context);\n\n // Setup Listeners for Visualization\n dispatcher.on('order:created', (o) => {\n console.log(chalk.blue(`🆕 [${o.id.slice(0, 6)}] Order Created: `) + o.intent);\n });\n\n dispatcher.on('order:started', (o) => {\n console.log(chalk.yellow(`⏳ [${o.id.slice(0, 6)}] Processing...`));\n });\n\n dispatcher.on('order:blocked', (o) => {\n console.log(chalk.red(`🛑 [${o.id.slice(0, 6)}] BLOCKED by Kill-Switch`));\n console.log(chalk.dim(` Target: ${o.targetAgent} | Action: ${o.action}`));\n console.log(chalk.dim(' Run with --force to execute automatically (NOT RECOMMENDED).'));\n });\n\n dispatcher.on('agent:SINDRE', (o) => console.log(chalk.cyan(`🤖 Sindre (Vault): I'm on it! (${o.action})`)));\n dispatcher.on('agent:EITRI', (o) => console.log(chalk.green(`👷 Eitri (Smith): Ready to build! (${o.action})`)));\n\n // Simulation: Frank Analysis Logic\n // In a real scenario, this would call LLM/MCP to get the decomposition.\n // Here we hardcode a mocked response to demonstrate the CLI flow.\n\n console.log(chalk.dim('🧠 Frank is analyzing your intent...'));\n await new Promise(r => setTimeout(r, 800)); // Simulate thinking\n\n // MOCK: Dispatch logic\n if (intent.toLowerCase().includes('db') || intent.toLowerCase().includes('database')) {\n await dispatcher.dispatch('FRANK', 'SINDRE', intent, 'db.analyze', { raw: intent });\n } else if (intent.toLowerCase().includes('create') || intent.toLowerCase().includes('code')) {\n await dispatcher.dispatch('FRANK', 'EITRI', intent, 'fs.write', { path: 'src/demo.ts', content: '// demo' });\n } else {\n console.log(chalk.gray(\"Frank didn't understand. Try 'create file' or 'check database'.\"));\n }\n });\n\n return command;\n}\n","\nimport EventEmitter from 'events';\nimport { ServiceOrder, SwarmAgent, NexusContext } from '@rigstate/shared';\nimport { v4 as uuidv4 } from 'uuid';\n\nimport { HiveGateway } from '../hive/gateway';\nimport { Logger } from '../utils/logger';\n\n/**\n * THE NEXUS DISPATCHER\n * \"The Brain Stem\" of Rigstate.\n * Routes ServiceOrders between agents and enforces the Human Kill-Switch.\n */\nexport class NexusDispatcher extends EventEmitter {\n private context: NexusContext;\n private orderQueue: ServiceOrder[] = [];\n private orderHistory: ServiceOrder[] = [];\n private gateway: HiveGateway;\n\n constructor(context: NexusContext) {\n super();\n this.context = context;\n this.gateway = new HiveGateway(\n process.env.RIGSTATE_HIVE_URL || 'https://rigstate.com/api/hive',\n process.env.RIGSTATE_HIVE_TOKEN\n );\n Logger.info(`🧠 NEXUS DISPATCHER ONLINE. Context: ${context.projectId} (DryRun: ${context.dryRun})`);\n }\n\n /**\n * Creates a new Service Order and routes it.\n */\n public async dispatch(\n source: SwarmAgent,\n target: SwarmAgent,\n intent: string,\n action: string,\n params: Record<string, any>,\n constraints: string[] = []\n ): Promise<ServiceOrder> {\n\n const order: ServiceOrder = {\n id: uuidv4(),\n traceId: uuidv4(), // TODO: Inherit traceId if chained\n sourceAgent: source,\n targetAgent: target,\n priority: 'NORMAL',\n intent,\n action,\n parameters: params,\n constraints,\n status: 'PENDING',\n createdAt: new Date().toISOString()\n };\n\n this.orderQueue.push(order);\n this.emit('order:created', order);\n\n // Security / Kill-Switch Check\n // EITRI (The Smith) is the only one who can hammer the metal (write files)\n if (target === 'EITRI' && order.action.startsWith('fs.write')) {\n if (this.context.dryRun) {\n Logger.info(`🛑 NEXUS KILL-SWITCH: Order ${order.id} blocked by Dry-Run protocol.`);\n order.status = 'PENDING'; // Kept as PENDING but blocked\n // Ideally status should represent AWAITING_APPROVAL explicitly\n // But for now strict dry-run just prevents execution\n this.emit('order:blocked', order);\n return order;\n }\n }\n\n // If automatic or dry-run disabled\n return this.executeOrder(order);\n }\n\n /**\n * Executes the order (simulated for now, essentially \"Sending\" it)\n */\n private async executeOrder(order: ServiceOrder): Promise<ServiceOrder> {\n order.status = 'EXECUTING';\n order.startedAt = new Date().toISOString();\n this.emit('order:started', order);\n\n try {\n Logger.info(`🚀 NEXUS: Routing Order ${order.id} [${order.sourceAgent} -> ${order.targetAgent}]: ${order.intent}`);\n\n // SPECIAL ROUTING: HIVE UPLINK\n if (order.targetAgent === 'MAJA' && order.action === 'HIVE_TRANSMIT') {\n const signal = order.parameters.signal;\n if (signal) {\n await this.gateway.transmit(signal);\n order.status = 'COMPLETED';\n return order;\n }\n }\n\n // Here we would actually call the Agent's handler function\n // For now, we just emit the specific event for listeners\n this.emit(`agent:${order.targetAgent}`, order);\n\n // Simulation of async completion would happen via callback/promise resolution elsewhere\n return order;\n\n } catch (error: unknown) {\n const errorMessage = error instanceof Error ? error.message : 'Unknown error occurred';\n Logger.error(`Dispatch failed for order ${order.id}`, error);\n\n order.status = 'FAILED';\n order.error = {\n code: 'DISPATCH_ERROR',\n message: errorMessage\n };\n this.emit('order:failed', order);\n return order;\n }\n }\n\n /**\n * Human Approval (The \"Red Button\")\n */\n public async approveOrder(orderId: string): Promise<void> {\n const order = this.orderQueue.find(o => o.id === orderId);\n if (!order) throw new Error(`Order ${orderId} not found`);\n\n if (order.status !== 'AWAITING_APPROVAL') {\n Logger.warn(`Order ${orderId} is not awaiting approval (Status: ${order.status})`);\n return;\n }\n\n Logger.info(`✅ HUMAN APPROVED Order ${orderId}`);\n await this.executeOrder(order);\n }\n}\n","\nimport axios, { AxiosInstance } from 'axios';\nimport { ImmuneSignal } from './protocol';\nimport { HiveScrubber } from './scrubber';\nimport chalk from 'chalk';\n\n/**\n * THE HIVE GATEWAY\n * Connects the local Rigstate instance to the Global Hive Mind (rigstate.com).\n */\nexport class HiveGateway {\n private client: AxiosInstance;\n private enabled: boolean;\n private lastSignalTime: number = 0;\n private readonly MIN_INTERVAL_MS = 5000; // Throttle: Max 1 signal per 5s\n\n constructor(baseUrl: string, token?: string) {\n this.enabled = !!token;\n\n if (!this.enabled) {\n console.log(chalk.dim('⚠️ Hive Gateway disabled (No Token provided). Running in localized mode.'));\n }\n\n this.client = axios.create({\n baseURL: baseUrl,\n headers: {\n 'Authorization': `Bearer ${token}`,\n 'Content-Type': 'application/json',\n 'X-Rigstate-Client': 'CLI-0.2.0'\n },\n timeout: 5000\n });\n }\n\n /**\n * Transmit an Immune Signal to the Hive.\n * Includes Pre-Flight Scrubbing and Throttling.\n */\n public async transmit(signal: ImmuneSignal): Promise<boolean> {\n if (!this.enabled) return false;\n\n // 1. THROTTLE CHECK\n const now = Date.now();\n if (now - this.lastSignalTime < this.MIN_INTERVAL_MS) {\n console.warn(chalk.yellow('⏳ Hive Gateway Throttled. Signal dropped to preventing spam.'));\n return false;\n }\n\n // 2. SCRUBBER VERIFICATION (Double Check)\n // Even if Frank ran it, we run it again here at the edge.\n const scrubResult = HiveScrubber.scrub(signal.ruleContent);\n if (scrubResult.riskScore > 20) {\n console.error(chalk.red(`🛑 HIVE BLOCKED: Signal contains sensitive data (Risk: ${scrubResult.riskScore})`));\n return false;\n }\n\n // 3. TRANSMISSION\n try {\n console.log(chalk.blue(`📡 Uplinking to Hive... [${signal.vector}]`));\n\n // Using the scrubbed content just to be 100% safe\n const payload = { ...signal, ruleContent: scrubResult.sanitizedContent };\n\n await this.client.post('/signal', payload);\n\n this.lastSignalTime = now;\n console.log(chalk.green('✅ Signal Received by Hive Core. Knowledge Shared.'));\n return true;\n } catch (error: any) {\n console.error(chalk.red(`❌ Hive Transmission Failed: ${error.message}`));\n return false;\n }\n }\n}\n","\n/**\n * THE HIVE SCRUBBER\n * Sanitizes local rules and signals before they are broadcast to the Global Registry.\n * Ensures strict anonymity.\n */\n\nexport interface ScrubberResult {\n sanitizedContent: string;\n redactionCount: number;\n riskScore: number; // 0-100 (If too high, do not broadcast)\n}\n\nexport class HiveScrubber {\n\n // Patterns that definitely identify a project and MUST be removed\n private static SENSITIVE_PATTERNS = [\n /(api_key|secret|token|password)[\\s]*[:=][\\s]*['\"][a-zA-Z0-9_\\-]+['\"]/gi, // Secrets\n /[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}/g, // Emails\n /(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\. (?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)/g, // IPs\n /postgres:\\/\\/[^:]+:[^@]+@/g, // DB Connection Strings\n ];\n\n // Generic replacements for project-specific terms to keep the rule abstract\n private static ABSTRACTION_MAP: Record<string, string> = {\n 'Vibeline': '{PROJECT_NAME}',\n 'Rigstate': '{FRAMEWORK}',\n 'Steinhofve': '{USER}',\n };\n\n /**\n * Scrubs a string (rule content or log excerpt) of sensitive data.\n */\n public static scrub(content: string, customTerms: string[] = []): ScrubberResult {\n let scrubbed = content;\n let count = 0;\n let risk = 0;\n\n // 1. Remove Hard Credentials (High Risk)\n this.SENSITIVE_PATTERNS.forEach(pattern => {\n if (pattern.test(scrubbed)) {\n scrubbed = scrubbed.replace(pattern, '[REDACTED_CREDENTIAL]');\n count++;\n risk += 50; // High penalty for finding secrets\n }\n });\n\n // 2. Abstract Project Specifics (Medium Risk)\n Object.entries(this.ABSTRACTION_MAP).forEach(([term, replacement]) => {\n const regex = new RegExp(term, 'gi');\n if (regex.test(scrubbed)) {\n scrubbed = scrubbed.replace(regex, replacement);\n count++;\n }\n });\n\n // 3. Scrub Custom Terms (e.g. Table names passed from context)\n customTerms.forEach(term => {\n const regex = new RegExp(term, 'gi');\n if (regex.test(scrubbed)) {\n scrubbed = scrubbed.replace(regex, '{ENTITY}');\n count++;\n }\n });\n\n return {\n sanitizedContent: scrubbed,\n redactionCount: count,\n riskScore: Math.min(risk, 100)\n };\n }\n}\n","import chalk from 'chalk';\n\nexport enum LogLevel {\n INFO = 'INFO',\n WARN = 'WARN',\n ERROR = 'ERROR',\n DEBUG = 'DEBUG'\n}\n\nexport class Logger {\n private static formatMessage(level: LogLevel, message: string, context?: unknown): string {\n const timestamp = new Date().toISOString();\n let prefix = '';\n\n switch (level) {\n case LogLevel.INFO:\n prefix = chalk.blue(`[${LogLevel.INFO}]`);\n break;\n case LogLevel.WARN:\n prefix = chalk.yellow(`[${LogLevel.WARN}]`);\n break;\n case LogLevel.ERROR:\n prefix = chalk.red(`[${LogLevel.ERROR}]`);\n break;\n case LogLevel.DEBUG:\n prefix = chalk.gray(`[${LogLevel.DEBUG}]`);\n break;\n }\n\n let output = `${chalk.gray(timestamp)} ${prefix} ${message}`;\n\n if (context) {\n if (context instanceof Error) {\n output += `\\n${chalk.red(context.stack || context.message)}`;\n } else if (typeof context === 'object') {\n try {\n output += `\\n${chalk.gray(JSON.stringify(context, null, 2))}`;\n } catch (e) {\n output += `\\n${chalk.gray('[Circular or invalid object]')}`;\n }\n } else {\n output += ` ${String(context)}`;\n }\n }\n\n return output;\n }\n\n static info(message: string, context?: unknown) {\n console.log(this.formatMessage(LogLevel.INFO, message, context));\n }\n\n static warn(message: string, context?: unknown) {\n console.warn(this.formatMessage(LogLevel.WARN, message, context));\n }\n\n static error(message: string, error?: unknown) {\n console.error(this.formatMessage(LogLevel.ERROR, message, error));\n }\n\n static debug(message: string, context?: unknown) {\n if (process.env.DEBUG || process.env.RIGSTATE_DEBUG) {\n console.debug(this.formatMessage(LogLevel.DEBUG, message, context));\n }\n }\n}\n","import { Command } from 'commander';\nimport chalk from 'chalk';\nimport { performOverride, getSessionState } from '../utils/governance.js';\nimport { getApiKey, getProjectId, getApiUrl } from '../utils/config.js';\nimport axios from 'axios';\n\nexport function createOverrideCommand() {\n const override = new Command('override');\n\n override\n .description('Emergency Override for Governance Soft Locks')\n .argument('<violationId>', 'ID of the violation to override (or \"all\")')\n .requiredOption('-r, --reason <reason>', 'Description of why this override is necessary')\n .action(async (violationId, options) => {\n const { reason } = options;\n\n console.log(chalk.bold(`\\n🔓 Initiating Governance Override Protocol...`));\n\n const session = await getSessionState(process.cwd());\n\n if (session.status !== 'SOFT_LOCK') {\n console.log(chalk.yellow(' Info: Session is not currently locked.'));\n return; // Not locked, but maybe we still want to log the \"intent\"?\n }\n\n console.log(chalk.dim(` Active Violation: ${session.active_violation}`));\n console.log(chalk.dim(` Reason Provided: \"${reason}\"`));\n\n // Perform Local Unlock\n const success = await performOverride(violationId, reason, process.cwd());\n\n if (success) {\n console.log(chalk.green(` ✅ Session UNLOCKED.`));\n console.log(chalk.dim(` This event has been logged to the Mission Report.`));\n\n // Optional: Notify Cloud about the Override (Audit Trail)\n try {\n const projectId = getProjectId();\n if (projectId) {\n const apiUrl = getApiUrl();\n const apiKey = getApiKey();\n\n await axios.post(`${apiUrl}/api/v1/execution-logs`, {\n project_id: projectId,\n task_id: 'OVERRIDE-' + Date.now(),\n task_title: `Governance Override: ${violationId}`,\n status: 'COMPLETED',\n execution_summary: `Manual override executed. Reason: ${reason}`,\n agent_role: 'SUPERVISOR' // Override is a supervisor action\n }, {\n headers: { Authorization: `Bearer ${apiKey}` }\n });\n console.log(chalk.dim(` ☁ Audit log synced to Cloud.`));\n }\n } catch (e: any) {\n console.log(chalk.dim(` (Cloud audit sync failed: ${e.message})`));\n }\n\n } else {\n console.log(chalk.red(` 🛑 Override Failed. Check project configuration.`));\n }\n });\n\n return override;\n}\n","export async function checkVersion() {}\n","\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport axios from 'axios';\nimport inquirer from 'inquirer';\nimport { getApiKey, getApiUrl, getProjectId } from '../utils/config.js';\n\nexport function createIdeaCommand(): Command {\n return new Command('idea')\n .description('Capture a new idea or feature request')\n .argument('[title]', 'Quick title of the idea')\n .option('-d, --desc <text>', 'Detailed description')\n .option('-t, --tag <tags>', 'Comma separated tags (e.g. ui,auth)')\n .action(async (title, options) => {\n try {\n const apiKey = getApiKey();\n const apiUrl = getApiUrl();\n const projectId = getProjectId();\n\n if (!projectId) {\n console.error(chalk.red('Project context missing. Run rigstate link.'));\n process.exit(1);\n }\n\n // Interactive Inputs if missing\n let ideaTitle = title;\n let ideaDesc = options.desc;\n let tags = options.tag ? options.tag.split(',') : [];\n\n if (!ideaTitle) {\n const ans = await inquirer.prompt([{\n type: 'input',\n name: 'title',\n message: 'Idea Title:'\n }]);\n ideaTitle = ans.title;\n }\n\n if (!ideaDesc) {\n const ans = await inquirer.prompt([{\n type: 'input',\n name: 'desc',\n message: 'Description (Optional):'\n }]);\n ideaDesc = ans.desc;\n }\n\n if (tags.length === 0) {\n // Maybe ask for tags? Or just let it be empty\n }\n\n const spinner = ora('Securing idea in the Lab...').start();\n\n // Submit to API\n const response = await axios.post(\n `${apiUrl}/api/v1/ideas`,\n {\n project_id: projectId,\n title: ideaTitle,\n description: ideaDesc,\n tags\n },\n { headers: { Authorization: `Bearer ${apiKey}` } }\n );\n\n if (response.data.success) {\n spinner.succeed(chalk.green('Idea Captured! 💡'));\n console.log(chalk.dim(`ID: ${response.data.data?.id || 'Saved'}`));\n } else {\n throw new Error(response.data.error);\n }\n\n } catch (e: any) {\n console.error(chalk.red(`\\nFailed to capture idea: ${e.message}`));\n }\n });\n}\n"],"mappings":"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","names":["Command","chalk","path","Command","chalk","ora","axios","fs","path","chalk","axios","Command","chalk","fs","path","axios","fs","path","chalk","fs","path","chalk","config","InterventionLevel","fs","path","chalk","axios","getGovernanceConfig","setSoftLock","InterventionLevel","Command","chalk","Command","fs","path","chalk","config","getApiKey","getApiUrl","syncEnv","syncProjectRules","suggestNextMove","Command","chalk","ora","axios","fs","path","fs","path","Command","ora","chalk","path","fs","axios","Command","chalk","ora","axios","glob","fs","path","Command","ora","chalk","path","glob","fs","axios","Command","chalk","ora","axios","fs","path","provisionSkills","generateSkillsDiscoveryBlock","runGuardianWatchdog","Command","chalk","fs","path","ora","fs","path","axios","Command","ora","chalk","inquirer","path","fs","Command","chalk","ora","axios","glob","fs","path","execSync","fs","path","chalk","CACHE_FILE","Command","ora","chalk","axios","path","execSync","isCodeFile","glob","fs","Command","chalk","ora","fs","path","chalk","fs","EventEmitter","path","isCodeFile","absolutePath","path","axios","chalk","fs","path","axios","fs","path","CACHE_FILE","CACHE_TTL_MS","axios","saveCachedRules","loadCachedRules","path","fs","axios","EventEmitter","axios","EventEmitter","config","chalk","path","config","Command","ora","chalk","path","fs","Command","chalk","ora","axios","inquirer","Command","chalk","ora","chokidar","fs","path","execSync","axios","watch","config","Command","chalk","ora","axios","execSync","fs","path","Command","chalk","config","Command","chalk","path","fs","fileURLToPath","__filename","__dirname","Command","chalk","EventEmitter","axios","chalk","axios","chalk","chalk","EventEmitter","inquirer","Command","chalk","Command","chalk","axios","Command","chalk","ora","axios","inquirer","Command","chalk"]}