@agentuity/core 2.0.7 → 2.0.9-v3.48d5810
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/dist/services/coder/agents.d.ts +172 -0
- package/dist/services/coder/agents.d.ts.map +1 -0
- package/dist/services/coder/agents.js +77 -0
- package/dist/services/coder/agents.js.map +1 -0
- package/dist/services/coder/api-reference.d.ts +4 -0
- package/dist/services/coder/api-reference.d.ts.map +1 -0
- package/dist/services/coder/api-reference.js +551 -0
- package/dist/services/coder/api-reference.js.map +1 -0
- package/dist/services/coder/client.d.ts +170 -0
- package/dist/services/coder/client.d.ts.map +1 -0
- package/dist/services/coder/client.js +351 -0
- package/dist/services/coder/client.js.map +1 -0
- package/dist/services/coder/close-codes.d.ts +76 -0
- package/dist/services/coder/close-codes.d.ts.map +1 -0
- package/dist/services/coder/close-codes.js +77 -0
- package/dist/services/coder/close-codes.js.map +1 -0
- package/dist/services/coder/discover.d.ts +13 -0
- package/dist/services/coder/discover.d.ts.map +1 -0
- package/dist/services/coder/discover.js +18 -0
- package/dist/services/coder/discover.js.map +1 -0
- package/dist/services/coder/github.d.ts +13 -0
- package/dist/services/coder/github.d.ts.map +1 -0
- package/dist/services/coder/github.js +15 -0
- package/dist/services/coder/github.js.map +1 -0
- package/dist/services/coder/index.d.ts +26 -0
- package/dist/services/coder/index.d.ts.map +1 -0
- package/dist/services/coder/index.js +18 -0
- package/dist/services/coder/index.js.map +1 -0
- package/dist/services/coder/loop-state.d.ts +10 -0
- package/dist/services/coder/loop-state.d.ts.map +1 -0
- package/dist/services/coder/loop-state.js +13 -0
- package/dist/services/coder/loop-state.js.map +1 -0
- package/dist/services/coder/protocol.d.ts +1855 -0
- package/dist/services/coder/protocol.d.ts.map +1 -0
- package/dist/services/coder/protocol.js +976 -0
- package/dist/services/coder/protocol.js.map +1 -0
- package/dist/services/coder/session-data.d.ts +28 -0
- package/dist/services/coder/session-data.d.ts.map +1 -0
- package/dist/services/coder/session-data.js +28 -0
- package/dist/services/coder/session-data.js.map +1 -0
- package/dist/services/coder/sessions.d.ts +164 -0
- package/dist/services/coder/sessions.d.ts.map +1 -0
- package/dist/services/coder/sessions.js +149 -0
- package/dist/services/coder/sessions.js.map +1 -0
- package/dist/services/coder/skills.d.ts +17 -0
- package/dist/services/coder/skills.d.ts.map +1 -0
- package/dist/services/coder/skills.js +43 -0
- package/dist/services/coder/skills.js.map +1 -0
- package/dist/services/coder/sse.d.ts +255 -0
- package/dist/services/coder/sse.d.ts.map +1 -0
- package/dist/services/coder/sse.js +676 -0
- package/dist/services/coder/sse.js.map +1 -0
- package/dist/services/coder/types.d.ts +2090 -0
- package/dist/services/coder/types.d.ts.map +1 -0
- package/dist/services/coder/types.js +802 -0
- package/dist/services/coder/types.js.map +1 -0
- package/dist/services/coder/users.d.ts +12 -0
- package/dist/services/coder/users.d.ts.map +1 -0
- package/dist/services/coder/users.js +35 -0
- package/dist/services/coder/users.js.map +1 -0
- package/dist/services/coder/util.d.ts +82 -0
- package/dist/services/coder/util.d.ts.map +1 -0
- package/dist/services/coder/util.js +60 -0
- package/dist/services/coder/util.js.map +1 -0
- package/dist/services/coder/websocket.d.ts +346 -0
- package/dist/services/coder/websocket.d.ts.map +1 -0
- package/dist/services/coder/websocket.js +791 -0
- package/dist/services/coder/websocket.js.map +1 -0
- package/dist/services/coder/workspaces.d.ts +13 -0
- package/dist/services/coder/workspaces.d.ts.map +1 -0
- package/dist/services/coder/workspaces.js +37 -0
- package/dist/services/coder/workspaces.js.map +1 -0
- package/dist/services/index.d.ts +1 -0
- package/dist/services/index.d.ts.map +1 -1
- package/dist/services/index.js +1 -0
- package/dist/services/index.js.map +1 -1
- package/dist/services/oauth/types.d.ts +11 -0
- package/dist/services/oauth/types.d.ts.map +1 -1
- package/dist/services/oauth/types.js +4 -0
- package/dist/services/oauth/types.js.map +1 -1
- package/dist/services/project/deploy.d.ts +57 -6
- package/dist/services/project/deploy.d.ts.map +1 -1
- package/dist/services/project/deploy.js +39 -4
- package/dist/services/project/deploy.js.map +1 -1
- package/dist/services/queue/service.d.ts +28 -0
- package/dist/services/queue/service.d.ts.map +1 -1
- package/dist/services/queue/service.js +54 -9
- package/dist/services/queue/service.js.map +1 -1
- package/dist/services/sandbox/cli-list.d.ts +1 -1
- package/dist/services/sandbox/client.d.ts +10 -4
- package/dist/services/sandbox/client.d.ts.map +1 -1
- package/dist/services/sandbox/client.js +2 -2
- package/dist/services/sandbox/client.js.map +1 -1
- package/dist/services/sandbox/create.d.ts +2 -2
- package/dist/services/sandbox/execute.d.ts +2 -2
- package/dist/services/sandbox/execution.d.ts +4 -4
- package/dist/services/sandbox/files.d.ts +10 -2
- package/dist/services/sandbox/files.d.ts.map +1 -1
- package/dist/services/sandbox/files.js +14 -0
- package/dist/services/sandbox/files.js.map +1 -1
- package/dist/services/sandbox/get.d.ts +2 -2
- package/dist/services/sandbox/list.d.ts +4 -4
- package/dist/services/sandbox/run.d.ts +3 -3
- package/dist/services/sandbox/types.d.ts +20 -12
- package/dist/services/sandbox/types.d.ts.map +1 -1
- package/dist/services/sandbox/types.js +4 -4
- package/dist/services/sandbox/types.js.map +1 -1
- package/dist/services/session/events.d.ts +2 -2
- package/dist/services/workflow/types.d.ts +8 -8
- package/package.json +280 -100
- package/src/services/coder/agents.ts +148 -0
- package/src/services/coder/api-reference.ts +573 -0
- package/src/services/coder/client.ts +509 -0
- package/src/services/coder/close-codes.ts +83 -0
- package/src/services/coder/discover.ts +23 -0
- package/src/services/coder/github.ts +33 -0
- package/src/services/coder/index.ts +100 -0
- package/src/services/coder/loop-state.ts +19 -0
- package/src/services/coder/protocol.ts +1200 -0
- package/src/services/coder/session-data.ts +63 -0
- package/src/services/coder/sessions.ts +267 -0
- package/src/services/coder/skills.ts +102 -0
- package/src/services/coder/sse.ts +796 -0
- package/src/services/coder/types.ts +935 -0
- package/src/services/coder/users.ts +59 -0
- package/src/services/coder/util.ts +87 -0
- package/src/services/coder/websocket.ts +943 -0
- package/src/services/coder/workspaces.ts +77 -0
- package/src/services/index.ts +1 -0
- package/src/services/oauth/types.ts +4 -0
- package/src/services/project/deploy.ts +67 -26
- package/src/services/queue/service.ts +56 -13
- package/src/services/sandbox/client.ts +10 -8
- package/src/services/sandbox/files.ts +28 -2
- package/src/services/sandbox/types.ts +8 -6
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Server-Sent Events (SSE) client for observing Coder Hub sessions.
|
|
3
|
+
*
|
|
4
|
+
* SSE provides a unidirectional stream of events from the server, ideal for
|
|
5
|
+
* observers who want to watch session activity without sending commands.
|
|
6
|
+
*
|
|
7
|
+
* @module coder/sse
|
|
8
|
+
*
|
|
9
|
+
* @example Class-based API with callbacks
|
|
10
|
+
* ```typescript
|
|
11
|
+
* import { CoderSSEClient } from '@agentuity/core/coder';
|
|
12
|
+
*
|
|
13
|
+
* const client = new CoderSSEClient({
|
|
14
|
+
* apiKey: 'your-api-key',
|
|
15
|
+
* sessionId: 'session-123',
|
|
16
|
+
* onSnapshot: (data) => {
|
|
17
|
+
* console.log('Session state:', data);
|
|
18
|
+
* },
|
|
19
|
+
* onBroadcast: (data) => {
|
|
20
|
+
* console.log('Broadcast event:', data.event, data.data);
|
|
21
|
+
* },
|
|
22
|
+
* onPresence: (data) => {
|
|
23
|
+
* console.log('Participant:', data.event, data.participant);
|
|
24
|
+
* },
|
|
25
|
+
* onError: (err) => {
|
|
26
|
+
* console.error('SSE error:', err);
|
|
27
|
+
* },
|
|
28
|
+
* });
|
|
29
|
+
*
|
|
30
|
+
* client.connect();
|
|
31
|
+
*
|
|
32
|
+
* // Later: close the connection
|
|
33
|
+
* client.close();
|
|
34
|
+
* ```
|
|
35
|
+
*
|
|
36
|
+
* @example Async iterator API
|
|
37
|
+
* ```typescript
|
|
38
|
+
* import { streamCoderSessionSSE } from '@agentuity/core/coder';
|
|
39
|
+
*
|
|
40
|
+
* const controller = new AbortController();
|
|
41
|
+
*
|
|
42
|
+
* for await (const event of streamCoderSessionSSE({
|
|
43
|
+
* sessionId: 'session-123',
|
|
44
|
+
* signal: controller.signal,
|
|
45
|
+
* })) {
|
|
46
|
+
* console.log('Event:', event.event, event.data);
|
|
47
|
+
*
|
|
48
|
+
* if (event.event === 'broadcast' && event.data.event === 'session_complete') {
|
|
49
|
+
* controller.abort(); // Stop the stream
|
|
50
|
+
* }
|
|
51
|
+
* }
|
|
52
|
+
* ```
|
|
53
|
+
*/
|
|
54
|
+
import { z } from 'zod/v4';
|
|
55
|
+
import type { Logger } from '../../logger.ts';
|
|
56
|
+
import type { BroadcastEventMessage, ObserverSseMessage, PresenceEventMessage, SseHydrationMessage, SseSessionSnapshotMessage } from './protocol.ts';
|
|
57
|
+
/**
|
|
58
|
+
* Options for the SSE client (both class-based and async iterator APIs).
|
|
59
|
+
*/
|
|
60
|
+
export declare const CoderSSEOptionsSchema: z.ZodObject<{
|
|
61
|
+
apiKey: z.ZodOptional<z.ZodString>;
|
|
62
|
+
orgId: z.ZodOptional<z.ZodString>;
|
|
63
|
+
sessionId: z.ZodString;
|
|
64
|
+
url: z.ZodOptional<z.ZodString>;
|
|
65
|
+
region: z.ZodOptional<z.ZodString>;
|
|
66
|
+
subscribe: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
67
|
+
logger: z.ZodOptional<z.ZodCustom<Logger, Logger>>;
|
|
68
|
+
reconnect: z.ZodOptional<z.ZodBoolean>;
|
|
69
|
+
maxReconnectAttempts: z.ZodOptional<z.ZodNumber>;
|
|
70
|
+
reconnectDelayMs: z.ZodOptional<z.ZodNumber>;
|
|
71
|
+
maxReconnectDelayMs: z.ZodOptional<z.ZodNumber>;
|
|
72
|
+
signal: z.ZodOptional<z.ZodCustom<AbortSignal, AbortSignal>>;
|
|
73
|
+
}, z.core.$strip>;
|
|
74
|
+
export type CoderSSEOptions = z.infer<typeof CoderSSEOptionsSchema>;
|
|
75
|
+
/**
|
|
76
|
+
* Options for the class-based SSE client.
|
|
77
|
+
*
|
|
78
|
+
* Extends the base options with callbacks for each event type.
|
|
79
|
+
*/
|
|
80
|
+
export declare const CoderSSEClientOptionsSchema: z.ZodObject<{
|
|
81
|
+
apiKey: z.ZodOptional<z.ZodString>;
|
|
82
|
+
orgId: z.ZodOptional<z.ZodString>;
|
|
83
|
+
sessionId: z.ZodString;
|
|
84
|
+
url: z.ZodOptional<z.ZodString>;
|
|
85
|
+
region: z.ZodOptional<z.ZodString>;
|
|
86
|
+
subscribe: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
87
|
+
logger: z.ZodOptional<z.ZodCustom<Logger, Logger>>;
|
|
88
|
+
reconnect: z.ZodOptional<z.ZodBoolean>;
|
|
89
|
+
maxReconnectAttempts: z.ZodOptional<z.ZodNumber>;
|
|
90
|
+
reconnectDelayMs: z.ZodOptional<z.ZodNumber>;
|
|
91
|
+
maxReconnectDelayMs: z.ZodOptional<z.ZodNumber>;
|
|
92
|
+
signal: z.ZodOptional<z.ZodCustom<AbortSignal, AbortSignal>>;
|
|
93
|
+
onSnapshot: z.ZodOptional<z.ZodCustom<(data: SseSessionSnapshotMessage) => void, (data: SseSessionSnapshotMessage) => void>>;
|
|
94
|
+
onHydration: z.ZodOptional<z.ZodCustom<(data: SseHydrationMessage) => void, (data: SseHydrationMessage) => void>>;
|
|
95
|
+
onPresence: z.ZodOptional<z.ZodCustom<(data: PresenceEventMessage) => void, (data: PresenceEventMessage) => void>>;
|
|
96
|
+
onBroadcast: z.ZodOptional<z.ZodCustom<(data: BroadcastEventMessage) => void, (data: BroadcastEventMessage) => void>>;
|
|
97
|
+
onEvent: z.ZodOptional<z.ZodCustom<(event: CoderSSEEvent) => void, (event: CoderSSEEvent) => void>>;
|
|
98
|
+
onOpen: z.ZodOptional<z.ZodCustom<() => void, () => void>>;
|
|
99
|
+
onClose: z.ZodOptional<z.ZodCustom<() => void, () => void>>;
|
|
100
|
+
onError: z.ZodOptional<z.ZodCustom<(error: Error) => void, (error: Error) => void>>;
|
|
101
|
+
}, z.core.$strip>;
|
|
102
|
+
export type CoderSSEClientOptions = z.infer<typeof CoderSSEClientOptionsSchema>;
|
|
103
|
+
/**
|
|
104
|
+
* Error type for SSE operations.
|
|
105
|
+
*
|
|
106
|
+
* @example
|
|
107
|
+
* ```typescript
|
|
108
|
+
* try {
|
|
109
|
+
* for await (const event of streamCoderSessionSSE({ sessionId: 'invalid' })) {
|
|
110
|
+
* // ...
|
|
111
|
+
* }
|
|
112
|
+
* } catch (err) {
|
|
113
|
+
* if (err instanceof CoderSSEError) {
|
|
114
|
+
* console.log('SSE error code:', err.code);
|
|
115
|
+
* }
|
|
116
|
+
* }
|
|
117
|
+
* ```
|
|
118
|
+
*/
|
|
119
|
+
export declare const CoderSSEError: {
|
|
120
|
+
new (args?: ({
|
|
121
|
+
code: "connection_failed" | "auth_failed" | "max_reconnects_exceeded" | "parse_error";
|
|
122
|
+
sessionId?: string;
|
|
123
|
+
} & {
|
|
124
|
+
message?: string;
|
|
125
|
+
cause?: unknown;
|
|
126
|
+
}) | undefined): import("../../error.ts").RichError & {
|
|
127
|
+
readonly _tag: "CoderSSEError";
|
|
128
|
+
} & Readonly<{
|
|
129
|
+
code: "connection_failed" | "auth_failed" | "max_reconnects_exceeded" | "parse_error";
|
|
130
|
+
sessionId?: string;
|
|
131
|
+
}>;
|
|
132
|
+
readonly defaultMessage?: string;
|
|
133
|
+
};
|
|
134
|
+
/**
|
|
135
|
+
* A single SSE event with its event name and parsed data.
|
|
136
|
+
*/
|
|
137
|
+
export interface CoderSSEEvent {
|
|
138
|
+
/** The SSE event name (e.g., 'snapshot', 'broadcast', 'presence') */
|
|
139
|
+
event: string;
|
|
140
|
+
/** The parsed event data */
|
|
141
|
+
data: ObserverSseMessage;
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Connection state for the SSE client.
|
|
145
|
+
*/
|
|
146
|
+
export type CoderSSEState = 'connecting' | 'connected' | 'reconnecting' | 'closed';
|
|
147
|
+
/**
|
|
148
|
+
* Class-based SSE client for observing Coder Hub sessions.
|
|
149
|
+
*
|
|
150
|
+
* Provides callback-based event handling for session observation via Server-Sent Events.
|
|
151
|
+
* Automatically reconnects on disconnection with exponential backoff.
|
|
152
|
+
*
|
|
153
|
+
* @example
|
|
154
|
+
* ```typescript
|
|
155
|
+
* const client = new CoderSSEClient({
|
|
156
|
+
* apiKey: 'your-api-key',
|
|
157
|
+
* sessionId: 'session-123',
|
|
158
|
+
* onSnapshot: (data) => console.log('Snapshot:', data),
|
|
159
|
+
* onBroadcast: (data) => console.log('Broadcast:', data),
|
|
160
|
+
* onPresence: (data) => console.log('Presence:', data),
|
|
161
|
+
* });
|
|
162
|
+
*
|
|
163
|
+
* client.connect();
|
|
164
|
+
*
|
|
165
|
+
* // Check connection state
|
|
166
|
+
* console.log('State:', client.state);
|
|
167
|
+
* console.log('Connected:', client.isConnected);
|
|
168
|
+
*
|
|
169
|
+
* // Close when done
|
|
170
|
+
* client.close();
|
|
171
|
+
* ```
|
|
172
|
+
*/
|
|
173
|
+
export declare class CoderSSEClient {
|
|
174
|
+
#private;
|
|
175
|
+
constructor(options: CoderSSEClientOptions);
|
|
176
|
+
/**
|
|
177
|
+
* The current connection state.
|
|
178
|
+
*
|
|
179
|
+
* - `'connecting'` - Initial connection in progress
|
|
180
|
+
* - `'connected'` - Connected and receiving events
|
|
181
|
+
* - `'reconnecting'` - Reconnecting after disconnect
|
|
182
|
+
* - `'closed'` - Connection closed (manually or after max retries)
|
|
183
|
+
*/
|
|
184
|
+
get state(): CoderSSEState;
|
|
185
|
+
/**
|
|
186
|
+
* Whether the client is currently connected and receiving events.
|
|
187
|
+
*/
|
|
188
|
+
get isConnected(): boolean;
|
|
189
|
+
/**
|
|
190
|
+
* Establish the SSE connection and start receiving events.
|
|
191
|
+
*
|
|
192
|
+
* If already connected or connecting, this is a no-op.
|
|
193
|
+
* Automatically reconnects on disconnection unless `close()` was called.
|
|
194
|
+
*/
|
|
195
|
+
connect(): void;
|
|
196
|
+
/**
|
|
197
|
+
* Close the SSE connection and stop receiving events.
|
|
198
|
+
*
|
|
199
|
+
* After calling `close()`, you can call `connect()` again to reconnect.
|
|
200
|
+
*/
|
|
201
|
+
close(): void;
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Stream Coder Hub session events via Server-Sent Events (SSE).
|
|
205
|
+
*
|
|
206
|
+
* Returns an async iterator that yields events as they arrive from the server.
|
|
207
|
+
* The connection is automatically managed (reconnection, cleanup).
|
|
208
|
+
*
|
|
209
|
+
* @param options - Configuration for the SSE subscription
|
|
210
|
+
* @yields Events from the session as they arrive
|
|
211
|
+
* @throws {CoderSSEError} If connection fails or max reconnection attempts exceeded
|
|
212
|
+
*
|
|
213
|
+
* @example
|
|
214
|
+
* ```typescript
|
|
215
|
+
* import { streamCoderSessionSSE } from '@agentuity/core/coder';
|
|
216
|
+
*
|
|
217
|
+
* // Basic usage
|
|
218
|
+
* for await (const event of streamCoderSessionSSE({
|
|
219
|
+
* sessionId: 'session-123',
|
|
220
|
+
* })) {
|
|
221
|
+
* if (event.event === 'snapshot') {
|
|
222
|
+
* console.log('Session:', event.data.label);
|
|
223
|
+
* } else if (event.event === 'broadcast') {
|
|
224
|
+
* console.log('Event:', event.data.event);
|
|
225
|
+
* }
|
|
226
|
+
* }
|
|
227
|
+
* ```
|
|
228
|
+
*
|
|
229
|
+
* @example With abort signal
|
|
230
|
+
* ```typescript
|
|
231
|
+
* const controller = new AbortController();
|
|
232
|
+
*
|
|
233
|
+
* // Stop after 60 seconds
|
|
234
|
+
* setTimeout(() => controller.abort(), 60000);
|
|
235
|
+
*
|
|
236
|
+
* for await (const event of streamCoderSessionSSE({
|
|
237
|
+
* sessionId: 'session-123',
|
|
238
|
+
* signal: controller.signal,
|
|
239
|
+
* })) {
|
|
240
|
+
* console.log(event);
|
|
241
|
+
* }
|
|
242
|
+
* ```
|
|
243
|
+
*
|
|
244
|
+
* @example With event filtering
|
|
245
|
+
* ```typescript
|
|
246
|
+
* for await (const event of streamCoderSessionSSE({
|
|
247
|
+
* sessionId: 'session-123',
|
|
248
|
+
* subscribe: ['task_*', 'agent_*'], // Only task and agent events
|
|
249
|
+
* })) {
|
|
250
|
+
* console.log(event);
|
|
251
|
+
* }
|
|
252
|
+
* ```
|
|
253
|
+
*/
|
|
254
|
+
export declare function streamCoderSessionSSE(options: CoderSSEOptions): AsyncGenerator<CoderSSEEvent, void, unknown>;
|
|
255
|
+
//# sourceMappingURL=sse.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sse.d.ts","sourceRoot":"","sources":["../../../src/services/coder/sse.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoDG;AAEH,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAE3B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAM9C,OAAO,KAAK,EACX,qBAAqB,EACrB,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,EACnB,yBAAyB,EACzB,MAAM,eAAe,CAAC;AAIvB;;GAEG;AACH,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;iBAyBhC,CAAC;AACH,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC;AAEpE;;;;GAIG;AACH,eAAO,MAAM,2BAA2B;;;;;;;;;;;;;iDAGvB,yBAAyB,KAAK,IAAI,SAAlC,yBAAyB,KAAK,IAAI;kDAKlC,mBAAmB,KAAK,IAAI,SAA5B,mBAAmB,KAAK,IAAI;iDAK5B,oBAAoB,KAAK,IAAI,SAA7B,oBAAoB,KAAK,IAAI;kDAK7B,qBAAqB,KAAK,IAAI,SAA9B,qBAAqB,KAAK,IAAI;+CAK7B,aAAa,KAAK,IAAI,UAAtB,aAAa,KAAK,IAAI;4CAIhB,IAAI,QAAJ,IAAI;6CAEH,IAAI,QAAJ,IAAI;+CAEF,KAAK,KAAK,IAAI,UAAd,KAAK,KAAK,IAAI;iBACvC,CAAC;AACH,MAAM,MAAM,qBAAqB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,2BAA2B,CAAC,CAAC;AAEhF;;;;;;;;;;;;;;;GAeG;AACH,eAAO,MAAM,aAAa;;cACnB,mBAAmB,GAAG,aAAa,GAAG,yBAAyB,GAAG,aAAa;oBACzE,MAAM;;;;;;;cADZ,mBAAmB,GAAG,aAAa,GAAG,yBAAyB,GAAG,aAAa;oBACzE,MAAM;;;CACf,CAAC;AAEL;;GAEG;AACH,MAAM,WAAW,aAAa;IAC7B,qEAAqE;IACrE,KAAK,EAAE,MAAM,CAAC;IACd,4BAA4B;IAC5B,IAAI,EAAE,kBAAkB,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG,YAAY,GAAG,WAAW,GAAG,cAAc,GAAG,QAAQ,CAAC;AAmEnF;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,qBAAa,cAAc;;gBA4Bd,OAAO,EAAE,qBAAqB;IAwB1C;;;;;;;OAOG;IACH,IAAI,KAAK,IAAI,aAAa,CAEzB;IAED;;OAEG;IACH,IAAI,WAAW,IAAI,OAAO,CAEzB;IAED;;;;;OAKG;IACH,OAAO,IAAI,IAAI;IAaf;;;;OAIG;IACH,KAAK,IAAI,IAAI;CA0Kb;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkDG;AACH,wBAAuB,qBAAqB,CAC3C,OAAO,EAAE,eAAe,GACtB,cAAc,CAAC,aAAa,EAAE,IAAI,EAAE,OAAO,CAAC,CA6M9C"}
|