cloison-runtime 0.1.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/LICENSE +21 -0
- package/README.md +313 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +47 -0
- package/dist/cli.js.map +1 -0
- package/dist/config/index.d.ts +57 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +27 -0
- package/dist/config/index.js.map +1 -0
- package/dist/credentials/index.d.ts +4 -0
- package/dist/credentials/index.d.ts.map +1 -0
- package/dist/credentials/index.js +3 -0
- package/dist/credentials/index.js.map +1 -0
- package/dist/credentials/proxy.d.ts +3 -0
- package/dist/credentials/proxy.d.ts.map +1 -0
- package/dist/credentials/proxy.js +11 -0
- package/dist/credentials/proxy.js.map +1 -0
- package/dist/credentials/store.d.ts +7 -0
- package/dist/credentials/store.d.ts.map +1 -0
- package/dist/credentials/store.js +115 -0
- package/dist/credentials/store.js.map +1 -0
- package/dist/credentials/types.d.ts +14 -0
- package/dist/credentials/types.d.ts.map +1 -0
- package/dist/credentials/types.js +2 -0
- package/dist/credentials/types.js.map +1 -0
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +2 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/runner.d.ts +7 -0
- package/dist/hooks/runner.d.ts.map +1 -0
- package/dist/hooks/runner.js +20 -0
- package/dist/hooks/runner.js.map +1 -0
- package/dist/hooks/types.d.ts +39 -0
- package/dist/hooks/types.d.ts.map +1 -0
- package/dist/hooks/types.js +2 -0
- package/dist/hooks/types.js.map +1 -0
- package/dist/index.d.ts +32 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +58 -0
- package/dist/index.js.map +1 -0
- package/dist/infra/env.d.ts +2 -0
- package/dist/infra/env.d.ts.map +1 -0
- package/dist/infra/env.js +6 -0
- package/dist/infra/env.js.map +1 -0
- package/dist/infra/warning-filter.d.ts +8 -0
- package/dist/infra/warning-filter.d.ts.map +1 -0
- package/dist/infra/warning-filter.js +66 -0
- package/dist/infra/warning-filter.js.map +1 -0
- package/dist/logging/subsystem.d.ts +29 -0
- package/dist/logging/subsystem.d.ts.map +1 -0
- package/dist/logging/subsystem.js +322 -0
- package/dist/logging/subsystem.js.map +1 -0
- package/dist/memory/embedding-batch.d.ts +38 -0
- package/dist/memory/embedding-batch.d.ts.map +1 -0
- package/dist/memory/embedding-batch.js +253 -0
- package/dist/memory/embedding-batch.js.map +1 -0
- package/dist/memory/embedding-cache.d.ts +16 -0
- package/dist/memory/embedding-cache.d.ts.map +1 -0
- package/dist/memory/embedding-cache.js +113 -0
- package/dist/memory/embedding-cache.js.map +1 -0
- package/dist/memory/embeddings-debug.d.ts +2 -0
- package/dist/memory/embeddings-debug.d.ts.map +1 -0
- package/dist/memory/embeddings-debug.js +12 -0
- package/dist/memory/embeddings-debug.js.map +1 -0
- package/dist/memory/embeddings.d.ts +17 -0
- package/dist/memory/embeddings.d.ts.map +1 -0
- package/dist/memory/embeddings.js +203 -0
- package/dist/memory/embeddings.js.map +1 -0
- package/dist/memory/file-indexer.d.ts +26 -0
- package/dist/memory/file-indexer.d.ts.map +1 -0
- package/dist/memory/file-indexer.js +260 -0
- package/dist/memory/file-indexer.js.map +1 -0
- package/dist/memory/fs-utils.d.ts +12 -0
- package/dist/memory/fs-utils.d.ts.map +1 -0
- package/dist/memory/fs-utils.js +24 -0
- package/dist/memory/fs-utils.js.map +1 -0
- package/dist/memory/hybrid.d.ts +46 -0
- package/dist/memory/hybrid.d.ts.map +1 -0
- package/dist/memory/hybrid.js +85 -0
- package/dist/memory/hybrid.js.map +1 -0
- package/dist/memory/index.d.ts +17 -0
- package/dist/memory/index.d.ts.map +1 -0
- package/dist/memory/index.js +15 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/memory/internal.d.ts +39 -0
- package/dist/memory/internal.d.ts.map +1 -0
- package/dist/memory/internal.js +292 -0
- package/dist/memory/internal.js.map +1 -0
- package/dist/memory/manager-search.d.ts +61 -0
- package/dist/memory/manager-search.d.ts.map +1 -0
- package/dist/memory/manager-search.js +102 -0
- package/dist/memory/manager-search.js.map +1 -0
- package/dist/memory/mmr.d.ts +63 -0
- package/dist/memory/mmr.d.ts.map +1 -0
- package/dist/memory/mmr.js +165 -0
- package/dist/memory/mmr.js.map +1 -0
- package/dist/memory/query-expansion.d.ts +42 -0
- package/dist/memory/query-expansion.d.ts.map +1 -0
- package/dist/memory/query-expansion.js +776 -0
- package/dist/memory/query-expansion.js.map +1 -0
- package/dist/memory/session-indexer.d.ts +41 -0
- package/dist/memory/session-indexer.d.ts.map +1 -0
- package/dist/memory/session-indexer.js +367 -0
- package/dist/memory/session-indexer.js.map +1 -0
- package/dist/memory/simple-manager.d.ts +29 -0
- package/dist/memory/simple-manager.d.ts.map +1 -0
- package/dist/memory/simple-manager.js +216 -0
- package/dist/memory/simple-manager.js.map +1 -0
- package/dist/memory/sqlite.d.ts +2 -0
- package/dist/memory/sqlite.d.ts.map +1 -0
- package/dist/memory/sqlite.js +16 -0
- package/dist/memory/sqlite.js.map +1 -0
- package/dist/memory/ssrf.d.ts +18 -0
- package/dist/memory/ssrf.d.ts.map +1 -0
- package/dist/memory/ssrf.js +396 -0
- package/dist/memory/ssrf.js.map +1 -0
- package/dist/memory/temporal-decay.d.ts +26 -0
- package/dist/memory/temporal-decay.d.ts.map +1 -0
- package/dist/memory/temporal-decay.js +120 -0
- package/dist/memory/temporal-decay.js.map +1 -0
- package/dist/memory/types.d.ts +95 -0
- package/dist/memory/types.d.ts.map +1 -0
- package/dist/memory/types.js +2 -0
- package/dist/memory/types.js.map +1 -0
- package/dist/package.json +68 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.d.ts.map +1 -0
- package/dist/platform/index.js +2 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/platform/platform.d.ts +3 -0
- package/dist/platform/platform.d.ts.map +1 -0
- package/dist/platform/platform.js +91 -0
- package/dist/platform/platform.js.map +1 -0
- package/dist/platform/types.d.ts +18 -0
- package/dist/platform/types.d.ts.map +1 -0
- package/dist/platform/types.js +2 -0
- package/dist/platform/types.js.map +1 -0
- package/dist/runtime/agent.d.ts +36 -0
- package/dist/runtime/agent.d.ts.map +1 -0
- package/dist/runtime/agent.js +250 -0
- package/dist/runtime/agent.js.map +1 -0
- package/dist/runtime/api-key-rotation.d.ts +26 -0
- package/dist/runtime/api-key-rotation.d.ts.map +1 -0
- package/dist/runtime/api-key-rotation.js +174 -0
- package/dist/runtime/api-key-rotation.js.map +1 -0
- package/dist/runtime/context-guard.d.ts +32 -0
- package/dist/runtime/context-guard.d.ts.map +1 -0
- package/dist/runtime/context-guard.js +61 -0
- package/dist/runtime/context-guard.js.map +1 -0
- package/dist/runtime/failover-error.d.ts +62 -0
- package/dist/runtime/failover-error.d.ts.map +1 -0
- package/dist/runtime/failover-error.js +733 -0
- package/dist/runtime/failover-error.js.map +1 -0
- package/dist/runtime/failover-policy.d.ts +5 -0
- package/dist/runtime/failover-policy.d.ts.map +1 -0
- package/dist/runtime/failover-policy.js +18 -0
- package/dist/runtime/failover-policy.js.map +1 -0
- package/dist/runtime/index.d.ts +13 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +13 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/memory-flush.d.ts +24 -0
- package/dist/runtime/memory-flush.d.ts.map +1 -0
- package/dist/runtime/memory-flush.js +64 -0
- package/dist/runtime/memory-flush.js.map +1 -0
- package/dist/runtime/memory-tools.d.ts +14 -0
- package/dist/runtime/memory-tools.d.ts.map +1 -0
- package/dist/runtime/memory-tools.js +58 -0
- package/dist/runtime/memory-tools.js.map +1 -0
- package/dist/runtime/model-fallback.d.ts +56 -0
- package/dist/runtime/model-fallback.d.ts.map +1 -0
- package/dist/runtime/model-fallback.js +301 -0
- package/dist/runtime/model-fallback.js.map +1 -0
- package/dist/runtime/model-fallback.types.d.ts +14 -0
- package/dist/runtime/model-fallback.types.d.ts.map +1 -0
- package/dist/runtime/model-fallback.types.js +3 -0
- package/dist/runtime/model-fallback.types.js.map +1 -0
- package/dist/runtime/retry.d.ts +24 -0
- package/dist/runtime/retry.d.ts.map +1 -0
- package/dist/runtime/retry.js +100 -0
- package/dist/runtime/retry.js.map +1 -0
- package/dist/runtime/session-pruning.d.ts +22 -0
- package/dist/runtime/session-pruning.d.ts.map +1 -0
- package/dist/runtime/session-pruning.js +118 -0
- package/dist/runtime/session-pruning.js.map +1 -0
- package/dist/runtime/stream-adapters.d.ts +11 -0
- package/dist/runtime/stream-adapters.d.ts.map +1 -0
- package/dist/runtime/stream-adapters.js +46 -0
- package/dist/runtime/stream-adapters.js.map +1 -0
- package/dist/runtime/subagent.d.ts +83 -0
- package/dist/runtime/subagent.d.ts.map +1 -0
- package/dist/runtime/subagent.js +190 -0
- package/dist/runtime/subagent.js.map +1 -0
- package/dist/runtime/tool-result-truncation.d.ts +25 -0
- package/dist/runtime/tool-result-truncation.d.ts.map +1 -0
- package/dist/runtime/tool-result-truncation.js +115 -0
- package/dist/runtime/tool-result-truncation.js.map +1 -0
- package/dist/sandbox/cgroup.d.ts +20 -0
- package/dist/sandbox/cgroup.d.ts.map +1 -0
- package/dist/sandbox/cgroup.js +82 -0
- package/dist/sandbox/cgroup.js.map +1 -0
- package/dist/sandbox/index.d.ts +12 -0
- package/dist/sandbox/index.d.ts.map +1 -0
- package/dist/sandbox/index.js +10 -0
- package/dist/sandbox/index.js.map +1 -0
- package/dist/sandbox/ipc.d.ts +26 -0
- package/dist/sandbox/ipc.d.ts.map +1 -0
- package/dist/sandbox/ipc.js +154 -0
- package/dist/sandbox/ipc.js.map +1 -0
- package/dist/sandbox/manager.d.ts +4 -0
- package/dist/sandbox/manager.d.ts.map +1 -0
- package/dist/sandbox/manager.js +251 -0
- package/dist/sandbox/manager.js.map +1 -0
- package/dist/sandbox/namespace.d.ts +12 -0
- package/dist/sandbox/namespace.d.ts.map +1 -0
- package/dist/sandbox/namespace.js +119 -0
- package/dist/sandbox/namespace.js.map +1 -0
- package/dist/sandbox/proxy-tools.d.ts +14 -0
- package/dist/sandbox/proxy-tools.d.ts.map +1 -0
- package/dist/sandbox/proxy-tools.js +63 -0
- package/dist/sandbox/proxy-tools.js.map +1 -0
- package/dist/sandbox/rootfs.d.ts +20 -0
- package/dist/sandbox/rootfs.d.ts.map +1 -0
- package/dist/sandbox/rootfs.js +247 -0
- package/dist/sandbox/rootfs.js.map +1 -0
- package/dist/sandbox/seccomp-apply.d.ts +9 -0
- package/dist/sandbox/seccomp-apply.d.ts.map +1 -0
- package/dist/sandbox/seccomp-apply.js +227 -0
- package/dist/sandbox/seccomp-apply.js.map +1 -0
- package/dist/sandbox/seccomp.d.ts +13 -0
- package/dist/sandbox/seccomp.d.ts.map +1 -0
- package/dist/sandbox/seccomp.js +120 -0
- package/dist/sandbox/seccomp.js.map +1 -0
- package/dist/sandbox/types.d.ts +66 -0
- package/dist/sandbox/types.d.ts.map +1 -0
- package/dist/sandbox/types.js +8 -0
- package/dist/sandbox/types.js.map +1 -0
- package/dist/sandbox/worker.d.ts +15 -0
- package/dist/sandbox/worker.d.ts.map +1 -0
- package/dist/sandbox/worker.js +151 -0
- package/dist/sandbox/worker.js.map +1 -0
- package/dist/sessions/index.d.ts +3 -0
- package/dist/sessions/index.d.ts.map +1 -0
- package/dist/sessions/index.js +3 -0
- package/dist/sessions/index.js.map +1 -0
- package/dist/sessions/store.d.ts +17 -0
- package/dist/sessions/store.d.ts.map +1 -0
- package/dist/sessions/store.js +70 -0
- package/dist/sessions/store.js.map +1 -0
- package/dist/sessions/transcript-events.d.ts +11 -0
- package/dist/sessions/transcript-events.d.ts.map +1 -0
- package/dist/sessions/transcript-events.js +40 -0
- package/dist/sessions/transcript-events.js.map +1 -0
- package/dist/shared/agent-session.d.ts +10 -0
- package/dist/shared/agent-session.d.ts.map +1 -0
- package/dist/shared/agent-session.js +33 -0
- package/dist/shared/agent-session.js.map +1 -0
- package/dist/shared/constants.d.ts +6 -0
- package/dist/shared/constants.d.ts.map +1 -0
- package/dist/shared/constants.js +17 -0
- package/dist/shared/constants.js.map +1 -0
- package/dist/shared/fs.d.ts +7 -0
- package/dist/shared/fs.d.ts.map +1 -0
- package/dist/shared/fs.js +14 -0
- package/dist/shared/fs.js.map +1 -0
- package/dist/shared/index.d.ts +4 -0
- package/dist/shared/index.d.ts.map +1 -0
- package/dist/shared/index.js +4 -0
- package/dist/shared/index.js.map +1 -0
- package/dist/skills/enablement.d.ts +10 -0
- package/dist/skills/enablement.d.ts.map +1 -0
- package/dist/skills/enablement.js +52 -0
- package/dist/skills/enablement.js.map +1 -0
- package/dist/skills/index.d.ts +4 -0
- package/dist/skills/index.d.ts.map +1 -0
- package/dist/skills/index.js +4 -0
- package/dist/skills/index.js.map +1 -0
- package/dist/skills/loader.d.ts +8 -0
- package/dist/skills/loader.d.ts.map +1 -0
- package/dist/skills/loader.js +8 -0
- package/dist/skills/loader.js.map +1 -0
- package/dist/skills/registry.d.ts +19 -0
- package/dist/skills/registry.d.ts.map +1 -0
- package/dist/skills/registry.js +106 -0
- package/dist/skills/registry.js.map +1 -0
- package/dist/utils/boolean.d.ts +6 -0
- package/dist/utils/boolean.d.ts.map +1 -0
- package/dist/utils/boolean.js +28 -0
- package/dist/utils/boolean.js.map +1 -0
- package/dist/utils/run-with-concurrency.d.ts +12 -0
- package/dist/utils/run-with-concurrency.d.ts.map +1 -0
- package/dist/utils/run-with-concurrency.js +40 -0
- package/dist/utils/run-with-concurrency.js.map +1 -0
- package/dist/utils.d.ts +3 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +38 -0
- package/dist/utils.js.map +1 -0
- package/dist/workspace/index.d.ts +3 -0
- package/dist/workspace/index.d.ts.map +1 -0
- package/dist/workspace/index.js +2 -0
- package/dist/workspace/index.js.map +1 -0
- package/dist/workspace/runner.d.ts +19 -0
- package/dist/workspace/runner.d.ts.map +1 -0
- package/dist/workspace/runner.js +491 -0
- package/dist/workspace/runner.js.map +1 -0
- package/dist/workspace/types.d.ts +37 -0
- package/dist/workspace/types.d.ts.map +1 -0
- package/dist/workspace/types.js +2 -0
- package/dist/workspace/types.js.map +1 -0
- package/dist/workspace/workspace.d.ts +12 -0
- package/dist/workspace/workspace.d.ts.map +1 -0
- package/dist/workspace/workspace.js +85 -0
- package/dist/workspace/workspace.js.map +1 -0
- package/package.json +82 -0
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
import * as path from "node:path";
|
|
3
|
+
import * as os from "node:os";
|
|
4
|
+
const NODE_REQUIRED_SYSCALLS = [
|
|
5
|
+
"read", "write", "open", "close", "stat", "fstat", "lstat",
|
|
6
|
+
"poll", "lseek", "mmap", "mprotect", "munmap", "brk",
|
|
7
|
+
"rt_sigaction", "rt_sigprocmask", "rt_sigreturn", "ioctl",
|
|
8
|
+
"pread64", "pwrite64", "readv", "writev", "access",
|
|
9
|
+
"pipe", "select", "sched_yield", "mremap", "msync",
|
|
10
|
+
"mincore", "madvise", "shmget", "shmat", "shmctl",
|
|
11
|
+
"dup", "dup2", "pause", "nanosleep", "getitimer",
|
|
12
|
+
"alarm", "setitimer", "getpid", "sendfile",
|
|
13
|
+
"socket", "connect", "accept", "sendto", "recvfrom",
|
|
14
|
+
"sendmsg", "recvmsg", "shutdown", "bind", "listen",
|
|
15
|
+
"getsockname", "getpeername", "socketpair",
|
|
16
|
+
"setsockopt", "getsockopt",
|
|
17
|
+
"clone", "fork", "vfork", "execve",
|
|
18
|
+
"exit", "wait4", "kill", "uname",
|
|
19
|
+
"fcntl", "flock", "fsync", "fdatasync", "truncate", "ftruncate",
|
|
20
|
+
"getdents", "getcwd", "chdir", "fchdir",
|
|
21
|
+
"rename", "mkdir", "rmdir", "creat", "link", "unlink",
|
|
22
|
+
"symlink", "readlink", "chmod", "fchmod", "chown", "fchown",
|
|
23
|
+
"lchown", "umask", "gettimeofday", "getrlimit",
|
|
24
|
+
"getrusage", "sysinfo", "times", "getuid", "syslog",
|
|
25
|
+
"getgid", "setuid", "setgid", "geteuid", "getegid",
|
|
26
|
+
"setpgid", "getppid", "getpgrp", "setsid",
|
|
27
|
+
"setreuid", "setregid", "getgroups", "setgroups",
|
|
28
|
+
"setresuid", "getresuid", "setresgid", "getresgid",
|
|
29
|
+
"sigpending", "sigaltstack", "statfs", "fstatfs",
|
|
30
|
+
"arch_prctl", "set_tid_address", "set_robust_list",
|
|
31
|
+
"get_robust_list",
|
|
32
|
+
"futex", "sched_getaffinity",
|
|
33
|
+
"epoll_create", "epoll_ctl", "epoll_wait",
|
|
34
|
+
"epoll_create1", "epoll_pwait",
|
|
35
|
+
"eventfd", "eventfd2", "timerfd_create", "timerfd_settime",
|
|
36
|
+
"signalfd", "signalfd4",
|
|
37
|
+
"clock_gettime", "clock_getres", "clock_nanosleep",
|
|
38
|
+
"exit_group", "tgkill", "openat", "mkdirat",
|
|
39
|
+
"fchownat", "newfstatat", "unlinkat", "renameat",
|
|
40
|
+
"linkat", "symlinkat", "readlinkat", "fchmodat",
|
|
41
|
+
"faccessat", "pselect6", "ppoll",
|
|
42
|
+
"splice", "tee", "sync_file_range", "utimensat",
|
|
43
|
+
"fallocate", "accept4", "pipe2", "inotify_init1",
|
|
44
|
+
"preadv", "pwritev", "recvmmsg", "sendmmsg",
|
|
45
|
+
"getrandom", "memfd_create", "copy_file_range",
|
|
46
|
+
"statx", "rseq",
|
|
47
|
+
"close_range", "openat2", "pidfd_open",
|
|
48
|
+
"clone3", "faccessat2",
|
|
49
|
+
"process_mrelease", "futex_waitv",
|
|
50
|
+
"preadv2", "pwritev2",
|
|
51
|
+
"io_uring_setup", "io_uring_enter", "io_uring_register",
|
|
52
|
+
"mlock", "munlock",
|
|
53
|
+
"prctl", "capget", "capset",
|
|
54
|
+
"getdents64", "dup3",
|
|
55
|
+
"sched_setaffinity", "sched_getaffinity",
|
|
56
|
+
];
|
|
57
|
+
const BLOCKED_SYSCALLS = [
|
|
58
|
+
"ptrace",
|
|
59
|
+
"mount", "umount2",
|
|
60
|
+
"pivot_root", "chroot",
|
|
61
|
+
"reboot", "kexec_load", "kexec_file_load",
|
|
62
|
+
"init_module", "finit_module", "delete_module",
|
|
63
|
+
"acct",
|
|
64
|
+
"swapon", "swapoff",
|
|
65
|
+
"nfsservctl",
|
|
66
|
+
"personality",
|
|
67
|
+
"keyctl", "request_key", "add_key",
|
|
68
|
+
"bpf",
|
|
69
|
+
"userfaultfd",
|
|
70
|
+
"perf_event_open",
|
|
71
|
+
"lookup_dcookie",
|
|
72
|
+
"kcmp",
|
|
73
|
+
"process_vm_readv", "process_vm_writev",
|
|
74
|
+
"move_pages", "migrate_pages",
|
|
75
|
+
"mbind", "set_mempolicy", "get_mempolicy",
|
|
76
|
+
"unshare", "setns",
|
|
77
|
+
];
|
|
78
|
+
export function buildDefaultProfile() {
|
|
79
|
+
return {
|
|
80
|
+
defaultAction: "SCMP_ACT_ERRNO",
|
|
81
|
+
syscalls: [
|
|
82
|
+
{
|
|
83
|
+
names: NODE_REQUIRED_SYSCALLS,
|
|
84
|
+
action: "SCMP_ACT_ALLOW",
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
names: BLOCKED_SYSCALLS,
|
|
88
|
+
action: "SCMP_ACT_ERRNO",
|
|
89
|
+
},
|
|
90
|
+
],
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
export function buildRestrictedProfile(additionalAllowed) {
|
|
94
|
+
const allowed = [...NODE_REQUIRED_SYSCALLS, ...(additionalAllowed ?? [])];
|
|
95
|
+
return {
|
|
96
|
+
defaultAction: "SCMP_ACT_KILL",
|
|
97
|
+
syscalls: [
|
|
98
|
+
{
|
|
99
|
+
names: allowed,
|
|
100
|
+
action: "SCMP_ACT_ALLOW",
|
|
101
|
+
},
|
|
102
|
+
],
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
export function writeSeccompProfile(profile, sandboxId) {
|
|
106
|
+
const tmpDir = path.join(os.tmpdir(), "cloison-runtime-seccomp");
|
|
107
|
+
fs.mkdirSync(tmpDir, { recursive: true, mode: 0o700 });
|
|
108
|
+
const profilePath = path.join(tmpDir, `${sandboxId}.json`);
|
|
109
|
+
fs.writeFileSync(profilePath, JSON.stringify(profile, null, 2), { mode: 0o600 });
|
|
110
|
+
return profilePath;
|
|
111
|
+
}
|
|
112
|
+
export function cleanupSeccompProfile(profilePath) {
|
|
113
|
+
try {
|
|
114
|
+
fs.unlinkSync(profilePath);
|
|
115
|
+
}
|
|
116
|
+
catch {
|
|
117
|
+
// best effort
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=seccomp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"seccomp.js","sourceRoot":"","sources":["../../src/sandbox/seccomp.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
export interface SandboxConfig {
|
|
2
|
+
memoryLimitMb?: number;
|
|
3
|
+
cpuWeight?: number;
|
|
4
|
+
pidsLimit?: number;
|
|
5
|
+
networkIsolation?: boolean;
|
|
6
|
+
timeoutMs?: number;
|
|
7
|
+
mountBinds?: MountBind[];
|
|
8
|
+
}
|
|
9
|
+
export interface MountBind {
|
|
10
|
+
source: string;
|
|
11
|
+
target: string;
|
|
12
|
+
readonly: boolean;
|
|
13
|
+
}
|
|
14
|
+
export interface SandboxCapabilities {
|
|
15
|
+
hasUserNamespace: boolean;
|
|
16
|
+
hasPidNamespace: boolean;
|
|
17
|
+
hasMountNamespace: boolean;
|
|
18
|
+
hasNetNamespace: boolean;
|
|
19
|
+
hasCgroupV2: boolean;
|
|
20
|
+
hasSeccomp: boolean;
|
|
21
|
+
hasUnshare: boolean;
|
|
22
|
+
platform: "linux";
|
|
23
|
+
}
|
|
24
|
+
export interface SandboxProcess {
|
|
25
|
+
pid: number;
|
|
26
|
+
stdin: NodeJS.WritableStream;
|
|
27
|
+
stdout: NodeJS.ReadableStream;
|
|
28
|
+
stderr: NodeJS.ReadableStream;
|
|
29
|
+
kill(): void;
|
|
30
|
+
waitForExit(): Promise<number>;
|
|
31
|
+
}
|
|
32
|
+
export interface SandboxManager {
|
|
33
|
+
capabilities(): Promise<SandboxCapabilities>;
|
|
34
|
+
spawn(options: SandboxSpawnOptions): Promise<SandboxProcess>;
|
|
35
|
+
}
|
|
36
|
+
export interface SandboxSpawnOptions {
|
|
37
|
+
command: string;
|
|
38
|
+
args: string[];
|
|
39
|
+
env: Record<string, string>;
|
|
40
|
+
cwd: string;
|
|
41
|
+
config: SandboxConfig;
|
|
42
|
+
/** Env keys to preserve after credential sanitization (e.g. the LLM provider API key) */
|
|
43
|
+
protectedKeys?: string[];
|
|
44
|
+
onStderr?: (data: string) => void;
|
|
45
|
+
}
|
|
46
|
+
export interface IpcMessage {
|
|
47
|
+
jsonrpc: "2.0";
|
|
48
|
+
id?: number | string;
|
|
49
|
+
method?: string;
|
|
50
|
+
params?: unknown;
|
|
51
|
+
result?: unknown;
|
|
52
|
+
error?: IpcError;
|
|
53
|
+
}
|
|
54
|
+
export interface IpcError {
|
|
55
|
+
code: number;
|
|
56
|
+
message: string;
|
|
57
|
+
data?: unknown;
|
|
58
|
+
}
|
|
59
|
+
export declare const IPC_ERROR_CODES: {
|
|
60
|
+
readonly PARSE_ERROR: -32700;
|
|
61
|
+
readonly INVALID_REQUEST: -32600;
|
|
62
|
+
readonly METHOD_NOT_FOUND: -32601;
|
|
63
|
+
readonly INVALID_PARAMS: -32602;
|
|
64
|
+
readonly INTERNAL_ERROR: -32603;
|
|
65
|
+
};
|
|
66
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/sandbox/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,SAAS,EAAE,CAAC;CAC1B;AAED,MAAM,WAAW,SAAS;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,mBAAmB;IAClC,gBAAgB,EAAE,OAAO,CAAC;IAC1B,eAAe,EAAE,OAAO,CAAC;IACzB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,cAAc;IAC7B,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC,cAAc,CAAC;IAC7B,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC;IAC9B,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC;IAC9B,IAAI,IAAI,IAAI,CAAC;IACb,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,cAAc;IAC7B,YAAY,IAAI,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAC7C,KAAK,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;CAC9D;AAED,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC5B,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,aAAa,CAAC;IACtB,yFAAyF;IACzF,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CACnC;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,KAAK,CAAC;IACf,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,QAAQ,CAAC;CAClB;AAED,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB;AAED,eAAO,MAAM,eAAe;;;;;;CAMlB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/sandbox/types.ts"],"names":[],"mappings":"AAkEA,MAAM,CAAC,MAAM,eAAe,GAAG;IAC7B,WAAW,EAAE,CAAC,KAAK;IACnB,eAAe,EAAE,CAAC,KAAK;IACvB,gBAAgB,EAAE,CAAC,KAAK;IACxB,cAAc,EAAE,CAAC,KAAK;IACtB,cAAc,EAAE,CAAC,KAAK;CACd,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export interface WorkerConfig {
|
|
2
|
+
workspaceDir: string;
|
|
3
|
+
sessionsDir: string;
|
|
4
|
+
sessionId: string;
|
|
5
|
+
message: string;
|
|
6
|
+
model: string;
|
|
7
|
+
provider: string;
|
|
8
|
+
systemPrompt?: string;
|
|
9
|
+
enableCodingTools: boolean;
|
|
10
|
+
contextTokens?: number;
|
|
11
|
+
maxRetries?: number;
|
|
12
|
+
enableSubagents?: boolean;
|
|
13
|
+
}
|
|
14
|
+
export declare function startWorker(): Promise<void>;
|
|
15
|
+
//# sourceMappingURL=worker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../../src/sandbox/worker.ts"],"names":[],"mappings":"AAWA,MAAM,WAAW,YAAY;IAC3B,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED,wBAAsB,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC,CAsJjD"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { Writable } from "node:stream";
|
|
2
|
+
import * as path from "node:path";
|
|
3
|
+
import { fileURLToPath } from "node:url";
|
|
4
|
+
import * as fs from "node:fs";
|
|
5
|
+
import { createIpcPeer } from "./ipc.js";
|
|
6
|
+
import { createProxyTools } from "./proxy-tools.js";
|
|
7
|
+
import { resolveSessionManager, extractAssistantResponse, } from "../shared/index.js";
|
|
8
|
+
export async function startWorker() {
|
|
9
|
+
// Capture a direct reference to stdout.write BEFORE overriding, so the
|
|
10
|
+
// IPC peer can still write JSON-RPC messages to the real stdout fd.
|
|
11
|
+
const rawStdoutWrite = process.stdout.write.bind(process.stdout);
|
|
12
|
+
const ipcOutputStream = new Writable({
|
|
13
|
+
write(chunk, encoding, callback) {
|
|
14
|
+
rawStdoutWrite(chunk, encoding, callback);
|
|
15
|
+
},
|
|
16
|
+
});
|
|
17
|
+
// Redirect ALL stdout/console output to stderr so that libraries or SDK
|
|
18
|
+
// code using process.stdout.write() directly can't corrupt the IPC channel.
|
|
19
|
+
process.stdout.write = function (chunk, encodingOrCallback, callback) {
|
|
20
|
+
return process.stderr.write.call(process.stderr, chunk, encodingOrCallback, callback);
|
|
21
|
+
};
|
|
22
|
+
const stderrWrite = (msg) => { process.stderr.write(msg + "\n"); };
|
|
23
|
+
console.log = (...args) => stderrWrite(args.map(String).join(" "));
|
|
24
|
+
console.info = console.log;
|
|
25
|
+
console.warn = console.log;
|
|
26
|
+
console.error = console.log;
|
|
27
|
+
console.debug = console.log;
|
|
28
|
+
const config = readWorkerConfig();
|
|
29
|
+
if (!config) {
|
|
30
|
+
process.exit(1);
|
|
31
|
+
}
|
|
32
|
+
const peer = createIpcPeer(process.stdin, ipcOutputStream);
|
|
33
|
+
peer.handle("agent.run", async (params) => {
|
|
34
|
+
const runParams = (params ?? {});
|
|
35
|
+
const message = runParams.message ?? config.message;
|
|
36
|
+
const model = runParams.model ?? config.model;
|
|
37
|
+
const provider = runParams.provider ?? config.provider;
|
|
38
|
+
const systemPrompt = runParams.systemPrompt ?? config.systemPrompt;
|
|
39
|
+
const sessionId = runParams.sessionId ?? config.sessionId;
|
|
40
|
+
try {
|
|
41
|
+
const { createAgentSession, SessionManager, codingTools, } = await import("@mariozechner/pi-coding-agent");
|
|
42
|
+
const { getModel } = await import("@mariozechner/pi-ai");
|
|
43
|
+
const resolvedModel = getModel(provider, model);
|
|
44
|
+
fs.mkdirSync(config.sessionsDir, { recursive: true });
|
|
45
|
+
const sessionManager = resolveSessionManager(SessionManager, config.workspaceDir, config.sessionsDir);
|
|
46
|
+
const proxyTools = createProxyTools(peer);
|
|
47
|
+
const tools = config.enableCodingTools
|
|
48
|
+
? [...codingTools]
|
|
49
|
+
: [];
|
|
50
|
+
const customTools = proxyTools;
|
|
51
|
+
if (config.enableSubagents !== false) {
|
|
52
|
+
try {
|
|
53
|
+
const { createSubagentTool } = await import("../runtime/subagent.js");
|
|
54
|
+
const subTool = createSubagentTool({
|
|
55
|
+
runtime: {
|
|
56
|
+
run: async (opts) => {
|
|
57
|
+
const subResult = await peer.call("agent.run.subagent", opts);
|
|
58
|
+
if (subResult.error)
|
|
59
|
+
throw new Error(subResult.error);
|
|
60
|
+
return { response: subResult.response ?? "", sessionId: subResult.sessionId ?? "" };
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
});
|
|
64
|
+
customTools.push(subTool);
|
|
65
|
+
}
|
|
66
|
+
catch {
|
|
67
|
+
// subagent support not available in this build
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
const { session } = await createAgentSession({
|
|
71
|
+
cwd: config.workspaceDir,
|
|
72
|
+
model: resolvedModel,
|
|
73
|
+
tools,
|
|
74
|
+
customTools,
|
|
75
|
+
sessionManager,
|
|
76
|
+
});
|
|
77
|
+
const pendingToolArgs = new Map();
|
|
78
|
+
const unsubscribe = session.subscribe((event) => {
|
|
79
|
+
peer.notify("agent.event", {
|
|
80
|
+
type: event.type,
|
|
81
|
+
...event,
|
|
82
|
+
});
|
|
83
|
+
if (event.type === "tool_execution_start") {
|
|
84
|
+
pendingToolArgs.set(event.toolCallId, event.args ?? {});
|
|
85
|
+
peer.notify("hooks.before_tool_call", {
|
|
86
|
+
toolName: event.toolName,
|
|
87
|
+
input: event.args ?? {},
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
if (event.type === "tool_execution_end") {
|
|
91
|
+
const input = pendingToolArgs.get(event.toolCallId) ?? {};
|
|
92
|
+
pendingToolArgs.delete(event.toolCallId);
|
|
93
|
+
peer.notify("hooks.after_tool_call", {
|
|
94
|
+
toolName: event.toolName,
|
|
95
|
+
input,
|
|
96
|
+
result: event.result,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
try {
|
|
101
|
+
await session.sendUserMessage(message);
|
|
102
|
+
}
|
|
103
|
+
finally {
|
|
104
|
+
unsubscribe();
|
|
105
|
+
}
|
|
106
|
+
const responseText = extractAssistantResponse(session.messages);
|
|
107
|
+
return { response: responseText, sessionId };
|
|
108
|
+
}
|
|
109
|
+
catch (err) {
|
|
110
|
+
return { error: String(err) };
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
peer.start();
|
|
114
|
+
process.on("SIGTERM", () => {
|
|
115
|
+
peer.stop();
|
|
116
|
+
process.exit(0);
|
|
117
|
+
});
|
|
118
|
+
process.on("SIGINT", () => {
|
|
119
|
+
peer.stop();
|
|
120
|
+
process.exit(0);
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
function readWorkerConfig() {
|
|
124
|
+
const configJson = process.env["SANDBOX_WORKER_CONFIG"];
|
|
125
|
+
if (!configJson) {
|
|
126
|
+
process.stderr.write("SANDBOX_WORKER_CONFIG env var not set\n");
|
|
127
|
+
return null;
|
|
128
|
+
}
|
|
129
|
+
try {
|
|
130
|
+
return JSON.parse(configJson);
|
|
131
|
+
}
|
|
132
|
+
catch {
|
|
133
|
+
process.stderr.write("Failed to parse SANDBOX_WORKER_CONFIG\n");
|
|
134
|
+
return null;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
const isDirectRun = (() => {
|
|
138
|
+
if (!process.argv[1])
|
|
139
|
+
return false;
|
|
140
|
+
const normalize = (p) => p.replace(/\.ts$/, ".js");
|
|
141
|
+
const thisPath = normalize(fileURLToPath(import.meta.url));
|
|
142
|
+
const argResolved = normalize(path.resolve(process.argv[1]));
|
|
143
|
+
return thisPath === argResolved;
|
|
144
|
+
})();
|
|
145
|
+
if (isDirectRun) {
|
|
146
|
+
startWorker().catch((err) => {
|
|
147
|
+
process.stderr.write(`Worker failed: ${err}\n`);
|
|
148
|
+
process.exit(1);
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
//# sourceMappingURL=worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.js","sourceRoot":"","sources":["../../src/sandbox/worker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { type SessionEntry, type SessionStore, loadSessionStore, saveSessionStore, getOrCreateSession, updateSession, getSessionStorePath, } from "./store.js";
|
|
2
|
+
export { onSessionTranscriptUpdate, emitSessionTranscriptUpdate, type SessionTranscriptUpdate, } from "./transcript-events.js";
|
|
3
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sessions/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,YAAY,EACjB,gBAAgB,EAChB,gBAAgB,EAChB,kBAAkB,EAClB,aAAa,EACb,mBAAmB,GACpB,MAAM,YAAY,CAAC;AAEpB,OAAO,EACL,yBAAyB,EACzB,2BAA2B,EAC3B,KAAK,uBAAuB,GAC7B,MAAM,wBAAwB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/sessions/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,gBAAgB,EAChB,gBAAgB,EAChB,kBAAkB,EAClB,aAAa,EACb,mBAAmB,GACpB,MAAM,YAAY,CAAC;AAEpB,OAAO,EACL,yBAAyB,EACzB,2BAA2B,GAE5B,MAAM,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export interface SessionEntry {
|
|
2
|
+
id: string;
|
|
3
|
+
agentId?: string;
|
|
4
|
+
model?: string;
|
|
5
|
+
createdAt: string;
|
|
6
|
+
updatedAt: string;
|
|
7
|
+
metadata?: Record<string, unknown>;
|
|
8
|
+
}
|
|
9
|
+
export interface SessionStore {
|
|
10
|
+
entries: Record<string, SessionEntry>;
|
|
11
|
+
}
|
|
12
|
+
export declare function getSessionStorePath(stateDir: string): string;
|
|
13
|
+
export declare function loadSessionStore(stateDir: string): SessionStore;
|
|
14
|
+
export declare function saveSessionStore(stateDir: string, store: SessionStore): void;
|
|
15
|
+
export declare function getOrCreateSession(stateDir: string, sessionId: string, defaults?: Partial<SessionEntry>): Promise<SessionEntry>;
|
|
16
|
+
export declare function updateSession(stateDir: string, sessionId: string, update: Partial<SessionEntry>): Promise<void>;
|
|
17
|
+
//# sourceMappingURL=store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../src/sessions/store.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAED,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;CACvC;AAED,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAE5D;AAED,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,YAAY,CAQ/D;AAsBD,wBAAgB,gBAAgB,CAC9B,QAAQ,EAAE,MAAM,EAChB,KAAK,EAAE,YAAY,GAClB,IAAI,CAGN;AAED,wBAAsB,kBAAkB,CACtC,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,QAAQ,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAC/B,OAAO,CAAC,YAAY,CAAC,CAiBvB;AAED,wBAAsB,aAAa,CACjC,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,OAAO,CAAC,YAAY,CAAC,GAC5B,OAAO,CAAC,IAAI,CAAC,CAaf"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
import * as path from "node:path";
|
|
3
|
+
import { atomicWriteFileSync } from "../shared/index.js";
|
|
4
|
+
export function getSessionStorePath(stateDir) {
|
|
5
|
+
return path.join(stateDir, "sessions.json");
|
|
6
|
+
}
|
|
7
|
+
export function loadSessionStore(stateDir) {
|
|
8
|
+
const filePath = getSessionStorePath(stateDir);
|
|
9
|
+
try {
|
|
10
|
+
const raw = fs.readFileSync(filePath, "utf-8");
|
|
11
|
+
return JSON.parse(raw);
|
|
12
|
+
}
|
|
13
|
+
catch {
|
|
14
|
+
return { entries: {} };
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
const sessionStoreLocks = new Map();
|
|
18
|
+
async function withSessionLock(stateDir, fn) {
|
|
19
|
+
const key = path.resolve(stateDir);
|
|
20
|
+
const previous = sessionStoreLocks.get(key) ?? Promise.resolve();
|
|
21
|
+
let release;
|
|
22
|
+
const currentPromise = new Promise((r) => { release = r; });
|
|
23
|
+
sessionStoreLocks.set(key, currentPromise);
|
|
24
|
+
try {
|
|
25
|
+
await previous;
|
|
26
|
+
return fn();
|
|
27
|
+
}
|
|
28
|
+
finally {
|
|
29
|
+
release();
|
|
30
|
+
if (sessionStoreLocks.get(key) === currentPromise) {
|
|
31
|
+
sessionStoreLocks.delete(key);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
export function saveSessionStore(stateDir, store) {
|
|
36
|
+
const filePath = getSessionStorePath(stateDir);
|
|
37
|
+
atomicWriteFileSync(filePath, JSON.stringify(store, null, 2));
|
|
38
|
+
}
|
|
39
|
+
export async function getOrCreateSession(stateDir, sessionId, defaults) {
|
|
40
|
+
return withSessionLock(stateDir, () => {
|
|
41
|
+
const store = loadSessionStore(stateDir);
|
|
42
|
+
if (store.entries[sessionId]) {
|
|
43
|
+
return store.entries[sessionId];
|
|
44
|
+
}
|
|
45
|
+
const entry = {
|
|
46
|
+
id: sessionId,
|
|
47
|
+
createdAt: new Date().toISOString(),
|
|
48
|
+
updatedAt: new Date().toISOString(),
|
|
49
|
+
...defaults,
|
|
50
|
+
};
|
|
51
|
+
store.entries[sessionId] = entry;
|
|
52
|
+
saveSessionStore(stateDir, store);
|
|
53
|
+
return entry;
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
export async function updateSession(stateDir, sessionId, update) {
|
|
57
|
+
await withSessionLock(stateDir, () => {
|
|
58
|
+
const store = loadSessionStore(stateDir);
|
|
59
|
+
const existing = store.entries[sessionId];
|
|
60
|
+
if (!existing)
|
|
61
|
+
return;
|
|
62
|
+
store.entries[sessionId] = {
|
|
63
|
+
...existing,
|
|
64
|
+
...update,
|
|
65
|
+
updatedAt: new Date().toISOString(),
|
|
66
|
+
};
|
|
67
|
+
saveSessionStore(stateDir, store);
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/sessions/store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export type SessionTranscriptUpdate = {
|
|
2
|
+
sessionFile: string;
|
|
3
|
+
sessionKey?: string;
|
|
4
|
+
message?: unknown;
|
|
5
|
+
messageId?: string;
|
|
6
|
+
};
|
|
7
|
+
type SessionTranscriptListener = (update: SessionTranscriptUpdate) => void;
|
|
8
|
+
export declare function onSessionTranscriptUpdate(listener: SessionTranscriptListener): () => void;
|
|
9
|
+
export declare function emitSessionTranscriptUpdate(update: string | SessionTranscriptUpdate): void;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=transcript-events.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transcript-events.d.ts","sourceRoot":"","sources":["../../src/sessions/transcript-events.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,uBAAuB,GAAG;IACpC,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,KAAK,yBAAyB,GAAG,CAAC,MAAM,EAAE,uBAAuB,KAAK,IAAI,CAAC;AAI3E,wBAAgB,yBAAyB,CAAC,QAAQ,EAAE,yBAAyB,GAAG,MAAM,IAAI,CAKzF;AAED,wBAAgB,2BAA2B,CAAC,MAAM,EAAE,MAAM,GAAG,uBAAuB,GAAG,IAAI,CA6B1F"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
// Ported verbatim from OpenClaw src/sessions/transcript-events.ts
|
|
2
|
+
const SESSION_TRANSCRIPT_LISTENERS = new Set();
|
|
3
|
+
export function onSessionTranscriptUpdate(listener) {
|
|
4
|
+
SESSION_TRANSCRIPT_LISTENERS.add(listener);
|
|
5
|
+
return () => {
|
|
6
|
+
SESSION_TRANSCRIPT_LISTENERS.delete(listener);
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
export function emitSessionTranscriptUpdate(update) {
|
|
10
|
+
const normalized = typeof update === "string"
|
|
11
|
+
? { sessionFile: update }
|
|
12
|
+
: {
|
|
13
|
+
sessionFile: update.sessionFile,
|
|
14
|
+
sessionKey: update.sessionKey,
|
|
15
|
+
message: update.message,
|
|
16
|
+
messageId: update.messageId,
|
|
17
|
+
};
|
|
18
|
+
const trimmed = normalized.sessionFile.trim();
|
|
19
|
+
if (!trimmed)
|
|
20
|
+
return;
|
|
21
|
+
const nextUpdate = {
|
|
22
|
+
sessionFile: trimmed,
|
|
23
|
+
...(typeof normalized.sessionKey === "string" && normalized.sessionKey.trim()
|
|
24
|
+
? { sessionKey: normalized.sessionKey.trim() }
|
|
25
|
+
: {}),
|
|
26
|
+
...(normalized.message !== undefined ? { message: normalized.message } : {}),
|
|
27
|
+
...(typeof normalized.messageId === "string" && normalized.messageId.trim()
|
|
28
|
+
? { messageId: normalized.messageId.trim() }
|
|
29
|
+
: {}),
|
|
30
|
+
};
|
|
31
|
+
for (const listener of SESSION_TRANSCRIPT_LISTENERS) {
|
|
32
|
+
try {
|
|
33
|
+
listener(nextUpdate);
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
/* ignore */
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=transcript-events.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transcript-events.js","sourceRoot":"","sources":["../../src/sessions/transcript-events.ts"],"names":[],"mappings":"AAAA,kEAAkE;AAWlE,MAAM,4BAA4B,GAAG,IAAI,GAAG,EAA6B,CAAC;AAE1E,MAAM,UAAU,yBAAyB,CAAC,QAAmC;IAC3E,4BAA4B,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC3C,OAAO,GAAG,EAAE;QACV,4BAA4B,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IAChD,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,2BAA2B,CAAC,MAAwC;IAClF,MAAM,UAAU,GACd,OAAO,MAAM,KAAK,QAAQ;QACxB,CAAC,CAAC,EAAE,WAAW,EAAE,MAAM,EAAE;QACzB,CAAC,CAAC;YACE,WAAW,EAAE,MAAM,CAAC,WAAW;YAC/B,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,SAAS,EAAE,MAAM,CAAC,SAAS;SAC5B,CAAC;IACR,MAAM,OAAO,GAAG,UAAU,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;IAC9C,IAAI,CAAC,OAAO;QAAE,OAAO;IACrB,MAAM,UAAU,GAA4B;QAC1C,WAAW,EAAE,OAAO;QACpB,GAAG,CAAC,OAAO,UAAU,CAAC,UAAU,KAAK,QAAQ,IAAI,UAAU,CAAC,UAAU,CAAC,IAAI,EAAE;YAC3E,CAAC,CAAC,EAAE,UAAU,EAAE,UAAU,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE;YAC9C,CAAC,CAAC,EAAE,CAAC;QACP,GAAG,CAAC,UAAU,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5E,GAAG,CAAC,OAAO,UAAU,CAAC,SAAS,KAAK,QAAQ,IAAI,UAAU,CAAC,SAAS,CAAC,IAAI,EAAE;YACzE,CAAC,CAAC,EAAE,SAAS,EAAE,UAAU,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE;YAC5C,CAAC,CAAC,EAAE,CAAC;KACR,CAAC;IACF,KAAK,MAAM,QAAQ,IAAI,4BAA4B,EAAE,CAAC;QACpD,IAAI,CAAC;YACH,QAAQ,CAAC,UAAU,CAAC,CAAC;QACvB,CAAC;QAAC,MAAM,CAAC;YACP,YAAY;QACd,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
interface SessionManagerFactory<T> {
|
|
2
|
+
continueRecent(workspaceDir: string, sessionsDir: string): T;
|
|
3
|
+
create(workspaceDir: string, sessionsDir: string): T;
|
|
4
|
+
}
|
|
5
|
+
export declare function resolveSessionManager<T>(SessionManager: SessionManagerFactory<T>, workspaceDir: string, sessionsDir: string): T;
|
|
6
|
+
export declare function extractAssistantResponse(messages: readonly {
|
|
7
|
+
role: string;
|
|
8
|
+
}[]): string;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=agent-session.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-session.d.ts","sourceRoot":"","sources":["../../src/shared/agent-session.ts"],"names":[],"mappings":"AAEA,UAAU,qBAAqB,CAAC,CAAC;IAC/B,cAAc,CAAC,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,CAAC,CAAC;IAC7D,MAAM,CAAC,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,CAAC,CAAC;CACtD;AAED,wBAAgB,qBAAqB,CAAC,CAAC,EACrC,cAAc,EAAE,qBAAqB,CAAC,CAAC,CAAC,EACxC,YAAY,EAAE,MAAM,EACpB,WAAW,EAAE,MAAM,GAClB,CAAC,CAkBH;AAED,wBAAgB,wBAAwB,CACtC,QAAQ,EAAE,SAAS;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,EAAE,GACpC,MAAM,CAWR"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
export function resolveSessionManager(SessionManager, workspaceDir, sessionsDir) {
|
|
3
|
+
const hasExisting = (() => {
|
|
4
|
+
try {
|
|
5
|
+
return fs.readdirSync(sessionsDir).some((f) => f.endsWith(".jsonl"));
|
|
6
|
+
}
|
|
7
|
+
catch {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
})();
|
|
11
|
+
if (hasExisting) {
|
|
12
|
+
try {
|
|
13
|
+
return SessionManager.continueRecent(workspaceDir, sessionsDir);
|
|
14
|
+
}
|
|
15
|
+
catch {
|
|
16
|
+
return SessionManager.create(workspaceDir, sessionsDir);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
return SessionManager.create(workspaceDir, sessionsDir);
|
|
20
|
+
}
|
|
21
|
+
export function extractAssistantResponse(messages) {
|
|
22
|
+
for (let i = messages.length - 1; i >= 0; i--) {
|
|
23
|
+
const msg = messages[i];
|
|
24
|
+
if (msg.role === "assistant" && Array.isArray(msg.content)) {
|
|
25
|
+
return msg.content
|
|
26
|
+
.filter((block) => block.type === "text")
|
|
27
|
+
.map((block) => block.text ?? "")
|
|
28
|
+
.join("");
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
return "";
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=agent-session.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-session.js","sourceRoot":"","sources":["../../src/shared/agent-session.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAO9B,MAAM,UAAU,qBAAqB,CACnC,cAAwC,EACxC,YAAoB,EACpB,WAAmB;IAEnB,MAAM,WAAW,GAAG,CAAC,GAAG,EAAE;QACxB,IAAI,CAAC;YACH,OAAO,EAAE,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;QACvE,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC,CAAC,EAAE,CAAC;IAEL,IAAI,WAAW,EAAE,CAAC;QAChB,IAAI,CAAC;YACH,OAAO,cAAc,CAAC,cAAc,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;QAClE,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,cAAc,CAAC,MAAM,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC;IAED,OAAO,cAAc,CAAC,MAAM,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;AAC1D,CAAC;AAED,MAAM,UAAU,wBAAwB,CACtC,QAAqC;IAErC,KAAK,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QAC9C,MAAM,GAAG,GAAG,QAAQ,CAAC,CAAC,CAAwC,CAAC;QAC/D,IAAI,GAAG,CAAC,IAAI,KAAK,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC;YAC3D,OAAQ,GAAG,CAAC,OAAkD;iBAC3D,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC;iBACxC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC;iBAChC,IAAI,CAAC,EAAE,CAAC,CAAC;QACd,CAAC;IACH,CAAC;IACD,OAAO,EAAE,CAAC;AACZ,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare const DEFAULT_MODEL = "claude-sonnet-4-20250514";
|
|
2
|
+
export declare const DEFAULT_PROVIDER = "anthropic";
|
|
3
|
+
export declare const LINUX_REQUIRED_MESSAGE: string;
|
|
4
|
+
export declare function buildProviderEnvKey(provider: string): string;
|
|
5
|
+
export declare const PROTECTED_SYSTEM_ENV_KEYS: Set<string>;
|
|
6
|
+
//# sourceMappingURL=constants.d.ts.map
|