@hongmaple0820/scale-engine 0.29.0 → 0.38.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.en.md +86 -374
- package/README.md +89 -547
- package/dist/api/cli.js +189 -12
- package/dist/api/cli.js.map +1 -1
- package/dist/api/doctor.d.ts +38 -3
- package/dist/api/doctor.js +269 -44
- package/dist/api/doctor.js.map +1 -1
- package/dist/api/mcp.js +2 -2
- package/dist/api/mcp.js.map +1 -1
- package/dist/api/quickstart.d.ts +34 -4
- package/dist/api/quickstart.js +90 -73
- package/dist/api/quickstart.js.map +1 -1
- package/dist/bootstrap/DependencyBootstrap.d.ts +89 -0
- package/dist/bootstrap/DependencyBootstrap.js +441 -0
- package/dist/bootstrap/DependencyBootstrap.js.map +1 -0
- package/dist/capabilities/InstalledSkillsIntegration.js +14 -6
- package/dist/capabilities/InstalledSkillsIntegration.js.map +1 -1
- package/dist/codegraph/CodeIntelligence.d.ts +12 -0
- package/dist/codegraph/CodeIntelligence.js +251 -30
- package/dist/codegraph/CodeIntelligence.js.map +1 -1
- package/dist/config/profiles.d.ts +12 -0
- package/dist/config/profiles.js +39 -4
- package/dist/config/profiles.js.map +1 -1
- package/dist/core/ExternalCommand.d.ts +9 -0
- package/dist/core/ExternalCommand.js +56 -0
- package/dist/core/ExternalCommand.js.map +1 -0
- package/dist/evolution/SessionLearnings.d.ts +70 -0
- package/dist/evolution/SessionLearnings.js +217 -0
- package/dist/evolution/SessionLearnings.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/knowledge/CerebrumManager.d.ts +2 -2
- package/dist/knowledge/CerebrumManager.js.map +1 -1
- package/dist/knowledge/GraphifyKnowledgeBase.d.ts +38 -0
- package/dist/knowledge/GraphifyKnowledgeBase.js +409 -0
- package/dist/knowledge/GraphifyKnowledgeBase.js.map +1 -0
- package/dist/memory/MemoryFabric.js +1 -0
- package/dist/memory/MemoryFabric.js.map +1 -1
- package/dist/memory/MemoryIntelligence.d.ts +42 -0
- package/dist/memory/MemoryIntelligence.js +215 -0
- package/dist/memory/MemoryIntelligence.js.map +1 -0
- package/dist/memory/MemoryProviders.d.ts +22 -0
- package/dist/memory/MemoryProviders.js +138 -5
- package/dist/memory/MemoryProviders.js.map +1 -1
- package/dist/memory/index.d.ts +1 -0
- package/dist/memory/index.js +1 -0
- package/dist/memory/index.js.map +1 -1
- package/dist/runtime/AiOsRuntime.d.ts +101 -1
- package/dist/runtime/AiOsRuntime.js +464 -14
- package/dist/runtime/AiOsRuntime.js.map +1 -1
- package/dist/runtime/ExecutionLedger.d.ts +46 -0
- package/dist/runtime/ExecutionLedger.js +71 -0
- package/dist/runtime/ExecutionLedger.js.map +1 -0
- package/dist/runtime/index.d.ts +1 -0
- package/dist/runtime/index.js +1 -0
- package/dist/runtime/index.js.map +1 -1
- package/dist/skills/RoleSkills.d.ts +20 -0
- package/dist/skills/RoleSkills.js +154 -0
- package/dist/skills/RoleSkills.js.map +1 -0
- package/dist/skills/SkillDiscovery.d.ts +5 -0
- package/dist/skills/SkillDiscovery.js +15 -0
- package/dist/skills/SkillDiscovery.js.map +1 -1
- package/dist/skills/SkillFrontmatter.d.ts +28 -0
- package/dist/skills/SkillFrontmatter.js +152 -0
- package/dist/skills/SkillFrontmatter.js.map +1 -0
- package/dist/skills/SkillRegistry.d.ts +11 -0
- package/dist/skills/SkillRegistry.js +12 -0
- package/dist/skills/SkillRegistry.js.map +1 -1
- package/dist/skills/SkillRepository.js +5 -5
- package/dist/skills/SkillRepository.js.map +1 -1
- package/dist/skills/index.d.ts +1 -0
- package/dist/skills/index.js +1 -0
- package/dist/skills/index.js.map +1 -1
- package/dist/skills/routing/SkillPolicy.js +2 -2
- package/dist/skills/routing/SkillPolicy.js.map +1 -1
- package/dist/testing/DiffTestSelector.d.ts +22 -0
- package/dist/testing/DiffTestSelector.js +114 -0
- package/dist/testing/DiffTestSelector.js.map +1 -0
- package/dist/testing/index.d.ts +1 -0
- package/dist/testing/index.js +3 -0
- package/dist/testing/index.js.map +1 -0
- package/dist/tools/RtkRuntime.d.ts +9 -0
- package/dist/tools/RtkRuntime.js +43 -0
- package/dist/tools/RtkRuntime.js.map +1 -0
- package/dist/tools/ToolCapabilityRegistry.d.ts +1 -0
- package/dist/tools/ToolCapabilityRegistry.js +68 -11
- package/dist/tools/ToolCapabilityRegistry.js.map +1 -1
- package/dist/tools/ToolOrchestrator.js +6 -4
- package/dist/tools/ToolOrchestrator.js.map +1 -1
- package/dist/tools/ToolPolicy.js +16 -1
- package/dist/tools/ToolPolicy.js.map +1 -1
- package/dist/workflow/AdaptiveWorkflowRouter.d.ts +38 -0
- package/dist/workflow/AdaptiveWorkflowRouter.js +214 -0
- package/dist/workflow/AdaptiveWorkflowRouter.js.map +1 -0
- package/dist/workflow/CommitDiscipline.d.ts +68 -0
- package/dist/workflow/CommitDiscipline.js +327 -0
- package/dist/workflow/CommitDiscipline.js.map +1 -0
- package/dist/workflow/CrossRepoOrchestrator.d.ts +92 -0
- package/dist/workflow/CrossRepoOrchestrator.js +400 -0
- package/dist/workflow/CrossRepoOrchestrator.js.map +1 -0
- package/dist/workflow/EvolutionShadowPromoter.d.ts +46 -0
- package/dist/workflow/EvolutionShadowPromoter.js +73 -0
- package/dist/workflow/EvolutionShadowPromoter.js.map +1 -0
- package/dist/workflow/GovernanceRoi.d.ts +52 -0
- package/dist/workflow/GovernanceRoi.js +204 -0
- package/dist/workflow/GovernanceRoi.js.map +1 -0
- package/dist/workflow/GovernanceTemplates.js +2 -2
- package/dist/workflow/McpGovernance.d.ts +63 -0
- package/dist/workflow/McpGovernance.js +198 -0
- package/dist/workflow/McpGovernance.js.map +1 -0
- package/dist/workflow/ReviewAnalyzer.d.ts +15 -0
- package/dist/workflow/ReviewAnalyzer.js +82 -0
- package/dist/workflow/ReviewAnalyzer.js.map +1 -1
- package/dist/workflow/SecurityAudit.d.ts +27 -0
- package/dist/workflow/SecurityAudit.js +294 -0
- package/dist/workflow/SecurityAudit.js.map +1 -0
- package/dist/workflow/SessionCoordinator.d.ts +103 -0
- package/dist/workflow/SessionCoordinator.js +401 -0
- package/dist/workflow/SessionCoordinator.js.map +1 -0
- package/dist/workflow/SessionPreamble.d.ts +19 -0
- package/dist/workflow/SessionPreamble.js +125 -0
- package/dist/workflow/SessionPreamble.js.map +1 -0
- package/dist/workflow/ShipPipeline.d.ts +30 -0
- package/dist/workflow/ShipPipeline.js +366 -0
- package/dist/workflow/ShipPipeline.js.map +1 -0
- package/dist/workflow/TaskDependencyGraph.d.ts +73 -0
- package/dist/workflow/TaskDependencyGraph.js +245 -0
- package/dist/workflow/TaskDependencyGraph.js.map +1 -0
- package/dist/workflow/WorkflowGuidance.d.ts +5 -1
- package/dist/workflow/WorkflowGuidance.js +31 -0
- package/dist/workflow/WorkflowGuidance.js.map +1 -1
- package/dist/workflow/WorkflowTemplates.d.ts +38 -0
- package/dist/workflow/WorkflowTemplates.js +371 -0
- package/dist/workflow/WorkflowTemplates.js.map +1 -0
- package/dist/workflow/WorkspacePolicy.d.ts +46 -0
- package/dist/workflow/WorkspacePolicy.js +141 -0
- package/dist/workflow/WorkspacePolicy.js.map +1 -0
- package/dist/workflow/gates/GateSystem.js +12 -9
- package/dist/workflow/gates/GateSystem.js.map +1 -1
- package/dist/workflow/index.d.ts +12 -0
- package/dist/workflow/index.js +12 -0
- package/dist/workflow/index.js.map +1 -1
- package/docs/AI_ENGINEERING_OS_POSITIONING.md +9 -0
- package/docs/CODE_INTELLIGENCE.md +22 -5
- package/docs/CONTEXT_BUDGET.md +1 -1
- package/docs/EXTERNAL_REFERENCES.md +5 -2
- package/docs/MEMORY_FABRIC.md +7 -3
- package/docs/SKILL-REPOSITORY.md +3 -3
- package/docs/start/quickstart.md +11 -0
- package/docs/workflow/templates/skill-plan.md +1 -1
- package/package.json +3 -2
|
@@ -353,4 +353,86 @@ const STOP_WORDS = new Set([
|
|
|
353
353
|
'implement', 'implementation', 'create', 'support', 'feature',
|
|
354
354
|
'description', 'requirement', 'solution', 'approach',
|
|
355
355
|
]);
|
|
356
|
+
const ROLE_CHECK_PATTERNS = {
|
|
357
|
+
'security-reviewer': [
|
|
358
|
+
{ check: 'Hardcoded credentials', pattern: /\b(password|passwd|api[_-]?key|secret|token)\b\s*[:=]\s*['"][^'"]{8,}['"]/i, severity: 'CRITICAL' },
|
|
359
|
+
{ check: 'SQL injection risk', pattern: /(?:query|execute)\s*\(\s*[`'"].*\$\{/i, severity: 'CRITICAL' },
|
|
360
|
+
{ check: 'XSS via innerHTML', pattern: /\.innerHTML\s*=/i, severity: 'HIGH' },
|
|
361
|
+
{ check: 'eval with user input', pattern: /\beval\s*\(/i, severity: 'CRITICAL' },
|
|
362
|
+
{ check: 'Weak crypto (MD5/SHA1)', pattern: /\b(?:md5|sha1)\b.*(?:hash|createHash)/i, severity: 'HIGH' },
|
|
363
|
+
],
|
|
364
|
+
'eng-manager': [
|
|
365
|
+
{ check: 'Large file changes', pattern: /.*/, severity: 'MEDIUM' }, // Handled by file count
|
|
366
|
+
{ check: 'Test coverage for source changes', pattern: /\.(ts|tsx|js|jsx)$/i, severity: 'MEDIUM' },
|
|
367
|
+
],
|
|
368
|
+
'qa-lead': [
|
|
369
|
+
{ check: 'Empty catch block', pattern: /catch\s*(?:\([^)]*\))?\s*\{\s*\}/i, severity: 'HIGH' },
|
|
370
|
+
{ check: 'Focused test (.only)', pattern: /\b(describe|it|test)\.only\s*\(/i, severity: 'HIGH' },
|
|
371
|
+
{ check: 'Skipped test (.skip)', pattern: /\b(describe|it|test)\.skip\s*\(/i, severity: 'MEDIUM' },
|
|
372
|
+
],
|
|
373
|
+
'release-engineer': [
|
|
374
|
+
{ check: 'Version bump in package.json', pattern: /"version"\s*:\s*"/i, severity: 'MEDIUM' },
|
|
375
|
+
{ check: 'Changelog update', pattern: /CHANGELOG/i, severity: 'MEDIUM' },
|
|
376
|
+
],
|
|
377
|
+
'design-reviewer': [
|
|
378
|
+
{ check: 'Accessibility attributes', pattern: /aria-|role=/i, severity: 'MEDIUM' },
|
|
379
|
+
{ check: 'Inline styles', pattern: /style\s*=\s*\{/i, severity: 'LOW' },
|
|
380
|
+
],
|
|
381
|
+
'ceo-reviewer': [],
|
|
382
|
+
};
|
|
383
|
+
export function analyzeRoleReview(input) {
|
|
384
|
+
const findings = [];
|
|
385
|
+
const checklistItems = [];
|
|
386
|
+
const patterns = ROLE_CHECK_PATTERNS[input.role] ?? [];
|
|
387
|
+
if (input.role === 'eng-manager') {
|
|
388
|
+
// Check if source changes have corresponding test changes
|
|
389
|
+
const sourceChanged = input.changedFiles.some(f => isSourcePath(f.path) && !isTestPath(f.path));
|
|
390
|
+
const testChanged = input.changedFiles.some(f => isTestPath(f.path));
|
|
391
|
+
if (sourceChanged && !testChanged) {
|
|
392
|
+
findings.push({
|
|
393
|
+
category: 'process',
|
|
394
|
+
severity: 'MEDIUM',
|
|
395
|
+
description: 'Source files changed without corresponding test updates (eng-manager perspective).',
|
|
396
|
+
});
|
|
397
|
+
checklistItems.push({ item: 'Test coverage for source changes', status: 'fail' });
|
|
398
|
+
}
|
|
399
|
+
else if (sourceChanged) {
|
|
400
|
+
checklistItems.push({ item: 'Test coverage for source changes', status: 'pass' });
|
|
401
|
+
}
|
|
402
|
+
// Check for excessive file count
|
|
403
|
+
if (input.changedFiles.length > 20) {
|
|
404
|
+
findings.push({
|
|
405
|
+
category: 'process',
|
|
406
|
+
severity: 'MEDIUM',
|
|
407
|
+
description: `Large changeset (${input.changedFiles.length} files). Consider splitting into smaller PRs (eng-manager perspective).`,
|
|
408
|
+
});
|
|
409
|
+
}
|
|
410
|
+
return { role: input.role, findings, checklistItems };
|
|
411
|
+
}
|
|
412
|
+
if (input.role === 'release-engineer') {
|
|
413
|
+
const hasVersionBump = input.changedFiles.some(f => f.path.includes('package.json'));
|
|
414
|
+
const hasChangelog = input.changedFiles.some(f => f.path.includes('CHANGELOG'));
|
|
415
|
+
checklistItems.push({ item: 'Version bump', status: hasVersionBump ? 'pass' : 'skip' });
|
|
416
|
+
checklistItems.push({ item: 'Changelog update', status: hasChangelog ? 'pass' : 'skip' });
|
|
417
|
+
return { role: input.role, findings, checklistItems };
|
|
418
|
+
}
|
|
419
|
+
// For other roles, scan diffs for patterns
|
|
420
|
+
for (const diff of input.diffs) {
|
|
421
|
+
const added = getAddedLines(diff.text);
|
|
422
|
+
for (const { check, pattern, severity } of patterns) {
|
|
423
|
+
const match = firstMatch(added, pattern);
|
|
424
|
+
if (match) {
|
|
425
|
+
findings.push({
|
|
426
|
+
category: 'security',
|
|
427
|
+
severity,
|
|
428
|
+
description: `${check} (${input.role} perspective).`,
|
|
429
|
+
file: diff.file,
|
|
430
|
+
evidence: evidence(match, check),
|
|
431
|
+
});
|
|
432
|
+
checklistItems.push({ item: check, status: 'fail' });
|
|
433
|
+
}
|
|
434
|
+
}
|
|
435
|
+
}
|
|
436
|
+
return { role: input.role, findings, checklistItems };
|
|
437
|
+
}
|
|
356
438
|
//# sourceMappingURL=ReviewAnalyzer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ReviewAnalyzer.js","sourceRoot":"","sources":["../../src/workflow/ReviewAnalyzer.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ReviewAnalyzer.js","sourceRoot":"","sources":["../../src/workflow/ReviewAnalyzer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export type OwaspCategory = 'injection' | 'auth' | 'exposure' | 'xxe' | 'access-control' | 'misconfig' | 'xss' | 'deserialization' | 'components' | 'logging';
|
|
2
|
+
export type StrideCategory = 'spoofing' | 'tampering' | 'repudiation' | 'info-disclosure' | 'denial-of-service' | 'elevation-of-privilege';
|
|
3
|
+
export type FindingSeverity = 'critical' | 'high' | 'medium' | 'low';
|
|
4
|
+
export interface SecurityFinding {
|
|
5
|
+
id: string;
|
|
6
|
+
category: OwaspCategory | StrideCategory;
|
|
7
|
+
severity: FindingSeverity;
|
|
8
|
+
title: string;
|
|
9
|
+
description: string;
|
|
10
|
+
file?: string;
|
|
11
|
+
line?: number;
|
|
12
|
+
evidence: string;
|
|
13
|
+
recommendation: string;
|
|
14
|
+
}
|
|
15
|
+
export interface SecurityAuditResult {
|
|
16
|
+
findings: SecurityFinding[];
|
|
17
|
+
owaspCoverage: Record<OwaspCategory, 'checked' | 'not-applicable' | 'unchecked'>;
|
|
18
|
+
strideCoverage: Record<StrideCategory, 'checked' | 'not-applicable' | 'unchecked'>;
|
|
19
|
+
riskScore: number;
|
|
20
|
+
summary: string;
|
|
21
|
+
}
|
|
22
|
+
export interface AuditOptions {
|
|
23
|
+
projectDir?: string;
|
|
24
|
+
files?: string[];
|
|
25
|
+
}
|
|
26
|
+
export declare function runSecurityAudit(opts?: AuditOptions): Promise<SecurityAuditResult>;
|
|
27
|
+
export declare function summarizeSecurityAudit(result: SecurityAuditResult): string;
|
|
@@ -0,0 +1,294 @@
|
|
|
1
|
+
// SCALE Engine — Security Audit Engine (v0.33.0)
|
|
2
|
+
// OWASP Top 10 + STRIDE security audit for code review.
|
|
3
|
+
// Inspired by gstack's /cso security audit skill.
|
|
4
|
+
import { readFileSync, existsSync } from 'node:fs';
|
|
5
|
+
import { join } from 'node:path';
|
|
6
|
+
const SECURITY_PATTERNS = [
|
|
7
|
+
// Injection
|
|
8
|
+
{
|
|
9
|
+
id: 'sql-concat',
|
|
10
|
+
category: 'injection',
|
|
11
|
+
severity: 'critical',
|
|
12
|
+
title: 'SQL string concatenation detected',
|
|
13
|
+
pattern: /(?:query|execute|raw)\s*\(\s*[`'"].*\$\{|(?:query|execute|raw)\s*\(\s*['"].*\+\s*(?:req\.|params\.|input|user)/i,
|
|
14
|
+
description: 'SQL query built with string concatenation or template literals using user input.',
|
|
15
|
+
recommendation: 'Use parameterized queries or an ORM with built-in escaping.',
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
id: 'eval-usage',
|
|
19
|
+
category: 'injection',
|
|
20
|
+
severity: 'critical',
|
|
21
|
+
title: 'Dynamic code execution detected',
|
|
22
|
+
pattern: /\b(?:eval|Function|setTimeout|setInterval)\s*\(\s*(?:req\.|params\.|input|user|req\[)/i,
|
|
23
|
+
description: 'Dynamic code execution with user-controlled input.',
|
|
24
|
+
recommendation: 'Never pass user input to eval/Function. Use safe alternatives like JSON.parse or a sandboxed VM.',
|
|
25
|
+
},
|
|
26
|
+
// Auth
|
|
27
|
+
{
|
|
28
|
+
id: 'hardcoded-password',
|
|
29
|
+
category: 'auth',
|
|
30
|
+
severity: 'critical',
|
|
31
|
+
title: 'Hardcoded password or secret',
|
|
32
|
+
pattern: /(?:password|passwd|secret|api[_-]?key|token|auth[_-]?key)\s*[:=]\s*['"][^'"]{8,}['"]/i,
|
|
33
|
+
description: 'Hardcoded credential found in source code.',
|
|
34
|
+
recommendation: 'Move secrets to environment variables or a secret manager.',
|
|
35
|
+
testFileExempt: true,
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
id: 'weak-crypto',
|
|
39
|
+
category: 'auth',
|
|
40
|
+
severity: 'high',
|
|
41
|
+
title: 'Weak cryptographic algorithm',
|
|
42
|
+
pattern: /\b(?:md5|sha1)\b.*(?:hash|digest|createHash)/i,
|
|
43
|
+
description: 'Weak hash algorithm (MD5/SHA1) used for security-sensitive operation.',
|
|
44
|
+
recommendation: 'Use SHA-256 or stronger. For passwords, use bcrypt, argon2, or scrypt.',
|
|
45
|
+
},
|
|
46
|
+
// XSS
|
|
47
|
+
{
|
|
48
|
+
id: 'innerhtml',
|
|
49
|
+
category: 'xss',
|
|
50
|
+
severity: 'high',
|
|
51
|
+
title: 'innerHTML assignment detected',
|
|
52
|
+
pattern: /\.innerHTML\s*=\s*(?!['"]\s*['"])/,
|
|
53
|
+
description: 'Direct innerHTML assignment may allow XSS if input is not sanitized.',
|
|
54
|
+
recommendation: 'Use textContent, or sanitize with DOMPurify before assigning to innerHTML.',
|
|
55
|
+
testFileExempt: true,
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
id: 'dangerously-set-html',
|
|
59
|
+
category: 'xss',
|
|
60
|
+
severity: 'high',
|
|
61
|
+
title: 'dangerouslySetInnerHTML usage',
|
|
62
|
+
pattern: /dangerouslySetInnerHTML\s*:/,
|
|
63
|
+
description: 'React dangerouslySetInnerHTML bypasses XSS protection.',
|
|
64
|
+
recommendation: 'Sanitize HTML with DOMPurify before passing to dangerouslySetInnerHTML.',
|
|
65
|
+
testFileExempt: true,
|
|
66
|
+
},
|
|
67
|
+
// Exposure
|
|
68
|
+
{
|
|
69
|
+
id: 'stack-trace-exposure',
|
|
70
|
+
category: 'exposure',
|
|
71
|
+
severity: 'medium',
|
|
72
|
+
title: 'Stack trace exposure in response',
|
|
73
|
+
pattern: /(?:res\.|response\.)\s*(?:send|json|write)\s*\(\s*(?:err|error)\s*(?:\.stack)?\s*\)/i,
|
|
74
|
+
description: 'Error stack trace sent to client, leaking internal implementation details.',
|
|
75
|
+
recommendation: 'Return generic error messages to clients. Log detailed errors server-side only.',
|
|
76
|
+
},
|
|
77
|
+
// Access Control
|
|
78
|
+
{
|
|
79
|
+
id: 'path-traversal',
|
|
80
|
+
category: 'access-control',
|
|
81
|
+
severity: 'critical',
|
|
82
|
+
title: 'Potential path traversal vulnerability',
|
|
83
|
+
pattern: /(?:readFile|readFileSync|createReadStream|access)\s*\(\s*(?:req\.|params\.|query\.|input|user)/i,
|
|
84
|
+
description: 'File system operation with user-controlled path.',
|
|
85
|
+
recommendation: 'Validate and normalize paths. Use path.resolve with a base directory check.',
|
|
86
|
+
},
|
|
87
|
+
// Logging
|
|
88
|
+
{
|
|
89
|
+
id: 'sensitive-logging',
|
|
90
|
+
category: 'logging',
|
|
91
|
+
severity: 'medium',
|
|
92
|
+
title: 'Sensitive data in log output',
|
|
93
|
+
pattern: /console\.\w+\s*\(.*(?:password|secret|token|key|credential)/i,
|
|
94
|
+
description: 'Sensitive data may be written to logs.',
|
|
95
|
+
recommendation: 'Redact sensitive fields before logging.',
|
|
96
|
+
},
|
|
97
|
+
// Deserialization
|
|
98
|
+
{
|
|
99
|
+
id: 'unsafe-deserialize',
|
|
100
|
+
category: 'deserialization',
|
|
101
|
+
severity: 'high',
|
|
102
|
+
title: 'Unsafe deserialization',
|
|
103
|
+
pattern: /JSON\.parse\s*\(\s*(?:req\.|params\.|body|input|user)/i,
|
|
104
|
+
description: 'JSON.parse with untrusted input without validation.',
|
|
105
|
+
recommendation: 'Validate JSON schema after parsing. Consider using a schema validator like zod or ajv.',
|
|
106
|
+
testFileExempt: true,
|
|
107
|
+
},
|
|
108
|
+
];
|
|
109
|
+
// ============================================================================
|
|
110
|
+
// Core Audit
|
|
111
|
+
// ============================================================================
|
|
112
|
+
export async function runSecurityAudit(opts) {
|
|
113
|
+
const projectDir = opts?.projectDir ?? process.cwd();
|
|
114
|
+
const files = opts?.files ?? [];
|
|
115
|
+
const findings = [];
|
|
116
|
+
let findingCounter = 0;
|
|
117
|
+
// Scan each file
|
|
118
|
+
for (const filePath of files) {
|
|
119
|
+
const fullPath = join(projectDir, filePath);
|
|
120
|
+
if (!existsSync(fullPath))
|
|
121
|
+
continue;
|
|
122
|
+
let content;
|
|
123
|
+
try {
|
|
124
|
+
content = readFileSync(fullPath, 'utf-8');
|
|
125
|
+
}
|
|
126
|
+
catch {
|
|
127
|
+
continue;
|
|
128
|
+
}
|
|
129
|
+
const lines = content.split('\n');
|
|
130
|
+
const isTestFile = isTestPath(filePath);
|
|
131
|
+
for (const patternDef of SECURITY_PATTERNS) {
|
|
132
|
+
if (patternDef.testFileExempt && isTestFile)
|
|
133
|
+
continue;
|
|
134
|
+
for (let i = 0; i < lines.length; i++) {
|
|
135
|
+
if (patternDef.pattern.test(lines[i])) {
|
|
136
|
+
findingCounter++;
|
|
137
|
+
findings.push({
|
|
138
|
+
id: `SEC-${String(findingCounter).padStart(3, '0')}`,
|
|
139
|
+
category: patternDef.category,
|
|
140
|
+
severity: patternDef.severity,
|
|
141
|
+
title: patternDef.title,
|
|
142
|
+
description: patternDef.description,
|
|
143
|
+
file: filePath,
|
|
144
|
+
line: i + 1,
|
|
145
|
+
evidence: lines[i].trim().slice(0, 200),
|
|
146
|
+
recommendation: patternDef.recommendation,
|
|
147
|
+
});
|
|
148
|
+
break; // One finding per pattern per file
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
// Build coverage maps
|
|
154
|
+
const owaspCoverage = buildOwaspCoverage(findings);
|
|
155
|
+
const strideCoverage = buildStrideCoverage(findings);
|
|
156
|
+
const riskScore = calculateRiskScore(findings);
|
|
157
|
+
const summary = buildSummary(findings, riskScore);
|
|
158
|
+
return { findings, owaspCoverage, strideCoverage, riskScore, summary };
|
|
159
|
+
}
|
|
160
|
+
// ============================================================================
|
|
161
|
+
// Coverage
|
|
162
|
+
// ============================================================================
|
|
163
|
+
function buildOwaspCoverage(findings) {
|
|
164
|
+
const categories = [
|
|
165
|
+
'injection', 'auth', 'exposure', 'xxe', 'access-control',
|
|
166
|
+
'misconfig', 'xss', 'deserialization', 'components', 'logging',
|
|
167
|
+
];
|
|
168
|
+
const foundCategories = new Set(findings.map(f => f.category));
|
|
169
|
+
const result = {};
|
|
170
|
+
for (const cat of categories) {
|
|
171
|
+
if (foundCategories.has(cat)) {
|
|
172
|
+
result[cat] = 'checked';
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
result[cat] = 'not-applicable';
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return result;
|
|
179
|
+
}
|
|
180
|
+
function buildStrideCoverage(findings) {
|
|
181
|
+
const categories = [
|
|
182
|
+
'spoofing', 'tampering', 'repudiation', 'info-disclosure', 'denial-of-service', 'elevation-of-privilege',
|
|
183
|
+
];
|
|
184
|
+
// Map OWASP categories to STRIDE
|
|
185
|
+
const owaspToStride = {
|
|
186
|
+
'auth': 'spoofing',
|
|
187
|
+
'injection': 'tampering',
|
|
188
|
+
'xss': 'tampering',
|
|
189
|
+
'deserialization': 'tampering',
|
|
190
|
+
'logging': 'repudiation',
|
|
191
|
+
'exposure': 'info-disclosure',
|
|
192
|
+
'xxe': 'info-disclosure',
|
|
193
|
+
'access-control': 'elevation-of-privilege',
|
|
194
|
+
'components': 'elevation-of-privilege',
|
|
195
|
+
'misconfig': 'denial-of-service',
|
|
196
|
+
};
|
|
197
|
+
const foundStride = new Set();
|
|
198
|
+
for (const f of findings) {
|
|
199
|
+
const stride = owaspToStride[f.category];
|
|
200
|
+
if (stride)
|
|
201
|
+
foundStride.add(stride);
|
|
202
|
+
}
|
|
203
|
+
const result = {};
|
|
204
|
+
for (const cat of categories) {
|
|
205
|
+
result[cat] = foundStride.has(cat) ? 'checked' : 'not-applicable';
|
|
206
|
+
}
|
|
207
|
+
return result;
|
|
208
|
+
}
|
|
209
|
+
// ============================================================================
|
|
210
|
+
// Risk Score
|
|
211
|
+
// ============================================================================
|
|
212
|
+
function calculateRiskScore(findings) {
|
|
213
|
+
if (findings.length === 0)
|
|
214
|
+
return 0;
|
|
215
|
+
const weights = {
|
|
216
|
+
critical: 25,
|
|
217
|
+
high: 15,
|
|
218
|
+
medium: 8,
|
|
219
|
+
low: 3,
|
|
220
|
+
};
|
|
221
|
+
let score = 0;
|
|
222
|
+
for (const f of findings) {
|
|
223
|
+
score += weights[f.severity];
|
|
224
|
+
}
|
|
225
|
+
return Math.min(100, score);
|
|
226
|
+
}
|
|
227
|
+
// ============================================================================
|
|
228
|
+
// Summary
|
|
229
|
+
// ============================================================================
|
|
230
|
+
function buildSummary(findings, riskScore) {
|
|
231
|
+
if (findings.length === 0) {
|
|
232
|
+
return 'No security findings detected.';
|
|
233
|
+
}
|
|
234
|
+
const critical = findings.filter(f => f.severity === 'critical').length;
|
|
235
|
+
const high = findings.filter(f => f.severity === 'high').length;
|
|
236
|
+
const medium = findings.filter(f => f.severity === 'medium').length;
|
|
237
|
+
const low = findings.filter(f => f.severity === 'low').length;
|
|
238
|
+
const lines = [
|
|
239
|
+
`Security audit found ${findings.length} finding(s):`,
|
|
240
|
+
` Critical: ${critical}, High: ${high}, Medium: ${medium}, Low: ${low}`,
|
|
241
|
+
` Risk Score: ${riskScore}/100`,
|
|
242
|
+
];
|
|
243
|
+
if (critical > 0) {
|
|
244
|
+
lines.push(' ⚠️ CRITICAL findings require immediate remediation before merge.');
|
|
245
|
+
}
|
|
246
|
+
return lines.join('\n');
|
|
247
|
+
}
|
|
248
|
+
// ============================================================================
|
|
249
|
+
// Formatter
|
|
250
|
+
// ============================================================================
|
|
251
|
+
export function summarizeSecurityAudit(result) {
|
|
252
|
+
const lines = ['## Security Audit Result\n'];
|
|
253
|
+
if (result.findings.length === 0) {
|
|
254
|
+
lines.push('No security findings detected.');
|
|
255
|
+
return lines.join('\n');
|
|
256
|
+
}
|
|
257
|
+
lines.push(`**Risk Score:** ${result.riskScore}/100\n`);
|
|
258
|
+
const bySeverity = {
|
|
259
|
+
critical: result.findings.filter(f => f.severity === 'critical'),
|
|
260
|
+
high: result.findings.filter(f => f.severity === 'high'),
|
|
261
|
+
medium: result.findings.filter(f => f.severity === 'medium'),
|
|
262
|
+
low: result.findings.filter(f => f.severity === 'low'),
|
|
263
|
+
};
|
|
264
|
+
for (const [severity, items] of Object.entries(bySeverity)) {
|
|
265
|
+
if (items.length === 0)
|
|
266
|
+
continue;
|
|
267
|
+
const icon = severity === 'critical' ? '🔴' : severity === 'high' ? '🟠' : severity === 'medium' ? '🟡' : '🔵';
|
|
268
|
+
lines.push(`### ${icon} ${severity.toUpperCase()} (${items.length})\n`);
|
|
269
|
+
for (const f of items) {
|
|
270
|
+
lines.push(`**${f.id}: ${f.title}**`);
|
|
271
|
+
if (f.file)
|
|
272
|
+
lines.push(` File: \`${f.file}${f.line ? `:${f.line}` : ''}\``);
|
|
273
|
+
lines.push(` ${f.description}`);
|
|
274
|
+
lines.push(` Recommendation: ${f.recommendation}`);
|
|
275
|
+
lines.push('');
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
// OWASP coverage
|
|
279
|
+
lines.push('### OWASP Top 10 Coverage\n');
|
|
280
|
+
for (const [cat, status] of Object.entries(result.owaspCoverage)) {
|
|
281
|
+
const icon = status === 'checked' ? '✅' : '⬜';
|
|
282
|
+
lines.push(`${icon} ${cat}`);
|
|
283
|
+
}
|
|
284
|
+
return lines.join('\n');
|
|
285
|
+
}
|
|
286
|
+
// ============================================================================
|
|
287
|
+
// Helpers
|
|
288
|
+
// ============================================================================
|
|
289
|
+
function isTestPath(path) {
|
|
290
|
+
const normalized = path.replace(/\\/g, '/');
|
|
291
|
+
return /(^|\/)(tests?|__tests__)\//i.test(normalized) ||
|
|
292
|
+
/\.(test|spec)\.(ts|tsx|js|jsx|mjs|cjs)$/i.test(normalized);
|
|
293
|
+
}
|
|
294
|
+
//# sourceMappingURL=SecurityAudit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SecurityAudit.js","sourceRoot":"","sources":["../../src/workflow/SecurityAudit.ts"],"names":[],"mappings":"AAAA,iDAAiD;AACjD,wDAAwD;AACxD,kDAAkD;AAElD,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAClD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAoEhC,MAAM,iBAAiB,GAAsB;IAC3C,YAAY;IACZ;QACE,EAAE,EAAE,YAAY;QAChB,QAAQ,EAAE,WAAW;QACrB,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,mCAAmC;QAC1C,OAAO,EAAE,iHAAiH;QAC1H,WAAW,EAAE,kFAAkF;QAC/F,cAAc,EAAE,6DAA6D;KAC9E;IACD;QACE,EAAE,EAAE,YAAY;QAChB,QAAQ,EAAE,WAAW;QACrB,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,iCAAiC;QACxC,OAAO,EAAE,wFAAwF;QACjG,WAAW,EAAE,oDAAoD;QACjE,cAAc,EAAE,kGAAkG;KACnH;IAED,OAAO;IACP;QACE,EAAE,EAAE,oBAAoB;QACxB,QAAQ,EAAE,MAAM;QAChB,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,8BAA8B;QACrC,OAAO,EAAE,uFAAuF;QAChG,WAAW,EAAE,4CAA4C;QACzD,cAAc,EAAE,4DAA4D;QAC5E,cAAc,EAAE,IAAI;KACrB;IACD;QACE,EAAE,EAAE,aAAa;QACjB,QAAQ,EAAE,MAAM;QAChB,QAAQ,EAAE,MAAM;QAChB,KAAK,EAAE,8BAA8B;QACrC,OAAO,EAAE,+CAA+C;QACxD,WAAW,EAAE,uEAAuE;QACpF,cAAc,EAAE,wEAAwE;KACzF;IAED,MAAM;IACN;QACE,EAAE,EAAE,WAAW;QACf,QAAQ,EAAE,KAAK;QACf,QAAQ,EAAE,MAAM;QAChB,KAAK,EAAE,+BAA+B;QACtC,OAAO,EAAE,mCAAmC;QAC5C,WAAW,EAAE,sEAAsE;QACnF,cAAc,EAAE,4EAA4E;QAC5F,cAAc,EAAE,IAAI;KACrB;IACD;QACE,EAAE,EAAE,sBAAsB;QAC1B,QAAQ,EAAE,KAAK;QACf,QAAQ,EAAE,MAAM;QAChB,KAAK,EAAE,+BAA+B;QACtC,OAAO,EAAE,6BAA6B;QACtC,WAAW,EAAE,wDAAwD;QACrE,cAAc,EAAE,yEAAyE;QACzF,cAAc,EAAE,IAAI;KACrB;IAED,WAAW;IACX;QACE,EAAE,EAAE,sBAAsB;QAC1B,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE,QAAQ;QAClB,KAAK,EAAE,kCAAkC;QACzC,OAAO,EAAE,sFAAsF;QAC/F,WAAW,EAAE,4EAA4E;QACzF,cAAc,EAAE,iFAAiF;KAClG;IAED,iBAAiB;IACjB;QACE,EAAE,EAAE,gBAAgB;QACpB,QAAQ,EAAE,gBAAgB;QAC1B,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,wCAAwC;QAC/C,OAAO,EAAE,iGAAiG;QAC1G,WAAW,EAAE,kDAAkD;QAC/D,cAAc,EAAE,6EAA6E;KAC9F;IAED,UAAU;IACV;QACE,EAAE,EAAE,mBAAmB;QACvB,QAAQ,EAAE,SAAS;QACnB,QAAQ,EAAE,QAAQ;QAClB,KAAK,EAAE,8BAA8B;QACrC,OAAO,EAAE,8DAA8D;QACvE,WAAW,EAAE,wCAAwC;QACrD,cAAc,EAAE,yCAAyC;KAC1D;IAED,kBAAkB;IAClB;QACE,EAAE,EAAE,oBAAoB;QACxB,QAAQ,EAAE,iBAAiB;QAC3B,QAAQ,EAAE,MAAM;QAChB,KAAK,EAAE,wBAAwB;QAC/B,OAAO,EAAE,wDAAwD;QACjE,WAAW,EAAE,qDAAqD;QAClE,cAAc,EAAE,wFAAwF;QACxG,cAAc,EAAE,IAAI;KACrB;CACF,CAAA;AAED,+EAA+E;AAC/E,aAAa;AACb,+EAA+E;AAE/E,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,IAAmB;IACxD,MAAM,UAAU,GAAG,IAAI,EAAE,UAAU,IAAI,OAAO,CAAC,GAAG,EAAE,CAAA;IACpD,MAAM,KAAK,GAAG,IAAI,EAAE,KAAK,IAAI,EAAE,CAAA;IAE/B,MAAM,QAAQ,GAAsB,EAAE,CAAA;IACtC,IAAI,cAAc,GAAG,CAAC,CAAA;IAEtB,iBAAiB;IACjB,KAAK,MAAM,QAAQ,IAAI,KAAK,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAC3C,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;YAAE,SAAQ;QAEnC,IAAI,OAAe,CAAA;QACnB,IAAI,CAAC;YACH,OAAO,GAAG,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;QAC3C,CAAC;QAAC,MAAM,CAAC;YACP,SAAQ;QACV,CAAC;QAED,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QACjC,MAAM,UAAU,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEvC,KAAK,MAAM,UAAU,IAAI,iBAAiB,EAAE,CAAC;YAC3C,IAAI,UAAU,CAAC,cAAc,IAAI,UAAU;gBAAE,SAAQ;YAErD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBACtC,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBACtC,cAAc,EAAE,CAAA;oBAChB,QAAQ,CAAC,IAAI,CAAC;wBACZ,EAAE,EAAE,OAAO,MAAM,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE;wBACpD,QAAQ,EAAE,UAAU,CAAC,QAAQ;wBAC7B,QAAQ,EAAE,UAAU,CAAC,QAAQ;wBAC7B,KAAK,EAAE,UAAU,CAAC,KAAK;wBACvB,WAAW,EAAE,UAAU,CAAC,WAAW;wBACnC,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,CAAC,GAAG,CAAC;wBACX,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC;wBACvC,cAAc,EAAE,UAAU,CAAC,cAAc;qBAC1C,CAAC,CAAA;oBACF,MAAK,CAAC,mCAAmC;gBAC3C,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,sBAAsB;IACtB,MAAM,aAAa,GAAG,kBAAkB,CAAC,QAAQ,CAAC,CAAA;IAClD,MAAM,cAAc,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAA;IACpD,MAAM,SAAS,GAAG,kBAAkB,CAAC,QAAQ,CAAC,CAAA;IAE9C,MAAM,OAAO,GAAG,YAAY,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAA;IAEjD,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,cAAc,EAAE,SAAS,EAAE,OAAO,EAAE,CAAA;AACxE,CAAC;AAED,+EAA+E;AAC/E,WAAW;AACX,+EAA+E;AAE/E,SAAS,kBAAkB,CAAC,QAA2B;IACrD,MAAM,UAAU,GAAoB;QAClC,WAAW,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,gBAAgB;QACxD,WAAW,EAAE,KAAK,EAAE,iBAAiB,EAAE,YAAY,EAAE,SAAS;KAC/D,CAAA;IAED,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAA;IAC9D,MAAM,MAAM,GAA+D,EAAE,CAAA;IAE7E,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAC7B,IAAI,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAC7B,MAAM,CAAC,GAAG,CAAC,GAAG,SAAS,CAAA;QACzB,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,GAAG,CAAC,GAAG,gBAAgB,CAAA;QAChC,CAAC;IACH,CAAC;IAED,OAAO,MAA2E,CAAA;AACpF,CAAC;AAED,SAAS,mBAAmB,CAAC,QAA2B;IACtD,MAAM,UAAU,GAAqB;QACnC,UAAU,EAAE,WAAW,EAAE,aAAa,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,wBAAwB;KACzG,CAAA;IAED,iCAAiC;IACjC,MAAM,aAAa,GAAmC;QACpD,MAAM,EAAE,UAAU;QAClB,WAAW,EAAE,WAAW;QACxB,KAAK,EAAE,WAAW;QAClB,iBAAiB,EAAE,WAAW;QAC9B,SAAS,EAAE,aAAa;QACxB,UAAU,EAAE,iBAAiB;QAC7B,KAAK,EAAE,iBAAiB;QACxB,gBAAgB,EAAE,wBAAwB;QAC1C,YAAY,EAAE,wBAAwB;QACtC,WAAW,EAAE,mBAAmB;KACjC,CAAA;IAED,MAAM,WAAW,GAAG,IAAI,GAAG,EAAkB,CAAA;IAC7C,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;QACzB,MAAM,MAAM,GAAG,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;QACxC,IAAI,MAAM;YAAE,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACrC,CAAC;IAED,MAAM,MAAM,GAA+D,EAAE,CAAA;IAC7E,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAC7B,MAAM,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,gBAAgB,CAAA;IACnE,CAAC;IAED,OAAO,MAA4E,CAAA;AACrF,CAAC;AAED,+EAA+E;AAC/E,aAAa;AACb,+EAA+E;AAE/E,SAAS,kBAAkB,CAAC,QAA2B;IACrD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,CAAC,CAAA;IAEnC,MAAM,OAAO,GAAoC;QAC/C,QAAQ,EAAE,EAAE;QACZ,IAAI,EAAE,EAAE;QACR,MAAM,EAAE,CAAC;QACT,GAAG,EAAE,CAAC;KACP,CAAA;IAED,IAAI,KAAK,GAAG,CAAC,CAAA;IACb,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;QACzB,KAAK,IAAI,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;IAC9B,CAAC;IAED,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;AAC7B,CAAC;AAED,+EAA+E;AAC/E,UAAU;AACV,+EAA+E;AAE/E,SAAS,YAAY,CAAC,QAA2B,EAAE,SAAiB;IAClE,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,gCAAgC,CAAA;IACzC,CAAC;IAED,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAC,MAAM,CAAA;IACvE,MAAM,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,MAAM,CAAA;IAC/D,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC,MAAM,CAAA;IACnE,MAAM,GAAG,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,KAAK,CAAC,CAAC,MAAM,CAAA;IAE7D,MAAM,KAAK,GAAa;QACtB,wBAAwB,QAAQ,CAAC,MAAM,cAAc;QACrD,eAAe,QAAQ,WAAW,IAAI,aAAa,MAAM,UAAU,GAAG,EAAE;QACxE,iBAAiB,SAAS,MAAM;KACjC,CAAA;IAED,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;QACjB,KAAK,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAA;IACnF,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AACzB,CAAC;AAED,+EAA+E;AAC/E,YAAY;AACZ,+EAA+E;AAE/E,MAAM,UAAU,sBAAsB,CAAC,MAA2B;IAChE,MAAM,KAAK,GAAa,CAAC,4BAA4B,CAAC,CAAA;IAEtD,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjC,KAAK,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAA;QAC5C,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACzB,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,mBAAmB,MAAM,CAAC,SAAS,QAAQ,CAAC,CAAA;IAEvD,MAAM,UAAU,GAAG;QACjB,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,UAAU,CAAC;QAChE,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC;QACxD,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC;QAC5D,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,KAAK,CAAC;KACvD,CAAA;IAED,KAAK,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;QAC3D,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,SAAQ;QAChC,MAAM,IAAI,GAAG,QAAQ,KAAK,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;QAC9G,KAAK,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,QAAQ,CAAC,WAAW,EAAE,KAAK,KAAK,CAAC,MAAM,KAAK,CAAC,CAAA;QAEvE,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;YACtB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,KAAK,IAAI,CAAC,CAAA;YACrC,IAAI,CAAC,CAAC,IAAI;gBAAE,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;YAC5E,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC,CAAA;YAChC,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,cAAc,EAAE,CAAC,CAAA;YACnD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAChB,CAAC;IACH,CAAC;IAED,iBAAiB;IACjB,KAAK,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAA;IACzC,KAAK,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE,CAAC;QACjE,MAAM,IAAI,GAAG,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAA;QAC7C,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,IAAI,GAAG,EAAE,CAAC,CAAA;IAC9B,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AACzB,CAAC;AAED,+EAA+E;AAC/E,UAAU;AACV,+EAA+E;AAE/E,SAAS,UAAU,CAAC,IAAY;IAC9B,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;IAC3C,OAAO,6BAA6B,CAAC,IAAI,CAAC,UAAU,CAAC;QACnD,0CAA0C,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;AAC/D,CAAC"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
export type SessionTaskStatus = 'planned' | 'active' | 'blocked' | 'done' | 'cancelled';
|
|
2
|
+
export type DependencyType = 'blocks' | 'soft-dep' | 'data-flow';
|
|
3
|
+
export type OverlapRisk = 'low' | 'medium' | 'high';
|
|
4
|
+
export type EnforcementLevel = 'advisory' | 'warn' | 'block';
|
|
5
|
+
export type ConflictResolution = 'accept' | 'defer' | 'split-files' | 'manual';
|
|
6
|
+
export interface SessionTask {
|
|
7
|
+
sessionId: string;
|
|
8
|
+
taskId: string;
|
|
9
|
+
files: string[];
|
|
10
|
+
dependencies: string[];
|
|
11
|
+
status: SessionTaskStatus;
|
|
12
|
+
startedAt: string;
|
|
13
|
+
completedAt?: string;
|
|
14
|
+
metadata?: Record<string, unknown>;
|
|
15
|
+
}
|
|
16
|
+
export interface FileOverlap {
|
|
17
|
+
file: string;
|
|
18
|
+
sessions: Array<{
|
|
19
|
+
sessionId: string;
|
|
20
|
+
taskId: string;
|
|
21
|
+
}>;
|
|
22
|
+
risk: OverlapRisk;
|
|
23
|
+
suggestion: string;
|
|
24
|
+
}
|
|
25
|
+
export interface TaskDependencyEdge {
|
|
26
|
+
from: string;
|
|
27
|
+
to: string;
|
|
28
|
+
type: DependencyType;
|
|
29
|
+
reason: string;
|
|
30
|
+
}
|
|
31
|
+
export interface ConflictRecord {
|
|
32
|
+
id: string;
|
|
33
|
+
file: string;
|
|
34
|
+
sessions: string[];
|
|
35
|
+
resolution: ConflictResolution;
|
|
36
|
+
resolvedBy?: string;
|
|
37
|
+
resolvedAt: string;
|
|
38
|
+
notes?: string;
|
|
39
|
+
}
|
|
40
|
+
export interface SessionCoordinatorConfig {
|
|
41
|
+
enforcement: EnforcementLevel;
|
|
42
|
+
maxConcurrentSessions: number;
|
|
43
|
+
trackFileOverlaps: boolean;
|
|
44
|
+
autoBlockOnHighRisk: boolean;
|
|
45
|
+
}
|
|
46
|
+
export interface SessionCoordinatorInput {
|
|
47
|
+
projectDir?: string;
|
|
48
|
+
scaleDir?: string;
|
|
49
|
+
config?: Partial<SessionCoordinatorConfig>;
|
|
50
|
+
}
|
|
51
|
+
export interface CoordinationStatus {
|
|
52
|
+
activeSessions: number;
|
|
53
|
+
activeTasks: SessionTask[];
|
|
54
|
+
fileOverlaps: FileOverlap[];
|
|
55
|
+
blockedTasks: Array<{
|
|
56
|
+
taskId: string;
|
|
57
|
+
blockedBy: string[];
|
|
58
|
+
}>;
|
|
59
|
+
conflicts: ConflictRecord[];
|
|
60
|
+
recommendations: string[];
|
|
61
|
+
}
|
|
62
|
+
export interface TopologicalOrder {
|
|
63
|
+
order: string[];
|
|
64
|
+
cycles: string[][];
|
|
65
|
+
blocked: string[];
|
|
66
|
+
}
|
|
67
|
+
export declare class SessionCoordinator {
|
|
68
|
+
private tasks;
|
|
69
|
+
private dependencies;
|
|
70
|
+
private conflicts;
|
|
71
|
+
private config;
|
|
72
|
+
private statePath;
|
|
73
|
+
private stateDir;
|
|
74
|
+
constructor(input?: SessionCoordinatorInput);
|
|
75
|
+
registerSession(task: Omit<SessionTask, 'status' | 'startedAt'>): SessionTask;
|
|
76
|
+
activateTask(taskId: string): {
|
|
77
|
+
allowed: boolean;
|
|
78
|
+
blockers: string[];
|
|
79
|
+
};
|
|
80
|
+
completeTask(taskId: string): void;
|
|
81
|
+
cancelTask(taskId: string): void;
|
|
82
|
+
blockTask(taskId: string): void;
|
|
83
|
+
detectOverlaps(): FileOverlap[];
|
|
84
|
+
addDependency(edge: TaskDependencyEdge): void;
|
|
85
|
+
getTopologicalOrder(): TopologicalOrder;
|
|
86
|
+
getDependencies(taskId: string): {
|
|
87
|
+
upstream: string[];
|
|
88
|
+
downstream: string[];
|
|
89
|
+
};
|
|
90
|
+
recordConflict(conflict: Omit<ConflictRecord, 'id' | 'resolvedAt'>): ConflictRecord;
|
|
91
|
+
getCoordinationStatus(): CoordinationStatus;
|
|
92
|
+
private loadState;
|
|
93
|
+
private saveState;
|
|
94
|
+
private getActiveTasks;
|
|
95
|
+
getTask(taskId: string): SessionTask | undefined;
|
|
96
|
+
listTasks(): SessionTask[];
|
|
97
|
+
private getTaskBlockers;
|
|
98
|
+
private assessOverlapRisk;
|
|
99
|
+
private suggestOverlapResolution;
|
|
100
|
+
private findCycles;
|
|
101
|
+
private buildRecommendations;
|
|
102
|
+
}
|
|
103
|
+
export declare function summarizeCoordinationStatus(status: CoordinationStatus): string;
|