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.
- package/LICENSE +21 -0
- package/README.md +668 -0
- package/SECURITY.md +253 -0
- package/assets/logo.png +0 -0
- package/dist/agent/context.d.ts +37 -0
- package/dist/agent/context.d.ts.map +1 -0
- package/dist/agent/context.js +211 -0
- package/dist/agent/context.js.map +1 -0
- package/dist/agent/docker_sandbox.d.ts +41 -0
- package/dist/agent/docker_sandbox.d.ts.map +1 -0
- package/dist/agent/docker_sandbox.js +239 -0
- package/dist/agent/docker_sandbox.js.map +1 -0
- package/dist/agent/loop.d.ts +86 -0
- package/dist/agent/loop.d.ts.map +1 -0
- package/dist/agent/loop.js +858 -0
- package/dist/agent/loop.js.map +1 -0
- package/dist/agent/memory.d.ts +21 -0
- package/dist/agent/memory.d.ts.map +1 -0
- package/dist/agent/memory.js +128 -0
- package/dist/agent/memory.js.map +1 -0
- package/dist/agent/security/execution_audit.d.ts +17 -0
- package/dist/agent/security/execution_audit.d.ts.map +1 -0
- package/dist/agent/security/execution_audit.js +126 -0
- package/dist/agent/security/execution_audit.js.map +1 -0
- package/dist/agent/security/input_validation/entity.d.ts +57 -0
- package/dist/agent/security/input_validation/entity.d.ts.map +1 -0
- package/dist/agent/security/input_validation/entity.js +121 -0
- package/dist/agent/security/input_validation/entity.js.map +1 -0
- package/dist/agent/security/input_validation/index.d.ts +114 -0
- package/dist/agent/security/input_validation/index.d.ts.map +1 -0
- package/dist/agent/security/input_validation/index.js +971 -0
- package/dist/agent/security/input_validation/index.js.map +1 -0
- package/dist/agent/security/input_validation/lattice.d.ts +33 -0
- package/dist/agent/security/input_validation/lattice.d.ts.map +1 -0
- package/dist/agent/security/input_validation/lattice.js +61 -0
- package/dist/agent/security/input_validation/lattice.js.map +1 -0
- package/dist/agent/security/input_validation/program_graph.d.ts +51 -0
- package/dist/agent/security/input_validation/program_graph.d.ts.map +1 -0
- package/dist/agent/security/input_validation/program_graph.js +285 -0
- package/dist/agent/security/input_validation/program_graph.js.map +1 -0
- package/dist/agent/security/input_validation/security_policy.d.ts +29 -0
- package/dist/agent/security/input_validation/security_policy.d.ts.map +1 -0
- package/dist/agent/security/input_validation/security_policy.js +256 -0
- package/dist/agent/security/input_validation/security_policy.js.map +1 -0
- package/dist/agent/security/memory_audit.d.ts +14 -0
- package/dist/agent/security/memory_audit.d.ts.map +1 -0
- package/dist/agent/security/memory_audit.js +126 -0
- package/dist/agent/security/memory_audit.js.map +1 -0
- package/dist/agent/security/skill_audit.d.ts +15 -0
- package/dist/agent/security/skill_audit.d.ts.map +1 -0
- package/dist/agent/security/skill_audit.js +112 -0
- package/dist/agent/security/skill_audit.js.map +1 -0
- package/dist/agent/security/snapshot_and_rollback/base.d.ts +10 -0
- package/dist/agent/security/snapshot_and_rollback/base.d.ts.map +1 -0
- package/dist/agent/security/snapshot_and_rollback/base.js +10 -0
- package/dist/agent/security/snapshot_and_rollback/base.js.map +1 -0
- package/dist/agent/security/snapshot_and_rollback/docker_snapshot.d.ts +52 -0
- package/dist/agent/security/snapshot_and_rollback/docker_snapshot.d.ts.map +1 -0
- package/dist/agent/security/snapshot_and_rollback/docker_snapshot.js +358 -0
- package/dist/agent/security/snapshot_and_rollback/docker_snapshot.js.map +1 -0
- package/dist/agent/security/snapshot_and_rollback/index.d.ts +7 -0
- package/dist/agent/security/snapshot_and_rollback/index.d.ts.map +1 -0
- package/dist/agent/security/snapshot_and_rollback/index.js +450 -0
- package/dist/agent/security/snapshot_and_rollback/index.js.map +1 -0
- package/dist/agent/skills.d.ts +35 -0
- package/dist/agent/skills.d.ts.map +1 -0
- package/dist/agent/skills.js +235 -0
- package/dist/agent/skills.js.map +1 -0
- package/dist/agent/subagent.d.ts +39 -0
- package/dist/agent/subagent.d.ts.map +1 -0
- package/dist/agent/subagent.js +151 -0
- package/dist/agent/subagent.js.map +1 -0
- package/dist/agent/tools/base.d.ts +32 -0
- package/dist/agent/tools/base.d.ts.map +1 -0
- package/dist/agent/tools/base.js +91 -0
- package/dist/agent/tools/base.js.map +1 -0
- package/dist/agent/tools/cron.d.ts +46 -0
- package/dist/agent/tools/cron.d.ts.map +1 -0
- package/dist/agent/tools/cron.js +95 -0
- package/dist/agent/tools/cron.js.map +1 -0
- package/dist/agent/tools/filesystem.d.ts +102 -0
- package/dist/agent/tools/filesystem.d.ts.map +1 -0
- package/dist/agent/tools/filesystem.js +257 -0
- package/dist/agent/tools/filesystem.js.map +1 -0
- package/dist/agent/tools/message.d.ts +40 -0
- package/dist/agent/tools/message.d.ts.map +1 -0
- package/dist/agent/tools/message.js +55 -0
- package/dist/agent/tools/message.js.map +1 -0
- package/dist/agent/tools/registry.d.ts +16 -0
- package/dist/agent/tools/registry.d.ts.map +1 -0
- package/dist/agent/tools/registry.js +47 -0
- package/dist/agent/tools/registry.js.map +1 -0
- package/dist/agent/tools/shell.d.ts +40 -0
- package/dist/agent/tools/shell.d.ts.map +1 -0
- package/dist/agent/tools/shell.js +166 -0
- package/dist/agent/tools/shell.js.map +1 -0
- package/dist/agent/tools/spawn.d.ts +30 -0
- package/dist/agent/tools/spawn.d.ts.map +1 -0
- package/dist/agent/tools/spawn.js +50 -0
- package/dist/agent/tools/spawn.js.map +1 -0
- package/dist/agent/tools/web.d.ts +59 -0
- package/dist/agent/tools/web.d.ts.map +1 -0
- package/dist/agent/tools/web.js +167 -0
- package/dist/agent/tools/web.js.map +1 -0
- package/dist/bus/events.d.ts +31 -0
- package/dist/bus/events.d.ts.map +1 -0
- package/dist/bus/events.js +28 -0
- package/dist/bus/events.js.map +1 -0
- package/dist/bus/queue.d.ts +32 -0
- package/dist/bus/queue.d.ts.map +1 -0
- package/dist/bus/queue.js +104 -0
- package/dist/bus/queue.js.map +1 -0
- package/dist/channels/base.d.ts +25 -0
- package/dist/channels/base.d.ts.map +1 -0
- package/dist/channels/base.js +54 -0
- package/dist/channels/base.js.map +1 -0
- package/dist/channels/dingtalk.d.ts +31 -0
- package/dist/channels/dingtalk.d.ts.map +1 -0
- package/dist/channels/dingtalk.js +177 -0
- package/dist/channels/dingtalk.js.map +1 -0
- package/dist/channels/discord.d.ts +30 -0
- package/dist/channels/discord.d.ts.map +1 -0
- package/dist/channels/discord.js +197 -0
- package/dist/channels/discord.js.map +1 -0
- package/dist/channels/email.d.ts +41 -0
- package/dist/channels/email.d.ts.map +1 -0
- package/dist/channels/email.js +210 -0
- package/dist/channels/email.js.map +1 -0
- package/dist/channels/feishu.d.ts +32 -0
- package/dist/channels/feishu.d.ts.map +1 -0
- package/dist/channels/feishu.js +109 -0
- package/dist/channels/feishu.js.map +1 -0
- package/dist/channels/manager.d.ts +24 -0
- package/dist/channels/manager.d.ts.map +1 -0
- package/dist/channels/manager.js +205 -0
- package/dist/channels/manager.js.map +1 -0
- package/dist/channels/mochat.d.ts +38 -0
- package/dist/channels/mochat.d.ts.map +1 -0
- package/dist/channels/mochat.js +201 -0
- package/dist/channels/mochat.js.map +1 -0
- package/dist/channels/qq.d.ts +40 -0
- package/dist/channels/qq.d.ts.map +1 -0
- package/dist/channels/qq.js +280 -0
- package/dist/channels/qq.js.map +1 -0
- package/dist/channels/slack.d.ts +27 -0
- package/dist/channels/slack.d.ts.map +1 -0
- package/dist/channels/slack.js +118 -0
- package/dist/channels/slack.js.map +1 -0
- package/dist/channels/telegram.d.ts +31 -0
- package/dist/channels/telegram.d.ts.map +1 -0
- package/dist/channels/telegram.js +218 -0
- package/dist/channels/telegram.js.map +1 -0
- package/dist/channels/whatsapp.d.ts +29 -0
- package/dist/channels/whatsapp.d.ts.map +1 -0
- package/dist/channels/whatsapp.js +117 -0
- package/dist/channels/whatsapp.js.map +1 -0
- package/dist/cli/commands.d.ts +8 -0
- package/dist/cli/commands.d.ts.map +1 -0
- package/dist/cli/commands.js +537 -0
- package/dist/cli/commands.js.map +1 -0
- package/dist/config/loader.d.ts +24 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +182 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/schema.d.ts +2921 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +257 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/cron/service.d.ts +38 -0
- package/dist/cron/service.d.ts.map +1 -0
- package/dist/cron/service.js +336 -0
- package/dist/cron/service.js.map +1 -0
- package/dist/cron/types.d.ts +46 -0
- package/dist/cron/types.d.ts.map +1 -0
- package/dist/cron/types.js +6 -0
- package/dist/cron/types.js.map +1 -0
- package/dist/heartbeat/service.d.ts +26 -0
- package/dist/heartbeat/service.d.ts.map +1 -0
- package/dist/heartbeat/service.js +142 -0
- package/dist/heartbeat/service.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +14 -0
- package/dist/index.js.map +1 -0
- package/dist/providers/base.d.ts +38 -0
- package/dist/providers/base.d.ts.map +1 -0
- package/dist/providers/base.js +21 -0
- package/dist/providers/base.js.map +1 -0
- package/dist/providers/litellm_provider.d.ts +35 -0
- package/dist/providers/litellm_provider.d.ts.map +1 -0
- package/dist/providers/litellm_provider.js +205 -0
- package/dist/providers/litellm_provider.js.map +1 -0
- package/dist/providers/registry.d.ts +44 -0
- package/dist/providers/registry.d.ts.map +1 -0
- package/dist/providers/registry.js +252 -0
- package/dist/providers/registry.js.map +1 -0
- package/dist/providers/transcription.d.ts +10 -0
- package/dist/providers/transcription.d.ts.map +1 -0
- package/dist/providers/transcription.js +83 -0
- package/dist/providers/transcription.js.map +1 -0
- package/dist/session/manager.d.ts +35 -0
- package/dist/session/manager.d.ts.map +1 -0
- package/dist/session/manager.js +193 -0
- package/dist/session/manager.js.map +1 -0
- package/dist/utils/helpers.d.ts +15 -0
- package/dist/utils/helpers.d.ts.map +1 -0
- package/dist/utils/helpers.js +100 -0
- package/dist/utils/helpers.js.map +1 -0
- package/dist/utils/logger.d.ts +7 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +25 -0
- package/dist/utils/logger.js.map +1 -0
- package/package.json +58 -0
- package/templates/AGENTS.md +51 -0
- package/templates/HEARTBEAT.md +16 -0
- package/templates/SOUL.md +36 -0
- package/templates/TOOLS.md +150 -0
- package/templates/USER.md +17 -0
- 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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"}
|