@dotsetlabs/dotclaw 1.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/.env.example +54 -0
- package/LICENSE +21 -0
- package/README.md +111 -0
- package/config-examples/groups/global/CLAUDE.md +21 -0
- package/config-examples/groups/main/CLAUDE.md +47 -0
- package/config-examples/mount-allowlist.json +25 -0
- package/config-examples/plugin-http.json +18 -0
- package/config-examples/runtime.json +30 -0
- package/config-examples/tool-budgets.json +24 -0
- package/config-examples/tool-policy.json +51 -0
- package/container/.dockerignore +6 -0
- package/container/Dockerfile +74 -0
- package/container/agent-runner/package-lock.json +92 -0
- package/container/agent-runner/package.json +20 -0
- package/container/agent-runner/src/agent-config.ts +295 -0
- package/container/agent-runner/src/container-protocol.ts +73 -0
- package/container/agent-runner/src/daemon.ts +91 -0
- package/container/agent-runner/src/index.ts +1428 -0
- package/container/agent-runner/src/ipc.ts +321 -0
- package/container/agent-runner/src/memory.ts +336 -0
- package/container/agent-runner/src/prompt-packs.ts +341 -0
- package/container/agent-runner/src/tools.ts +1720 -0
- package/container/agent-runner/tsconfig.json +19 -0
- package/container/build.sh +23 -0
- package/container/skills/agent-browser.md +159 -0
- package/dist/admin-commands.d.ts +7 -0
- package/dist/admin-commands.d.ts.map +1 -0
- package/dist/admin-commands.js +87 -0
- package/dist/admin-commands.js.map +1 -0
- package/dist/agent-context.d.ts +42 -0
- package/dist/agent-context.d.ts.map +1 -0
- package/dist/agent-context.js +92 -0
- package/dist/agent-context.js.map +1 -0
- package/dist/agent-execution.d.ts +68 -0
- package/dist/agent-execution.d.ts.map +1 -0
- package/dist/agent-execution.js +169 -0
- package/dist/agent-execution.js.map +1 -0
- package/dist/agent-semaphore.d.ts +2 -0
- package/dist/agent-semaphore.d.ts.map +1 -0
- package/dist/agent-semaphore.js +52 -0
- package/dist/agent-semaphore.js.map +1 -0
- package/dist/behavior-config.d.ts +14 -0
- package/dist/behavior-config.d.ts.map +1 -0
- package/dist/behavior-config.js +52 -0
- package/dist/behavior-config.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +626 -0
- package/dist/cli.js.map +1 -0
- package/dist/config.d.ts +31 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +38 -0
- package/dist/config.js.map +1 -0
- package/dist/container-protocol.d.ts +72 -0
- package/dist/container-protocol.d.ts.map +1 -0
- package/dist/container-protocol.js +3 -0
- package/dist/container-protocol.js.map +1 -0
- package/dist/container-runner.d.ts +59 -0
- package/dist/container-runner.d.ts.map +1 -0
- package/dist/container-runner.js +813 -0
- package/dist/container-runner.js.map +1 -0
- package/dist/cost.d.ts +9 -0
- package/dist/cost.d.ts.map +1 -0
- package/dist/cost.js +11 -0
- package/dist/cost.js.map +1 -0
- package/dist/dashboard.d.ts +58 -0
- package/dist/dashboard.d.ts.map +1 -0
- package/dist/dashboard.js +471 -0
- package/dist/dashboard.js.map +1 -0
- package/dist/db.d.ts +99 -0
- package/dist/db.d.ts.map +1 -0
- package/dist/db.js +423 -0
- package/dist/db.js.map +1 -0
- package/dist/error-messages.d.ts +17 -0
- package/dist/error-messages.d.ts.map +1 -0
- package/dist/error-messages.js +109 -0
- package/dist/error-messages.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2072 -0
- package/dist/index.js.map +1 -0
- package/dist/locks.d.ts +2 -0
- package/dist/locks.d.ts.map +1 -0
- package/dist/locks.js +26 -0
- package/dist/locks.js.map +1 -0
- package/dist/logger.d.ts +4 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +15 -0
- package/dist/logger.js.map +1 -0
- package/dist/maintenance.d.ts +13 -0
- package/dist/maintenance.d.ts.map +1 -0
- package/dist/maintenance.js +151 -0
- package/dist/maintenance.js.map +1 -0
- package/dist/memory-embeddings.d.ts +13 -0
- package/dist/memory-embeddings.d.ts.map +1 -0
- package/dist/memory-embeddings.js +126 -0
- package/dist/memory-embeddings.js.map +1 -0
- package/dist/memory-recall.d.ts +8 -0
- package/dist/memory-recall.d.ts.map +1 -0
- package/dist/memory-recall.js +127 -0
- package/dist/memory-recall.js.map +1 -0
- package/dist/memory-store.d.ts +149 -0
- package/dist/memory-store.d.ts.map +1 -0
- package/dist/memory-store.js +787 -0
- package/dist/memory-store.js.map +1 -0
- package/dist/metrics.d.ts +12 -0
- package/dist/metrics.d.ts.map +1 -0
- package/dist/metrics.js +134 -0
- package/dist/metrics.js.map +1 -0
- package/dist/model-registry.d.ts +67 -0
- package/dist/model-registry.d.ts.map +1 -0
- package/dist/model-registry.js +230 -0
- package/dist/model-registry.js.map +1 -0
- package/dist/mount-security.d.ts +37 -0
- package/dist/mount-security.d.ts.map +1 -0
- package/dist/mount-security.js +284 -0
- package/dist/mount-security.js.map +1 -0
- package/dist/paths.d.ts +80 -0
- package/dist/paths.d.ts.map +1 -0
- package/dist/paths.js +149 -0
- package/dist/paths.js.map +1 -0
- package/dist/personalization.d.ts +6 -0
- package/dist/personalization.d.ts.map +1 -0
- package/dist/personalization.js +180 -0
- package/dist/personalization.js.map +1 -0
- package/dist/progress.d.ts +15 -0
- package/dist/progress.d.ts.map +1 -0
- package/dist/progress.js +92 -0
- package/dist/progress.js.map +1 -0
- package/dist/runtime-config.d.ts +227 -0
- package/dist/runtime-config.d.ts.map +1 -0
- package/dist/runtime-config.js +297 -0
- package/dist/runtime-config.js.map +1 -0
- package/dist/task-scheduler.d.ts +9 -0
- package/dist/task-scheduler.d.ts.map +1 -0
- package/dist/task-scheduler.js +195 -0
- package/dist/task-scheduler.js.map +1 -0
- package/dist/telegram-format.d.ts +3 -0
- package/dist/telegram-format.d.ts.map +1 -0
- package/dist/telegram-format.js +200 -0
- package/dist/telegram-format.js.map +1 -0
- package/dist/tool-budgets.d.ts +16 -0
- package/dist/tool-budgets.d.ts.map +1 -0
- package/dist/tool-budgets.js +83 -0
- package/dist/tool-budgets.js.map +1 -0
- package/dist/tool-policy.d.ts +18 -0
- package/dist/tool-policy.d.ts.map +1 -0
- package/dist/tool-policy.js +84 -0
- package/dist/tool-policy.js.map +1 -0
- package/dist/trace-writer.d.ts +39 -0
- package/dist/trace-writer.d.ts.map +1 -0
- package/dist/trace-writer.js +27 -0
- package/dist/trace-writer.js.map +1 -0
- package/dist/types.d.ts +81 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/utils.d.ts +4 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +30 -0
- package/dist/utils.js.map +1 -0
- package/launchd/com.dotclaw.plist +32 -0
- package/package.json +89 -0
- package/scripts/autotune.js +53 -0
- package/scripts/bootstrap.js +348 -0
- package/scripts/configure.js +200 -0
- package/scripts/doctor.js +164 -0
- package/scripts/init.js +209 -0
- package/scripts/install.sh +219 -0
- package/systemd/dotclaw.service +22 -0
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"target": "ES2022",
|
|
4
|
+
"module": "NodeNext",
|
|
5
|
+
"moduleResolution": "NodeNext",
|
|
6
|
+
"outDir": "./dist",
|
|
7
|
+
"rootDir": "./src",
|
|
8
|
+
"strict": true,
|
|
9
|
+
"noUnusedLocals": true,
|
|
10
|
+
"noUnusedParameters": true,
|
|
11
|
+
"esModuleInterop": true,
|
|
12
|
+
"skipLibCheck": true,
|
|
13
|
+
"declaration": true,
|
|
14
|
+
"declarationMap": true,
|
|
15
|
+
"sourceMap": true
|
|
16
|
+
},
|
|
17
|
+
"include": ["src/**/*"],
|
|
18
|
+
"exclude": ["node_modules", "dist"]
|
|
19
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Build the DotClaw agent container image
|
|
3
|
+
|
|
4
|
+
set -e
|
|
5
|
+
|
|
6
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
7
|
+
cd "$SCRIPT_DIR"
|
|
8
|
+
|
|
9
|
+
IMAGE_NAME="dotclaw-agent"
|
|
10
|
+
TAG="${1:-latest}"
|
|
11
|
+
|
|
12
|
+
echo "Building DotClaw agent container image..."
|
|
13
|
+
echo "Image: ${IMAGE_NAME}:${TAG}"
|
|
14
|
+
|
|
15
|
+
# Build with Docker
|
|
16
|
+
docker build -t "${IMAGE_NAME}:${TAG}" .
|
|
17
|
+
|
|
18
|
+
echo ""
|
|
19
|
+
echo "Build complete!"
|
|
20
|
+
echo "Image: ${IMAGE_NAME}:${TAG}"
|
|
21
|
+
echo ""
|
|
22
|
+
echo "Test with:"
|
|
23
|
+
echo " echo '{\"prompt\":\"What is 2+2?\",\"groupFolder\":\"test\",\"chatJid\":\"test@g.us\",\"isMain\":false}' | docker run -i ${IMAGE_NAME}:${TAG}"
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: agent-browser
|
|
3
|
+
description: Automates browser interactions for web testing, form filling, screenshots, and data extraction. Use when the user needs to navigate websites, interact with web pages, fill forms, take screenshots, test web applications, or extract information from web pages.
|
|
4
|
+
allowed-tools: Bash(agent-browser:*)
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Browser Automation with agent-browser
|
|
8
|
+
|
|
9
|
+
## Quick start
|
|
10
|
+
|
|
11
|
+
```bash
|
|
12
|
+
agent-browser open <url> # Navigate to page
|
|
13
|
+
agent-browser snapshot -i # Get interactive elements with refs
|
|
14
|
+
agent-browser click @e1 # Click element by ref
|
|
15
|
+
agent-browser fill @e2 "text" # Fill input by ref
|
|
16
|
+
agent-browser close # Close browser
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
## Core workflow
|
|
20
|
+
|
|
21
|
+
1. Navigate: `agent-browser open <url>`
|
|
22
|
+
2. Snapshot: `agent-browser snapshot -i` (returns elements with refs like `@e1`, `@e2`)
|
|
23
|
+
3. Interact using refs from the snapshot
|
|
24
|
+
4. Re-snapshot after navigation or significant DOM changes
|
|
25
|
+
|
|
26
|
+
## Commands
|
|
27
|
+
|
|
28
|
+
### Navigation
|
|
29
|
+
|
|
30
|
+
```bash
|
|
31
|
+
agent-browser open <url> # Navigate to URL
|
|
32
|
+
agent-browser back # Go back
|
|
33
|
+
agent-browser forward # Go forward
|
|
34
|
+
agent-browser reload # Reload page
|
|
35
|
+
agent-browser close # Close browser
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
### Snapshot (page analysis)
|
|
39
|
+
|
|
40
|
+
```bash
|
|
41
|
+
agent-browser snapshot # Full accessibility tree
|
|
42
|
+
agent-browser snapshot -i # Interactive elements only (recommended)
|
|
43
|
+
agent-browser snapshot -c # Compact output
|
|
44
|
+
agent-browser snapshot -d 3 # Limit depth to 3
|
|
45
|
+
agent-browser snapshot -s "#main" # Scope to CSS selector
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
### Interactions (use @refs from snapshot)
|
|
49
|
+
|
|
50
|
+
```bash
|
|
51
|
+
agent-browser click @e1 # Click
|
|
52
|
+
agent-browser dblclick @e1 # Double-click
|
|
53
|
+
agent-browser fill @e2 "text" # Clear and type
|
|
54
|
+
agent-browser type @e2 "text" # Type without clearing
|
|
55
|
+
agent-browser press Enter # Press key
|
|
56
|
+
agent-browser hover @e1 # Hover
|
|
57
|
+
agent-browser check @e1 # Check checkbox
|
|
58
|
+
agent-browser uncheck @e1 # Uncheck checkbox
|
|
59
|
+
agent-browser select @e1 "value" # Select dropdown option
|
|
60
|
+
agent-browser scroll down 500 # Scroll page
|
|
61
|
+
agent-browser upload @e1 file.pdf # Upload files
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
### Get information
|
|
65
|
+
|
|
66
|
+
```bash
|
|
67
|
+
agent-browser get text @e1 # Get element text
|
|
68
|
+
agent-browser get html @e1 # Get innerHTML
|
|
69
|
+
agent-browser get value @e1 # Get input value
|
|
70
|
+
agent-browser get attr @e1 href # Get attribute
|
|
71
|
+
agent-browser get title # Get page title
|
|
72
|
+
agent-browser get url # Get current URL
|
|
73
|
+
agent-browser get count ".item" # Count matching elements
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### Screenshots & PDF
|
|
77
|
+
|
|
78
|
+
```bash
|
|
79
|
+
agent-browser screenshot # Save to temp directory
|
|
80
|
+
agent-browser screenshot path.png # Save to specific path
|
|
81
|
+
agent-browser screenshot --full # Full page
|
|
82
|
+
agent-browser pdf output.pdf # Save as PDF
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
### Wait
|
|
86
|
+
|
|
87
|
+
```bash
|
|
88
|
+
agent-browser wait @e1 # Wait for element
|
|
89
|
+
agent-browser wait 2000 # Wait milliseconds
|
|
90
|
+
agent-browser wait --text "Success" # Wait for text
|
|
91
|
+
agent-browser wait --url "**/dashboard" # Wait for URL pattern
|
|
92
|
+
agent-browser wait --load networkidle # Wait for network idle
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
### Semantic locators (alternative to refs)
|
|
96
|
+
|
|
97
|
+
```bash
|
|
98
|
+
agent-browser find role button click --name "Submit"
|
|
99
|
+
agent-browser find text "Sign In" click
|
|
100
|
+
agent-browser find label "Email" fill "user@test.com"
|
|
101
|
+
agent-browser find placeholder "Search" type "query"
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
### Authentication with saved state
|
|
105
|
+
|
|
106
|
+
```bash
|
|
107
|
+
# Login once
|
|
108
|
+
agent-browser open https://app.example.com/login
|
|
109
|
+
agent-browser snapshot -i
|
|
110
|
+
agent-browser fill @e1 "username"
|
|
111
|
+
agent-browser fill @e2 "password"
|
|
112
|
+
agent-browser click @e3
|
|
113
|
+
agent-browser wait --url "**/dashboard"
|
|
114
|
+
agent-browser state save auth.json
|
|
115
|
+
|
|
116
|
+
# Later: load saved state
|
|
117
|
+
agent-browser state load auth.json
|
|
118
|
+
agent-browser open https://app.example.com/dashboard
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
### Cookies & Storage
|
|
122
|
+
|
|
123
|
+
```bash
|
|
124
|
+
agent-browser cookies # Get all cookies
|
|
125
|
+
agent-browser cookies set name value # Set cookie
|
|
126
|
+
agent-browser cookies clear # Clear cookies
|
|
127
|
+
agent-browser storage local # Get localStorage
|
|
128
|
+
agent-browser storage local set k v # Set value
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
### JavaScript
|
|
132
|
+
|
|
133
|
+
```bash
|
|
134
|
+
agent-browser eval "document.title" # Run JavaScript
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
## Example: Form submission
|
|
138
|
+
|
|
139
|
+
```bash
|
|
140
|
+
agent-browser open https://example.com/form
|
|
141
|
+
agent-browser snapshot -i
|
|
142
|
+
# Output shows: textbox "Email" [ref=e1], textbox "Password" [ref=e2], button "Submit" [ref=e3]
|
|
143
|
+
|
|
144
|
+
agent-browser fill @e1 "user@example.com"
|
|
145
|
+
agent-browser fill @e2 "password123"
|
|
146
|
+
agent-browser click @e3
|
|
147
|
+
agent-browser wait --load networkidle
|
|
148
|
+
agent-browser snapshot -i # Check result
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
## Example: Data extraction
|
|
152
|
+
|
|
153
|
+
```bash
|
|
154
|
+
agent-browser open https://example.com/products
|
|
155
|
+
agent-browser snapshot -i
|
|
156
|
+
agent-browser get text @e1 # Get product title
|
|
157
|
+
agent-browser get attr @e2 href # Get link URL
|
|
158
|
+
agent-browser screenshot products.png
|
|
159
|
+
```
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-commands.d.ts","sourceRoot":"","sources":["../src/admin-commands.ts"],"names":[],"mappings":"AAAA,KAAK,aAAa,GAAG;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC;AA4DzD,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM,GAAG,aAAa,GAAG,IAAI,CA6B7F"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
function splitArgs(input) {
|
|
2
|
+
const tokens = [];
|
|
3
|
+
const regex = /"([^"]*)"|'([^']*)'|(\S+)/g;
|
|
4
|
+
let match;
|
|
5
|
+
while ((match = regex.exec(input)) !== null) {
|
|
6
|
+
tokens.push(match[1] || match[2] || match[3]);
|
|
7
|
+
}
|
|
8
|
+
return tokens;
|
|
9
|
+
}
|
|
10
|
+
function normalizeCommand(tokens) {
|
|
11
|
+
if (tokens.length === 0)
|
|
12
|
+
return null;
|
|
13
|
+
const [firstRaw, secondRaw, ...rest] = tokens;
|
|
14
|
+
const first = firstRaw.toLowerCase();
|
|
15
|
+
const second = secondRaw ? secondRaw.toLowerCase() : '';
|
|
16
|
+
if (first === 'add' && second === 'group') {
|
|
17
|
+
return { command: 'add-group', args: rest };
|
|
18
|
+
}
|
|
19
|
+
if ((first === 'remove' || first === 'delete') && second === 'group') {
|
|
20
|
+
return { command: 'remove-group', args: rest };
|
|
21
|
+
}
|
|
22
|
+
if (first === 'list' && second === 'groups') {
|
|
23
|
+
return { command: 'groups', args: rest };
|
|
24
|
+
}
|
|
25
|
+
if (first === 'set' && second === 'model') {
|
|
26
|
+
return { command: 'set-model', args: rest };
|
|
27
|
+
}
|
|
28
|
+
if (first === 'model') {
|
|
29
|
+
return { command: 'set-model', args: [secondRaw, ...rest].filter(Boolean) };
|
|
30
|
+
}
|
|
31
|
+
if (first === 'remember') {
|
|
32
|
+
return { command: 'remember', args: [secondRaw, ...rest].filter(Boolean) };
|
|
33
|
+
}
|
|
34
|
+
if (first === 'style') {
|
|
35
|
+
return { command: 'style', args: [secondRaw, ...rest].filter(Boolean) };
|
|
36
|
+
}
|
|
37
|
+
if (first === 'tools') {
|
|
38
|
+
return { command: 'tools', args: [secondRaw, ...rest].filter(Boolean) };
|
|
39
|
+
}
|
|
40
|
+
if (first === 'caution') {
|
|
41
|
+
return { command: 'caution', args: [secondRaw, ...rest].filter(Boolean) };
|
|
42
|
+
}
|
|
43
|
+
if (first === 'memory') {
|
|
44
|
+
return { command: 'memory', args: [secondRaw, ...rest].filter(Boolean) };
|
|
45
|
+
}
|
|
46
|
+
if (first === 'groups') {
|
|
47
|
+
return { command: 'groups', args: [secondRaw, ...rest].filter(Boolean) };
|
|
48
|
+
}
|
|
49
|
+
if (first === 'help') {
|
|
50
|
+
return { command: 'help', args: [] };
|
|
51
|
+
}
|
|
52
|
+
if (first === 'add-group' || first === 'remove-group' || first === 'set-model') {
|
|
53
|
+
return { command: first, args: [secondRaw, ...rest].filter(Boolean) };
|
|
54
|
+
}
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
export function parseAdminCommand(content, botUsername) {
|
|
58
|
+
const text = content.trim();
|
|
59
|
+
if (!text)
|
|
60
|
+
return null;
|
|
61
|
+
if (text.startsWith('/')) {
|
|
62
|
+
const tokens = splitArgs(text.slice(1));
|
|
63
|
+
if (tokens.length === 0)
|
|
64
|
+
return null;
|
|
65
|
+
const rawCommand = tokens[0];
|
|
66
|
+
const command = rawCommand.split('@')[0].toLowerCase();
|
|
67
|
+
const rest = tokens.slice(1);
|
|
68
|
+
if (command === 'dotclaw' || command === 'dc') {
|
|
69
|
+
return normalizeCommand(rest) || { command: 'help', args: [] };
|
|
70
|
+
}
|
|
71
|
+
if (command === 'help' || command === 'groups') {
|
|
72
|
+
return { command, args: rest };
|
|
73
|
+
}
|
|
74
|
+
return null;
|
|
75
|
+
}
|
|
76
|
+
if (botUsername) {
|
|
77
|
+
const mention = `@${botUsername.toLowerCase()}`;
|
|
78
|
+
if (text.toLowerCase().startsWith(mention)) {
|
|
79
|
+
const remainder = text.slice(mention.length).trim();
|
|
80
|
+
if (!remainder)
|
|
81
|
+
return null;
|
|
82
|
+
return normalizeCommand(splitArgs(remainder));
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=admin-commands.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-commands.js","sourceRoot":"","sources":["../src/admin-commands.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { ToolPolicy } from './tool-policy.js';
|
|
2
|
+
import { loadModelRegistry, getTokenEstimateConfig, getModelPricing, ModelCapabilities } from './model-registry.js';
|
|
3
|
+
export type AgentContext = {
|
|
4
|
+
memoryRecall: string[];
|
|
5
|
+
userProfile: string | null;
|
|
6
|
+
memoryStats: {
|
|
7
|
+
total: number;
|
|
8
|
+
user: number;
|
|
9
|
+
group: number;
|
|
10
|
+
global: number;
|
|
11
|
+
};
|
|
12
|
+
behaviorConfig: Record<string, unknown>;
|
|
13
|
+
toolPolicy: ToolPolicy;
|
|
14
|
+
toolReliability: Array<{
|
|
15
|
+
name: string;
|
|
16
|
+
success_rate: number;
|
|
17
|
+
count: number;
|
|
18
|
+
avg_duration_ms: number | null;
|
|
19
|
+
}>;
|
|
20
|
+
resolvedModel: {
|
|
21
|
+
model: string;
|
|
22
|
+
override?: {
|
|
23
|
+
context_window?: number;
|
|
24
|
+
max_output_tokens?: number;
|
|
25
|
+
temperature?: number;
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
modelRegistry: ReturnType<typeof loadModelRegistry>;
|
|
29
|
+
modelPricing: ReturnType<typeof getModelPricing>;
|
|
30
|
+
tokenEstimate: ReturnType<typeof getTokenEstimateConfig>;
|
|
31
|
+
modelCapabilities: ModelCapabilities;
|
|
32
|
+
dynamicMemoryBudget: number;
|
|
33
|
+
};
|
|
34
|
+
export declare function buildAgentContext(params: {
|
|
35
|
+
groupFolder: string;
|
|
36
|
+
userId?: string | null;
|
|
37
|
+
recallQuery: string;
|
|
38
|
+
recallMaxResults: number;
|
|
39
|
+
recallMaxTokens: number;
|
|
40
|
+
toolDeny?: string[];
|
|
41
|
+
}): Promise<AgentContext>;
|
|
42
|
+
//# sourceMappingURL=agent-context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-context.d.ts","sourceRoot":"","sources":["../src/agent-context.ts"],"names":[],"mappings":"AAGA,OAAO,EAA+C,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAG3F,OAAO,EAAgB,iBAAiB,EAAE,sBAAsB,EAAE,eAAe,EAAwB,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAGxJ,MAAM,MAAM,YAAY,GAAG;IACzB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,WAAW,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAC5E,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACxC,UAAU,EAAE,UAAU,CAAC;IACvB,eAAe,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,eAAe,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE,CAAC,CAAC;IAC9G,aAAa,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE;YAAE,cAAc,CAAC,EAAE,MAAM,CAAC;YAAC,iBAAiB,CAAC,EAAE,MAAM,CAAC;YAAC,WAAW,CAAC,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC;IAC3H,aAAa,EAAE,UAAU,CAAC,OAAO,iBAAiB,CAAC,CAAC;IACpD,YAAY,EAAE,UAAU,CAAC,OAAO,eAAe,CAAC,CAAC;IACjD,aAAa,EAAE,UAAU,CAAC,OAAO,sBAAsB,CAAC,CAAC;IACzD,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,mBAAmB,EAAE,MAAM,CAAC;CAC7B,CAAC;AA4BF,wBAAsB,iBAAiB,CAAC,MAAM,EAAE;IAC9C,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,EAAE,MAAM,CAAC;IACzB,eAAe,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;CACrB,GAAG,OAAO,CAAC,YAAY,CAAC,CAgFxB"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { buildHybridMemoryRecall } from './memory-recall.js';
|
|
2
|
+
import { buildUserProfile, getMemoryStats } from './memory-store.js';
|
|
3
|
+
import { loadPersonalizedBehaviorConfig } from './personalization.js';
|
|
4
|
+
import { getEffectiveToolPolicy, mergeToolPolicyDeny } from './tool-policy.js';
|
|
5
|
+
import { applyToolBudgets } from './tool-budgets.js';
|
|
6
|
+
import { getToolReliability } from './db.js';
|
|
7
|
+
import { resolveModel, loadModelRegistry, getTokenEstimateConfig, getModelPricing, getModelCapabilities } from './model-registry.js';
|
|
8
|
+
import { loadRuntimeConfig } from './runtime-config.js';
|
|
9
|
+
/**
|
|
10
|
+
* Calculate dynamic memory token budget based on model capabilities
|
|
11
|
+
* Reserves 15% of available context for memories (min 800, max 4000)
|
|
12
|
+
*/
|
|
13
|
+
function calculateMemoryBudget(modelCapabilities, maxOutputTokens, configuredMax) {
|
|
14
|
+
const contextWindow = modelCapabilities.context_length;
|
|
15
|
+
const outputReserve = modelCapabilities.max_completion_tokens || maxOutputTokens;
|
|
16
|
+
// Available tokens after reserving output space
|
|
17
|
+
const availableTokens = contextWindow - outputReserve;
|
|
18
|
+
// Reserve 15% for memories
|
|
19
|
+
const memoryShare = 0.15;
|
|
20
|
+
const calculatedBudget = Math.floor(availableTokens * memoryShare);
|
|
21
|
+
// Clamp between 800 and 4000, and also respect configured max
|
|
22
|
+
return Math.min(Math.max(800, Math.min(4000, calculatedBudget)), configuredMax);
|
|
23
|
+
}
|
|
24
|
+
export async function buildAgentContext(params) {
|
|
25
|
+
const runtime = loadRuntimeConfig();
|
|
26
|
+
const defaultModel = runtime.host.defaultModel;
|
|
27
|
+
const modelRegistry = loadModelRegistry(defaultModel);
|
|
28
|
+
const resolvedModel = resolveModel({
|
|
29
|
+
groupFolder: params.groupFolder,
|
|
30
|
+
userId: params.userId ?? null,
|
|
31
|
+
defaultModel
|
|
32
|
+
});
|
|
33
|
+
const tokenEstimate = getTokenEstimateConfig(resolvedModel.override);
|
|
34
|
+
const modelPricing = getModelPricing(modelRegistry, resolvedModel.model);
|
|
35
|
+
// Get model capabilities (auto-detected from OpenRouter or defaults)
|
|
36
|
+
const modelCapabilities = await getModelCapabilities(resolvedModel.model);
|
|
37
|
+
// Calculate dynamic memory budget based on model context window
|
|
38
|
+
const dynamicMemoryBudget = calculateMemoryBudget(modelCapabilities, runtime.agent.context.maxOutputTokens, params.recallMaxTokens);
|
|
39
|
+
const memoryRecall = await buildHybridMemoryRecall({
|
|
40
|
+
groupFolder: params.groupFolder,
|
|
41
|
+
userId: params.userId ?? null,
|
|
42
|
+
query: params.recallQuery,
|
|
43
|
+
maxResults: params.recallMaxResults,
|
|
44
|
+
maxTokens: dynamicMemoryBudget
|
|
45
|
+
});
|
|
46
|
+
const userProfile = buildUserProfile({
|
|
47
|
+
groupFolder: params.groupFolder,
|
|
48
|
+
userId: params.userId ?? null
|
|
49
|
+
});
|
|
50
|
+
const memoryStats = getMemoryStats({
|
|
51
|
+
groupFolder: params.groupFolder,
|
|
52
|
+
userId: params.userId ?? null
|
|
53
|
+
});
|
|
54
|
+
const behaviorConfig = loadPersonalizedBehaviorConfig({
|
|
55
|
+
groupFolder: params.groupFolder,
|
|
56
|
+
userId: params.userId ?? null
|
|
57
|
+
});
|
|
58
|
+
const baseToolPolicy = getEffectiveToolPolicy({
|
|
59
|
+
groupFolder: params.groupFolder,
|
|
60
|
+
userId: params.userId ?? null
|
|
61
|
+
});
|
|
62
|
+
const budgetedToolPolicy = applyToolBudgets({
|
|
63
|
+
groupFolder: params.groupFolder,
|
|
64
|
+
userId: params.userId ?? null,
|
|
65
|
+
toolPolicy: baseToolPolicy
|
|
66
|
+
});
|
|
67
|
+
const toolPolicy = params.toolDeny && params.toolDeny.length > 0
|
|
68
|
+
? mergeToolPolicyDeny(budgetedToolPolicy, params.toolDeny)
|
|
69
|
+
: budgetedToolPolicy;
|
|
70
|
+
const toolReliability = getToolReliability({ groupFolder: params.groupFolder, limit: 200 })
|
|
71
|
+
.map(row => ({
|
|
72
|
+
name: row.tool_name,
|
|
73
|
+
success_rate: row.total > 0 ? row.ok_count / row.total : 0,
|
|
74
|
+
count: row.total,
|
|
75
|
+
avg_duration_ms: row.avg_duration_ms
|
|
76
|
+
}));
|
|
77
|
+
return {
|
|
78
|
+
memoryRecall,
|
|
79
|
+
userProfile,
|
|
80
|
+
memoryStats,
|
|
81
|
+
behaviorConfig,
|
|
82
|
+
toolPolicy,
|
|
83
|
+
toolReliability,
|
|
84
|
+
resolvedModel,
|
|
85
|
+
modelRegistry,
|
|
86
|
+
modelPricing,
|
|
87
|
+
tokenEstimate,
|
|
88
|
+
modelCapabilities,
|
|
89
|
+
dynamicMemoryBudget
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=agent-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-context.js","sourceRoot":"","sources":["../src/agent-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACrE,OAAO,EAAE,8BAA8B,EAAE,MAAM,sBAAsB,CAAC;AACtE,OAAO,EAAE,sBAAsB,EAAE,mBAAmB,EAAc,MAAM,kBAAkB,CAAC;AAC3F,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,sBAAsB,EAAE,eAAe,EAAE,oBAAoB,EAAqB,MAAM,qBAAqB,CAAC;AACxJ,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAiBxD;;;GAGG;AACH,SAAS,qBAAqB,CAC5B,iBAAoC,EACpC,eAAuB,EACvB,aAAqB;IAErB,MAAM,aAAa,GAAG,iBAAiB,CAAC,cAAc,CAAC;IACvD,MAAM,aAAa,GAAG,iBAAiB,CAAC,qBAAqB,IAAI,eAAe,CAAC;IAEjF,gDAAgD;IAChD,MAAM,eAAe,GAAG,aAAa,GAAG,aAAa,CAAC;IAEtD,2BAA2B;IAC3B,MAAM,WAAW,GAAG,IAAI,CAAC;IACzB,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,WAAW,CAAC,CAAC;IAEnE,8DAA8D;IAC9D,OAAO,IAAI,CAAC,GAAG,CACb,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC,EAC/C,aAAa,CACd,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,MAOvC;IACC,MAAM,OAAO,GAAG,iBAAiB,EAAE,CAAC;IACpC,MAAM,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC;IAC/C,MAAM,aAAa,GAAG,iBAAiB,CAAC,YAAY,CAAC,CAAC;IACtD,MAAM,aAAa,GAAG,YAAY,CAAC;QACjC,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,IAAI;QAC7B,YAAY;KACb,CAAC,CAAC;IACH,MAAM,aAAa,GAAG,sBAAsB,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IACrE,MAAM,YAAY,GAAG,eAAe,CAAC,aAAa,EAAE,aAAa,CAAC,KAAK,CAAC,CAAC;IAEzE,qEAAqE;IACrE,MAAM,iBAAiB,GAAG,MAAM,oBAAoB,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAE1E,gEAAgE;IAChE,MAAM,mBAAmB,GAAG,qBAAqB,CAC/C,iBAAiB,EACjB,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,eAAe,EACrC,MAAM,CAAC,eAAe,CACvB,CAAC;IAEF,MAAM,YAAY,GAAG,MAAM,uBAAuB,CAAC;QACjD,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,IAAI;QAC7B,KAAK,EAAE,MAAM,CAAC,WAAW;QACzB,UAAU,EAAE,MAAM,CAAC,gBAAgB;QACnC,SAAS,EAAE,mBAAmB;KAC/B,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,gBAAgB,CAAC;QACnC,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,IAAI;KAC9B,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,cAAc,CAAC;QACjC,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,IAAI;KAC9B,CAAC,CAAC;IAEH,MAAM,cAAc,GAAG,8BAA8B,CAAC;QACpD,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,IAAI;KAC9B,CAAuC,CAAC;IAEzC,MAAM,cAAc,GAAG,sBAAsB,CAAC;QAC5C,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,IAAI;KAC9B,CAAC,CAAC;IACH,MAAM,kBAAkB,GAAG,gBAAgB,CAAC;QAC1C,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,IAAI;QAC7B,UAAU,EAAE,cAAc;KAC3B,CAAC,CAAC;IACH,MAAM,UAAU,GAAG,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;QAC9D,CAAC,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,MAAM,CAAC,QAAQ,CAAC;QAC1D,CAAC,CAAC,kBAAkB,CAAC;IAEvB,MAAM,eAAe,GAAG,kBAAkB,CAAC,EAAE,WAAW,EAAE,MAAM,CAAC,WAAW,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;SACxF,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACX,IAAI,EAAE,GAAG,CAAC,SAAS;QACnB,YAAY,EAAE,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1D,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,eAAe,EAAE,GAAG,CAAC,eAAe;KACrC,CAAC,CAAC,CAAC;IAEN,OAAO;QACL,YAAY;QACZ,WAAW;QACX,WAAW;QACX,cAAc;QACd,UAAU;QACV,eAAe;QACf,aAAa;QACb,aAAa;QACb,YAAY;QACZ,aAAa;QACb,iBAAiB;QACjB,mBAAmB;KACpB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { AgentContext } from './agent-context.js';
|
|
2
|
+
import type { ContainerOutput } from './container-protocol.js';
|
|
3
|
+
import type { RegisteredGroup } from './types.js';
|
|
4
|
+
export type TraceBase = {
|
|
5
|
+
trace_id: string;
|
|
6
|
+
timestamp: string;
|
|
7
|
+
created_at: number;
|
|
8
|
+
chat_id: string;
|
|
9
|
+
group_folder: string;
|
|
10
|
+
user_id?: string;
|
|
11
|
+
input_text: string;
|
|
12
|
+
source: string;
|
|
13
|
+
};
|
|
14
|
+
export declare class AgentExecutionError extends Error {
|
|
15
|
+
context: AgentContext;
|
|
16
|
+
constructor(message: string, context: AgentContext);
|
|
17
|
+
}
|
|
18
|
+
export declare function createTraceBase(params: {
|
|
19
|
+
chatId: string;
|
|
20
|
+
groupFolder: string;
|
|
21
|
+
userId?: string | null;
|
|
22
|
+
inputText: string;
|
|
23
|
+
source: string;
|
|
24
|
+
}): TraceBase;
|
|
25
|
+
export declare function executeAgentRun(params: {
|
|
26
|
+
group: RegisteredGroup;
|
|
27
|
+
prompt: string;
|
|
28
|
+
chatJid: string;
|
|
29
|
+
userId?: string | null;
|
|
30
|
+
userName?: string;
|
|
31
|
+
recallQuery: string;
|
|
32
|
+
recallMaxResults: number;
|
|
33
|
+
recallMaxTokens: number;
|
|
34
|
+
toolDeny?: string[];
|
|
35
|
+
sessionId?: string;
|
|
36
|
+
persistSession?: boolean;
|
|
37
|
+
onSessionUpdate?: (sessionId: string) => void;
|
|
38
|
+
useGroupLock?: boolean;
|
|
39
|
+
abortSignal?: AbortSignal;
|
|
40
|
+
isScheduledTask?: boolean;
|
|
41
|
+
isBackgroundTask?: boolean;
|
|
42
|
+
taskId?: string;
|
|
43
|
+
streaming?: {
|
|
44
|
+
enabled: boolean;
|
|
45
|
+
draftId: number;
|
|
46
|
+
minIntervalMs?: number;
|
|
47
|
+
minChars?: number;
|
|
48
|
+
};
|
|
49
|
+
availableGroups?: Array<{
|
|
50
|
+
jid: string;
|
|
51
|
+
name: string;
|
|
52
|
+
lastActivity: string;
|
|
53
|
+
isRegistered: boolean;
|
|
54
|
+
}>;
|
|
55
|
+
}): Promise<{
|
|
56
|
+
output: ContainerOutput;
|
|
57
|
+
context: AgentContext;
|
|
58
|
+
}>;
|
|
59
|
+
export declare function recordAgentTelemetry(params: {
|
|
60
|
+
traceBase: TraceBase;
|
|
61
|
+
output: ContainerOutput | null;
|
|
62
|
+
context: AgentContext;
|
|
63
|
+
metricsSource?: 'telegram' | 'scheduler';
|
|
64
|
+
toolAuditSource: 'message' | 'background' | 'scheduler' | 'heartbeat';
|
|
65
|
+
errorMessage?: string;
|
|
66
|
+
errorType?: string;
|
|
67
|
+
}): void;
|
|
68
|
+
//# sourceMappingURL=agent-execution.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-execution.d.ts","sourceRoot":"","sources":["../src/agent-execution.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAUrE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAElD,MAAM,MAAM,SAAS,GAAG;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,qBAAa,mBAAoB,SAAQ,KAAK;IAC5C,OAAO,EAAE,YAAY,CAAC;gBACV,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY;CAInD;AAGD,wBAAgB,eAAe,CAAC,MAAM,EAAE;IACtC,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;CAChB,GAAG,SAAS,CAWZ;AAkBD,wBAAsB,eAAe,CAAC,MAAM,EAAE;IAC5C,KAAK,EAAE,eAAe,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,EAAE,MAAM,CAAC;IACzB,eAAe,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,eAAe,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9C,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE;QACV,OAAO,EAAE,OAAO,CAAC;QACjB,OAAO,EAAE,MAAM,CAAC;QAChB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,eAAe,CAAC,EAAE,KAAK,CAAC;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;CACrG,GAAG,OAAO,CAAC;IAAE,MAAM,EAAE,eAAe,CAAC;IAAC,OAAO,EAAE,YAAY,CAAA;CAAE,CAAC,CA+D9D;AAED,wBAAgB,oBAAoB,CAAC,MAAM,EAAE;IAC3C,SAAS,EAAE,SAAS,CAAC;IACrB,MAAM,EAAE,eAAe,GAAG,IAAI,CAAC;IAC/B,OAAO,EAAE,YAAY,CAAC;IACtB,aAAa,CAAC,EAAE,UAAU,GAAG,WAAW,CAAC;IACzC,eAAe,EAAE,SAAS,GAAG,YAAY,GAAG,WAAW,GAAG,WAAW,CAAC;IACtE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,GAAG,IAAI,CAsEP"}
|