@sandagent/daemon 0.8.5

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 (48) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +378 -0
  3. package/dist/bundle.mjs +219213 -0
  4. package/dist/cli.d.ts +3 -0
  5. package/dist/cli.d.ts.map +1 -0
  6. package/dist/cli.js +20 -0
  7. package/dist/cli.js.map +1 -0
  8. package/dist/index.d.ts +4 -0
  9. package/dist/index.d.ts.map +1 -0
  10. package/dist/index.js +3 -0
  11. package/dist/index.js.map +1 -0
  12. package/dist/nextjs.d.ts +20 -0
  13. package/dist/nextjs.d.ts.map +1 -0
  14. package/dist/nextjs.js +45 -0
  15. package/dist/nextjs.js.map +1 -0
  16. package/dist/router.d.ts +13 -0
  17. package/dist/router.d.ts.map +1 -0
  18. package/dist/router.js +58 -0
  19. package/dist/router.js.map +1 -0
  20. package/dist/routes/coding.d.ts +22 -0
  21. package/dist/routes/coding.d.ts.map +1 -0
  22. package/dist/routes/coding.js +84 -0
  23. package/dist/routes/coding.js.map +1 -0
  24. package/dist/routes/fs.d.ts +83 -0
  25. package/dist/routes/fs.d.ts.map +1 -0
  26. package/dist/routes/fs.js +135 -0
  27. package/dist/routes/fs.js.map +1 -0
  28. package/dist/routes/git.d.ts +37 -0
  29. package/dist/routes/git.d.ts.map +1 -0
  30. package/dist/routes/git.js +106 -0
  31. package/dist/routes/git.js.map +1 -0
  32. package/dist/routes/health.d.ts +7 -0
  33. package/dist/routes/health.d.ts.map +1 -0
  34. package/dist/routes/health.js +5 -0
  35. package/dist/routes/health.js.map +1 -0
  36. package/dist/routes/volumes.d.ts +16 -0
  37. package/dist/routes/volumes.d.ts.map +1 -0
  38. package/dist/routes/volumes.js +21 -0
  39. package/dist/routes/volumes.js.map +1 -0
  40. package/dist/server.d.ts +8 -0
  41. package/dist/server.d.ts.map +1 -0
  42. package/dist/server.js +37 -0
  43. package/dist/server.js.map +1 -0
  44. package/dist/utils.d.ts +25 -0
  45. package/dist/utils.d.ts.map +1 -0
  46. package/dist/utils.js +51 -0
  47. package/dist/utils.js.map +1 -0
  48. package/package.json +54 -0
package/dist/cli.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=cli.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":""}
package/dist/cli.js ADDED
@@ -0,0 +1,20 @@
1
+ #!/usr/bin/env node
2
+ import { createDaemon } from "./server.js";
3
+ import { ensureDir } from "./utils.js";
4
+ const host = process.env.SANDAGENT_DAEMON_HOST ?? "0.0.0.0";
5
+ const port = Number(process.env.SANDAGENT_DAEMON_PORT ?? "3080");
6
+ const root = process.env.SANDAGENT_ROOT ?? "/workspace";
7
+ async function main() {
8
+ await ensureDir(root);
9
+ await ensureDir(`${root}/volumes`);
10
+ const server = createDaemon({ host, port, root });
11
+ server.listen(port, host, () => {
12
+ console.log(`sandagent-daemon listening on http://${host}:${port}`);
13
+ console.log(` root: ${root}`);
14
+ });
15
+ }
16
+ main().catch((err) => {
17
+ console.error("fatal:", err);
18
+ process.exit(1);
19
+ });
20
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAEvC,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,SAAS,CAAC;AAC5D,MAAM,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,MAAM,CAAC,CAAC;AACjE,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,YAAY,CAAC;AAExD,KAAK,UAAU,IAAI;IACjB,MAAM,SAAS,CAAC,IAAI,CAAC,CAAC;IACtB,MAAM,SAAS,CAAC,GAAG,IAAI,UAAU,CAAC,CAAC;IACnC,MAAM,MAAM,GAAG,YAAY,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;IAClD,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE;QAC7B,OAAO,CAAC,GAAG,CAAC,wCAAwC,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC;QACpE,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACL,CAAC;AAED,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;IACnB,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IAC7B,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { DaemonRouter } from "./router.js";
2
+ export { createDaemon, type DaemonConfig } from "./server.js";
3
+ export type { ApiEnvelope, AppState } from "./utils.js";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,KAAK,YAAY,EAAE,MAAM,aAAa,CAAC;AAC9D,YAAY,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,3 @@
1
+ export { DaemonRouter } from "./router.js";
2
+ export { createDaemon } from "./server.js";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAqB,MAAM,aAAa,CAAC"}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * Next.js Route Handler adapter for sandagent-daemon.
3
+ *
4
+ * Usage in Next.js app router:
5
+ *
6
+ * // app/api/daemon/[...path]/route.ts
7
+ * import { createNextHandler } from "@sandagent/daemon/nextjs";
8
+ * const handler = createNextHandler({ root: "/workspace", prefix: "/api/daemon" });
9
+ * export const GET = handler;
10
+ * export const POST = handler;
11
+ *
12
+ * Requests to /api/daemon/healthz → daemon /healthz
13
+ * Requests to /api/daemon/api/fs/read → daemon /api/fs/read
14
+ * Requests to /api/daemon/api/coding/run → daemon /api/coding/run (NDJSON stream)
15
+ */
16
+ export declare function createNextHandler(opts: {
17
+ root: string;
18
+ prefix?: string;
19
+ }): (req: Request) => Promise<Response>;
20
+ //# sourceMappingURL=nextjs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nextjs.d.ts","sourceRoot":"","sources":["../src/nextjs.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAKH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,IAKzD,KAAK,OAAO,KAAG,OAAO,CAAC,QAAQ,CAAC,CA6B/C"}
package/dist/nextjs.js ADDED
@@ -0,0 +1,45 @@
1
+ /**
2
+ * Next.js Route Handler adapter for sandagent-daemon.
3
+ *
4
+ * Usage in Next.js app router:
5
+ *
6
+ * // app/api/daemon/[...path]/route.ts
7
+ * import { createNextHandler } from "@sandagent/daemon/nextjs";
8
+ * const handler = createNextHandler({ root: "/workspace", prefix: "/api/daemon" });
9
+ * export const GET = handler;
10
+ * export const POST = handler;
11
+ *
12
+ * Requests to /api/daemon/healthz → daemon /healthz
13
+ * Requests to /api/daemon/api/fs/read → daemon /api/fs/read
14
+ * Requests to /api/daemon/api/coding/run → daemon /api/coding/run (NDJSON stream)
15
+ */
16
+ import { DaemonRouter } from "./router.js";
17
+ import { codingRunStream } from "./routes/coding.js";
18
+ export function createNextHandler(opts) {
19
+ const router = new DaemonRouter({ root: opts.root });
20
+ const env = process.env;
21
+ const prefix = opts.prefix ?? "/api/daemon";
22
+ return async (req) => {
23
+ const url = new URL(req.url);
24
+ // Strip the mount prefix to get the daemon-internal path
25
+ const pathname = url.pathname.startsWith(prefix)
26
+ ? url.pathname.slice(prefix.length) || "/"
27
+ : url.pathname;
28
+ const method = req.method ?? "GET";
29
+ // Streaming: /api/coding/run → NDJSON stream
30
+ if (method === "POST" && pathname === "/api/coding/run") {
31
+ const body = (await req.json().catch(() => ({})));
32
+ return codingRunStream(body, env);
33
+ }
34
+ // Standard JSON routes
35
+ const params = method === "GET"
36
+ ? Object.fromEntries(url.searchParams)
37
+ : (await req.json().catch(() => ({})));
38
+ const result = await router.handle(method, pathname, params);
39
+ if (!result) {
40
+ return Response.json({ ok: false, data: null, error: `not found: ${method} ${pathname}` }, { status: 404 });
41
+ }
42
+ return Response.json(result.body, { status: result.status });
43
+ };
44
+ }
45
+ //# sourceMappingURL=nextjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nextjs.js","sourceRoot":"","sources":["../src/nextjs.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAmB,MAAM,oBAAoB,CAAC;AAEtE,MAAM,UAAU,iBAAiB,CAAC,IAAuC;IACvE,MAAM,MAAM,GAAG,IAAI,YAAY,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACrD,MAAM,GAAG,GAAG,OAAO,CAAC,GAA6B,CAAC;IAClD,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,aAAa,CAAC;IAE5C,OAAO,KAAK,EAAE,GAAY,EAAqB,EAAE;QAC/C,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC7B,yDAAyD;QACzD,MAAM,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC;YAC9C,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,GAAG;YAC1C,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC;QACjB,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC;QAEnC,6CAA6C;QAC7C,IAAI,MAAM,KAAK,MAAM,IAAI,QAAQ,KAAK,iBAAiB,EAAE,CAAC;YACxD,MAAM,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAe,CAAC;YAChE,OAAO,eAAe,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QACpC,CAAC;QAED,uBAAuB;QACvB,MAAM,MAAM,GACV,MAAM,KAAK,KAAK;YACd,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,YAAY,CAAC;YACtC,CAAC,CAAE,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAA6B,CAAC;QAExE,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;QAC7D,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO,QAAQ,CAAC,IAAI,CAClB,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,cAAc,MAAM,IAAI,QAAQ,EAAE,EAAE,EACpE,EAAE,MAAM,EAAE,GAAG,EAAE,CAChB,CAAC;QACJ,CAAC;QACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;IAC/D,CAAC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { ApiEnvelope } from "./utils.js";
2
+ export declare class DaemonRouter {
3
+ private state;
4
+ private routes;
5
+ constructor(opts: {
6
+ root: string;
7
+ });
8
+ handle(method: string, pathname: string, params: Record<string, unknown>): Promise<{
9
+ status: number;
10
+ body: ApiEnvelope;
11
+ } | null>;
12
+ }
13
+ //# sourceMappingURL=router.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"router.d.ts","sourceRoot":"","sources":["../src/router.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,WAAW,EAAY,MAAM,YAAY,CAAC;AAMxD,qBAAa,YAAY;IACvB,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,MAAM,CAAmC;gBAErC,IAAI,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE;IA2B5B,MAAM,CACV,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC9B,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,WAAW,CAAA;KAAE,GAAG,IAAI,CAAC;CAqBzD"}
package/dist/router.js ADDED
@@ -0,0 +1,58 @@
1
+ import * as fsRoutes from "./routes/fs.js";
2
+ import * as gitRoutes from "./routes/git.js";
3
+ import { healthHandler } from "./routes/health.js";
4
+ import { volumesEnsure, volumesList, volumesRemove } from "./routes/volumes.js";
5
+ import { AppError, fail } from "./utils.js";
6
+ export class DaemonRouter {
7
+ state;
8
+ routes;
9
+ constructor(opts) {
10
+ this.state = {
11
+ root: opts.root,
12
+ volumesRoot: `${opts.root}/volumes`,
13
+ };
14
+ this.routes = [
15
+ ["GET", "/api/volumes/list", (s) => volumesList(s)],
16
+ ["POST", "/api/volumes/ensure", (s, b) => volumesEnsure(s, b)],
17
+ ["POST", "/api/volumes/remove", (s, b) => volumesRemove(s, b)],
18
+ ["GET", "/api/fs/list", (s, q) => fsRoutes.fsList(s, q)],
19
+ ["GET", "/api/fs/read", (s, q) => fsRoutes.fsRead(s, q)],
20
+ ["GET", "/api/fs/stat", (s, q) => fsRoutes.fsStat(s, q)],
21
+ ["GET", "/api/fs/exists", (s, q) => fsRoutes.fsExists(s, q)],
22
+ ["GET", "/api/fs/find", (s, q) => fsRoutes.fsFind(s, q)],
23
+ ["POST", "/api/fs/write", (s, b) => fsRoutes.fsWrite(s, b)],
24
+ ["POST", "/api/fs/append", (s, b) => fsRoutes.fsAppend(s, b)],
25
+ ["POST", "/api/fs/mkdir", (s, b) => fsRoutes.fsMkdir(s, b)],
26
+ ["POST", "/api/fs/remove", (s, b) => fsRoutes.fsRemove(s, b)],
27
+ ["POST", "/api/fs/move", (s, b) => fsRoutes.fsMove(s, b)],
28
+ ["POST", "/api/fs/copy", (s, b) => fsRoutes.fsCopy(s, b)],
29
+ ["POST", "/api/git/status", (s, b) => gitRoutes.gitStatus(s, b)],
30
+ ["POST", "/api/git/exec", (s, b) => gitRoutes.gitExec(s, b)],
31
+ ["POST", "/api/git/clone", (s, b) => gitRoutes.gitClone(s, b)],
32
+ ["POST", "/api/git/init", (s, b) => gitRoutes.gitInit(s, b)],
33
+ ];
34
+ }
35
+ async handle(method, pathname, params) {
36
+ if (pathname === "/healthz" && method === "GET") {
37
+ return { status: 200, body: healthHandler(this.state) };
38
+ }
39
+ for (const [m, p, handler] of this.routes) {
40
+ if (method === m && pathname === p) {
41
+ try {
42
+ return { status: 200, body: await handler(this.state, params) };
43
+ }
44
+ catch (err) {
45
+ if (err instanceof AppError) {
46
+ return { status: err.status, body: fail(err.message) };
47
+ }
48
+ return {
49
+ status: 500,
50
+ body: fail(err instanceof Error ? err.message : String(err)),
51
+ };
52
+ }
53
+ }
54
+ }
55
+ return null;
56
+ }
57
+ }
58
+ //# sourceMappingURL=router.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"router.js","sourceRoot":"","sources":["../src/router.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ import type * as http from "node:http";
2
+ export interface RunRequest {
3
+ runner?: string;
4
+ model?: string;
5
+ userInput: string;
6
+ systemPrompt?: string;
7
+ maxTurns?: number;
8
+ allowedTools?: string[];
9
+ resume?: string;
10
+ skillPaths?: string[];
11
+ cwd?: string;
12
+ }
13
+ /**
14
+ * POST /api/coding/run — Node http.ServerResponse version (standalone daemon)
15
+ */
16
+ export declare function sandagentRun(req: RunRequest, res: http.ServerResponse, env: Record<string, string>): Promise<void>;
17
+ /**
18
+ * POST /api/coding/run — Web Response version (Next.js embed)
19
+ * Returns a streaming Response with NDJSON body.
20
+ */
21
+ export declare function codingRunStream(req: RunRequest, env: Record<string, string>): Response;
22
+ //# sourceMappingURL=coding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coding.d.ts","sourceRoot":"","sources":["../../src/routes/coding.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,IAAI,MAAM,WAAW,CAAC;AAGvC,MAAM,WAAW,UAAU;IACzB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED;;GAEG;AACH,wBAAsB,YAAY,CAChC,GAAG,EAAE,UAAU,EACf,GAAG,EAAE,IAAI,CAAC,cAAc,EACxB,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAC1B,OAAO,CAAC,IAAI,CAAC,CAkCf;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAC7B,GAAG,EAAE,UAAU,EACf,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAC1B,QAAQ,CA0CV"}
@@ -0,0 +1,84 @@
1
+ import { createRunner } from "@sandagent/runner-core";
2
+ /**
3
+ * POST /api/coding/run — Node http.ServerResponse version (standalone daemon)
4
+ */
5
+ export async function sandagentRun(req, res, env) {
6
+ const abortController = new AbortController();
7
+ res.on("close", () => abortController.abort());
8
+ res.writeHead(200, {
9
+ "Content-Type": "application/x-ndjson",
10
+ "Cache-Control": "no-cache",
11
+ "Transfer-Encoding": "chunked",
12
+ });
13
+ try {
14
+ const stream = createRunner({
15
+ runner: req.runner ?? "claude",
16
+ model: req.model ?? "claude-sonnet-4-20250514",
17
+ userInput: req.userInput,
18
+ systemPrompt: req.systemPrompt,
19
+ maxTurns: req.maxTurns,
20
+ allowedTools: req.allowedTools,
21
+ resume: req.resume,
22
+ skillPaths: req.skillPaths,
23
+ cwd: req.cwd ?? process.env.SANDAGENT_ROOT ?? "/workspace",
24
+ env,
25
+ abortController,
26
+ });
27
+ for await (const chunk of stream) {
28
+ res.write(chunk);
29
+ }
30
+ }
31
+ catch (err) {
32
+ const msg = err instanceof Error ? err.message : String(err);
33
+ res.write(`${JSON.stringify({ error: msg })}\n`);
34
+ }
35
+ finally {
36
+ res.end();
37
+ }
38
+ }
39
+ /**
40
+ * POST /api/coding/run — Web Response version (Next.js embed)
41
+ * Returns a streaming Response with NDJSON body.
42
+ */
43
+ export function codingRunStream(req, env) {
44
+ const abortController = new AbortController();
45
+ const body = new ReadableStream({
46
+ async start(controller) {
47
+ try {
48
+ const stream = createRunner({
49
+ runner: req.runner ?? "claude",
50
+ model: req.model ?? "claude-sonnet-4-20250514",
51
+ userInput: req.userInput,
52
+ systemPrompt: req.systemPrompt,
53
+ maxTurns: req.maxTurns,
54
+ allowedTools: req.allowedTools,
55
+ resume: req.resume,
56
+ skillPaths: req.skillPaths,
57
+ cwd: req.cwd ?? process.env.SANDAGENT_ROOT ?? "/workspace",
58
+ env,
59
+ abortController,
60
+ });
61
+ for await (const chunk of stream) {
62
+ controller.enqueue(new TextEncoder().encode(chunk));
63
+ }
64
+ }
65
+ catch (err) {
66
+ const msg = err instanceof Error ? err.message : String(err);
67
+ controller.enqueue(new TextEncoder().encode(`${JSON.stringify({ error: msg })}\n`));
68
+ }
69
+ finally {
70
+ controller.close();
71
+ }
72
+ },
73
+ cancel() {
74
+ abortController.abort();
75
+ },
76
+ });
77
+ return new Response(body, {
78
+ headers: {
79
+ "Content-Type": "application/x-ndjson",
80
+ "Cache-Control": "no-cache",
81
+ },
82
+ });
83
+ }
84
+ //# sourceMappingURL=coding.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coding.js","sourceRoot":"","sources":["../../src/routes/coding.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AActD;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,GAAe,EACf,GAAwB,EACxB,GAA2B;IAE3B,MAAM,eAAe,GAAG,IAAI,eAAe,EAAE,CAAC;IAC9C,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC,CAAC;IAE/C,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,cAAc,EAAE,sBAAsB;QACtC,eAAe,EAAE,UAAU;QAC3B,mBAAmB,EAAE,SAAS;KAC/B,CAAC,CAAC;IAEH,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,YAAY,CAAC;YAC1B,MAAM,EAAE,GAAG,CAAC,MAAM,IAAI,QAAQ;YAC9B,KAAK,EAAE,GAAG,CAAC,KAAK,IAAI,0BAA0B;YAC9C,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,YAAY,EAAE,GAAG,CAAC,YAAY;YAC9B,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,YAAY,EAAE,GAAG,CAAC,YAAY;YAC9B,MAAM,EAAE,GAAG,CAAC,MAAM;YAClB,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,GAAG,EAAE,GAAG,CAAC,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,YAAY;YAC1D,GAAG;YACH,eAAe;SAChB,CAAC,CAAC;QAEH,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YACjC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC;IACH,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC7D,GAAG,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC;YAAS,CAAC;QACT,GAAG,CAAC,GAAG,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,eAAe,CAC7B,GAAe,EACf,GAA2B;IAE3B,MAAM,eAAe,GAAG,IAAI,eAAe,EAAE,CAAC;IAE9C,MAAM,IAAI,GAAG,IAAI,cAAc,CAAC;QAC9B,KAAK,CAAC,KAAK,CAAC,UAAU;YACpB,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,YAAY,CAAC;oBAC1B,MAAM,EAAE,GAAG,CAAC,MAAM,IAAI,QAAQ;oBAC9B,KAAK,EAAE,GAAG,CAAC,KAAK,IAAI,0BAA0B;oBAC9C,SAAS,EAAE,GAAG,CAAC,SAAS;oBACxB,YAAY,EAAE,GAAG,CAAC,YAAY;oBAC9B,QAAQ,EAAE,GAAG,CAAC,QAAQ;oBACtB,YAAY,EAAE,GAAG,CAAC,YAAY;oBAC9B,MAAM,EAAE,GAAG,CAAC,MAAM;oBAClB,UAAU,EAAE,GAAG,CAAC,UAAU;oBAC1B,GAAG,EAAE,GAAG,CAAC,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,YAAY;oBAC1D,GAAG;oBACH,eAAe;iBAChB,CAAC,CAAC;gBACH,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBACjC,UAAU,CAAC,OAAO,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;gBACtD,CAAC;YACH,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;gBAC7D,UAAU,CAAC,OAAO,CAChB,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,CAChE,CAAC;YACJ,CAAC;oBAAS,CAAC;gBACT,UAAU,CAAC,KAAK,EAAE,CAAC;YACrB,CAAC;QACH,CAAC;QACD,MAAM;YACJ,eAAe,CAAC,KAAK,EAAE,CAAC;QAC1B,CAAC;KACF,CAAC,CAAC;IAEH,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE;QACxB,OAAO,EAAE;YACP,cAAc,EAAE,sBAAsB;YACtC,eAAe,EAAE,UAAU;SAC5B;KACF,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,83 @@
1
+ import type { AppState } from "../utils.js";
2
+ interface PathQuery {
3
+ volume?: string;
4
+ path: string;
5
+ }
6
+ interface ListQuery {
7
+ volume?: string;
8
+ path?: string;
9
+ }
10
+ interface FindQuery {
11
+ volume?: string;
12
+ path?: string;
13
+ pattern: string;
14
+ limit?: number;
15
+ }
16
+ interface WriteBody {
17
+ volume?: string;
18
+ path: string;
19
+ content: string;
20
+ create_dirs?: boolean;
21
+ }
22
+ interface RemoveBody {
23
+ volume?: string;
24
+ path: string;
25
+ recursive?: boolean;
26
+ }
27
+ interface MkdirBody {
28
+ volume?: string;
29
+ path: string;
30
+ recursive?: boolean;
31
+ }
32
+ interface MoveCopyBody {
33
+ volume?: string;
34
+ from: string;
35
+ to: string;
36
+ create_dirs?: boolean;
37
+ }
38
+ export declare function fsList(state: AppState, q: ListQuery): Promise<import("../utils.js").ApiEnvelope<{
39
+ name: string;
40
+ path: string;
41
+ is_dir: boolean;
42
+ size: number;
43
+ }[]>>;
44
+ export declare function fsRead(state: AppState, q: PathQuery): Promise<import("../utils.js").ApiEnvelope<{
45
+ path: string;
46
+ content: string;
47
+ }>>;
48
+ export declare function fsStat(state: AppState, q: PathQuery): Promise<import("../utils.js").ApiEnvelope<{
49
+ path: string;
50
+ is_dir: boolean;
51
+ size: number;
52
+ }>>;
53
+ export declare function fsExists(state: AppState, q: PathQuery): Promise<import("../utils.js").ApiEnvelope<{
54
+ path: string;
55
+ exists: boolean;
56
+ }>>;
57
+ export declare function fsFind(state: AppState, q: FindQuery): Promise<import("../utils.js").ApiEnvelope<{
58
+ name: string;
59
+ path: string;
60
+ is_dir: boolean;
61
+ size: number;
62
+ }[]>>;
63
+ export declare function fsWrite(state: AppState, body: WriteBody): Promise<import("../utils.js").ApiEnvelope<{
64
+ path: string;
65
+ content: string;
66
+ }>>;
67
+ export declare function fsAppend(state: AppState, body: WriteBody): Promise<import("../utils.js").ApiEnvelope<{
68
+ path: string;
69
+ }>>;
70
+ export declare function fsMkdir(state: AppState, body: MkdirBody): Promise<import("../utils.js").ApiEnvelope<{
71
+ path: string;
72
+ }>>;
73
+ export declare function fsRemove(state: AppState, body: RemoveBody): Promise<import("../utils.js").ApiEnvelope<{
74
+ path: string;
75
+ }>>;
76
+ export declare function fsMove(state: AppState, body: MoveCopyBody): Promise<import("../utils.js").ApiEnvelope<{
77
+ path: string;
78
+ }>>;
79
+ export declare function fsCopy(state: AppState, body: MoveCopyBody): Promise<import("../utils.js").ApiEnvelope<{
80
+ path: string;
81
+ }>>;
82
+ export {};
83
+ //# sourceMappingURL=fs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fs.d.ts","sourceRoot":"","sources":["../../src/routes/fs.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAU5C,UAAU,SAAS;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,UAAU,SAAS;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,UAAU,SAAS;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAID,UAAU,SAAS;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,UAAU,UAAU;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,UAAU,SAAS;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,UAAU,YAAY;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAID,wBAAsB,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS;;;;;MAkBzD;AAED,wBAAsB,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS;;;IAKzD;AAED,wBAAsB,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS;;;;IASzD;AAED,wBAAsB,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS;;;IAQ3D;AAED,wBAAsB,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS;UAMhD,MAAM;UACN,MAAM;YACJ,OAAO;UACT,MAAM;MA4Bf;AAED,wBAAsB,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS;;;IAQ7D;AAED,wBAAsB,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS;;IAQ9D;AAED,wBAAsB,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS;;IAK7D;AAED,wBAAsB,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU;;IAU/D;AAED,wBAAsB,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;;IAS/D;AAED,wBAAsB,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;;IAS/D"}
@@ -0,0 +1,135 @@
1
+ import * as fs from "node:fs/promises";
2
+ import * as path from "node:path";
3
+ import { ensureDir, ok, resolveUnderRoot, resolveVolumeRoot, } from "../utils.js";
4
+ // --- Handlers ---
5
+ export async function fsList(state, q) {
6
+ const root = resolveVolumeRoot(state, q.volume);
7
+ const target = resolveUnderRoot(root, q.path ?? ".");
8
+ const entries = await fs.readdir(target, { withFileTypes: true });
9
+ const result = await Promise.all(entries.map(async (e) => {
10
+ const fullPath = path.join(target, e.name);
11
+ const stat = await fs.stat(fullPath).catch(() => null);
12
+ return {
13
+ name: e.name,
14
+ path: fullPath,
15
+ is_dir: e.isDirectory(),
16
+ size: stat?.isFile() ? stat.size : 0,
17
+ };
18
+ }));
19
+ result.sort((a, b) => a.name.localeCompare(b.name));
20
+ return ok(result);
21
+ }
22
+ export async function fsRead(state, q) {
23
+ const root = resolveVolumeRoot(state, q.volume);
24
+ const target = resolveUnderRoot(root, q.path);
25
+ const content = await fs.readFile(target, "utf-8");
26
+ return ok({ path: target, content });
27
+ }
28
+ export async function fsStat(state, q) {
29
+ const root = resolveVolumeRoot(state, q.volume);
30
+ const target = resolveUnderRoot(root, q.path);
31
+ const stat = await fs.stat(target);
32
+ return ok({
33
+ path: target,
34
+ is_dir: stat.isDirectory(),
35
+ size: stat.isFile() ? stat.size : 0,
36
+ });
37
+ }
38
+ export async function fsExists(state, q) {
39
+ const root = resolveVolumeRoot(state, q.volume);
40
+ const target = resolveUnderRoot(root, q.path);
41
+ const exists = await fs.stat(target).then(() => true, () => false);
42
+ return ok({ path: target, exists });
43
+ }
44
+ export async function fsFind(state, q) {
45
+ const root = resolveVolumeRoot(state, q.volume);
46
+ const start = resolveUnderRoot(root, q.path ?? ".");
47
+ const needle = q.pattern.toLowerCase();
48
+ const limit = Math.min(Math.max(q.limit ?? 200, 1), 2000);
49
+ const result = [];
50
+ const queue = [start];
51
+ while (queue.length > 0 && result.length < limit) {
52
+ const dir = queue.shift();
53
+ let entries;
54
+ try {
55
+ entries = await fs.readdir(dir);
56
+ }
57
+ catch {
58
+ continue;
59
+ }
60
+ for (const name of entries) {
61
+ const fullPath = path.join(dir, name);
62
+ const stat = await fs.stat(fullPath).catch(() => null);
63
+ if (stat?.isDirectory())
64
+ queue.push(fullPath);
65
+ if (name.toLowerCase().includes(needle)) {
66
+ result.push({
67
+ name,
68
+ path: fullPath,
69
+ is_dir: stat?.isDirectory() ?? false,
70
+ size: stat?.isFile() ? stat.size : 0,
71
+ });
72
+ if (result.length >= limit)
73
+ break;
74
+ }
75
+ }
76
+ }
77
+ return ok(result);
78
+ }
79
+ export async function fsWrite(state, body) {
80
+ const root = resolveVolumeRoot(state, body.volume);
81
+ const target = resolveUnderRoot(root, body.path);
82
+ if (body.create_dirs !== false) {
83
+ await ensureDir(path.dirname(target));
84
+ }
85
+ await fs.writeFile(target, body.content, "utf-8");
86
+ return ok({ path: target, content: body.content });
87
+ }
88
+ export async function fsAppend(state, body) {
89
+ const root = resolveVolumeRoot(state, body.volume);
90
+ const target = resolveUnderRoot(root, body.path);
91
+ if (body.create_dirs !== false) {
92
+ await ensureDir(path.dirname(target));
93
+ }
94
+ await fs.appendFile(target, body.content, "utf-8");
95
+ return ok({ path: target });
96
+ }
97
+ export async function fsMkdir(state, body) {
98
+ const root = resolveVolumeRoot(state, body.volume);
99
+ const target = resolveUnderRoot(root, body.path);
100
+ await fs.mkdir(target, { recursive: body.recursive ?? true });
101
+ return ok({ path: target });
102
+ }
103
+ export async function fsRemove(state, body) {
104
+ const root = resolveVolumeRoot(state, body.volume);
105
+ const target = resolveUnderRoot(root, body.path);
106
+ const stat = await fs.stat(target);
107
+ if (stat.isDirectory()) {
108
+ await fs.rm(target, { recursive: body.recursive ?? false });
109
+ }
110
+ else {
111
+ await fs.unlink(target);
112
+ }
113
+ return ok({ path: target });
114
+ }
115
+ export async function fsMove(state, body) {
116
+ const root = resolveVolumeRoot(state, body.volume);
117
+ const from = resolveUnderRoot(root, body.from);
118
+ const to = resolveUnderRoot(root, body.to);
119
+ if (body.create_dirs !== false) {
120
+ await ensureDir(path.dirname(to));
121
+ }
122
+ await fs.rename(from, to);
123
+ return ok({ path: to });
124
+ }
125
+ export async function fsCopy(state, body) {
126
+ const root = resolveVolumeRoot(state, body.volume);
127
+ const from = resolveUnderRoot(root, body.from);
128
+ const to = resolveUnderRoot(root, body.to);
129
+ if (body.create_dirs !== false) {
130
+ await ensureDir(path.dirname(to));
131
+ }
132
+ await fs.copyFile(from, to);
133
+ return ok({ path: to });
134
+ }
135
+ //# sourceMappingURL=fs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fs.js","sourceRoot":"","sources":["../../src/routes/fs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,37 @@
1
+ import type { AppState } from "../utils.js";
2
+ interface GitCommandResponse {
3
+ stdout: string;
4
+ stderr: string;
5
+ code: number;
6
+ }
7
+ export declare function gitStatus(state: AppState, body: {
8
+ volume?: string;
9
+ repo: string;
10
+ }): Promise<import("../utils.js").ApiEnvelope<GitCommandResponse>>;
11
+ export declare function gitExec(state: AppState, body: {
12
+ volume?: string;
13
+ repo: string;
14
+ args: string[];
15
+ }): Promise<import("../utils.js").ApiEnvelope<GitCommandResponse>>;
16
+ export declare function gitClone(state: AppState, body: {
17
+ volume?: string;
18
+ repo_parent: string;
19
+ url: string;
20
+ branch?: string;
21
+ depth?: number;
22
+ target_dir?: string;
23
+ list_files_limit?: number;
24
+ }): Promise<import("../utils.js").ApiEnvelope<{
25
+ repo_path: string;
26
+ tracked_files_count: number;
27
+ tracked_files: string[];
28
+ tracked_files_truncated: boolean;
29
+ command: GitCommandResponse;
30
+ }>>;
31
+ export declare function gitInit(state: AppState, body: {
32
+ volume?: string;
33
+ repo: string;
34
+ initial_branch?: string;
35
+ }): Promise<import("../utils.js").ApiEnvelope<GitCommandResponse>>;
36
+ export {};
37
+ //# sourceMappingURL=git.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git.d.ts","sourceRoot":"","sources":["../../src/routes/git.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAiC5C,UAAU,kBAAkB;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;CACd;AA0BD,wBAAsB,SAAS,CAC7B,KAAK,EAAE,QAAQ,EACf,IAAI,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,kEAMxC;AAED,wBAAsB,OAAO,CAC3B,KAAK,EAAE,QAAQ,EACf,IAAI,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,EAAE,CAAA;CAAE,kEASxD;AAED,wBAAsB,QAAQ,CAC5B,KAAK,EAAE,QAAQ,EACf,IAAI,EAAE;IACJ,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;;;;;;IAwCF;AAED,wBAAsB,OAAO,CAC3B,KAAK,EAAE,QAAQ,EACf,IAAI,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,cAAc,CAAC,EAAE,MAAM,CAAA;CAAE,kEAQjE"}