@hongmaple0820/scale-engine 0.8.0 → 0.10.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 +237 -0
- package/README.md +111 -50
- package/dist/adapters/ClaudeCodeAdapter.d.ts +2 -0
- package/dist/adapters/ClaudeCodeAdapter.js +5 -0
- package/dist/adapters/ClaudeCodeAdapter.js.map +1 -1
- package/dist/adapters/CodexAdapter.d.ts +1 -0
- package/dist/adapters/CodexAdapter.js +5 -0
- package/dist/adapters/CodexAdapter.js.map +1 -1
- package/dist/adapters/GeminiAdapter.d.ts +1 -0
- package/dist/adapters/GeminiAdapter.js +4 -0
- package/dist/adapters/GeminiAdapter.js.map +1 -1
- package/dist/adapters/HermesAdapter.d.ts +1 -0
- package/dist/adapters/HermesAdapter.js +4 -0
- package/dist/adapters/HermesAdapter.js.map +1 -1
- package/dist/adapters/OpenClawAdapter.d.ts +1 -0
- package/dist/adapters/OpenClawAdapter.js +4 -0
- package/dist/adapters/OpenClawAdapter.js.map +1 -1
- package/dist/adapters/QCoderAdapter.d.ts +1 -0
- package/dist/adapters/QCoderAdapter.js +4 -0
- package/dist/adapters/QCoderAdapter.js.map +1 -1
- package/dist/adapters/TraeAdapter.d.ts +1 -0
- package/dist/adapters/TraeAdapter.js +4 -0
- package/dist/adapters/TraeAdapter.js.map +1 -1
- package/dist/adapters/VSCAdapter.d.ts +1 -0
- package/dist/adapters/VSCAdapter.js +4 -0
- package/dist/adapters/VSCAdapter.js.map +1 -1
- package/dist/adapters/WorkBuddyAdapter.d.ts +1 -0
- package/dist/adapters/WorkBuddyAdapter.js +4 -0
- package/dist/adapters/WorkBuddyAdapter.js.map +1 -1
- package/dist/agents/AgentSourceLoader.js +1 -1
- package/dist/agents/AgentSourceLoader.js.map +1 -1
- package/dist/agents/types.d.ts +1 -1
- package/dist/api/cli.js +236 -5
- package/dist/api/cli.js.map +1 -1
- package/dist/api/quickstart.d.ts +23 -0
- package/dist/api/quickstart.js +57 -0
- package/dist/api/quickstart.js.map +1 -0
- package/dist/artifact/types.d.ts +9 -1
- package/dist/artifact/types.js.map +1 -1
- package/dist/capabilities/BrowserCapability.d.ts +30 -0
- package/dist/capabilities/BrowserCapability.js +73 -0
- package/dist/capabilities/BrowserCapability.js.map +1 -0
- package/dist/capabilities/CapabilityRegistry.d.ts +17 -0
- package/dist/capabilities/CapabilityRegistry.js +65 -0
- package/dist/capabilities/CapabilityRegistry.js.map +1 -0
- package/dist/capabilities/ComputerCapability.d.ts +28 -0
- package/dist/capabilities/ComputerCapability.js +40 -0
- package/dist/capabilities/ComputerCapability.js.map +1 -0
- package/dist/capabilities/InstalledSkillsIntegration.d.ts +66 -0
- package/dist/capabilities/InstalledSkillsIntegration.js +188 -0
- package/dist/capabilities/InstalledSkillsIntegration.js.map +1 -0
- package/dist/capabilities/SearchCapability.d.ts +46 -0
- package/dist/capabilities/SearchCapability.js +88 -0
- package/dist/capabilities/SearchCapability.js.map +1 -0
- package/dist/capabilities/index.d.ts +6 -0
- package/dist/capabilities/index.js +9 -0
- package/dist/capabilities/index.js.map +1 -0
- package/dist/capabilities/types.d.ts +92 -0
- package/dist/capabilities/types.js +7 -0
- package/dist/capabilities/types.js.map +1 -0
- package/dist/cli/liteCommands.d.ts +81 -0
- package/dist/cli/liteCommands.js +148 -0
- package/dist/cli/liteCommands.js.map +1 -0
- package/dist/cli/phaseCommands.d.ts +159 -0
- package/dist/cli/phaseCommands.js +826 -0
- package/dist/cli/phaseCommands.js.map +1 -0
- package/dist/core/logger.js +9 -2
- package/dist/core/logger.js.map +1 -1
- package/dist/hooks/HookGeneratorEnhanced.js +84 -5
- package/dist/hooks/HookGeneratorEnhanced.js.map +1 -1
- package/dist/hooks/WorkflowHooksManager.d.ts +30 -0
- package/dist/hooks/WorkflowHooksManager.js +117 -0
- package/dist/hooks/WorkflowHooksManager.js.map +1 -0
- package/dist/hooks/index.d.ts +2 -0
- package/dist/hooks/index.js +2 -1
- package/dist/hooks/index.js.map +1 -1
- package/dist/skills/SkillDiscovery.d.ts +27 -1
- package/dist/skills/SkillDiscovery.js +106 -11
- package/dist/skills/SkillDiscovery.js.map +1 -1
- package/dist/skills/SkillExecutor.d.ts +11 -1
- package/dist/skills/SkillExecutor.js +160 -5
- package/dist/skills/SkillExecutor.js.map +1 -1
- package/dist/workflow/EvidenceStore.d.ts +20 -0
- package/dist/workflow/EvidenceStore.js +48 -0
- package/dist/workflow/EvidenceStore.js.map +1 -0
- package/dist/workflow/ReviewAnalyzer.d.ts +28 -0
- package/dist/workflow/ReviewAnalyzer.js +80 -0
- package/dist/workflow/ReviewAnalyzer.js.map +1 -0
- package/dist/workflow/ReviewStore.d.ts +32 -0
- package/dist/workflow/ReviewStore.js +42 -0
- package/dist/workflow/ReviewStore.js.map +1 -0
- package/dist/workflow/VerificationCommands.d.ts +19 -0
- package/dist/workflow/VerificationCommands.js +123 -0
- package/dist/workflow/VerificationCommands.js.map +1 -0
- package/dist/workflow/WorkflowEngine.d.ts +62 -0
- package/dist/workflow/WorkflowEngine.js +151 -0
- package/dist/workflow/WorkflowEngine.js.map +1 -0
- package/dist/workflow/cognitive/AmbiguityScorer.d.ts +17 -0
- package/dist/workflow/cognitive/AmbiguityScorer.js +107 -0
- package/dist/workflow/cognitive/AmbiguityScorer.js.map +1 -0
- package/dist/workflow/cognitive/ConsensusPlanner.d.ts +26 -0
- package/dist/workflow/cognitive/ConsensusPlanner.js +141 -0
- package/dist/workflow/cognitive/ConsensusPlanner.js.map +1 -0
- package/dist/workflow/cognitive/SocraticQuestioner.d.ts +33 -0
- package/dist/workflow/cognitive/SocraticQuestioner.js +276 -0
- package/dist/workflow/cognitive/SocraticQuestioner.js.map +1 -0
- package/dist/workflow/execution/RalphEngine.d.ts +36 -0
- package/dist/workflow/execution/RalphEngine.js +123 -0
- package/dist/workflow/execution/RalphEngine.js.map +1 -0
- package/dist/workflow/execution/UltraworkEngine.d.ts +43 -0
- package/dist/workflow/execution/UltraworkEngine.js +135 -0
- package/dist/workflow/execution/UltraworkEngine.js.map +1 -0
- package/dist/workflow/gates/GateSystem.d.ts +104 -0
- package/dist/workflow/gates/GateSystem.js +579 -0
- package/dist/workflow/gates/GateSystem.js.map +1 -0
- package/dist/workflow/index.d.ts +12 -0
- package/dist/workflow/index.js +14 -0
- package/dist/workflow/index.js.map +1 -0
- package/dist/workflow/quality/HonestDelivery.d.ts +19 -0
- package/dist/workflow/quality/HonestDelivery.js +77 -0
- package/dist/workflow/quality/HonestDelivery.js.map +1 -0
- package/dist/workflow/quality/KarpathyEvaluator.d.ts +18 -0
- package/dist/workflow/quality/KarpathyEvaluator.js +76 -0
- package/dist/workflow/quality/KarpathyEvaluator.js.map +1 -0
- package/dist/workflow/types.d.ts +139 -0
- package/dist/workflow/types.js +4 -0
- package/dist/workflow/types.js.map +1 -0
- package/dist/workflows/DAGBuilder.js +1 -1
- package/dist/workflows/DAGBuilder.js.map +1 -1
- package/dist/workflows/WorkflowOrchestrator.js +1 -1
- package/dist/workflows/WorkflowOrchestrator.js.map +1 -1
- package/dist/workflows/index.js +1 -1
- package/dist/workflows/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
export function parseChangedFiles(output) {
|
|
2
|
+
return output
|
|
3
|
+
.split('\n')
|
|
4
|
+
.map(line => line.trim())
|
|
5
|
+
.filter(Boolean)
|
|
6
|
+
.map(line => {
|
|
7
|
+
const [status, ...pathParts] = line.split(/\s+/);
|
|
8
|
+
return { status, path: pathParts.join(' ') };
|
|
9
|
+
})
|
|
10
|
+
.filter(file => file.path.length > 0);
|
|
11
|
+
}
|
|
12
|
+
export function shouldReviewFile(path) {
|
|
13
|
+
const normalized = path.replace(/\\/g, '/');
|
|
14
|
+
return !normalized.endsWith('/') &&
|
|
15
|
+
!normalized.startsWith('.scale/') &&
|
|
16
|
+
!normalized.startsWith('dist/') &&
|
|
17
|
+
!normalized.includes('node_modules/') &&
|
|
18
|
+
!/\.(png|jpe?g|gif|webp|ico|db|db-shm|db-wal)$/i.test(normalized);
|
|
19
|
+
}
|
|
20
|
+
export function summarizeFindings(findings) {
|
|
21
|
+
return {
|
|
22
|
+
critical: findings.filter(f => f.severity === 'CRITICAL').length,
|
|
23
|
+
high: findings.filter(f => f.severity === 'HIGH').length,
|
|
24
|
+
medium: findings.filter(f => f.severity === 'MEDIUM').length,
|
|
25
|
+
low: findings.filter(f => f.severity === 'LOW').length,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
export function analyzeReview(input) {
|
|
29
|
+
const changedFiles = parseChangedFiles(input.statusOutput).filter(file => shouldReviewFile(file.path));
|
|
30
|
+
const findings = [];
|
|
31
|
+
if (!input.taskPayload?.verificationEvidenceIds?.length) {
|
|
32
|
+
findings.push({
|
|
33
|
+
category: 'process',
|
|
34
|
+
severity: 'HIGH',
|
|
35
|
+
description: 'Task has no persisted verification evidence; run scale verify before review.',
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
const deletedSource = changedFiles.filter(file => file.status.includes('D') && /\.(ts|tsx|js|jsx|test\.ts|spec\.ts)$/i.test(file.path));
|
|
39
|
+
for (const file of deletedSource) {
|
|
40
|
+
findings.push({
|
|
41
|
+
category: 'logic',
|
|
42
|
+
severity: 'HIGH',
|
|
43
|
+
description: 'Source or test file deletion requires explicit review.',
|
|
44
|
+
file: file.path,
|
|
45
|
+
evidence: file.status,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
const publicApiChanged = changedFiles.some(file => /(^src\/api\/|^src\/artifact\/types\.ts$|^src\/workflow\/types\.ts$|^src\/.*types\.ts$)/.test(file.path.replace(/\\/g, '/')));
|
|
49
|
+
const docsOrTestsChanged = changedFiles.some(file => /(^tests\/|^docs\/|README)/.test(file.path.replace(/\\/g, '/')));
|
|
50
|
+
if (publicApiChanged && !docsOrTestsChanged) {
|
|
51
|
+
findings.push({
|
|
52
|
+
category: 'process',
|
|
53
|
+
severity: 'MEDIUM',
|
|
54
|
+
description: 'Public API or shared type changes were detected without accompanying docs or tests.',
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
let totalDiffLines = 0;
|
|
58
|
+
for (const diff of input.diffs) {
|
|
59
|
+
const text = diff.text.slice(0, 20000);
|
|
60
|
+
totalDiffLines += text.split('\n').filter(line => line.startsWith('+') || line.startsWith('-')).length;
|
|
61
|
+
if (/(password|api[_-]?key|secret|token|auth)\s*[:=]\s*['"][^'"]+['"]/i.test(text)) {
|
|
62
|
+
findings.push({
|
|
63
|
+
category: 'security',
|
|
64
|
+
severity: 'CRITICAL',
|
|
65
|
+
description: 'Possible hardcoded secret introduced in diff.',
|
|
66
|
+
file: diff.file,
|
|
67
|
+
evidence: 'secret-like assignment pattern found in git diff',
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
if (totalDiffLines > (input.largeDiffThreshold ?? 800)) {
|
|
72
|
+
findings.push({
|
|
73
|
+
category: 'process',
|
|
74
|
+
severity: 'MEDIUM',
|
|
75
|
+
description: `Large diff detected (${totalDiffLines} changed lines); consider splitting review scope.`,
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
return { changedFiles, findings };
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=ReviewAnalyzer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReviewAnalyzer.js","sourceRoot":"","sources":["../../src/workflow/ReviewAnalyzer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export type ReviewSeverity = 'CRITICAL' | 'HIGH' | 'MEDIUM' | 'LOW';
|
|
2
|
+
export type ReviewCategory = 'style' | 'logic' | 'security' | 'performance' | 'process';
|
|
3
|
+
export interface ReviewFinding {
|
|
4
|
+
category: ReviewCategory;
|
|
5
|
+
severity: ReviewSeverity;
|
|
6
|
+
description: string;
|
|
7
|
+
file?: string;
|
|
8
|
+
evidence?: string;
|
|
9
|
+
}
|
|
10
|
+
export interface ReviewSummary {
|
|
11
|
+
critical: number;
|
|
12
|
+
high: number;
|
|
13
|
+
medium: number;
|
|
14
|
+
low: number;
|
|
15
|
+
}
|
|
16
|
+
export interface ReviewRecord {
|
|
17
|
+
id: string;
|
|
18
|
+
taskId?: string;
|
|
19
|
+
passed: boolean;
|
|
20
|
+
findings: ReviewFinding[];
|
|
21
|
+
changedFiles: string[];
|
|
22
|
+
summary: ReviewSummary;
|
|
23
|
+
createdAt: number;
|
|
24
|
+
}
|
|
25
|
+
export declare class ReviewStore {
|
|
26
|
+
private reviewsDir;
|
|
27
|
+
constructor(scaleDir?: string);
|
|
28
|
+
saveReview(input: Omit<ReviewRecord, 'id' | 'createdAt'>): ReviewRecord;
|
|
29
|
+
listReviews(limit?: number): ReviewRecord[];
|
|
30
|
+
getReview(id: string): ReviewRecord | null;
|
|
31
|
+
private readRecordFile;
|
|
32
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { existsSync, mkdirSync, readFileSync, readdirSync, writeFileSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
export class ReviewStore {
|
|
4
|
+
constructor(scaleDir = process.env.SCALE_DIR ?? '.scale') {
|
|
5
|
+
this.reviewsDir = join(scaleDir, 'reviews');
|
|
6
|
+
if (!existsSync(this.reviewsDir))
|
|
7
|
+
mkdirSync(this.reviewsDir, { recursive: true });
|
|
8
|
+
}
|
|
9
|
+
saveReview(input) {
|
|
10
|
+
const record = {
|
|
11
|
+
id: `REVIEW-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`,
|
|
12
|
+
createdAt: Date.now(),
|
|
13
|
+
...input,
|
|
14
|
+
};
|
|
15
|
+
const file = join(this.reviewsDir, `${record.id}.json`);
|
|
16
|
+
writeFileSync(file, JSON.stringify(record, null, 2), 'utf-8');
|
|
17
|
+
return record;
|
|
18
|
+
}
|
|
19
|
+
listReviews(limit = 20) {
|
|
20
|
+
if (!existsSync(this.reviewsDir))
|
|
21
|
+
return [];
|
|
22
|
+
return readdirSync(this.reviewsDir)
|
|
23
|
+
.filter(file => file.endsWith('.json'))
|
|
24
|
+
.map(file => this.readRecordFile(join(this.reviewsDir, file)))
|
|
25
|
+
.filter((record) => Boolean(record))
|
|
26
|
+
.sort((a, b) => b.createdAt - a.createdAt)
|
|
27
|
+
.slice(0, limit);
|
|
28
|
+
}
|
|
29
|
+
getReview(id) {
|
|
30
|
+
const file = join(this.reviewsDir, `${id}.json`);
|
|
31
|
+
return this.readRecordFile(file);
|
|
32
|
+
}
|
|
33
|
+
readRecordFile(file) {
|
|
34
|
+
try {
|
|
35
|
+
return JSON.parse(readFileSync(file, 'utf-8'));
|
|
36
|
+
}
|
|
37
|
+
catch {
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=ReviewStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReviewStore.js","sourceRoot":"","sources":["../../src/workflow/ReviewStore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AACzF,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AA8BhC,MAAM,OAAO,WAAW;IAGtB,YAAY,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,QAAQ;QACtD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAA;QAC3C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;IACnF,CAAC;IAED,UAAU,CAAC,KAA6C;QACtD,MAAM,MAAM,GAAiB;YAC3B,EAAE,EAAE,UAAU,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE;YACpE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,GAAG,KAAK;SACT,CAAA;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,MAAM,CAAC,EAAE,OAAO,CAAC,CAAA;QACvD,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAA;QAC7D,OAAO,MAAM,CAAA;IACf,CAAC;IAED,WAAW,CAAC,KAAK,GAAG,EAAE;QACpB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO,EAAE,CAAA;QAC3C,OAAO,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC;aAChC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;aACtC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC;aAC7D,MAAM,CAAC,CAAC,MAAM,EAA0B,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;aAC3D,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,SAAS,CAAC;aACzC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAA;IACpB,CAAC;IAED,SAAS,CAAC,EAAU;QAClB,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,OAAO,CAAC,CAAA;QAChD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAA;IAClC,CAAC;IAEO,cAAc,CAAC,IAAY;QACjC,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAiB,CAAA;QAChE,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAA;QACb,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export interface VerificationCommandConfig {
|
|
2
|
+
build?: string;
|
|
3
|
+
lint?: string;
|
|
4
|
+
test?: string;
|
|
5
|
+
coverage?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface ResolvedVerificationCommand {
|
|
8
|
+
command?: string;
|
|
9
|
+
source: 'override' | 'package-script' | 'fallback' | 'missing';
|
|
10
|
+
reason: string;
|
|
11
|
+
}
|
|
12
|
+
export interface ResolvedVerificationCommands {
|
|
13
|
+
packageManager: string;
|
|
14
|
+
build: ResolvedVerificationCommand;
|
|
15
|
+
lint: ResolvedVerificationCommand;
|
|
16
|
+
test: ResolvedVerificationCommand;
|
|
17
|
+
coverage: ResolvedVerificationCommand;
|
|
18
|
+
}
|
|
19
|
+
export declare function detectVerificationCommands(cwd?: string, overrides?: VerificationCommandConfig): ResolvedVerificationCommands;
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { existsSync, readFileSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
export function detectVerificationCommands(cwd = process.cwd(), overrides = {}) {
|
|
4
|
+
const pkg = readPackageJson(cwd);
|
|
5
|
+
const scripts = pkg?.scripts ?? {};
|
|
6
|
+
const packageManager = detectPackageManager(cwd, pkg);
|
|
7
|
+
return {
|
|
8
|
+
packageManager,
|
|
9
|
+
build: resolveBuildCommand(packageManager, scripts, overrides.build),
|
|
10
|
+
lint: resolveScriptCommand(packageManager, scripts, 'lint', overrides.lint),
|
|
11
|
+
test: resolveScriptCommand(packageManager, scripts, 'test', overrides.test),
|
|
12
|
+
coverage: resolveCoverageCommand(packageManager, scripts, overrides.coverage),
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
function readPackageJson(cwd) {
|
|
16
|
+
try {
|
|
17
|
+
return JSON.parse(readFileSync(join(cwd, 'package.json'), 'utf8'));
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function detectPackageManager(cwd, pkg) {
|
|
24
|
+
const declared = pkg?.packageManager?.split('@')[0];
|
|
25
|
+
if (declared)
|
|
26
|
+
return declared;
|
|
27
|
+
if (existsSync(join(cwd, 'package-lock.json')))
|
|
28
|
+
return 'npm';
|
|
29
|
+
if (existsSync(join(cwd, 'pnpm-lock.yaml')))
|
|
30
|
+
return 'pnpm';
|
|
31
|
+
if (existsSync(join(cwd, 'yarn.lock')))
|
|
32
|
+
return 'yarn';
|
|
33
|
+
if (existsSync(join(cwd, 'bun.lock')) || existsSync(join(cwd, 'bun.lockb')))
|
|
34
|
+
return 'bun';
|
|
35
|
+
return 'npm';
|
|
36
|
+
}
|
|
37
|
+
function resolveScriptCommand(packageManager, scripts, scriptName, override) {
|
|
38
|
+
if (override?.trim()) {
|
|
39
|
+
return {
|
|
40
|
+
command: override.trim(),
|
|
41
|
+
source: 'override',
|
|
42
|
+
reason: `provided by CLI/config override for ${scriptName}`,
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
if (!scripts[scriptName]) {
|
|
46
|
+
return {
|
|
47
|
+
source: 'missing',
|
|
48
|
+
reason: `package.json has no "${scriptName}" script`,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
command: runScriptCommand(packageManager, scriptName),
|
|
53
|
+
source: 'package-script',
|
|
54
|
+
reason: `detected package.json "${scriptName}" script`,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
function resolveCoverageCommand(packageManager, scripts, override) {
|
|
58
|
+
if (override?.trim()) {
|
|
59
|
+
return {
|
|
60
|
+
command: override.trim(),
|
|
61
|
+
source: 'override',
|
|
62
|
+
reason: 'provided by CLI/config override for coverage',
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
if (scripts.coverage) {
|
|
66
|
+
return {
|
|
67
|
+
command: runScriptCommand(packageManager, 'coverage'),
|
|
68
|
+
source: 'package-script',
|
|
69
|
+
reason: 'detected package.json "coverage" script',
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
if (scripts.test) {
|
|
73
|
+
return {
|
|
74
|
+
command: `${runScriptCommand(packageManager, 'test')} -- --coverage`,
|
|
75
|
+
source: 'fallback',
|
|
76
|
+
reason: 'no "coverage" script; using test script with coverage flag',
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
return {
|
|
80
|
+
source: 'missing',
|
|
81
|
+
reason: 'package.json has neither "coverage" nor "test" script',
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
function resolveBuildCommand(packageManager, scripts, override) {
|
|
85
|
+
if (override?.trim()) {
|
|
86
|
+
return {
|
|
87
|
+
command: override.trim(),
|
|
88
|
+
source: 'override',
|
|
89
|
+
reason: 'provided by CLI/config override for build',
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
if (scripts.build) {
|
|
93
|
+
return {
|
|
94
|
+
command: runScriptCommand(packageManager, 'build'),
|
|
95
|
+
source: 'package-script',
|
|
96
|
+
reason: 'detected package.json "build" script',
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
if (scripts.typecheck) {
|
|
100
|
+
return {
|
|
101
|
+
command: runScriptCommand(packageManager, 'typecheck'),
|
|
102
|
+
source: 'fallback',
|
|
103
|
+
reason: 'no "build" script; using package.json "typecheck" script',
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
return {
|
|
107
|
+
source: 'missing',
|
|
108
|
+
reason: 'package.json has neither "build" nor "typecheck" script',
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
function runScriptCommand(packageManager, scriptName) {
|
|
112
|
+
if (packageManager === 'npm') {
|
|
113
|
+
return scriptName === 'test' ? 'npm test' : `npm run ${scriptName}`;
|
|
114
|
+
}
|
|
115
|
+
if (packageManager === 'yarn') {
|
|
116
|
+
return `yarn ${scriptName}`;
|
|
117
|
+
}
|
|
118
|
+
if (packageManager === 'bun') {
|
|
119
|
+
return `bun run ${scriptName}`;
|
|
120
|
+
}
|
|
121
|
+
return scriptName === 'test' ? `${packageManager} test` : `${packageManager} run ${scriptName}`;
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=VerificationCommands.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VerificationCommands.js","sourceRoot":"","sources":["../../src/workflow/VerificationCommands.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import type { IEventBus } from '../core/eventBus.js';
|
|
2
|
+
import type { ICapabilityRegistry } from '../capabilities/types.js';
|
|
3
|
+
import type { ISkillRegistry } from '../skills/SkillRegistry.js';
|
|
4
|
+
import { GateSystem } from './gates/GateSystem.js';
|
|
5
|
+
import type { VerificationCommandConfig } from './VerificationCommands.js';
|
|
6
|
+
import { AmbiguityScorer } from './cognitive/AmbiguityScorer.js';
|
|
7
|
+
import { ConsensusPlanner } from './cognitive/ConsensusPlanner.js';
|
|
8
|
+
import { SocraticQuestioner } from './cognitive/SocraticQuestioner.js';
|
|
9
|
+
import { RalphEngine, PRDManager } from './execution/RalphEngine.js';
|
|
10
|
+
import { UltraworkEngine } from './execution/UltraworkEngine.js';
|
|
11
|
+
import { KarpathyEvaluator } from './quality/KarpathyEvaluator.js';
|
|
12
|
+
import type { PRDDocument, UserStory, TaskDefinition, SocraticSession } from './types.js';
|
|
13
|
+
export interface WorkflowEngineConfig {
|
|
14
|
+
eventBus: IEventBus;
|
|
15
|
+
capabilityRegistry?: ICapabilityRegistry;
|
|
16
|
+
skillRegistry?: ISkillRegistry;
|
|
17
|
+
verificationCommands?: VerificationCommandConfig;
|
|
18
|
+
}
|
|
19
|
+
export declare class WorkflowEngine {
|
|
20
|
+
private eventBus;
|
|
21
|
+
private capabilityRegistry?;
|
|
22
|
+
private skillRegistry?;
|
|
23
|
+
private gateSystem;
|
|
24
|
+
private ambiguityScorer;
|
|
25
|
+
private consensusPlanner;
|
|
26
|
+
private socraticQuestioner;
|
|
27
|
+
private ralphEngine;
|
|
28
|
+
private ultraworkEngine;
|
|
29
|
+
private prdManager;
|
|
30
|
+
private modelRouter;
|
|
31
|
+
private karpathyEvaluator;
|
|
32
|
+
constructor(config: WorkflowEngineConfig);
|
|
33
|
+
explore(requirement: string): Promise<{
|
|
34
|
+
ambiguityScore: number;
|
|
35
|
+
gateResult: unknown;
|
|
36
|
+
socraticSession?: SocraticSession;
|
|
37
|
+
}>;
|
|
38
|
+
refineRequirement(session: SocraticSession, questionId: string, answer: string): SocraticSession;
|
|
39
|
+
getNextQuestion(session: SocraticSession): import('./types.js').SocraticQuestion | null;
|
|
40
|
+
plan(requirement: string): Promise<unknown>;
|
|
41
|
+
build(tasks: TaskDefinition[]): Promise<Map<string, unknown>>;
|
|
42
|
+
verify(commandOverrides?: VerificationCommandConfig): Promise<import('./types.js').GateResult[]>;
|
|
43
|
+
executePRD(title: string, stories: UserStory[]): Promise<PRDDocument>;
|
|
44
|
+
checkKarpathy(context: {
|
|
45
|
+
hypothesesListed: boolean;
|
|
46
|
+
hasExtraFeatures: boolean;
|
|
47
|
+
changesTraceable: boolean;
|
|
48
|
+
hasVerifiableGoal: boolean;
|
|
49
|
+
}): unknown;
|
|
50
|
+
generateDeliveryReport(): string;
|
|
51
|
+
executeSkill(skillId: string, input: Record<string, unknown>): Promise<unknown>;
|
|
52
|
+
executeMCPCapability(toolName: string, input: Record<string, unknown>): Promise<unknown>;
|
|
53
|
+
routeModel(taskType: string): string;
|
|
54
|
+
getGates(): GateSystem;
|
|
55
|
+
getAmbiguityScorer(): AmbiguityScorer;
|
|
56
|
+
getConsensusPlanner(): ConsensusPlanner;
|
|
57
|
+
getSocraticQuestioner(): SocraticQuestioner;
|
|
58
|
+
getRalphEngine(): RalphEngine;
|
|
59
|
+
getUltraworkEngine(): UltraworkEngine;
|
|
60
|
+
getPRDManager(): PRDManager;
|
|
61
|
+
getKarpathyEvaluator(): KarpathyEvaluator;
|
|
62
|
+
}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
// SCALE Engine — Workflow Integration
|
|
2
|
+
// 工作流与 CLI/MCP 的集成层
|
|
3
|
+
import { GateSystem } from './gates/GateSystem.js';
|
|
4
|
+
import { AmbiguityScorer } from './cognitive/AmbiguityScorer.js';
|
|
5
|
+
import { ConsensusPlanner } from './cognitive/ConsensusPlanner.js';
|
|
6
|
+
import { SocraticQuestioner } from './cognitive/SocraticQuestioner.js';
|
|
7
|
+
import { RalphEngine, PRDManager } from './execution/RalphEngine.js';
|
|
8
|
+
import { UltraworkEngine, ModelRouter } from './execution/UltraworkEngine.js';
|
|
9
|
+
import { KarpathyEvaluator } from './quality/KarpathyEvaluator.js';
|
|
10
|
+
export class WorkflowEngine {
|
|
11
|
+
constructor(config) {
|
|
12
|
+
this.eventBus = config.eventBus;
|
|
13
|
+
this.capabilityRegistry = config.capabilityRegistry;
|
|
14
|
+
this.skillRegistry = config.skillRegistry;
|
|
15
|
+
// Initialize workflow modules
|
|
16
|
+
this.gateSystem = new GateSystem(this.eventBus, config.verificationCommands);
|
|
17
|
+
this.ambiguityScorer = new AmbiguityScorer();
|
|
18
|
+
this.consensusPlanner = new ConsensusPlanner(this.eventBus);
|
|
19
|
+
this.socraticQuestioner = new SocraticQuestioner(this.eventBus);
|
|
20
|
+
this.ralphEngine = new RalphEngine(this.eventBus);
|
|
21
|
+
this.ultraworkEngine = new UltraworkEngine(this.eventBus);
|
|
22
|
+
this.prdManager = new PRDManager();
|
|
23
|
+
this.modelRouter = new ModelRouter();
|
|
24
|
+
this.karpathyEvaluator = new KarpathyEvaluator();
|
|
25
|
+
}
|
|
26
|
+
// Phase 1: Exploration with Gate G1
|
|
27
|
+
async explore(requirement) {
|
|
28
|
+
// G1: Exploration gate
|
|
29
|
+
const gateResult = await this.gateSystem.executeGate('G1');
|
|
30
|
+
// Analyze requirement ambiguity
|
|
31
|
+
const ambiguityResult = this.ambiguityScorer.analyzeRequirement(requirement);
|
|
32
|
+
// If ambiguity > 20%, start Socratic session
|
|
33
|
+
let socraticSession = undefined;
|
|
34
|
+
if (ambiguityResult.requiresQuestioning) {
|
|
35
|
+
socraticSession = this.socraticQuestioner.startSession(requirement, ambiguityResult);
|
|
36
|
+
}
|
|
37
|
+
return {
|
|
38
|
+
ambiguityScore: ambiguityResult.totalScore,
|
|
39
|
+
gateResult,
|
|
40
|
+
socraticSession
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
// Continue Socratic refinement session
|
|
44
|
+
refineRequirement(session, questionId, answer) {
|
|
45
|
+
this.socraticQuestioner.recordAnswer(session.sessionId, questionId, answer);
|
|
46
|
+
const progress = this.socraticQuestioner.evaluateProgress(session);
|
|
47
|
+
// If refined, generate refined requirement
|
|
48
|
+
if (progress.refined) {
|
|
49
|
+
const refined = this.socraticQuestioner.generateRefinedRequirement(session);
|
|
50
|
+
session.status = 'refined';
|
|
51
|
+
// Store refined requirement in session
|
|
52
|
+
if (session.finalAmbiguity) {
|
|
53
|
+
session.finalAmbiguity.totalScore = progress.newAmbiguity;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return session;
|
|
57
|
+
}
|
|
58
|
+
// Get next question for refinement
|
|
59
|
+
getNextQuestion(session) {
|
|
60
|
+
return this.socraticQuestioner.askNextQuestion(session);
|
|
61
|
+
}
|
|
62
|
+
// Phase 2: Planning with Consensus
|
|
63
|
+
async plan(requirement) {
|
|
64
|
+
// Run consensus planner
|
|
65
|
+
const consensusResult = await this.consensusPlanner.execute(requirement);
|
|
66
|
+
// G2: Planning gate (if L-level task)
|
|
67
|
+
if (consensusResult.viableOptions.length > 1) {
|
|
68
|
+
await this.gateSystem.executeGate('G2');
|
|
69
|
+
}
|
|
70
|
+
return consensusResult;
|
|
71
|
+
}
|
|
72
|
+
// Phase 3: Build with Task orchestration
|
|
73
|
+
async build(tasks) {
|
|
74
|
+
this.ultraworkEngine.addTasks(tasks);
|
|
75
|
+
return await this.ultraworkEngine.executeParallel();
|
|
76
|
+
}
|
|
77
|
+
// Phase 4: Verify with build and quality gates
|
|
78
|
+
async verify(commandOverrides) {
|
|
79
|
+
if (commandOverrides) {
|
|
80
|
+
this.gateSystem = new GateSystem(this.eventBus, commandOverrides);
|
|
81
|
+
}
|
|
82
|
+
const results = await this.gateSystem.executeAll(['G0', 'G4', 'G5', 'G6', 'G7']);
|
|
83
|
+
return results;
|
|
84
|
+
}
|
|
85
|
+
// Phase 5: PRD-driven execution with Ralph
|
|
86
|
+
async executePRD(title, stories) {
|
|
87
|
+
const prd = this.prdManager.createPRD(title, stories);
|
|
88
|
+
this.ralphEngine.setPRD(prd);
|
|
89
|
+
return await this.ralphEngine.run();
|
|
90
|
+
}
|
|
91
|
+
// Karpathy principles check
|
|
92
|
+
checkKarpathy(context) {
|
|
93
|
+
return this.karpathyEvaluator.evaluateAll(context);
|
|
94
|
+
}
|
|
95
|
+
// Generate honest delivery report
|
|
96
|
+
generateDeliveryReport() {
|
|
97
|
+
return this.ralphEngine.generateDeliveryReport();
|
|
98
|
+
}
|
|
99
|
+
// Execute skill (MCP integration)
|
|
100
|
+
async executeSkill(skillId, input) {
|
|
101
|
+
if (!this.skillRegistry) {
|
|
102
|
+
throw new Error('Skill registry not configured');
|
|
103
|
+
}
|
|
104
|
+
// This would integrate with SkillExecutor
|
|
105
|
+
const skill = this.skillRegistry.get(skillId);
|
|
106
|
+
if (!skill) {
|
|
107
|
+
throw new Error(`Skill not found: ${skillId}`);
|
|
108
|
+
}
|
|
109
|
+
return { skillId, input, status: 'delegated' };
|
|
110
|
+
}
|
|
111
|
+
// Execute MCP capability
|
|
112
|
+
async executeMCPCapability(toolName, input) {
|
|
113
|
+
if (!this.capabilityRegistry) {
|
|
114
|
+
throw new Error('Capability registry not configured');
|
|
115
|
+
}
|
|
116
|
+
// Route to appropriate capability
|
|
117
|
+
if (toolName.includes('browser')) {
|
|
118
|
+
const browser = this.capabilityRegistry.getBrowser();
|
|
119
|
+
if (!browser)
|
|
120
|
+
throw new Error('Browser capability not available');
|
|
121
|
+
return { capability: 'browser', toolName, input };
|
|
122
|
+
}
|
|
123
|
+
if (toolName.includes('search') || toolName.includes('fetch')) {
|
|
124
|
+
const search = this.capabilityRegistry.getSearch();
|
|
125
|
+
if (!search)
|
|
126
|
+
throw new Error('Search capability not available');
|
|
127
|
+
return { capability: 'search', toolName, input };
|
|
128
|
+
}
|
|
129
|
+
if (toolName.includes('exa')) {
|
|
130
|
+
const exa = this.capabilityRegistry.getExa();
|
|
131
|
+
if (!exa)
|
|
132
|
+
throw new Error('Exa capability not available');
|
|
133
|
+
return { capability: 'exa', toolName, input };
|
|
134
|
+
}
|
|
135
|
+
throw new Error(`Unknown MCP tool: ${toolName}`);
|
|
136
|
+
}
|
|
137
|
+
// Model routing for task execution
|
|
138
|
+
routeModel(taskType) {
|
|
139
|
+
return this.modelRouter.route(taskType);
|
|
140
|
+
}
|
|
141
|
+
// Getters for individual modules
|
|
142
|
+
getGates() { return this.gateSystem; }
|
|
143
|
+
getAmbiguityScorer() { return this.ambiguityScorer; }
|
|
144
|
+
getConsensusPlanner() { return this.consensusPlanner; }
|
|
145
|
+
getSocraticQuestioner() { return this.socraticQuestioner; }
|
|
146
|
+
getRalphEngine() { return this.ralphEngine; }
|
|
147
|
+
getUltraworkEngine() { return this.ultraworkEngine; }
|
|
148
|
+
getPRDManager() { return this.prdManager; }
|
|
149
|
+
getKarpathyEvaluator() { return this.karpathyEvaluator; }
|
|
150
|
+
}
|
|
151
|
+
//# sourceMappingURL=WorkflowEngine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WorkflowEngine.js","sourceRoot":"","sources":["../../src/workflow/WorkflowEngine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { AmbiguityScoreResult } from '../types.js';
|
|
2
|
+
export declare class AmbiguityScorer {
|
|
3
|
+
private dimensions;
|
|
4
|
+
private threshold;
|
|
5
|
+
setThreshold(value: number): void;
|
|
6
|
+
setGoalClarity(score: number): void;
|
|
7
|
+
setInputOutputBoundary(score: number): void;
|
|
8
|
+
setTechStackConstraints(score: number): void;
|
|
9
|
+
setTimeConstraints(score: number): void;
|
|
10
|
+
setQualityStandards(score: number): void;
|
|
11
|
+
setRiskBoundaries(score: number): void;
|
|
12
|
+
setAcceptanceCriteria(score: number): void;
|
|
13
|
+
calculate(): AmbiguityScoreResult;
|
|
14
|
+
private calculateWeightedSum;
|
|
15
|
+
analyzeRequirement(requirement: string): AmbiguityScoreResult;
|
|
16
|
+
formatReport(result: AmbiguityScoreResult): string;
|
|
17
|
+
}
|