@action-llama/action-llama 0.25.0 → 0.26.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/agents/container-entry.d.ts.map +1 -1
- package/dist/agents/container-entry.js +5 -1
- package/dist/agents/container-entry.js.map +1 -1
- package/dist/agents/session-loop.d.ts +1 -0
- package/dist/agents/session-loop.d.ts.map +1 -1
- package/dist/agents/session-loop.js +7 -1
- package/dist/agents/session-loop.js.map +1 -1
- package/dist/build-info.json +1 -1
- package/dist/cli/commands/logs.d.ts +0 -1
- package/dist/cli/commands/logs.d.ts.map +1 -1
- package/dist/cli/commands/logs.js +51 -12
- package/dist/cli/commands/logs.js.map +1 -1
- package/dist/cli/commands/run-agent.d.ts.map +1 -1
- package/dist/cli/commands/run-agent.js +4 -0
- package/dist/cli/commands/run-agent.js.map +1 -1
- package/dist/cli/main.js +1 -2
- package/dist/cli/main.js.map +1 -1
- package/dist/control/routes/log-helpers.d.ts +15 -0
- package/dist/control/routes/log-helpers.d.ts.map +1 -1
- package/dist/control/routes/log-helpers.js +58 -3
- package/dist/control/routes/log-helpers.js.map +1 -1
- package/dist/control/routes/log-summary.d.ts +2 -1
- package/dist/control/routes/log-summary.d.ts.map +1 -1
- package/dist/control/routes/log-summary.js +15 -10
- package/dist/control/routes/log-summary.js.map +1 -1
- package/dist/control/routes/logs.d.ts.map +1 -1
- package/dist/control/routes/logs.js +40 -85
- package/dist/control/routes/logs.js.map +1 -1
- package/dist/control/routes/stats.d.ts.map +1 -1
- package/dist/control/routes/stats.js +156 -114
- package/dist/control/routes/stats.js.map +1 -1
- package/dist/db/schema.d.ts.map +1 -1
- package/dist/db/schema.js +1 -0
- package/dist/db/schema.js.map +1 -1
- package/dist/docker/host-user-runtime.d.ts.map +1 -1
- package/dist/docker/host-user-runtime.js +3 -0
- package/dist/docker/host-user-runtime.js.map +1 -1
- package/dist/frontend/assets/{index-BxREMoPG.js → index-D4A0OA-O.js} +2 -2
- package/dist/frontend/assets/index-DxRXtsfX.css +2 -0
- package/dist/frontend/index.html +2 -2
- package/dist/gateway/routes/dashboard.js +1 -1
- package/dist/gateway/routes/dashboard.js.map +1 -1
- package/dist/stats/store.d.ts +31 -0
- package/dist/stats/store.d.ts.map +1 -1
- package/dist/stats/store.js +122 -0
- package/dist/stats/store.js.map +1 -1
- package/drizzle/0002_add_result_index.sql +1 -0
- package/drizzle/meta/_journal.json +7 -0
- package/package.json +1 -1
- package/dist/frontend/assets/index-DBiTqSKn.css +0 -2
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { promises as fs } from "fs";
|
|
2
2
|
import { resolve } from "path";
|
|
3
|
-
import { readdirSync } from "fs";
|
|
3
|
+
import { readdirSync, existsSync } from "fs";
|
|
4
4
|
export const SAFE_AGENT_NAME = /^[a-z0-9][a-z0-9-]*[a-z0-9]$|^[a-z0-9]$/;
|
|
5
5
|
export const MAX_LINES = 2000;
|
|
6
6
|
export const DEFAULT_LINES = 200;
|
|
@@ -172,9 +172,60 @@ export async function readLastEntries(filePath, limit, afterTime, beforeTime, in
|
|
|
172
172
|
return { entries: [], byteOffset: 0 };
|
|
173
173
|
}
|
|
174
174
|
}
|
|
175
|
+
/** Construct the path for a specific date's log file. Returns null if file doesn't exist. */
|
|
176
|
+
export function logFileForDate(projectPath, prefix, date) {
|
|
177
|
+
const filePath = resolve(logsDir(projectPath), `${prefix}-${date}.log`);
|
|
178
|
+
return existsSync(filePath) ? filePath : null;
|
|
179
|
+
}
|
|
180
|
+
/** Read last N entries across multiple daily log files (newest first). */
|
|
181
|
+
export async function readLastEntriesMultiFile(files, limit, afterTime, beforeTime, instanceFilter, grep) {
|
|
182
|
+
if (files.length === 0)
|
|
183
|
+
return { entries: [], latestFile: null, byteOffset: 0 };
|
|
184
|
+
const collected = [];
|
|
185
|
+
let latestByteOffset = 0;
|
|
186
|
+
const latestFile = files[files.length - 1];
|
|
187
|
+
// Iterate from newest to oldest
|
|
188
|
+
for (let i = files.length - 1; i >= 0 && collected.length < limit; i--) {
|
|
189
|
+
const remaining = limit - collected.length;
|
|
190
|
+
const { entries, byteOffset } = await readLastEntries(files[i], remaining, afterTime, beforeTime, instanceFilter, grep);
|
|
191
|
+
if (i === files.length - 1)
|
|
192
|
+
latestByteOffset = byteOffset;
|
|
193
|
+
collected.unshift(...entries);
|
|
194
|
+
}
|
|
195
|
+
// Trim to limit (in case older files provided more than needed)
|
|
196
|
+
const trimmed = collected.slice(-limit);
|
|
197
|
+
return { entries: trimmed, latestFile, byteOffset: latestByteOffset };
|
|
198
|
+
}
|
|
199
|
+
/** Read entries forward across date boundaries starting from a cursor. */
|
|
200
|
+
export async function readEntriesForwardMultiFile(projectPath, prefix, cursorDate, cursorOffset, limit, afterTime, beforeTime, instanceFilter, grep) {
|
|
201
|
+
const allFiles = findLogFiles(projectPath, prefix);
|
|
202
|
+
if (allFiles.length === 0)
|
|
203
|
+
return { entries: [], newDate: cursorDate, newOffset: cursorOffset };
|
|
204
|
+
// Find the index of the cursor's date file (or the first file after it)
|
|
205
|
+
let startIdx = allFiles.findIndex((f) => {
|
|
206
|
+
const d = dateFromLogFile(f);
|
|
207
|
+
return d !== null && d >= cursorDate;
|
|
208
|
+
});
|
|
209
|
+
if (startIdx === -1)
|
|
210
|
+
startIdx = allFiles.length; // all files are older than cursor
|
|
211
|
+
const collected = [];
|
|
212
|
+
let finalDate = cursorDate;
|
|
213
|
+
let finalOffset = cursorOffset;
|
|
214
|
+
for (let i = startIdx; i < allFiles.length && collected.length < limit; i++) {
|
|
215
|
+
const fileDate = dateFromLogFile(allFiles[i]);
|
|
216
|
+
const isCursorFile = fileDate === cursorDate;
|
|
217
|
+
const offset = isCursorFile ? cursorOffset : 0;
|
|
218
|
+
const remaining = limit - collected.length;
|
|
219
|
+
const { entries, newOffset } = await readEntriesForward(allFiles[i], offset, remaining, afterTime, beforeTime, instanceFilter, grep);
|
|
220
|
+
collected.push(...entries);
|
|
221
|
+
finalDate = fileDate || cursorDate;
|
|
222
|
+
finalOffset = newOffset;
|
|
223
|
+
}
|
|
224
|
+
return { entries: collected.slice(0, limit), newDate: finalDate, newOffset: finalOffset };
|
|
225
|
+
}
|
|
175
226
|
// ── Query parsing ─────────────────────────────────────────────────────────────
|
|
176
227
|
export function parseQueryParams(query) {
|
|
177
|
-
let lines = parseInt(query.lines || "", 10);
|
|
228
|
+
let lines = parseInt(query.lines || query.limit || "", 10);
|
|
178
229
|
if (isNaN(lines) || lines < 1)
|
|
179
230
|
lines = DEFAULT_LINES;
|
|
180
231
|
if (lines > MAX_LINES)
|
|
@@ -183,6 +234,10 @@ export function parseQueryParams(query) {
|
|
|
183
234
|
const after = query.after ? parseInt(query.after, 10) : undefined;
|
|
184
235
|
const before = query.before ? parseInt(query.before, 10) : undefined;
|
|
185
236
|
const grep = query.grep || undefined;
|
|
186
|
-
|
|
237
|
+
// Minimum log level: trace=10, debug=20, info=30, warn=40, error=50 (default: info)
|
|
238
|
+
const levelNames = { trace: 10, debug: 20, info: 30, warn: 40, error: 50 };
|
|
239
|
+
const rawLevel = query.level?.toLowerCase();
|
|
240
|
+
const minLevel = rawLevel ? (levelNames[rawLevel] ?? parseInt(rawLevel, 10)) : 30;
|
|
241
|
+
return { lines, cursor, after: isNaN(after) ? undefined : after, before: isNaN(before) ? undefined : before, grep, minLevel: isNaN(minLevel) ? 30 : minLevel };
|
|
187
242
|
}
|
|
188
243
|
//# sourceMappingURL=log-helpers.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"log-helpers.js","sourceRoot":"","sources":["../../../src/control/routes/log-helpers.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"log-helpers.js","sourceRoot":"","sources":["../../../src/control/routes/log-helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Hono } from "hono";
|
|
2
2
|
import type { StatsStore } from "../../stats/store.js";
|
|
3
|
-
|
|
3
|
+
import type { Logger } from "../../shared/logger.js";
|
|
4
|
+
export declare function registerLogSummaryRoutes(app: Hono, projectPath: string, statsStore?: StatsStore, logger?: Logger): void;
|
|
4
5
|
//# sourceMappingURL=log-summary.d.ts.map
|
|
@@ -1 +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;
|
|
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;AACvD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAyBrD,wBAAgB,wBAAwB,CACtC,GAAG,EAAE,IAAI,EACT,WAAW,EAAE,MAAM,EACnB,UAAU,CAAC,EAAE,UAAU,EACvB,MAAM,CAAC,EAAE,MAAM,GACd,IAAI,CA0HN"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { loadGlobalConfig } from "../../shared/config.js";
|
|
2
2
|
import { loadCredentialField } from "../../shared/credentials.js";
|
|
3
3
|
import { OpenAIProvider } from "../../models/providers/openai.js";
|
|
4
4
|
import { AnthropicProvider } from "../../models/providers/anthropic.js";
|
|
@@ -18,7 +18,7 @@ function createProvider(model, apiKey) {
|
|
|
18
18
|
return new CustomProvider({ ...model, apiKey });
|
|
19
19
|
}
|
|
20
20
|
}
|
|
21
|
-
export function registerLogSummaryRoutes(app, projectPath, statsStore) {
|
|
21
|
+
export function registerLogSummaryRoutes(app, projectPath, statsStore, logger) {
|
|
22
22
|
app.post("/api/logs/agents/:name/:instanceId/summarize", async (c) => {
|
|
23
23
|
const name = c.req.param("name");
|
|
24
24
|
const instanceId = c.req.param("instanceId");
|
|
@@ -62,18 +62,21 @@ export function registerLogSummaryRoutes(app, projectPath, statsStore) {
|
|
|
62
62
|
if (entries.length === 0) {
|
|
63
63
|
return c.json({ summary: "No log entries found for this instance.", cached: false });
|
|
64
64
|
}
|
|
65
|
-
// Resolve
|
|
66
|
-
let
|
|
65
|
+
// Resolve model from project config
|
|
66
|
+
let globalConfig;
|
|
67
67
|
try {
|
|
68
|
-
|
|
68
|
+
globalConfig = loadGlobalConfig(projectPath);
|
|
69
69
|
}
|
|
70
70
|
catch (err) {
|
|
71
|
-
|
|
71
|
+
const msg = `Failed to load project config: ${err instanceof Error ? err.message : String(err)}`;
|
|
72
|
+
logger?.error({ agent: name, err }, msg);
|
|
73
|
+
return c.json({ error: msg }, 500);
|
|
72
74
|
}
|
|
73
|
-
if (!
|
|
74
|
-
|
|
75
|
+
if (!globalConfig.models || Object.keys(globalConfig.models).length === 0) {
|
|
76
|
+
logger?.error({ agent: name }, "No models configured in project config");
|
|
77
|
+
return c.json({ error: "No models configured in project config" }, 500);
|
|
75
78
|
}
|
|
76
|
-
const model =
|
|
79
|
+
const model = Object.values(globalConfig.models)[0];
|
|
77
80
|
// Resolve API key from credential store
|
|
78
81
|
const credType = `${model.provider}_key`;
|
|
79
82
|
let apiKey;
|
|
@@ -106,7 +109,9 @@ export function registerLogSummaryRoutes(app, projectPath, statsStore) {
|
|
|
106
109
|
summary = response.content;
|
|
107
110
|
}
|
|
108
111
|
catch (err) {
|
|
109
|
-
|
|
112
|
+
const msg = `Failed to generate summary: ${err instanceof Error ? err.message : String(err)}`;
|
|
113
|
+
logger?.error({ agent: name, instanceId, err }, msg);
|
|
114
|
+
return c.json({ error: msg }, 500);
|
|
110
115
|
}
|
|
111
116
|
// Cache for completed runs
|
|
112
117
|
if (!query.lines && !query.after && !query.before && !query.grep) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"log-summary.js","sourceRoot":"","sources":["../../../src/control/routes/log-summary.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
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;AAyDjC,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,GAAG,IAAI,CAwBtE"}
|
|
@@ -1,70 +1,50 @@
|
|
|
1
|
-
import { SAFE_AGENT_NAME,
|
|
1
|
+
import { SAFE_AGENT_NAME, findLogFiles, dateFromLogFile, readLastEntriesMultiFile, readEntriesForwardMultiFile, encodeCursor, decodeCursor, parseQueryParams, } from "./log-helpers.js";
|
|
2
|
+
async function handleLogRequest(projectPath, prefix, query, instanceFilter) {
|
|
3
|
+
const { lines, cursor, after, before, grep, minLevel } = parseQueryParams(query);
|
|
4
|
+
let grepRe;
|
|
5
|
+
if (grep) {
|
|
6
|
+
try {
|
|
7
|
+
grepRe = new RegExp(grep);
|
|
8
|
+
}
|
|
9
|
+
catch {
|
|
10
|
+
return { status: 400, body: { error: "Invalid grep pattern" } };
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
const filterLevel = (entries) => minLevel > 0 ? entries.filter((e) => e.level >= minLevel) : entries;
|
|
14
|
+
if (cursor) {
|
|
15
|
+
const parsed = decodeCursor(cursor);
|
|
16
|
+
if (!parsed)
|
|
17
|
+
return { status: 400, body: { error: "Invalid cursor" } };
|
|
18
|
+
const files = findLogFiles(projectPath, prefix);
|
|
19
|
+
if (files.length === 0)
|
|
20
|
+
return { status: 200, body: { entries: [], cursor: null, hasMore: false } };
|
|
21
|
+
const { entries, newDate, newOffset } = await readEntriesForwardMultiFile(projectPath, prefix, parsed.date, parsed.offsets[0] || 0, lines, after, before, instanceFilter, grepRe);
|
|
22
|
+
const filtered = filterLevel(entries);
|
|
23
|
+
const newCursor = encodeCursor(newDate, [newOffset]);
|
|
24
|
+
return { status: 200, body: { entries: filtered, cursor: newCursor, hasMore: entries.length >= lines } };
|
|
25
|
+
}
|
|
26
|
+
const files = findLogFiles(projectPath, prefix);
|
|
27
|
+
if (files.length === 0)
|
|
28
|
+
return { status: 200, body: { entries: [], cursor: null, hasMore: false } };
|
|
29
|
+
const { entries, latestFile, byteOffset } = await readLastEntriesMultiFile(files, lines, after, before, instanceFilter, grepRe);
|
|
30
|
+
const filtered = filterLevel(entries);
|
|
31
|
+
const date = latestFile ? dateFromLogFile(latestFile) || "" : "";
|
|
32
|
+
const resCursor = encodeCursor(date, [byteOffset]);
|
|
33
|
+
return { status: 200, body: { entries: filtered, cursor: resCursor, hasMore: false } };
|
|
34
|
+
}
|
|
2
35
|
export function registerLogRoutes(app, projectPath) {
|
|
3
36
|
// ── Scheduler logs ────────────────────────────────────────────────────────
|
|
4
37
|
app.get("/api/logs/scheduler", async (c) => {
|
|
5
|
-
const {
|
|
6
|
-
|
|
7
|
-
if (grep) {
|
|
8
|
-
try {
|
|
9
|
-
grepRe = new RegExp(grep);
|
|
10
|
-
}
|
|
11
|
-
catch {
|
|
12
|
-
return c.json({ error: "Invalid grep pattern" }, 400);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
if (cursor) {
|
|
16
|
-
const parsed = decodeCursor(cursor);
|
|
17
|
-
if (!parsed)
|
|
18
|
-
return c.json({ error: "Invalid cursor" }, 400);
|
|
19
|
-
const file = findLatestLogFile(projectPath, "scheduler");
|
|
20
|
-
if (!file)
|
|
21
|
-
return c.json({ entries: [], cursor: null, hasMore: false });
|
|
22
|
-
const currentDate = dateFromLogFile(file);
|
|
23
|
-
// If date rolled over, read from start of new file
|
|
24
|
-
const offset = currentDate !== parsed.date ? 0 : parsed.offsets[0] || 0;
|
|
25
|
-
const { entries, newOffset } = await readEntriesForward(file, offset, lines, after, before, undefined, grepRe);
|
|
26
|
-
const newCursor = encodeCursor(currentDate || parsed.date, [newOffset]);
|
|
27
|
-
return c.json({ entries, cursor: newCursor, hasMore: entries.length >= lines });
|
|
28
|
-
}
|
|
29
|
-
const file = findLatestLogFile(projectPath, "scheduler");
|
|
30
|
-
if (!file)
|
|
31
|
-
return c.json({ entries: [], cursor: null, hasMore: false });
|
|
32
|
-
const { entries, byteOffset } = await readLastEntries(file, lines, after, before, undefined, grepRe);
|
|
33
|
-
const date = dateFromLogFile(file) || "";
|
|
34
|
-
const resCursor = encodeCursor(date, [byteOffset]);
|
|
35
|
-
return c.json({ entries, cursor: resCursor, hasMore: false });
|
|
38
|
+
const { status, body } = await handleLogRequest(projectPath, "scheduler", c.req.query());
|
|
39
|
+
return c.json(body, status);
|
|
36
40
|
});
|
|
37
41
|
// ── Agent logs (all instances in one file) ─────────────────────────────
|
|
38
42
|
app.get("/api/logs/agents/:name", async (c) => {
|
|
39
43
|
const name = c.req.param("name");
|
|
40
44
|
if (!SAFE_AGENT_NAME.test(name))
|
|
41
45
|
return c.json({ error: "Invalid agent name" }, 400);
|
|
42
|
-
const {
|
|
43
|
-
|
|
44
|
-
if (grep) {
|
|
45
|
-
try {
|
|
46
|
-
grepRe = new RegExp(grep);
|
|
47
|
-
}
|
|
48
|
-
catch {
|
|
49
|
-
return c.json({ error: "Invalid grep pattern" }, 400);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
const file = findLatestLogFile(projectPath, name);
|
|
53
|
-
if (!file)
|
|
54
|
-
return c.json({ entries: [], cursor: null, hasMore: false });
|
|
55
|
-
if (cursor) {
|
|
56
|
-
const parsed = decodeCursor(cursor);
|
|
57
|
-
if (!parsed)
|
|
58
|
-
return c.json({ error: "Invalid cursor" }, 400);
|
|
59
|
-
const currentDate = dateFromLogFile(file);
|
|
60
|
-
const offset = currentDate !== parsed.date ? 0 : parsed.offsets[0] || 0;
|
|
61
|
-
const { entries, newOffset } = await readEntriesForward(file, offset, lines, after, before, undefined, grepRe);
|
|
62
|
-
const newCursor = encodeCursor(currentDate || parsed.date, [newOffset]);
|
|
63
|
-
return c.json({ entries, cursor: newCursor, hasMore: entries.length >= lines });
|
|
64
|
-
}
|
|
65
|
-
const { entries, byteOffset } = await readLastEntries(file, lines, after, before, undefined, grepRe);
|
|
66
|
-
const date = dateFromLogFile(file) || "";
|
|
67
|
-
return c.json({ entries, cursor: encodeCursor(date, [byteOffset]), hasMore: false });
|
|
46
|
+
const { status, body } = await handleLogRequest(projectPath, name, c.req.query());
|
|
47
|
+
return c.json(body, status);
|
|
68
48
|
});
|
|
69
49
|
// ── Specific instance logs (filter by instance field) ─────────────────
|
|
70
50
|
app.get("/api/logs/agents/:name/:instanceId", async (c) => {
|
|
@@ -74,33 +54,8 @@ export function registerLogRoutes(app, projectPath) {
|
|
|
74
54
|
return c.json({ error: "Invalid agent name" }, 400);
|
|
75
55
|
if (!SAFE_AGENT_NAME.test(instanceId))
|
|
76
56
|
return c.json({ error: "Invalid instance ID" }, 400);
|
|
77
|
-
const {
|
|
78
|
-
|
|
79
|
-
if (grep) {
|
|
80
|
-
try {
|
|
81
|
-
grepRe = new RegExp(grep);
|
|
82
|
-
}
|
|
83
|
-
catch {
|
|
84
|
-
return c.json({ error: "Invalid grep pattern" }, 400);
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
const instanceFilter = instanceId;
|
|
88
|
-
const file = findLatestLogFile(projectPath, name);
|
|
89
|
-
if (!file)
|
|
90
|
-
return c.json({ entries: [], cursor: null, hasMore: false });
|
|
91
|
-
if (cursor) {
|
|
92
|
-
const parsed = decodeCursor(cursor);
|
|
93
|
-
if (!parsed)
|
|
94
|
-
return c.json({ error: "Invalid cursor" }, 400);
|
|
95
|
-
const currentDate = dateFromLogFile(file);
|
|
96
|
-
const offset = currentDate !== parsed.date ? 0 : parsed.offsets[0] || 0;
|
|
97
|
-
const { entries, newOffset } = await readEntriesForward(file, offset, lines, after, before, instanceFilter, grepRe);
|
|
98
|
-
const newCursor = encodeCursor(currentDate || parsed.date, [newOffset]);
|
|
99
|
-
return c.json({ entries, cursor: newCursor, hasMore: entries.length >= lines });
|
|
100
|
-
}
|
|
101
|
-
const { entries, byteOffset } = await readLastEntries(file, lines, after, before, instanceFilter, grepRe);
|
|
102
|
-
const date = dateFromLogFile(file) || "";
|
|
103
|
-
return c.json({ entries, cursor: encodeCursor(date, [byteOffset]), hasMore: false });
|
|
57
|
+
const { status, body } = await handleLogRequest(projectPath, name, c.req.query(), instanceId);
|
|
58
|
+
return c.json(body, status);
|
|
104
59
|
});
|
|
105
60
|
}
|
|
106
61
|
//# sourceMappingURL=logs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logs.js","sourceRoot":"","sources":["../../../src/control/routes/logs.ts"],"names":[],"mappings":"AACA,OAAO,EACL,eAAe,EACf,
|
|
1
|
+
{"version":3,"file":"logs.js","sourceRoot":"","sources":["../../../src/control/routes/logs.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stats.d.ts","sourceRoot":"","sources":["../../../src/control/routes/stats.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AACjC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAEjE,MAAM,WAAW,gBAAgB;IAC/B,SAAS,CAAC,EAAE;QACV,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC;QAChC,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG;YAAE,OAAO,EAAE,OAAO,CAAC;YAAC,UAAU,EAAE,IAAI,CAAA;SAAE,EAAE,CAAC;KACnE,CAAC;CACH;AAED,wBAAgB,mBAAmB,CACjC,GAAG,EAAE,IAAI,EACT,UAAU,CAAC,EAAE,UAAU,EACvB,aAAa,CAAC,EAAE,aAAa,EAC7B,WAAW,CAAC,EAAE,gBAAgB,GAC7B,IAAI,
|
|
1
|
+
{"version":3,"file":"stats.d.ts","sourceRoot":"","sources":["../../../src/control/routes/stats.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AACjC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAEjE,MAAM,WAAW,gBAAgB;IAC/B,SAAS,CAAC,EAAE;QACV,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC;QAChC,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG;YAAE,OAAO,EAAE,OAAO,CAAC;YAAC,UAAU,EAAE,IAAI,CAAA;SAAE,EAAE,CAAC;KACnE,CAAC;CACH;AAED,wBAAgB,mBAAmB,CACjC,GAAG,EAAE,IAAI,EACT,UAAU,CAAC,EAAE,UAAU,EACvB,aAAa,CAAC,EAAE,aAAa,EAC7B,WAAW,CAAC,EAAE,gBAAgB,GAC7B,IAAI,CA6VN"}
|