@ctxkit/cli 0.2.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.
Files changed (85) hide show
  1. package/dist/commands/apply.d.ts +3 -0
  2. package/dist/commands/apply.d.ts.map +1 -0
  3. package/dist/commands/apply.js +45 -0
  4. package/dist/commands/apply.js.map +1 -0
  5. package/dist/commands/bootstrap-cmd.d.ts +3 -0
  6. package/dist/commands/bootstrap-cmd.d.ts.map +1 -0
  7. package/dist/commands/bootstrap-cmd.js +104 -0
  8. package/dist/commands/bootstrap-cmd.js.map +1 -0
  9. package/dist/commands/codex.d.ts +3 -0
  10. package/dist/commands/codex.d.ts.map +1 -0
  11. package/dist/commands/codex.js +64 -0
  12. package/dist/commands/codex.js.map +1 -0
  13. package/dist/commands/conflicts-cmd.d.ts +3 -0
  14. package/dist/commands/conflicts-cmd.d.ts.map +1 -0
  15. package/dist/commands/conflicts-cmd.js +178 -0
  16. package/dist/commands/conflicts-cmd.js.map +1 -0
  17. package/dist/commands/daemon.d.ts +4 -0
  18. package/dist/commands/daemon.d.ts.map +1 -0
  19. package/dist/commands/daemon.js +107 -0
  20. package/dist/commands/daemon.js.map +1 -0
  21. package/dist/commands/drift.d.ts +3 -0
  22. package/dist/commands/drift.d.ts.map +1 -0
  23. package/dist/commands/drift.js +65 -0
  24. package/dist/commands/drift.js.map +1 -0
  25. package/dist/commands/history-cmd.d.ts +3 -0
  26. package/dist/commands/history-cmd.d.ts.map +1 -0
  27. package/dist/commands/history-cmd.js +100 -0
  28. package/dist/commands/history-cmd.js.map +1 -0
  29. package/dist/commands/hooks-cmd.d.ts +3 -0
  30. package/dist/commands/hooks-cmd.d.ts.map +1 -0
  31. package/dist/commands/hooks-cmd.js +98 -0
  32. package/dist/commands/hooks-cmd.js.map +1 -0
  33. package/dist/commands/index-cmd.d.ts +3 -0
  34. package/dist/commands/index-cmd.d.ts.map +1 -0
  35. package/dist/commands/index-cmd.js +112 -0
  36. package/dist/commands/index-cmd.js.map +1 -0
  37. package/dist/commands/init.d.ts +3 -0
  38. package/dist/commands/init.d.ts.map +1 -0
  39. package/dist/commands/init.js +158 -0
  40. package/dist/commands/init.js.map +1 -0
  41. package/dist/commands/inject.d.ts +3 -0
  42. package/dist/commands/inject.d.ts.map +1 -0
  43. package/dist/commands/inject.js +68 -0
  44. package/dist/commands/inject.js.map +1 -0
  45. package/dist/commands/migrate-cmd.d.ts +3 -0
  46. package/dist/commands/migrate-cmd.d.ts.map +1 -0
  47. package/dist/commands/migrate-cmd.js +132 -0
  48. package/dist/commands/migrate-cmd.js.map +1 -0
  49. package/dist/commands/plugin.d.ts +3 -0
  50. package/dist/commands/plugin.d.ts.map +1 -0
  51. package/dist/commands/plugin.js +327 -0
  52. package/dist/commands/plugin.js.map +1 -0
  53. package/dist/commands/pr-context-cmd.d.ts +3 -0
  54. package/dist/commands/pr-context-cmd.d.ts.map +1 -0
  55. package/dist/commands/pr-context-cmd.js +128 -0
  56. package/dist/commands/pr-context-cmd.js.map +1 -0
  57. package/dist/commands/propose.d.ts +3 -0
  58. package/dist/commands/propose.d.ts.map +1 -0
  59. package/dist/commands/propose.js +109 -0
  60. package/dist/commands/propose.js.map +1 -0
  61. package/dist/commands/run.d.ts +3 -0
  62. package/dist/commands/run.d.ts.map +1 -0
  63. package/dist/commands/run.js +133 -0
  64. package/dist/commands/run.js.map +1 -0
  65. package/dist/commands/sessions.d.ts +3 -0
  66. package/dist/commands/sessions.d.ts.map +1 -0
  67. package/dist/commands/sessions.js +93 -0
  68. package/dist/commands/sessions.js.map +1 -0
  69. package/dist/commands/speckit-cmd.d.ts +3 -0
  70. package/dist/commands/speckit-cmd.d.ts.map +1 -0
  71. package/dist/commands/speckit-cmd.js +196 -0
  72. package/dist/commands/speckit-cmd.js.map +1 -0
  73. package/dist/commands/validate.d.ts +3 -0
  74. package/dist/commands/validate.d.ts.map +1 -0
  75. package/dist/commands/validate.js +75 -0
  76. package/dist/commands/validate.js.map +1 -0
  77. package/dist/index.d.ts +3 -0
  78. package/dist/index.d.ts.map +1 -0
  79. package/dist/index.js +49 -0
  80. package/dist/index.js.map +1 -0
  81. package/dist/services/agents-md.d.ts +34 -0
  82. package/dist/services/agents-md.d.ts.map +1 -0
  83. package/dist/services/agents-md.js +248 -0
  84. package/dist/services/agents-md.js.map +1 -0
  85. package/package.json +45 -0
@@ -0,0 +1,128 @@
1
+ import { Command } from 'commander';
2
+ import { execSync } from 'node:child_process';
3
+ export const prContextCommand = new Command('pr')
4
+ .description('Generate PR context documents')
5
+ .option('--session <id>', 'Specific session ID')
6
+ .option('--branch', 'Use current branch (all sessions since merge-base)')
7
+ .option('--since <ref>', 'Git ref to diff from (default: merge-base with main)')
8
+ .option('--format <md|json>', 'Output format', 'md')
9
+ .option('--link-specs', 'Cross-reference spec-kit artifacts')
10
+ .option('--gh', 'Pipe-friendly output for gh pr create --body-file -')
11
+ .option('--json', 'Output as JSON')
12
+ .action(async (options) => {
13
+ try {
14
+ let repoRoot;
15
+ try {
16
+ repoRoot = execSync('git rev-parse --show-toplevel', {
17
+ encoding: 'utf-8',
18
+ timeout: 3000,
19
+ stdio: ['pipe', 'pipe', 'pipe'],
20
+ }).trim();
21
+ }
22
+ catch {
23
+ console.error('Error: Not a git repository');
24
+ process.exit(1);
25
+ return;
26
+ }
27
+ const daemonUrl = process.env.CTXKIT_DAEMON_URL || 'http://127.0.0.1:3742';
28
+ // Get sessions from daemon
29
+ let sessions = [];
30
+ try {
31
+ if (options.session) {
32
+ const res = await fetch(`${daemonUrl}/api/v1/sessions/${options.session}`);
33
+ if (res.ok) {
34
+ const data = await res.json();
35
+ sessions = [{
36
+ ...data,
37
+ tool_events: data.tool_events || [],
38
+ }];
39
+ }
40
+ }
41
+ else {
42
+ const res = await fetch(`${daemonUrl}/api/v1/sessions?repo_path=${encodeURIComponent(repoRoot)}&limit=20`);
43
+ if (res.ok) {
44
+ const data = await res.json();
45
+ // For each session, fetch detailed events
46
+ for (const s of data.sessions) {
47
+ const detailRes = await fetch(`${daemonUrl}/api/v1/sessions/${s.id}`);
48
+ if (detailRes.ok) {
49
+ const detail = await detailRes.json();
50
+ sessions.push({
51
+ ...detail,
52
+ tool_events: detail.tool_events || [],
53
+ });
54
+ }
55
+ }
56
+ }
57
+ }
58
+ }
59
+ catch {
60
+ console.error('Error: Daemon not running. Start with \'ctxkit daemon start\'');
61
+ process.exit(1);
62
+ return;
63
+ }
64
+ if (sessions.length === 0) {
65
+ if (options.json) {
66
+ console.log(JSON.stringify({ message: 'No session data found for the specified range' }));
67
+ }
68
+ else {
69
+ console.log('No session data found for the specified range.');
70
+ }
71
+ return;
72
+ }
73
+ // Determine git range
74
+ let gitRange;
75
+ if (options.since) {
76
+ gitRange = `${options.since}..HEAD`;
77
+ }
78
+ else if (options.branch) {
79
+ try {
80
+ const branch = execSync('git rev-parse --abbrev-ref HEAD', {
81
+ cwd: repoRoot,
82
+ encoding: 'utf-8',
83
+ stdio: ['pipe', 'pipe', 'pipe'],
84
+ }).trim();
85
+ const mergeBase = execSync(`git merge-base main ${branch}`, {
86
+ cwd: repoRoot,
87
+ encoding: 'utf-8',
88
+ stdio: ['pipe', 'pipe', 'pipe'],
89
+ }).trim();
90
+ gitRange = `${mergeBase}..HEAD`;
91
+ }
92
+ catch { /* use default */ }
93
+ }
94
+ const { collectPrContext, renderPrMarkdown, renderPrJson, renderGhBody } = await import('@ctxkit/core');
95
+ const prContext = collectPrContext(sessions, {
96
+ repoRoot,
97
+ gitRange,
98
+ linkSpecs: options.linkSpecs,
99
+ });
100
+ if (options.json) {
101
+ console.log(JSON.stringify({
102
+ format: options.format || 'markdown',
103
+ content: options.format === 'json' ? prContext : renderPrMarkdown(prContext),
104
+ stats: prContext.stats,
105
+ }, null, 2));
106
+ }
107
+ else if (options.gh) {
108
+ console.log(renderGhBody(prContext));
109
+ }
110
+ else if (options.format === 'json') {
111
+ console.log(renderPrJson(prContext));
112
+ }
113
+ else {
114
+ console.log(renderPrMarkdown(prContext));
115
+ }
116
+ }
117
+ catch (error) {
118
+ const message = error instanceof Error ? error.message : String(error);
119
+ if (options.json) {
120
+ console.log(JSON.stringify({ error: message }));
121
+ }
122
+ else {
123
+ console.error(`Error: ${message}`);
124
+ }
125
+ process.exit(1);
126
+ }
127
+ });
128
+ //# sourceMappingURL=pr-context-cmd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pr-context-cmd.js","sourceRoot":"","sources":["../../src/commands/pr-context-cmd.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare const proposeCommand: Command;
3
+ //# sourceMappingURL=propose.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"propose.d.ts","sourceRoot":"","sources":["../../src/commands/propose.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,eAAO,MAAM,cAAc,SAmHvB,CAAC"}
@@ -0,0 +1,109 @@
1
+ import { Command } from 'commander';
2
+ import { readFileSync, existsSync, statSync } from 'node:fs';
3
+ import { resolve, dirname, join } from 'node:path';
4
+ import { parseCtxFile } from '@ctxkit/core';
5
+ export const proposeCommand = new Command('propose')
6
+ .description('Generate a .ctx update proposal showing what would change')
7
+ .argument('<ctx-path>', 'Path to .ctx file or directory containing .ctx')
8
+ .option('--check-files', 'Check for dead file references', false)
9
+ .option('--daemon <url>', 'Daemon URL to submit proposal', 'http://localhost:3742')
10
+ .option('--json', 'Output as JSON', false)
11
+ .action(async (ctxPathArg, options) => {
12
+ let ctxPath = resolve(ctxPathArg);
13
+ // If path is a directory, look for .ctx inside it
14
+ if (existsSync(ctxPath) && statSync(ctxPath).isDirectory()) {
15
+ ctxPath = join(ctxPath, '.ctx');
16
+ }
17
+ if (!existsSync(ctxPath)) {
18
+ console.error(`Error: .ctx file not found at ${ctxPath}`);
19
+ process.exitCode = 1;
20
+ return;
21
+ }
22
+ const content = readFileSync(ctxPath, 'utf-8');
23
+ const { ctx } = parseCtxFile(content);
24
+ const ctxDir = dirname(ctxPath);
25
+ if (options.json) {
26
+ const result = {
27
+ path: ctxPath,
28
+ version: ctx.version,
29
+ summary: ctx.summary,
30
+ key_files: ctx.key_files.length,
31
+ contracts: ctx.contracts.length,
32
+ decisions: ctx.decisions.length,
33
+ gotchas: ctx.gotchas.length,
34
+ tags: ctx.tags,
35
+ refs: ctx.refs.length,
36
+ };
37
+ if (options.checkFiles) {
38
+ const deadRefs = [];
39
+ for (const kf of ctx.key_files) {
40
+ if (!existsSync(resolve(ctxDir, kf.path))) {
41
+ deadRefs.push({ type: 'key_file', path: kf.path });
42
+ }
43
+ }
44
+ for (const ref of ctx.refs) {
45
+ if (!existsSync(resolve(ctxDir, ref.target))) {
46
+ deadRefs.push({ type: 'ref', path: ref.target });
47
+ }
48
+ }
49
+ result.dead_references = deadRefs;
50
+ }
51
+ console.log(JSON.stringify(result, null, 2));
52
+ return;
53
+ }
54
+ console.log(`Analyzing ${ctxPath}...\n`);
55
+ // Check for dead references
56
+ if (options.checkFiles) {
57
+ let deadCount = 0;
58
+ for (const kf of ctx.key_files) {
59
+ const absPath = resolve(ctxDir, kf.path);
60
+ if (!existsSync(absPath)) {
61
+ console.log(` ✗ Dead reference: key_files/${kf.path}`);
62
+ console.log(` File not found at ${absPath}`);
63
+ deadCount++;
64
+ }
65
+ }
66
+ for (const ref of ctx.refs) {
67
+ const absTarget = resolve(ctxDir, ref.target);
68
+ if (!existsSync(absTarget)) {
69
+ console.log(` ✗ Dead reference: refs/${ref.target}`);
70
+ console.log(` Target not found at ${absTarget}`);
71
+ deadCount++;
72
+ }
73
+ }
74
+ if (deadCount === 0) {
75
+ console.log(' ✓ No dead references found');
76
+ }
77
+ else {
78
+ console.log(`\n Found ${deadCount} dead reference(s)`);
79
+ }
80
+ }
81
+ // Show summary stats
82
+ console.log('\n.ctx Summary:');
83
+ console.log(` Version: ${ctx.version}`);
84
+ console.log(` Key files: ${ctx.key_files.length}`);
85
+ console.log(` Contracts: ${ctx.contracts.length}`);
86
+ console.log(` Decisions: ${ctx.decisions.length}`);
87
+ console.log(` Gotchas: ${ctx.gotchas.length}`);
88
+ console.log(` Tags: ${ctx.tags.join(', ') || '(none)'}`);
89
+ console.log(` Refs: ${ctx.refs.length}`);
90
+ // Show locked entries
91
+ const lockedFiles = ctx.key_files.filter((kf) => kf.locked);
92
+ const lockedContracts = ctx.contracts.filter((c) => c.locked);
93
+ const lockedDecisions = ctx.decisions.filter((d) => d.locked);
94
+ const totalLocked = lockedFiles.length + lockedContracts.length + lockedDecisions.length;
95
+ if (totalLocked > 0) {
96
+ console.log(`\n Locked entries (${totalLocked}):`);
97
+ for (const kf of lockedFiles) {
98
+ console.log(` 🔒 key_files/${kf.path}${kf.owner ? ` (owner: ${kf.owner})` : ''}`);
99
+ }
100
+ for (const c of lockedContracts) {
101
+ console.log(` 🔒 contracts/${c.name}${c.owner ? ` (owner: ${c.owner})` : ''}`);
102
+ }
103
+ for (const d of lockedDecisions) {
104
+ console.log(` 🔒 decisions/${d.id}${d.owner ? ` (owner: ${d.owner})` : ''}`);
105
+ }
106
+ }
107
+ console.log();
108
+ });
109
+ //# sourceMappingURL=propose.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"propose.js","sourceRoot":"","sources":["../../src/commands/propose.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare const runCommand: Command;
3
+ //# sourceMappingURL=run.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,eAAO,MAAM,UAAU,SA2GnB,CAAC"}
@@ -0,0 +1,133 @@
1
+ import { Command } from 'commander';
2
+ import { buildContextPack } from '@ctxkit/core';
3
+ import { execSync, spawn } from 'node:child_process';
4
+ import { existsSync } from 'node:fs';
5
+ import { resolve, join, dirname } from 'node:path';
6
+ export const runCommand = new Command('run')
7
+ .description('Wrap an agent command with context injection')
8
+ .option('--daemon <url>', 'Daemon URL', 'http://localhost:3742')
9
+ .option('--cwd <path>', 'Working directory', process.cwd())
10
+ .option('--budget <tokens>', 'Token budget', '4000')
11
+ .option('--agent <id>', 'Agent identifier', 'default')
12
+ .option('--request <text>', 'Initial request text', '')
13
+ .argument('<cmd...>', 'Command to wrap')
14
+ .allowExcessArguments(true)
15
+ .action(async (cmdArgs, options) => {
16
+ const workingDir = resolve(options.cwd);
17
+ const repoRoot = findRepoRoot(workingDir);
18
+ const budgetTokens = parseInt(options.budget, 10);
19
+ const daemonUrl = options.daemon;
20
+ if (isNaN(budgetTokens) || budgetTokens <= 0) {
21
+ console.error('Error: Invalid budget: must be a positive number');
22
+ process.exit(1);
23
+ }
24
+ // Step 1: Create session on daemon
25
+ let sessionId = null;
26
+ try {
27
+ const res = await fetch(`${daemonUrl}/api/v1/sessions`, {
28
+ method: 'POST',
29
+ headers: { 'Content-Type': 'application/json' },
30
+ body: JSON.stringify({
31
+ repo_path: repoRoot,
32
+ working_dir: workingDir,
33
+ branch: getBranch(repoRoot),
34
+ agent_id: options.agent,
35
+ }),
36
+ });
37
+ if (res.ok) {
38
+ const data = await res.json();
39
+ sessionId = data.id;
40
+ console.error(`[ctxkit] Session started: ${sessionId}`);
41
+ }
42
+ }
43
+ catch {
44
+ console.error('[ctxkit] Warning: Could not connect to daemon, running without session tracking');
45
+ }
46
+ // Step 2: Build context pack
47
+ const result = buildContextPack({
48
+ workingDir,
49
+ repoRoot,
50
+ requestText: options.request || cmdArgs.join(' '),
51
+ budgetTokens,
52
+ });
53
+ const contextJson = JSON.stringify(result.pack);
54
+ // Step 3: Record event on daemon if session exists
55
+ if (sessionId) {
56
+ try {
57
+ await fetch(`${daemonUrl}/api/v1/context-pack`, {
58
+ method: 'POST',
59
+ headers: { 'Content-Type': 'application/json' },
60
+ body: JSON.stringify({
61
+ session_id: sessionId,
62
+ repo_path: repoRoot,
63
+ working_dir: workingDir,
64
+ request_text: options.request || cmdArgs.join(' '),
65
+ budget_tokens: budgetTokens,
66
+ }),
67
+ });
68
+ }
69
+ catch {
70
+ // Non-fatal: context pack already built locally
71
+ }
72
+ }
73
+ // Step 4: Spawn wrapped command with context injected via env
74
+ const [cmd, ...args] = cmdArgs;
75
+ const child = spawn(cmd, args, {
76
+ cwd: workingDir,
77
+ stdio: ['pipe', 'inherit', 'inherit'],
78
+ env: {
79
+ ...process.env,
80
+ CTXL_CONTEXT_PACK: contextJson,
81
+ CTXL_SESSION_ID: sessionId || '',
82
+ CTXL_DAEMON_URL: daemonUrl,
83
+ CTXL_TOKENS_USED: String(result.pack.total_tokens),
84
+ CTXL_TOKENS_BUDGET: String(result.pack.budget_tokens),
85
+ },
86
+ });
87
+ // Step 5: End session when child exits
88
+ child.on('close', async (code) => {
89
+ if (sessionId) {
90
+ try {
91
+ await fetch(`${daemonUrl}/api/v1/sessions/${sessionId}`, {
92
+ method: 'PATCH',
93
+ headers: { 'Content-Type': 'application/json' },
94
+ body: JSON.stringify({ status: 'completed' }),
95
+ });
96
+ console.error(`[ctxkit] Session ended: ${sessionId}`);
97
+ }
98
+ catch {
99
+ // Non-fatal
100
+ }
101
+ }
102
+ process.exit(code ?? 0);
103
+ });
104
+ child.on('error', (err) => {
105
+ console.error(`[ctxkit] Failed to start command: ${err.message}`);
106
+ process.exit(1);
107
+ });
108
+ });
109
+ function findRepoRoot(startDir) {
110
+ let current = startDir;
111
+ while (true) {
112
+ if (existsSync(join(current, '.git'))) {
113
+ return current;
114
+ }
115
+ const parent = dirname(current);
116
+ if (parent === current) {
117
+ return startDir;
118
+ }
119
+ current = parent;
120
+ }
121
+ }
122
+ function getBranch(repoRoot) {
123
+ try {
124
+ return execSync('git rev-parse --abbrev-ref HEAD', {
125
+ cwd: repoRoot,
126
+ encoding: 'utf-8',
127
+ }).trim();
128
+ }
129
+ catch {
130
+ return 'unknown';
131
+ }
132
+ }
133
+ //# sourceMappingURL=run.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run.js","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare const sessionsCommand: Command;
3
+ //# sourceMappingURL=sessions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../src/commands/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,eAAO,MAAM,eAAe,SAoDxB,CAAC"}
@@ -0,0 +1,93 @@
1
+ import { Command } from 'commander';
2
+ export const sessionsCommand = new Command('sessions')
3
+ .description('List and inspect agent sessions')
4
+ .option('--daemon <url>', 'Daemon URL', 'http://localhost:3742')
5
+ .option('--status <status>', 'Filter by status (active/completed)')
6
+ .option('--limit <n>', 'Maximum results', '20')
7
+ .option('--json', 'Output as JSON', false)
8
+ .action(async (options) => {
9
+ const baseUrl = options.daemon;
10
+ const params = new URLSearchParams();
11
+ if (options.status)
12
+ params.set('status', options.status);
13
+ params.set('limit', options.limit);
14
+ try {
15
+ const res = await fetch(`${baseUrl}/api/v1/sessions?${params}`);
16
+ if (!res.ok) {
17
+ const err = await res.json();
18
+ console.error(`Error: ${err.error?.message || 'Unknown error'}`);
19
+ process.exitCode = 1;
20
+ return;
21
+ }
22
+ const data = await res.json();
23
+ if (options.json) {
24
+ console.log(JSON.stringify(data, null, 2));
25
+ return;
26
+ }
27
+ const sessions = data.sessions;
28
+ if (sessions.length === 0) {
29
+ console.log('No sessions found.');
30
+ return;
31
+ }
32
+ // Table header
33
+ console.log(`${'ID'.padEnd(16)} ${'Agent'.padEnd(10)} ${'Status'.padEnd(12)} ${'Requests'.padEnd(10)} ${'Started'.padEnd(24)}`);
34
+ console.log('─'.repeat(72));
35
+ for (const s of sessions) {
36
+ console.log(`${(s.id || '').padEnd(16)} ${(s.agent_id || '-').padEnd(10)} ${(s.status || '').padEnd(12)} ${String(s.request_count || 0).padEnd(10)} ${(s.started_at || '').padEnd(24)}`);
37
+ }
38
+ console.log(`\nTotal: ${data.total}`);
39
+ }
40
+ catch (err) {
41
+ console.error(`Failed to connect to daemon at ${baseUrl}: ${err.message}`);
42
+ process.exitCode = 1;
43
+ }
44
+ });
45
+ // Subcommand: sessions show <id>
46
+ sessionsCommand
47
+ .command('show <id>')
48
+ .description('Show session details with request timeline')
49
+ .option('--json', 'Output as JSON', false)
50
+ .action(async (id, opts, cmd) => {
51
+ const baseUrl = cmd.parent?.opts().daemon || 'http://localhost:3742';
52
+ try {
53
+ const res = await fetch(`${baseUrl}/api/v1/sessions/${id}`);
54
+ if (!res.ok) {
55
+ const err = await res.json();
56
+ console.error(`Error: ${err.error?.message || 'Unknown error'}`);
57
+ process.exitCode = 1;
58
+ return;
59
+ }
60
+ const session = await res.json();
61
+ if (opts.json) {
62
+ console.log(JSON.stringify(session, null, 2));
63
+ return;
64
+ }
65
+ console.log(`Session: ${session.id}`);
66
+ console.log(` Status: ${session.status}`);
67
+ console.log(` Agent: ${session.agent_id || '-'}`);
68
+ console.log(` Repo: ${session.repo_path}`);
69
+ console.log(` Dir: ${session.working_dir}`);
70
+ console.log(` Branch: ${session.branch || '-'}`);
71
+ console.log(` Started: ${session.started_at}`);
72
+ console.log(` Ended: ${session.ended_at || '-'}`);
73
+ if (session.events && session.events.length > 0) {
74
+ console.log(`\n Timeline (${session.events.length} requests):`);
75
+ console.log(' ' + '─'.repeat(60));
76
+ for (let i = 0; i < session.events.length; i++) {
77
+ const e = session.events[i];
78
+ const text = e.request_text.length > 40
79
+ ? e.request_text.slice(0, 40) + '...'
80
+ : e.request_text;
81
+ console.log(` ${i + 1}. [${e.created_at}] ${text} (${e.token_count}/${e.budget} tok)`);
82
+ }
83
+ }
84
+ else {
85
+ console.log('\n No requests recorded.');
86
+ }
87
+ }
88
+ catch (err) {
89
+ console.error(`Failed to connect to daemon at ${baseUrl}: ${err.message}`);
90
+ process.exitCode = 1;
91
+ }
92
+ });
93
+ //# sourceMappingURL=sessions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sessions.js","sourceRoot":"","sources":["../../src/commands/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,OAAO,CAAC,UAAU,CAAC;KACnD,WAAW,CAAC,iCAAiC,CAAC;KAC9C,MAAM,CAAC,gBAAgB,EAAE,YAAY,EAAE,uBAAuB,CAAC;KAC/D,MAAM,CAAC,mBAAmB,EAAE,qCAAqC,CAAC;KAClE,MAAM,CAAC,aAAa,EAAE,iBAAiB,EAAE,IAAI,CAAC;KAC9C,MAAM,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,CAAC;KACzC,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;IACxB,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC;IAC/B,MAAM,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;IACrC,IAAI,OAAO,CAAC,MAAM;QAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IACzD,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IAEnC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,OAAO,oBAAoB,MAAM,EAAE,CAAC,CAAC;QAChE,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YACZ,MAAM,GAAG,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;YAC7B,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,KAAK,EAAE,OAAO,IAAI,eAAe,EAAE,CAAC,CAAC;YACjE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;QAE9B,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAC3C,OAAO;QACT,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE/B,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;YAClC,OAAO;QACT,CAAC;QAED,eAAe;QACf,OAAO,CAAC,GAAG,CACT,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CACnH,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAE5B,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;YACzB,OAAO,CAAC,GAAG,CACT,GAAG,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,aAAa,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAC5K,CAAC;QACJ,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACxC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,kCAAkC,OAAO,KAAM,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;QACtF,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;IACvB,CAAC;AACH,CAAC,CAAC,CAAC;AAEL,iCAAiC;AACjC,eAAe;KACZ,OAAO,CAAC,WAAW,CAAC;KACpB,WAAW,CAAC,4CAA4C,CAAC;KACzD,MAAM,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,CAAC;KACzC,MAAM,CAAC,KAAK,EAAE,EAAU,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE;IACtC,MAAM,OAAO,GAAG,GAAG,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,MAAM,IAAI,uBAAuB,CAAC;IAErE,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,OAAO,oBAAoB,EAAE,EAAE,CAAC,CAAC;QAC5D,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YACZ,MAAM,GAAG,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;YAC7B,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,KAAK,EAAE,OAAO,IAAI,eAAe,EAAE,CAAC,CAAC;YACjE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;QAEjC,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9C,OAAO;QACT,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,YAAY,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QACtC,OAAO,CAAC,GAAG,CAAC,aAAa,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QAC3C,OAAO,CAAC,GAAG,CAAC,YAAY,OAAO,CAAC,QAAQ,IAAI,GAAG,EAAE,CAAC,CAAC;QACnD,OAAO,CAAC,GAAG,CAAC,WAAW,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;QAC5C,OAAO,CAAC,GAAG,CAAC,UAAU,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;QAC7C,OAAO,CAAC,GAAG,CAAC,aAAa,OAAO,CAAC,MAAM,IAAI,GAAG,EAAE,CAAC,CAAC;QAClD,OAAO,CAAC,GAAG,CAAC,cAAc,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;QAChD,OAAO,CAAC,GAAG,CAAC,YAAY,OAAO,CAAC,QAAQ,IAAI,GAAG,EAAE,CAAC,CAAC;QAEnD,IAAI,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChD,OAAO,CAAC,GAAG,CAAC,iBAAiB,OAAO,CAAC,MAAM,CAAC,MAAM,aAAa,CAAC,CAAC;YACjE,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;YACnC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC/C,MAAM,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBAC5B,MAAM,IAAI,GAAG,CAAC,CAAC,YAAY,CAAC,MAAM,GAAG,EAAE;oBACrC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK;oBACrC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;gBACnB,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,UAAU,KAAK,IAAI,KAAK,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,MAAM,OAAO,CAC3E,CAAC;YACJ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,kCAAkC,OAAO,KAAM,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;QACtF,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;IACvB,CAAC;AACH,CAAC,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare const speckitCommand: Command;
3
+ //# sourceMappingURL=speckit-cmd.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"speckit-cmd.d.ts","sourceRoot":"","sources":["../../src/commands/speckit-cmd.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,eAAO,MAAM,cAAc,SACkB,CAAC"}