bemadralphy 0.2.0 → 0.3.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.
@@ -1,11 +1,25 @@
1
1
  import { access, mkdir, writeFile } from 'node:fs/promises';
2
2
  import path from 'node:path';
3
3
  import { CostTracker } from './cost.js';
4
+ import { estimateRunCost } from './cost.js';
5
+ import { loadRunConfig } from './config.js';
6
+ import { appendRunHistory, findRunHistory, readRunHistory } from './history.js';
7
+ import { loadPlugins, runPhaseHooks } from './plugins/index.js';
4
8
  import { executePhase, explorePhase, intakePhase, planningPhase, postPhase, scaffoldPhase, steeringPhase, syncPhase, verifyPhase, } from './phases/index.js';
5
9
  import { loadState, saveState } from './state.js';
6
10
  import { generateSpecs } from './specs/index.js';
7
11
  import { assertCommandExists, runCommand } from './utils/exec.js';
8
- import { logInfo } from './utils/logging.js';
12
+ import { configureLogger, logError, logInfo, logProgress, logSummary, } from './utils/logging.js';
13
+ const PHASES = [
14
+ { name: 'intake', run: intakePhase },
15
+ { name: 'planning', run: planningPhase },
16
+ { name: 'steering', run: steeringPhase },
17
+ { name: 'scaffold', run: scaffoldPhase },
18
+ { name: 'sync', run: syncPhase },
19
+ { name: 'execute', run: executePhase },
20
+ { name: 'verify', run: verifyPhase },
21
+ { name: 'post', run: postPhase },
22
+ ];
9
23
  export async function runInit(projectRoot = process.cwd()) {
10
24
  const bemadDir = path.join(projectRoot, '.bemadralphy');
11
25
  const openspecDir = path.join(projectRoot, 'openspec');
@@ -41,72 +55,267 @@ export async function runInit(projectRoot = process.cwd()) {
41
55
  logInfo('init: completed scaffold of .bemadralphy, openspec/, and _bmad-output/');
42
56
  }
43
57
  export async function runPipeline(options) {
44
- const projectRoot = options.projectRoot ?? process.cwd();
45
- const executionProfile = normalizeExecutionProfile(options.executionProfile);
46
- const audienceProfile = normalizeAudienceProfile(options.audienceProfile);
58
+ const normalized = await resolveRunOptions(options);
59
+ configureLogger({ outputFormat: normalized.output });
60
+ const runId = new Date().toISOString();
61
+ configureLogger({ outputFormat: normalized.output, runId });
62
+ logProgress('run', 'start', 'run started', {
63
+ mode: normalized.mode,
64
+ engine: normalized.engine ?? 'ralphy',
65
+ output: normalized.output,
66
+ });
67
+ const pluginRuntime = await loadPlugins(normalized.projectRoot, normalized.plugins);
68
+ const estimate = await estimateRunCost(normalized.projectRoot, normalized.maxParallel);
69
+ const persistedState = normalized.resume ? await loadState(normalized.projectRoot) : null;
70
+ const startPhase = resolveStartPhase(normalized, persistedState);
71
+ const startIndex = PHASES.findIndex((phase) => phase.name === startPhase);
72
+ if (startIndex < 0) {
73
+ throw new Error(`run: unknown start phase "${startPhase}"`);
74
+ }
75
+ if (typeof normalized.budget === 'number' && estimate.minUsd > normalized.budget) {
76
+ throw new Error(`run: budget too low for estimate (budget=${normalized.budget.toFixed(2)} min_estimate=${estimate.minUsd.toFixed(2)})`);
77
+ }
78
+ const plannedPhases = PHASES.slice(startIndex).map((phase) => phase.name);
79
+ if (normalized.dryRun) {
80
+ logSummary({
81
+ dryRun: true,
82
+ plannedPhases,
83
+ taskCount: estimate.taskCount,
84
+ estimatedUsd: estimate.estimatedUsd,
85
+ estimateRange: [estimate.minUsd, estimate.maxUsd],
86
+ resumeTarget: startPhase,
87
+ heuristic: estimate.heuristic,
88
+ });
89
+ logInfo('run: dry-run complete');
90
+ return;
91
+ }
92
+ await appendRunHistory(normalized.projectRoot, {
93
+ runId,
94
+ startedAt: runId,
95
+ status: 'running',
96
+ mode: normalized.mode,
97
+ engine: normalized.engine,
98
+ output: normalized.output,
99
+ phase: startPhase,
100
+ options: {
101
+ mode: normalized.mode,
102
+ engine: normalized.engine,
103
+ planningEngine: normalized.planningEngine,
104
+ maxParallel: normalized.maxParallel,
105
+ executionProfile: normalized.executionProfile,
106
+ audienceProfile: normalized.audienceProfile,
107
+ budget: normalized.budget,
108
+ brownfield: normalized.brownfield,
109
+ swarm: normalized.swarm,
110
+ createPr: normalized.createPr,
111
+ plugins: normalized.plugins,
112
+ },
113
+ resumeFromPhase: startPhase,
114
+ });
47
115
  const context = {
48
- runId: new Date().toISOString(),
49
- mode: options.mode,
50
- dryRun: options.dryRun,
51
- projectRoot,
52
- engine: options.engine,
53
- planningEngine: options.planningEngine,
54
- maxParallel: options.maxParallel,
55
- executionProfile,
56
- audienceProfile,
57
- budget: options.budget,
58
- brownfield: options.brownfield,
59
- swarm: options.swarm,
60
- createPr: options.createPr,
116
+ runId,
117
+ mode: normalized.mode,
118
+ dryRun: normalized.dryRun,
119
+ projectRoot: normalized.projectRoot,
120
+ engine: normalized.engine,
121
+ planningEngine: normalized.planningEngine,
122
+ maxParallel: normalized.maxParallel,
123
+ executionProfile: normalized.executionProfile,
124
+ audienceProfile: normalized.audienceProfile,
125
+ budget: normalized.budget,
126
+ brownfield: normalized.brownfield,
127
+ swarm: normalized.swarm,
128
+ createPr: normalized.createPr,
129
+ output: normalized.output,
130
+ resume: normalized.resume,
131
+ fromPhase: normalized.fromPhase,
61
132
  };
62
- logInfo(`run: starting pipeline (mode=${options.mode})`);
63
133
  const cost = new CostTracker();
64
- let ctx = await intakePhase(context);
65
- await saveState(ctx.projectRoot, stateFrom(ctx, 'intake'));
66
- ctx = await planningPhase(ctx);
67
- await saveState(ctx.projectRoot, stateFrom(ctx, 'planning'));
68
- ctx = await steeringPhase(ctx);
69
- await saveState(ctx.projectRoot, stateFrom(ctx, 'steering'));
70
- ctx = await scaffoldPhase(ctx);
71
- await saveState(ctx.projectRoot, stateFrom(ctx, 'scaffold'));
72
- ctx = await syncPhase(ctx);
73
- await saveState(ctx.projectRoot, stateFrom(ctx, 'sync'));
74
- ctx = await executePhase(ctx);
75
- await saveState(ctx.projectRoot, stateFrom(ctx, 'execute'));
76
- ctx = await verifyPhase(ctx);
77
- await saveState(ctx.projectRoot, stateFrom(ctx, 'verify'));
78
- ctx = await postPhase(ctx);
79
- await saveState(ctx.projectRoot, stateFrom(ctx, 'post'));
134
+ let ctx = context;
135
+ for (const phase of PHASES.slice(startIndex)) {
136
+ try {
137
+ logProgress('phase', 'start', `${phase.name} phase started`, { phase: phase.name });
138
+ await runPhaseHooks(pluginRuntime.beforeHooks, phase.name, ctx);
139
+ ctx = await phase.run(ctx);
140
+ await runPhaseHooks(pluginRuntime.afterHooks, phase.name, ctx);
141
+ await saveState(ctx.projectRoot, stateFrom(ctx, phase.name, 'running'));
142
+ logProgress('phase', 'done', `${phase.name} phase completed`, { phase: phase.name });
143
+ }
144
+ catch (error) {
145
+ const message = error.message;
146
+ logError(`run: phase "${phase.name}" failed`, { phase: phase.name, error: message });
147
+ await saveState(ctx.projectRoot, stateFrom(ctx, phase.name, 'failed', message));
148
+ await appendFailure(ctx.projectRoot, runId, phase.name, message);
149
+ await appendRunHistory(ctx.projectRoot, {
150
+ runId,
151
+ startedAt: runId,
152
+ finishedAt: new Date().toISOString(),
153
+ status: 'failed',
154
+ mode: ctx.mode,
155
+ engine: ctx.engine,
156
+ output: ctx.output,
157
+ phase: phase.name,
158
+ resumeFromPhase: phase.name,
159
+ options: {
160
+ mode: normalized.mode,
161
+ engine: normalized.engine,
162
+ planningEngine: normalized.planningEngine,
163
+ maxParallel: normalized.maxParallel,
164
+ executionProfile: normalized.executionProfile,
165
+ audienceProfile: normalized.audienceProfile,
166
+ budget: normalized.budget,
167
+ brownfield: normalized.brownfield,
168
+ swarm: normalized.swarm,
169
+ createPr: normalized.createPr,
170
+ plugins: normalized.plugins,
171
+ },
172
+ error: message,
173
+ });
174
+ logProgress('phase', 'failed', `${phase.name} phase failed`, {
175
+ phase: phase.name,
176
+ error: message,
177
+ });
178
+ throw error;
179
+ }
180
+ }
80
181
  await cost.persist(ctx.projectRoot);
182
+ await saveState(ctx.projectRoot, stateFrom(ctx, 'post', 'completed'));
183
+ await appendRunHistory(ctx.projectRoot, {
184
+ runId,
185
+ startedAt: runId,
186
+ finishedAt: new Date().toISOString(),
187
+ status: 'completed',
188
+ mode: ctx.mode,
189
+ engine: ctx.engine,
190
+ output: ctx.output,
191
+ phase: 'post',
192
+ options: {
193
+ mode: normalized.mode,
194
+ engine: normalized.engine,
195
+ planningEngine: normalized.planningEngine,
196
+ maxParallel: normalized.maxParallel,
197
+ executionProfile: normalized.executionProfile,
198
+ audienceProfile: normalized.audienceProfile,
199
+ budget: normalized.budget,
200
+ brownfield: normalized.brownfield,
201
+ swarm: normalized.swarm,
202
+ createPr: normalized.createPr,
203
+ plugins: normalized.plugins,
204
+ },
205
+ });
206
+ logSummary({
207
+ runId: ctx.runId,
208
+ status: 'completed',
209
+ phase: 'post',
210
+ estimatedUsd: estimate.estimatedUsd,
211
+ taskCount: estimate.taskCount,
212
+ });
81
213
  logInfo(`run: completed pipeline (runId=${ctx.runId})`);
82
214
  }
83
215
  export async function runExplore(query) {
84
216
  await explorePhase(query);
85
217
  }
86
- export async function runStatus() {
218
+ export async function runStatus(output = 'text') {
219
+ configureLogger({ outputFormat: output });
87
220
  const projectRoot = process.cwd();
88
221
  const state = await loadState(projectRoot);
89
222
  if (!state) {
90
223
  logInfo('status: no state found (.bemadralphy/state.yaml missing)');
91
224
  return;
92
225
  }
93
- logInfo(`status: phase=${state.phase} mode=${state.mode} engine=${state.engine ?? 'n/a'}`);
226
+ if (output === 'json') {
227
+ logSummary({ status: 'ok', state });
228
+ return;
229
+ }
230
+ logInfo(`status: phase=${state.phase} status=${state.status ?? 'n/a'} mode=${state.mode} engine=${state.engine ?? 'n/a'}`);
231
+ }
232
+ export async function runHistory(output = 'text') {
233
+ configureLogger({ outputFormat: output });
234
+ const records = await readRunHistory(process.cwd());
235
+ if (output === 'json') {
236
+ logSummary({ runs: records });
237
+ return;
238
+ }
239
+ if (records.length === 0) {
240
+ logInfo('history: no runs found');
241
+ return;
242
+ }
243
+ for (const row of records) {
244
+ logInfo(`history: runId=${row.runId} status=${row.status} phase=${row.phase ?? 'n/a'} mode=${row.mode}`);
245
+ }
246
+ }
247
+ export async function runReplay(runId, options = {}) {
248
+ const projectRoot = options.projectRoot ?? process.cwd();
249
+ const record = await findRunHistory(projectRoot, runId);
250
+ if (!record) {
251
+ throw new Error(`replay: run "${runId}" not found`);
252
+ }
253
+ const replayPhaseCandidate = options.fromPhase ?? record.resumeFromPhase ?? record.phase;
254
+ const replayOptions = {
255
+ ...(record.options ?? {}),
256
+ ...options,
257
+ projectRoot,
258
+ resume: true,
259
+ fromPhase: replayPhaseCandidate && isPipelinePhase(replayPhaseCandidate)
260
+ ? replayPhaseCandidate
261
+ : undefined,
262
+ };
263
+ await runPipeline(replayOptions);
94
264
  }
95
- function stateFrom(ctx, phase) {
265
+ function stateFrom(ctx, phase, status, lastError) {
266
+ const phaseIndex = PHASES.findIndex((entry) => entry.name === phase);
267
+ const nextPhase = phaseIndex >= 0 ? PHASES[phaseIndex + 1]?.name : undefined;
268
+ const resumeFromPhase = status === 'completed' ? undefined : status === 'failed' ? phase : nextPhase;
96
269
  return {
97
270
  phase,
271
+ status,
272
+ lastCompletedPhase: status === 'failed' ? undefined : phase,
273
+ failedPhase: status === 'failed' ? phase : undefined,
274
+ resumeFromPhase,
275
+ lastError,
98
276
  mode: ctx.mode,
99
277
  engine: ctx.engine,
100
278
  executionProfile: ctx.executionProfile,
101
279
  audienceProfile: ctx.audienceProfile,
102
280
  startedAt: ctx.runId,
281
+ updatedAt: new Date().toISOString(),
282
+ finishedAt: status === 'completed' ? new Date().toISOString() : undefined,
283
+ runId: ctx.runId,
284
+ };
285
+ }
286
+ async function resolveRunOptions(options) {
287
+ const projectRoot = options.projectRoot ?? process.cwd();
288
+ const config = await loadRunConfig(projectRoot);
289
+ return {
290
+ mode: normalizeMode(options.mode ?? config.mode),
291
+ engine: options.engine ?? config.engine,
292
+ planningEngine: options.planningEngine ?? config.planningEngine,
293
+ maxParallel: normalizeMaxParallel(options.maxParallel ?? config.maxParallel),
294
+ executionProfile: normalizeExecutionProfile(options.executionProfile ?? config.executionProfile),
295
+ audienceProfile: normalizeAudienceProfile(options.audienceProfile ?? config.audienceProfile),
296
+ budget: normalizeBudget(options.budget ?? config.budget),
297
+ brownfield: options.brownfield ?? config.brownfield ?? false,
298
+ swarm: options.swarm ?? config.swarm,
299
+ createPr: options.createPr ?? config.createPr ?? false,
300
+ dryRun: options.dryRun ?? false,
301
+ resume: options.resume ?? false,
302
+ fromPhase: options.fromPhase,
303
+ output: normalizeOutput(options.output ?? config.output),
304
+ plugins: normalizePlugins(options.plugins ?? config.plugins),
305
+ projectRoot,
103
306
  };
104
307
  }
308
+ function normalizeMode(value) {
309
+ if (value === 'auto' || value === 'hybrid' || value === 'supervised') {
310
+ return value;
311
+ }
312
+ return 'hybrid';
313
+ }
105
314
  function normalizeExecutionProfile(value) {
106
315
  if (value === 'safe' || value === 'balanced' || value === 'fast') {
107
316
  return value;
108
317
  }
109
- return 'balanced';
318
+ return undefined;
110
319
  }
111
320
  function normalizeAudienceProfile(value) {
112
321
  if (value === 'solo-dev' ||
@@ -117,4 +326,52 @@ function normalizeAudienceProfile(value) {
117
326
  }
118
327
  return undefined;
119
328
  }
329
+ function normalizeMaxParallel(value) {
330
+ if (typeof value === 'number' && Number.isFinite(value) && value > 0) {
331
+ return Math.floor(value);
332
+ }
333
+ return 3;
334
+ }
335
+ function normalizeBudget(value) {
336
+ if (typeof value === 'number' && Number.isFinite(value) && value >= 0) {
337
+ return value;
338
+ }
339
+ return undefined;
340
+ }
341
+ function normalizeOutput(value) {
342
+ if (value === 'json') {
343
+ return 'json';
344
+ }
345
+ return 'text';
346
+ }
347
+ function normalizePlugins(value) {
348
+ if (!value) {
349
+ return [];
350
+ }
351
+ return value.filter((entry) => typeof entry === 'string' && entry.trim().length > 0);
352
+ }
353
+ function resolveStartPhase(options, state) {
354
+ if (options.fromPhase && isPipelinePhase(options.fromPhase)) {
355
+ return options.fromPhase;
356
+ }
357
+ if (options.resume && state?.failedPhase && isPipelinePhase(state.failedPhase)) {
358
+ return state.failedPhase;
359
+ }
360
+ if (options.resume && state?.resumeFromPhase && isPipelinePhase(state.resumeFromPhase)) {
361
+ return state.resumeFromPhase;
362
+ }
363
+ if (options.resume && state?.lastCompletedPhase && isPipelinePhase(state.lastCompletedPhase)) {
364
+ const index = PHASES.findIndex((phase) => phase.name === state.lastCompletedPhase);
365
+ return PHASES[index + 1]?.name ?? 'post';
366
+ }
367
+ return 'intake';
368
+ }
369
+ function isPipelinePhase(value) {
370
+ return PHASES.some((phase) => phase.name === value);
371
+ }
372
+ async function appendFailure(projectRoot, runId, phase, message) {
373
+ const failuresPath = path.join(projectRoot, '.bemadralphy', 'failures.log');
374
+ await mkdir(path.dirname(failuresPath), { recursive: true });
375
+ await writeFile(failuresPath, `${new Date().toISOString()} runId=${runId} phase=${phase} error=${message}\n`, { encoding: 'utf-8', flag: 'a' });
376
+ }
120
377
  //# sourceMappingURL=orchestrator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../src/orchestrator.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../src/orchestrator.ts"],"names":[],"mappings":"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"}
@@ -5,11 +5,13 @@ import { resolveExecutionPolicy } from '../swarm/detector.js';
5
5
  import { runKimiParlBatch } from '../swarm/kimi-parl.js';
6
6
  import { BeadsWriter } from '../beads/writer.js';
7
7
  import { assertCommandExists, runCommand } from '../utils/exec.js';
8
- import { logInfo } from '../utils/logging.js';
8
+ import { logInfo, logProgress } from '../utils/logging.js';
9
9
  export async function executePhase(ctx) {
10
10
  logInfo('Phase 6 (execute): swarm-aware task execution');
11
+ logProgress('phase', 'start', 'execute phase started');
11
12
  if (ctx.dryRun) {
12
13
  logInfo('execute: dry-run, skipping');
14
+ logProgress('phase', 'done', 'execute phase skipped due to dry run');
13
15
  return ctx;
14
16
  }
15
17
  const engineName = ctx.engine ?? 'ralphy';
@@ -42,6 +44,7 @@ export async function executePhase(ctx) {
42
44
  else {
43
45
  await runBdReadyLoop(ctx, adapter);
44
46
  }
47
+ logProgress('phase', 'done', 'execute phase completed');
45
48
  return ctx;
46
49
  }
47
50
  async function runBdReadyLoop(ctx, adapter) {
@@ -60,17 +63,32 @@ async function runBdReadyLoop(ctx, adapter) {
60
63
  logInfo('execute: no ready tasks');
61
64
  return;
62
65
  }
66
+ let completedCount = 0;
63
67
  for (const id of ids) {
64
- const result = await adapter.execute({ id, title: id }, { cwd: ctx.projectRoot });
68
+ logProgress('task', 'start', `execute: task ${id} started`, { taskId: id });
69
+ const result = await adapter.execute({ id, title: id }, { cwd: ctx.projectRoot, dryRun: ctx.dryRun });
65
70
  if (result.status === 'success') {
66
71
  await writer.close(id);
72
+ logProgress('task', 'done', `execute: task ${id} completed`, { taskId: id });
67
73
  }
68
74
  else if (result.status === 'failed') {
69
75
  await writer.update(id, result.error ?? 'task failed');
76
+ logProgress('task', 'failed', `execute: task ${id} failed`, {
77
+ taskId: id,
78
+ error: result.error ?? 'task failed',
79
+ });
70
80
  }
71
81
  else {
72
82
  await writer.update(id, result.output ?? 'task skipped');
73
83
  logInfo(`execute: task ${id} skipped`);
84
+ logProgress('task', 'progress', `execute: task ${id} skipped`, { taskId: id });
85
+ }
86
+ completedCount += 1;
87
+ if (typeof ctx.budget === 'number') {
88
+ const estimatedSpent = Number((completedCount * 0.07).toFixed(4));
89
+ if (estimatedSpent > ctx.budget) {
90
+ throw new Error(`execute: estimated budget exceeded (${estimatedSpent.toFixed(2)} > ${ctx.budget.toFixed(2)})`);
91
+ }
74
92
  }
75
93
  }
76
94
  }
@@ -1 +1 @@
1
- {"version":3,"file":"execute.js","sourceRoot":"","sources":["../../src/phases/execute.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"execute.js","sourceRoot":"","sources":["../../src/phases/execute.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,4 @@
1
+ import type { OutputFormat } from '../utils/logging.js';
1
2
  export type PipelineMode = 'auto' | 'hybrid' | 'supervised';
2
3
  export type ExecutionProfile = 'safe' | 'balanced' | 'fast';
3
4
  export type AudienceProfile = 'solo-dev' | 'agency-team' | 'product-team' | 'enterprise-team';
@@ -23,4 +24,7 @@ export type PipelineContext = {
23
24
  brownfield?: boolean;
24
25
  swarm?: 'native' | 'process' | 'off';
25
26
  createPr?: boolean;
27
+ output?: OutputFormat;
28
+ resume?: boolean;
29
+ fromPhase?: string;
26
30
  };
@@ -0,0 +1,10 @@
1
+ import type { PipelineContext } from '../phases/types.js';
2
+ import type { PhaseHook, PhaseName } from './types.js';
3
+ type HookRegistry = Record<PhaseName, PhaseHook[]>;
4
+ export type PluginRuntime = {
5
+ beforeHooks: HookRegistry;
6
+ afterHooks: HookRegistry;
7
+ };
8
+ export declare function loadPlugins(projectRoot: string, pluginEntries: string[]): Promise<PluginRuntime>;
9
+ export declare function runPhaseHooks(hooks: HookRegistry, phase: PhaseName, context: PipelineContext): Promise<void>;
10
+ export {};
@@ -0,0 +1,59 @@
1
+ import { access } from 'node:fs/promises';
2
+ import path from 'node:path';
3
+ import { pathToFileURL } from 'node:url';
4
+ import { engineAdapters } from '../engines/index.js';
5
+ function createHookRegistry() {
6
+ return {
7
+ intake: [],
8
+ planning: [],
9
+ steering: [],
10
+ scaffold: [],
11
+ sync: [],
12
+ execute: [],
13
+ verify: [],
14
+ post: [],
15
+ };
16
+ }
17
+ export async function loadPlugins(projectRoot, pluginEntries) {
18
+ const beforeHooks = createHookRegistry();
19
+ const afterHooks = createHookRegistry();
20
+ const api = {
21
+ registerEngine(name, adapter) {
22
+ engineAdapters[name] = adapter;
23
+ },
24
+ onBeforePhase(phase, hook) {
25
+ beforeHooks[phase].push(hook);
26
+ },
27
+ onAfterPhase(phase, hook) {
28
+ afterHooks[phase].push(hook);
29
+ },
30
+ };
31
+ for (const entry of pluginEntries) {
32
+ const pluginPath = path.isAbsolute(entry) ? entry : path.join(projectRoot, entry);
33
+ if (!(await exists(pluginPath))) {
34
+ continue;
35
+ }
36
+ const loaded = await import(pathToFileURL(pluginPath).href);
37
+ const plugin = (loaded.default ?? loaded.plugin ?? loaded);
38
+ if (!plugin || typeof plugin.register !== 'function') {
39
+ continue;
40
+ }
41
+ await plugin.register(api);
42
+ }
43
+ return { beforeHooks, afterHooks };
44
+ }
45
+ export async function runPhaseHooks(hooks, phase, context) {
46
+ for (const hook of hooks[phase]) {
47
+ await hook(context);
48
+ }
49
+ }
50
+ async function exists(targetPath) {
51
+ try {
52
+ await access(targetPath);
53
+ return true;
54
+ }
55
+ catch {
56
+ return false;
57
+ }
58
+ }
59
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/plugins/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAMrD,SAAS,kBAAkB;IACzB,OAAO;QACL,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE,EAAE;QACZ,QAAQ,EAAE,EAAE;QACZ,QAAQ,EAAE,EAAE;QACZ,IAAI,EAAE,EAAE;QACR,OAAO,EAAE,EAAE;QACX,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,EAAE;KACT,CAAC;AACJ,CAAC;AAOD,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,WAAmB,EAAE,aAAuB;IAC5E,MAAM,WAAW,GAAG,kBAAkB,EAAE,CAAC;IACzC,MAAM,UAAU,GAAG,kBAAkB,EAAE,CAAC;IACxC,MAAM,GAAG,GAAc;QACrB,cAAc,CAAC,IAAI,EAAE,OAAO;YAC1B,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC;QACjC,CAAC;QACD,aAAa,CAAC,KAAK,EAAE,IAAI;YACvB,WAAW,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC;QACD,YAAY,CAAC,KAAK,EAAE,IAAI;YACtB,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC;KACF,CAAC;IAEF,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;QAClC,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAClF,IAAI,CAAC,CAAC,MAAM,MAAM,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC;YAChC,SAAS;QACX,CAAC;QACD,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAgB,CAAC;QAC1E,IAAI,CAAC,MAAM,IAAI,OAAO,MAAM,CAAC,QAAQ,KAAK,UAAU,EAAE,CAAC;YACrD,SAAS;QACX,CAAC;QACD,MAAM,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC;IAED,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC;AACrC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,KAAmB,EACnB,KAAgB,EAChB,OAAwB;IAExB,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;QAChC,MAAM,IAAI,CAAC,OAAO,CAAC,CAAC;IACtB,CAAC;AACH,CAAC;AAED,KAAK,UAAU,MAAM,CAAC,UAAkB;IACtC,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,UAAU,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { EngineAdapter } from '../engines/types.js';
2
+ import type { PipelineContext } from '../phases/types.js';
3
+ export type PhaseName = 'intake' | 'planning' | 'steering' | 'scaffold' | 'sync' | 'execute' | 'verify' | 'post';
4
+ export type PhaseHook = (context: PipelineContext) => Promise<void> | void;
5
+ export type PluginApi = {
6
+ registerEngine: (name: string, adapter: EngineAdapter) => void;
7
+ onBeforePhase: (phase: PhaseName, hook: PhaseHook) => void;
8
+ onAfterPhase: (phase: PhaseName, hook: PhaseHook) => void;
9
+ };
10
+ export type BemadPlugin = {
11
+ name: string;
12
+ register: (api: PluginApi) => Promise<void> | void;
13
+ };
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/plugins/types.ts"],"names":[],"mappings":""}
package/dist/state.d.ts CHANGED
@@ -1,5 +1,10 @@
1
1
  export type PipelineState = {
2
2
  phase: string;
3
+ lastCompletedPhase?: string;
4
+ failedPhase?: string;
5
+ status?: 'running' | 'failed' | 'completed';
6
+ resumeFromPhase?: string;
7
+ lastError?: string;
3
8
  mode: 'auto' | 'hybrid' | 'supervised';
4
9
  engine?: string;
5
10
  executionProfile?: 'safe' | 'balanced' | 'fast';
@@ -9,6 +14,9 @@ export type PipelineState = {
9
14
  tasksTotal?: number;
10
15
  costUsd?: number;
11
16
  startedAt?: string;
17
+ updatedAt?: string;
18
+ finishedAt?: string;
19
+ runId?: string;
12
20
  };
13
21
  export declare function loadState(projectRoot: string): Promise<PipelineState | null>;
14
22
  export declare function saveState(projectRoot: string, state: PipelineState): Promise<void>;
package/dist/state.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"state.js","sourceRoot":"","sources":["../src/state.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAexC,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,WAAmB;IACjD,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,cAAc,EAAE,YAAY,CAAC,CAAC;IACvE,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAC/C,OAAQ,KAAK,CAAC,GAAG,CAAmB,IAAI,IAAI,CAAC;IAC/C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,WAAmB,EAAE,KAAoB;IACvE,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC;IACnD,MAAM,KAAK,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACtC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;IAC/C,MAAM,SAAS,CAAC,SAAS,EAAE,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,CAAC;AACxD,CAAC"}
1
+ {"version":3,"file":"state.js","sourceRoot":"","sources":["../src/state.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAuBxC,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,WAAmB;IACjD,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,cAAc,EAAE,YAAY,CAAC,CAAC;IACvE,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAC/C,OAAQ,KAAK,CAAC,GAAG,CAAmB,IAAI,IAAI,CAAC;IAC/C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,WAAmB,EAAE,KAAoB;IACvE,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC;IACnD,MAAM,KAAK,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACtC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;IAC/C,MAAM,SAAS,CAAC,SAAS,EAAE,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,CAAC;AACxD,CAAC"}