@principles/pd-cli 1.73.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.md +90 -0
- package/dist/commands/artifact.d.ts +14 -0
- package/dist/commands/artifact.d.ts.map +1 -0
- package/dist/commands/artifact.js +67 -0
- package/dist/commands/artifact.js.map +1 -0
- package/dist/commands/candidate.d.ts +83 -0
- package/dist/commands/candidate.d.ts.map +1 -0
- package/dist/commands/candidate.js +891 -0
- package/dist/commands/candidate.js.map +1 -0
- package/dist/commands/central-sync.d.ts +10 -0
- package/dist/commands/central-sync.d.ts.map +1 -0
- package/dist/commands/central-sync.js +32 -0
- package/dist/commands/central-sync.js.map +1 -0
- package/dist/commands/console.d.ts +9 -0
- package/dist/commands/console.d.ts.map +1 -0
- package/dist/commands/console.js +114 -0
- package/dist/commands/console.js.map +1 -0
- package/dist/commands/context.d.ts +7 -0
- package/dist/commands/context.d.ts.map +1 -0
- package/dist/commands/context.js +55 -0
- package/dist/commands/context.js.map +1 -0
- package/dist/commands/demo-story-a.d.ts +12 -0
- package/dist/commands/demo-story-a.d.ts.map +1 -0
- package/dist/commands/demo-story-a.js +175 -0
- package/dist/commands/demo-story-a.js.map +1 -0
- package/dist/commands/diagnose.d.ts +35 -0
- package/dist/commands/diagnose.d.ts.map +1 -0
- package/dist/commands/diagnose.js +390 -0
- package/dist/commands/diagnose.js.map +1 -0
- package/dist/commands/evolution-tasks-list.d.ts +15 -0
- package/dist/commands/evolution-tasks-list.d.ts.map +1 -0
- package/dist/commands/evolution-tasks-list.js +34 -0
- package/dist/commands/evolution-tasks-list.js.map +1 -0
- package/dist/commands/evolution-tasks-show.d.ts +14 -0
- package/dist/commands/evolution-tasks-show.d.ts.map +1 -0
- package/dist/commands/evolution-tasks-show.js +52 -0
- package/dist/commands/evolution-tasks-show.js.map +1 -0
- package/dist/commands/flow.d.ts +7 -0
- package/dist/commands/flow.d.ts.map +1 -0
- package/dist/commands/flow.js +57 -0
- package/dist/commands/flow.js.map +1 -0
- package/dist/commands/health.d.ts +16 -0
- package/dist/commands/health.d.ts.map +1 -0
- package/dist/commands/health.js +150 -0
- package/dist/commands/health.js.map +1 -0
- package/dist/commands/history.d.ts +11 -0
- package/dist/commands/history.d.ts.map +1 -0
- package/dist/commands/history.js +50 -0
- package/dist/commands/history.js.map +1 -0
- package/dist/commands/legacy-cleanup.d.ts +27 -0
- package/dist/commands/legacy-cleanup.d.ts.map +1 -0
- package/dist/commands/legacy-cleanup.js +171 -0
- package/dist/commands/legacy-cleanup.js.map +1 -0
- package/dist/commands/legacy-import.d.ts +7 -0
- package/dist/commands/legacy-import.d.ts.map +1 -0
- package/dist/commands/legacy-import.js +86 -0
- package/dist/commands/legacy-import.js.map +1 -0
- package/dist/commands/pain-record.d.ts +10 -0
- package/dist/commands/pain-record.d.ts.map +1 -0
- package/dist/commands/pain-record.js +162 -0
- package/dist/commands/pain-record.js.map +1 -0
- package/dist/commands/proven-channel-baseline.d.ts +12 -0
- package/dist/commands/proven-channel-baseline.d.ts.map +1 -0
- package/dist/commands/proven-channel-baseline.js +97 -0
- package/dist/commands/proven-channel-baseline.js.map +1 -0
- package/dist/commands/remediation-output.d.ts +40 -0
- package/dist/commands/remediation-output.d.ts.map +1 -0
- package/dist/commands/remediation-output.js +23 -0
- package/dist/commands/remediation-output.js.map +1 -0
- package/dist/commands/run.d.ts +10 -0
- package/dist/commands/run.d.ts.map +1 -0
- package/dist/commands/run.js +68 -0
- package/dist/commands/run.js.map +1 -0
- package/dist/commands/runtime-activation.d.ts +11 -0
- package/dist/commands/runtime-activation.d.ts.map +1 -0
- package/dist/commands/runtime-activation.js +150 -0
- package/dist/commands/runtime-activation.js.map +1 -0
- package/dist/commands/runtime-canary.d.ts +30 -0
- package/dist/commands/runtime-canary.d.ts.map +1 -0
- package/dist/commands/runtime-canary.js +343 -0
- package/dist/commands/runtime-canary.js.map +1 -0
- package/dist/commands/runtime-diagnostics-export.d.ts +20 -0
- package/dist/commands/runtime-diagnostics-export.d.ts.map +1 -0
- package/dist/commands/runtime-diagnostics-export.js +177 -0
- package/dist/commands/runtime-diagnostics-export.js.map +1 -0
- package/dist/commands/runtime-features.d.ts +26 -0
- package/dist/commands/runtime-features.d.ts.map +1 -0
- package/dist/commands/runtime-features.js +70 -0
- package/dist/commands/runtime-features.js.map +1 -0
- package/dist/commands/runtime-gfi-snapshot.d.ts +7 -0
- package/dist/commands/runtime-gfi-snapshot.d.ts.map +1 -0
- package/dist/commands/runtime-gfi-snapshot.js +101 -0
- package/dist/commands/runtime-gfi-snapshot.js.map +1 -0
- package/dist/commands/runtime-health-snapshot.d.ts +7 -0
- package/dist/commands/runtime-health-snapshot.d.ts.map +1 -0
- package/dist/commands/runtime-health-snapshot.js +93 -0
- package/dist/commands/runtime-health-snapshot.js.map +1 -0
- package/dist/commands/runtime-idle-trigger.d.ts +12 -0
- package/dist/commands/runtime-idle-trigger.d.ts.map +1 -0
- package/dist/commands/runtime-idle-trigger.js +102 -0
- package/dist/commands/runtime-idle-trigger.js.map +1 -0
- package/dist/commands/runtime-internalization-enqueue-successors.d.ts +9 -0
- package/dist/commands/runtime-internalization-enqueue-successors.d.ts.map +1 -0
- package/dist/commands/runtime-internalization-enqueue-successors.js +393 -0
- package/dist/commands/runtime-internalization-enqueue-successors.js.map +1 -0
- package/dist/commands/runtime-internalization-integrity-repair.d.ts +9 -0
- package/dist/commands/runtime-internalization-integrity-repair.d.ts.map +1 -0
- package/dist/commands/runtime-internalization-integrity-repair.js +54 -0
- package/dist/commands/runtime-internalization-integrity-repair.js.map +1 -0
- package/dist/commands/runtime-internalization-integrity.d.ts +7 -0
- package/dist/commands/runtime-internalization-integrity.d.ts.map +1 -0
- package/dist/commands/runtime-internalization-integrity.js +53 -0
- package/dist/commands/runtime-internalization-integrity.js.map +1 -0
- package/dist/commands/runtime-internalization-queue.d.ts +7 -0
- package/dist/commands/runtime-internalization-queue.d.ts.map +1 -0
- package/dist/commands/runtime-internalization-queue.js +85 -0
- package/dist/commands/runtime-internalization-queue.js.map +1 -0
- package/dist/commands/runtime-internalization-run-once.d.ts +12 -0
- package/dist/commands/runtime-internalization-run-once.d.ts.map +1 -0
- package/dist/commands/runtime-internalization-run-once.js +546 -0
- package/dist/commands/runtime-internalization-run-once.js.map +1 -0
- package/dist/commands/runtime-internalization-wake-once.d.ts +8 -0
- package/dist/commands/runtime-internalization-wake-once.d.ts.map +1 -0
- package/dist/commands/runtime-internalization-wake-once.js +72 -0
- package/dist/commands/runtime-internalization-wake-once.js.map +1 -0
- package/dist/commands/runtime-pain-flood-simulation.d.ts +10 -0
- package/dist/commands/runtime-pain-flood-simulation.d.ts.map +1 -0
- package/dist/commands/runtime-pain-flood-simulation.js +104 -0
- package/dist/commands/runtime-pain-flood-simulation.js.map +1 -0
- package/dist/commands/runtime-pruning.d.ts +45 -0
- package/dist/commands/runtime-pruning.d.ts.map +1 -0
- package/dist/commands/runtime-pruning.js +355 -0
- package/dist/commands/runtime-pruning.js.map +1 -0
- package/dist/commands/runtime-recovery.d.ts +9 -0
- package/dist/commands/runtime-recovery.d.ts.map +1 -0
- package/dist/commands/runtime-recovery.js +94 -0
- package/dist/commands/runtime-recovery.js.map +1 -0
- package/dist/commands/runtime-synthetic-baseline.d.ts +7 -0
- package/dist/commands/runtime-synthetic-baseline.d.ts.map +1 -0
- package/dist/commands/runtime-synthetic-baseline.js +59 -0
- package/dist/commands/runtime-synthetic-baseline.js.map +1 -0
- package/dist/commands/runtime-uat.d.ts +52 -0
- package/dist/commands/runtime-uat.d.ts.map +1 -0
- package/dist/commands/runtime-uat.js +274 -0
- package/dist/commands/runtime-uat.js.map +1 -0
- package/dist/commands/runtime.d.ts +20 -0
- package/dist/commands/runtime.d.ts.map +1 -0
- package/dist/commands/runtime.js +256 -0
- package/dist/commands/runtime.js.map +1 -0
- package/dist/commands/samples-list.d.ts +11 -0
- package/dist/commands/samples-list.d.ts.map +1 -0
- package/dist/commands/samples-list.js +37 -0
- package/dist/commands/samples-list.js.map +1 -0
- package/dist/commands/samples-review.d.ts +14 -0
- package/dist/commands/samples-review.d.ts.map +1 -0
- package/dist/commands/samples-review.js +22 -0
- package/dist/commands/samples-review.js.map +1 -0
- package/dist/commands/task.d.ts +14 -0
- package/dist/commands/task.d.ts.map +1 -0
- package/dist/commands/task.js +92 -0
- package/dist/commands/task.js.map +1 -0
- package/dist/commands/trace.d.ts +19 -0
- package/dist/commands/trace.d.ts.map +1 -0
- package/dist/commands/trace.js +154 -0
- package/dist/commands/trace.js.map +1 -0
- package/dist/commands/trajectory.d.ts +11 -0
- package/dist/commands/trajectory.d.ts.map +1 -0
- package/dist/commands/trajectory.js +47 -0
- package/dist/commands/trajectory.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +736 -0
- package/dist/index.js.map +1 -0
- package/dist/legacy/legacy-import.d.ts +15 -0
- package/dist/legacy/legacy-import.d.ts.map +1 -0
- package/dist/legacy/legacy-import.js +141 -0
- package/dist/legacy/legacy-import.js.map +1 -0
- package/dist/legacy/session-history-import.d.ts +26 -0
- package/dist/legacy/session-history-import.d.ts.map +1 -0
- package/dist/legacy/session-history-import.js +151 -0
- package/dist/legacy/session-history-import.js.map +1 -0
- package/dist/principle-tree-ledger-adapter.d.ts +12 -0
- package/dist/principle-tree-ledger-adapter.d.ts.map +1 -0
- package/dist/principle-tree-ledger-adapter.js +12 -0
- package/dist/principle-tree-ledger-adapter.js.map +1 -0
- package/dist/resolve-workspace.d.ts +12 -0
- package/dist/resolve-workspace.d.ts.map +1 -0
- package/dist/resolve-workspace.js +20 -0
- package/dist/resolve-workspace.js.map +1 -0
- package/dist/services/demo-story-a-runner.d.ts +8 -0
- package/dist/services/demo-story-a-runner.d.ts.map +1 -0
- package/dist/services/demo-story-a-runner.js +369 -0
- package/dist/services/demo-story-a-runner.js.map +1 -0
- package/dist/services/feature-flag-loader.d.ts +6 -0
- package/dist/services/feature-flag-loader.d.ts.map +1 -0
- package/dist/services/feature-flag-loader.js +54 -0
- package/dist/services/feature-flag-loader.js.map +1 -0
- package/dist/services/pain-flood-simulation-runner.d.ts +10 -0
- package/dist/services/pain-flood-simulation-runner.d.ts.map +1 -0
- package/dist/services/pain-flood-simulation-runner.js +289 -0
- package/dist/services/pain-flood-simulation-runner.js.map +1 -0
- package/dist/services/proven-channel-baseline-runner.d.ts +12 -0
- package/dist/services/proven-channel-baseline-runner.d.ts.map +1 -0
- package/dist/services/proven-channel-baseline-runner.js +114 -0
- package/dist/services/proven-channel-baseline-runner.js.map +1 -0
- package/dist/services/synthetic-baseline-runner.d.ts +8 -0
- package/dist/services/synthetic-baseline-runner.d.ts.map +1 -0
- package/dist/services/synthetic-baseline-runner.js +251 -0
- package/dist/services/synthetic-baseline-runner.js.map +1 -0
- package/package.json +35 -0
- package/src/commands/artifact.ts +82 -0
- package/src/commands/candidate.ts +1117 -0
- package/src/commands/central-sync.ts +44 -0
- package/src/commands/console.ts +121 -0
- package/src/commands/context.ts +72 -0
- package/src/commands/demo-story-a.ts +195 -0
- package/src/commands/diagnose.ts +452 -0
- package/src/commands/evolution-tasks-list.ts +44 -0
- package/src/commands/evolution-tasks-show.ts +60 -0
- package/src/commands/flow.ts +60 -0
- package/src/commands/health.ts +189 -0
- package/src/commands/history.ts +63 -0
- package/src/commands/legacy-cleanup.ts +206 -0
- package/src/commands/legacy-import.ts +104 -0
- package/src/commands/pain-record.ts +167 -0
- package/src/commands/proven-channel-baseline.ts +113 -0
- package/src/commands/remediation-output.ts +66 -0
- package/src/commands/run.ts +89 -0
- package/src/commands/runtime-activation.ts +176 -0
- package/src/commands/runtime-canary.ts +371 -0
- package/src/commands/runtime-diagnostics-export.ts +229 -0
- package/src/commands/runtime-features.ts +103 -0
- package/src/commands/runtime-gfi-snapshot.ts +135 -0
- package/src/commands/runtime-health-snapshot.ts +106 -0
- package/src/commands/runtime-internalization-enqueue-successors.ts +479 -0
- package/src/commands/runtime-internalization-integrity-repair.ts +69 -0
- package/src/commands/runtime-internalization-integrity.ts +63 -0
- package/src/commands/runtime-internalization-queue.ts +106 -0
- package/src/commands/runtime-internalization-run-once.ts +658 -0
- package/src/commands/runtime-internalization-wake-once.ts +87 -0
- package/src/commands/runtime-pain-flood-simulation.ts +121 -0
- package/src/commands/runtime-pruning.ts +438 -0
- package/src/commands/runtime-recovery.ts +107 -0
- package/src/commands/runtime-synthetic-baseline.ts +70 -0
- package/src/commands/runtime-uat.ts +339 -0
- package/src/commands/runtime.ts +281 -0
- package/src/commands/samples-list.ts +43 -0
- package/src/commands/samples-review.ts +32 -0
- package/src/commands/task.ts +130 -0
- package/src/commands/trace.ts +174 -0
- package/src/commands/trajectory.ts +64 -0
- package/src/index.ts +829 -0
- package/src/legacy/legacy-import.ts +179 -0
- package/src/legacy/session-history-import.ts +231 -0
- package/src/principle-tree-ledger-adapter.ts +13 -0
- package/src/resolve-workspace.ts +20 -0
- package/src/services/demo-story-a-runner.ts +472 -0
- package/src/services/feature-flag-loader.ts +73 -0
- package/src/services/pain-flood-simulation-runner.ts +354 -0
- package/src/services/proven-channel-baseline-runner.ts +150 -0
- package/src/services/synthetic-baseline-runner.ts +291 -0
- package/tests/commands/candidate-audit-repair.test.ts +338 -0
- package/tests/commands/candidate-intake.test.ts +589 -0
- package/tests/commands/candidate-internalization-backfill.test.ts +480 -0
- package/tests/commands/candidate-internalize.test.ts +272 -0
- package/tests/commands/candidate-route.test.ts +328 -0
- package/tests/commands/candidate-show.test.ts +95 -0
- package/tests/commands/cli-command-tree.test.ts +64 -0
- package/tests/commands/context.test.ts +114 -0
- package/tests/commands/demo-story-a.test.ts +255 -0
- package/tests/commands/diagnose.test.ts +792 -0
- package/tests/commands/health.test.ts +330 -0
- package/tests/commands/pain-record.test.ts +316 -0
- package/tests/commands/plugin-config-resolution-cutover.test.ts +220 -0
- package/tests/commands/proven-channel-baseline.test.ts +441 -0
- package/tests/commands/runtime-activation.test.ts +168 -0
- package/tests/commands/runtime-canary.test.ts +369 -0
- package/tests/commands/runtime-diagnostics-export.test.ts +170 -0
- package/tests/commands/runtime-features.test.ts +114 -0
- package/tests/commands/runtime-health-snapshot.test.ts +357 -0
- package/tests/commands/runtime-internalization-enqueue-successors.test.ts +803 -0
- package/tests/commands/runtime-internalization-integrity-repair.test.ts +169 -0
- package/tests/commands/runtime-internalization-integrity.test.ts +102 -0
- package/tests/commands/runtime-internalization-queue.test.ts +252 -0
- package/tests/commands/runtime-internalization-run-once.test.ts +1318 -0
- package/tests/commands/runtime-internalization-wake-once.test.ts +170 -0
- package/tests/commands/runtime-internalization.test.ts +52 -0
- package/tests/commands/runtime-pain-flood-simulation.test.ts +418 -0
- package/tests/commands/runtime-pruning.test.ts +693 -0
- package/tests/commands/runtime-recovery.test.ts +96 -0
- package/tests/commands/runtime-synthetic-baseline.test.ts +249 -0
- package/tests/commands/runtime-uat.test.ts +397 -0
- package/tests/commands/runtime.test.ts +262 -0
- package/tests/commands/trace.test.ts +314 -0
- package/tests/e2e/candidate-intake-e2e.test.ts +316 -0
- package/tests/services/feature-flag-loader.test.ts +207 -0
- package/tests/services/proven-channel-baseline-runner.test.ts +30 -0
- package/tsconfig.json +26 -0
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pd health command implementation — Runtime V2 edition.
|
|
3
|
+
*
|
|
4
|
+
* Usage: pd health [--workspace <path>] [--json]
|
|
5
|
+
*
|
|
6
|
+
* Reads workspace/.pd/state.db and workspace/.state/principle_training_state.json
|
|
7
|
+
* to provide Runtime V2 health diagnostics.
|
|
8
|
+
* Uses read models from @principles/core/runtime-v2 (no direct ledger access).
|
|
9
|
+
*/
|
|
10
|
+
import * as fs from 'fs';
|
|
11
|
+
import * as path from 'path';
|
|
12
|
+
import Database from 'better-sqlite3';
|
|
13
|
+
import { resolveWorkspaceDir } from '../resolve-workspace.js';
|
|
14
|
+
import { PruningReadModel, PainChainReadModel, auditCandidateLedgerConsistency, getLedgerFilePathPublic } from '@principles/core/runtime-v2';
|
|
15
|
+
function painChainTraceToLastSuccessfulChain(trace) {
|
|
16
|
+
const totalMs = (trace.latencyMs.painToTask ?? 0)
|
|
17
|
+
+ (trace.latencyMs.taskToRun ?? 0)
|
|
18
|
+
+ (trace.latencyMs.runToArtifact ?? 0);
|
|
19
|
+
return {
|
|
20
|
+
painId: trace.painId,
|
|
21
|
+
taskId: trace.taskId,
|
|
22
|
+
runId: trace.runId ?? '',
|
|
23
|
+
artifactId: trace.artifactId ?? '',
|
|
24
|
+
candidateIds: trace.candidateIds,
|
|
25
|
+
ledgerEntryIds: trace.ledgerEntryIds,
|
|
26
|
+
latencyMs: { totalMs: totalMs > 0 ? totalMs : undefined },
|
|
27
|
+
failureCategory: trace.failureCategory,
|
|
28
|
+
checkedAt: trace.checkedAt,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
export async function handleHealth(opts = {}) {
|
|
32
|
+
const workspaceDir = opts.workspace
|
|
33
|
+
? path.resolve(opts.workspace)
|
|
34
|
+
: resolveWorkspaceDir();
|
|
35
|
+
const generatedAt = new Date().toISOString();
|
|
36
|
+
const pdDbPath = path.join(workspaceDir, '.pd', 'state.db');
|
|
37
|
+
const ledgerStateDir = path.join(workspaceDir, '.state');
|
|
38
|
+
const ledgerPath = getLedgerFilePathPublic(ledgerStateDir);
|
|
39
|
+
const pruningModel = new PruningReadModel({ workspaceDir });
|
|
40
|
+
const healthSummary = pruningModel.getHealthSummary();
|
|
41
|
+
const ledgerByStatus = healthSummary.byStatus;
|
|
42
|
+
const { missingLedgerCount } = await auditCandidateLedgerConsistency(workspaceDir);
|
|
43
|
+
let candidatesTotal = 0, candidatesConsumed = 0, candidatesPending = 0;
|
|
44
|
+
let tasksTotal = 0;
|
|
45
|
+
const tasksByStatus = {};
|
|
46
|
+
let pdDbExists = false;
|
|
47
|
+
let lastSuccessfulChain = undefined;
|
|
48
|
+
let partialHealth = false;
|
|
49
|
+
function buildHealth() {
|
|
50
|
+
return {
|
|
51
|
+
generatedAt,
|
|
52
|
+
workspace: workspaceDir,
|
|
53
|
+
partialHealth,
|
|
54
|
+
pdStateDb: { path: pdDbPath, exists: pdDbExists },
|
|
55
|
+
ledger: {
|
|
56
|
+
path: ledgerPath,
|
|
57
|
+
exists: fs.existsSync(ledgerPath),
|
|
58
|
+
totalPrinciples: healthSummary.totalPrinciples,
|
|
59
|
+
byStatus: ledgerByStatus,
|
|
60
|
+
},
|
|
61
|
+
candidates: { total: candidatesTotal, consumed: candidatesConsumed, pending: candidatesPending },
|
|
62
|
+
tasks: { total: tasksTotal, byStatus: tasksByStatus },
|
|
63
|
+
candidateLedgerConsistency: {
|
|
64
|
+
status: missingLedgerCount === 0 ? 'ok' : 'degraded',
|
|
65
|
+
missing: missingLedgerCount,
|
|
66
|
+
},
|
|
67
|
+
lastSuccessfulChain,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
function writeHealth() {
|
|
71
|
+
const health = buildHealth();
|
|
72
|
+
if (opts.json) {
|
|
73
|
+
console.log(JSON.stringify(health, null, 2));
|
|
74
|
+
if (health.candidateLedgerConsistency.status === 'degraded')
|
|
75
|
+
process.exit(1);
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
console.log(`generatedAt: ${health.generatedAt}`);
|
|
79
|
+
console.log(`workspace: ${health.workspace}`);
|
|
80
|
+
console.log(`pdStateDb.exists: ${health.pdStateDb.exists}`);
|
|
81
|
+
console.log(`pdStateDb.path: ${health.pdStateDb.path}`);
|
|
82
|
+
console.log(`ledger.exists: ${health.ledger.exists}`);
|
|
83
|
+
console.log(`ledger.path: ${health.ledger.path}`);
|
|
84
|
+
console.log(`ledger.totalPrinciples: ${health.ledger.totalPrinciples}`);
|
|
85
|
+
console.log(`ledger.byStatus: ${JSON.stringify(health.ledger.byStatus)}`);
|
|
86
|
+
console.log(`candidates.total: ${health.candidates.total}`);
|
|
87
|
+
console.log(`candidates.consumed: ${health.candidates.consumed}`);
|
|
88
|
+
console.log(`candidates.pending: ${health.candidates.pending}`);
|
|
89
|
+
console.log(`tasks.total: ${health.tasks.total}`);
|
|
90
|
+
console.log(`tasks.byStatus: ${JSON.stringify(health.tasks.byStatus)}`);
|
|
91
|
+
console.log(`candidateLedgerConsistency.status: ${health.candidateLedgerConsistency.status}`);
|
|
92
|
+
console.log(`candidateLedgerConsistency.missing: ${health.candidateLedgerConsistency.missing}`);
|
|
93
|
+
if (health.lastSuccessfulChain) {
|
|
94
|
+
console.log('lastSuccessfulChain:');
|
|
95
|
+
console.log(` taskId: ${health.lastSuccessfulChain.taskId}`);
|
|
96
|
+
console.log(` runId: ${health.lastSuccessfulChain.runId}`);
|
|
97
|
+
console.log(` artifactId: ${health.lastSuccessfulChain.artifactId}`);
|
|
98
|
+
console.log(` candidateIds: ${health.lastSuccessfulChain.candidateIds.join(', ')}`);
|
|
99
|
+
console.log(` ledgerEntries: ${health.lastSuccessfulChain.ledgerEntryIds.join(', ')}`);
|
|
100
|
+
}
|
|
101
|
+
console.log('');
|
|
102
|
+
if (health.candidateLedgerConsistency.status === 'degraded') {
|
|
103
|
+
console.warn('⚠️ Candidate/ledger consistency is DEGRADED. Run: pd candidate audit --workspace "' + workspaceDir + '" --json');
|
|
104
|
+
console.warn(' To repair missing entries: pd candidate repair --candidate-id <id> --workspace "' + workspaceDir + '" --json');
|
|
105
|
+
process.exit(1);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
if (fs.existsSync(pdDbPath)) {
|
|
109
|
+
pdDbExists = true;
|
|
110
|
+
const db = Database(pdDbPath, { readonly: true });
|
|
111
|
+
try {
|
|
112
|
+
const cRow = db.prepare('SELECT COUNT(*) as total, status FROM principle_candidates GROUP BY status').all();
|
|
113
|
+
for (const r of cRow) {
|
|
114
|
+
candidatesTotal += r.total;
|
|
115
|
+
if (r.status === 'consumed')
|
|
116
|
+
candidatesConsumed = r.total;
|
|
117
|
+
if (r.status === 'pending')
|
|
118
|
+
candidatesPending = r.total;
|
|
119
|
+
}
|
|
120
|
+
const tRows = db.prepare('SELECT COUNT(*) as total, status FROM tasks GROUP BY status').all();
|
|
121
|
+
for (const r of tRows) {
|
|
122
|
+
tasksTotal += r.total;
|
|
123
|
+
tasksByStatus[r.status] = r.total;
|
|
124
|
+
}
|
|
125
|
+
const painChainModel = new PainChainReadModel({ workspaceDir });
|
|
126
|
+
try {
|
|
127
|
+
const chain = await painChainModel.getLastSuccessfulChain();
|
|
128
|
+
if (chain) {
|
|
129
|
+
lastSuccessfulChain = painChainTraceToLastSuccessfulChain(chain);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
catch {
|
|
133
|
+
partialHealth = true;
|
|
134
|
+
}
|
|
135
|
+
finally {
|
|
136
|
+
await painChainModel.close();
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
catch (err) {
|
|
140
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
141
|
+
console.warn(`Warning: could not read full state.db metrics — partial health data: ${msg}`);
|
|
142
|
+
partialHealth = true;
|
|
143
|
+
}
|
|
144
|
+
finally {
|
|
145
|
+
db.close();
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
writeHealth();
|
|
149
|
+
}
|
|
150
|
+
//# sourceMappingURL=health.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.js","sourceRoot":"","sources":["../../src/commands/health.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
interface HistoryQueryOptions {
|
|
2
|
+
limit?: number;
|
|
3
|
+
cursor?: string;
|
|
4
|
+
from?: string;
|
|
5
|
+
to?: string;
|
|
6
|
+
json?: boolean;
|
|
7
|
+
workspace?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function handleHistoryQuery(taskId: string, opts: HistoryQueryOptions): Promise<void>;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=history.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"history.d.ts","sourceRoot":"","sources":["../../src/commands/history.ts"],"names":[],"mappings":"AAUA,UAAU,mBAAmB;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAsB,kBAAkB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC,CA2CjG"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pd history query — Query run history for a task with pagination.
|
|
3
|
+
*
|
|
4
|
+
* Usage:
|
|
5
|
+
* pd history query <taskId> [--limit N] [--cursor <cursor>]
|
|
6
|
+
* pd history query <taskId> --from <date> --to <date>
|
|
7
|
+
*/
|
|
8
|
+
import { SqliteConnection, SqliteHistoryQuery } from '@principles/core';
|
|
9
|
+
import { resolveWorkspaceDir } from '../resolve-workspace.js';
|
|
10
|
+
export async function handleHistoryQuery(taskId, opts) {
|
|
11
|
+
const workspaceDir = resolveWorkspaceDir(opts.workspace);
|
|
12
|
+
const connection = new SqliteConnection(workspaceDir);
|
|
13
|
+
try {
|
|
14
|
+
const historyQuery = new SqliteHistoryQuery(connection);
|
|
15
|
+
const queryOpts = opts.limit || opts.from || opts.to
|
|
16
|
+
? {
|
|
17
|
+
limit: opts.limit,
|
|
18
|
+
timeWindowStart: opts.from,
|
|
19
|
+
timeWindowEnd: opts.to,
|
|
20
|
+
}
|
|
21
|
+
: undefined;
|
|
22
|
+
const result = await historyQuery.query(taskId, opts.cursor, queryOpts);
|
|
23
|
+
if (opts.json) {
|
|
24
|
+
console.log(JSON.stringify(result, null, 2));
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (result.entries.length === 0) {
|
|
28
|
+
console.log('No history entries found.');
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
console.log(`\nHistory for ${taskId} (${result.entries.length} entries${result.truncated ? ', truncated' : ''}):\n`);
|
|
32
|
+
for (const entry of result.entries) {
|
|
33
|
+
const text = entry.text ? (entry.text.length > 60 ? entry.text.substring(0, 57) + '...' : entry.text) : '<empty>';
|
|
34
|
+
console.log(' [%s] %-8s %s', entry.ts.substring(11, 19), entry.role, text);
|
|
35
|
+
}
|
|
36
|
+
if (result.nextCursor) {
|
|
37
|
+
console.log(`\n nextCursor: ${result.nextCursor}`);
|
|
38
|
+
}
|
|
39
|
+
console.log('');
|
|
40
|
+
}
|
|
41
|
+
catch (error) {
|
|
42
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
43
|
+
console.error(`Error: ${message}`);
|
|
44
|
+
process.exit(1);
|
|
45
|
+
}
|
|
46
|
+
finally {
|
|
47
|
+
connection.close();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=history.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"history.js","sourceRoot":"","sources":["../../src/commands/history.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AACH,OAAO,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAW9D,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,MAAc,EAAE,IAAyB;IAChF,MAAM,YAAY,GAAG,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACzD,MAAM,UAAU,GAAG,IAAI,gBAAgB,CAAC,YAAY,CAAC,CAAC;IAEtD,IAAI,CAAC;QACH,MAAM,YAAY,GAAG,IAAI,kBAAkB,CAAC,UAAU,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,EAAE;YAClD,CAAC,CAAC;gBACE,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,eAAe,EAAE,IAAI,CAAC,IAAI;gBAC1B,aAAa,EAAE,IAAI,CAAC,EAAE;aACvB;YACH,CAAC,CAAC,SAAS,CAAC;QACd,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAExE,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAC7C,OAAO;QACT,CAAC;QAED,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAChC,OAAO,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;YACzC,OAAO;QACT,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,iBAAiB,MAAM,KAAK,MAAM,CAAC,OAAO,CAAC,MAAM,WAAW,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;QACrH,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;YACnC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YAClH,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC9E,CAAC;QAED,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;YACtB,OAAO,CAAC,GAAG,CAAC,mBAAmB,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC;QACtD,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAClB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACvE,OAAO,CAAC,KAAK,CAAC,UAAU,OAAO,EAAE,CAAC,CAAC;QACnC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;YAAS,CAAC;QACT,UAAU,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pd legacy cleanup
|
|
3
|
+
*
|
|
4
|
+
* Cleans legacy artifacts from workspaces:
|
|
5
|
+
* - .state/pd_tasks.json (removes empathy-optimizer entries)
|
|
6
|
+
* - .state/sessions/*.json (archives sessions with cron:pd-empathy-optimizer)
|
|
7
|
+
* - .state/diagnostician_tasks.json (archives)
|
|
8
|
+
* - .state/.evolution_complete_* (archives)
|
|
9
|
+
* - .state/.diagnostician_report_* (archives)
|
|
10
|
+
* - ~/.openclaw/cron/jobs.json (removes pd-empathy-optimizer cron jobs)
|
|
11
|
+
*
|
|
12
|
+
* Usage:
|
|
13
|
+
* pd legacy cleanup --workspace <path> --dry-run
|
|
14
|
+
* pd legacy cleanup --workspace <path> --apply
|
|
15
|
+
*/
|
|
16
|
+
interface CleanupTarget {
|
|
17
|
+
path: string;
|
|
18
|
+
action: 'remove' | 'archive';
|
|
19
|
+
reason: string;
|
|
20
|
+
archivePath?: string;
|
|
21
|
+
}
|
|
22
|
+
export declare function handleLegacyCleanup(workspacePath: string, dryRun: boolean): Promise<{
|
|
23
|
+
targets: CleanupTarget[];
|
|
24
|
+
applied: number;
|
|
25
|
+
}>;
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=legacy-cleanup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-cleanup.d.ts","sourceRoot":"","sources":["../../src/commands/legacy-cleanup.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAMH,UAAU,aAAa;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,QAAQ,GAAG,SAAS,CAAC;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAyID,wBAAsB,mBAAmB,CACvC,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,OAAO,GACd,OAAO,CAAC;IAAE,OAAO,EAAE,aAAa,EAAE,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC,CAwCxD"}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pd legacy cleanup
|
|
3
|
+
*
|
|
4
|
+
* Cleans legacy artifacts from workspaces:
|
|
5
|
+
* - .state/pd_tasks.json (removes empathy-optimizer entries)
|
|
6
|
+
* - .state/sessions/*.json (archives sessions with cron:pd-empathy-optimizer)
|
|
7
|
+
* - .state/diagnostician_tasks.json (archives)
|
|
8
|
+
* - .state/.evolution_complete_* (archives)
|
|
9
|
+
* - .state/.diagnostician_report_* (archives)
|
|
10
|
+
* - ~/.openclaw/cron/jobs.json (removes pd-empathy-optimizer cron jobs)
|
|
11
|
+
*
|
|
12
|
+
* Usage:
|
|
13
|
+
* pd legacy cleanup --workspace <path> --dry-run
|
|
14
|
+
* pd legacy cleanup --workspace <path> --apply
|
|
15
|
+
*/
|
|
16
|
+
import * as fs from 'fs';
|
|
17
|
+
import * as path from 'path';
|
|
18
|
+
import * as os from 'os';
|
|
19
|
+
function glob(pattern) {
|
|
20
|
+
const results = [];
|
|
21
|
+
const baseDir = path.dirname(pattern);
|
|
22
|
+
const filePattern = path.basename(pattern).replace(/\*/g, '');
|
|
23
|
+
if (!fs.existsSync(baseDir))
|
|
24
|
+
return [];
|
|
25
|
+
for (const file of fs.readdirSync(baseDir)) {
|
|
26
|
+
if (file.startsWith(filePattern) || filePattern === '') {
|
|
27
|
+
const fullPath = path.join(baseDir, file);
|
|
28
|
+
const stat = fs.statSync(fullPath);
|
|
29
|
+
if (stat.isFile())
|
|
30
|
+
results.push(fullPath);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return results;
|
|
34
|
+
}
|
|
35
|
+
function findLegacyTargets(workspacePath) {
|
|
36
|
+
const targets = [];
|
|
37
|
+
const stateDir = path.join(workspacePath, '.state');
|
|
38
|
+
const archiveTimestamp = new Date().toISOString().replace(/[:.]/g, '-');
|
|
39
|
+
const archiveDir = path.join(stateDir, 'legacy-archive', archiveTimestamp);
|
|
40
|
+
// 1. pd_tasks.json — remove empathy-optimizer entries
|
|
41
|
+
const pdTasksPath = path.join(stateDir, 'pd_tasks.json');
|
|
42
|
+
if (fs.existsSync(pdTasksPath)) {
|
|
43
|
+
try {
|
|
44
|
+
const content = fs.readFileSync(pdTasksPath, 'utf-8');
|
|
45
|
+
const tasks = JSON.parse(content);
|
|
46
|
+
const filtered = tasks.filter((t) => !t.id?.includes('empathy-optimizer') && !t.name?.includes('Empathy Optimizer'));
|
|
47
|
+
if (filtered.length !== tasks.length) {
|
|
48
|
+
targets.push({
|
|
49
|
+
path: pdTasksPath,
|
|
50
|
+
action: 'archive',
|
|
51
|
+
reason: 'Removed empathy-optimizer entries from pd_tasks.json',
|
|
52
|
+
archivePath: path.join(archiveDir, 'pd_tasks.json.backup'),
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
catch { /* skip invalid JSON */ }
|
|
57
|
+
}
|
|
58
|
+
// 2. sessions/*.json — archive empathy cron sessions
|
|
59
|
+
const sessionsDir = path.join(stateDir, 'sessions');
|
|
60
|
+
if (fs.existsSync(sessionsDir)) {
|
|
61
|
+
for (const file of fs.readdirSync(sessionsDir)) {
|
|
62
|
+
if (!file.endsWith('.json'))
|
|
63
|
+
continue;
|
|
64
|
+
const filePath = path.join(sessionsDir, file);
|
|
65
|
+
try {
|
|
66
|
+
const content = fs.readFileSync(filePath, 'utf-8');
|
|
67
|
+
const session = JSON.parse(content);
|
|
68
|
+
if (session.sessionKey?.includes('cron:pd-empathy-optimizer') ||
|
|
69
|
+
session.sessionKey?.includes('cron:empathy-optimizer')) {
|
|
70
|
+
targets.push({
|
|
71
|
+
path: filePath,
|
|
72
|
+
action: 'archive',
|
|
73
|
+
reason: `Legacy empathy cron session: ${session.sessionKey}`,
|
|
74
|
+
archivePath: path.join(archiveDir, 'sessions', file),
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
catch { /* skip */ }
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
// 3. diagnostician_tasks.json
|
|
82
|
+
const diagPath = path.join(stateDir, 'diagnostician_tasks.json');
|
|
83
|
+
if (fs.existsSync(diagPath)) {
|
|
84
|
+
targets.push({
|
|
85
|
+
path: diagPath,
|
|
86
|
+
action: 'archive',
|
|
87
|
+
reason: 'Legacy diagnostician task store',
|
|
88
|
+
archivePath: path.join(archiveDir, 'diagnostician_tasks.json'),
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
// 4. .evolution_complete_* markers
|
|
92
|
+
for (const marker of glob(path.join(stateDir, '.evolution_complete_*'))) {
|
|
93
|
+
targets.push({
|
|
94
|
+
path: marker,
|
|
95
|
+
action: 'archive',
|
|
96
|
+
reason: 'Legacy evolution marker',
|
|
97
|
+
archivePath: path.join(archiveDir, path.basename(marker)),
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
// 5. .diagnostician_report_* markers
|
|
101
|
+
for (const marker of glob(path.join(stateDir, '.diagnostician_report_*'))) {
|
|
102
|
+
targets.push({
|
|
103
|
+
path: marker,
|
|
104
|
+
action: 'archive',
|
|
105
|
+
reason: 'Legacy diagnostician report marker',
|
|
106
|
+
archivePath: path.join(archiveDir, path.basename(marker)),
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
// 6. OpenClaw cron jobs.json
|
|
110
|
+
const cronPath = path.join(os.homedir(), '.openclaw', 'cron', 'jobs.json');
|
|
111
|
+
if (fs.existsSync(cronPath)) {
|
|
112
|
+
try {
|
|
113
|
+
const content = fs.readFileSync(cronPath, 'utf-8');
|
|
114
|
+
const store = JSON.parse(content);
|
|
115
|
+
const filtered = store.jobs.filter((j) => !j.id?.includes('pd-empathy-optimizer') && !j.name?.includes('Empathy Optimizer'));
|
|
116
|
+
if (filtered.length !== store.jobs.length) {
|
|
117
|
+
targets.push({
|
|
118
|
+
path: cronPath,
|
|
119
|
+
action: 'archive',
|
|
120
|
+
reason: 'Removed pd-empathy-optimizer cron jobs',
|
|
121
|
+
archivePath: path.join(os.homedir(), '.openclaw', 'cron', `jobs.json.backup-${archiveTimestamp}`),
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
catch { /* skip */ }
|
|
126
|
+
}
|
|
127
|
+
return targets;
|
|
128
|
+
}
|
|
129
|
+
export async function handleLegacyCleanup(workspacePath, dryRun) {
|
|
130
|
+
const targets = findLegacyTargets(workspacePath);
|
|
131
|
+
let applied = 0;
|
|
132
|
+
if (dryRun) {
|
|
133
|
+
console.log(`\n=== DRY RUN: Would process ${targets.length} target(s) ===`);
|
|
134
|
+
for (const t of targets) {
|
|
135
|
+
console.log(` ${t.action}: ${t.path}`);
|
|
136
|
+
console.log(` Reason: ${t.reason}`);
|
|
137
|
+
if (t.archivePath) {
|
|
138
|
+
console.log(` Archive: ${t.archivePath}`);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
if (targets.length === 0) {
|
|
142
|
+
console.log(' No legacy artifacts found.');
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
console.log(`\n=== Applying ${targets.length} cleanup(s) ===`);
|
|
147
|
+
for (const t of targets) {
|
|
148
|
+
try {
|
|
149
|
+
if (t.action === 'archive' && t.archivePath) {
|
|
150
|
+
const archiveDir = path.dirname(t.archivePath);
|
|
151
|
+
if (!fs.existsSync(archiveDir)) {
|
|
152
|
+
fs.mkdirSync(archiveDir, { recursive: true });
|
|
153
|
+
}
|
|
154
|
+
fs.copyFileSync(t.path, t.archivePath);
|
|
155
|
+
fs.unlinkSync(t.path);
|
|
156
|
+
console.log(` Archived: ${t.path} -> ${t.archivePath}`);
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
fs.unlinkSync(t.path);
|
|
160
|
+
console.log(` Removed: ${t.path}`);
|
|
161
|
+
}
|
|
162
|
+
applied++;
|
|
163
|
+
}
|
|
164
|
+
catch (err) {
|
|
165
|
+
console.error(` ERROR processing ${t.path}: ${String(err)}`);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
return { targets, applied };
|
|
170
|
+
}
|
|
171
|
+
//# sourceMappingURL=legacy-cleanup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-cleanup.js","sourceRoot":"","sources":["../../src/commands/legacy-cleanup.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-import.d.ts","sourceRoot":"","sources":["../../src/commands/legacy-import.ts"],"names":[],"mappings":"AAmBA,UAAU,mBAAmB;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB;AAED,wBAAsB,0BAA0B,CAAC,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC,CA+EzF"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pd legacy import openclaw — Import OpenClaw legacy data into PD runtime-v2 store.
|
|
3
|
+
*
|
|
4
|
+
* Usage:
|
|
5
|
+
* pd legacy import openclaw --workspace <path>
|
|
6
|
+
*
|
|
7
|
+
* This command is the formal operator path for migrating OpenClaw workspace data
|
|
8
|
+
* into PD runtime-v2 SQLite. It must be run before trajectory/history/context commands
|
|
9
|
+
* can return results on a workspace that only has OpenClaw legacy data.
|
|
10
|
+
*
|
|
11
|
+
* Two import stages:
|
|
12
|
+
* 1. Task/Run metadata from .state/diagnostician_tasks.json
|
|
13
|
+
* 2. Session history from .state/trajectory.db (assistant_turns, user_turns, tool_calls)
|
|
14
|
+
*/
|
|
15
|
+
import { SqliteConnection } from '@principles/core';
|
|
16
|
+
import { syncOpenClawWorkspace } from '../legacy/legacy-import.js';
|
|
17
|
+
import { importSessionHistory } from '../legacy/session-history-import.js';
|
|
18
|
+
import { resolveWorkspaceDir } from '../resolve-workspace.js';
|
|
19
|
+
export async function handleLegacyImportOpenClaw(opts) {
|
|
20
|
+
const workspaceDir = resolveWorkspaceDir(opts.workspace);
|
|
21
|
+
const connection = new SqliteConnection(workspaceDir);
|
|
22
|
+
try {
|
|
23
|
+
const openclawWorkspace = workspaceDir; // same workspace for now
|
|
24
|
+
// Stage 1: Task/Run metadata import
|
|
25
|
+
if (opts.json) {
|
|
26
|
+
console.log(JSON.stringify({ stage: 1, source: '.state/diagnostician_tasks.json' }));
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
console.log('Stage 1: Importing diagnostician tasks and runs...');
|
|
30
|
+
}
|
|
31
|
+
const syncResult = await syncOpenClawWorkspace(workspaceDir, connection);
|
|
32
|
+
if (opts.json) {
|
|
33
|
+
console.log(JSON.stringify({
|
|
34
|
+
stage: 1,
|
|
35
|
+
tasksImported: syncResult.tasksSynced,
|
|
36
|
+
runsImported: syncResult.runsSynced,
|
|
37
|
+
}));
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
console.log(` → ${syncResult.tasksSynced} tasks, ${syncResult.runsSynced} runs synced`);
|
|
41
|
+
}
|
|
42
|
+
// Stage 2: Session history import (if better-sqlite3 is available)
|
|
43
|
+
try {
|
|
44
|
+
if (opts.json) {
|
|
45
|
+
console.log(JSON.stringify({ stage: 2, source: '.state/trajectory.db' }));
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
console.log('Stage 2: Importing session history from trajectory.db...');
|
|
49
|
+
}
|
|
50
|
+
const historyResult = await importSessionHistory(openclawWorkspace, workspaceDir, () => connection.getDb());
|
|
51
|
+
if (opts.json) {
|
|
52
|
+
console.log(JSON.stringify({
|
|
53
|
+
stage: 2,
|
|
54
|
+
sessionsProcessed: historyResult.sessionsProcessed,
|
|
55
|
+
entriesImported: historyResult.entriesImported,
|
|
56
|
+
}));
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
console.log(` → ${historyResult.sessionsProcessed} sessions, ${historyResult.entriesImported} entries imported`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
catch (historyError) {
|
|
63
|
+
const msg = historyError instanceof Error ? historyError.message : String(historyError);
|
|
64
|
+
if (opts.json) {
|
|
65
|
+
console.log(JSON.stringify({
|
|
66
|
+
stage: 2,
|
|
67
|
+
skipped: true,
|
|
68
|
+
reason: `better-sqlite3 not available: ${msg}`,
|
|
69
|
+
}));
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
console.log(` → Stage 2 skipped (better-sqlite3 not available: ${msg})`);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
if (!opts.json) {
|
|
76
|
+
console.log('\nImport complete. You can now run:');
|
|
77
|
+
console.log(' pd trajectory locate --task <id> --workspace <path>');
|
|
78
|
+
console.log(' pd history query <id> --workspace <path>');
|
|
79
|
+
console.log(' pd context build <id> --workspace <path>');
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
finally {
|
|
83
|
+
connection.close();
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=legacy-import.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"legacy-import.js","sourceRoot":"","sources":["../../src/commands/legacy-import.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
interface RecordOptions {
|
|
2
|
+
reason?: string;
|
|
3
|
+
score?: number;
|
|
4
|
+
source?: string;
|
|
5
|
+
workspace?: string;
|
|
6
|
+
json?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare function handlePainRecord(opts: RecordOptions): Promise<void>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=pain-record.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pain-record.d.ts","sourceRoot":"","sources":["../../src/commands/pain-record.ts"],"names":[],"mappings":"AAiBA,UAAU,aAAa;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB;AAED,wBAAsB,gBAAgB,CAAC,IAAI,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CA6IzE"}
|