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,40 @@
1
+ /**
2
+ * Shell execution tool
3
+ */
4
+ import { Tool } from "./base";
5
+ import type { DockerSandbox } from "../docker_sandbox";
6
+ export declare class ExecTool extends Tool {
7
+ private timeout;
8
+ private workingDir;
9
+ private denyPatterns;
10
+ private allowPatterns;
11
+ private restrictToWorkspace;
12
+ private dockerSandbox;
13
+ constructor(opts?: {
14
+ timeout?: number;
15
+ workingDir?: string | null;
16
+ denyPatterns?: RegExp[] | null;
17
+ allowPatterns?: RegExp[] | null;
18
+ restrictToWorkspace?: boolean;
19
+ dockerSandbox?: DockerSandbox | null;
20
+ });
21
+ get name(): string;
22
+ get description(): string;
23
+ get parameters(): {
24
+ type: "object";
25
+ properties: {
26
+ command: {
27
+ type: "string";
28
+ description: string;
29
+ };
30
+ working_dir: {
31
+ type: "string";
32
+ description: string;
33
+ };
34
+ };
35
+ required: string[];
36
+ };
37
+ execute(params: Record<string, unknown>): Promise<string>;
38
+ private _guardCommand;
39
+ }
40
+ //# sourceMappingURL=shell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell.d.ts","sourceRoot":"","sources":["../../../src/agent/tools/shell.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAqBvD,qBAAa,QAAS,SAAQ,IAAI;IAChC,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,UAAU,CAAgB;IAClC,OAAO,CAAC,YAAY,CAAW;IAC/B,OAAO,CAAC,aAAa,CAAW;IAChC,OAAO,CAAC,mBAAmB,CAAU;IACrC,OAAO,CAAC,aAAa,CAAuB;gBAEhC,IAAI,GAAE;QAChB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;QAC3B,YAAY,CAAC,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;QAC/B,aAAa,CAAC,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;QAChC,mBAAmB,CAAC,EAAE,OAAO,CAAC;QAC9B,aAAa,CAAC,EAAE,aAAa,GAAG,IAAI,CAAC;KACjC;IAYN,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,IAAI,WAAW,IAAI,MAAM,CAExB;IAED,IAAI,UAAU;;;;;;;;;;;;;MAYb;IAEK,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAqD/D,OAAO,CAAC,aAAa;CAuBtB"}
@@ -0,0 +1,166 @@
1
+ "use strict";
2
+ /**
3
+ * Shell execution tool
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
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.ExecTool = void 0;
40
+ const child_process = __importStar(require("child_process"));
41
+ const base_1 = require("./base");
42
+ const DENY_PATTERNS_SANDBOX = [
43
+ /\b(format|mkfs|diskpart)\b/i,
44
+ /\bdd\s+if=/i,
45
+ />\s*\/dev\/sd/,
46
+ /\b(shutdown|reboot|poweroff)\b/i,
47
+ /:\(\)\s*\{.*\};\s*:/,
48
+ ];
49
+ const DENY_PATTERNS_HOST = [
50
+ /\brm\s+-[rf]{1,2}\b/i,
51
+ /\bdel\s+\/[fq]\b/i,
52
+ /\brmdir\s+\/s\b/i,
53
+ /\b(format|mkfs|diskpart)\b/i,
54
+ /\bdd\s+if=/i,
55
+ />\s*\/dev\/sd/,
56
+ /\b(shutdown|reboot|poweroff)\b/i,
57
+ /:\(\)\s*\{.*\};\s*:/,
58
+ ];
59
+ class ExecTool extends base_1.Tool {
60
+ timeout;
61
+ workingDir;
62
+ denyPatterns;
63
+ allowPatterns;
64
+ restrictToWorkspace;
65
+ dockerSandbox;
66
+ constructor(opts = {}) {
67
+ super();
68
+ this.timeout = opts.timeout ?? 60;
69
+ this.workingDir = opts.workingDir ?? null;
70
+ this.dockerSandbox = opts.dockerSandbox ?? null;
71
+ this.denyPatterns =
72
+ opts.denyPatterns ??
73
+ (this.dockerSandbox?.isRunning ? DENY_PATTERNS_SANDBOX : DENY_PATTERNS_HOST);
74
+ this.allowPatterns = opts.allowPatterns ?? [];
75
+ this.restrictToWorkspace = opts.restrictToWorkspace ?? false;
76
+ }
77
+ get name() {
78
+ return "exec";
79
+ }
80
+ get description() {
81
+ return "Execute a shell command and return its output. Use with caution.";
82
+ }
83
+ get parameters() {
84
+ return {
85
+ type: "object",
86
+ properties: {
87
+ command: { type: "string", description: "The shell command to execute" },
88
+ working_dir: {
89
+ type: "string",
90
+ description: "Optional working directory for the command",
91
+ },
92
+ },
93
+ required: ["command"],
94
+ };
95
+ }
96
+ async execute(params) {
97
+ const command = params["command"];
98
+ const workingDir = params["working_dir"] ?? this.workingDir ?? process.cwd();
99
+ const guardError = this._guardCommand(command, workingDir);
100
+ if (guardError)
101
+ return guardError;
102
+ if (this.dockerSandbox?.isRunning) {
103
+ try {
104
+ const [stdout, stderr, code] = await this.dockerSandbox.exec(command, workingDir, this.timeout);
105
+ const parts = [];
106
+ if (stdout)
107
+ parts.push(stdout);
108
+ if (stderr.trim())
109
+ parts.push(`STDERR:\n${stderr}`);
110
+ if (code !== 0)
111
+ parts.push(`\nExit code: ${code}`);
112
+ const result = parts.join("\n") || "(no output)";
113
+ return result.length > 10000
114
+ ? result.slice(0, 10000) + `\n... (truncated, ${result.length - 10000} more chars)`
115
+ : result;
116
+ }
117
+ catch (e) {
118
+ return `Error executing command in sandbox: ${e}`;
119
+ }
120
+ }
121
+ return new Promise((resolve) => {
122
+ const timer = setTimeout(() => {
123
+ resolve(`Error: Command timed out after ${this.timeout} seconds`);
124
+ }, this.timeout * 1000);
125
+ const proc = child_process.exec(command, { cwd: workingDir, timeout: this.timeout * 1000 }, (error, stdout, stderr) => {
126
+ clearTimeout(timer);
127
+ const parts = [];
128
+ if (stdout)
129
+ parts.push(stdout);
130
+ if (stderr?.trim())
131
+ parts.push(`STDERR:\n${stderr}`);
132
+ if (error?.code)
133
+ parts.push(`\nExit code: ${error.code}`);
134
+ const result = parts.join("\n") || "(no output)";
135
+ resolve(result.length > 10000
136
+ ? result.slice(0, 10000) + `\n... (truncated, ${result.length - 10000} more chars)`
137
+ : result);
138
+ });
139
+ proc.on("error", (e) => {
140
+ clearTimeout(timer);
141
+ resolve(`Error executing command: ${e.message}`);
142
+ });
143
+ });
144
+ }
145
+ _guardCommand(command, cwd) {
146
+ const lower = command.toLowerCase();
147
+ for (const pattern of this.denyPatterns) {
148
+ if (pattern.test(lower)) {
149
+ return "Error: Command blocked by safety guard (dangerous pattern detected)";
150
+ }
151
+ }
152
+ if (this.allowPatterns.length > 0) {
153
+ if (!this.allowPatterns.some((p) => p.test(lower))) {
154
+ return "Error: Command blocked by safety guard (not in allowlist)";
155
+ }
156
+ }
157
+ if (this.restrictToWorkspace) {
158
+ if (command.includes("../") || command.includes("..\\")) {
159
+ return "Error: Command blocked by safety guard (path traversal detected)";
160
+ }
161
+ }
162
+ return null;
163
+ }
164
+ }
165
+ exports.ExecTool = ExecTool;
166
+ //# sourceMappingURL=shell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell.js","sourceRoot":"","sources":["../../../src/agent/tools/shell.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Spawn tool
3
+ */
4
+ import { Tool } from "./base";
5
+ import type { SubagentManager } from "../subagent";
6
+ export declare class SpawnTool extends Tool {
7
+ private manager;
8
+ private originChannel;
9
+ private originChatId;
10
+ constructor(manager: SubagentManager);
11
+ setContext(channel: string, chatId: string): void;
12
+ get name(): string;
13
+ get description(): string;
14
+ get parameters(): {
15
+ type: "object";
16
+ properties: {
17
+ task: {
18
+ type: "string";
19
+ description: string;
20
+ };
21
+ label: {
22
+ type: "string";
23
+ description: string;
24
+ };
25
+ };
26
+ required: string[];
27
+ };
28
+ execute(params: Record<string, unknown>): Promise<string>;
29
+ }
30
+ //# sourceMappingURL=spawn.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spawn.d.ts","sourceRoot":"","sources":["../../../src/agent/tools/spawn.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAEnD,qBAAa,SAAU,SAAQ,IAAI;IACjC,OAAO,CAAC,OAAO,CAAkB;IACjC,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,YAAY,CAAS;gBAEjB,OAAO,EAAE,eAAe;IAOpC,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAKjD,IAAI,IAAI,IAAI,MAAM,CAAoB;IACtC,IAAI,WAAW,IAAI,MAAM,CAMxB;IACD,IAAI,UAAU;;;;;;;;;;;;;MASb;IAEK,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;CAUhE"}
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ /**
3
+ * Spawn tool
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.SpawnTool = void 0;
7
+ const base_1 = require("./base");
8
+ class SpawnTool extends base_1.Tool {
9
+ manager;
10
+ originChannel;
11
+ originChatId;
12
+ constructor(manager) {
13
+ super();
14
+ this.manager = manager;
15
+ this.originChannel = "cli";
16
+ this.originChatId = "direct";
17
+ }
18
+ setContext(channel, chatId) {
19
+ this.originChannel = channel;
20
+ this.originChatId = chatId;
21
+ }
22
+ get name() { return "spawn"; }
23
+ get description() {
24
+ return ("Spawn a subagent to handle a task in the background. " +
25
+ "Use this for complex or time-consuming tasks that can run independently. " +
26
+ "The subagent will complete the task and report back when done.");
27
+ }
28
+ get parameters() {
29
+ return {
30
+ type: "object",
31
+ properties: {
32
+ task: { type: "string", description: "The task for the subagent to complete" },
33
+ label: { type: "string", description: "Optional short label for the task (for display)" },
34
+ },
35
+ required: ["task"],
36
+ };
37
+ }
38
+ async execute(params) {
39
+ const task = params["task"];
40
+ const label = params["label"];
41
+ return this.manager.spawn({
42
+ task,
43
+ label,
44
+ originChannel: this.originChannel,
45
+ originChatId: this.originChatId,
46
+ });
47
+ }
48
+ }
49
+ exports.SpawnTool = SpawnTool;
50
+ //# sourceMappingURL=spawn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/agent/tools/spawn.ts"],"names":[],"mappings":";AAAA;;GAEG;;;AAEH,iCAA8B;AAG9B,MAAa,SAAU,SAAQ,WAAI;IACzB,OAAO,CAAkB;IACzB,aAAa,CAAS;IACtB,YAAY,CAAS;IAE7B,YAAY,OAAwB;QAClC,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;IAC/B,CAAC;IAED,UAAU,CAAC,OAAe,EAAE,MAAc;QACxC,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;QAC7B,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;IAC7B,CAAC;IAED,IAAI,IAAI,KAAa,OAAO,OAAO,CAAC,CAAC,CAAC;IACtC,IAAI,WAAW;QACb,OAAO,CACL,uDAAuD;YACvD,2EAA2E;YAC3E,gEAAgE,CACjE,CAAC;IACJ,CAAC;IACD,IAAI,UAAU;QACZ,OAAO;YACL,IAAI,EAAE,QAAiB;YACvB,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAiB,EAAE,WAAW,EAAE,uCAAuC,EAAE;gBACvF,KAAK,EAAE,EAAE,IAAI,EAAE,QAAiB,EAAE,WAAW,EAAE,iDAAiD,EAAE;aACnG;YACD,QAAQ,EAAE,CAAC,MAAM,CAAC;SACnB,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,MAA+B;QAC3C,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAW,CAAC;QACtC,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAuB,CAAC;QACpD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;YACxB,IAAI;YACJ,KAAK;YACL,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC,CAAC;IACL,CAAC;CACF;AA9CD,8BA8CC"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * Web tools
3
+ */
4
+ import { Tool } from "./base";
5
+ export declare class WebSearchTool extends Tool {
6
+ private apiKey;
7
+ private maxResults;
8
+ constructor(opts?: {
9
+ apiKey?: string | null;
10
+ maxResults?: number;
11
+ });
12
+ get name(): string;
13
+ get description(): string;
14
+ get parameters(): {
15
+ type: "object";
16
+ properties: {
17
+ query: {
18
+ type: "string";
19
+ description: string;
20
+ };
21
+ count: {
22
+ type: "integer";
23
+ description: string;
24
+ minimum: number;
25
+ maximum: number;
26
+ };
27
+ };
28
+ required: string[];
29
+ };
30
+ execute(params: Record<string, unknown>): Promise<string>;
31
+ }
32
+ export declare class WebFetchTool extends Tool {
33
+ private maxChars;
34
+ constructor(maxChars?: number);
35
+ get name(): string;
36
+ get description(): string;
37
+ get parameters(): {
38
+ type: "object";
39
+ properties: {
40
+ url: {
41
+ type: "string";
42
+ description: string;
43
+ };
44
+ extractMode: {
45
+ type: "string";
46
+ enum: string[];
47
+ description: string;
48
+ };
49
+ maxChars: {
50
+ type: "integer";
51
+ minimum: number;
52
+ };
53
+ };
54
+ required: string[];
55
+ };
56
+ execute(params: Record<string, unknown>): Promise<string>;
57
+ private _htmlToText;
58
+ }
59
+ //# sourceMappingURL=web.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"web.d.ts","sourceRoot":"","sources":["../../../src/agent/tools/web.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AA8B9B,qBAAa,aAAc,SAAQ,IAAI;IACrC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,UAAU,CAAS;gBAEf,IAAI,GAAE;QAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAA;KAAO;IAMtE,IAAI,IAAI,IAAI,MAAM,CAAyB;IAC3C,IAAI,WAAW,IAAI,MAAM,CAAkE;IAC3F,IAAI,UAAU;;;;;;;;;;;;;;;MASb;IAEK,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;CA2BhE;AAED,qBAAa,YAAa,SAAQ,IAAI;IACpC,OAAO,CAAC,QAAQ,CAAS;gBAEb,QAAQ,SAAQ;IAK5B,IAAI,IAAI,IAAI,MAAM,CAAwB;IAC1C,IAAI,WAAW,IAAI,MAAM,CAAoE;IAC7F,IAAI,UAAU;;;;;;;;;;;;;;;;;;MAUb;IAEK,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAkD/D,OAAO,CAAC,WAAW;CAYpB"}
@@ -0,0 +1,167 @@
1
+ "use strict";
2
+ /**
3
+ * Web tools
4
+ */
5
+ var __importDefault = (this && this.__importDefault) || function (mod) {
6
+ return (mod && mod.__esModule) ? mod : { "default": mod };
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.WebFetchTool = exports.WebSearchTool = void 0;
10
+ const axios_1 = __importDefault(require("axios"));
11
+ const base_1 = require("./base");
12
+ const USER_AGENT = "Mozilla/5.0 (Macintosh; Intel Mac OS X 14_7_2) AppleWebKit/537.36";
13
+ function stripTags(text) {
14
+ text = text.replace(/<script[\s\S]*?<\/script>/gi, "");
15
+ text = text.replace(/<style[\s\S]*?<\/style>/gi, "");
16
+ text = text.replace(/<[^>]+>/g, "");
17
+ return text.replace(/&amp;/g, "&").replace(/&lt;/g, "<").replace(/&gt;/g, ">").replace(/&quot;/g, '"').replace(/&#39;/g, "'").trim();
18
+ }
19
+ function normalize(text) {
20
+ text = text.replace(/[ \t]+/g, " ");
21
+ text = text.replace(/\n{3,}/g, "\n\n");
22
+ return text.trim();
23
+ }
24
+ function validateUrl(url) {
25
+ try {
26
+ const p = new URL(url);
27
+ if (!["http:", "https:"].includes(p.protocol)) {
28
+ return [false, `Only http/https allowed, got '${p.protocol}'`];
29
+ }
30
+ if (!p.hostname)
31
+ return [false, "Missing domain"];
32
+ return [true, ""];
33
+ }
34
+ catch (e) {
35
+ return [false, String(e)];
36
+ }
37
+ }
38
+ class WebSearchTool extends base_1.Tool {
39
+ apiKey;
40
+ maxResults;
41
+ constructor(opts = {}) {
42
+ super();
43
+ this.apiKey = opts.apiKey ?? process.env.BRAVE_API_KEY ?? "";
44
+ this.maxResults = opts.maxResults ?? 5;
45
+ }
46
+ get name() { return "web_search"; }
47
+ get description() { return "Search the web. Returns titles, URLs, and snippets."; }
48
+ get parameters() {
49
+ return {
50
+ type: "object",
51
+ properties: {
52
+ query: { type: "string", description: "Search query" },
53
+ count: { type: "integer", description: "Results (1-10)", minimum: 1, maximum: 10 },
54
+ },
55
+ required: ["query"],
56
+ };
57
+ }
58
+ async execute(params) {
59
+ const query = params["query"];
60
+ const count = Math.min(Math.max(params["count"] ?? this.maxResults, 1), 10);
61
+ if (!this.apiKey)
62
+ return "Error: BRAVE_API_KEY not configured";
63
+ try {
64
+ const resp = await axios_1.default.get("https://api.search.brave.com/res/v1/web/search", {
65
+ params: { q: query, count },
66
+ headers: { Accept: "application/json", "X-Subscription-Token": this.apiKey },
67
+ timeout: 10000,
68
+ });
69
+ const results = (resp.data?.web?.results ?? []);
70
+ if (!results.length)
71
+ return `No results for: ${query}`;
72
+ const lines = [`Results for: ${query}\n`];
73
+ for (let i = 0; i < Math.min(results.length, count); i++) {
74
+ const item = results[i];
75
+ lines.push(`${i + 1}. ${item["title"] ?? ""}\n ${item["url"] ?? ""}`);
76
+ if (item["description"])
77
+ lines.push(` ${item["description"]}`);
78
+ }
79
+ return lines.join("\n");
80
+ }
81
+ catch (e) {
82
+ return `Error: ${e}`;
83
+ }
84
+ }
85
+ }
86
+ exports.WebSearchTool = WebSearchTool;
87
+ class WebFetchTool extends base_1.Tool {
88
+ maxChars;
89
+ constructor(maxChars = 50000) {
90
+ super();
91
+ this.maxChars = maxChars;
92
+ }
93
+ get name() { return "web_fetch"; }
94
+ get description() { return "Fetch URL and extract readable content (HTML → text)."; }
95
+ get parameters() {
96
+ return {
97
+ type: "object",
98
+ properties: {
99
+ url: { type: "string", description: "URL to fetch" },
100
+ extractMode: { type: "string", enum: ["markdown", "text"], description: "Extraction mode" },
101
+ maxChars: { type: "integer", minimum: 100 },
102
+ },
103
+ required: ["url"],
104
+ };
105
+ }
106
+ async execute(params) {
107
+ const url = params["url"];
108
+ const maxChars = params["maxChars"] ?? this.maxChars;
109
+ const [valid, errMsg] = validateUrl(url);
110
+ if (!valid) {
111
+ return JSON.stringify({ error: `URL validation failed: ${errMsg}`, url });
112
+ }
113
+ try {
114
+ const resp = await axios_1.default.get(url, {
115
+ headers: { "User-Agent": USER_AGENT },
116
+ timeout: 30000,
117
+ maxRedirects: 5,
118
+ responseType: "text",
119
+ validateStatus: null,
120
+ });
121
+ const contentType = resp.headers["content-type"] ?? "";
122
+ let text;
123
+ let extractor;
124
+ if (contentType.includes("application/json")) {
125
+ text = JSON.stringify(resp.data, null, 2);
126
+ extractor = "json";
127
+ }
128
+ else if (contentType.includes("text/html") || resp.data.slice(0, 256).toLowerCase().startsWith("<!doctype")) {
129
+ text = this._htmlToText(resp.data);
130
+ extractor = "html-strip";
131
+ }
132
+ else {
133
+ text = resp.data;
134
+ extractor = "raw";
135
+ }
136
+ const truncated = text.length > maxChars;
137
+ if (truncated)
138
+ text = text.slice(0, maxChars);
139
+ return JSON.stringify({
140
+ url,
141
+ finalUrl: resp.request?.res?.responseUrl ?? url,
142
+ status: resp.status,
143
+ extractor,
144
+ truncated,
145
+ length: text.length,
146
+ text,
147
+ });
148
+ }
149
+ catch (e) {
150
+ return JSON.stringify({ error: String(e), url });
151
+ }
152
+ }
153
+ _htmlToText(html) {
154
+ // Simple HTML-to-text conversion
155
+ let text = html;
156
+ // Remove script and style
157
+ text = text.replace(/<script[\s\S]*?<\/script>/gi, "");
158
+ text = text.replace(/<style[\s\S]*?<\/style>/gi, "");
159
+ // Replace block elements with newlines
160
+ text = text.replace(/<\/?(p|div|section|article|h[1-6]|li|br|hr)[^>]*>/gi, "\n");
161
+ // Strip remaining tags
162
+ text = stripTags(text);
163
+ return normalize(text);
164
+ }
165
+ }
166
+ exports.WebFetchTool = WebFetchTool;
167
+ //# sourceMappingURL=web.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"web.js","sourceRoot":"","sources":["../../../src/agent/tools/web.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Event types for the message bus
3
+ */
4
+ export interface InboundMessage {
5
+ /** telegram, discord, slack, whatsapp, etc. */
6
+ channel: string;
7
+ /** User identifier */
8
+ senderId: string;
9
+ /** Chat/channel identifier */
10
+ chatId: string;
11
+ /** Message text */
12
+ content: string;
13
+ timestamp: Date;
14
+ /** Media URLs */
15
+ media: string[];
16
+ /** Channel-specific data */
17
+ metadata: Record<string, unknown>;
18
+ }
19
+ export declare function makeInboundMessage(opts: Omit<InboundMessage, "timestamp" | "media" | "metadata"> & Partial<Pick<InboundMessage, "timestamp" | "media" | "metadata">>): InboundMessage;
20
+ /** Unique key for session identification */
21
+ export declare function sessionKey(msg: InboundMessage): string;
22
+ export interface OutboundMessage {
23
+ channel: string;
24
+ chatId: string;
25
+ content: string;
26
+ replyTo?: string;
27
+ media: string[];
28
+ metadata: Record<string, unknown>;
29
+ }
30
+ export declare function makeOutboundMessage(opts: Omit<OutboundMessage, "media" | "metadata"> & Partial<Pick<OutboundMessage, "media" | "metadata">>): OutboundMessage;
31
+ //# sourceMappingURL=events.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../src/bus/events.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,cAAc;IAC7B,+CAA+C;IAC/C,OAAO,EAAE,MAAM,CAAC;IAChB,sBAAsB;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,8BAA8B;IAC9B,MAAM,EAAE,MAAM,CAAC;IACf,mBAAmB;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;IAChB,iBAAiB;IACjB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,4BAA4B;IAC5B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED,wBAAgB,kBAAkB,CAChC,IAAI,EAAE,IAAI,CAAC,cAAc,EAAE,WAAW,GAAG,OAAO,GAAG,UAAU,CAAC,GAC5D,OAAO,CAAC,IAAI,CAAC,cAAc,EAAE,WAAW,GAAG,OAAO,GAAG,UAAU,CAAC,CAAC,GAClE,cAAc,CAOhB;AAED,4CAA4C;AAC5C,wBAAgB,UAAU,CAAC,GAAG,EAAE,cAAc,GAAG,MAAM,CAEtD;AAED,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED,wBAAgB,mBAAmB,CACjC,IAAI,EAAE,IAAI,CAAC,eAAe,EAAE,OAAO,GAAG,UAAU,CAAC,GAC/C,OAAO,CAAC,IAAI,CAAC,eAAe,EAAE,OAAO,GAAG,UAAU,CAAC,CAAC,GACrD,eAAe,CAMjB"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ /**
3
+ * Event types for the message bus
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.makeInboundMessage = makeInboundMessage;
7
+ exports.sessionKey = sessionKey;
8
+ exports.makeOutboundMessage = makeOutboundMessage;
9
+ function makeInboundMessage(opts) {
10
+ return {
11
+ timestamp: new Date(),
12
+ media: [],
13
+ metadata: {},
14
+ ...opts,
15
+ };
16
+ }
17
+ /** Unique key for session identification */
18
+ function sessionKey(msg) {
19
+ return `${msg.channel}:${msg.chatId}`;
20
+ }
21
+ function makeOutboundMessage(opts) {
22
+ return {
23
+ media: [],
24
+ metadata: {},
25
+ ...opts,
26
+ };
27
+ }
28
+ //# sourceMappingURL=events.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.js","sourceRoot":"","sources":["../../src/bus/events.ts"],"names":[],"mappings":";AAAA;;GAEG;;AAkBH,gDAUC;AAGD,gCAEC;AAWD,kDASC;AAnCD,SAAgB,kBAAkB,CAChC,IACmE;IAEnE,OAAO;QACL,SAAS,EAAE,IAAI,IAAI,EAAE;QACrB,KAAK,EAAE,EAAE;QACT,QAAQ,EAAE,EAAE;QACZ,GAAG,IAAI;KACR,CAAC;AACJ,CAAC;AAED,4CAA4C;AAC5C,SAAgB,UAAU,CAAC,GAAmB;IAC5C,OAAO,GAAG,GAAG,CAAC,OAAO,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;AACxC,CAAC;AAWD,SAAgB,mBAAmB,CACjC,IACsD;IAEtD,OAAO;QACL,KAAK,EAAE,EAAE;QACT,QAAQ,EAAE,EAAE;QACZ,GAAG,IAAI;KACR,CAAC;AACJ,CAAC"}
@@ -0,0 +1,32 @@
1
+ /**
2
+ * Async message queue
3
+ */
4
+ import { InboundMessage, OutboundMessage } from "./events";
5
+ type OutboundHandler = (msg: OutboundMessage) => Promise<void>;
6
+ /**
7
+ * Async message bus that decouples chat channels from the agent core.
8
+ *
9
+ * Channels push messages to the inbound queue, and the agent processes
10
+ * them and pushes responses to the outbound queue.
11
+ */
12
+ export declare class MessageBus {
13
+ private _inbound;
14
+ private _outbound;
15
+ private _outboundSubscribers;
16
+ private _running;
17
+ publishInbound(msg: InboundMessage): Promise<void>;
18
+ consumeInbound(): Promise<InboundMessage>;
19
+ publishOutbound(msg: OutboundMessage): Promise<void>;
20
+ consumeOutbound(): Promise<OutboundMessage>;
21
+ subscribeOutbound(channel: string, callback: OutboundHandler): void;
22
+ /**
23
+ * Dispatch outbound messages to subscribed channels.
24
+ * Run this as a background task.
25
+ */
26
+ dispatchOutbound(): Promise<void>;
27
+ stop(): void;
28
+ get inboundSize(): number;
29
+ get outboundSize(): number;
30
+ }
31
+ export {};
32
+ //# sourceMappingURL=queue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../../src/bus/queue.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAG3D,KAAK,eAAe,GAAG,CAAC,GAAG,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AA6B/D;;;;;GAKG;AACH,qBAAa,UAAU;IACrB,OAAO,CAAC,QAAQ,CAAoC;IACpD,OAAO,CAAC,SAAS,CAAqC;IACtD,OAAO,CAAC,oBAAoB,CAAwC;IACpE,OAAO,CAAC,QAAQ,CAAS;IAEnB,cAAc,CAAC,GAAG,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAIlD,cAAc,IAAI,OAAO,CAAC,cAAc,CAAC;IAIzC,eAAe,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpD,eAAe,IAAI,OAAO,CAAC,eAAe,CAAC;IAIjD,iBAAiB,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,eAAe,GAAG,IAAI;IAOnE;;;OAGG;IACG,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IA2BvC,IAAI,IAAI,IAAI;IAIZ,IAAI,WAAW,IAAI,MAAM,CAExB;IAED,IAAI,YAAY,IAAI,MAAM,CAEzB;CACF"}