@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.
- package/README.md +327 -211
- package/dist/src/cli/chat/App.d.ts.map +1 -1
- package/dist/src/cli/chat/App.js +6 -0
- package/dist/src/cli/chat/App.js.map +1 -1
- package/dist/src/cli/chat/state/local-commands.d.ts +3 -1
- package/dist/src/cli/chat/state/local-commands.d.ts.map +1 -1
- package/dist/src/cli/chat/state/local-commands.js +178 -3
- package/dist/src/cli/chat/state/local-commands.js.map +1 -1
- package/dist/src/cli/chat/state/types.d.ts +6 -0
- package/dist/src/cli/chat/state/types.d.ts.map +1 -1
- package/dist/src/cli/chat/submit.d.ts +2 -0
- package/dist/src/cli/chat/submit.d.ts.map +1 -1
- package/dist/src/cli/chat/submit.js +10 -1
- package/dist/src/cli/chat/submit.js.map +1 -1
- package/dist/src/cli/chat/utils/runtime.d.ts +1 -0
- package/dist/src/cli/chat/utils/runtime.d.ts.map +1 -1
- package/dist/src/cli/chat/utils/runtime.js +1 -0
- package/dist/src/cli/chat/utils/runtime.js.map +1 -1
- package/dist/src/cli/daemon.d.ts +14 -0
- package/dist/src/cli/daemon.d.ts.map +1 -0
- package/dist/src/cli/daemon.js +61 -0
- package/dist/src/cli/daemon.js.map +1 -0
- package/dist/src/cli/heartbeat.d.ts.map +1 -1
- package/dist/src/cli/heartbeat.js +14 -5
- package/dist/src/cli/heartbeat.js.map +1 -1
- package/dist/src/cli/main.js +6 -0
- package/dist/src/cli/main.js.map +1 -1
- package/dist/src/index.d.ts +4 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +2 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/runtime/heartbeat-lucid.d.ts +42 -0
- package/dist/src/runtime/heartbeat-lucid.d.ts.map +1 -0
- package/dist/src/runtime/heartbeat-lucid.js +188 -0
- package/dist/src/runtime/heartbeat-lucid.js.map +1 -0
- package/dist/src/runtime/heartbeat-scheduler.d.ts +13 -0
- package/dist/src/runtime/heartbeat-scheduler.d.ts.map +1 -1
- package/dist/src/runtime/heartbeat-scheduler.js +74 -4
- package/dist/src/runtime/heartbeat-scheduler.js.map +1 -1
- package/dist/src/runtime/heartbeat-views.d.ts +50 -0
- package/dist/src/runtime/heartbeat-views.d.ts.map +1 -0
- package/dist/src/runtime/heartbeat-views.js +60 -0
- package/dist/src/runtime/heartbeat-views.js.map +1 -0
- package/dist/src/server/app.d.ts +6 -0
- package/dist/src/server/app.d.ts.map +1 -0
- package/dist/src/server/app.js +36 -0
- package/dist/src/server/app.js.map +1 -0
- package/dist/src/server/dev.d.ts +2 -0
- package/dist/src/server/dev.d.ts.map +1 -0
- package/dist/src/server/dev.js +39 -0
- package/dist/src/server/dev.js.map +1 -0
- package/dist/src/server/features/control-plane/router.d.ts +37 -0
- package/dist/src/server/features/control-plane/router.d.ts.map +1 -0
- package/dist/src/server/features/control-plane/router.js +34 -0
- package/dist/src/server/features/control-plane/router.js.map +1 -0
- package/dist/src/server/features/control-plane/services/chat-sessions.d.ts +4 -0
- package/dist/src/server/features/control-plane/services/chat-sessions.d.ts.map +1 -0
- package/dist/src/server/features/control-plane/services/chat-sessions.js +63 -0
- package/dist/src/server/features/control-plane/services/chat-sessions.js.map +1 -0
- package/dist/src/server/features/control-plane/services/control-plane-state.d.ts +4 -0
- package/dist/src/server/features/control-plane/services/control-plane-state.d.ts.map +1 -0
- package/dist/src/server/features/control-plane/services/control-plane-state.js +19 -0
- package/dist/src/server/features/control-plane/services/control-plane-state.js.map +1 -0
- package/dist/src/server/features/control-plane/services/heartbeat.d.ts +7 -0
- package/dist/src/server/features/control-plane/services/heartbeat.d.ts.map +1 -0
- package/dist/src/server/features/control-plane/services/heartbeat.js +12 -0
- package/dist/src/server/features/control-plane/services/heartbeat.js.map +1 -0
- package/dist/src/server/features/control-plane/types.d.ts +31 -0
- package/dist/src/server/features/control-plane/types.d.ts.map +1 -0
- package/dist/src/server/features/control-plane/types.js +2 -0
- package/dist/src/server/features/control-plane/types.js.map +1 -0
- package/dist/src/server/index.d.ts +8 -0
- package/dist/src/server/index.d.ts.map +1 -0
- package/dist/src/server/index.js +42 -0
- package/dist/src/server/index.js.map +1 -0
- package/dist/src/server/logger.d.ts +8 -0
- package/dist/src/server/logger.d.ts.map +1 -0
- package/dist/src/server/logger.js +11 -0
- package/dist/src/server/logger.js.map +1 -0
- package/dist/src/server/middleware/request-logging.d.ts +4 -0
- package/dist/src/server/middleware/request-logging.d.ts.map +1 -0
- package/dist/src/server/middleware/request-logging.js +15 -0
- package/dist/src/server/middleware/request-logging.js.map +1 -0
- package/dist/src/server/router.d.ts +55 -0
- package/dist/src/server/router.d.ts.map +1 -0
- package/dist/src/server/router.js +14 -0
- package/dist/src/server/router.js.map +1 -0
- package/dist/src/server/static.d.ts +4 -0
- package/dist/src/server/static.d.ts.map +1 -0
- package/dist/src/server/static.js +25 -0
- package/dist/src/server/static.js.map +1 -0
- package/dist/src/server/trpc.d.ts +9 -0
- package/dist/src/server/trpc.d.ts.map +1 -0
- package/dist/src/server/trpc.js +5 -0
- package/dist/src/server/trpc.js.map +1 -0
- package/dist/src/server/types.d.ts +17 -0
- package/dist/src/server/types.d.ts.map +1 -0
- package/dist/src/server/types.js +2 -0
- package/dist/src/server/types.js.map +1 -0
- package/dist/src/web/assets/index-DmYQXJQf.css +1 -0
- package/dist/src/web/assets/index-xFJTOaTY.js +9 -0
- package/dist/src/web/index.html +13 -0
- 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":"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"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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}}
|