@hongmaple0820/scale-engine 0.6.0 → 0.7.1

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 (92) hide show
  1. package/README.md +29 -6
  2. package/dist/adapters/ClaudeCodeAdapter.d.ts +1 -1
  3. package/dist/adapters/ClaudeCodeAdapter.js +1 -1
  4. package/dist/adapters/ClaudeCodeAdapter.js.map +1 -1
  5. package/dist/adapters/QCoderAdapter.d.ts +13 -0
  6. package/dist/adapters/QCoderAdapter.js +153 -0
  7. package/dist/adapters/QCoderAdapter.js.map +1 -0
  8. package/dist/adapters/TraeAdapter.d.ts +13 -0
  9. package/dist/adapters/TraeAdapter.js +153 -0
  10. package/dist/adapters/TraeAdapter.js.map +1 -0
  11. package/dist/adapters/VSCAdapter.d.ts +13 -0
  12. package/dist/adapters/VSCAdapter.js +153 -0
  13. package/dist/adapters/VSCAdapter.js.map +1 -0
  14. package/dist/adapters/WorkBuddyAdapter.d.ts +13 -0
  15. package/dist/adapters/WorkBuddyAdapter.js +153 -0
  16. package/dist/adapters/WorkBuddyAdapter.js.map +1 -0
  17. package/dist/adapters/index.d.ts +4 -0
  18. package/dist/adapters/index.js +13 -1
  19. package/dist/adapters/index.js.map +1 -1
  20. package/dist/api/cli.js +59 -3
  21. package/dist/api/cli.js.map +1 -1
  22. package/dist/api/doctor.js +29 -10
  23. package/dist/api/doctor.js.map +1 -1
  24. package/dist/artifact/types.d.ts +3 -3
  25. package/dist/artifact/types.js.map +1 -1
  26. package/dist/context/ContextBuilder.d.ts +4 -0
  27. package/dist/context/ContextBuilder.js +43 -9
  28. package/dist/context/ContextBuilder.js.map +1 -1
  29. package/dist/dashboard/DashboardServer.d.ts +63 -0
  30. package/dist/dashboard/DashboardServer.js +167 -0
  31. package/dist/dashboard/DashboardServer.js.map +1 -0
  32. package/dist/evolution/AutoDefectCreator.d.ts +34 -0
  33. package/dist/evolution/AutoDefectCreator.js +115 -0
  34. package/dist/evolution/AutoDefectCreator.js.map +1 -0
  35. package/dist/evolution/BehaviorTracker.d.ts +8 -0
  36. package/dist/evolution/BehaviorTracker.js +18 -1
  37. package/dist/evolution/BehaviorTracker.js.map +1 -1
  38. package/dist/evolution/EvolutionEvaluator.d.ts +59 -0
  39. package/dist/evolution/EvolutionEvaluator.js +115 -0
  40. package/dist/evolution/EvolutionEvaluator.js.map +1 -0
  41. package/dist/evolution/LessonValidator.d.ts +36 -0
  42. package/dist/evolution/LessonValidator.js +136 -0
  43. package/dist/evolution/LessonValidator.js.map +1 -0
  44. package/dist/fsm/FSMAgentBridge.d.ts +59 -0
  45. package/dist/fsm/FSMAgentBridge.js +195 -0
  46. package/dist/fsm/FSMAgentBridge.js.map +1 -0
  47. package/dist/fsm/index.d.ts +2 -0
  48. package/dist/fsm/index.js +3 -0
  49. package/dist/fsm/index.js.map +1 -0
  50. package/dist/guardrails/DetectorEnhanced.d.ts +111 -0
  51. package/dist/guardrails/DetectorEnhanced.js +200 -0
  52. package/dist/guardrails/DetectorEnhanced.js.map +1 -0
  53. package/dist/hooks/HookDeployer.d.ts +44 -0
  54. package/dist/hooks/HookDeployer.js +145 -0
  55. package/dist/hooks/HookDeployer.js.map +1 -0
  56. package/dist/hooks/HookGeneratorEnhanced.d.ts +67 -0
  57. package/dist/hooks/HookGeneratorEnhanced.js +238 -0
  58. package/dist/hooks/HookGeneratorEnhanced.js.map +1 -0
  59. package/dist/hooks/index.d.ts +4 -0
  60. package/dist/hooks/index.js +4 -0
  61. package/dist/hooks/index.js.map +1 -0
  62. package/dist/index.d.ts +26 -2
  63. package/dist/index.js +21 -5
  64. package/dist/index.js.map +1 -1
  65. package/dist/knowledge/SQLiteKnowledgeBase.js +28 -28
  66. package/dist/skills/SkillDiscovery.js +8 -0
  67. package/dist/skills/SkillDiscovery.js.map +1 -1
  68. package/dist/skills/SkillExecutor.d.ts +28 -0
  69. package/dist/skills/SkillExecutor.js +84 -0
  70. package/dist/skills/SkillExecutor.js.map +1 -0
  71. package/dist/skills/SkillRegistry.d.ts +93 -0
  72. package/dist/skills/SkillRegistry.js +130 -0
  73. package/dist/skills/SkillRegistry.js.map +1 -0
  74. package/dist/skills/TriggerEngine.d.ts +43 -0
  75. package/dist/skills/TriggerEngine.js +144 -0
  76. package/dist/skills/TriggerEngine.js.map +1 -0
  77. package/dist/skills/coreSkills.d.ts +6 -0
  78. package/dist/skills/coreSkills.js +41 -0
  79. package/dist/skills/coreSkills.js.map +1 -0
  80. package/dist/skills/index.d.ts +4 -0
  81. package/dist/skills/index.js +6 -0
  82. package/dist/skills/index.js.map +1 -0
  83. package/dist/workflows/GateParser.d.ts +55 -0
  84. package/dist/workflows/GateParser.js +73 -0
  85. package/dist/workflows/GateParser.js.map +1 -0
  86. package/dist/workflows/WorkflowExecutor.d.ts +56 -0
  87. package/dist/workflows/WorkflowExecutor.js +145 -0
  88. package/dist/workflows/WorkflowExecutor.js.map +1 -0
  89. package/dist/workflows/index.d.ts +4 -0
  90. package/dist/workflows/index.js +5 -0
  91. package/dist/workflows/index.js.map +1 -0
  92. package/package.json +5 -2
@@ -0,0 +1,73 @@
1
+ // SCALE Engine — Gate Parser (v0.7.0)
2
+ // 解析验证门控表达式
3
+ export class GateParser {
4
+ parse(expression) {
5
+ const expr = expression.trim();
6
+ if (expr.includes(" and ") || expr.includes(" or ")) {
7
+ const connector = expr.includes(" and ") ? "and" : "or";
8
+ const parts = expr.split(connector === "and" ? " and " : " or ");
9
+ return { type: "compound", connector, expressions: parts.map(p => this.parse(p)) };
10
+ }
11
+ if (expr.includes(" == ") || expr.includes(" != ")) {
12
+ const op = expr.includes(" == ") ? "==" : "!=";
13
+ const [field, value] = expr.split(" " + op + " ");
14
+ return { type: "status_check", field: field.trim(), operator: op, value: value.trim() };
15
+ }
16
+ const compMatch = expr.match(/([a-zA-Z_]+)\s*(<=|>=|<|>|==)\s*([0-9.]+|[a-zA-Z_]+)/);
17
+ if (compMatch)
18
+ return { type: "comparison", field: compMatch[1], operator: compMatch[2], value: parseFloat(compMatch[3]) || compMatch[3] };
19
+ if (expr.includes(" pass") || expr.includes(" fails")) {
20
+ const cmd = expr.replace(" pass", "").replace(" fails", "").trim();
21
+ return { type: "command_check", command: cmd };
22
+ }
23
+ if (expr.includes("approval") || expr.includes("human"))
24
+ return { type: "approval_check" };
25
+ return { type: "comparison", field: "unknown", operator: "==", value: "true" };
26
+ }
27
+ async evaluate(expr, ctx) {
28
+ if (expr.type === "comparison")
29
+ return this.evalComparison(expr, ctx);
30
+ if (expr.type === "status_check")
31
+ return this.evalStatus(expr, ctx);
32
+ if (expr.type === "command_check")
33
+ return this.evalCommand(expr, ctx);
34
+ if (expr.type === "approval_check")
35
+ return { passed: false, expression: "human approval", evaluated: expr, reason: "Requires human approval" };
36
+ if (expr.type === "compound")
37
+ return this.evalCompound(expr, ctx);
38
+ return { passed: false, expression: "", evaluated: expr, reason: "Unknown type" };
39
+ }
40
+ async evaluateString(expr, ctx) {
41
+ return this.evaluate(this.parse(expr), ctx);
42
+ }
43
+ evalComparison(expr, ctx) {
44
+ if (!ctx.artifact)
45
+ return { passed: false, expression: "", evaluated: expr, reason: "No artifact" };
46
+ const payload = ctx.artifact.payload;
47
+ const fieldValue = payload[expr.field ?? ""] ?? ctx.artifact[expr.field];
48
+ const target = expr.value;
49
+ const passed = expr.operator === "<=" ? fieldValue <= target : expr.operator === "<" ? fieldValue < target : fieldValue === target;
50
+ return { passed, expression: expr.field + " " + expr.operator + " " + expr.value, evaluated: expr, reason: passed ? "OK" : "Failed" };
51
+ }
52
+ evalStatus(expr, ctx) {
53
+ if (!ctx.artifact)
54
+ return { passed: false, expression: "", evaluated: expr, reason: "No artifact" };
55
+ const status = ctx.artifact.status;
56
+ const passed = expr.operator === "==" ? status === expr.value : status !== expr.value;
57
+ return { passed, expression: expr.field + " " + expr.operator + " " + expr.value, evaluated: expr, reason: passed ? "OK" : "Mismatch" };
58
+ }
59
+ async evalCommand(expr, ctx) {
60
+ if (!ctx.runCommand)
61
+ return { passed: false, expression: expr.command ?? "", evaluated: expr, reason: "No runner" };
62
+ const result = await ctx.runCommand(expr.command ?? "");
63
+ return { passed: result.success, expression: expr.command + " pass", evaluated: expr, reason: result.success ? "OK" : result.output };
64
+ }
65
+ async evalCompound(expr, ctx) {
66
+ if (!expr.expressions)
67
+ return { passed: false, expression: "", evaluated: expr, reason: "No sub-expr" };
68
+ const results = await Promise.all(expr.expressions.map(e => this.evaluate(e, ctx)));
69
+ const passed = expr.connector === "and" ? results.every(r => r.passed) : results.some(r => r.passed);
70
+ return { passed, expression: expr.connector ?? "and", evaluated: expr, reason: passed ? "All OK" : "Some failed" };
71
+ }
72
+ }
73
+ //# sourceMappingURL=GateParser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GateParser.js","sourceRoot":"","sources":["../../src/workflows/GateParser.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,56 @@
1
+ import type { WorkflowPreset } from "../artifact/types.js";
2
+ import type { IEventBus } from "../core/eventBus.js";
3
+ import type { IArtifactStore } from "../artifact/store.js";
4
+ import { GateResult } from "./GateParser.js";
5
+ export interface WorkflowSession {
6
+ id: string;
7
+ presetId: string;
8
+ presetName: string;
9
+ currentStep: number;
10
+ totalSteps: number;
11
+ status: "running" | "paused" | "completed" | "failed" | "blocked";
12
+ blockingReason?: string;
13
+ verifiedSteps: number[];
14
+ stepHistory: StepHistoryEntry[];
15
+ startedAt: number;
16
+ pausedAt?: number;
17
+ completedAt?: number;
18
+ context: Record<string, unknown>;
19
+ }
20
+ export interface StepHistoryEntry {
21
+ stepId: string;
22
+ stepIndex: number;
23
+ action: string;
24
+ status: "pending" | "running" | "verified" | "failed" | "skipped";
25
+ startedAt: number;
26
+ completedAt?: number;
27
+ output?: unknown;
28
+ error?: string;
29
+ gateResult?: GateResult;
30
+ }
31
+ export interface IWorkflowExecutor {
32
+ start(preset: WorkflowPreset, context: Record<string, unknown>): Promise<WorkflowSession>;
33
+ getStatus(sessionId: string): Promise<WorkflowSession | null>;
34
+ pause(sessionId: string, reason?: string): Promise<void>;
35
+ resume(sessionId: string): Promise<void>;
36
+ executeStep(sessionId: string, stepIndex?: number): Promise<StepHistoryEntry>;
37
+ runAll(sessionId: string): Promise<WorkflowSession>;
38
+ getHistory(sessionId: string): Promise<StepHistoryEntry[]>;
39
+ }
40
+ export declare class WorkflowExecutor implements IWorkflowExecutor {
41
+ private sessions;
42
+ private gateParser;
43
+ private eventBus;
44
+ private store;
45
+ constructor(eventBus: IEventBus, store: IArtifactStore);
46
+ start(preset: WorkflowPreset, context: Record<string, unknown>): Promise<WorkflowSession>;
47
+ getStatus(sessionId: string): Promise<WorkflowSession | null>;
48
+ pause(sessionId: string, reason?: string): Promise<void>;
49
+ resume(sessionId: string): Promise<void>;
50
+ executeStep(sessionId: string, stepIndex?: number): Promise<StepHistoryEntry>;
51
+ runAll(sessionId: string): Promise<WorkflowSession>;
52
+ getHistory(sessionId: string): Promise<StepHistoryEntry[]>;
53
+ private executeAction;
54
+ private getPresetStep;
55
+ private getRelatedArtifact;
56
+ }
@@ -0,0 +1,145 @@
1
+ // SCALE Engine — Workflow Executor (v0.7.0)
2
+ // 工作流执行器:执行预设工作流步骤
3
+ import { GateParser } from "./GateParser.js";
4
+ import { logger } from "../core/logger.js";
5
+ export class WorkflowExecutor {
6
+ sessions = new Map();
7
+ gateParser = new GateParser();
8
+ eventBus;
9
+ store;
10
+ constructor(eventBus, store) {
11
+ this.eventBus = eventBus;
12
+ this.store = store;
13
+ }
14
+ async start(preset, context) {
15
+ const session = {
16
+ id: `WF-${Date.now()}`,
17
+ presetId: preset.id,
18
+ presetName: preset.name,
19
+ currentStep: 0,
20
+ totalSteps: preset.steps.length,
21
+ status: "running",
22
+ verifiedSteps: [],
23
+ stepHistory: preset.steps.map((s, i) => ({
24
+ stepId: s.stepId, stepIndex: i, action: s.action, status: "pending", startedAt: 0
25
+ })),
26
+ startedAt: Date.now(),
27
+ context,
28
+ };
29
+ this.sessions.set(session.id, session);
30
+ this.eventBus.emit("workflow.started", { sessionId: session.id, presetId: preset.id });
31
+ logger.info({ sessionId: session.id, presetId: preset.id }, "Workflow started");
32
+ return session;
33
+ }
34
+ async getStatus(sessionId) {
35
+ return this.sessions.get(sessionId) ?? null;
36
+ }
37
+ async pause(sessionId, reason) {
38
+ const session = this.sessions.get(sessionId);
39
+ if (!session)
40
+ return;
41
+ session.status = "paused";
42
+ session.pausedAt = Date.now();
43
+ session.blockingReason = reason;
44
+ this.eventBus.emit("workflow.paused", { sessionId, reason });
45
+ logger.info({ sessionId, reason }, "Workflow paused");
46
+ }
47
+ async resume(sessionId) {
48
+ const session = this.sessions.get(sessionId);
49
+ if (!session || session.status !== "paused")
50
+ return;
51
+ session.status = "running";
52
+ session.pausedAt = undefined;
53
+ session.blockingReason = undefined;
54
+ this.eventBus.emit("workflow.resumed", { sessionId });
55
+ logger.info({ sessionId }, "Workflow resumed");
56
+ }
57
+ async executeStep(sessionId, stepIndex) {
58
+ const session = this.sessions.get(sessionId);
59
+ if (!session)
60
+ throw new Error("Session not found");
61
+ if (session.status === "paused")
62
+ throw new Error("Session is paused");
63
+ const idx = stepIndex ?? session.currentStep;
64
+ const step = session.stepHistory[idx];
65
+ if (!step)
66
+ throw new Error("Step not found");
67
+ step.status = "running";
68
+ step.startedAt = Date.now();
69
+ try {
70
+ // 执行动作(模拟)
71
+ step.output = await this.executeAction(session.context, step.action);
72
+ // 验证门控
73
+ const presetStep = this.getPresetStep(session.presetId, idx);
74
+ if (presetStep?.verificationGate) {
75
+ const gateResult = await this.gateParser.evaluateString(presetStep.verificationGate, {
76
+ artifact: await this.getRelatedArtifact(session.context),
77
+ runCommand: async (_cmd) => ({ success: true, output: "" })
78
+ });
79
+ step.gateResult = gateResult;
80
+ if (!gateResult.passed) {
81
+ step.status = "failed";
82
+ step.error = gateResult.reason;
83
+ session.status = "blocked";
84
+ session.blockingReason = gateResult.reason;
85
+ return step;
86
+ }
87
+ }
88
+ step.status = "verified";
89
+ step.completedAt = Date.now();
90
+ session.verifiedSteps.push(idx);
91
+ session.currentStep = idx + 1;
92
+ if (session.currentStep >= session.totalSteps) {
93
+ session.status = "completed";
94
+ session.completedAt = Date.now();
95
+ this.eventBus.emit("workflow.completed", { sessionId });
96
+ }
97
+ return step;
98
+ }
99
+ catch (err) {
100
+ step.status = "failed";
101
+ step.error = String(err);
102
+ step.completedAt = Date.now();
103
+ session.status = "failed";
104
+ throw err;
105
+ }
106
+ }
107
+ async runAll(sessionId) {
108
+ const session = this.sessions.get(sessionId);
109
+ if (!session)
110
+ throw new Error("Session not found");
111
+ for (let i = 0; i < session.totalSteps; i++) {
112
+ if (session.status === "blocked" || session.status === "failed")
113
+ break;
114
+ await this.executeStep(sessionId, i);
115
+ }
116
+ return session;
117
+ }
118
+ async getHistory(sessionId) {
119
+ const session = this.sessions.get(sessionId);
120
+ return session?.stepHistory ?? [];
121
+ }
122
+ async executeAction(_context, action) {
123
+ // 模拟执行,实际由 Agent 或 CLI 处理
124
+ if (action.startsWith("scale "))
125
+ return { command: action, executed: true };
126
+ return { action, result: "simulated" };
127
+ }
128
+ getPresetStep(presetId, stepIndex) {
129
+ // 从 presets.ts 导入的预设中获取 - 简化版本
130
+ const presets = {
131
+ "basic-dev": [{ stepId: "explore", action: "explore", isMandatory: true }],
132
+ "tdd-dev": [{ stepId: "explore", action: "explore", isMandatory: true }],
133
+ "bug-fix": [{ stepId: "reproduce", action: "reproduce", isMandatory: true }],
134
+ };
135
+ return presets[presetId]?.[stepIndex];
136
+ }
137
+ async getRelatedArtifact(context) {
138
+ const artifactId = context.artifactId;
139
+ if (!artifactId)
140
+ return undefined;
141
+ const artifact = await this.store.get(artifactId);
142
+ return artifact ?? undefined;
143
+ }
144
+ }
145
+ //# sourceMappingURL=WorkflowExecutor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WorkflowExecutor.js","sourceRoot":"","sources":["../../src/workflows/WorkflowExecutor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export { WORKFLOW_PRESETS, getWorkflowPreset, listWorkflowPresets, getPresetsByScenario } from "./presets.js";
2
+ export type { WorkflowPreset, ScenarioMode, WorkflowStep } from "../artifact/types.js";
3
+ export { WorkflowExecutor, type IWorkflowExecutor, type WorkflowSession, type StepHistoryEntry } from "./WorkflowExecutor.js";
4
+ export { GateParser, type IGateParser, type GateExpression, type GateResult } from "./GateParser.js";
@@ -0,0 +1,5 @@
1
+ // SCALE Engine — Workflows Module Index (v0.7.0)
2
+ export { WORKFLOW_PRESETS, getWorkflowPreset, listWorkflowPresets, getPresetsByScenario } from "./presets.js";
3
+ export { WorkflowExecutor } from "./WorkflowExecutor.js";
4
+ export { GateParser } from "./GateParser.js";
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/workflows/index.ts"],"names":[],"mappings":"AAAA,iDAAiD;AAEjD,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAA;AAE7G,OAAO,EAAE,gBAAgB,EAAuE,MAAM,uBAAuB,CAAA;AAC7H,OAAO,EAAE,UAAU,EAA0D,MAAM,iBAAiB,CAAA"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@hongmaple0820/scale-engine",
3
- "version": "0.6.0",
4
- "description": "SCALE Engine v0.6.0 — AI engineering scaffold: 7 agent adapters, 11 artifacts FSM, 9 guardrail detectors, SQLite knowledge base, skill ecosystem, 10 workflow presets, 4-level self-evolution",
3
+ "version": "0.7.1",
4
+ "description": "SCALE Engine v0.7.1 — AI engineering scaffold: SessionStart FSM context injection, AutoDefectCreator for self-evolution loop, enhanced memory recall, 11 agent adapters, FSM artifacts, guardrail detectors",
5
5
  "type": "module",
6
6
  "bin": {
7
7
  "scale": "./dist/api/cli.js"
@@ -17,6 +17,9 @@
17
17
  "files": [
18
18
  "dist"
19
19
  ],
20
+ "publishConfig": {
21
+ "access": "public"
22
+ },
20
23
  "scripts": {
21
24
  "build": "tsc",
22
25
  "dev": "bun --watch src/api/cli.ts",