@roackb2/heddle 0.0.12 → 0.0.14

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 (103) hide show
  1. package/README.md +327 -211
  2. package/dist/src/cli/chat/App.d.ts.map +1 -1
  3. package/dist/src/cli/chat/App.js +6 -0
  4. package/dist/src/cli/chat/App.js.map +1 -1
  5. package/dist/src/cli/chat/state/local-commands.d.ts +3 -1
  6. package/dist/src/cli/chat/state/local-commands.d.ts.map +1 -1
  7. package/dist/src/cli/chat/state/local-commands.js +178 -3
  8. package/dist/src/cli/chat/state/local-commands.js.map +1 -1
  9. package/dist/src/cli/chat/state/types.d.ts +6 -0
  10. package/dist/src/cli/chat/state/types.d.ts.map +1 -1
  11. package/dist/src/cli/chat/submit.d.ts +2 -0
  12. package/dist/src/cli/chat/submit.d.ts.map +1 -1
  13. package/dist/src/cli/chat/submit.js +10 -1
  14. package/dist/src/cli/chat/submit.js.map +1 -1
  15. package/dist/src/cli/chat/utils/runtime.d.ts +1 -0
  16. package/dist/src/cli/chat/utils/runtime.d.ts.map +1 -1
  17. package/dist/src/cli/chat/utils/runtime.js +1 -0
  18. package/dist/src/cli/chat/utils/runtime.js.map +1 -1
  19. package/dist/src/cli/daemon.d.ts +14 -0
  20. package/dist/src/cli/daemon.d.ts.map +1 -0
  21. package/dist/src/cli/daemon.js +61 -0
  22. package/dist/src/cli/daemon.js.map +1 -0
  23. package/dist/src/cli/heartbeat.d.ts.map +1 -1
  24. package/dist/src/cli/heartbeat.js +14 -5
  25. package/dist/src/cli/heartbeat.js.map +1 -1
  26. package/dist/src/cli/main.js +6 -0
  27. package/dist/src/cli/main.js.map +1 -1
  28. package/dist/src/index.d.ts +4 -0
  29. package/dist/src/index.d.ts.map +1 -1
  30. package/dist/src/index.js +2 -0
  31. package/dist/src/index.js.map +1 -1
  32. package/dist/src/runtime/heartbeat-lucid.d.ts +42 -0
  33. package/dist/src/runtime/heartbeat-lucid.d.ts.map +1 -0
  34. package/dist/src/runtime/heartbeat-lucid.js +188 -0
  35. package/dist/src/runtime/heartbeat-lucid.js.map +1 -0
  36. package/dist/src/runtime/heartbeat-scheduler.d.ts +13 -0
  37. package/dist/src/runtime/heartbeat-scheduler.d.ts.map +1 -1
  38. package/dist/src/runtime/heartbeat-scheduler.js +74 -4
  39. package/dist/src/runtime/heartbeat-scheduler.js.map +1 -1
  40. package/dist/src/runtime/heartbeat-views.d.ts +50 -0
  41. package/dist/src/runtime/heartbeat-views.d.ts.map +1 -0
  42. package/dist/src/runtime/heartbeat-views.js +60 -0
  43. package/dist/src/runtime/heartbeat-views.js.map +1 -0
  44. package/dist/src/server/app.d.ts +6 -0
  45. package/dist/src/server/app.d.ts.map +1 -0
  46. package/dist/src/server/app.js +36 -0
  47. package/dist/src/server/app.js.map +1 -0
  48. package/dist/src/server/dev.d.ts +2 -0
  49. package/dist/src/server/dev.d.ts.map +1 -0
  50. package/dist/src/server/dev.js +39 -0
  51. package/dist/src/server/dev.js.map +1 -0
  52. package/dist/src/server/features/control-plane/router.d.ts +37 -0
  53. package/dist/src/server/features/control-plane/router.d.ts.map +1 -0
  54. package/dist/src/server/features/control-plane/router.js +34 -0
  55. package/dist/src/server/features/control-plane/router.js.map +1 -0
  56. package/dist/src/server/features/control-plane/services/chat-sessions.d.ts +4 -0
  57. package/dist/src/server/features/control-plane/services/chat-sessions.d.ts.map +1 -0
  58. package/dist/src/server/features/control-plane/services/chat-sessions.js +63 -0
  59. package/dist/src/server/features/control-plane/services/chat-sessions.js.map +1 -0
  60. package/dist/src/server/features/control-plane/services/control-plane-state.d.ts +4 -0
  61. package/dist/src/server/features/control-plane/services/control-plane-state.d.ts.map +1 -0
  62. package/dist/src/server/features/control-plane/services/control-plane-state.js +19 -0
  63. package/dist/src/server/features/control-plane/services/control-plane-state.js.map +1 -0
  64. package/dist/src/server/features/control-plane/services/heartbeat.d.ts +7 -0
  65. package/dist/src/server/features/control-plane/services/heartbeat.d.ts.map +1 -0
  66. package/dist/src/server/features/control-plane/services/heartbeat.js +12 -0
  67. package/dist/src/server/features/control-plane/services/heartbeat.js.map +1 -0
  68. package/dist/src/server/features/control-plane/types.d.ts +31 -0
  69. package/dist/src/server/features/control-plane/types.d.ts.map +1 -0
  70. package/dist/src/server/features/control-plane/types.js +2 -0
  71. package/dist/src/server/features/control-plane/types.js.map +1 -0
  72. package/dist/src/server/index.d.ts +8 -0
  73. package/dist/src/server/index.d.ts.map +1 -0
  74. package/dist/src/server/index.js +42 -0
  75. package/dist/src/server/index.js.map +1 -0
  76. package/dist/src/server/logger.d.ts +8 -0
  77. package/dist/src/server/logger.d.ts.map +1 -0
  78. package/dist/src/server/logger.js +11 -0
  79. package/dist/src/server/logger.js.map +1 -0
  80. package/dist/src/server/middleware/request-logging.d.ts +4 -0
  81. package/dist/src/server/middleware/request-logging.d.ts.map +1 -0
  82. package/dist/src/server/middleware/request-logging.js +15 -0
  83. package/dist/src/server/middleware/request-logging.js.map +1 -0
  84. package/dist/src/server/router.d.ts +55 -0
  85. package/dist/src/server/router.d.ts.map +1 -0
  86. package/dist/src/server/router.js +14 -0
  87. package/dist/src/server/router.js.map +1 -0
  88. package/dist/src/server/static.d.ts +4 -0
  89. package/dist/src/server/static.d.ts.map +1 -0
  90. package/dist/src/server/static.js +25 -0
  91. package/dist/src/server/static.js.map +1 -0
  92. package/dist/src/server/trpc.d.ts +9 -0
  93. package/dist/src/server/trpc.d.ts.map +1 -0
  94. package/dist/src/server/trpc.js +5 -0
  95. package/dist/src/server/trpc.js.map +1 -0
  96. package/dist/src/server/types.d.ts +17 -0
  97. package/dist/src/server/types.d.ts.map +1 -0
  98. package/dist/src/server/types.js +2 -0
  99. package/dist/src/server/types.js.map +1 -0
  100. package/dist/src/web/assets/index-DmYQXJQf.css +1 -0
  101. package/dist/src/web/assets/index-xFJTOaTY.js +9 -0
  102. package/dist/src/web/index.html +13 -0
  103. package/package.json +18 -3
@@ -0,0 +1,63 @@
1
+ import { existsSync, readFileSync } from 'node:fs';
2
+ export function readChatSessionViews(sessionsPath) {
3
+ if (!existsSync(sessionsPath)) {
4
+ return [];
5
+ }
6
+ try {
7
+ const parsed = JSON.parse(readFileSync(sessionsPath, 'utf8'));
8
+ if (!Array.isArray(parsed)) {
9
+ return [];
10
+ }
11
+ return parsed.flatMap(projectChatSessionView).sort((left, right) => {
12
+ return (right.updatedAt ?? '').localeCompare(left.updatedAt ?? '');
13
+ });
14
+ }
15
+ catch {
16
+ return [];
17
+ }
18
+ }
19
+ export function projectChatSessionView(raw) {
20
+ if (!raw || typeof raw !== 'object' || Array.isArray(raw)) {
21
+ return [];
22
+ }
23
+ const candidate = raw;
24
+ const id = typeof candidate.id === 'string' ? candidate.id : undefined;
25
+ const name = typeof candidate.name === 'string' ? candidate.name : undefined;
26
+ if (!id || !name) {
27
+ return [];
28
+ }
29
+ const turns = Array.isArray(candidate.turns) ? candidate.turns : [];
30
+ const messages = Array.isArray(candidate.messages) ? candidate.messages : [];
31
+ const lastTurn = readObject(turns.at(-1));
32
+ const context = readObject(candidate.context);
33
+ return [{
34
+ id,
35
+ name,
36
+ createdAt: readString(candidate.createdAt),
37
+ updatedAt: readString(candidate.updatedAt),
38
+ model: readString(candidate.model),
39
+ driftEnabled: typeof candidate.driftEnabled === 'boolean' ? candidate.driftEnabled : undefined,
40
+ messageCount: messages.length,
41
+ turnCount: turns.length,
42
+ lastPrompt: readString(lastTurn?.prompt),
43
+ lastOutcome: readString(lastTurn?.outcome),
44
+ lastSummary: readString(lastTurn?.summary),
45
+ context: context ? {
46
+ estimatedHistoryTokens: readNumber(context.estimatedHistoryTokens),
47
+ estimatedRequestTokens: readNumber(context.estimatedRequestTokens),
48
+ lastRunInputTokens: readNumber(context.lastRunInputTokens),
49
+ lastRunOutputTokens: readNumber(context.lastRunOutputTokens),
50
+ lastRunTotalTokens: readNumber(context.lastRunTotalTokens),
51
+ } : undefined,
52
+ }];
53
+ }
54
+ function readObject(value) {
55
+ return value && typeof value === 'object' && !Array.isArray(value) ? value : undefined;
56
+ }
57
+ function readString(value) {
58
+ return typeof value === 'string' ? value : undefined;
59
+ }
60
+ function readNumber(value) {
61
+ return typeof value === 'number' && Number.isFinite(value) ? value : undefined;
62
+ }
63
+ //# sourceMappingURL=chat-sessions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat-sessions.js","sourceRoot":"","sources":["../../../../../../src/server/features/control-plane/services/chat-sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAGnD,MAAM,UAAU,oBAAoB,CAAC,YAAoB;IACvD,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;QAC9B,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,YAAY,EAAE,MAAM,CAAC,CAAY,CAAC;QACzE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3B,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,OAAO,MAAM,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YACjE,OAAO,CAAC,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;IACL,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,GAAY;IACjD,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QAC1D,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,SAAS,GAAG,GAA8B,CAAC;IACjD,MAAM,EAAE,GAAG,OAAO,SAAS,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IACvE,MAAM,IAAI,GAAG,OAAO,SAAS,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7E,IAAI,CAAC,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;QACjB,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IACpE,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;IAC7E,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,MAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IAE9C,OAAO,CAAC;YACN,EAAE;YACF,IAAI;YACJ,SAAS,EAAE,UAAU,CAAC,SAAS,CAAC,SAAS,CAAC;YAC1C,SAAS,EAAE,UAAU,CAAC,SAAS,CAAC,SAAS,CAAC;YAC1C,KAAK,EAAE,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC;YAClC,YAAY,EAAE,OAAO,SAAS,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;YAC9F,YAAY,EAAE,QAAQ,CAAC,MAAM;YAC7B,SAAS,EAAE,KAAK,CAAC,MAAM;YACvB,UAAU,EAAE,UAAU,CAAC,QAAQ,EAAE,MAAM,CAAC;YACxC,WAAW,EAAE,UAAU,CAAC,QAAQ,EAAE,OAAO,CAAC;YAC1C,WAAW,EAAE,UAAU,CAAC,QAAQ,EAAE,OAAO,CAAC;YAC1C,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;gBACjB,sBAAsB,EAAE,UAAU,CAAC,OAAO,CAAC,sBAAsB,CAAC;gBAClE,sBAAsB,EAAE,UAAU,CAAC,OAAO,CAAC,sBAAsB,CAAC;gBAClE,kBAAkB,EAAE,UAAU,CAAC,OAAO,CAAC,kBAAkB,CAAC;gBAC1D,mBAAmB,EAAE,UAAU,CAAC,OAAO,CAAC,mBAAmB,CAAC;gBAC5D,kBAAkB,EAAE,UAAU,CAAC,OAAO,CAAC,kBAAkB,CAAC;aAC3D,CAAC,CAAC,CAAC,SAAS;SACd,CAAC,CAAC;AACL,CAAC;AAED,SAAS,UAAU,CAAC,KAAc;IAChC,OAAO,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAgC,CAAC,CAAC,CAAC,SAAS,CAAC;AACpH,CAAC;AAED,SAAS,UAAU,CAAC,KAAc;IAChC,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;AACvD,CAAC;AAED,SAAS,UAAU,CAAC,KAAc;IAChC,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;AACjF,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { HeddleServerContext } from '../../../types.js';
2
+ import type { ControlPlaneState } from '../types.js';
3
+ export declare function loadControlPlaneState(context: HeddleServerContext): Promise<ControlPlaneState>;
4
+ //# sourceMappingURL=control-plane-state.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"control-plane-state.d.ts","sourceRoot":"","sources":["../../../../../../src/server/features/control-plane/services/control-plane-state.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAIrD,wBAAsB,qBAAqB,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAepG"}
@@ -0,0 +1,19 @@
1
+ import { resolve } from 'node:path';
2
+ import { readChatSessionViews } from './chat-sessions.js';
3
+ import { listControlPlaneHeartbeatRuns, listControlPlaneHeartbeatTasks } from './heartbeat.js';
4
+ export async function loadControlPlaneState(context) {
5
+ const [tasks, runs] = await Promise.all([
6
+ listControlPlaneHeartbeatTasks(context.stateRoot),
7
+ listControlPlaneHeartbeatRuns(context.stateRoot, { limit: 20 }),
8
+ ]);
9
+ return {
10
+ workspaceRoot: context.workspaceRoot,
11
+ stateRoot: context.stateRoot,
12
+ sessions: readChatSessionViews(resolve(context.stateRoot, 'chat-sessions.json')),
13
+ heartbeat: {
14
+ tasks,
15
+ runs,
16
+ },
17
+ };
18
+ }
19
+ //# sourceMappingURL=control-plane-state.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"control-plane-state.js","sourceRoot":"","sources":["../../../../../../src/server/features/control-plane/services/control-plane-state.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAC1D,OAAO,EAAE,6BAA6B,EAAE,8BAA8B,EAAE,MAAM,gBAAgB,CAAC;AAE/F,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAC,OAA4B;IACtE,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACtC,8BAA8B,CAAC,OAAO,CAAC,SAAS,CAAC;QACjD,6BAA6B,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;KAChE,CAAC,CAAC;IAEH,OAAO;QACL,aAAa,EAAE,OAAO,CAAC,aAAa;QACpC,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,QAAQ,EAAE,oBAAoB,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE,oBAAoB,CAAC,CAAC;QAChF,SAAS,EAAE;YACT,KAAK;YACL,IAAI;SACL;KACF,CAAC;AACJ,CAAC"}
@@ -0,0 +1,7 @@
1
+ export declare function createHeartbeatStore(stateRoot: string): import("../../../../index.js").HeartbeatTaskStore;
2
+ export declare function listControlPlaneHeartbeatTasks(stateRoot: string): Promise<import("../../../../index.js").HeartbeatTaskView[]>;
3
+ export declare function listControlPlaneHeartbeatRuns(stateRoot: string, options?: {
4
+ taskId?: string;
5
+ limit?: number;
6
+ }): Promise<import("../../../../index.js").HeartbeatRunView[]>;
7
+ //# sourceMappingURL=heartbeat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"heartbeat.d.ts","sourceRoot":"","sources":["../../../../../../src/server/features/control-plane/services/heartbeat.ts"],"names":[],"mappings":"AAOA,wBAAgB,oBAAoB,CAAC,SAAS,EAAE,MAAM,qDAErD;AAED,wBAAsB,8BAA8B,CAAC,SAAS,EAAE,MAAM,+DAErE;AAED,wBAAsB,6BAA6B,CACjD,SAAS,EAAE,MAAM,EACjB,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAO,8DAGlD"}
@@ -0,0 +1,12 @@
1
+ import { resolve } from 'node:path';
2
+ import { createFileHeartbeatTaskStore, listHeartbeatRunViews, listHeartbeatTaskViews, } from '../../../../index.js';
3
+ export function createHeartbeatStore(stateRoot) {
4
+ return createFileHeartbeatTaskStore({ dir: resolve(stateRoot, 'heartbeat') });
5
+ }
6
+ export async function listControlPlaneHeartbeatTasks(stateRoot) {
7
+ return await listHeartbeatTaskViews(createHeartbeatStore(stateRoot));
8
+ }
9
+ export async function listControlPlaneHeartbeatRuns(stateRoot, options = {}) {
10
+ return await listHeartbeatRunViews(createHeartbeatStore(stateRoot), options);
11
+ }
12
+ //# sourceMappingURL=heartbeat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"heartbeat.js","sourceRoot":"","sources":["../../../../../../src/server/features/control-plane/services/heartbeat.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EACL,4BAA4B,EAC5B,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,sBAAsB,CAAC;AAE9B,MAAM,UAAU,oBAAoB,CAAC,SAAiB;IACpD,OAAO,4BAA4B,CAAC,EAAE,GAAG,EAAE,OAAO,CAAC,SAAS,EAAE,WAAW,CAAC,EAAE,CAAC,CAAC;AAChF,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,8BAA8B,CAAC,SAAiB;IACpE,OAAO,MAAM,sBAAsB,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,CAAC;AACvE,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,6BAA6B,CACjD,SAAiB,EACjB,UAA+C,EAAE;IAEjD,OAAO,MAAM,qBAAqB,CAAC,oBAAoB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,CAAC;AAC/E,CAAC"}
@@ -0,0 +1,31 @@
1
+ import type { HeartbeatRunView, HeartbeatTaskView } from '../../../runtime/heartbeat-views.js';
2
+ export type ChatSessionView = {
3
+ id: string;
4
+ name: string;
5
+ createdAt?: string;
6
+ updatedAt?: string;
7
+ model?: string;
8
+ driftEnabled?: boolean;
9
+ messageCount: number;
10
+ turnCount: number;
11
+ lastPrompt?: string;
12
+ lastOutcome?: string;
13
+ lastSummary?: string;
14
+ context?: {
15
+ estimatedHistoryTokens?: number;
16
+ estimatedRequestTokens?: number;
17
+ lastRunInputTokens?: number;
18
+ lastRunOutputTokens?: number;
19
+ lastRunTotalTokens?: number;
20
+ };
21
+ };
22
+ export type ControlPlaneState = {
23
+ workspaceRoot: string;
24
+ stateRoot: string;
25
+ sessions: ChatSessionView[];
26
+ heartbeat: {
27
+ tasks: HeartbeatTaskView[];
28
+ runs: HeartbeatRunView[];
29
+ };
30
+ };
31
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/server/features/control-plane/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAE/F,MAAM,MAAM,eAAe,GAAG;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE;QACR,sBAAsB,CAAC,EAAE,MAAM,CAAC;QAChC,sBAAsB,CAAC,EAAE,MAAM,CAAC;QAChC,kBAAkB,CAAC,EAAE,MAAM,CAAC;QAC5B,mBAAmB,CAAC,EAAE,MAAM,CAAC;QAC7B,kBAAkB,CAAC,EAAE,MAAM,CAAC;KAC7B,CAAC;CACH,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,eAAe,EAAE,CAAC;IAC5B,SAAS,EAAE;QACT,KAAK,EAAE,iBAAiB,EAAE,CAAC;QAC3B,IAAI,EAAE,gBAAgB,EAAE,CAAC;KAC1B,CAAC;CACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/server/features/control-plane/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,8 @@
1
+ import type { HeddleServerListenOptions } from './types.js';
2
+ export type { HeddleServerListenOptions, HeddleServerOptions } from './types.js';
3
+ export { appRouter, type AppRouter } from './router.js';
4
+ export { createHeddleServerApp } from './app.js';
5
+ export { createServerLogger } from './logger.js';
6
+ export { projectChatSessionView } from './features/control-plane/services/chat-sessions.js';
7
+ export declare function listenHeddleServer(options: HeddleServerListenOptions): Promise<void>;
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/server/index.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,YAAY,CAAC;AAE5D,YAAY,EAAE,yBAAyB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACjF,OAAO,EAAE,SAAS,EAAE,KAAK,SAAS,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,sBAAsB,EAAE,MAAM,oDAAoD,CAAC;AAE5F,wBAAsB,kBAAkB,CAAC,OAAO,EAAE,yBAAyB,GAAG,OAAO,CAAC,IAAI,CAAC,CAyB1F"}
@@ -0,0 +1,42 @@
1
+ import { dirname, resolve } from 'node:path';
2
+ import { fileURLToPath } from 'node:url';
3
+ import { createHeddleServerApp } from './app.js';
4
+ import { createServerLogger } from './logger.js';
5
+ import { assertWebAssetsBuilt } from './static.js';
6
+ export { appRouter } from './router.js';
7
+ export { createHeddleServerApp } from './app.js';
8
+ export { createServerLogger } from './logger.js';
9
+ export { projectChatSessionView } from './features/control-plane/services/chat-sessions.js';
10
+ export async function listenHeddleServer(options) {
11
+ const assetsDir = options.assetsDir ?? resolveDefaultAssetsDir();
12
+ assertWebAssetsBuilt(assetsDir);
13
+ const logger = options.logger ?? createServerLogger({ stateRoot: options.stateRoot });
14
+ const app = createHeddleServerApp({ ...options, assetsDir, logger });
15
+ await new Promise((resolveListen, rejectListen) => {
16
+ const server = app.listen(options.port, options.host, () => {
17
+ server.off('error', rejectListen);
18
+ logger.info({
19
+ host: options.host,
20
+ port: options.port,
21
+ workspaceRoot: options.workspaceRoot,
22
+ stateRoot: options.stateRoot,
23
+ assetsDir,
24
+ }, 'Heddle server started');
25
+ process.stdout.write(`Heddle server listening at http://${options.host}:${options.port}\n`);
26
+ process.stdout.write(`workspace=${options.workspaceRoot}\n`);
27
+ resolveListen();
28
+ });
29
+ server.once('error', (error) => {
30
+ logger.error({ error }, 'Heddle server failed');
31
+ rejectListen(error);
32
+ });
33
+ });
34
+ }
35
+ function resolveDefaultAssetsDir() {
36
+ if (process.env.HEDDLE_WEB_DIST) {
37
+ return resolve(process.env.HEDDLE_WEB_DIST);
38
+ }
39
+ const moduleDir = dirname(fileURLToPath(import.meta.url));
40
+ return resolve(moduleDir, '../web');
41
+ }
42
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/server/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAInD,OAAO,EAAE,SAAS,EAAkB,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,sBAAsB,EAAE,MAAM,oDAAoD,CAAC;AAE5F,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,OAAkC;IACzE,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,uBAAuB,EAAE,CAAC;IACjE,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAChC,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,kBAAkB,CAAC,EAAE,SAAS,EAAE,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;IACtF,MAAM,GAAG,GAAG,qBAAqB,CAAC,EAAE,GAAG,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;IAErE,MAAM,IAAI,OAAO,CAAO,CAAC,aAAa,EAAE,YAAY,EAAE,EAAE;QACtD,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,GAAG,EAAE;YACzD,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;YAClC,MAAM,CAAC,IAAI,CAAC;gBACV,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,aAAa,EAAE,OAAO,CAAC,aAAa;gBACpC,SAAS,EAAE,OAAO,CAAC,SAAS;gBAC5B,SAAS;aACV,EAAE,uBAAuB,CAAC,CAAC;YAC5B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,qCAAqC,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC;YAC5F,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,OAAO,CAAC,aAAa,IAAI,CAAC,CAAC;YAC7D,aAAa,EAAE,CAAC;QAClB,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;YAC7B,MAAM,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,EAAE,sBAAsB,CAAC,CAAC;YAChD,YAAY,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,uBAAuB;IAC9B,IAAI,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC;QAChC,OAAO,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAC9C,CAAC;IAED,MAAM,SAAS,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IAC1D,OAAO,OAAO,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;AACtC,CAAC"}
@@ -0,0 +1,8 @@
1
+ export declare function createServerLogger(options: {
2
+ stateRoot: string;
3
+ logFilePath?: string;
4
+ level?: string;
5
+ pretty?: boolean;
6
+ console?: boolean;
7
+ }): import("pino").Logger<never, boolean>;
8
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/server/logger.ts"],"names":[],"mappings":"AAGA,wBAAgB,kBAAkB,CAAC,OAAO,EAAE;IAC1C,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,yCAOA"}
@@ -0,0 +1,11 @@
1
+ import { resolve } from 'node:path';
2
+ import { createLogger } from '../utils/logger.js';
3
+ export function createServerLogger(options) {
4
+ return createLogger({
5
+ level: options.level ?? process.env.HEDDLE_LOG_LEVEL ?? process.env.LOG_LEVEL ?? 'info',
6
+ pretty: options.pretty ?? process.env.NODE_ENV !== 'production',
7
+ console: options.console ?? true,
8
+ logFilePath: options.logFilePath ?? resolve(options.stateRoot, 'logs', 'server.log'),
9
+ });
10
+ }
11
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/server/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,MAAM,UAAU,kBAAkB,CAAC,OAMlC;IACC,OAAO,YAAY,CAAC;QAClB,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,MAAM;QACvF,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY;QAC/D,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,IAAI;QAChC,WAAW,EAAE,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,YAAY,CAAC;KACrF,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { NextFunction, Request, Response } from 'express';
2
+ import type { Logger } from 'pino';
3
+ export declare function createRequestLoggingMiddleware(logger: Logger): (request: Request, response: Response, next: NextFunction) => void;
4
+ //# sourceMappingURL=request-logging.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"request-logging.d.ts","sourceRoot":"","sources":["../../../../src/server/middleware/request-logging.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAEnC,wBAAgB,8BAA8B,CAAC,MAAM,EAAE,MAAM,IACnD,SAAS,OAAO,EAAE,UAAU,QAAQ,EAAE,MAAM,YAAY,UAYjE"}
@@ -0,0 +1,15 @@
1
+ export function createRequestLoggingMiddleware(logger) {
2
+ return (request, response, next) => {
3
+ const startedAt = Date.now();
4
+ response.once('finish', () => {
5
+ logger.info({
6
+ method: request.method,
7
+ path: request.originalUrl,
8
+ statusCode: response.statusCode,
9
+ durationMs: Date.now() - startedAt,
10
+ }, 'HTTP request');
11
+ });
12
+ next();
13
+ };
14
+ }
15
+ //# sourceMappingURL=request-logging.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"request-logging.js","sourceRoot":"","sources":["../../../../src/server/middleware/request-logging.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,8BAA8B,CAAC,MAAc;IAC3D,OAAO,CAAC,OAAgB,EAAE,QAAkB,EAAE,IAAkB,EAAE,EAAE;QAClE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC7B,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE;YAC3B,MAAM,CAAC,IAAI,CAAC;gBACV,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,IAAI,EAAE,OAAO,CAAC,WAAW;gBACzB,UAAU,EAAE,QAAQ,CAAC,UAAU;gBAC/B,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS;aACnC,EAAE,cAAc,CAAC,CAAC;QACrB,CAAC,CAAC,CAAC;QACH,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,55 @@
1
+ export declare const appRouter: import("@trpc/server").TRPCBuiltRouter<{
2
+ ctx: import("./types.js").HeddleServerContext;
3
+ meta: object;
4
+ errorShape: import("@trpc/server").TRPCDefaultErrorShape;
5
+ transformer: false;
6
+ }, import("@trpc/server").TRPCDecorateCreateRouterOptions<{
7
+ health: import("@trpc/server").TRPCQueryProcedure<{
8
+ input: void;
9
+ output: {
10
+ ok: boolean;
11
+ service: string;
12
+ workspaceRoot: string;
13
+ stateRoot: string;
14
+ };
15
+ meta: object;
16
+ }>;
17
+ controlPlane: import("@trpc/server").TRPCBuiltRouter<{
18
+ ctx: import("./types.js").HeddleServerContext;
19
+ meta: object;
20
+ errorShape: import("@trpc/server").TRPCDefaultErrorShape;
21
+ transformer: false;
22
+ }, import("@trpc/server").TRPCDecorateCreateRouterOptions<{
23
+ state: import("@trpc/server").TRPCQueryProcedure<{
24
+ input: void;
25
+ output: import("./features/control-plane/types.js").ControlPlaneState;
26
+ meta: object;
27
+ }>;
28
+ sessions: import("@trpc/server").TRPCQueryProcedure<{
29
+ input: void;
30
+ output: {
31
+ sessions: import("./features/control-plane/types.js").ChatSessionView[];
32
+ };
33
+ meta: object;
34
+ }>;
35
+ heartbeatTasks: import("@trpc/server").TRPCQueryProcedure<{
36
+ input: void;
37
+ output: {
38
+ tasks: import("../index.js").HeartbeatTaskView[];
39
+ };
40
+ meta: object;
41
+ }>;
42
+ heartbeatRuns: import("@trpc/server").TRPCQueryProcedure<{
43
+ input: {
44
+ taskId?: string | undefined;
45
+ limit?: number | undefined;
46
+ } | undefined;
47
+ output: {
48
+ runs: import("../index.js").HeartbeatRunView[];
49
+ };
50
+ meta: object;
51
+ }>;
52
+ }>>;
53
+ }>>;
54
+ export type AppRouter = typeof appRouter;
55
+ //# sourceMappingURL=router.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"router.d.ts","sourceRoot":"","sources":["../../../src/server/router.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAUpB,CAAC;AAEH,MAAM,MAAM,SAAS,GAAG,OAAO,SAAS,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { procedure, router } from './trpc.js';
2
+ import { controlPlaneRouter } from './features/control-plane/router.js';
3
+ export const appRouter = router({
4
+ health: procedure.query(({ ctx }) => {
5
+ return {
6
+ ok: true,
7
+ service: 'heddle-server',
8
+ workspaceRoot: ctx.workspaceRoot,
9
+ stateRoot: ctx.stateRoot,
10
+ };
11
+ }),
12
+ controlPlane: controlPlaneRouter,
13
+ });
14
+ //# sourceMappingURL=router.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"router.js","sourceRoot":"","sources":["../../../src/server/router.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AAExE,MAAM,CAAC,MAAM,SAAS,GAAG,MAAM,CAAC;IAC9B,MAAM,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;QAClC,OAAO;YACL,EAAE,EAAE,IAAI;YACR,OAAO,EAAE,eAAe;YACxB,aAAa,EAAE,GAAG,CAAC,aAAa;YAChC,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC;IACJ,CAAC,CAAC;IACF,YAAY,EAAE,kBAAkB;CACjC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import express from 'express';
2
+ export declare function assertWebAssetsBuilt(assetsDir: string): void;
3
+ export declare function installWebStaticRoutes(app: express.Express, assetsDir: string): void;
4
+ //# sourceMappingURL=static.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"static.d.ts","sourceRoot":"","sources":["../../../src/server/static.ts"],"names":[],"mappings":"AAEA,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,wBAAgB,oBAAoB,CAAC,SAAS,EAAE,MAAM,QAKrD;AAED,wBAAgB,sBAAsB,CAAC,GAAG,EAAE,OAAO,CAAC,OAAO,EAAE,SAAS,EAAE,MAAM,QAc7E"}
@@ -0,0 +1,25 @@
1
+ import { existsSync } from 'node:fs';
2
+ import { join } from 'node:path';
3
+ import express from 'express';
4
+ export function assertWebAssetsBuilt(assetsDir) {
5
+ const indexPath = join(assetsDir, 'index.html');
6
+ if (!existsSync(indexPath)) {
7
+ throw new Error(`Web assets not found at ${assetsDir}. Run yarn build before starting heddle daemon.`);
8
+ }
9
+ }
10
+ export function installWebStaticRoutes(app, assetsDir) {
11
+ const indexPath = join(assetsDir, 'index.html');
12
+ app.use(express.static(assetsDir, {
13
+ immutable: true,
14
+ index: false,
15
+ maxAge: '1y',
16
+ }));
17
+ app.get(/.*/, (_request, response) => {
18
+ response.sendFile(indexPath, {
19
+ headers: {
20
+ 'Cache-Control': 'no-store',
21
+ },
22
+ });
23
+ });
24
+ }
25
+ //# sourceMappingURL=static.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"static.js","sourceRoot":"","sources":["../../../src/server/static.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,MAAM,UAAU,oBAAoB,CAAC,SAAiB;IACpD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;IAChD,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,KAAK,CAAC,2BAA2B,SAAS,iDAAiD,CAAC,CAAC;IACzG,CAAC;AACH,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,GAAoB,EAAE,SAAiB;IAC5E,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;IAChD,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE;QAChC,SAAS,EAAE,IAAI;QACf,KAAK,EAAE,KAAK;QACZ,MAAM,EAAE,IAAI;KACb,CAAC,CAAC,CAAC;IACJ,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,EAAE;QACnC,QAAQ,CAAC,QAAQ,CAAC,SAAS,EAAE;YAC3B,OAAO,EAAE;gBACP,eAAe,EAAE,UAAU;aAC5B;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { HeddleServerContext } from './types.js';
2
+ export declare const router: import("@trpc/server").TRPCRouterBuilder<{
3
+ ctx: HeddleServerContext;
4
+ meta: object;
5
+ errorShape: import("@trpc/server").TRPCDefaultErrorShape;
6
+ transformer: false;
7
+ }>;
8
+ export declare const procedure: import("@trpc/server").TRPCProcedureBuilder<HeddleServerContext, object, object, import("@trpc/server").TRPCUnsetMarker, import("@trpc/server").TRPCUnsetMarker, import("@trpc/server").TRPCUnsetMarker, import("@trpc/server").TRPCUnsetMarker, false>;
9
+ //# sourceMappingURL=trpc.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trpc.d.ts","sourceRoot":"","sources":["../../../src/server/trpc.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAItD,eAAO,MAAM,MAAM;;;;;EAAW,CAAC;AAC/B,eAAO,MAAM,SAAS,yPAAc,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { initTRPC } from '@trpc/server';
2
+ const t = initTRPC.context().create();
3
+ export const router = t.router;
4
+ export const procedure = t.procedure;
5
+ //# sourceMappingURL=trpc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trpc.js","sourceRoot":"","sources":["../../../src/server/trpc.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAGxC,MAAM,CAAC,GAAG,QAAQ,CAAC,OAAO,EAAuB,CAAC,MAAM,EAAE,CAAC;AAE3D,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC;AAC/B,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC,CAAC,SAAS,CAAC"}
@@ -0,0 +1,17 @@
1
+ import type { Logger } from 'pino';
2
+ export type HeddleServerOptions = {
3
+ workspaceRoot: string;
4
+ stateRoot: string;
5
+ assetsDir?: string;
6
+ logger?: Logger;
7
+ };
8
+ export type HeddleServerListenOptions = HeddleServerOptions & {
9
+ host: string;
10
+ port: number;
11
+ };
12
+ export type HeddleServerContext = {
13
+ workspaceRoot: string;
14
+ stateRoot: string;
15
+ logger: Logger;
16
+ };
17
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/server/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAEnC,MAAM,MAAM,mBAAmB,GAAG;IAChC,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG,mBAAmB,GAAG;IAC5D,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/server/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1 @@
1
+ :root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#10131c;--panel:#191f2de0;--text:#eef2ff;--muted:#98a2b3;--line:#98a2b333;--accent:#88d8c0;--warn:#f4c27a;--bad:#ff8f8f;--good:#83e29e}*{box-sizing:border-box}body{background:radial-gradient(circle at 12% 0%, #88d8c02e, transparent 28rem), radial-gradient(circle at 86% 8%, #f4c27a1a, transparent 24rem), linear-gradient(145deg, #0d111a 0%, var(--bg) 56%, #151827 100%);min-height:100vh;color:var(--text);margin:0;font:15px/1.5 ui-sans-serif,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif}button{font:inherit}.shell{width:min(1180px,100vw - 32px);margin:0 auto;padding:30px 0 48px}.hero{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:22px;display:flex}.eyebrow{color:var(--accent);letter-spacing:.16em;text-transform:uppercase;margin:0 0 10px;font-size:12px;font-weight:800}h1{letter-spacing:-.065em;max-width:820px;margin:0;font-size:clamp(34px,6vw,64px);line-height:.94}h2,h3,p{margin-top:0}.lede{max-width:680px;color:var(--muted);margin:16px 0 0;font-size:17px}.status{text-overflow:ellipsis;white-space:nowrap;border:1px solid var(--line);max-width:min(440px,100%);color:var(--muted);background:#191f2dc7;border-radius:999px;padding:9px 13px;overflow:hidden}.status.bad{color:var(--bad);border-color:#ff8f8f66}.tabs{flex-wrap:wrap;gap:10px;margin:18px 0;display:flex}.tabs button{border:1px solid var(--line);color:var(--text);background:var(--panel);cursor:pointer;border-radius:999px;padding:9px 14px}.tabs button.active{border-color:var(--accent);color:#07110e;background:var(--accent)}.grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.wide{grid-column:span 2}.panel{border:1px solid var(--line);background:var(--panel);border-radius:24px;min-width:0;padding:18px;box-shadow:0 24px 80px #00000038}.panel h2{letter-spacing:-.02em;margin-bottom:12px;font-size:18px}.strong{overflow-wrap:anywhere;margin-bottom:6px;font-weight:800}.muted{color:var(--muted);font-size:13px}.metric{letter-spacing:-.05em;margin-bottom:4px;font-size:44px;font-weight:850;line-height:1}.item{border-top:1px solid #98a2b324;padding:14px 0}.item:first-child{border-top:0;padding-top:0}.item:last-child{padding-bottom:0}.item h3{letter-spacing:-.015em;margin-bottom:2px;font-size:16px}.pills{flex-wrap:wrap;gap:6px;margin:8px 0;display:flex}.pill{color:var(--muted);border:1px solid #98a2b33d;border-radius:999px;align-items:center;padding:2px 8px;font-size:12px;display:inline-flex}.pill.good{color:var(--good);border-color:#83e29e5c}.pill.warn{color:var(--warn);border-color:#f4c27a66}.pill.bad{color:var(--bad);border-color:#ff8f8f66}.summary{color:#d6dded;white-space:pre-wrap;overflow-wrap:anywhere;margin:8px 0 0}.empty{color:var(--muted)}pre{color:#d6dded;background:#0b0f18;border-radius:16px;margin:0;padding:14px;overflow:auto}@media (width<=840px){.shell{width:min(100vw - 22px,680px);padding-top:18px}.hero{display:block}.status{margin-top:14px;display:inline-flex}.grid{grid-template-columns:1fr}.wide{grid-column:auto}}