seclaw-agent 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.
Files changed (219) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +668 -0
  3. package/SECURITY.md +253 -0
  4. package/assets/logo.png +0 -0
  5. package/dist/agent/context.d.ts +37 -0
  6. package/dist/agent/context.d.ts.map +1 -0
  7. package/dist/agent/context.js +211 -0
  8. package/dist/agent/context.js.map +1 -0
  9. package/dist/agent/docker_sandbox.d.ts +41 -0
  10. package/dist/agent/docker_sandbox.d.ts.map +1 -0
  11. package/dist/agent/docker_sandbox.js +239 -0
  12. package/dist/agent/docker_sandbox.js.map +1 -0
  13. package/dist/agent/loop.d.ts +86 -0
  14. package/dist/agent/loop.d.ts.map +1 -0
  15. package/dist/agent/loop.js +858 -0
  16. package/dist/agent/loop.js.map +1 -0
  17. package/dist/agent/memory.d.ts +21 -0
  18. package/dist/agent/memory.d.ts.map +1 -0
  19. package/dist/agent/memory.js +128 -0
  20. package/dist/agent/memory.js.map +1 -0
  21. package/dist/agent/security/execution_audit.d.ts +17 -0
  22. package/dist/agent/security/execution_audit.d.ts.map +1 -0
  23. package/dist/agent/security/execution_audit.js +126 -0
  24. package/dist/agent/security/execution_audit.js.map +1 -0
  25. package/dist/agent/security/input_validation/entity.d.ts +57 -0
  26. package/dist/agent/security/input_validation/entity.d.ts.map +1 -0
  27. package/dist/agent/security/input_validation/entity.js +121 -0
  28. package/dist/agent/security/input_validation/entity.js.map +1 -0
  29. package/dist/agent/security/input_validation/index.d.ts +114 -0
  30. package/dist/agent/security/input_validation/index.d.ts.map +1 -0
  31. package/dist/agent/security/input_validation/index.js +971 -0
  32. package/dist/agent/security/input_validation/index.js.map +1 -0
  33. package/dist/agent/security/input_validation/lattice.d.ts +33 -0
  34. package/dist/agent/security/input_validation/lattice.d.ts.map +1 -0
  35. package/dist/agent/security/input_validation/lattice.js +61 -0
  36. package/dist/agent/security/input_validation/lattice.js.map +1 -0
  37. package/dist/agent/security/input_validation/program_graph.d.ts +51 -0
  38. package/dist/agent/security/input_validation/program_graph.d.ts.map +1 -0
  39. package/dist/agent/security/input_validation/program_graph.js +285 -0
  40. package/dist/agent/security/input_validation/program_graph.js.map +1 -0
  41. package/dist/agent/security/input_validation/security_policy.d.ts +29 -0
  42. package/dist/agent/security/input_validation/security_policy.d.ts.map +1 -0
  43. package/dist/agent/security/input_validation/security_policy.js +256 -0
  44. package/dist/agent/security/input_validation/security_policy.js.map +1 -0
  45. package/dist/agent/security/memory_audit.d.ts +14 -0
  46. package/dist/agent/security/memory_audit.d.ts.map +1 -0
  47. package/dist/agent/security/memory_audit.js +126 -0
  48. package/dist/agent/security/memory_audit.js.map +1 -0
  49. package/dist/agent/security/skill_audit.d.ts +15 -0
  50. package/dist/agent/security/skill_audit.d.ts.map +1 -0
  51. package/dist/agent/security/skill_audit.js +112 -0
  52. package/dist/agent/security/skill_audit.js.map +1 -0
  53. package/dist/agent/security/snapshot_and_rollback/base.d.ts +10 -0
  54. package/dist/agent/security/snapshot_and_rollback/base.d.ts.map +1 -0
  55. package/dist/agent/security/snapshot_and_rollback/base.js +10 -0
  56. package/dist/agent/security/snapshot_and_rollback/base.js.map +1 -0
  57. package/dist/agent/security/snapshot_and_rollback/docker_snapshot.d.ts +52 -0
  58. package/dist/agent/security/snapshot_and_rollback/docker_snapshot.d.ts.map +1 -0
  59. package/dist/agent/security/snapshot_and_rollback/docker_snapshot.js +358 -0
  60. package/dist/agent/security/snapshot_and_rollback/docker_snapshot.js.map +1 -0
  61. package/dist/agent/security/snapshot_and_rollback/index.d.ts +7 -0
  62. package/dist/agent/security/snapshot_and_rollback/index.d.ts.map +1 -0
  63. package/dist/agent/security/snapshot_and_rollback/index.js +450 -0
  64. package/dist/agent/security/snapshot_and_rollback/index.js.map +1 -0
  65. package/dist/agent/skills.d.ts +35 -0
  66. package/dist/agent/skills.d.ts.map +1 -0
  67. package/dist/agent/skills.js +235 -0
  68. package/dist/agent/skills.js.map +1 -0
  69. package/dist/agent/subagent.d.ts +39 -0
  70. package/dist/agent/subagent.d.ts.map +1 -0
  71. package/dist/agent/subagent.js +151 -0
  72. package/dist/agent/subagent.js.map +1 -0
  73. package/dist/agent/tools/base.d.ts +32 -0
  74. package/dist/agent/tools/base.d.ts.map +1 -0
  75. package/dist/agent/tools/base.js +91 -0
  76. package/dist/agent/tools/base.js.map +1 -0
  77. package/dist/agent/tools/cron.d.ts +46 -0
  78. package/dist/agent/tools/cron.d.ts.map +1 -0
  79. package/dist/agent/tools/cron.js +95 -0
  80. package/dist/agent/tools/cron.js.map +1 -0
  81. package/dist/agent/tools/filesystem.d.ts +102 -0
  82. package/dist/agent/tools/filesystem.d.ts.map +1 -0
  83. package/dist/agent/tools/filesystem.js +257 -0
  84. package/dist/agent/tools/filesystem.js.map +1 -0
  85. package/dist/agent/tools/message.d.ts +40 -0
  86. package/dist/agent/tools/message.d.ts.map +1 -0
  87. package/dist/agent/tools/message.js +55 -0
  88. package/dist/agent/tools/message.js.map +1 -0
  89. package/dist/agent/tools/registry.d.ts +16 -0
  90. package/dist/agent/tools/registry.d.ts.map +1 -0
  91. package/dist/agent/tools/registry.js +47 -0
  92. package/dist/agent/tools/registry.js.map +1 -0
  93. package/dist/agent/tools/shell.d.ts +40 -0
  94. package/dist/agent/tools/shell.d.ts.map +1 -0
  95. package/dist/agent/tools/shell.js +166 -0
  96. package/dist/agent/tools/shell.js.map +1 -0
  97. package/dist/agent/tools/spawn.d.ts +30 -0
  98. package/dist/agent/tools/spawn.d.ts.map +1 -0
  99. package/dist/agent/tools/spawn.js +50 -0
  100. package/dist/agent/tools/spawn.js.map +1 -0
  101. package/dist/agent/tools/web.d.ts +59 -0
  102. package/dist/agent/tools/web.d.ts.map +1 -0
  103. package/dist/agent/tools/web.js +167 -0
  104. package/dist/agent/tools/web.js.map +1 -0
  105. package/dist/bus/events.d.ts +31 -0
  106. package/dist/bus/events.d.ts.map +1 -0
  107. package/dist/bus/events.js +28 -0
  108. package/dist/bus/events.js.map +1 -0
  109. package/dist/bus/queue.d.ts +32 -0
  110. package/dist/bus/queue.d.ts.map +1 -0
  111. package/dist/bus/queue.js +104 -0
  112. package/dist/bus/queue.js.map +1 -0
  113. package/dist/channels/base.d.ts +25 -0
  114. package/dist/channels/base.d.ts.map +1 -0
  115. package/dist/channels/base.js +54 -0
  116. package/dist/channels/base.js.map +1 -0
  117. package/dist/channels/dingtalk.d.ts +31 -0
  118. package/dist/channels/dingtalk.d.ts.map +1 -0
  119. package/dist/channels/dingtalk.js +177 -0
  120. package/dist/channels/dingtalk.js.map +1 -0
  121. package/dist/channels/discord.d.ts +30 -0
  122. package/dist/channels/discord.d.ts.map +1 -0
  123. package/dist/channels/discord.js +197 -0
  124. package/dist/channels/discord.js.map +1 -0
  125. package/dist/channels/email.d.ts +41 -0
  126. package/dist/channels/email.d.ts.map +1 -0
  127. package/dist/channels/email.js +210 -0
  128. package/dist/channels/email.js.map +1 -0
  129. package/dist/channels/feishu.d.ts +32 -0
  130. package/dist/channels/feishu.d.ts.map +1 -0
  131. package/dist/channels/feishu.js +109 -0
  132. package/dist/channels/feishu.js.map +1 -0
  133. package/dist/channels/manager.d.ts +24 -0
  134. package/dist/channels/manager.d.ts.map +1 -0
  135. package/dist/channels/manager.js +205 -0
  136. package/dist/channels/manager.js.map +1 -0
  137. package/dist/channels/mochat.d.ts +38 -0
  138. package/dist/channels/mochat.d.ts.map +1 -0
  139. package/dist/channels/mochat.js +201 -0
  140. package/dist/channels/mochat.js.map +1 -0
  141. package/dist/channels/qq.d.ts +40 -0
  142. package/dist/channels/qq.d.ts.map +1 -0
  143. package/dist/channels/qq.js +280 -0
  144. package/dist/channels/qq.js.map +1 -0
  145. package/dist/channels/slack.d.ts +27 -0
  146. package/dist/channels/slack.d.ts.map +1 -0
  147. package/dist/channels/slack.js +118 -0
  148. package/dist/channels/slack.js.map +1 -0
  149. package/dist/channels/telegram.d.ts +31 -0
  150. package/dist/channels/telegram.d.ts.map +1 -0
  151. package/dist/channels/telegram.js +218 -0
  152. package/dist/channels/telegram.js.map +1 -0
  153. package/dist/channels/whatsapp.d.ts +29 -0
  154. package/dist/channels/whatsapp.d.ts.map +1 -0
  155. package/dist/channels/whatsapp.js +117 -0
  156. package/dist/channels/whatsapp.js.map +1 -0
  157. package/dist/cli/commands.d.ts +8 -0
  158. package/dist/cli/commands.d.ts.map +1 -0
  159. package/dist/cli/commands.js +537 -0
  160. package/dist/cli/commands.js.map +1 -0
  161. package/dist/config/loader.d.ts +24 -0
  162. package/dist/config/loader.d.ts.map +1 -0
  163. package/dist/config/loader.js +182 -0
  164. package/dist/config/loader.js.map +1 -0
  165. package/dist/config/schema.d.ts +2921 -0
  166. package/dist/config/schema.d.ts.map +1 -0
  167. package/dist/config/schema.js +257 -0
  168. package/dist/config/schema.js.map +1 -0
  169. package/dist/cron/service.d.ts +38 -0
  170. package/dist/cron/service.d.ts.map +1 -0
  171. package/dist/cron/service.js +336 -0
  172. package/dist/cron/service.js.map +1 -0
  173. package/dist/cron/types.d.ts +46 -0
  174. package/dist/cron/types.d.ts.map +1 -0
  175. package/dist/cron/types.js +6 -0
  176. package/dist/cron/types.js.map +1 -0
  177. package/dist/heartbeat/service.d.ts +26 -0
  178. package/dist/heartbeat/service.d.ts.map +1 -0
  179. package/dist/heartbeat/service.js +142 -0
  180. package/dist/heartbeat/service.js.map +1 -0
  181. package/dist/index.d.ts +7 -0
  182. package/dist/index.d.ts.map +1 -0
  183. package/dist/index.js +14 -0
  184. package/dist/index.js.map +1 -0
  185. package/dist/providers/base.d.ts +38 -0
  186. package/dist/providers/base.d.ts.map +1 -0
  187. package/dist/providers/base.js +21 -0
  188. package/dist/providers/base.js.map +1 -0
  189. package/dist/providers/litellm_provider.d.ts +35 -0
  190. package/dist/providers/litellm_provider.d.ts.map +1 -0
  191. package/dist/providers/litellm_provider.js +205 -0
  192. package/dist/providers/litellm_provider.js.map +1 -0
  193. package/dist/providers/registry.d.ts +44 -0
  194. package/dist/providers/registry.d.ts.map +1 -0
  195. package/dist/providers/registry.js +252 -0
  196. package/dist/providers/registry.js.map +1 -0
  197. package/dist/providers/transcription.d.ts +10 -0
  198. package/dist/providers/transcription.d.ts.map +1 -0
  199. package/dist/providers/transcription.js +83 -0
  200. package/dist/providers/transcription.js.map +1 -0
  201. package/dist/session/manager.d.ts +35 -0
  202. package/dist/session/manager.d.ts.map +1 -0
  203. package/dist/session/manager.js +193 -0
  204. package/dist/session/manager.js.map +1 -0
  205. package/dist/utils/helpers.d.ts +15 -0
  206. package/dist/utils/helpers.d.ts.map +1 -0
  207. package/dist/utils/helpers.js +100 -0
  208. package/dist/utils/helpers.js.map +1 -0
  209. package/dist/utils/logger.d.ts +7 -0
  210. package/dist/utils/logger.d.ts.map +1 -0
  211. package/dist/utils/logger.js +25 -0
  212. package/dist/utils/logger.js.map +1 -0
  213. package/package.json +58 -0
  214. package/templates/AGENTS.md +51 -0
  215. package/templates/HEARTBEAT.md +16 -0
  216. package/templates/SOUL.md +36 -0
  217. package/templates/TOOLS.md +150 -0
  218. package/templates/USER.md +17 -0
  219. package/templates/memory/MEMORY.md +23 -0
@@ -0,0 +1,239 @@
1
+ "use strict";
2
+ /**
3
+ * Docker sandbox
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ var __importDefault = (this && this.__importDefault) || function (mod) {
39
+ return (mod && mod.__esModule) ? mod : { "default": mod };
40
+ };
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.DockerSandbox = void 0;
43
+ const child_process_1 = require("child_process");
44
+ const child_process_2 = require("child_process");
45
+ const path = __importStar(require("path"));
46
+ const uuid_1 = require("uuid");
47
+ const logger_1 = __importDefault(require("../utils/logger"));
48
+ class DockerSandbox {
49
+ image;
50
+ containerName;
51
+ workspaceHost;
52
+ workspaceContainer;
53
+ workspaceReadOnly;
54
+ extraMounts;
55
+ extraEnv;
56
+ memoryLimit;
57
+ network;
58
+ snapshotEnabled;
59
+ snapshotMax;
60
+ containerId = null;
61
+ constructor(opts = {}) {
62
+ this.image = opts.image ?? "ubuntu:22.04";
63
+ this.containerName = opts.containerName ?? `seclaw-${(0, uuid_1.v4)().replace(/-/g, "").slice(0, 8)}`;
64
+ this.workspaceHost = opts.workspaceHost;
65
+ this.workspaceContainer = opts.workspaceContainer ?? "/workspace";
66
+ this.workspaceReadOnly = opts.workspaceReadOnly ?? true;
67
+ this.extraMounts = opts.extraMounts ?? [];
68
+ this.extraEnv = opts.extraEnv ?? {};
69
+ this.memoryLimit = opts.memoryLimit;
70
+ this.network = opts.network ?? "bridge";
71
+ this.snapshotEnabled = opts.snapshotEnabled ?? true;
72
+ this.snapshotMax = opts.snapshotMax ?? 10;
73
+ }
74
+ get isRunning() {
75
+ return this.containerId !== null;
76
+ }
77
+ start() {
78
+ const inspect = (0, child_process_1.spawnSync)("docker", ["inspect", "--format", "{{.State.Status}}", this.containerName], { encoding: "utf-8" });
79
+ if (inspect.status === 0) {
80
+ const status = inspect.stdout.trim();
81
+ if (status === "running") {
82
+ const idRes = (0, child_process_1.spawnSync)("docker", ["inspect", "--format", "{{.Id}}", this.containerName], { encoding: "utf-8" });
83
+ this.containerId = idRes.stdout.trim();
84
+ logger_1.default.info(`Docker sandbox reused (already running): ${this.containerName} (${this.containerId.slice(0, 12)})`);
85
+ return;
86
+ }
87
+ else {
88
+ const restart = (0, child_process_1.spawnSync)("docker", ["start", this.containerName], { encoding: "utf-8" });
89
+ if (restart.status === 0) {
90
+ const idRes = (0, child_process_1.spawnSync)("docker", ["inspect", "--format", "{{.Id}}", this.containerName], { encoding: "utf-8" });
91
+ this.containerId = idRes.stdout.trim();
92
+ logger_1.default.info(`Docker sandbox restarted: ${this.containerName} (${this.containerId.slice(0, 12)})`);
93
+ return;
94
+ }
95
+ (0, child_process_1.spawnSync)("docker", ["rm", "-f", this.containerName], { encoding: "utf-8" });
96
+ }
97
+ }
98
+ const cmd = ["run", "-d", "--name", this.containerName, "--network", this.network];
99
+ if (this.workspaceHost) {
100
+ const resolved = path.resolve(this.workspaceHost);
101
+ const mode = this.workspaceReadOnly ? "ro" : "rw";
102
+ cmd.push("-v", `${resolved}:${this.workspaceContainer}:${mode}`);
103
+ }
104
+ for (const mount of this.extraMounts)
105
+ cmd.push("-v", mount);
106
+ for (const [k, v] of Object.entries(this.extraEnv))
107
+ cmd.push("-e", `${k}=${v}`);
108
+ if (this.memoryLimit)
109
+ cmd.push("-m", this.memoryLimit);
110
+ cmd.push(this.image, "sleep", "infinity");
111
+ const result = (0, child_process_1.spawnSync)("docker", cmd, { encoding: "utf-8" });
112
+ if (result.status !== 0) {
113
+ throw new Error(`Failed to start Docker sandbox '${this.containerName}': ${result.stderr?.trim()}`);
114
+ }
115
+ this.containerId = result.stdout.trim();
116
+ logger_1.default.info(`Docker sandbox created: ${this.containerName} (${this.containerId.slice(0, 12)})`);
117
+ }
118
+ stop() {
119
+ if (!this.containerId)
120
+ return;
121
+ (0, child_process_1.spawnSync)("docker", ["stop", this.containerName], { encoding: "utf-8" });
122
+ logger_1.default.info(`Docker sandbox stopped (preserved): ${this.containerName}`);
123
+ this.containerId = null;
124
+ }
125
+ destroy() {
126
+ (0, child_process_1.spawnSync)("docker", ["rm", "-f", this.containerName], { encoding: "utf-8" });
127
+ logger_1.default.info(`Docker sandbox destroyed: ${this.containerName}`);
128
+ this.containerId = null;
129
+ }
130
+ buildRunCmd(imageOverride) {
131
+ const image = imageOverride ?? this.image;
132
+ const cmd = ["docker", "run", "-d", "--name", this.containerName, "--network", this.network];
133
+ if (this.workspaceHost) {
134
+ const resolved = path.resolve(this.workspaceHost);
135
+ const mode = this.workspaceReadOnly ? "ro" : "rw";
136
+ cmd.push("-v", `${resolved}:${this.workspaceContainer}:${mode}`);
137
+ }
138
+ for (const mount of this.extraMounts)
139
+ cmd.push("-v", mount);
140
+ for (const [k, v] of Object.entries(this.extraEnv))
141
+ cmd.push("-e", `${k}=${v}`);
142
+ if (this.memoryLimit)
143
+ cmd.push("-m", this.memoryLimit);
144
+ cmd.push(image, "sleep", "infinity");
145
+ return cmd;
146
+ }
147
+ async exec(command, workingDir, timeout = 60) {
148
+ if (!this.containerId)
149
+ throw new Error("Docker sandbox is not running");
150
+ const wdContainer = workingDir ? this.hostToContainer(workingDir) : this.workspaceContainer;
151
+ const dockerCmd = ["docker", "exec", "-w", wdContainer, this.containerName, "sh", "-c", command];
152
+ return new Promise((resolve) => {
153
+ const child = (0, child_process_2.spawn)(dockerCmd[0], dockerCmd.slice(1), { stdio: ["ignore", "pipe", "pipe"] });
154
+ let stdout = "";
155
+ let stderr = "";
156
+ child.stdout.on("data", (d) => (stdout += d.toString("utf-8")));
157
+ child.stderr.on("data", (d) => (stderr += d.toString("utf-8")));
158
+ const timer = setTimeout(() => {
159
+ child.kill();
160
+ resolve(["", `Command timed out after ${timeout}s`, 1]);
161
+ }, timeout * 1000);
162
+ child.on("close", (code) => {
163
+ clearTimeout(timer);
164
+ resolve([stdout, stderr, code ?? 0]);
165
+ });
166
+ });
167
+ }
168
+ async execWithStdin(command, stdinData, workingDir, timeout = 60) {
169
+ if (!this.containerId)
170
+ throw new Error("Docker sandbox is not running");
171
+ const wdContainer = workingDir ? this.hostToContainer(workingDir) : this.workspaceContainer;
172
+ const dockerCmd = ["docker", "exec", "-i", "-w", wdContainer, this.containerName, "sh", "-c", command];
173
+ return new Promise((resolve) => {
174
+ const child = (0, child_process_2.spawn)(dockerCmd[0], dockerCmd.slice(1), { stdio: ["pipe", "pipe", "pipe"] });
175
+ let stdout = "";
176
+ let stderr = "";
177
+ child.stdout.on("data", (d) => (stdout += d.toString("utf-8")));
178
+ child.stderr.on("data", (d) => (stderr += d.toString("utf-8")));
179
+ const timer = setTimeout(() => {
180
+ child.kill();
181
+ resolve(["", `Command timed out after ${timeout}s`, 1]);
182
+ }, timeout * 1000);
183
+ child.on("close", (code) => {
184
+ clearTimeout(timer);
185
+ resolve([stdout, stderr, code ?? 0]);
186
+ });
187
+ child.stdin.write(stdinData);
188
+ child.stdin.end();
189
+ });
190
+ }
191
+ hostToContainer(hostPath) {
192
+ let resolved;
193
+ try {
194
+ resolved = path.resolve(hostPath.replace(/^~/, process.env["HOME"] ?? "~"));
195
+ }
196
+ catch {
197
+ return hostPath;
198
+ }
199
+ if (this.workspaceHost) {
200
+ const hostWs = path.resolve(this.workspaceHost);
201
+ if (resolved === hostWs)
202
+ return this.workspaceContainer;
203
+ if (resolved.startsWith(hostWs + path.sep) || resolved.startsWith(hostWs + "/")) {
204
+ return this.workspaceContainer + resolved.slice(hostWs.length);
205
+ }
206
+ }
207
+ for (const mount of this.extraMounts) {
208
+ const parts = mount.split(":");
209
+ if (parts.length < 2)
210
+ continue;
211
+ let mntHost;
212
+ try {
213
+ mntHost = path.resolve(parts[0].replace(/^~/, process.env["HOME"] ?? "~"));
214
+ }
215
+ catch {
216
+ continue;
217
+ }
218
+ const mntContainer = parts[1];
219
+ if (resolved === mntHost)
220
+ return mntContainer;
221
+ if (resolved.startsWith(mntHost + "/"))
222
+ return mntContainer + resolved.slice(mntHost.length);
223
+ }
224
+ return hostPath;
225
+ }
226
+ containerToHost(containerPath) {
227
+ if (!this.workspaceHost)
228
+ return containerPath;
229
+ const wc = this.workspaceContainer;
230
+ const hostWs = path.resolve(this.workspaceHost);
231
+ if (containerPath === wc)
232
+ return hostWs;
233
+ if (containerPath.startsWith(wc + "/"))
234
+ return hostWs + containerPath.slice(wc.length);
235
+ return containerPath;
236
+ }
237
+ }
238
+ exports.DockerSandbox = DockerSandbox;
239
+ //# sourceMappingURL=docker_sandbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"docker_sandbox.js","sourceRoot":"","sources":["../../src/agent/docker_sandbox.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,86 @@
1
+ /**
2
+ * Agent loop - TypeScript port of seclaw/agent/loop.py
3
+ */
4
+ import { MessageBus } from "../bus/queue";
5
+ import { InboundMessage, OutboundMessage } from "../bus/events";
6
+ import type { LLMProvider } from "../providers/base";
7
+ import { SessionManager } from "../session/manager";
8
+ import type { DockerSandbox } from "./docker_sandbox";
9
+ import type { CronService } from "../cron/service";
10
+ export interface ExecToolConfig {
11
+ timeout?: number;
12
+ }
13
+ export interface SecurityConfig {
14
+ inputValidationEnabled?: boolean;
15
+ outputValidationEnabled?: boolean;
16
+ postExecutionAuditEnabled?: boolean;
17
+ executionLogEnabled?: boolean;
18
+ executionLogStep?: number;
19
+ prohibitedCommands?: string[];
20
+ dockerSandbox?: {
21
+ snapshotMinIntervalSeconds?: number;
22
+ };
23
+ }
24
+ export interface AgentLoopOptions {
25
+ bus: MessageBus;
26
+ provider: LLMProvider;
27
+ workspace: string;
28
+ model?: string;
29
+ maxIterations?: number;
30
+ temperature?: number;
31
+ maxTokens?: number;
32
+ memoryWindow?: number;
33
+ braveApiKey?: string;
34
+ execConfig?: ExecToolConfig;
35
+ cronService?: CronService | null;
36
+ restrictToWorkspace?: boolean;
37
+ sessionManager?: SessionManager;
38
+ dockerSandbox?: DockerSandbox | null;
39
+ securityConfig?: SecurityConfig;
40
+ onReady?: () => void;
41
+ }
42
+ export declare class AgentLoop {
43
+ private bus;
44
+ private provider;
45
+ private workspace;
46
+ private model;
47
+ private maxIterations;
48
+ private temperature;
49
+ private maxTokens;
50
+ private memoryWindow;
51
+ private braveApiKey?;
52
+ private execConfig;
53
+ private cronService?;
54
+ private restrictToWorkspace;
55
+ private dockerSandbox?;
56
+ private securityConfig;
57
+ private onReady?;
58
+ private readySignaled;
59
+ private readyPromise;
60
+ private resolveReady;
61
+ private context;
62
+ private sessions;
63
+ private tools;
64
+ private subagents;
65
+ private running;
66
+ private security;
67
+ private dockerSnapshot;
68
+ constructor(opts: AgentLoopOptions);
69
+ private _registerDefaultTools;
70
+ private _setToolContext;
71
+ run(): Promise<void>;
72
+ stop(): void;
73
+ private _signalReady;
74
+ waitUntilReady(timeoutMs?: number): Promise<void>;
75
+ private _secondsSinceLastUserMessage;
76
+ private _isToolOutputSummary;
77
+ private _llmSummarizeToolOutput;
78
+ private _appendToolResultWithIncrementalCompression;
79
+ private _takeSnapshotIfEnabled;
80
+ private _buildConfirmationMessage;
81
+ _processMessage(msg: InboundMessage, sessionKeyOverride?: string): Promise<OutboundMessage | null>;
82
+ private _processSystemMessage;
83
+ private _consolidateMemory;
84
+ processDirect(content: string, sessionKey?: string, channel?: string, chatId?: string): Promise<string>;
85
+ }
86
+ //# sourceMappingURL=loop.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loop.d.ts","sourceRoot":"","sources":["../../src/agent/loop.ts"],"names":[],"mappings":"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"}