@cardor/agent-harness-kit 0.14.0 → 0.15.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (136) hide show
  1. package/bin/ahk.js +1 -1
  2. package/dist/chunk-LQ7SDMK6.js +82 -0
  3. package/dist/chunk-LQ7SDMK6.js.map +1 -0
  4. package/dist/cli.js +1984 -109
  5. package/dist/cli.js.map +1 -1
  6. package/dist/index.js +6 -1
  7. package/dist/index.js.map +1 -1
  8. package/package.json +13 -6
  9. package/dist/cli.d.ts +0 -2
  10. package/dist/cli.d.ts.map +0 -1
  11. package/dist/commands/build.d.ts +0 -6
  12. package/dist/commands/build.d.ts.map +0 -1
  13. package/dist/commands/build.js +0 -39
  14. package/dist/commands/build.js.map +0 -1
  15. package/dist/commands/dashboard.d.ts +0 -7
  16. package/dist/commands/dashboard.d.ts.map +0 -1
  17. package/dist/commands/dashboard.js +0 -27
  18. package/dist/commands/dashboard.js.map +0 -1
  19. package/dist/commands/export.d.ts +0 -8
  20. package/dist/commands/export.d.ts.map +0 -1
  21. package/dist/commands/export.js +0 -33
  22. package/dist/commands/export.js.map +0 -1
  23. package/dist/commands/health.d.ts +0 -2
  24. package/dist/commands/health.d.ts.map +0 -1
  25. package/dist/commands/health.js +0 -78
  26. package/dist/commands/health.js.map +0 -1
  27. package/dist/commands/init-helpers.d.ts +0 -9
  28. package/dist/commands/init-helpers.d.ts.map +0 -1
  29. package/dist/commands/init-helpers.js +0 -40
  30. package/dist/commands/init-helpers.js.map +0 -1
  31. package/dist/commands/init.d.ts +0 -9
  32. package/dist/commands/init.d.ts.map +0 -1
  33. package/dist/commands/init.js +0 -192
  34. package/dist/commands/init.js.map +0 -1
  35. package/dist/commands/migrate.d.ts +0 -6
  36. package/dist/commands/migrate.d.ts.map +0 -1
  37. package/dist/commands/migrate.js +0 -45
  38. package/dist/commands/migrate.js.map +0 -1
  39. package/dist/commands/serve.d.ts +0 -6
  40. package/dist/commands/serve.d.ts.map +0 -1
  41. package/dist/commands/serve.js +0 -13
  42. package/dist/commands/serve.js.map +0 -1
  43. package/dist/commands/status.d.ts +0 -6
  44. package/dist/commands/status.d.ts.map +0 -1
  45. package/dist/commands/status.js +0 -71
  46. package/dist/commands/status.js.map +0 -1
  47. package/dist/commands/sync.d.ts +0 -7
  48. package/dist/commands/sync.d.ts.map +0 -1
  49. package/dist/commands/sync.js +0 -57
  50. package/dist/commands/sync.js.map +0 -1
  51. package/dist/commands/task/add.d.ts +0 -2
  52. package/dist/commands/task/add.d.ts.map +0 -1
  53. package/dist/commands/task/add.js +0 -53
  54. package/dist/commands/task/add.js.map +0 -1
  55. package/dist/commands/task/done.d.ts +0 -2
  56. package/dist/commands/task/done.d.ts.map +0 -1
  57. package/dist/commands/task/done.js +0 -45
  58. package/dist/commands/task/done.js.map +0 -1
  59. package/dist/commands/task/index.d.ts +0 -4
  60. package/dist/commands/task/index.d.ts.map +0 -1
  61. package/dist/commands/task/index.js +0 -4
  62. package/dist/commands/task/index.js.map +0 -1
  63. package/dist/commands/task/list.d.ts +0 -7
  64. package/dist/commands/task/list.d.ts.map +0 -1
  65. package/dist/commands/task/list.js +0 -42
  66. package/dist/commands/task/list.js.map +0 -1
  67. package/dist/core/config.d.ts +0 -5
  68. package/dist/core/config.d.ts.map +0 -1
  69. package/dist/core/config.js +0 -77
  70. package/dist/core/config.js.map +0 -1
  71. package/dist/core/dashboard-server.d.ts +0 -7
  72. package/dist/core/dashboard-server.d.ts.map +0 -1
  73. package/dist/core/dashboard-server.js +0 -223
  74. package/dist/core/dashboard-server.js.map +0 -1
  75. package/dist/core/db.d.ts +0 -57
  76. package/dist/core/db.d.ts.map +0 -1
  77. package/dist/core/db.js +0 -348
  78. package/dist/core/db.js.map +0 -1
  79. package/dist/core/materializer/agent-templates/test123.txt +0 -0
  80. package/dist/core/materializer/claude-code.d.ts +0 -8
  81. package/dist/core/materializer/claude-code.d.ts.map +0 -1
  82. package/dist/core/materializer/claude-code.js +0 -66
  83. package/dist/core/materializer/claude-code.js.map +0 -1
  84. package/dist/core/materializer/index.d.ts +0 -8
  85. package/dist/core/materializer/index.d.ts.map +0 -1
  86. package/dist/core/materializer/index.js +0 -13
  87. package/dist/core/materializer/index.js.map +0 -1
  88. package/dist/core/materializer/mcp-merge.d.ts +0 -3
  89. package/dist/core/materializer/mcp-merge.d.ts.map +0 -1
  90. package/dist/core/materializer/mcp-merge.js +0 -59
  91. package/dist/core/materializer/mcp-merge.js.map +0 -1
  92. package/dist/core/materializer/opencode.d.ts +0 -8
  93. package/dist/core/materializer/opencode.d.ts.map +0 -1
  94. package/dist/core/materializer/opencode.js +0 -59
  95. package/dist/core/materializer/opencode.js.map +0 -1
  96. package/dist/core/materializer/scaffold-utils.d.ts +0 -4
  97. package/dist/core/materializer/scaffold-utils.d.ts.map +0 -1
  98. package/dist/core/materializer/scaffold-utils.js +0 -28
  99. package/dist/core/materializer/scaffold-utils.js.map +0 -1
  100. package/dist/core/materializer/templates.d.ts +0 -33
  101. package/dist/core/materializer/templates.d.ts.map +0 -1
  102. package/dist/core/materializer/templates.js +0 -187
  103. package/dist/core/materializer/templates.js.map +0 -1
  104. package/dist/core/mcp-server.d.ts +0 -3
  105. package/dist/core/mcp-server.d.ts.map +0 -1
  106. package/dist/core/mcp-server.js +0 -264
  107. package/dist/core/mcp-server.js.map +0 -1
  108. package/dist/core/server-types.d.ts +0 -67
  109. package/dist/core/server-types.d.ts.map +0 -1
  110. package/dist/core/server-types.js +0 -3
  111. package/dist/core/server-types.js.map +0 -1
  112. package/dist/core/sqlite-adapter.d.ts +0 -14
  113. package/dist/core/sqlite-adapter.d.ts.map +0 -1
  114. package/dist/core/sqlite-adapter.js +0 -20
  115. package/dist/core/sqlite-adapter.js.map +0 -1
  116. package/dist/dashboard-dist/assets/index-Cdm4QZ8j.js +0 -9
  117. package/dist/dashboard-dist/assets/index-DJInh0UZ.js +0 -9
  118. package/dist/dashboard-dist/assets/index-TQMzdmXs.css +0 -1
  119. package/dist/index.d.ts +0 -3
  120. package/dist/index.d.ts.map +0 -1
  121. package/dist/tests/db.test.d.ts +0 -2
  122. package/dist/tests/db.test.d.ts.map +0 -1
  123. package/dist/tests/db.test.js +0 -172
  124. package/dist/tests/db.test.js.map +0 -1
  125. package/dist/tests/slugify.test.d.ts +0 -2
  126. package/dist/tests/slugify.test.d.ts.map +0 -1
  127. package/dist/tests/slugify.test.js +0 -19
  128. package/dist/tests/slugify.test.js.map +0 -1
  129. package/dist/tests/templates.test.d.ts +0 -2
  130. package/dist/tests/templates.test.d.ts.map +0 -1
  131. package/dist/tests/templates.test.js +0 -71
  132. package/dist/tests/templates.test.js.map +0 -1
  133. package/dist/types.d.ts +0 -141
  134. package/dist/types.d.ts.map +0 -1
  135. package/dist/types.js +0 -3
  136. package/dist/types.js.map +0 -1
@@ -1,53 +0,0 @@
1
- import * as p from '@clack/prompts';
2
- import pc from 'picocolors';
3
- import { loadConfig } from '../../core/config.js';
4
- import { openDB } from '../../core/db.js';
5
- import { slugify } from '../../core/materializer/scaffold-utils.js';
6
- export async function runTaskAdd(cwd) {
7
- p.intro(pc.bold('agent-harness-kit — add task'));
8
- const titleVal = await p.text({
9
- message: 'Task title',
10
- validate: (v) => (v.trim() ? undefined : 'Title is required'),
11
- });
12
- if (p.isCancel(titleVal)) {
13
- p.cancel('Cancelled.');
14
- process.exit(0);
15
- }
16
- const title = titleVal.trim();
17
- const descVal = await p.text({
18
- message: 'Description (what and why)',
19
- placeholder: 'Optional',
20
- });
21
- if (p.isCancel(descVal)) {
22
- p.cancel('Cancelled.');
23
- process.exit(0);
24
- }
25
- const description = descVal.trim();
26
- const acceptance = [];
27
- p.log.info('Acceptance criteria — one per line, empty line to finish');
28
- while (true) {
29
- const val = await p.text({ message: '>', placeholder: 'Criterion (or press Enter to finish)' });
30
- if (p.isCancel(val) || !val || !val.trim())
31
- break;
32
- acceptance.push(val.trim());
33
- }
34
- const spinner = p.spinner();
35
- spinner.start('Saving...');
36
- try {
37
- const config = await loadConfig(cwd);
38
- const db = openDB(config, cwd);
39
- const slug = slugify(title);
40
- const task = db.addTask({ slug, title, description: description || undefined, acceptance });
41
- db.writeFeatureList(cwd);
42
- db.close();
43
- spinner.stop('');
44
- console.log(pc.green(`✓ Task #${task.id} added — ${task.slug} (pending)`));
45
- console.log(pc.cyan('→') + ' ' + pc.cyan('ahk status') + ' to see all tasks');
46
- }
47
- catch (err) {
48
- spinner.stop(pc.red('Failed'));
49
- p.log.error(err instanceof Error ? err.message : String(err));
50
- process.exit(1);
51
- }
52
- }
53
- //# sourceMappingURL=add.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"add.js","sourceRoot":"","sources":["../../../src/commands/task/add.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export declare function runTaskDone(cwd: string, idOrSlug: string): Promise<void>;
2
- //# sourceMappingURL=done.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"done.d.ts","sourceRoot":"","sources":["../../../src/commands/task/done.ts"],"names":[],"mappings":"AAOA,wBAAsB,WAAW,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAyC9E"}
@@ -1,45 +0,0 @@
1
- import pc from 'picocolors';
2
- import { spawnSync } from 'node:child_process';
3
- import { existsSync } from 'node:fs';
4
- import { resolve } from 'node:path';
5
- import { loadConfig } from '../../core/config.js';
6
- import { openDB } from '../../core/db.js';
7
- export async function runTaskDone(cwd, idOrSlug) {
8
- const config = await loadConfig(cwd);
9
- // Run health check first if required
10
- if (config.health.required) {
11
- const scriptPath = resolve(cwd, config.health.scriptPath);
12
- if (existsSync(scriptPath)) {
13
- const result = spawnSync('bash', [scriptPath], { cwd, stdio: 'pipe', encoding: 'utf8' });
14
- if (result.status !== 0) {
15
- console.error(pc.red('✗ Health check failed — cannot mark task as done.'));
16
- if (result.stdout)
17
- console.error(result.stdout);
18
- if (result.stderr)
19
- console.error(result.stderr);
20
- process.exit(1);
21
- }
22
- }
23
- }
24
- const db = openDB(config, cwd);
25
- try {
26
- const parsed = parseInt(idOrSlug, 10);
27
- const isId = !isNaN(parsed);
28
- const task = isId ? db.getTaskById(parsed) : db.getTaskBySlug(idOrSlug);
29
- if (!task) {
30
- console.error(pc.red(`Task not found: ${idOrSlug}`));
31
- process.exit(1);
32
- }
33
- if (task.status === 'done') {
34
- console.log(pc.dim(`Task #${task.id} is already done.`));
35
- return;
36
- }
37
- db.updateTaskStatus(task.id, 'done');
38
- db.writeFeatureList(cwd);
39
- console.log(pc.green(`✓ Task #${task.id} — ${task.slug} marked as done`));
40
- }
41
- finally {
42
- db.close();
43
- }
44
- }
45
- //# sourceMappingURL=done.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"done.js","sourceRoot":"","sources":["../../../src/commands/task/done.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,YAAY,CAAA;AAC3B,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAA;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAEzC,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,GAAW,EAAE,QAAgB;IAC7D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,GAAG,CAAC,CAAA;IAEpC,qCAAqC;IACrC,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QAC3B,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;QACzD,IAAI,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAA;YACxF,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACxB,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,mDAAmD,CAAC,CAAC,CAAA;gBAC1E,IAAI,MAAM,CAAC,MAAM;oBAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;gBAC/C,IAAI,MAAM,CAAC,MAAM;oBAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;gBAC/C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YACjB,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAE9B,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAA;QACrC,MAAM,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;QAEvE,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,mBAAmB,QAAQ,EAAE,CAAC,CAAC,CAAA;YACpD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YAC3B,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAA;YACxD,OAAM;QACR,CAAC;QAED,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;QACpC,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAA;QAExB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,EAAE,MAAM,IAAI,CAAC,IAAI,iBAAiB,CAAC,CAAC,CAAA;IAC3E,CAAC;YAAS,CAAC;QACT,EAAE,CAAC,KAAK,EAAE,CAAA;IACZ,CAAC;AACH,CAAC"}
@@ -1,4 +0,0 @@
1
- export { runTaskAdd } from './add.js';
2
- export { runTaskList } from './list.js';
3
- export { runTaskDone } from './done.js';
4
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/task/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA"}
@@ -1,4 +0,0 @@
1
- export { runTaskAdd } from './add.js';
2
- export { runTaskList } from './list.js';
3
- export { runTaskDone } from './done.js';
4
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/task/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA"}
@@ -1,7 +0,0 @@
1
- interface TaskListOptions {
2
- status?: string;
3
- json?: boolean;
4
- }
5
- export declare function runTaskList(cwd: string, opts: TaskListOptions): Promise<void>;
6
- export {};
7
- //# sourceMappingURL=list.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../src/commands/task/list.ts"],"names":[],"mappings":"AAMA,UAAU,eAAe;IACvB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,OAAO,CAAA;CACf;AASD,wBAAsB,WAAW,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CAqCnF"}
@@ -1,42 +0,0 @@
1
- import Table from 'cli-table3';
2
- import pc from 'picocolors';
3
- import { loadConfig } from '../../core/config.js';
4
- import { openDB } from '../../core/db.js';
5
- const STATUS_COLOR = {
6
- pending: (s) => pc.dim(s),
7
- in_progress: (s) => pc.cyan(s),
8
- done: (s) => pc.green(s),
9
- blocked: (s) => pc.red(s),
10
- };
11
- export async function runTaskList(cwd, opts) {
12
- const config = await loadConfig(cwd);
13
- const db = openDB(config, cwd);
14
- try {
15
- const validStatuses = ['pending', 'in_progress', 'done', 'blocked'];
16
- const filterStatus = opts.status && validStatuses.includes(opts.status)
17
- ? opts.status
18
- : undefined;
19
- const tasks = filterStatus ? db.getTasks(filterStatus) : db.getTasks();
20
- if (opts.json) {
21
- console.log(JSON.stringify(tasks, null, 2));
22
- return;
23
- }
24
- if (tasks.length === 0) {
25
- console.log(pc.dim('No tasks' + (filterStatus ? ` with status: ${filterStatus}` : '') + '.'));
26
- return;
27
- }
28
- const table = new Table({
29
- head: ['ID', 'Slug', 'Title', 'Status'].map((h) => pc.bold(h)),
30
- style: { head: [], border: [] },
31
- });
32
- for (const t of tasks) {
33
- const colorFn = STATUS_COLOR[t.status] ?? ((s) => s);
34
- table.push([String(t.id), t.slug, t.title.slice(0, 50), colorFn(t.status)]);
35
- }
36
- console.log(table.toString());
37
- }
38
- finally {
39
- db.close();
40
- }
41
- }
42
- //# sourceMappingURL=list.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/task/list.ts"],"names":[],"mappings":"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"}
@@ -1,5 +0,0 @@
1
- import type { HarnessConfig } from '../types.js';
2
- export declare function findConfigFile(cwd: string): string | null;
3
- export declare function loadConfig(cwd: string): Promise<HarnessConfig>;
4
- export declare function defineHarness(config: HarnessConfig): HarnessConfig;
5
- //# sourceMappingURL=config.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/core/config.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAQhD,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAMzD;AAED,wBAAsB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAepE;AAED,wBAAgB,aAAa,CAAC,MAAM,EAAE,aAAa,GAAG,aAAa,CAElE"}
@@ -1,77 +0,0 @@
1
- import { createJiti } from 'jiti';
2
- import { existsSync } from 'node:fs';
3
- import { join } from 'node:path';
4
- const CONFIG_NAMES = [
5
- 'agent-harness-kit.config.ts',
6
- 'agent-harness-kit.config.js',
7
- 'agent-harness-kit.config.mjs',
8
- ];
9
- export function findConfigFile(cwd) {
10
- for (const name of CONFIG_NAMES) {
11
- const candidate = join(cwd, name);
12
- if (existsSync(candidate))
13
- return candidate;
14
- }
15
- return null;
16
- }
17
- export async function loadConfig(cwd) {
18
- const configPath = findConfigFile(cwd);
19
- if (!configPath) {
20
- throw new Error('No agent-harness-kit.config found. Run: ahk init');
21
- }
22
- const jiti = createJiti(import.meta.url);
23
- const mod = await jiti.import(configPath);
24
- const config = mod.default ?? mod;
25
- if (!config || typeof config !== 'object') {
26
- throw new Error(`agent-harness-kit.config must export a default HarnessConfig object.`);
27
- }
28
- return applyDefaults(config);
29
- }
30
- export function defineHarness(config) {
31
- return config;
32
- }
33
- function applyDefaults(config) {
34
- const c = config;
35
- return {
36
- ...config,
37
- provider: c.provider ?? 'claude-code',
38
- project: {
39
- docsPath: './docs',
40
- agentsMd: './AGENTS.md',
41
- ...c.project,
42
- },
43
- agents: {
44
- lead: { instructionsPath: null },
45
- explorer: { instructionsPath: null },
46
- builder: { instructionsPath: null },
47
- reviewer: { instructionsPath: null },
48
- custom: [],
49
- ...c.agents,
50
- },
51
- storage: {
52
- dir: '.harness',
53
- dbPath: '.harness/harness.db',
54
- tasks: { adapter: 'local' },
55
- sections: {
56
- toolsUsed: true,
57
- filesModified: true,
58
- result: true,
59
- blockers: true,
60
- nextSteps: false,
61
- },
62
- markdownFallback: { enabled: true, path: '.harness/current.md' },
63
- ...c.storage,
64
- },
65
- health: {
66
- scriptPath: './health.sh',
67
- required: true,
68
- ...c.health,
69
- },
70
- tools: {
71
- mcp: { enabled: true, port: 3742 },
72
- scripts: { enabled: true, outputDir: './.harness/scripts' },
73
- ...c.tools,
74
- },
75
- };
76
- }
77
- //# sourceMappingURL=config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/core/config.ts"],"names":[],"mappings":"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"}
@@ -1,7 +0,0 @@
1
- import type { HarnessDB } from './db.js';
2
- export interface DashboardServerResult {
3
- url: string;
4
- close: () => void;
5
- }
6
- export declare function startDashboardServer(db: HarnessDB, dbPath: string, staticPath: string, port: number): DashboardServerResult;
7
- //# sourceMappingURL=dashboard-server.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dashboard-server.d.ts","sourceRoot":"","sources":["../../src/core/dashboard-server.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAA;AAsCxC,MAAM,WAAW,qBAAqB;IACpC,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,EAAE,MAAM,IAAI,CAAA;CAClB;AAED,wBAAgB,oBAAoB,CAClC,EAAE,EAAE,SAAS,EACb,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,MAAM,EAClB,IAAI,EAAE,MAAM,GACX,qBAAqB,CAkNvB"}
@@ -1,223 +0,0 @@
1
- import { Hono } from 'hono';
2
- import { serve } from '@hono/node-server';
3
- import { WebSocketServer } from 'ws';
4
- import { watch } from 'node:fs';
5
- import { existsSync, readFileSync } from 'node:fs';
6
- import { join, extname } from 'node:path';
7
- const AGENT_ORDER = ['lead', 'explorer', 'builder', 'reviewer'];
8
- // ─── Static file serving ──────────────────────────────────────────────────────
9
- const MIME = {
10
- '.html': 'text/html; charset=utf-8',
11
- '.js': 'application/javascript; charset=utf-8',
12
- '.css': 'text/css; charset=utf-8',
13
- '.json': 'application/json; charset=utf-8',
14
- '.svg': 'image/svg+xml',
15
- '.png': 'image/png',
16
- '.ico': 'image/x-icon',
17
- '.woff': 'font/woff',
18
- '.woff2': 'font/woff2',
19
- '.ttf': 'font/ttf',
20
- };
21
- function fileResponse(filePath) {
22
- const content = readFileSync(filePath);
23
- const mime = MIME[extname(filePath)] ?? 'application/octet-stream';
24
- return new Response(content, {
25
- headers: { 'Content-Type': mime, 'Cache-Control': 'no-cache' },
26
- });
27
- }
28
- export function startDashboardServer(db, dbPath, staticPath, port) {
29
- const app = new Hono();
30
- // ─── CORS ─────────────────────────────────────────────────────────────────
31
- app.use('/api/*', async (c, next) => {
32
- await next();
33
- c.res.headers.set('Access-Control-Allow-Origin', '*');
34
- });
35
- // ─── Stats overview ───────────────────────────────────────────────────────
36
- app.get('/api/stats', (c) => {
37
- const summary = db.getStatusSummary();
38
- const byStatus = { pending: 0, in_progress: 0, done: 0, blocked: 0 };
39
- for (const { status, total } of summary)
40
- byStatus[status] = total;
41
- const [{ total: totalActions }] = db.queryRaw(`SELECT COUNT(*) as total FROM actions`);
42
- const [{ total: totalFiles }] = db.queryRaw(`SELECT COUNT(*) as total FROM action_files`);
43
- const [{ total: uniqueTools }] = db.queryRaw(`SELECT COUNT(DISTINCT tool_name) as total FROM action_tools`);
44
- const [{ total: activeAgents }] = db.queryRaw(`SELECT COUNT(DISTINCT agent) as total FROM actions WHERE status = 'in_progress'`);
45
- return c.json({ byStatus, totalActions, totalFiles, uniqueTools, activeAgents });
46
- });
47
- // ─── Meta ─────────────────────────────────────────────────────────────────
48
- app.get('/api/meta', (c) => {
49
- return c.json({ ok: true });
50
- });
51
- // ─── Tasks list ───────────────────────────────────────────────────────────
52
- app.get('/api/tasks', (c) => {
53
- const rows = db.queryRaw(`
54
- SELECT t.*,
55
- COUNT(ta.id) as acceptance_total,
56
- COALESCE(SUM(ta.met), 0) as acceptance_met
57
- FROM tasks t
58
- LEFT JOIN task_acceptance ta ON ta.task_id = t.id
59
- GROUP BY t.id
60
- ORDER BY t.id
61
- `);
62
- return c.json(rows);
63
- });
64
- // ─── Task detail ──────────────────────────────────────────────────────────
65
- app.get('/api/tasks/:id', (c) => {
66
- const id = parseInt(c.req.param('id'));
67
- const task = db.getTaskById(id);
68
- if (!task)
69
- return c.json({ error: 'Not found' }, 404);
70
- const acceptance = db.getTaskAcceptance(id);
71
- const actions = db.getActionsForTask(id).map((action) => ({
72
- ...action,
73
- sections: db.getActionSections(action.id),
74
- files: db.queryRaw(`SELECT * FROM action_files WHERE action_id = ?`, action.id),
75
- tools: db.queryRaw(`SELECT * FROM action_tools WHERE action_id = ? ORDER BY called_at`, action.id),
76
- }));
77
- return c.json({ ...task, acceptance, actions });
78
- });
79
- // ─── Tools top ────────────────────────────────────────────────────────────
80
- app.get('/api/tools/top', (c) => {
81
- const limit = parseInt(c.req.query('limit') ?? '20');
82
- return c.json(db.getTopTools(limit));
83
- });
84
- // ─── Tools recent ─────────────────────────────────────────────────────────
85
- app.get('/api/tools/recent', (c) => {
86
- const limit = parseInt(c.req.query('limit') ?? '50');
87
- const rows = db.queryRaw(`
88
- SELECT at.*, t.id as task_id, t.title as task_title, t.slug as task_slug, a.agent
89
- FROM action_tools at
90
- JOIN actions a ON at.action_id = a.id
91
- JOIN tasks t ON a.task_id = t.id
92
- ORDER BY at.called_at DESC
93
- LIMIT ?
94
- `, limit);
95
- return c.json(rows);
96
- });
97
- // ─── Files top ────────────────────────────────────────────────────────────
98
- app.get('/api/files/top', (c) => {
99
- const limit = parseInt(c.req.query('limit') ?? '20');
100
- const rows = db.queryRaw(`
101
- SELECT
102
- file_path,
103
- COUNT(*) as total,
104
- SUM(CASE WHEN operation='read' THEN 1 ELSE 0 END) as read,
105
- SUM(CASE WHEN operation='created' THEN 1 ELSE 0 END) as created,
106
- SUM(CASE WHEN operation='modified' THEN 1 ELSE 0 END) as modified,
107
- SUM(CASE WHEN operation='deleted' THEN 1 ELSE 0 END) as deleted
108
- FROM action_files
109
- GROUP BY file_path
110
- ORDER BY total DESC
111
- LIMIT ?
112
- `, limit);
113
- return c.json(rows);
114
- });
115
- // ─── Files recent ─────────────────────────────────────────────────────────
116
- app.get('/api/files/recent', (c) => {
117
- const limit = parseInt(c.req.query('limit') ?? '50');
118
- const rows = db.queryRaw(`
119
- SELECT af.*, t.id as task_id, t.title as task_title, t.slug as task_slug,
120
- a.agent, a.created_at as called_at
121
- FROM action_files af
122
- JOIN actions a ON af.action_id = a.id
123
- JOIN tasks t ON a.task_id = t.id
124
- ORDER BY a.created_at DESC
125
- LIMIT ?
126
- `, limit);
127
- return c.json(rows);
128
- });
129
- // ─── Agents stats ─────────────────────────────────────────────────────────
130
- app.get('/api/agents/stats', (c) => {
131
- const rows = db.queryRaw(`
132
- SELECT
133
- a.agent,
134
- COUNT(*) as actions_total,
135
- SUM(CASE WHEN a.status='completed' THEN 1 ELSE 0 END) as actions_done,
136
- SUM(CASE WHEN a.status='blocked' THEN 1 ELSE 0 END) as actions_blocked,
137
- COUNT(DISTINCT a.task_id) as tasks_worked,
138
- COUNT(DISTINCT af.file_path) as files_touched
139
- FROM actions a
140
- LEFT JOIN action_files af ON af.action_id = a.id
141
- GROUP BY a.agent
142
- ORDER BY actions_total DESC
143
- `);
144
- const sorted = rows.sort((a, b) => {
145
- const ai = AGENT_ORDER.indexOf(a.agent);
146
- const bi = AGENT_ORDER.indexOf(b.agent);
147
- if (ai === -1 && bi === -1)
148
- return 0;
149
- if (ai === -1)
150
- return 1;
151
- if (bi === -1)
152
- return -1;
153
- return ai - bi;
154
- });
155
- return c.json(sorted);
156
- });
157
- // ─── Timeline ─────────────────────────────────────────────────────────────
158
- app.get('/api/timeline', (c) => {
159
- const limit = parseInt(c.req.query('limit') ?? '50');
160
- const rows = db.queryRaw(`
161
- SELECT a.*, t.title as task_title, t.slug as task_slug, t.status as task_status
162
- FROM actions a
163
- JOIN tasks t ON a.task_id = t.id
164
- ORDER BY a.created_at DESC
165
- LIMIT ?
166
- `, limit);
167
- return c.json(rows);
168
- });
169
- // ─── Static SPA ───────────────────────────────────────────────────────────
170
- app.get('/*', (c) => {
171
- const urlPath = c.req.path;
172
- if (urlPath !== '/') {
173
- const candidate = join(staticPath, urlPath);
174
- if (existsSync(candidate)) {
175
- try {
176
- return fileResponse(candidate);
177
- }
178
- catch { /* fall through */ }
179
- }
180
- }
181
- return fileResponse(join(staticPath, 'index.html'));
182
- });
183
- // ─── Start HTTP server ────────────────────────────────────────────────────
184
- const httpServer = serve({ fetch: app.fetch, port });
185
- // ─── WebSocket ────────────────────────────────────────────────────────────
186
- const wss = new WebSocketServer({ noServer: true });
187
- httpServer.on('upgrade', (req, socket, head) => {
188
- if (req.url === '/ws') {
189
- wss.handleUpgrade(req, socket, head, (ws) => {
190
- wss.emit('connection', ws, req);
191
- });
192
- }
193
- else {
194
- socket.destroy();
195
- }
196
- });
197
- // ─── DB file watcher → broadcast update ──────────────────────────────────
198
- let debounce;
199
- const broadcast = () => {
200
- clearTimeout(debounce);
201
- debounce = setTimeout(() => {
202
- for (const client of wss.clients) {
203
- if (client.readyState === 1) {
204
- client.send(JSON.stringify({ type: 'update' }));
205
- }
206
- }
207
- }, 150);
208
- };
209
- // Watch WAL file for writes (more responsive in WAL mode)
210
- const walPath = `${dbPath}-wal`;
211
- const watchTarget = existsSync(walPath) ? walPath : dbPath;
212
- const watcher = watch(watchTarget, broadcast);
213
- return {
214
- url: `http://localhost:${port}`,
215
- close: () => {
216
- clearTimeout(debounce);
217
- watcher.close();
218
- wss.close();
219
- httpServer.close();
220
- },
221
- };
222
- }
223
- //# sourceMappingURL=dashboard-server.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dashboard-server.js","sourceRoot":"","sources":["../../src/core/dashboard-server.ts"],"names":[],"mappings":"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"}
package/dist/core/db.d.ts DELETED
@@ -1,57 +0,0 @@
1
- import type { TaskRow, TaskAcceptanceRow, ActionRow, ActionSectionRow, ActionFileRow, TaskStatus, AgentName, HarnessConfig } from '../types.js';
2
- export declare class HarnessDB {
3
- private db;
4
- private config;
5
- constructor(dbPath: string, config: HarnessConfig);
6
- addTask(params: {
7
- slug: string;
8
- title: string;
9
- description?: string;
10
- acceptance?: string[];
11
- }): TaskRow;
12
- getTasks(status?: TaskStatus): TaskRow[];
13
- getTaskById(id: number): TaskRow | null;
14
- getTaskBySlug(slug: string): TaskRow | null;
15
- getTaskAcceptance(taskId: number): TaskAcceptanceRow[];
16
- updateTaskStatus(idOrSlug: number | string, status: TaskStatus): TaskRow;
17
- claimTask(id: number, agent: string): TaskRow | null;
18
- startAction(taskId: number, agent: AgentName): ActionRow;
19
- writeSection(actionId: string, sectionType: string, content: string): void;
20
- completeAction(actionId: string, summary: string): ActionRow;
21
- getAction(actionId: string): ActionRow | null;
22
- getActionsForTask(taskId: number): ActionRow[];
23
- getActionSections(actionId: string): ActionSectionRow[];
24
- recordFile(actionId: string, filePath: string, operation: ActionFileRow['operation'], notes?: string): void;
25
- recordTool(actionId: string, toolName: string, argsJson?: string, resultSummary?: string): void;
26
- getFilesForTask(taskId: number): (ActionFileRow & {
27
- agent: AgentName;
28
- })[];
29
- getTopTools(limit?: number): {
30
- tool_name: string;
31
- uses: number;
32
- }[];
33
- getStatusSummary(): {
34
- status: string;
35
- total: number;
36
- }[];
37
- regenerateCurrentMd(): void;
38
- queryRaw<T = Record<string, unknown>>(sql: string, ...params: unknown[]): T[];
39
- exportJson(): {
40
- tasks: TaskRow[];
41
- actions: ActionRow[];
42
- sections: ActionSectionRow[];
43
- };
44
- close(): void;
45
- syncFromFeatureList(tasks: {
46
- slug: string;
47
- title: string;
48
- description?: string;
49
- acceptance?: string[];
50
- }[]): {
51
- added: number;
52
- skipped: number;
53
- };
54
- writeFeatureList(cwd: string): void;
55
- }
56
- export declare function openDB(config: HarnessConfig, cwd: string): HarnessDB;
57
- //# sourceMappingURL=db.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../src/core/db.ts"],"names":[],"mappings":"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"}