@proletariat/cli 0.3.95 → 0.3.97
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/dist/commands/config/index.js +1 -1
- package/dist/commands/config/index.js.map +1 -1
- package/dist/commands/db/repair.js +160 -35
- package/dist/commands/db/repair.js.map +1 -1
- package/dist/commands/gc.d.ts +14 -0
- package/dist/commands/gc.js +208 -0
- package/dist/commands/gc.js.map +1 -0
- package/dist/commands/linear/connect.d.ts +5 -0
- package/dist/commands/linear/connect.js +84 -0
- package/dist/commands/linear/connect.js.map +1 -1
- package/dist/commands/pr/merge.js +1 -1
- package/dist/commands/pr/merge.js.map +1 -1
- package/dist/commands/session/attach.d.ts +3 -3
- package/dist/commands/session/attach.js +37 -79
- package/dist/commands/session/attach.js.map +1 -1
- package/dist/commands/session/exec.js +1 -1
- package/dist/commands/session/exec.js.map +1 -1
- package/dist/commands/session/health.js +1 -1
- package/dist/commands/session/health.js.map +1 -1
- package/dist/commands/session/inspect.js +1 -1
- package/dist/commands/session/inspect.js.map +1 -1
- package/dist/commands/session/list.d.ts +1 -0
- package/dist/commands/session/list.js +111 -78
- package/dist/commands/session/list.js.map +1 -1
- package/dist/commands/session/peek.js +1 -1
- package/dist/commands/session/peek.js.map +1 -1
- package/dist/commands/session/poke.js +1 -1
- package/dist/commands/session/poke.js.map +1 -1
- package/dist/commands/session/prune.js +50 -11
- package/dist/commands/session/prune.js.map +1 -1
- package/dist/commands/session/restart.js +1 -1
- package/dist/commands/session/restart.js.map +1 -1
- package/dist/commands/session/watch.d.ts +1 -0
- package/dist/commands/session/watch.js +46 -2
- package/dist/commands/session/watch.js.map +1 -1
- package/dist/commands/{action → sync}/index.d.ts +2 -6
- package/dist/commands/sync/index.js +68 -0
- package/dist/commands/sync/index.js.map +1 -0
- package/dist/commands/sync/pause.d.ts +10 -0
- package/dist/commands/sync/pause.js +35 -0
- package/dist/commands/sync/pause.js.map +1 -0
- package/dist/commands/sync/queue.d.ts +10 -0
- package/dist/commands/sync/queue.js +106 -0
- package/dist/commands/sync/queue.js.map +1 -0
- package/dist/commands/sync/resume.d.ts +10 -0
- package/dist/commands/sync/resume.js +34 -0
- package/dist/commands/sync/resume.js.map +1 -0
- package/dist/commands/sync/start.d.ts +11 -0
- package/dist/commands/sync/start.js +73 -0
- package/dist/commands/sync/start.js.map +1 -0
- package/dist/commands/sync/status.d.ts +10 -0
- package/dist/commands/sync/status.js +40 -0
- package/dist/commands/sync/status.js.map +1 -0
- package/dist/commands/sync/stop.d.ts +10 -0
- package/dist/commands/sync/stop.js +39 -0
- package/dist/commands/sync/stop.js.map +1 -0
- package/dist/commands/ticket/create.js +1 -1
- package/dist/commands/ticket/create.js.map +1 -1
- package/dist/commands/ticket/edit.js +1 -1
- package/dist/commands/ticket/edit.js.map +1 -1
- package/dist/commands/ticket/list.js +1 -1
- package/dist/commands/ticket/list.js.map +1 -1
- package/dist/commands/ticket/update.js +1 -1
- package/dist/commands/ticket/update.js.map +1 -1
- package/dist/commands/work/complete.d.ts +1 -0
- package/dist/commands/work/complete.js +27 -25
- package/dist/commands/work/complete.js.map +1 -1
- package/dist/commands/work/drop.d.ts +14 -0
- package/dist/commands/work/drop.js +215 -0
- package/dist/commands/work/drop.js.map +1 -0
- package/dist/commands/work/ready.d.ts +1 -0
- package/dist/commands/work/ready.js +26 -25
- package/dist/commands/work/ready.js.map +1 -1
- package/dist/commands/work/resolve.js +1 -1
- package/dist/commands/work/resolve.js.map +1 -1
- package/dist/commands/work/ship.d.ts +1 -0
- package/dist/commands/work/ship.js +33 -32
- package/dist/commands/work/ship.js.map +1 -1
- package/dist/commands/work/start.d.ts +2 -0
- package/dist/commands/work/start.js +172 -125
- package/dist/commands/work/start.js.map +1 -1
- package/dist/commands/work/stop.d.ts +1 -0
- package/dist/commands/work/stop.js +40 -0
- package/dist/commands/work/stop.js.map +1 -1
- package/dist/lib/agents/commands.js +7 -5
- package/dist/lib/agents/commands.js.map +1 -1
- package/dist/lib/dashboard/data.js +1 -1
- package/dist/lib/dashboard/data.js.map +1 -1
- package/dist/lib/database/db-safety.d.ts +22 -0
- package/dist/lib/database/db-safety.js +91 -4
- package/dist/lib/database/db-safety.js.map +1 -1
- package/dist/lib/database/drizzle-schema.d.ts +17 -0
- package/dist/lib/database/drizzle-schema.js +1 -0
- package/dist/lib/database/drizzle-schema.js.map +1 -1
- package/dist/lib/database/index.d.ts +1 -1
- package/dist/lib/database/index.js +1 -1
- package/dist/lib/database/index.js.map +1 -1
- package/dist/lib/database/migrations/0017_drop_agent_work_fk.d.ts +13 -0
- package/dist/lib/database/migrations/0017_drop_agent_work_fk.js +85 -0
- package/dist/lib/database/migrations/0017_drop_agent_work_fk.js.map +1 -0
- package/dist/lib/database/migrations/0018_create_ticket_refs.d.ts +11 -0
- package/dist/lib/database/migrations/0018_create_ticket_refs.js +40 -0
- package/dist/lib/database/migrations/0018_create_ticket_refs.js.map +1 -0
- package/dist/lib/database/migrations/0019_gc_artifact_cleanup.d.ts +9 -0
- package/dist/lib/database/migrations/0019_gc_artifact_cleanup.js +23 -0
- package/dist/lib/database/migrations/0019_gc_artifact_cleanup.js.map +1 -0
- package/dist/lib/database/migrations/0020_transition_map.d.ts +2 -0
- package/dist/lib/database/migrations/0020_transition_map.js +27 -0
- package/dist/lib/database/migrations/0020_transition_map.js.map +1 -0
- package/dist/lib/database/migrations/index.js +8 -0
- package/dist/lib/database/migrations/index.js.map +1 -1
- package/dist/lib/execution/config.d.ts +10 -0
- package/dist/lib/execution/config.js +24 -0
- package/dist/lib/execution/config.js.map +1 -1
- package/dist/lib/execution/devcontainer.js +1 -1
- package/dist/lib/execution/devcontainer.js.map +1 -1
- package/dist/lib/execution/preflight.d.ts +51 -0
- package/dist/lib/execution/preflight.js +278 -0
- package/dist/lib/execution/preflight.js.map +1 -0
- package/dist/lib/execution/runners/docker-management.d.ts +9 -0
- package/dist/lib/execution/runners/docker-management.js +14 -3
- package/dist/lib/execution/runners/docker-management.js.map +1 -1
- package/dist/lib/execution/runners/prompt-builder.d.ts +6 -0
- package/dist/lib/execution/runners/prompt-builder.js +53 -10
- package/dist/lib/execution/runners/prompt-builder.js.map +1 -1
- package/dist/lib/execution/runners/shared.d.ts +1 -1
- package/dist/lib/execution/runners/shared.js +1 -1
- package/dist/lib/execution/runners/shared.js.map +1 -1
- package/dist/lib/execution/session-utils.d.ts +39 -0
- package/dist/lib/execution/session-utils.js +111 -0
- package/dist/lib/execution/session-utils.js.map +1 -1
- package/dist/lib/execution/spawner.d.ts +11 -1
- package/dist/lib/execution/spawner.js +46 -17
- package/dist/lib/execution/spawner.js.map +1 -1
- package/dist/lib/execution/storage.js +2 -1
- package/dist/lib/execution/storage.js.map +1 -1
- package/dist/lib/execution/ticket-refs.d.ts +71 -0
- package/dist/lib/execution/ticket-refs.js +125 -0
- package/dist/lib/execution/ticket-refs.js.map +1 -0
- package/dist/lib/execution/types.d.ts +7 -2
- package/dist/lib/execution/types.js +5 -3
- package/dist/lib/execution/types.js.map +1 -1
- package/dist/lib/external-issues/utils.d.ts +25 -0
- package/dist/lib/external-issues/utils.js +32 -0
- package/dist/lib/external-issues/utils.js.map +1 -0
- package/dist/lib/gc/index.d.ts +179 -0
- package/dist/lib/gc/index.js +655 -0
- package/dist/lib/gc/index.js.map +1 -0
- package/dist/lib/mcp/tools/action.js +1 -1
- package/dist/lib/mcp/tools/action.js.map +1 -1
- package/dist/lib/mcp/tools/ticket.js +1 -1
- package/dist/lib/mcp/tools/ticket.js.map +1 -1
- package/dist/lib/orchestrate/actions.js +30 -0
- package/dist/lib/orchestrate/actions.js.map +1 -1
- package/dist/lib/orchestrate/poller.js +3 -3
- package/dist/lib/orchestrate/poller.js.map +1 -1
- package/dist/lib/orchestrate/presets.js +2 -1
- package/dist/lib/orchestrate/presets.js.map +1 -1
- package/dist/lib/orchestrate/types.d.ts +1 -1
- package/dist/lib/orchestrate/types.js +1 -0
- package/dist/lib/orchestrate/types.js.map +1 -1
- package/dist/lib/pmo/index.js +1 -1
- package/dist/lib/pmo/index.js.map +1 -1
- package/dist/lib/pmo/markdown.js +1 -1
- package/dist/lib/pmo/markdown.js.map +1 -1
- package/dist/lib/pmo/schema.d.ts +3 -1
- package/dist/lib/pmo/schema.js +26 -2
- package/dist/lib/pmo/schema.js.map +1 -1
- package/dist/lib/pmo/storage/actions.js +1 -1
- package/dist/lib/pmo/storage/actions.js.map +1 -1
- package/dist/lib/pmo/storage/base.js +37 -15
- package/dist/lib/pmo/storage/base.js.map +1 -1
- package/dist/lib/pmo/storage/projects.js +2 -1
- package/dist/lib/pmo/storage/projects.js.map +1 -1
- package/dist/lib/pmo/storage/statuses.js +1 -1
- package/dist/lib/pmo/storage/statuses.js.map +1 -1
- package/dist/lib/pmo/storage/subtasks.js +1 -1
- package/dist/lib/pmo/storage/subtasks.js.map +1 -1
- package/dist/lib/pmo/storage/templates.js +1 -1
- package/dist/lib/pmo/storage/templates.js.map +1 -1
- package/dist/lib/pmo/storage/tickets.js +2 -1
- package/dist/lib/pmo/storage/tickets.js.map +1 -1
- package/dist/lib/pmo/storage/workflow-rules.js +1 -1
- package/dist/lib/pmo/storage/workflow-rules.js.map +1 -1
- package/dist/lib/pmo/utils.d.ts +6 -189
- package/dist/lib/pmo/utils.js +6 -306
- package/dist/lib/pmo/utils.js.map +1 -1
- package/dist/lib/prompt-json.d.ts +31 -0
- package/dist/lib/prompt-json.js.map +1 -1
- package/dist/lib/providers/auto-mapper.d.ts +45 -0
- package/dist/lib/providers/auto-mapper.js +115 -0
- package/dist/lib/providers/auto-mapper.js.map +1 -0
- package/dist/lib/providers/state-intents.d.ts +20 -0
- package/dist/lib/providers/state-intents.js +61 -7
- package/dist/lib/providers/state-intents.js.map +1 -1
- package/dist/lib/providers/state-resolution.d.ts +15 -11
- package/dist/lib/providers/state-resolution.js +54 -48
- package/dist/lib/providers/state-resolution.js.map +1 -1
- package/dist/lib/providers/transition-map.d.ts +59 -0
- package/dist/lib/providers/transition-map.js +113 -0
- package/dist/lib/providers/transition-map.js.map +1 -0
- package/dist/lib/session/heartbeat.js +1 -1
- package/dist/lib/session/heartbeat.js.map +1 -1
- package/dist/lib/session/index.d.ts +3 -1
- package/dist/lib/session/index.js +3 -1
- package/dist/lib/session/index.js.map +1 -1
- package/dist/lib/session/tmux-watchdog.d.ts +157 -0
- package/dist/lib/session/tmux-watchdog.js +424 -0
- package/dist/lib/session/tmux-watchdog.js.map +1 -0
- package/dist/lib/session/watcher.d.ts +22 -4
- package/dist/lib/session/watcher.js +66 -8
- package/dist/lib/session/watcher.js.map +1 -1
- package/dist/lib/sync/daemon-process.d.ts +9 -0
- package/dist/lib/sync/daemon-process.js +184 -0
- package/dist/lib/sync/daemon-process.js.map +1 -0
- package/dist/lib/sync/daemon.d.ts +39 -0
- package/dist/lib/sync/daemon.js +91 -0
- package/dist/lib/sync/daemon.js.map +1 -0
- package/dist/lib/sync/engine.d.ts +38 -0
- package/dist/lib/sync/engine.js +145 -0
- package/dist/lib/sync/engine.js.map +1 -0
- package/dist/lib/sync/merge-queue.d.ts +116 -0
- package/dist/lib/sync/merge-queue.js +321 -0
- package/dist/lib/sync/merge-queue.js.map +1 -0
- package/dist/lib/sync/reconciler.d.ts +44 -0
- package/dist/lib/sync/reconciler.js +88 -0
- package/dist/lib/sync/reconciler.js.map +1 -0
- package/dist/lib/utils/text.d.ts +44 -0
- package/dist/lib/utils/text.js +72 -0
- package/dist/lib/utils/text.js.map +1 -0
- package/dist/lib/work-lifecycle/post-execution.js +1 -1
- package/dist/lib/work-lifecycle/post-execution.js.map +1 -1
- package/dist/lib/work-lifecycle/settings.d.ts +138 -0
- package/dist/lib/work-lifecycle/settings.js +213 -0
- package/dist/lib/work-lifecycle/settings.js.map +1 -0
- package/dist/lib/work-lifecycle/transition.d.ts +73 -0
- package/dist/lib/work-lifecycle/transition.js +124 -0
- package/dist/lib/work-lifecycle/transition.js.map +1 -0
- package/oclif.manifest.json +3235 -3380
- package/package.json +1 -1
- package/dist/commands/action/create.d.ts +0 -26
- package/dist/commands/action/create.js +0 -245
- package/dist/commands/action/create.js.map +0 -1
- package/dist/commands/action/delete.d.ts +0 -18
- package/dist/commands/action/delete.js +0 -78
- package/dist/commands/action/delete.js.map +0 -1
- package/dist/commands/action/index.js +0 -103
- package/dist/commands/action/index.js.map +0 -1
- package/dist/commands/action/list.d.ts +0 -15
- package/dist/commands/action/list.js +0 -90
- package/dist/commands/action/list.js.map +0 -1
- package/dist/commands/action/run.d.ts +0 -20
- package/dist/commands/action/run.js +0 -188
- package/dist/commands/action/run.js.map +0 -1
- package/dist/commands/action/show.d.ts +0 -17
- package/dist/commands/action/show.js +0 -78
- package/dist/commands/action/show.js.map +0 -1
- package/dist/commands/action/update.d.ts +0 -27
- package/dist/commands/action/update.js +0 -288
- package/dist/commands/action/update.js.map +0 -1
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { Flags } from '@oclif/core';
|
|
2
|
+
import { PMOCommand, pmoBaseFlags } from '../../lib/pmo/index.js';
|
|
3
|
+
import { styles } from '../../lib/styles.js';
|
|
4
|
+
import { runSyncCycle } from '../../lib/sync/engine.js';
|
|
5
|
+
import { shouldOutputJson, outputSuccessAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
6
|
+
export default class Sync extends PMOCommand {
|
|
7
|
+
static description = 'Reconcile ticket state with GitHub PR status';
|
|
8
|
+
static examples = [
|
|
9
|
+
'<%= config.bin %> <%= command.id %>',
|
|
10
|
+
'<%= config.bin %> <%= command.id %> --dry-run',
|
|
11
|
+
];
|
|
12
|
+
static flags = {
|
|
13
|
+
...pmoBaseFlags,
|
|
14
|
+
'dry-run': Flags.boolean({
|
|
15
|
+
description: 'Show what would change without applying',
|
|
16
|
+
default: false,
|
|
17
|
+
}),
|
|
18
|
+
};
|
|
19
|
+
async execute() {
|
|
20
|
+
const { flags } = await this.parse(Sync);
|
|
21
|
+
const db = this.requireDB();
|
|
22
|
+
const projectId = await this.requireProject();
|
|
23
|
+
const jsonMode = shouldOutputJson(flags);
|
|
24
|
+
const report = await runSyncCycle(db, this.storage, projectId, {
|
|
25
|
+
cwd: this.hqPath ?? process.cwd(),
|
|
26
|
+
log: jsonMode ? undefined : (msg) => this.log(msg),
|
|
27
|
+
dryRun: flags['dry-run'],
|
|
28
|
+
});
|
|
29
|
+
if (jsonMode) {
|
|
30
|
+
outputSuccessAsJson({
|
|
31
|
+
checked: report.result.checked,
|
|
32
|
+
actions: report.result.actions,
|
|
33
|
+
applied: report.applied.length,
|
|
34
|
+
failed: report.failed.length,
|
|
35
|
+
errors: report.result.errors,
|
|
36
|
+
}, createMetadata('sync', flags));
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
// Summary
|
|
40
|
+
const { result, applied, skipped, failed } = report;
|
|
41
|
+
if (result.actions.length === 0) {
|
|
42
|
+
this.log(styles.muted('All tickets in sync — no changes needed.'));
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
this.log('');
|
|
46
|
+
this.log(styles.emphasis('Sync Summary:'));
|
|
47
|
+
this.log(` Checked: ${result.checked} ticket(s)`);
|
|
48
|
+
if (applied.length > 0) {
|
|
49
|
+
this.log(styles.success(` Applied: ${applied.length} correction(s)`));
|
|
50
|
+
}
|
|
51
|
+
if (skipped.length > 0) {
|
|
52
|
+
this.log(styles.warning(` Skipped: ${skipped.length} (dry-run)`));
|
|
53
|
+
}
|
|
54
|
+
if (failed.length > 0) {
|
|
55
|
+
this.log(styles.error(` Failed: ${failed.length}`));
|
|
56
|
+
for (const f of failed) {
|
|
57
|
+
this.log(styles.error(` ${f.action.ticketId}: ${f.error}`));
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
if (result.errors.length > 0) {
|
|
61
|
+
this.log(styles.error(` Errors: ${result.errors.length}`));
|
|
62
|
+
for (const e of result.errors) {
|
|
63
|
+
this.log(styles.error(` ${e.ticketId}: ${e.error}`));
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/sync/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { RuntimeCommand } from '../../lib/runtime-command.js';
|
|
2
|
+
export default class SyncPause extends RuntimeCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
};
|
|
9
|
+
execute(): Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { RuntimeCommand, runtimeBaseFlags } from '../../lib/runtime-command.js';
|
|
2
|
+
import { styles } from '../../lib/styles.js';
|
|
3
|
+
import { isMergeQueuePaused, pauseMergeQueue, } from '../../lib/sync/merge-queue.js';
|
|
4
|
+
import { shouldOutputJson, outputSuccessAsJson, outputErrorAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
5
|
+
export default class SyncPause extends RuntimeCommand {
|
|
6
|
+
static description = 'Pause the merge queue (keep monitoring but stop merging)';
|
|
7
|
+
static examples = [
|
|
8
|
+
'<%= config.bin %> <%= command.id %>',
|
|
9
|
+
];
|
|
10
|
+
static flags = {
|
|
11
|
+
...runtimeBaseFlags,
|
|
12
|
+
};
|
|
13
|
+
async execute() {
|
|
14
|
+
const { flags } = await this.parse(SyncPause);
|
|
15
|
+
const hqPath = this.requireHQ();
|
|
16
|
+
const jsonMode = shouldOutputJson(flags);
|
|
17
|
+
if (isMergeQueuePaused(hqPath)) {
|
|
18
|
+
if (jsonMode) {
|
|
19
|
+
outputErrorAsJson('ALREADY_PAUSED', 'Merge queue is already paused', createMetadata('sync pause', flags));
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
this.log(styles.warning('Merge queue is already paused.'));
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const state = pauseMergeQueue(hqPath);
|
|
26
|
+
if (jsonMode) {
|
|
27
|
+
outputSuccessAsJson({ paused: true, pausedAt: state.pausedAt }, createMetadata('sync pause', flags));
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
this.log(styles.success('Merge queue paused.'));
|
|
31
|
+
this.log(styles.muted('The daemon will continue monitoring but will not merge PRs.'));
|
|
32
|
+
this.log(styles.muted('Resume with: prlt sync resume'));
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=pause.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pause.js","sourceRoot":"","sources":["../../../src/commands/sync/pause.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA;AAC/E,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC5C,OAAO,EACL,kBAAkB,EAClB,eAAe,GAChB,MAAM,+BAA+B,CAAA;AACtC,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,iBAAiB,EACjB,cAAc,GACf,MAAM,0BAA0B,CAAA;AAEjC,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,cAAc;IACnD,MAAM,CAAC,WAAW,GAAG,0DAA0D,CAAA;IAE/E,MAAM,CAAC,QAAQ,GAAG;QAChB,qCAAqC;KACtC,CAAA;IAED,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,gBAAgB;KACpB,CAAA;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;QAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;QAC/B,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAA;QAExC,IAAI,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC;YAC/B,IAAI,QAAQ,EAAE,CAAC;gBACb,iBAAiB,CAAC,gBAAgB,EAAE,+BAA+B,EAAE,cAAc,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,CAAA;gBACzG,OAAM;YACR,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,gCAAgC,CAAC,CAAC,CAAA;YAC1D,OAAM;QACR,CAAC;QAED,MAAM,KAAK,GAAG,eAAe,CAAC,MAAM,CAAC,CAAA;QAErC,IAAI,QAAQ,EAAE,CAAC;YACb,mBAAmB,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,EAAE,cAAc,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,CAAA;YACpG,OAAM;QACR,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC,CAAA;QAC/C,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,6DAA6D,CAAC,CAAC,CAAA;QACrF,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,+BAA+B,CAAC,CAAC,CAAA;IACzD,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { RuntimeCommand } from '../../lib/runtime-command.js';
|
|
2
|
+
export default class SyncQueue extends RuntimeCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
};
|
|
9
|
+
execute(): Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { RuntimeCommand, runtimeBaseFlags } from '../../lib/runtime-command.js';
|
|
2
|
+
import { styles } from '../../lib/styles.js';
|
|
3
|
+
import { getMergeQueueState, buildMergeQueue, } from '../../lib/sync/merge-queue.js';
|
|
4
|
+
import { shouldOutputJson, outputSuccessAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
5
|
+
export default class SyncQueue extends RuntimeCommand {
|
|
6
|
+
static description = 'Show the merge queue state';
|
|
7
|
+
static examples = [
|
|
8
|
+
'<%= config.bin %> <%= command.id %>',
|
|
9
|
+
];
|
|
10
|
+
static flags = {
|
|
11
|
+
...runtimeBaseFlags,
|
|
12
|
+
};
|
|
13
|
+
async execute() {
|
|
14
|
+
const { flags } = await this.parse(SyncQueue);
|
|
15
|
+
const hqPath = this.requireHQ();
|
|
16
|
+
const jsonMode = shouldOutputJson(flags);
|
|
17
|
+
const state = getMergeQueueState(hqPath);
|
|
18
|
+
// Build current queue for display
|
|
19
|
+
let queue = [];
|
|
20
|
+
try {
|
|
21
|
+
const entries = buildMergeQueue({ cwd: hqPath });
|
|
22
|
+
queue = entries.map(e => ({
|
|
23
|
+
prNumber: e.pr.number,
|
|
24
|
+
headBranch: e.pr.headBranch,
|
|
25
|
+
ticketId: e.ticketId,
|
|
26
|
+
priority: e.priority,
|
|
27
|
+
}));
|
|
28
|
+
}
|
|
29
|
+
catch {
|
|
30
|
+
// Queue building may fail if gh is unavailable
|
|
31
|
+
}
|
|
32
|
+
if (jsonMode) {
|
|
33
|
+
outputSuccessAsJson({
|
|
34
|
+
...state,
|
|
35
|
+
queue,
|
|
36
|
+
}, createMetadata('sync queue', flags));
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
// Human output
|
|
40
|
+
this.log('');
|
|
41
|
+
this.log(styles.emphasis('Merge Queue'));
|
|
42
|
+
this.log('');
|
|
43
|
+
// Status line
|
|
44
|
+
if (state.paused) {
|
|
45
|
+
this.log(styles.warning(` Status: PAUSED (since ${formatTime(state.pausedAt)})`));
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
this.log(styles.success(' Status: ACTIVE'));
|
|
49
|
+
}
|
|
50
|
+
if (state.lastCycleAt) {
|
|
51
|
+
this.log(styles.muted(` Last cycle: ${formatTime(state.lastCycleAt)}`));
|
|
52
|
+
}
|
|
53
|
+
// Current PR
|
|
54
|
+
this.log('');
|
|
55
|
+
if (state.currentPR) {
|
|
56
|
+
this.log(styles.emphasis(' Processing:'));
|
|
57
|
+
this.log(` PR #${state.currentPR.prNumber} (${state.currentPR.headBranch})`);
|
|
58
|
+
if (state.currentPR.ticketId) {
|
|
59
|
+
this.log(` Ticket: ${state.currentPR.ticketId}`);
|
|
60
|
+
}
|
|
61
|
+
this.log(` Priority: P${state.currentPR.priority}`);
|
|
62
|
+
this.log(` Rebased: ${formatTime(state.currentPR.rebasedAt)}`);
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
this.log(styles.muted(' Processing: none'));
|
|
66
|
+
}
|
|
67
|
+
// Queue
|
|
68
|
+
this.log('');
|
|
69
|
+
if (queue.length > 0) {
|
|
70
|
+
this.log(styles.emphasis(` Queued (${queue.length}):`));
|
|
71
|
+
for (const entry of queue) {
|
|
72
|
+
const ticket = entry.ticketId ? ` [${entry.ticketId}]` : '';
|
|
73
|
+
this.log(` PR #${entry.prNumber}${ticket} — P${entry.priority} — ${entry.headBranch}`);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
this.log(styles.muted(' Queued: none'));
|
|
78
|
+
}
|
|
79
|
+
// Last merged
|
|
80
|
+
if (state.lastMergedPR) {
|
|
81
|
+
this.log('');
|
|
82
|
+
this.log(styles.emphasis(' Last merged:'));
|
|
83
|
+
this.log(styles.success(` PR #${state.lastMergedPR.prNumber} (${state.lastMergedPR.headBranch}) at ${formatTime(state.lastMergedPR.mergedAt)}`));
|
|
84
|
+
}
|
|
85
|
+
// Ejected PRs
|
|
86
|
+
if (state.ejectedPRs.length > 0) {
|
|
87
|
+
this.log('');
|
|
88
|
+
this.log(styles.emphasis(` Ejected (${state.ejectedPRs.length}):`));
|
|
89
|
+
for (const ej of state.ejectedPRs.slice(0, 5)) {
|
|
90
|
+
this.log(styles.warning(` PR #${ej.prNumber} (${ej.headBranch}) — ${ej.reason}`));
|
|
91
|
+
this.log(styles.muted(` at ${formatTime(ej.ejectedAt)}`));
|
|
92
|
+
}
|
|
93
|
+
if (state.ejectedPRs.length > 5) {
|
|
94
|
+
this.log(styles.muted(` ... and ${state.ejectedPRs.length - 5} more`));
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
this.log('');
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
function formatTime(iso) {
|
|
101
|
+
if (!iso)
|
|
102
|
+
return 'unknown';
|
|
103
|
+
const d = new Date(iso);
|
|
104
|
+
return d.toLocaleString();
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=queue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../../src/commands/sync/queue.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { RuntimeCommand } from '../../lib/runtime-command.js';
|
|
2
|
+
export default class SyncResume extends RuntimeCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
};
|
|
9
|
+
execute(): Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { RuntimeCommand, runtimeBaseFlags } from '../../lib/runtime-command.js';
|
|
2
|
+
import { styles } from '../../lib/styles.js';
|
|
3
|
+
import { isMergeQueuePaused, resumeMergeQueue, } from '../../lib/sync/merge-queue.js';
|
|
4
|
+
import { shouldOutputJson, outputSuccessAsJson, outputErrorAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
5
|
+
export default class SyncResume extends RuntimeCommand {
|
|
6
|
+
static description = 'Resume the merge queue';
|
|
7
|
+
static examples = [
|
|
8
|
+
'<%= config.bin %> <%= command.id %>',
|
|
9
|
+
];
|
|
10
|
+
static flags = {
|
|
11
|
+
...runtimeBaseFlags,
|
|
12
|
+
};
|
|
13
|
+
async execute() {
|
|
14
|
+
const { flags } = await this.parse(SyncResume);
|
|
15
|
+
const hqPath = this.requireHQ();
|
|
16
|
+
const jsonMode = shouldOutputJson(flags);
|
|
17
|
+
if (!isMergeQueuePaused(hqPath)) {
|
|
18
|
+
if (jsonMode) {
|
|
19
|
+
outputErrorAsJson('NOT_PAUSED', 'Merge queue is not paused', createMetadata('sync resume', flags));
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
this.log(styles.warning('Merge queue is not paused.'));
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
resumeMergeQueue(hqPath);
|
|
26
|
+
if (jsonMode) {
|
|
27
|
+
outputSuccessAsJson({ paused: false }, createMetadata('sync resume', flags));
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
this.log(styles.success('Merge queue resumed.'));
|
|
31
|
+
this.log(styles.muted('The daemon will process PRs on the next cycle.'));
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=resume.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resume.js","sourceRoot":"","sources":["../../../src/commands/sync/resume.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA;AAC/E,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC5C,OAAO,EACL,kBAAkB,EAClB,gBAAgB,GACjB,MAAM,+BAA+B,CAAA;AACtC,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,iBAAiB,EACjB,cAAc,GACf,MAAM,0BAA0B,CAAA;AAEjC,MAAM,CAAC,OAAO,OAAO,UAAW,SAAQ,cAAc;IACpD,MAAM,CAAC,WAAW,GAAG,wBAAwB,CAAA;IAE7C,MAAM,CAAC,QAAQ,GAAG;QAChB,qCAAqC;KACtC,CAAA;IAED,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,gBAAgB;KACpB,CAAA;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;QAC9C,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;QAC/B,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAA;QAExC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC;YAChC,IAAI,QAAQ,EAAE,CAAC;gBACb,iBAAiB,CAAC,YAAY,EAAE,2BAA2B,EAAE,cAAc,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC,CAAA;gBAClG,OAAM;YACR,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,CAAA;YACtD,OAAM;QACR,CAAC;QAED,gBAAgB,CAAC,MAAM,CAAC,CAAA;QAExB,IAAI,QAAQ,EAAE,CAAC;YACb,mBAAmB,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,cAAc,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC,CAAA;YAC5E,OAAM;QACR,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC,CAAA;QAChD,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,gDAAgD,CAAC,CAAC,CAAA;IAC1E,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { RuntimeCommand } from '../../lib/runtime-command.js';
|
|
2
|
+
export default class SyncStart extends RuntimeCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
interval: import("@oclif/core/interfaces").OptionFlag<number, import("@oclif/core/interfaces").CustomOptions>;
|
|
7
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
9
|
+
};
|
|
10
|
+
execute(): Promise<void>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { Flags } from '@oclif/core';
|
|
2
|
+
import { fork } from 'node:child_process';
|
|
3
|
+
import * as path from 'node:path';
|
|
4
|
+
import { RuntimeCommand, runtimeBaseFlags } from '../../lib/runtime-command.js';
|
|
5
|
+
import { styles } from '../../lib/styles.js';
|
|
6
|
+
import { isDaemonRunning, getDaemonInfo, writeDaemonInfo, getDaemonLogPath, } from '../../lib/sync/daemon.js';
|
|
7
|
+
import { shouldOutputJson, outputSuccessAsJson, outputErrorAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
8
|
+
export default class SyncStart extends RuntimeCommand {
|
|
9
|
+
static description = 'Start the board sync daemon';
|
|
10
|
+
static examples = [
|
|
11
|
+
'<%= config.bin %> <%= command.id %>',
|
|
12
|
+
'<%= config.bin %> <%= command.id %> --interval 30',
|
|
13
|
+
];
|
|
14
|
+
static flags = {
|
|
15
|
+
...runtimeBaseFlags,
|
|
16
|
+
interval: Flags.integer({
|
|
17
|
+
char: 'i',
|
|
18
|
+
description: 'Poll interval in seconds',
|
|
19
|
+
default: 60,
|
|
20
|
+
}),
|
|
21
|
+
};
|
|
22
|
+
async execute() {
|
|
23
|
+
const { flags } = await this.parse(SyncStart);
|
|
24
|
+
const hqPath = this.requireHQ();
|
|
25
|
+
const jsonMode = shouldOutputJson(flags);
|
|
26
|
+
// Check if already running
|
|
27
|
+
if (isDaemonRunning(hqPath)) {
|
|
28
|
+
const info = getDaemonInfo(hqPath);
|
|
29
|
+
if (jsonMode) {
|
|
30
|
+
outputErrorAsJson('ALREADY_RUNNING', `Daemon already running (PID ${info?.pid})`, createMetadata('sync start', flags));
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
this.log(styles.warning(`Sync daemon already running (PID ${info?.pid})`));
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const interval = flags.interval;
|
|
37
|
+
// Spawn a detached child process that runs the sync loop
|
|
38
|
+
const daemonScript = path.join(import.meta.dirname, '..', '..', 'lib', 'sync', 'daemon-process.js');
|
|
39
|
+
const logPath = getDaemonLogPath(hqPath);
|
|
40
|
+
const child = fork(daemonScript, [hqPath, String(interval)], {
|
|
41
|
+
detached: true,
|
|
42
|
+
stdio: 'ignore',
|
|
43
|
+
env: { ...process.env },
|
|
44
|
+
});
|
|
45
|
+
child.unref();
|
|
46
|
+
if (!child.pid) {
|
|
47
|
+
if (jsonMode) {
|
|
48
|
+
outputErrorAsJson('SPAWN_FAILED', 'Failed to spawn daemon process', createMetadata('sync start', flags));
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
this.error('Failed to spawn daemon process');
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
// Write PID file
|
|
55
|
+
writeDaemonInfo(hqPath, {
|
|
56
|
+
pid: child.pid,
|
|
57
|
+
startedAt: new Date().toISOString(),
|
|
58
|
+
intervalSeconds: interval,
|
|
59
|
+
});
|
|
60
|
+
if (jsonMode) {
|
|
61
|
+
outputSuccessAsJson({
|
|
62
|
+
pid: child.pid,
|
|
63
|
+
interval,
|
|
64
|
+
logPath,
|
|
65
|
+
}, createMetadata('sync start', flags));
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
this.log(styles.success(`Sync daemon started (PID ${child.pid})`));
|
|
69
|
+
this.log(` Interval: every ${interval}s`);
|
|
70
|
+
this.log(` Log: ${logPath}`);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=start.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"start.js","sourceRoot":"","sources":["../../../src/commands/sync/start.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAA;AACzC,OAAO,KAAK,IAAI,MAAM,WAAW,CAAA;AACjC,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA;AAC/E,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC5C,OAAO,EACL,eAAe,EACf,aAAa,EACb,eAAe,EACf,gBAAgB,GACjB,MAAM,0BAA0B,CAAA;AACjC,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,iBAAiB,EACjB,cAAc,GACf,MAAM,0BAA0B,CAAA;AAEjC,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,cAAc;IACnD,MAAM,CAAC,WAAW,GAAG,6BAA6B,CAAA;IAElD,MAAM,CAAC,QAAQ,GAAG;QAChB,qCAAqC;QACrC,mDAAmD;KACpD,CAAA;IAED,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,gBAAgB;QACnB,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC;YACtB,IAAI,EAAE,GAAG;YACT,WAAW,EAAE,0BAA0B;YACvC,OAAO,EAAE,EAAE;SACZ,CAAC;KACH,CAAA;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;QAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;QAC/B,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAA;QAExC,2BAA2B;QAC3B,IAAI,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC;YAC5B,MAAM,IAAI,GAAG,aAAa,CAAC,MAAM,CAAC,CAAA;YAClC,IAAI,QAAQ,EAAE,CAAC;gBACb,iBAAiB,CAAC,iBAAiB,EAAE,+BAA+B,IAAI,EAAE,GAAG,GAAG,EAAE,cAAc,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,CAAA;gBACtH,OAAM;YACR,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,oCAAoC,IAAI,EAAE,GAAG,GAAG,CAAC,CAAC,CAAA;YAC1E,OAAM;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAA;QAE/B,yDAAyD;QACzD,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,mBAAmB,CAAC,CAAA;QACnG,MAAM,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAA;QAExC,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE;YAC3D,QAAQ,EAAE,IAAI;YACd,KAAK,EAAE,QAAQ;YACf,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE;SACxB,CAAC,CAAA;QAEF,KAAK,CAAC,KAAK,EAAE,CAAA;QAEb,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;YACf,IAAI,QAAQ,EAAE,CAAC;gBACb,iBAAiB,CAAC,cAAc,EAAE,gCAAgC,EAAE,cAAc,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,CAAA;gBACxG,OAAM;YACR,CAAC;YACD,IAAI,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAA;YAC5C,OAAM;QACR,CAAC;QAED,iBAAiB;QACjB,eAAe,CAAC,MAAM,EAAE;YACtB,GAAG,EAAE,KAAK,CAAC,GAAG;YACd,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,eAAe,EAAE,QAAQ;SAC1B,CAAC,CAAA;QAEF,IAAI,QAAQ,EAAE,CAAC;YACb,mBAAmB,CAAC;gBAClB,GAAG,EAAE,KAAK,CAAC,GAAG;gBACd,QAAQ;gBACR,OAAO;aACR,EAAE,cAAc,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,CAAA;YACvC,OAAM;QACR,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,4BAA4B,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;QAClE,IAAI,CAAC,GAAG,CAAC,qBAAqB,QAAQ,GAAG,CAAC,CAAA;QAC1C,IAAI,CAAC,GAAG,CAAC,UAAU,OAAO,EAAE,CAAC,CAAA;IAC/B,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { RuntimeCommand } from '../../lib/runtime-command.js';
|
|
2
|
+
export default class SyncStatus extends RuntimeCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
};
|
|
9
|
+
execute(): Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { RuntimeCommand, runtimeBaseFlags } from '../../lib/runtime-command.js';
|
|
2
|
+
import { styles } from '../../lib/styles.js';
|
|
3
|
+
import { isDaemonRunning, getDaemonInfo, getDaemonLogPath } from '../../lib/sync/daemon.js';
|
|
4
|
+
import { shouldOutputJson, outputSuccessAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
5
|
+
export default class SyncStatus extends RuntimeCommand {
|
|
6
|
+
static description = 'Check the board sync daemon status';
|
|
7
|
+
static examples = [
|
|
8
|
+
'<%= config.bin %> <%= command.id %>',
|
|
9
|
+
];
|
|
10
|
+
static flags = {
|
|
11
|
+
...runtimeBaseFlags,
|
|
12
|
+
};
|
|
13
|
+
async execute() {
|
|
14
|
+
const { flags } = await this.parse(SyncStatus);
|
|
15
|
+
const hqPath = this.requireHQ();
|
|
16
|
+
const jsonMode = shouldOutputJson(flags);
|
|
17
|
+
const running = isDaemonRunning(hqPath);
|
|
18
|
+
const info = running ? getDaemonInfo(hqPath) : null;
|
|
19
|
+
const logPath = getDaemonLogPath(hqPath);
|
|
20
|
+
if (jsonMode) {
|
|
21
|
+
outputSuccessAsJson({
|
|
22
|
+
running,
|
|
23
|
+
...(info ?? {}),
|
|
24
|
+
logPath,
|
|
25
|
+
}, createMetadata('sync status', flags));
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
if (!running) {
|
|
29
|
+
this.log(styles.muted('Sync daemon is not running.'));
|
|
30
|
+
this.log(styles.muted(`Start it with: prlt sync start`));
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
this.log(styles.success('Sync daemon is running'));
|
|
34
|
+
this.log(` PID: ${info?.pid}`);
|
|
35
|
+
this.log(` Interval: every ${info?.intervalSeconds}s`);
|
|
36
|
+
this.log(` Started: ${info?.startedAt}`);
|
|
37
|
+
this.log(` Log: ${logPath}`);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../../src/commands/sync/status.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA;AAC/E,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAA;AAC3F,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,cAAc,GACf,MAAM,0BAA0B,CAAA;AAEjC,MAAM,CAAC,OAAO,OAAO,UAAW,SAAQ,cAAc;IACpD,MAAM,CAAC,WAAW,GAAG,oCAAoC,CAAA;IAEzD,MAAM,CAAC,QAAQ,GAAG;QAChB,qCAAqC;KACtC,CAAA;IAED,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,gBAAgB;KACpB,CAAA;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;QAC9C,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;QAC/B,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAA;QACxC,MAAM,OAAO,GAAG,eAAe,CAAC,MAAM,CAAC,CAAA;QACvC,MAAM,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QACnD,MAAM,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAA;QAExC,IAAI,QAAQ,EAAE,CAAC;YACb,mBAAmB,CAAC;gBAClB,OAAO;gBACP,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;gBACf,OAAO;aACR,EAAE,cAAc,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC,CAAA;YACxC,OAAM;QACR,CAAC;QAED,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC,CAAA;YACrD,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC,CAAA;YACxD,OAAM;QACR,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC,CAAA;QAClD,IAAI,CAAC,GAAG,CAAC,UAAU,IAAI,EAAE,GAAG,EAAE,CAAC,CAAA;QAC/B,IAAI,CAAC,GAAG,CAAC,qBAAqB,IAAI,EAAE,eAAe,GAAG,CAAC,CAAA;QACvD,IAAI,CAAC,GAAG,CAAC,cAAc,IAAI,EAAE,SAAS,EAAE,CAAC,CAAA;QACzC,IAAI,CAAC,GAAG,CAAC,UAAU,OAAO,EAAE,CAAC,CAAA;IAC/B,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { RuntimeCommand } from '../../lib/runtime-command.js';
|
|
2
|
+
export default class SyncStop extends RuntimeCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
machine: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
};
|
|
9
|
+
execute(): Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { RuntimeCommand, runtimeBaseFlags } from '../../lib/runtime-command.js';
|
|
2
|
+
import { styles } from '../../lib/styles.js';
|
|
3
|
+
import { isDaemonRunning, stopDaemon, getDaemonInfo } from '../../lib/sync/daemon.js';
|
|
4
|
+
import { shouldOutputJson, outputSuccessAsJson, outputErrorAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
5
|
+
export default class SyncStop extends RuntimeCommand {
|
|
6
|
+
static description = 'Stop the board sync daemon';
|
|
7
|
+
static examples = [
|
|
8
|
+
'<%= config.bin %> <%= command.id %>',
|
|
9
|
+
];
|
|
10
|
+
static flags = {
|
|
11
|
+
...runtimeBaseFlags,
|
|
12
|
+
};
|
|
13
|
+
async execute() {
|
|
14
|
+
const { flags } = await this.parse(SyncStop);
|
|
15
|
+
const hqPath = this.requireHQ();
|
|
16
|
+
const jsonMode = shouldOutputJson(flags);
|
|
17
|
+
if (!isDaemonRunning(hqPath)) {
|
|
18
|
+
if (jsonMode) {
|
|
19
|
+
outputErrorAsJson('NOT_RUNNING', 'No sync daemon is running', createMetadata('sync stop', flags));
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
this.log(styles.muted('No sync daemon is running.'));
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const info = getDaemonInfo(hqPath);
|
|
26
|
+
const stopped = stopDaemon(hqPath);
|
|
27
|
+
if (jsonMode) {
|
|
28
|
+
outputSuccessAsJson({ stopped, pid: info?.pid }, createMetadata('sync stop', flags));
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
if (stopped) {
|
|
32
|
+
this.log(styles.success(`Sync daemon stopped (PID ${info?.pid})`));
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
this.log(styles.warning('Daemon process not found — cleaned up PID file.'));
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=stop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stop.js","sourceRoot":"","sources":["../../../src/commands/sync/stop.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA;AAC/E,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAA;AACrF,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,iBAAiB,EACjB,cAAc,GACf,MAAM,0BAA0B,CAAA;AAEjC,MAAM,CAAC,OAAO,OAAO,QAAS,SAAQ,cAAc;IAClD,MAAM,CAAC,WAAW,GAAG,4BAA4B,CAAA;IAEjD,MAAM,CAAC,QAAQ,GAAG;QAChB,qCAAqC;KACtC,CAAA;IAED,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,gBAAgB;KACpB,CAAA;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAC5C,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;QAC/B,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAA;QAExC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC;YAC7B,IAAI,QAAQ,EAAE,CAAC;gBACb,iBAAiB,CAAC,aAAa,EAAE,2BAA2B,EAAE,cAAc,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,CAAA;gBACjG,OAAM;YACR,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC,CAAA;YACpD,OAAM;QACR,CAAC;QAED,MAAM,IAAI,GAAG,aAAa,CAAC,MAAM,CAAC,CAAA;QAClC,MAAM,OAAO,GAAG,UAAU,CAAC,MAAM,CAAC,CAAA;QAElC,IAAI,QAAQ,EAAE,CAAC;YACb,mBAAmB,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,cAAc,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,CAAA;YACpF,OAAM;QACR,CAAC;QAED,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,4BAA4B,IAAI,EAAE,GAAG,GAAG,CAAC,CAAC,CAAA;QACpE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,iDAAiD,CAAC,CAAC,CAAA;QAC7E,CAAC;IACH,CAAC"}
|
|
@@ -5,7 +5,7 @@ import { autoExportToBoard, PMOCommand, pmoBaseFlags } from '../../lib/pmo/index
|
|
|
5
5
|
// Note: inquirer import kept for inquirer.Separator usage in interactive mode
|
|
6
6
|
import { styles } from '../../lib/styles.js';
|
|
7
7
|
import { updateEpicTicketsSection } from '../../lib/pmo/epic-files.js';
|
|
8
|
-
import { getWorkspacePriorities } from '../../lib/
|
|
8
|
+
import { getWorkspacePriorities } from '../../lib/work-lifecycle/settings.js';
|
|
9
9
|
import { shouldOutputJson, outputErrorAsJson, outputDryRunSuccessAsJson, outputDryRunErrorsAsJson, createMetadata, } from '../../lib/prompt-json.js';
|
|
10
10
|
import { FlagResolver } from '../../lib/flags/index.js';
|
|
11
11
|
import { multiLineInput } from '../../lib/multiline-input.js';
|