@action-llama/action-llama 0.24.2 → 0.25.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/build-info.json +1 -1
- package/dist/control/index.d.ts +1 -0
- package/dist/control/index.d.ts.map +1 -1
- package/dist/control/index.js +1 -0
- package/dist/control/index.js.map +1 -1
- package/dist/control/routes/dashboard-api.js +1 -1
- package/dist/control/routes/dashboard-api.js.map +1 -1
- package/dist/control/routes/log-helpers.d.ts +38 -0
- package/dist/control/routes/log-helpers.d.ts.map +1 -0
- package/dist/control/routes/log-helpers.js +188 -0
- package/dist/control/routes/log-helpers.js.map +1 -0
- package/dist/control/routes/log-summary.d.ts +4 -0
- package/dist/control/routes/log-summary.d.ts.map +1 -0
- package/dist/control/routes/log-summary.js +126 -0
- package/dist/control/routes/log-summary.js.map +1 -0
- package/dist/control/routes/logs.d.ts.map +1 -1
- package/dist/control/routes/logs.js +1 -187
- package/dist/control/routes/logs.js.map +1 -1
- package/dist/frontend/assets/index-BxREMoPG.js +13 -0
- package/dist/frontend/assets/index-DBiTqSKn.css +2 -0
- package/dist/frontend/index.html +2 -2
- package/dist/gateway/routes/dashboard.d.ts.map +1 -1
- package/dist/gateway/routes/dashboard.js +2 -0
- package/dist/gateway/routes/dashboard.js.map +1 -1
- package/package.json +3 -2
- package/dist/frontend/assets/index-BH-R-o4m.js +0 -13
- package/dist/frontend/assets/index-NmgeBYN4.css +0 -2
package/dist/build-info.json
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"gitSha":"
|
|
1
|
+
{"gitSha":"72b92e29"}
|
package/dist/control/index.d.ts
CHANGED
|
@@ -7,5 +7,6 @@ export { registerControlRoutes } from "./routes/control.js";
|
|
|
7
7
|
export type { ControlRoutesDeps } from "./routes/control.js";
|
|
8
8
|
export { registerDashboardDataRoutes } from "./routes/dashboard.js";
|
|
9
9
|
export { registerLogRoutes } from "./routes/logs.js";
|
|
10
|
+
export { registerLogSummaryRoutes } from "./routes/log-summary.js";
|
|
10
11
|
export { registerStatsRoutes } from "./routes/stats.js";
|
|
11
12
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/control/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,YAAY,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,YAAY,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,YAAY,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/control/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,YAAY,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,YAAY,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,YAAY,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC"}
|
package/dist/control/index.js
CHANGED
|
@@ -4,5 +4,6 @@ export { SessionStore } from "./session-store.js";
|
|
|
4
4
|
export { registerControlRoutes } from "./routes/control.js";
|
|
5
5
|
export { registerDashboardDataRoutes } from "./routes/dashboard.js";
|
|
6
6
|
export { registerLogRoutes } from "./routes/logs.js";
|
|
7
|
+
export { registerLogSummaryRoutes } from "./routes/log-summary.js";
|
|
7
8
|
export { registerStatsRoutes } from "./routes/stats.js";
|
|
8
9
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/control/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAE5D,OAAO,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/control/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAE5D,OAAO,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC"}
|
|
@@ -104,7 +104,7 @@ export function registerDashboardApiRoutes(app, statusTracker, projectPath, stat
|
|
|
104
104
|
app.get("/api/dashboard/agents/:name/instances/:id", (c) => {
|
|
105
105
|
const instanceId = c.req.param("id");
|
|
106
106
|
const run = statsStore ? statsStore.queryRunByInstanceId(instanceId) : null;
|
|
107
|
-
const runningInstance = statusTracker.getInstances().find((i) => i.id === instanceId) || null;
|
|
107
|
+
const runningInstance = statusTracker.getInstances().find((i) => i.id === instanceId && i.status === "running") || null;
|
|
108
108
|
let parentEdge;
|
|
109
109
|
let webhookReceipt;
|
|
110
110
|
if (statsStore && run) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dashboard-api.js","sourceRoot":"","sources":["../../../src/control/routes/dashboard-api.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAMH,OAAO,EAAE,WAAW,EAAqB,MAAM,YAAY,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAC1E,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B;;;GAGG;AACH,MAAM,UAAU,qBAAqB,CACnC,GAAS,EACT,MAAqB,EACrB,YAA2B,EAC3B,QAAiB;IAEjB,GAAG,CAAC,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QACtC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QACnC,CAAC;QACD,MAAM,UAAU,GAAG,OAAO,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,MAAM,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;QAC1E,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QACnC,CAAC;QACD,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,EAAoB,CAAC;QAClD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC;QAC3B,IAAI,WAAW,CAAC,GAAG,EAAE,UAAU,CAAC,EAAE,CAAC;YACjC,IAAI,YAAoB,CAAC;YACzB,IAAI,YAAY,EAAE,CAAC;gBACjB,YAAY,GAAG,MAAM,YAAY,CAAC,aAAa,EAAE,CAAC;YACpD,CAAC;iBAAM,CAAC;gBACN,YAAY,GAAG,UAAU,CAAC;YAC5B,CAAC;YACD,MAAM,WAAW,GAAG,CAAC,QAAQ,IAAI,QAAQ,KAAK,WAAW,IAAI,QAAQ,KAAK,WAAW,CAAC;YACtF,MAAM,UAAU,GAAG,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC;YACjD,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE;gBAC/B,OAAO,EAAE;oBACP,YAAY,EAAE,cAAc,YAAY,sCAAsC,UAAU,EAAE;iBAC3F;aACF,CAAC,CAAC;QACL,CAAC;QACD,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,iBAAiB,EAAE,EAAE,GAAG,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,GAAG,CAAC,iBAAiB,EAAE,CAAC,CAAC,EAAE,EAAE;QAC/B,6EAA6E;QAC7E,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,IAAI,CAAC,kBAAkB,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QACvC,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;YAC5C,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;gBACrC,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;gBAC7B,IAAI,EAAE,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,YAAY,EAAE,CAAC;oBAC3D,MAAM,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;oBAC5D,MAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE;YAC/B,OAAO,EAAE;gBACP,YAAY,EAAE,2DAA2D;aAC1E;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,0BAA0B,CACxC,GAAS,EACT,aAA4B,EAC5B,WAAoB,EACpB,UAAuB;IAEvB,6DAA6D;IAC7D,GAAG,CAAC,GAAG,CAAC,uBAAuB,EAAE,CAAC,CAAC,EAAE,EAAE;QACrC,MAAM,MAAM,GAAG,aAAa,CAAC,YAAY,EAAE,CAAC;QAC5C,MAAM,aAAa,GAAG,aAAa,CAAC,gBAAgB,EAAE,CAAC;QACvD,MAAM,UAAU,GAAG,aAAa,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC;QACnD,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,iDAAiD;IACjD,GAAG,CAAC,GAAG,CAAC,6BAA6B,EAAE,CAAC,CAAC,EAAE,EAAE;QAC3C,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACjC,MAAM,MAAM,GAAG,aAAa,CAAC,YAAY,EAAE,CAAC;QAC5C,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,IAAI,CAAC;QAC1D,MAAM,OAAO,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,iBAAiB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC/F,MAAM,SAAS,GAAG,aAAa,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,IAAI,IAAI,CAAC,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC;QAC7G,MAAM,eAAe,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE3E,IAAI,WAAW,GAAG,IAAI,CAAC;QACvB,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,CAAC;gBACH,WAAW,GAAG,eAAe,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;YACnD,CAAC;YAAC,MAAM,CAAC;gBACP,2CAA2C;YAC7C,CAAC;QACH,CAAC;QAED,OAAO,CAAC,CAAC,IAAI,CAAC;YACZ,KAAK;YACL,WAAW;YACX,OAAO;YACP,gBAAgB,EAAE,SAAS;YAC3B,eAAe;SAChB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,8EAA8E;IAC9E,GAAG,CAAC,GAAG,CAAC,2CAA2C,EAAE,CAAC,CAAC,EAAE,EAAE;QACzD,MAAM,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACrC,MAAM,GAAG,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC5E,MAAM,eAAe,GAAG,aAAa,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,UAAU,CAAC,IAAI,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"dashboard-api.js","sourceRoot":"","sources":["../../../src/control/routes/dashboard-api.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
export declare const SAFE_AGENT_NAME: RegExp;
|
|
2
|
+
export declare const MAX_LINES = 2000;
|
|
3
|
+
export declare const DEFAULT_LINES = 200;
|
|
4
|
+
export interface LogEntry {
|
|
5
|
+
level: number;
|
|
6
|
+
time: number;
|
|
7
|
+
msg: string;
|
|
8
|
+
instance?: string;
|
|
9
|
+
[key: string]: unknown;
|
|
10
|
+
}
|
|
11
|
+
export declare function encodeCursor(date: string, offsets: number[]): string;
|
|
12
|
+
export declare function decodeCursor(cursor: string): {
|
|
13
|
+
date: string;
|
|
14
|
+
offsets: number[];
|
|
15
|
+
} | null;
|
|
16
|
+
export declare function logsDir(projectPath: string): string;
|
|
17
|
+
export declare function findLogFiles(projectPath: string, prefix: string): string[];
|
|
18
|
+
export declare function findLatestLogFile(projectPath: string, prefix: string): string | null;
|
|
19
|
+
export declare function dateFromLogFile(filePath: string): string | null;
|
|
20
|
+
export declare function parseLine(line: string): LogEntry | null;
|
|
21
|
+
/** Read entries forward from a byte offset. Returns entries and new byte offset. */
|
|
22
|
+
export declare function readEntriesForward(filePath: string, byteOffset: number, limit: number, afterTime?: number, beforeTime?: number, instanceFilter?: string, grep?: RegExp): Promise<{
|
|
23
|
+
entries: LogEntry[];
|
|
24
|
+
newOffset: number;
|
|
25
|
+
}>;
|
|
26
|
+
/** Read the last N entries from a file using reverse reading. */
|
|
27
|
+
export declare function readLastEntries(filePath: string, limit: number, afterTime?: number, beforeTime?: number, instanceFilter?: string, grep?: RegExp): Promise<{
|
|
28
|
+
entries: LogEntry[];
|
|
29
|
+
byteOffset: number;
|
|
30
|
+
}>;
|
|
31
|
+
export declare function parseQueryParams(query: Record<string, string | undefined>): {
|
|
32
|
+
lines: number;
|
|
33
|
+
cursor: string | undefined;
|
|
34
|
+
after: number | undefined;
|
|
35
|
+
before: number | undefined;
|
|
36
|
+
grep: string | undefined;
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=log-helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-helpers.d.ts","sourceRoot":"","sources":["../../../src/control/routes/log-helpers.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,eAAe,QAA4C,CAAC;AACzE,eAAO,MAAM,SAAS,OAAO,CAAC;AAC9B,eAAO,MAAM,aAAa,MAAM,CAAC;AAEjC,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAID,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,CAEpE;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,EAAE,CAAA;CAAE,GAAG,IAAI,CAWvF;AAID,wBAAgB,OAAO,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAEnD;AAED,wBAAgB,YAAY,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAU1E;AAED,wBAAgB,iBAAiB,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAGpF;AAED,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAG/D;AAID,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,GAAG,IAAI,CAcvD;AAED,oFAAoF;AACpF,wBAAsB,kBAAkB,CACtC,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,EACb,SAAS,CAAC,EAAE,MAAM,EAClB,UAAU,CAAC,EAAE,MAAM,EACnB,cAAc,CAAC,EAAE,MAAM,EACvB,IAAI,CAAC,EAAE,MAAM,GACZ,OAAO,CAAC;IAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAC,CA+BrD;AAED,iEAAiE;AACjE,wBAAsB,eAAe,CACnC,QAAQ,EAAE,MAAM,EAChB,KAAK,EAAE,MAAM,EACb,SAAS,CAAC,EAAE,MAAM,EAClB,UAAU,CAAC,EAAE,MAAM,EACnB,cAAc,CAAC,EAAE,MAAM,EACvB,IAAI,CAAC,EAAE,MAAM,GACZ,OAAO,CAAC;IAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,CAAC,CA4DtD;AAID,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;;;;;;EAWzE"}
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
import { promises as fs } from "fs";
|
|
2
|
+
import { resolve } from "path";
|
|
3
|
+
import { readdirSync } from "fs";
|
|
4
|
+
export const SAFE_AGENT_NAME = /^[a-z0-9][a-z0-9-]*[a-z0-9]$|^[a-z0-9]$/;
|
|
5
|
+
export const MAX_LINES = 2000;
|
|
6
|
+
export const DEFAULT_LINES = 200;
|
|
7
|
+
// ── Cursor helpers ────────────────────────────────────────────────────────────
|
|
8
|
+
export function encodeCursor(date, offsets) {
|
|
9
|
+
return Buffer.from(`${date}:${offsets.join(",")}`).toString("base64url");
|
|
10
|
+
}
|
|
11
|
+
export function decodeCursor(cursor) {
|
|
12
|
+
try {
|
|
13
|
+
const decoded = Buffer.from(cursor, "base64url").toString("utf-8");
|
|
14
|
+
const [date, offsetStr] = decoded.split(":");
|
|
15
|
+
if (!date || !offsetStr)
|
|
16
|
+
return null;
|
|
17
|
+
const offsets = offsetStr.split(",").map(Number);
|
|
18
|
+
if (offsets.some(isNaN))
|
|
19
|
+
return null;
|
|
20
|
+
return { date, offsets };
|
|
21
|
+
}
|
|
22
|
+
catch {
|
|
23
|
+
return null;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
// ── File discovery ────────────────────────────────────────────────────────────
|
|
27
|
+
export function logsDir(projectPath) {
|
|
28
|
+
return resolve(projectPath, ".al", "logs");
|
|
29
|
+
}
|
|
30
|
+
export function findLogFiles(projectPath, prefix) {
|
|
31
|
+
const dir = logsDir(projectPath);
|
|
32
|
+
try {
|
|
33
|
+
return readdirSync(dir)
|
|
34
|
+
.filter((f) => f.startsWith(`${prefix}-`) && f.endsWith(".log"))
|
|
35
|
+
.sort()
|
|
36
|
+
.map((f) => resolve(dir, f));
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
return [];
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
export function findLatestLogFile(projectPath, prefix) {
|
|
43
|
+
const files = findLogFiles(projectPath, prefix);
|
|
44
|
+
return files.length > 0 ? files[files.length - 1] : null;
|
|
45
|
+
}
|
|
46
|
+
export function dateFromLogFile(filePath) {
|
|
47
|
+
const match = filePath.match(/(\d{4}-\d{2}-\d{2})\.log$/);
|
|
48
|
+
return match ? match[1] : null;
|
|
49
|
+
}
|
|
50
|
+
// ── File reading ──────────────────────────────────────────────────────────────
|
|
51
|
+
export function parseLine(line) {
|
|
52
|
+
if (!line.trim())
|
|
53
|
+
return null;
|
|
54
|
+
try {
|
|
55
|
+
const obj = JSON.parse(line);
|
|
56
|
+
// Container format normalization
|
|
57
|
+
if (obj._log && typeof obj.level === "string") {
|
|
58
|
+
const levelMap = { trace: 10, debug: 20, info: 30, warn: 40, error: 50 };
|
|
59
|
+
const { _log, level: levelStr, ts, ...rest } = obj;
|
|
60
|
+
return { ...rest, level: levelMap[levelStr] ?? 30, time: ts ?? Date.now() };
|
|
61
|
+
}
|
|
62
|
+
return obj;
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
return null;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
/** Read entries forward from a byte offset. Returns entries and new byte offset. */
|
|
69
|
+
export async function readEntriesForward(filePath, byteOffset, limit, afterTime, beforeTime, instanceFilter, grep) {
|
|
70
|
+
try {
|
|
71
|
+
const stat = await fs.stat(filePath);
|
|
72
|
+
if (byteOffset >= stat.size)
|
|
73
|
+
return { entries: [], newOffset: byteOffset };
|
|
74
|
+
const fd = await fs.open(filePath, "r");
|
|
75
|
+
try {
|
|
76
|
+
const buf = Buffer.alloc(stat.size - byteOffset);
|
|
77
|
+
await fd.read(buf, 0, buf.length, byteOffset);
|
|
78
|
+
const text = buf.toString("utf-8");
|
|
79
|
+
const lines = text.split("\n");
|
|
80
|
+
const entries = [];
|
|
81
|
+
for (const line of lines) {
|
|
82
|
+
if (entries.length >= limit)
|
|
83
|
+
break;
|
|
84
|
+
const entry = parseLine(line);
|
|
85
|
+
if (!entry)
|
|
86
|
+
continue;
|
|
87
|
+
if (afterTime && entry.time <= afterTime)
|
|
88
|
+
continue;
|
|
89
|
+
if (beforeTime && entry.time >= beforeTime)
|
|
90
|
+
continue;
|
|
91
|
+
if (instanceFilter && entry.instance !== instanceFilter)
|
|
92
|
+
continue;
|
|
93
|
+
if (grep && !grep.test(JSON.stringify(entry)))
|
|
94
|
+
continue;
|
|
95
|
+
entries.push(entry);
|
|
96
|
+
}
|
|
97
|
+
return { entries, newOffset: stat.size };
|
|
98
|
+
}
|
|
99
|
+
finally {
|
|
100
|
+
await fd.close();
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
catch {
|
|
104
|
+
return { entries: [], newOffset: byteOffset };
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
/** Read the last N entries from a file using reverse reading. */
|
|
108
|
+
export async function readLastEntries(filePath, limit, afterTime, beforeTime, instanceFilter, grep) {
|
|
109
|
+
try {
|
|
110
|
+
const stat = await fs.stat(filePath);
|
|
111
|
+
if (stat.size === 0)
|
|
112
|
+
return { entries: [], byteOffset: 0 };
|
|
113
|
+
const fd = await fs.open(filePath, "r");
|
|
114
|
+
const entries = [];
|
|
115
|
+
let position = stat.size;
|
|
116
|
+
const chunkSize = 8192;
|
|
117
|
+
const buffer = Buffer.alloc(chunkSize);
|
|
118
|
+
let remainder = "";
|
|
119
|
+
// We need more raw lines than limit because of filtering
|
|
120
|
+
const rawLimit = limit * 3;
|
|
121
|
+
let rawCount = 0;
|
|
122
|
+
try {
|
|
123
|
+
while (rawCount < rawLimit && position > 0) {
|
|
124
|
+
const toRead = Math.min(chunkSize, position);
|
|
125
|
+
position -= toRead;
|
|
126
|
+
const { buffer: readBuf } = await fd.read(buffer, 0, toRead, position);
|
|
127
|
+
const chunk = readBuf.toString("utf-8", 0, toRead);
|
|
128
|
+
const text = chunk + remainder;
|
|
129
|
+
const parts = text.split("\n");
|
|
130
|
+
remainder = parts[0];
|
|
131
|
+
for (let i = parts.length - 1; i >= 1; i--) {
|
|
132
|
+
const line = parts[i];
|
|
133
|
+
if (!line.trim())
|
|
134
|
+
continue;
|
|
135
|
+
rawCount++;
|
|
136
|
+
const entry = parseLine(line);
|
|
137
|
+
if (!entry)
|
|
138
|
+
continue;
|
|
139
|
+
if (afterTime && entry.time <= afterTime)
|
|
140
|
+
continue;
|
|
141
|
+
if (beforeTime && entry.time >= beforeTime)
|
|
142
|
+
continue;
|
|
143
|
+
if (instanceFilter && entry.instance !== instanceFilter)
|
|
144
|
+
continue;
|
|
145
|
+
if (grep && !grep.test(JSON.stringify(entry)))
|
|
146
|
+
continue;
|
|
147
|
+
entries.unshift(entry);
|
|
148
|
+
if (entries.length > limit)
|
|
149
|
+
entries.shift();
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
if (position === 0 && remainder.trim()) {
|
|
153
|
+
const entry = parseLine(remainder);
|
|
154
|
+
if (entry) {
|
|
155
|
+
const inRange = (!afterTime || entry.time > afterTime) && (!beforeTime || entry.time < beforeTime)
|
|
156
|
+
&& (!instanceFilter || entry.instance === instanceFilter)
|
|
157
|
+
&& (!grep || grep.test(JSON.stringify(entry)));
|
|
158
|
+
if (inRange) {
|
|
159
|
+
entries.unshift(entry);
|
|
160
|
+
if (entries.length > limit)
|
|
161
|
+
entries.shift();
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
finally {
|
|
167
|
+
await fd.close();
|
|
168
|
+
}
|
|
169
|
+
return { entries: entries.slice(-limit), byteOffset: stat.size };
|
|
170
|
+
}
|
|
171
|
+
catch {
|
|
172
|
+
return { entries: [], byteOffset: 0 };
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
// ── Query parsing ─────────────────────────────────────────────────────────────
|
|
176
|
+
export function parseQueryParams(query) {
|
|
177
|
+
let lines = parseInt(query.lines || "", 10);
|
|
178
|
+
if (isNaN(lines) || lines < 1)
|
|
179
|
+
lines = DEFAULT_LINES;
|
|
180
|
+
if (lines > MAX_LINES)
|
|
181
|
+
lines = MAX_LINES;
|
|
182
|
+
const cursor = query.cursor || undefined;
|
|
183
|
+
const after = query.after ? parseInt(query.after, 10) : undefined;
|
|
184
|
+
const before = query.before ? parseInt(query.before, 10) : undefined;
|
|
185
|
+
const grep = query.grep || undefined;
|
|
186
|
+
return { lines, cursor, after: isNaN(after) ? undefined : after, before: isNaN(before) ? undefined : before, grep };
|
|
187
|
+
}
|
|
188
|
+
//# sourceMappingURL=log-helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-helpers.js","sourceRoot":"","sources":["../../../src/control/routes/log-helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-summary.d.ts","sourceRoot":"","sources":["../../../src/control/routes/log-summary.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAQjC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAyBvD,wBAAgB,wBAAwB,CACtC,GAAG,EAAE,IAAI,EACT,WAAW,EAAE,MAAM,EACnB,UAAU,CAAC,EAAE,UAAU,GACtB,IAAI,CA2HN"}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { loadAgentConfig } from "../../shared/config.js";
|
|
2
|
+
import { loadCredentialField } from "../../shared/credentials.js";
|
|
3
|
+
import { OpenAIProvider } from "../../models/providers/openai.js";
|
|
4
|
+
import { AnthropicProvider } from "../../models/providers/anthropic.js";
|
|
5
|
+
import { CustomProvider } from "../../models/providers/custom.js";
|
|
6
|
+
import { SAFE_AGENT_NAME, MAX_LINES, findLatestLogFile, readLastEntries, } from "./log-helpers.js";
|
|
7
|
+
// In-memory cache for summaries of completed runs
|
|
8
|
+
const summaryCache = new Map();
|
|
9
|
+
const DEFAULT_SUMMARY_LINES = 500;
|
|
10
|
+
function createProvider(model, apiKey) {
|
|
11
|
+
switch (model.provider) {
|
|
12
|
+
case "anthropic":
|
|
13
|
+
return new AnthropicProvider({ ...model, apiKey });
|
|
14
|
+
case "openai":
|
|
15
|
+
return new OpenAIProvider({ ...model, apiKey });
|
|
16
|
+
default:
|
|
17
|
+
// custom/openrouter/groq/etc. all use OpenAI-compatible API
|
|
18
|
+
return new CustomProvider({ ...model, apiKey });
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export function registerLogSummaryRoutes(app, projectPath, statsStore) {
|
|
22
|
+
app.post("/api/logs/agents/:name/:instanceId/summarize", async (c) => {
|
|
23
|
+
const name = c.req.param("name");
|
|
24
|
+
const instanceId = c.req.param("instanceId");
|
|
25
|
+
if (!SAFE_AGENT_NAME.test(name))
|
|
26
|
+
return c.json({ error: "Invalid agent name" }, 400);
|
|
27
|
+
if (!SAFE_AGENT_NAME.test(instanceId))
|
|
28
|
+
return c.json({ error: "Invalid instance ID" }, 400);
|
|
29
|
+
// Parse optional filter params
|
|
30
|
+
const query = c.req.query();
|
|
31
|
+
let lines = parseInt(query.lines || "", 10);
|
|
32
|
+
if (isNaN(lines) || lines < 1)
|
|
33
|
+
lines = DEFAULT_SUMMARY_LINES;
|
|
34
|
+
if (lines > MAX_LINES)
|
|
35
|
+
lines = MAX_LINES;
|
|
36
|
+
const after = query.after ? parseInt(query.after, 10) : undefined;
|
|
37
|
+
const before = query.before ? parseInt(query.before, 10) : undefined;
|
|
38
|
+
const grep = query.grep || undefined;
|
|
39
|
+
let grepRe;
|
|
40
|
+
if (grep) {
|
|
41
|
+
try {
|
|
42
|
+
grepRe = new RegExp(grep);
|
|
43
|
+
}
|
|
44
|
+
catch {
|
|
45
|
+
return c.json({ error: "Invalid grep pattern" }, 400);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
// Check cache for completed runs (only for default request)
|
|
49
|
+
const cacheKey = instanceId;
|
|
50
|
+
if (!query.lines && !query.after && !query.before && !query.grep) {
|
|
51
|
+
const cached = summaryCache.get(cacheKey);
|
|
52
|
+
if (cached) {
|
|
53
|
+
return c.json({ summary: cached, cached: true });
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
// Read log entries
|
|
57
|
+
const file = findLatestLogFile(projectPath, name);
|
|
58
|
+
if (!file) {
|
|
59
|
+
return c.json({ summary: "No log entries found for this instance.", cached: false });
|
|
60
|
+
}
|
|
61
|
+
const { entries } = await readLastEntries(file, lines, isNaN(after) ? undefined : after, isNaN(before) ? undefined : before, instanceId, grepRe);
|
|
62
|
+
if (entries.length === 0) {
|
|
63
|
+
return c.json({ summary: "No log entries found for this instance.", cached: false });
|
|
64
|
+
}
|
|
65
|
+
// Resolve agent model config
|
|
66
|
+
let agentConfig;
|
|
67
|
+
try {
|
|
68
|
+
agentConfig = loadAgentConfig(projectPath, name);
|
|
69
|
+
}
|
|
70
|
+
catch (err) {
|
|
71
|
+
return c.json({ error: `Failed to load agent config: ${err instanceof Error ? err.message : String(err)}` }, 500);
|
|
72
|
+
}
|
|
73
|
+
if (!agentConfig.models || agentConfig.models.length === 0) {
|
|
74
|
+
return c.json({ error: "Agent has no configured models" }, 500);
|
|
75
|
+
}
|
|
76
|
+
const model = agentConfig.models[0];
|
|
77
|
+
// Resolve API key from credential store
|
|
78
|
+
const credType = `${model.provider}_key`;
|
|
79
|
+
let apiKey;
|
|
80
|
+
try {
|
|
81
|
+
const key = await loadCredentialField(credType, "default", "token");
|
|
82
|
+
apiKey = key ?? "";
|
|
83
|
+
}
|
|
84
|
+
catch {
|
|
85
|
+
apiKey = "";
|
|
86
|
+
}
|
|
87
|
+
// Build prompt
|
|
88
|
+
const logText = entries
|
|
89
|
+
.map((e) => `[${new Date(e.time).toISOString()}] ${e.msg}`)
|
|
90
|
+
.join("\n");
|
|
91
|
+
const messages = [
|
|
92
|
+
{
|
|
93
|
+
role: "system",
|
|
94
|
+
content: "You are a concise technical assistant. Summarize the following agent run logs in 2-4 sentences. Focus on what the agent did, whether it succeeded, and any notable errors or outcomes. Do not include timestamps or log formatting in your summary.",
|
|
95
|
+
},
|
|
96
|
+
{
|
|
97
|
+
role: "user",
|
|
98
|
+
content: `Here are the logs from an agent run:\n\n${logText}`,
|
|
99
|
+
},
|
|
100
|
+
];
|
|
101
|
+
// Call model
|
|
102
|
+
let summary;
|
|
103
|
+
try {
|
|
104
|
+
const provider = createProvider(model, apiKey);
|
|
105
|
+
const response = await provider.chat(messages, { max_tokens: 300 });
|
|
106
|
+
summary = response.content;
|
|
107
|
+
}
|
|
108
|
+
catch (err) {
|
|
109
|
+
return c.json({ error: `Failed to generate summary: ${err instanceof Error ? err.message : String(err)}` }, 500);
|
|
110
|
+
}
|
|
111
|
+
// Cache for completed runs
|
|
112
|
+
if (!query.lines && !query.after && !query.before && !query.grep) {
|
|
113
|
+
try {
|
|
114
|
+
const run = statsStore?.queryRunByInstanceId(instanceId);
|
|
115
|
+
if (run && run.result) {
|
|
116
|
+
summaryCache.set(cacheKey, summary);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
catch {
|
|
120
|
+
// Non-critical — ignore cache errors
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return c.json({ summary, cached: false });
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
//# sourceMappingURL=log-summary.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-summary.js","sourceRoot":"","sources":["../../../src/control/routes/log-summary.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logs.d.ts","sourceRoot":"","sources":["../../../src/control/routes/logs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"logs.d.ts","sourceRoot":"","sources":["../../../src/control/routes/logs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAYjC,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,GAAG,IAAI,CAgGtE"}
|