@elizaos/plugin-agent-orchestrator 0.4.3 → 0.6.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/README.md +76 -35
- package/dist/actions/coding-task-handlers.d.ts.map +1 -1
- package/dist/actions/coding-task-helpers.d.ts +10 -0
- package/dist/actions/coding-task-helpers.d.ts.map +1 -1
- package/dist/actions/list-agents.d.ts +5 -3
- package/dist/actions/list-agents.d.ts.map +1 -1
- package/dist/actions/send-to-agent.d.ts +2 -1
- package/dist/actions/send-to-agent.d.ts.map +1 -1
- package/dist/actions/spawn-agent.d.ts +3 -2
- package/dist/actions/spawn-agent.d.ts.map +1 -1
- package/dist/actions/start-coding-task.d.ts +5 -4
- package/dist/actions/start-coding-task.d.ts.map +1 -1
- package/dist/actions/stop-agent.d.ts +2 -1
- package/dist/actions/stop-agent.d.ts.map +1 -1
- package/dist/api/agent-routes.d.ts +3 -3
- package/dist/api/agent-routes.d.ts.map +1 -1
- package/dist/api/coordinator-routes.d.ts.map +1 -1
- package/dist/api/routes.d.ts +3 -2
- package/dist/api/routes.d.ts.map +1 -1
- package/dist/index.d.ts +11 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7273 -2524
- package/dist/index.js.map +67 -33
- package/dist/providers/action-examples.d.ts +3 -2
- package/dist/providers/action-examples.d.ts.map +1 -1
- package/dist/providers/active-workspace-context.d.ts +5 -5
- package/dist/providers/active-workspace-context.d.ts.map +1 -1
- package/dist/services/config-env.d.ts +2 -0
- package/dist/services/config-env.d.ts.map +1 -1
- package/dist/services/pty-auto-response.d.ts.map +1 -1
- package/dist/services/pty-init.d.ts +4 -0
- package/dist/services/pty-init.d.ts.map +1 -1
- package/dist/services/pty-service.d.ts +16 -1
- package/dist/services/pty-service.d.ts.map +1 -1
- package/dist/services/pty-spawn.d.ts +1 -0
- package/dist/services/pty-spawn.d.ts.map +1 -1
- package/dist/services/pty-types.d.ts +4 -4
- package/dist/services/pty-types.d.ts.map +1 -1
- package/dist/services/stall-classifier.d.ts +1 -1
- package/dist/services/swarm-coordinator.d.ts +31 -4
- package/dist/services/swarm-coordinator.d.ts.map +1 -1
- package/dist/services/swarm-decision-loop.d.ts.map +1 -1
- package/dist/services/swarm-idle-watchdog.d.ts.map +1 -1
- package/dist/services/task-acceptance.d.ts +8 -0
- package/dist/services/task-acceptance.d.ts.map +1 -0
- package/dist/services/task-agent-frameworks.d.ts +52 -0
- package/dist/services/task-agent-frameworks.d.ts.map +1 -0
- package/dist/services/task-policy.d.ts +17 -0
- package/dist/services/task-policy.d.ts.map +1 -0
- package/dist/services/task-registry.d.ts +261 -0
- package/dist/services/task-registry.d.ts.map +1 -0
- package/dist/services/task-validation.d.ts +26 -0
- package/dist/services/task-validation.d.ts.map +1 -0
- package/dist/services/trajectory-context.d.ts +1 -1
- package/dist/services/trajectory-context.d.ts.map +1 -1
- package/package.json +8 -4
package/README.md
CHANGED
|
@@ -1,30 +1,37 @@
|
|
|
1
1
|
# @elizaos/plugin-agent-orchestrator
|
|
2
2
|
|
|
3
|
-
Orchestrate CLI
|
|
3
|
+
Orchestrate CLI task agents (Claude Code, Codex, Gemini CLI, Aider, Pi) via PTY sessions and git workspaces for open-ended background work.
|
|
4
4
|
|
|
5
|
-
Built for [Milady](https://github.com/milady-ai/milady). The plugin registers
|
|
5
|
+
Built for [Milady](https://github.com/milady-ai/milady). The plugin registers elizaOS-compatible actions and services so any Eliza agent can delegate substantial work to sub-agents while continuing the user conversation. The full experience, including live xterm views, PTY output streaming, and swarm monitoring, is available through the Milady frontend and server.
|
|
6
6
|
|
|
7
7
|
## Features
|
|
8
8
|
|
|
9
|
-
- **
|
|
10
|
-
- **
|
|
11
|
-
- **
|
|
12
|
-
- **
|
|
9
|
+
- **Open-ended task delegation**: Use task agents for anything beyond a simple reply, including coding, research, drafting, debugging, repo work, and multi-step execution
|
|
10
|
+
- **PTY session management**: Spawn, control, and monitor task agents running in pseudo-terminals
|
|
11
|
+
- **Current task status**: Surface active sessions, coordinator task state, and pending confirmations so the main agent can keep the user updated
|
|
12
|
+
- **Subscription-aware framework preference**: Prefer Claude Code or Codex when Milady knows the user is logged in with Anthropic or OpenAI-backed subscriptions
|
|
13
|
+
- **Git workspace provisioning**: Clone repos, create worktrees, manage branches, commits, pushes, and pull requests
|
|
14
|
+
- **Multi-agent support**: Claude Code, Codex, Gemini CLI, Aider, Pi, or generic shell flows through the same orchestration surface
|
|
13
15
|
|
|
14
16
|
## Prerequisites
|
|
15
17
|
|
|
16
|
-
This plugin spawns CLI
|
|
18
|
+
This plugin spawns CLI task agents in PTY sessions. You need at least one supported framework installed locally:
|
|
17
19
|
|
|
18
|
-
|
|
|
19
|
-
|
|
20
|
+
| Framework | Install | Docs |
|
|
21
|
+
|-----------|---------|------|
|
|
20
22
|
| **Claude Code** | `npm install -g @anthropic-ai/claude-code` | [claude.ai/claude-code](https://claude.ai/claude-code) |
|
|
21
23
|
| **Codex** | `npm install -g @openai/codex` | [github.com/openai/codex](https://github.com/openai/codex) |
|
|
22
24
|
| **Gemini CLI** | `npm install -g @google/gemini-cli` | [github.com/google-gemini/gemini-cli](https://github.com/google-gemini/gemini-cli) |
|
|
23
25
|
| **Aider** | `pip install aider-chat` | [aider.chat](https://aider.chat) |
|
|
26
|
+
| **Pi** | install the `pi` CLI available on your host | provider-specific |
|
|
24
27
|
|
|
25
|
-
Each
|
|
28
|
+
Each framework also needs its own auth. API keys still work, but the orchestrator can also detect subscription-backed CLI logins:
|
|
26
29
|
|
|
27
|
-
|
|
30
|
+
- `ANTHROPIC_API_KEY` or a Claude Code subscription login for Claude Code
|
|
31
|
+
- `OPENAI_API_KEY` or a Codex login for Codex
|
|
32
|
+
- `GOOGLE_GENERATIVE_AI_API_KEY` or `GOOGLE_API_KEY` for Gemini CLI
|
|
33
|
+
|
|
34
|
+
The provider surface exposes the currently available frameworks and the preferred default. If the user does not specify a framework, the plugin picks the best available option automatically.
|
|
28
35
|
|
|
29
36
|
## Installation
|
|
30
37
|
|
|
@@ -43,47 +50,45 @@ The following peer dependencies will be installed automatically:
|
|
|
43
50
|
### Register the Plugin
|
|
44
51
|
|
|
45
52
|
```typescript
|
|
46
|
-
import
|
|
53
|
+
import taskAgentPlugin from "@elizaos/plugin-agent-orchestrator";
|
|
47
54
|
|
|
48
|
-
// Add to your Milady or
|
|
55
|
+
// Add to your Milady or elizaOS agent configuration
|
|
49
56
|
const agent = {
|
|
50
|
-
plugins: [
|
|
57
|
+
plugins: [taskAgentPlugin],
|
|
51
58
|
// ... other config
|
|
52
59
|
};
|
|
53
60
|
```
|
|
54
61
|
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
#### PTY Session Management
|
|
58
|
-
|
|
59
|
-
| Action | Description |
|
|
60
|
-
|--------|-------------|
|
|
61
|
-
| `SPAWN_CODING_AGENT` | Spawn a new coding agent session |
|
|
62
|
-
| `SEND_TO_CODING_AGENT` | Send input or keys to a running agent |
|
|
63
|
-
| `STOP_CODING_AGENT` | Terminate an agent session |
|
|
64
|
-
| `LIST_CODING_AGENTS` | List all active sessions |
|
|
62
|
+
`codingAgentPlugin` is still exported as a compatibility alias, but `taskAgentPlugin` is the canonical export.
|
|
65
63
|
|
|
66
|
-
|
|
64
|
+
### Canonical Actions
|
|
67
65
|
|
|
68
66
|
| Action | Description |
|
|
69
67
|
|--------|-------------|
|
|
68
|
+
| `CREATE_TASK` | Create an asynchronous task-agent job for substantial work |
|
|
69
|
+
| `SPAWN_AGENT` | Spawn a task agent session immediately |
|
|
70
|
+
| `SEND_TO_AGENT` | Send input or keys to a running task agent |
|
|
71
|
+
| `LIST_AGENTS` | List active sessions and current task status |
|
|
72
|
+
| `STOP_AGENT` | Terminate an agent session |
|
|
70
73
|
| `PROVISION_WORKSPACE` | Clone a repo or create a worktree |
|
|
71
74
|
| `FINALIZE_WORKSPACE` | Commit, push, and optionally create PR |
|
|
72
75
|
|
|
76
|
+
Legacy action names such as `START_CODING_TASK`, `SPAWN_CODING_AGENT`, `SEND_TO_CODING_AGENT`, `LIST_CODING_AGENTS`, and `STOP_CODING_AGENT` remain supported as aliases.
|
|
77
|
+
|
|
73
78
|
### Example Conversation
|
|
74
79
|
|
|
75
80
|
```
|
|
76
|
-
User:
|
|
77
|
-
Agent: Starting
|
|
81
|
+
User: This is bigger than a simple reply. Create a background task to inspect the repo, fix the auth bug, and open a PR.
|
|
82
|
+
Agent: Starting a task agent for the repo work...
|
|
78
83
|
Session ID: abc123, Status: running
|
|
79
84
|
|
|
80
|
-
User: What
|
|
81
|
-
Agent: Active
|
|
82
|
-
1.
|
|
85
|
+
User: What task agents are running?
|
|
86
|
+
Agent: Active task agents:
|
|
87
|
+
1. Claude Code (abc123...) - running
|
|
83
88
|
Working in: /workspace
|
|
84
89
|
|
|
85
90
|
User: Tell it to accept the changes
|
|
86
|
-
Agent: Sent "y" to
|
|
91
|
+
Agent: Sent "y" to the task agent.
|
|
87
92
|
|
|
88
93
|
User: Create a PR for the fix
|
|
89
94
|
Agent: Workspace finalized!
|
|
@@ -95,7 +100,7 @@ Agent: Workspace finalized!
|
|
|
95
100
|
|
|
96
101
|
### PTYService
|
|
97
102
|
|
|
98
|
-
Manages PTY sessions for
|
|
103
|
+
Manages PTY sessions for task agents.
|
|
99
104
|
|
|
100
105
|
```typescript
|
|
101
106
|
import { PTYService } from "@elizaos/plugin-agent-orchestrator";
|
|
@@ -105,7 +110,7 @@ const ptyService = runtime.getService("PTY_SERVICE") as PTYService;
|
|
|
105
110
|
|
|
106
111
|
// Spawn a session
|
|
107
112
|
const session = await ptyService.spawnSession({
|
|
108
|
-
agentType: "claude
|
|
113
|
+
agentType: "claude",
|
|
109
114
|
workdir: "/path/to/project",
|
|
110
115
|
initialTask: "Fix the auth bug",
|
|
111
116
|
});
|
|
@@ -123,7 +128,7 @@ await ptyService.stopSession(session.id);
|
|
|
123
128
|
|
|
124
129
|
### CodingWorkspaceService
|
|
125
130
|
|
|
126
|
-
Manages git workspaces for
|
|
131
|
+
Manages git workspaces for task-agent jobs.
|
|
127
132
|
|
|
128
133
|
```typescript
|
|
129
134
|
import { CodingWorkspaceService } from "@elizaos/plugin-agent-orchestrator";
|
|
@@ -160,7 +165,7 @@ const pr = await workspaceService.createPR(workspace.id, {
|
|
|
160
165
|
|
|
161
166
|
## Configuration
|
|
162
167
|
|
|
163
|
-
Configure via runtime settings:
|
|
168
|
+
Configure via runtime settings and Milady config:
|
|
164
169
|
|
|
165
170
|
```typescript
|
|
166
171
|
// PTY Service config
|
|
@@ -178,8 +183,44 @@ runtime.setSetting("CODING_WORKSPACE_CONFIG", {
|
|
|
178
183
|
},
|
|
179
184
|
debug: true,
|
|
180
185
|
});
|
|
186
|
+
|
|
187
|
+
// Optional fixed default when you do not want auto-selection
|
|
188
|
+
runtime.setSetting("PARALLAX_DEFAULT_AGENT_TYPE", "codex");
|
|
189
|
+
|
|
190
|
+
// Selection strategy: "heuristic" | "fixed"
|
|
191
|
+
runtime.setSetting("PARALLAX_AGENT_SELECTION_STRATEGY", "heuristic");
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
To bias the preferred framework toward the user's paid subscription, Milady can store a provider hint in `~/.milady/milady.json`:
|
|
195
|
+
|
|
196
|
+
```json
|
|
197
|
+
{
|
|
198
|
+
"agents": {
|
|
199
|
+
"defaults": {
|
|
200
|
+
"subscriptionProvider": "anthropic-subscription"
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
181
204
|
```
|
|
182
205
|
|
|
206
|
+
Supported subscription hints currently include Anthropic and OpenAI-backed flows, which map to Claude Code and Codex when those CLIs are installed and authenticated.
|
|
207
|
+
|
|
208
|
+
## Testing
|
|
209
|
+
|
|
210
|
+
Run the standard suite:
|
|
211
|
+
|
|
212
|
+
```bash
|
|
213
|
+
bun test
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
Run the opt-in live smoke tests against real Claude Code and Codex sessions:
|
|
217
|
+
|
|
218
|
+
```bash
|
|
219
|
+
bun run test:live
|
|
220
|
+
```
|
|
221
|
+
|
|
222
|
+
The live suite creates a temporary workspace, asks the real CLI to complete a small file-writing task, and verifies both task execution and task-status visibility.
|
|
223
|
+
|
|
183
224
|
## Dependencies
|
|
184
225
|
|
|
185
226
|
- `pty-manager` - PTY session management with stall detection and auto-response
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"coding-task-handlers.d.ts","sourceRoot":"","sources":["../../src/actions/coding-task-handlers.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,eAAe,EACpB,KAAK,aAAa,EAElB,KAAK,MAAM,EAEX,KAAK,KAAK,EACX,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,gBAAgB,EAAkB,MAAM,uBAAuB,CAAC;AAC9E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAE7D,OAAO,EACL,KAAK,eAAe,EAKrB,MAAM,0BAA0B,CAAC;
|
|
1
|
+
{"version":3,"file":"coding-task-handlers.d.ts","sourceRoot":"","sources":["../../src/actions/coding-task-handlers.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,eAAe,EACpB,KAAK,aAAa,EAElB,KAAK,MAAM,EAEX,KAAK,KAAK,EACX,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,gBAAgB,EAAkB,MAAM,uBAAuB,CAAC;AAC9E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAE7D,OAAO,EACL,KAAK,eAAe,EAKrB,MAAM,0BAA0B,CAAC;AAElC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AAoI7E,0EAA0E;AAC1E,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,aAAa,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;IACvB,SAAS,EAAE,sBAAsB,GAAG,SAAS,CAAC;IAC9C,WAAW,EAAE,gBAAgB,CAAC;IAC9B,iBAAiB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC;IACtD,QAAQ,EAAE,eAAe,GAAG,SAAS,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,KAAK,GAAG,SAAS,CAAC;IACzB,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IACzB,gBAAgB,EAAE,eAAe,CAAC;IAClC,YAAY,EAAE,MAAM,CAAC;IACrB,sBAAsB,EAAE,sBAAsB,CAAC;IAC/C,aAAa,EAAE,MAAM,GAAG,SAAS,CAAC;IAClC,cAAc,EAAE,MAAM,GAAG,SAAS,CAAC;IACnC,aAAa,EAAE,MAAM,GAAG,SAAS,CAAC;CACnC;AAED;;;;;GAKG;AACH,wBAAsB,gBAAgB,CACpC,GAAG,EAAE,iBAAiB,EACtB,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC,CAyTnC"}
|
|
@@ -8,7 +8,17 @@
|
|
|
8
8
|
* @module actions/coding-task-helpers
|
|
9
9
|
*/
|
|
10
10
|
import { type HandlerCallback, type IAgentRuntime } from "@elizaos/core";
|
|
11
|
+
import type { AgentCredentials } from "coding-agent-adapters";
|
|
11
12
|
import type { PTYService } from "../services/pty-service.js";
|
|
13
|
+
/**
|
|
14
|
+
* Build agent credentials based on the user's configured LLM provider.
|
|
15
|
+
*
|
|
16
|
+
* - subscription/api_keys: reads provider-specific API keys from runtime settings
|
|
17
|
+
* - cloud: reads `cloud.apiKey` from milady.json and routes via Eliza Cloud base URLs.
|
|
18
|
+
* Note: Eliza Cloud does NOT proxy Google/Gemini, so `googleKey` is left undefined.
|
|
19
|
+
* Throws if cloud mode is selected but no cloud API key is paired.
|
|
20
|
+
*/
|
|
21
|
+
export declare function buildAgentCredentials(runtime: IAgentRuntime): AgentCredentials;
|
|
12
22
|
/**
|
|
13
23
|
* Create a scratch sandbox directory for non-repo tasks.
|
|
14
24
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"coding-task-helpers.d.ts","sourceRoot":"","sources":["../../src/actions/coding-task-helpers.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAMH,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,aAAa,EAEnB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"coding-task-helpers.d.ts","sourceRoot":"","sources":["../../src/actions/coding-task-helpers.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAMH,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,aAAa,EAEnB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAE9D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAU7D;;;;;;;GAOG;AACH,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,aAAa,GACrB,gBAAgB,CAuClB;AA6BD;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAC9B,OAAO,CAAC,EAAE,aAAa,EACvB,KAAK,CAAC,EAAE,MAAM,GACb,MAAM,CA0BR;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAC3B,IAAI,EAAE,MAAM,GAAG,SAAS,EACxB,IAAI,EAAE,MAAM,GAAG,SAAS,GACvB,MAAM,CA4BR;AAED;;;;;;GAMG;AACH,wBAAgB,qBAAqB,CACnC,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,aAAa,EACtB,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,MAAM,EACb,UAAU,EAAE,MAAM,GAAG,IAAI,EACzB,QAAQ,CAAC,EAAE,eAAe,EAC1B,iBAAiB,UAAQ,GACxB,IAAI,CAsEN"}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* LIST_AGENTS action - List active task-agent sessions and task progress.
|
|
3
3
|
*
|
|
4
|
-
* Returns information about
|
|
5
|
-
*
|
|
4
|
+
* Returns information about running PTY sessions together with the current
|
|
5
|
+
* coordinator task state so the main agent can keep the user updated while
|
|
6
|
+
* background work continues.
|
|
6
7
|
*
|
|
7
8
|
* @module actions/list-agents
|
|
8
9
|
*/
|
|
9
10
|
import type { Action } from "@elizaos/core";
|
|
10
11
|
export declare const listAgentsAction: Action;
|
|
12
|
+
export declare const listTaskAgentsAction: Action;
|
|
11
13
|
//# sourceMappingURL=list-agents.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"list-agents.d.ts","sourceRoot":"","sources":["../../src/actions/list-agents.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"list-agents.d.ts","sourceRoot":"","sources":["../../src/actions/list-agents.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EACV,MAAM,EAOP,MAAM,eAAe,CAAC;AAgCvB,eAAO,MAAM,gBAAgB,EAAE,MAqL9B,CAAC;AAEF,eAAO,MAAM,oBAAoB,QAAmB,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* SEND_TO_AGENT action - Send input to a running task agent.
|
|
3
3
|
*
|
|
4
4
|
* Allows sending text or commands to an active PTY session.
|
|
5
5
|
* Useful for responding to prompts, providing feedback, or giving new instructions.
|
|
@@ -8,4 +8,5 @@
|
|
|
8
8
|
*/
|
|
9
9
|
import type { Action } from "@elizaos/core";
|
|
10
10
|
export declare const sendToAgentAction: Action;
|
|
11
|
+
export declare const sendToTaskAgentAction: Action;
|
|
11
12
|
//# sourceMappingURL=send-to-agent.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"send-to-agent.d.ts","sourceRoot":"","sources":["../../src/actions/send-to-agent.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EACV,MAAM,EAOP,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"send-to-agent.d.ts","sourceRoot":"","sources":["../../src/actions/send-to-agent.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EACV,MAAM,EAOP,MAAM,eAAe,CAAC;AAKvB,eAAO,MAAM,iBAAiB,EAAE,MAkR/B,CAAC;AAEF,eAAO,MAAM,qBAAqB,QAAoB,CAAC"}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* SPAWN_AGENT action - Spawns a CLI task agent.
|
|
3
3
|
*
|
|
4
|
-
* Creates a new PTY session for a
|
|
4
|
+
* Creates a new PTY session for a task agent (Claude Code, Codex, etc.)
|
|
5
5
|
* and returns a session ID for subsequent interactions.
|
|
6
6
|
*
|
|
7
7
|
* @module actions/spawn-agent
|
|
8
8
|
*/
|
|
9
9
|
import { type Action } from "@elizaos/core";
|
|
10
10
|
export declare const spawnAgentAction: Action;
|
|
11
|
+
export declare const spawnTaskAgentAction: Action;
|
|
11
12
|
//# sourceMappingURL=spawn-agent.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spawn-agent.d.ts","sourceRoot":"","sources":["../../src/actions/spawn-agent.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,EACL,KAAK,MAAM,EAQZ,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"spawn-agent.d.ts","sourceRoot":"","sources":["../../src/actions/spawn-agent.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,EACL,KAAK,MAAM,EAQZ,MAAM,eAAe,CAAC;AAevB,eAAO,MAAM,gBAAgB,EAAE,MAsX9B,CAAC;AAEF,eAAO,MAAM,oBAAoB,QAAmB,CAAC"}
|
|
@@ -1,17 +1,18 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* CREATE_TASK action - Unified action to set up and launch task agents.
|
|
3
3
|
*
|
|
4
4
|
* Combines workspace provisioning and agent spawning into a single atomic action.
|
|
5
5
|
* - If a repo URL is provided, clones it into a fresh workspace
|
|
6
6
|
* - If no repo, creates a scratch sandbox directory
|
|
7
|
-
* - Spawns the specified
|
|
7
|
+
* - Spawns the specified task agent(s) in that workspace with the given task
|
|
8
8
|
* - Supports multi-agent mode via pipe-delimited `agents` param
|
|
9
9
|
*
|
|
10
|
-
* This eliminates the need for multi-action chaining (PROVISION_WORKSPACE ->
|
|
10
|
+
* This eliminates the need for multi-action chaining (PROVISION_WORKSPACE -> SPAWN_AGENT)
|
|
11
11
|
* and ensures agents always run in an isolated directory.
|
|
12
12
|
*
|
|
13
13
|
* @module actions/start-coding-task
|
|
14
14
|
*/
|
|
15
|
-
import type
|
|
15
|
+
import { type Action } from "@elizaos/core";
|
|
16
16
|
export declare const startCodingTaskAction: Action;
|
|
17
|
+
export declare const createTaskAction: Action;
|
|
17
18
|
//# sourceMappingURL=start-coding-task.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"start-coding-task.d.ts","sourceRoot":"","sources":["../../src/actions/start-coding-task.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"start-coding-task.d.ts","sourceRoot":"","sources":["../../src/actions/start-coding-task.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,EACL,KAAK,MAAM,EAQZ,MAAM,eAAe,CAAC;AAavB,eAAO,MAAM,qBAAqB,EAAE,MA4RnC,CAAC;AAEF,eAAO,MAAM,gBAAgB,QAAwB,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* STOP_AGENT action - Stop a running task-agent session.
|
|
3
3
|
*
|
|
4
4
|
* Terminates an active PTY session. Use when the agent is done,
|
|
5
5
|
* stuck, or needs to be cancelled.
|
|
@@ -8,4 +8,5 @@
|
|
|
8
8
|
*/
|
|
9
9
|
import { type Action } from "@elizaos/core";
|
|
10
10
|
export declare const stopAgentAction: Action;
|
|
11
|
+
export declare const stopTaskAgentAction: Action;
|
|
11
12
|
//# sourceMappingURL=stop-agent.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stop-agent.d.ts","sourceRoot":"","sources":["../../src/actions/stop-agent.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EACL,KAAK,MAAM,EAQZ,MAAM,eAAe,CAAC;AAGvB,eAAO,MAAM,eAAe,EAAE,
|
|
1
|
+
{"version":3,"file":"stop-agent.d.ts","sourceRoot":"","sources":["../../src/actions/stop-agent.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EACL,KAAK,MAAM,EAQZ,MAAM,eAAe,CAAC;AAGvB,eAAO,MAAM,eAAe,EAAE,MAgN7B,CAAC;AAEF,eAAO,MAAM,mBAAmB,QAAkB,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* Task Agent Route Handlers
|
|
3
3
|
*
|
|
4
|
-
* Handles routes for PTY-based
|
|
4
|
+
* Handles routes for PTY-based task-agent management:
|
|
5
5
|
* - Preflight checks, metrics, workspace files
|
|
6
6
|
* - Approval presets and config
|
|
7
7
|
* - Agent CRUD: list, spawn, get, send, stop, output
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
import type { IncomingMessage, ServerResponse } from "node:http";
|
|
12
12
|
import type { RouteContext } from "./routes.js";
|
|
13
13
|
/**
|
|
14
|
-
* Handle
|
|
14
|
+
* Handle task-agent routes (/api/coding-agents/*)
|
|
15
15
|
* Returns true if the route was handled, false otherwise
|
|
16
16
|
*/
|
|
17
17
|
export declare function handleAgentRoutes(req: IncomingMessage, res: ServerResponse, pathname: string, ctx: RouteContext): Promise<boolean>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agent-routes.d.ts","sourceRoot":"","sources":["../../src/api/agent-routes.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"agent-routes.d.ts","sourceRoot":"","sources":["../../src/api/agent-routes.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAcjE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAiMhD;;;GAGG;AACH,wBAAsB,iBAAiB,CACrC,GAAG,EAAE,eAAe,EACpB,GAAG,EAAE,cAAc,EACnB,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,YAAY,GAChB,OAAO,CAAC,OAAO,CAAC,CAumBlB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"coordinator-routes.d.ts","sourceRoot":"","sources":["../../src/api/coordinator-routes.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;
|
|
1
|
+
{"version":3,"file":"coordinator-routes.d.ts","sourceRoot":"","sources":["../../src/api/coordinator-routes.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAGzE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAahD;;;GAGG;AACH,wBAAsB,uBAAuB,CAC3C,GAAG,EAAE,eAAe,EACpB,GAAG,EAAE,cAAc,EACnB,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,YAAY,GAAG;IAAE,WAAW,CAAC,EAAE,gBAAgB,CAAA;CAAE,GACrD,OAAO,CAAC,OAAO,CAAC,CAgRlB"}
|
package/dist/api/routes.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* Task Agent API Routes — Dispatcher
|
|
3
3
|
*
|
|
4
4
|
* Provides shared helpers (parseBody, sendJson, sendError), types, and the
|
|
5
5
|
* top-level route dispatcher that delegates to domain-specific route modules.
|
|
@@ -25,7 +25,7 @@ export declare function parseBody(req: IncomingMessage): Promise<Record<string,
|
|
|
25
25
|
export declare function sendJson(res: ServerResponse, data: JsonValue, status?: number): void;
|
|
26
26
|
export declare function sendError(res: ServerResponse, message: string, status?: number): void;
|
|
27
27
|
/**
|
|
28
|
-
* Handle
|
|
28
|
+
* Handle task-agent routes
|
|
29
29
|
* Returns true if the route was handled, false otherwise
|
|
30
30
|
*/
|
|
31
31
|
export declare function handleCodingAgentRoutes(req: IncomingMessage, res: ServerResponse, pathname: string, ctx: RouteContext): Promise<boolean>;
|
|
@@ -33,4 +33,5 @@ export declare function handleCodingAgentRoutes(req: IncomingMessage, res: Serve
|
|
|
33
33
|
* Create route handler with services from runtime
|
|
34
34
|
*/
|
|
35
35
|
export declare function createCodingAgentRouteHandler(runtime: IAgentRuntime, coordinator?: SwarmCoordinator): (req: IncomingMessage, res: ServerResponse, pathname: string) => Promise<boolean>;
|
|
36
|
+
export declare const createTaskAgentRouteHandler: typeof createCodingAgentRouteHandler;
|
|
36
37
|
//# sourceMappingURL=routes.d.ts.map
|
package/dist/api/routes.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"routes.d.ts","sourceRoot":"","sources":["../../src/api/routes.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACzE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAO/E,MAAM,MAAM,SAAS,GACjB,MAAM,GACN,MAAM,GACN,OAAO,GACP,IAAI,GACJ,SAAS,EAAE,GACX;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAA;CAAE,CAAC;AAEjC,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,aAAa,CAAC;IACvB,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC;IAC9B,gBAAgB,EAAE,sBAAsB,GAAG,IAAI,CAAC;IAChD,WAAW,CAAC,EAAE,gBAAgB,CAAC;CAChC;AAGD,eAAO,MAAM,aAAa,QAAc,CAAC;AAGzC,wBAAsB,SAAS,CAC7B,GAAG,EAAE,eAAe,GACnB,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAsBlC;AAGD,wBAAgB,QAAQ,CACtB,GAAG,EAAE,cAAc,EACnB,IAAI,EAAE,SAAS,EACf,MAAM,SAAM,GACX,IAAI,CAGN;AAGD,wBAAgB,SAAS,CACvB,GAAG,EAAE,cAAc,EACnB,OAAO,EAAE,MAAM,EACf,MAAM,SAAM,GACX,IAAI,CAEN;AAED;;;GAGG;AACH,wBAAsB,uBAAuB,CAC3C,GAAG,EAAE,eAAe,EACpB,GAAG,EAAE,cAAc,EACnB,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,YAAY,GAChB,OAAO,CAAC,OAAO,CAAC,
|
|
1
|
+
{"version":3,"file":"routes.d.ts","sourceRoot":"","sources":["../../src/api/routes.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACzE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAO/E,MAAM,MAAM,SAAS,GACjB,MAAM,GACN,MAAM,GACN,OAAO,GACP,IAAI,GACJ,SAAS,EAAE,GACX;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAA;CAAE,CAAC;AAEjC,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,aAAa,CAAC;IACvB,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC;IAC9B,gBAAgB,EAAE,sBAAsB,GAAG,IAAI,CAAC;IAChD,WAAW,CAAC,EAAE,gBAAgB,CAAC;CAChC;AAGD,eAAO,MAAM,aAAa,QAAc,CAAC;AAGzC,wBAAsB,SAAS,CAC7B,GAAG,EAAE,eAAe,GACnB,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAsBlC;AAGD,wBAAgB,QAAQ,CACtB,GAAG,EAAE,cAAc,EACnB,IAAI,EAAE,SAAS,EACf,MAAM,SAAM,GACX,IAAI,CAGN;AAGD,wBAAgB,SAAS,CACvB,GAAG,EAAE,cAAc,EACnB,OAAO,EAAE,MAAM,EACf,MAAM,SAAM,GACX,IAAI,CAEN;AAED;;;GAGG;AACH,wBAAsB,uBAAuB,CAC3C,GAAG,EAAE,eAAe,EACpB,GAAG,EAAE,cAAc,EACnB,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,YAAY,GAChB,OAAO,CAAC,OAAO,CAAC,CAgClB;AAED;;GAEG;AACH,wBAAgB,6BAA6B,CAC3C,OAAO,EAAE,aAAa,EACtB,WAAW,CAAC,EAAE,gBAAgB,IAEtB,KAAK,eAAe,EAAE,KAAK,cAAc,EAAE,UAAU,MAAM,sBAiBpE;AAED,eAAO,MAAM,2BAA2B,sCAAgC,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* Task Agent Plugin for Milady
|
|
3
3
|
*
|
|
4
|
-
* Provides orchestration capabilities for CLI-based
|
|
5
|
-
* - PTY session management (spawn, control, monitor
|
|
4
|
+
* Provides orchestration capabilities for CLI-based task agents:
|
|
5
|
+
* - PTY session management (spawn, control, monitor task agents)
|
|
6
6
|
* - Git workspace provisioning (clone, branch, PR creation)
|
|
7
7
|
* - GitHub issue management (create, list, update, close)
|
|
8
8
|
* - Integration with Claude Code, Codex, Gemini CLI, Aider, Pi, etc.
|
|
@@ -10,8 +10,9 @@
|
|
|
10
10
|
* @module @elizaos/plugin-agent-orchestrator
|
|
11
11
|
*/
|
|
12
12
|
import type { Plugin } from "@elizaos/core";
|
|
13
|
+
export declare const taskAgentPlugin: Plugin;
|
|
13
14
|
export declare const codingAgentPlugin: Plugin;
|
|
14
|
-
export default
|
|
15
|
+
export default taskAgentPlugin;
|
|
15
16
|
export type { AdapterType, AgentCredentials, AgentFileDescriptor, ApprovalConfig, ApprovalPreset, PreflightResult, PresetDefinition, RiskLevel, ToolCategory, WriteMemoryOptions, } from "coding-agent-adapters";
|
|
16
17
|
export { finalizeWorkspaceAction } from "./actions/finalize-workspace.js";
|
|
17
18
|
export { listAgentsAction } from "./actions/list-agents.js";
|
|
@@ -19,9 +20,14 @@ export { manageIssuesAction } from "./actions/manage-issues.js";
|
|
|
19
20
|
export { provisionWorkspaceAction } from "./actions/provision-workspace.js";
|
|
20
21
|
export { sendToAgentAction } from "./actions/send-to-agent.js";
|
|
21
22
|
export { spawnAgentAction } from "./actions/spawn-agent.js";
|
|
23
|
+
export { createTaskAction } from "./actions/start-coding-task.js";
|
|
24
|
+
export { listTaskAgentsAction } from "./actions/list-agents.js";
|
|
25
|
+
export { sendToTaskAgentAction } from "./actions/send-to-agent.js";
|
|
26
|
+
export { spawnTaskAgentAction } from "./actions/spawn-agent.js";
|
|
22
27
|
export { startCodingTaskAction } from "./actions/start-coding-task.js";
|
|
23
28
|
export { stopAgentAction } from "./actions/stop-agent.js";
|
|
24
|
-
export {
|
|
29
|
+
export { stopTaskAgentAction } from "./actions/stop-agent.js";
|
|
30
|
+
export { createCodingAgentRouteHandler, createTaskAgentRouteHandler, handleCodingAgentRoutes, } from "./api/routes.js";
|
|
25
31
|
export type { CodingAgentType, PTYServiceConfig, SessionEventName, SessionInfo, SpawnSessionOptions, } from "./services/pty-service.js";
|
|
26
32
|
export { getCoordinator, PTYService } from "./services/pty-service.js";
|
|
27
33
|
export type { AgentDecisionCallback, ChatMessageCallback, CoordinationDecision, PendingDecision, SupervisionLevel, SwarmCompleteCallback, SwarmEvent, TaskCompletionSummary, TaskContext, WsBroadcastCallback, } from "./services/swarm-coordinator.js";
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAoB5C,eAAO,MAAM,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAoB5C,eAAO,MAAM,eAAe,EAAE,MAsC7B,CAAC;AAEF,eAAO,MAAM,iBAAiB,QAAkB,CAAC;AAEjD,eAAe,eAAe,CAAC;AAG/B,YAAY,EACV,WAAW,EACX,gBAAgB,EAChB,mBAAmB,EACnB,cAAc,EACd,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,SAAS,EACT,YAAY,EACZ,kBAAkB,GACnB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAC5E,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAEhE,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,uBAAuB,GACxB,MAAM,iBAAiB,CAAC;AAEzB,YAAY,EACV,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,WAAW,EACX,mBAAmB,GACpB,MAAM,2BAA2B,CAAC;AAEnC,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvE,YAAY,EACV,qBAAqB,EACrB,mBAAmB,EACnB,oBAAoB,EACpB,eAAe,EACf,gBAAgB,EAChB,qBAAqB,EACrB,UAAU,EACV,qBAAqB,EACrB,WAAW,EACX,mBAAmB,GACpB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,YAAY,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,yCAAyC,CAAC;AACvG,OAAO,EACL,wBAAwB,EACxB,6BAA6B,GAC9B,MAAM,yCAAyC,CAAC;AACjD,YAAY,EACV,kBAAkB,EAClB,qBAAqB,EACrB,aAAa,EACb,yBAAyB,EACzB,WAAW,EACX,eAAe,GAChB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC"}
|