@claude-flow/cli 3.0.0-alpha.13 → 3.0.0-alpha.14

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.
Files changed (102) hide show
  1. package/package.json +12 -4
  2. package/.agentic-flow/intelligence.json +0 -17
  3. package/.claude-flow/agents/store.json +0 -16
  4. package/.claude-flow/daemon-state.json +0 -123
  5. package/.claude-flow/daemon-test.log +0 -0
  6. package/.claude-flow/daemon.log +0 -0
  7. package/.claude-flow/daemon2.log +0 -0
  8. package/.claude-flow/daemon3.log +0 -0
  9. package/.claude-flow/hive-mind/state.json +0 -51
  10. package/.claude-flow/metrics/agent-metrics.json +0 -1
  11. package/.claude-flow/metrics/codebase-map.json +0 -11
  12. package/.claude-flow/metrics/consolidation.json +0 -6
  13. package/.claude-flow/metrics/performance.json +0 -87
  14. package/.claude-flow/metrics/security-audit.json +0 -10
  15. package/.claude-flow/metrics/task-metrics.json +0 -10
  16. package/.claude-flow/metrics/test-gaps.json +0 -6
  17. package/__tests__/README.md +0 -140
  18. package/__tests__/TEST_SUMMARY.md +0 -144
  19. package/__tests__/cli.test.ts +0 -558
  20. package/__tests__/commands.test.ts +0 -726
  21. package/__tests__/config-adapter.test.ts +0 -362
  22. package/__tests__/config-loading.test.ts +0 -106
  23. package/__tests__/coverage/.tmp/coverage-0.json +0 -1
  24. package/__tests__/coverage/.tmp/coverage-1.json +0 -1
  25. package/__tests__/coverage/.tmp/coverage-2.json +0 -1
  26. package/__tests__/coverage/.tmp/coverage-3.json +0 -1
  27. package/__tests__/coverage/.tmp/coverage-4.json +0 -1
  28. package/__tests__/coverage/.tmp/coverage-5.json +0 -1
  29. package/__tests__/mcp-client.test.ts +0 -480
  30. package/__tests__/p1-commands.test.ts +0 -1064
  31. package/agents/architect.yaml +0 -11
  32. package/agents/coder.yaml +0 -11
  33. package/agents/reviewer.yaml +0 -10
  34. package/agents/security-architect.yaml +0 -10
  35. package/agents/tester.yaml +0 -10
  36. package/docs/CONFIG_LOADING.md +0 -236
  37. package/docs/IMPLEMENTATION_COMPLETE.md +0 -421
  38. package/docs/MCP_CLIENT_GUIDE.md +0 -620
  39. package/docs/REFACTORING_SUMMARY.md +0 -247
  40. package/scripts/publish.sh +0 -46
  41. package/src/commands/agent.ts +0 -955
  42. package/src/commands/claims.ts +0 -317
  43. package/src/commands/completions.ts +0 -558
  44. package/src/commands/config.ts +0 -452
  45. package/src/commands/daemon.ts +0 -621
  46. package/src/commands/deployment.ts +0 -323
  47. package/src/commands/doctor.ts +0 -382
  48. package/src/commands/embeddings.ts +0 -686
  49. package/src/commands/hive-mind.ts +0 -928
  50. package/src/commands/hooks.ts +0 -2603
  51. package/src/commands/index.ts +0 -154
  52. package/src/commands/init.ts +0 -597
  53. package/src/commands/mcp.ts +0 -753
  54. package/src/commands/memory.ts +0 -1161
  55. package/src/commands/migrate.ts +0 -447
  56. package/src/commands/neural.ts +0 -253
  57. package/src/commands/performance.ts +0 -292
  58. package/src/commands/plugins.ts +0 -316
  59. package/src/commands/process.ts +0 -695
  60. package/src/commands/providers.ts +0 -259
  61. package/src/commands/security.ts +0 -288
  62. package/src/commands/session.ts +0 -891
  63. package/src/commands/start.ts +0 -457
  64. package/src/commands/status.ts +0 -736
  65. package/src/commands/swarm.ts +0 -648
  66. package/src/commands/task.ts +0 -792
  67. package/src/commands/workflow.ts +0 -742
  68. package/src/config-adapter.ts +0 -210
  69. package/src/index.ts +0 -443
  70. package/src/infrastructure/in-memory-repositories.ts +0 -310
  71. package/src/init/claudemd-generator.ts +0 -631
  72. package/src/init/executor.ts +0 -762
  73. package/src/init/helpers-generator.ts +0 -628
  74. package/src/init/index.ts +0 -60
  75. package/src/init/mcp-generator.ts +0 -83
  76. package/src/init/settings-generator.ts +0 -284
  77. package/src/init/statusline-generator.ts +0 -211
  78. package/src/init/types.ts +0 -447
  79. package/src/mcp-client.ts +0 -241
  80. package/src/mcp-server.ts +0 -577
  81. package/src/mcp-tools/agent-tools.ts +0 -466
  82. package/src/mcp-tools/config-tools.ts +0 -370
  83. package/src/mcp-tools/hive-mind-tools.ts +0 -521
  84. package/src/mcp-tools/hooks-tools.ts +0 -1888
  85. package/src/mcp-tools/index.ts +0 -16
  86. package/src/mcp-tools/memory-tools.ts +0 -270
  87. package/src/mcp-tools/session-tools.ts +0 -359
  88. package/src/mcp-tools/swarm-tools.ts +0 -105
  89. package/src/mcp-tools/task-tools.ts +0 -347
  90. package/src/mcp-tools/types.ts +0 -33
  91. package/src/mcp-tools/workflow-tools.ts +0 -573
  92. package/src/output.ts +0 -639
  93. package/src/parser.ts +0 -417
  94. package/src/prompt.ts +0 -619
  95. package/src/services/index.ts +0 -15
  96. package/src/services/worker-daemon.ts +0 -726
  97. package/src/suggest.ts +0 -245
  98. package/src/types.ts +0 -287
  99. package/tmp.json +0 -0
  100. package/tsconfig.json +0 -16
  101. package/tsconfig.tsbuildinfo +0 -1
  102. package/vitest.config.ts +0 -13
@@ -1,259 +0,0 @@
1
- /**
2
- * V3 CLI Providers Command
3
- * Manage AI providers, models, and configurations
4
- *
5
- * Created with ❤️ by ruv.io
6
- */
7
-
8
- import type { Command, CommandContext, CommandResult } from '../types.js';
9
- import { output } from '../output.js';
10
-
11
- // List subcommand
12
- const listCommand: Command = {
13
- name: 'list',
14
- description: 'List available AI providers and models',
15
- options: [
16
- { name: 'type', short: 't', type: 'string', description: 'Filter by type: llm, embedding, image', default: 'all' },
17
- { name: 'active', short: 'a', type: 'boolean', description: 'Show only active providers' },
18
- ],
19
- examples: [
20
- { command: 'claude-flow providers list', description: 'List all providers' },
21
- { command: 'claude-flow providers list -t embedding', description: 'List embedding providers' },
22
- ],
23
- action: async (ctx: CommandContext): Promise<CommandResult> => {
24
- const type = ctx.flags.type as string || 'all';
25
-
26
- output.writeln();
27
- output.writeln(output.bold('Available Providers'));
28
- output.writeln(output.dim('─'.repeat(60)));
29
-
30
- output.printTable({
31
- columns: [
32
- { key: 'provider', header: 'Provider', width: 18 },
33
- { key: 'type', header: 'Type', width: 12 },
34
- { key: 'models', header: 'Models', width: 25 },
35
- { key: 'status', header: 'Status', width: 12 },
36
- ],
37
- data: [
38
- { provider: 'Anthropic', type: 'LLM', models: 'claude-3.5-sonnet, opus', status: output.success('Active') },
39
- { provider: 'OpenAI', type: 'LLM', models: 'gpt-4o, gpt-4-turbo', status: output.success('Active') },
40
- { provider: 'OpenAI', type: 'Embedding', models: 'text-embedding-3-small/large', status: output.success('Active') },
41
- { provider: 'Transformers.js', type: 'Embedding', models: 'all-MiniLM-L6-v2', status: output.success('Active') },
42
- { provider: 'Agentic Flow', type: 'Embedding', models: 'ONNX optimized', status: output.success('Active') },
43
- { provider: 'Mock', type: 'All', models: 'mock-*', status: output.dim('Dev only') },
44
- ],
45
- });
46
-
47
- return { success: true };
48
- },
49
- };
50
-
51
- // Configure subcommand
52
- const configureCommand: Command = {
53
- name: 'configure',
54
- description: 'Configure provider settings and API keys',
55
- options: [
56
- { name: 'provider', short: 'p', type: 'string', description: 'Provider name', required: true },
57
- { name: 'key', short: 'k', type: 'string', description: 'API key' },
58
- { name: 'model', short: 'm', type: 'string', description: 'Default model' },
59
- { name: 'endpoint', short: 'e', type: 'string', description: 'Custom endpoint URL' },
60
- ],
61
- examples: [
62
- { command: 'claude-flow providers configure -p openai -k sk-...', description: 'Set OpenAI key' },
63
- { command: 'claude-flow providers configure -p anthropic -m claude-3.5-sonnet', description: 'Set default model' },
64
- ],
65
- action: async (ctx: CommandContext): Promise<CommandResult> => {
66
- const provider = ctx.flags.provider as string;
67
- const hasKey = ctx.flags.key as string;
68
- const model = ctx.flags.model as string;
69
-
70
- if (!provider) {
71
- output.printError('Provider name is required');
72
- return { success: false, exitCode: 1 };
73
- }
74
-
75
- output.writeln();
76
- output.writeln(output.bold(`Configure: ${provider}`));
77
- output.writeln(output.dim('─'.repeat(40)));
78
-
79
- const spinner = output.createSpinner({ text: 'Updating configuration...', spinner: 'dots' });
80
- spinner.start();
81
- await new Promise(r => setTimeout(r, 500));
82
- spinner.succeed('Configuration updated');
83
-
84
- output.writeln();
85
- output.printBox([
86
- `Provider: ${provider}`,
87
- `API Key: ${hasKey ? '••••••••' + (hasKey as string).slice(-4) : 'Not set'}`,
88
- `Model: ${model || 'Default'}`,
89
- `Status: Active`,
90
- ].join('\n'), 'Configuration');
91
-
92
- return { success: true };
93
- },
94
- };
95
-
96
- // Test subcommand
97
- const testCommand: Command = {
98
- name: 'test',
99
- description: 'Test provider connectivity and API access',
100
- options: [
101
- { name: 'provider', short: 'p', type: 'string', description: 'Provider to test' },
102
- { name: 'all', short: 'a', type: 'boolean', description: 'Test all configured providers' },
103
- ],
104
- examples: [
105
- { command: 'claude-flow providers test -p openai', description: 'Test OpenAI connection' },
106
- { command: 'claude-flow providers test --all', description: 'Test all providers' },
107
- ],
108
- action: async (ctx: CommandContext): Promise<CommandResult> => {
109
- const provider = ctx.flags.provider as string;
110
- const testAll = ctx.flags.all as boolean;
111
-
112
- output.writeln();
113
- output.writeln(output.bold('Provider Connectivity Test'));
114
- output.writeln(output.dim('─'.repeat(50)));
115
-
116
- const providers = testAll || !provider
117
- ? ['Anthropic', 'OpenAI (LLM)', 'OpenAI (Embedding)', 'Transformers.js', 'Agentic Flow']
118
- : [provider];
119
-
120
- for (const p of providers) {
121
- const spinner = output.createSpinner({ text: `Testing ${p}...`, spinner: 'dots' });
122
- spinner.start();
123
- await new Promise(r => setTimeout(r, 300));
124
- spinner.succeed(`${p}: Connected`);
125
- }
126
-
127
- output.writeln();
128
- output.printSuccess(`All ${providers.length} providers connected successfully`);
129
-
130
- return { success: true };
131
- },
132
- };
133
-
134
- // Models subcommand
135
- const modelsCommand: Command = {
136
- name: 'models',
137
- description: 'List and manage available models',
138
- options: [
139
- { name: 'provider', short: 'p', type: 'string', description: 'Filter by provider' },
140
- { name: 'capability', short: 'c', type: 'string', description: 'Filter by capability: chat, completion, embedding' },
141
- ],
142
- examples: [
143
- { command: 'claude-flow providers models', description: 'List all models' },
144
- { command: 'claude-flow providers models -p anthropic', description: 'List Anthropic models' },
145
- ],
146
- action: async (ctx: CommandContext): Promise<CommandResult> => {
147
- output.writeln();
148
- output.writeln(output.bold('Available Models'));
149
- output.writeln(output.dim('─'.repeat(70)));
150
-
151
- output.printTable({
152
- columns: [
153
- { key: 'model', header: 'Model', width: 28 },
154
- { key: 'provider', header: 'Provider', width: 14 },
155
- { key: 'capability', header: 'Capability', width: 12 },
156
- { key: 'context', header: 'Context', width: 10 },
157
- { key: 'cost', header: 'Cost/1K', width: 12 },
158
- ],
159
- data: [
160
- { model: 'claude-3.5-sonnet-20241022', provider: 'Anthropic', capability: 'Chat', context: '200K', cost: '$0.003/$0.015' },
161
- { model: 'claude-3-opus-20240229', provider: 'Anthropic', capability: 'Chat', context: '200K', cost: '$0.015/$0.075' },
162
- { model: 'gpt-4o', provider: 'OpenAI', capability: 'Chat', context: '128K', cost: '$0.005/$0.015' },
163
- { model: 'gpt-4-turbo', provider: 'OpenAI', capability: 'Chat', context: '128K', cost: '$0.01/$0.03' },
164
- { model: 'text-embedding-3-small', provider: 'OpenAI', capability: 'Embedding', context: '8K', cost: '$0.00002' },
165
- { model: 'text-embedding-3-large', provider: 'OpenAI', capability: 'Embedding', context: '8K', cost: '$0.00013' },
166
- { model: 'all-MiniLM-L6-v2', provider: 'Transformers', capability: 'Embedding', context: '512', cost: output.success('Free') },
167
- ],
168
- });
169
-
170
- return { success: true };
171
- },
172
- };
173
-
174
- // Usage subcommand
175
- const usageCommand: Command = {
176
- name: 'usage',
177
- description: 'View provider usage and costs',
178
- options: [
179
- { name: 'provider', short: 'p', type: 'string', description: 'Filter by provider' },
180
- { name: 'timeframe', short: 't', type: 'string', description: 'Timeframe: 24h, 7d, 30d', default: '7d' },
181
- ],
182
- examples: [
183
- { command: 'claude-flow providers usage', description: 'View all usage' },
184
- { command: 'claude-flow providers usage -t 30d', description: 'View 30-day usage' },
185
- ],
186
- action: async (ctx: CommandContext): Promise<CommandResult> => {
187
- const timeframe = ctx.flags.timeframe as string || '7d';
188
-
189
- output.writeln();
190
- output.writeln(output.bold(`Provider Usage (${timeframe})`));
191
- output.writeln(output.dim('─'.repeat(60)));
192
-
193
- output.printTable({
194
- columns: [
195
- { key: 'provider', header: 'Provider', width: 15 },
196
- { key: 'requests', header: 'Requests', width: 12 },
197
- { key: 'tokens', header: 'Tokens', width: 15 },
198
- { key: 'cost', header: 'Est. Cost', width: 12 },
199
- { key: 'trend', header: 'Trend', width: 12 },
200
- ],
201
- data: [
202
- { provider: 'Anthropic', requests: '12,847', tokens: '4.2M', cost: '$12.60', trend: output.warning('↑ 15%') },
203
- { provider: 'OpenAI (LLM)', requests: '3,421', tokens: '1.1M', cost: '$5.50', trend: output.success('↓ 8%') },
204
- { provider: 'OpenAI (Embed)', requests: '89,234', tokens: '12.4M', cost: '$0.25', trend: output.success('↓ 12%') },
205
- { provider: 'Transformers.js', requests: '234,567', tokens: '45.2M', cost: output.success('$0.00'), trend: '→' },
206
- ],
207
- });
208
-
209
- output.writeln();
210
- output.printBox([
211
- `Total Requests: 340,069`,
212
- `Total Tokens: 62.9M`,
213
- `Total Cost: $18.35`,
214
- ``,
215
- `Savings from local embeddings: $890.12`,
216
- ].join('\n'), 'Summary');
217
-
218
- return { success: true };
219
- },
220
- };
221
-
222
- // Main providers command
223
- export const providersCommand: Command = {
224
- name: 'providers',
225
- description: 'Manage AI providers, models, and configurations',
226
- subcommands: [listCommand, configureCommand, testCommand, modelsCommand, usageCommand],
227
- examples: [
228
- { command: 'claude-flow providers list', description: 'List all providers' },
229
- { command: 'claude-flow providers configure -p openai', description: 'Configure OpenAI' },
230
- { command: 'claude-flow providers test --all', description: 'Test all providers' },
231
- ],
232
- action: async (): Promise<CommandResult> => {
233
- output.writeln();
234
- output.writeln(output.bold('Claude Flow Provider Management'));
235
- output.writeln(output.dim('Multi-provider AI orchestration'));
236
- output.writeln();
237
- output.writeln('Subcommands:');
238
- output.printList([
239
- 'list - List available providers and their status',
240
- 'configure - Configure provider settings and API keys',
241
- 'test - Test provider connectivity',
242
- 'models - List and manage available models',
243
- 'usage - View usage statistics and costs',
244
- ]);
245
- output.writeln();
246
- output.writeln('Supported Providers:');
247
- output.printList([
248
- 'Anthropic (Claude models)',
249
- 'OpenAI (GPT + embeddings)',
250
- 'Transformers.js (local ONNX)',
251
- 'Agentic Flow (optimized ONNX with SIMD)',
252
- ]);
253
- output.writeln();
254
- output.writeln(output.dim('Created with ❤️ by ruv.io'));
255
- return { success: true };
256
- },
257
- };
258
-
259
- export default providersCommand;
@@ -1,288 +0,0 @@
1
- /**
2
- * V3 CLI Security Command
3
- * Security scanning, CVE detection, threat modeling, vulnerability management
4
- *
5
- * Created with ❤️ by ruv.io
6
- */
7
-
8
- import type { Command, CommandContext, CommandResult } from '../types.js';
9
- import { output } from '../output.js';
10
-
11
- // Scan subcommand
12
- const scanCommand: Command = {
13
- name: 'scan',
14
- description: 'Run security scan on target (code, dependencies, containers)',
15
- options: [
16
- { name: 'target', short: 't', type: 'string', description: 'Target path or URL to scan', default: '.' },
17
- { name: 'depth', short: 'd', type: 'string', description: 'Scan depth: quick, standard, deep', default: 'standard' },
18
- { name: 'type', type: 'string', description: 'Scan type: code, deps, container, all', default: 'all' },
19
- { name: 'output', short: 'o', type: 'string', description: 'Output format: text, json, sarif', default: 'text' },
20
- { name: 'fix', short: 'f', type: 'boolean', description: 'Auto-fix vulnerabilities where possible' },
21
- ],
22
- examples: [
23
- { command: 'claude-flow security scan -t ./src', description: 'Scan source directory' },
24
- { command: 'claude-flow security scan --depth deep --fix', description: 'Deep scan with auto-fix' },
25
- ],
26
- action: async (ctx: CommandContext): Promise<CommandResult> => {
27
- const target = ctx.flags.target as string || '.';
28
- const depth = ctx.flags.depth as string || 'standard';
29
- const scanType = ctx.flags.type as string || 'all';
30
-
31
- output.writeln();
32
- output.writeln(output.bold('Security Scan'));
33
- output.writeln(output.dim('─'.repeat(50)));
34
-
35
- const spinner = output.createSpinner({ text: `Scanning ${target}...`, spinner: 'dots' });
36
- spinner.start();
37
-
38
- // Simulate scan phases
39
- const phases = ['Analyzing code patterns', 'Checking dependencies', 'CVE database lookup', 'Generating report'];
40
- for (const phase of phases) {
41
- spinner.setText(phase + '...');
42
- await new Promise(r => setTimeout(r, 400));
43
- }
44
-
45
- spinner.succeed('Scan complete');
46
-
47
- output.writeln();
48
- output.printTable({
49
- columns: [
50
- { key: 'severity', header: 'Severity', width: 12 },
51
- { key: 'type', header: 'Type', width: 18 },
52
- { key: 'location', header: 'Location', width: 25 },
53
- { key: 'description', header: 'Description', width: 35 },
54
- ],
55
- data: [
56
- { severity: output.error('CRITICAL'), type: 'CVE-2024-1234', location: 'package.json:45', description: 'Prototype pollution in lodash' },
57
- { severity: output.warning('HIGH'), type: 'Hardcoded Secret', location: 'src/config.ts:12', description: 'API key exposed in source' },
58
- { severity: output.warning('MEDIUM'), type: 'SQL Injection', location: 'src/db/query.ts:78', description: 'Unsanitized user input' },
59
- { severity: output.info('LOW'), type: 'Outdated Dep', location: 'package.json:23', description: 'axios@0.21.0 has known issues' },
60
- ],
61
- });
62
-
63
- output.writeln();
64
- output.printBox([
65
- `Target: ${target}`,
66
- `Depth: ${depth}`,
67
- `Type: ${scanType}`,
68
- ``,
69
- `Critical: 1 High: 1 Medium: 1 Low: 1`,
70
- `Total Issues: 4`,
71
- ].join('\n'), 'Scan Summary');
72
-
73
- return { success: true };
74
- },
75
- };
76
-
77
- // CVE subcommand
78
- const cveCommand: Command = {
79
- name: 'cve',
80
- description: 'Check and manage CVE vulnerabilities',
81
- options: [
82
- { name: 'check', short: 'c', type: 'string', description: 'Check specific CVE ID' },
83
- { name: 'list', short: 'l', type: 'boolean', description: 'List all known CVEs' },
84
- { name: 'severity', short: 's', type: 'string', description: 'Filter by severity: critical, high, medium, low' },
85
- ],
86
- examples: [
87
- { command: 'claude-flow security cve --list', description: 'List all CVEs' },
88
- { command: 'claude-flow security cve -c CVE-2024-1234', description: 'Check specific CVE' },
89
- ],
90
- action: async (ctx: CommandContext): Promise<CommandResult> => {
91
- const checkCve = ctx.flags.check as string;
92
-
93
- output.writeln();
94
- output.writeln(output.bold('CVE Database'));
95
- output.writeln(output.dim('─'.repeat(50)));
96
-
97
- if (checkCve) {
98
- output.printBox([
99
- `CVE ID: ${checkCve}`,
100
- `Severity: CRITICAL (9.8)`,
101
- `Status: Active`,
102
- ``,
103
- `Description: Remote code execution vulnerability`,
104
- `Affected: lodash < 4.17.21`,
105
- `Fix: Upgrade to lodash >= 4.17.21`,
106
- ``,
107
- `References:`,
108
- ` - https://nvd.nist.gov/vuln/detail/${checkCve}`,
109
- ` - https://github.com/advisories`,
110
- ].join('\n'), 'CVE Details');
111
- } else {
112
- output.printTable({
113
- columns: [
114
- { key: 'id', header: 'CVE ID', width: 18 },
115
- { key: 'severity', header: 'Severity', width: 12 },
116
- { key: 'package', header: 'Package', width: 20 },
117
- { key: 'status', header: 'Status', width: 15 },
118
- ],
119
- data: [
120
- { id: 'CVE-2024-1234', severity: output.error('CRITICAL'), package: 'lodash@4.17.20', status: output.warning('Unfixed') },
121
- { id: 'CVE-2024-5678', severity: output.warning('HIGH'), package: 'axios@0.21.0', status: output.success('Fixed') },
122
- { id: 'CVE-2024-9012', severity: output.info('MEDIUM'), package: 'express@4.17.0', status: output.success('Fixed') },
123
- ],
124
- });
125
- }
126
-
127
- return { success: true };
128
- },
129
- };
130
-
131
- // Threats subcommand
132
- const threatsCommand: Command = {
133
- name: 'threats',
134
- description: 'Threat modeling and analysis',
135
- options: [
136
- { name: 'model', short: 'm', type: 'string', description: 'Threat model: stride, dread, pasta', default: 'stride' },
137
- { name: 'scope', short: 's', type: 'string', description: 'Analysis scope', default: '.' },
138
- { name: 'export', short: 'e', type: 'string', description: 'Export format: json, md, html' },
139
- ],
140
- examples: [
141
- { command: 'claude-flow security threats --model stride', description: 'Run STRIDE analysis' },
142
- { command: 'claude-flow security threats -e md', description: 'Export as markdown' },
143
- ],
144
- action: async (ctx: CommandContext): Promise<CommandResult> => {
145
- const model = ctx.flags.model as string || 'stride';
146
-
147
- output.writeln();
148
- output.writeln(output.bold(`Threat Model: ${model.toUpperCase()}`));
149
- output.writeln(output.dim('─'.repeat(50)));
150
-
151
- output.printTable({
152
- columns: [
153
- { key: 'category', header: 'Category', width: 20 },
154
- { key: 'threat', header: 'Threat', width: 30 },
155
- { key: 'risk', header: 'Risk', width: 10 },
156
- { key: 'mitigation', header: 'Mitigation', width: 30 },
157
- ],
158
- data: [
159
- { category: 'Spoofing', threat: 'API key theft', risk: output.error('High'), mitigation: 'Use secure key storage' },
160
- { category: 'Tampering', threat: 'Data manipulation', risk: output.warning('Medium'), mitigation: 'Input validation' },
161
- { category: 'Repudiation', threat: 'Action denial', risk: output.info('Low'), mitigation: 'Audit logging' },
162
- { category: 'Info Disclosure', threat: 'Data leakage', risk: output.error('High'), mitigation: 'Encryption at rest' },
163
- { category: 'DoS', threat: 'Resource exhaustion', risk: output.warning('Medium'), mitigation: 'Rate limiting' },
164
- { category: 'Elevation', threat: 'Privilege escalation', risk: output.error('High'), mitigation: 'RBAC implementation' },
165
- ],
166
- });
167
-
168
- return { success: true };
169
- },
170
- };
171
-
172
- // Audit subcommand
173
- const auditCommand: Command = {
174
- name: 'audit',
175
- description: 'Security audit logging and compliance',
176
- options: [
177
- { name: 'action', short: 'a', type: 'string', description: 'Action: log, list, export, clear', default: 'list' },
178
- { name: 'limit', short: 'l', type: 'number', description: 'Number of entries to show', default: '20' },
179
- { name: 'filter', short: 'f', type: 'string', description: 'Filter by event type' },
180
- ],
181
- examples: [
182
- { command: 'claude-flow security audit --action list', description: 'List audit logs' },
183
- { command: 'claude-flow security audit -a export', description: 'Export audit trail' },
184
- ],
185
- action: async (ctx: CommandContext): Promise<CommandResult> => {
186
- const action = ctx.flags.action as string || 'list';
187
-
188
- output.writeln();
189
- output.writeln(output.bold('Security Audit Log'));
190
- output.writeln(output.dim('─'.repeat(60)));
191
-
192
- output.printTable({
193
- columns: [
194
- { key: 'timestamp', header: 'Timestamp', width: 22 },
195
- { key: 'event', header: 'Event', width: 20 },
196
- { key: 'user', header: 'User', width: 15 },
197
- { key: 'status', header: 'Status', width: 12 },
198
- ],
199
- data: [
200
- { timestamp: '2024-01-15 14:32:01', event: 'AUTH_LOGIN', user: 'admin', status: output.success('Success') },
201
- { timestamp: '2024-01-15 14:30:45', event: 'CONFIG_CHANGE', user: 'system', status: output.success('Success') },
202
- { timestamp: '2024-01-15 14:28:12', event: 'AUTH_FAILED', user: 'unknown', status: output.error('Failed') },
203
- { timestamp: '2024-01-15 14:25:33', event: 'SCAN_COMPLETE', user: 'ci-bot', status: output.success('Success') },
204
- { timestamp: '2024-01-15 14:20:00', event: 'KEY_ROTATE', user: 'admin', status: output.success('Success') },
205
- ],
206
- });
207
-
208
- return { success: true };
209
- },
210
- };
211
-
212
- // Secrets subcommand
213
- const secretsCommand: Command = {
214
- name: 'secrets',
215
- description: 'Detect and manage secrets in codebase',
216
- options: [
217
- { name: 'action', short: 'a', type: 'string', description: 'Action: scan, list, rotate', default: 'scan' },
218
- { name: 'path', short: 'p', type: 'string', description: 'Path to scan', default: '.' },
219
- { name: 'ignore', short: 'i', type: 'string', description: 'Patterns to ignore' },
220
- ],
221
- examples: [
222
- { command: 'claude-flow security secrets --action scan', description: 'Scan for secrets' },
223
- { command: 'claude-flow security secrets -a rotate', description: 'Rotate compromised secrets' },
224
- ],
225
- action: async (ctx: CommandContext): Promise<CommandResult> => {
226
- const path = ctx.flags.path as string || '.';
227
-
228
- output.writeln();
229
- output.writeln(output.bold('Secret Detection'));
230
- output.writeln(output.dim('─'.repeat(50)));
231
-
232
- const spinner = output.createSpinner({ text: 'Scanning for secrets...', spinner: 'dots' });
233
- spinner.start();
234
- await new Promise(r => setTimeout(r, 800));
235
- spinner.succeed('Scan complete');
236
-
237
- output.writeln();
238
- output.printTable({
239
- columns: [
240
- { key: 'type', header: 'Secret Type', width: 20 },
241
- { key: 'location', header: 'Location', width: 30 },
242
- { key: 'risk', header: 'Risk', width: 12 },
243
- { key: 'action', header: 'Recommended', width: 20 },
244
- ],
245
- data: [
246
- { type: 'AWS Access Key', location: 'src/config.ts:15', risk: output.error('Critical'), action: 'Rotate immediately' },
247
- { type: 'GitHub Token', location: '.env.example:8', risk: output.warning('High'), action: 'Remove from repo' },
248
- { type: 'JWT Secret', location: 'src/auth.ts:42', risk: output.warning('High'), action: 'Use env variable' },
249
- { type: 'DB Password', location: 'docker-compose.yml:23', risk: output.warning('Medium'), action: 'Use secrets mgmt' },
250
- ],
251
- });
252
-
253
- return { success: true };
254
- },
255
- };
256
-
257
- // Main security command
258
- export const securityCommand: Command = {
259
- name: 'security',
260
- description: 'Security scanning, CVE detection, threat modeling, vulnerability management',
261
- subcommands: [scanCommand, cveCommand, threatsCommand, auditCommand, secretsCommand],
262
- examples: [
263
- { command: 'claude-flow security scan', description: 'Run security scan' },
264
- { command: 'claude-flow security cve --list', description: 'List known CVEs' },
265
- { command: 'claude-flow security threats', description: 'Run threat analysis' },
266
- ],
267
- action: async (): Promise<CommandResult> => {
268
- output.writeln();
269
- output.writeln(output.bold('Claude Flow Security Suite'));
270
- output.writeln(output.dim('Comprehensive security scanning and vulnerability management'));
271
- output.writeln();
272
- output.writeln('Subcommands:');
273
- output.printList([
274
- 'scan - Run security scans on code, deps, containers',
275
- 'cve - Check and manage CVE vulnerabilities',
276
- 'threats - Threat modeling (STRIDE, DREAD, PASTA)',
277
- 'audit - Security audit logging and compliance',
278
- 'secrets - Detect and manage secrets in codebase',
279
- ]);
280
- output.writeln();
281
- output.writeln('Use --help with subcommands for more info');
282
- output.writeln();
283
- output.writeln(output.dim('Created with ❤️ by ruv.io'));
284
- return { success: true };
285
- },
286
- };
287
-
288
- export default securityCommand;